+};
+
+/* Creates a new Action from the name of the action
+ A few action types need data set after making this call still. Check if
+ the returned action's "func" is one of these.
+ action_execute - the path needs to be set
+ action_restart - the path can optionally be set
+ action_desktop - the destination desktop needs to be set
+ action_send_to_desktop - the destination desktop needs to be set
+ action_move_relative_horz - the delta
+ action_move_relative_vert - the delta
+ action_resize_relative_horz - the delta
+ action_resize_relative_vert - the delta
+ action_move_relative - the deltas
+ action_resize_relative - the deltas
+*/
+
+ObAction* action_from_string(const gchar *name, ObUserAction uact);
+ObAction* action_parse(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node,
+ ObUserAction uact);
+void action_ref(ObAction *a);
+void action_unref(ObAction *a);
+
+ObAction* action_copy(const ObAction *a);
+
+/*! Executes a list of actions.
+ @param c The client associated with the action. Can be NULL.
+ @param state The keyboard modifiers state at the time the user action occured
+ @param button The mouse button used to execute the action.
+ @param x The x coord at which the user action occured.
+ @param y The y coord at which the user action occured.
+ @param cancel If the action is cancelling an interactive action. This only
+ affects interactive actions, but should generally always be FALSE.
+ @param done If the action is completing an interactive action. This only
+ affects interactive actions, but should generally always be FALSE.
+*/
+void action_run_list(GSList *acts, struct _ObClient *c, ObFrameContext context,
+ guint state, guint button, gint x, gint y, Time time,
+ gboolean cancel, gboolean done);
+
+#define action_run_mouse(a, c, n, s, b, x, y, t) \
+ action_run_list(a, c, n, s, b, x, y, t, FALSE, FALSE)