X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;ds=sidebyside;f=openbox%2Faction.h;h=bce741a6c794ff437ef543bee9964a796ba38c91;hb=411cc1d1d9e0c7ad07fe6bce548ccf101a2f4c7a;hp=99983ee19fd61987513d0faef9be8fdc6623b07a;hpb=1213b079bb0d32dcb97c37b2b0f6fcb0c8b6eefc;p=chaz%2Fopenbox diff --git a/openbox/action.h b/openbox/action.h index 99983ee1..bce741a6 100644 --- a/openbox/action.h +++ b/openbox/action.h @@ -99,7 +99,7 @@ struct SendToDesktopDirection { }; struct Desktop { - struct AnyAction any; + struct InteractiveAction inter; guint desk; }; @@ -152,7 +152,8 @@ union ActionData { }; struct _ObAction { - ObUserAction act; + guint ref; + /* The func member acts like an enum to tell which one of the structs in the data union are valid. */ @@ -173,10 +174,13 @@ struct _ObAction { action_resize_relative_vert - the delta */ -ObAction *action_from_string(const gchar *name, ObUserAction uact); -ObAction *action_parse(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node, +ObAction* action_from_string(const gchar *name, ObUserAction uact); +ObAction* action_parse(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node, ObUserAction uact); -void action_free(ObAction *a); +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. @@ -205,6 +209,8 @@ void action_run_list(GSList *acts, struct _ObClient *c, ObFrameContext context, #define action_run(a, c, s) \ action_run_list(a, c, OB_FRAME_CONTEXT_NONE, s, 0, -1, -1, FALSE, FALSE) +void action_run_string(const gchar *name, struct _ObClient *c); + /* Execute */ void action_execute(union ActionData *data); /* ActivateAction */