X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Faction.h;h=222755fcd9ce7340317137db782e50e2ee7e6122;hb=6611c30854e96f73feaafcef7ee3d4e38a799bfc;hp=bbd59804455a44498d6d7e826e09fe7a3b4a8ec7;hpb=16f46c296d1fcd3f27fc62a18e71c55fb3fd3e88;p=chaz%2Fopenbox diff --git a/openbox/action.h b/openbox/action.h index bbd59804..222755fc 100644 --- a/openbox/action.h +++ b/openbox/action.h @@ -32,8 +32,17 @@ typedef struct _ObAction ObAction; available (possibly NULL though) if it wants it. */ +typedef enum +{ + OB_CLIENT_ACTION_NO, + OB_CLIENT_ACTION_OPTIONAL, + OB_CLIENT_ACTION_ALWAYS +} ObClientActionReq; + struct AnyAction { + ObClientActionReq client_action; struct _ObClient *c; + ObFrameContext context; gboolean interactive; gint x; gint y; @@ -49,6 +58,7 @@ struct InteractiveAction { struct InterDirectionalAction{ struct InteractiveAction inter; ObDirection direction; + gboolean dialog; }; struct DirectionalAction{ @@ -90,7 +100,7 @@ struct SendToDesktopDirection { }; struct Desktop { - struct AnyAction any; + struct InteractiveAction inter; guint desk; }; @@ -121,6 +131,7 @@ struct CycleWindows { struct InteractiveAction inter; gboolean linear; gboolean forward; + gboolean dialog; }; union ActionData { @@ -143,7 +154,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. */ @@ -164,12 +176,15 @@ struct _ObAction { action_resize_relative_vert - the delta */ -ObAction *action_from_string(char *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 an action. +/*! 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. @@ -180,21 +195,23 @@ void action_free(ObAction *a); @param done If the action is completing an interactive action. This only affects interactive actions, but should generally always be FALSE. */ -void action_run_full(ObAction *a, struct _ObClient *c, +void action_run_list(GSList *acts, struct _ObClient *c, ObFrameContext context, guint state, guint button, gint x, gint y, gboolean cancel, gboolean done); -#define action_run_mouse(a, c, s, b, x, y) \ - action_run_full(a, c, s, b, x, y, FALSE, FALSE) +#define action_run_mouse(a, c, n, s, b, x, y) \ + action_run_list(a, c, n, s, b, x, y, FALSE, FALSE) #define action_run_interactive(a, c, s, n, d) \ - action_run_full(a, c, s, 0, -1, -1, n, d) + action_run_list(a, c, OB_FRAME_CONTEXT_NONE, s, 0, -1, -1, n, d) #define action_run_key(a, c, s, x, y) \ - action_run_full(a, c, s, 0, x, y, FALSE,FALSE) + action_run_list(a, c, OB_FRAME_CONTEXT_NONE, s, 0, x, y, FALSE, FALSE) #define action_run(a, c, s) \ - action_run_full(a, c, s, 0, -1, -1, FALSE,FALSE) + 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);