guint ref;
gchar *name;
- gboolean allow_interactive;
+ ObActionsType type;
ObActionsDataSetupFunc setup;
ObActionsDataFreeFunc free;
ObActionsRunFunc run;
+ ObActionsInteractiveInputFunc i_input;
+ ObActionsInteractiveCancelFunc i_cancel;
};
struct _ObActionsAct {
guint ref;
ObActionsDefinition *def;
-
gpointer options;
};
}
gboolean actions_register(const gchar *name,
- gboolean allow_interactive,
+ ObActionsType type,
ObActionsDataSetupFunc setup,
ObActionsDataFreeFunc free,
- ObActionsRunFunc run)
+ ObActionsRunFunc run,
+ ObActionsInteractiveInputFunc i_input,
+ ObActionsInteractiveCancelFunc i_cancel)
{
GSList *it;
ObActionsDefinition *def;
return FALSE;
}
+ g_assert((i_input == NULL) == (i_cancel == NULL));
+
def = g_new(ObActionsDefinition, 1);
def->ref = 1;
def->name = g_strdup(name);
- def->allow_interactive = allow_interactive;
+ def->type = type;
def->setup = setup;
def->free = free;
def->run = run;
+ def->i_input = i_input;
+ def->i_cancel = i_cancel;
return TRUE;
}
return act;
}
+gboolean actions_act_is_interactive(ObActionsAct *act)
+{
+ return act->def->i_cancel != NULL;
+}
+
void actions_act_ref(ObActionsAct *act)
{
++act->ref;
g_free(act);
}
}
+
+static void actions_setup_data(ObActionsData *data,
+ ObUserAction uact,
+ Time time,
+ guint state,
+ gint x,
+ gint y)
+{
+ data->any.uact = uact;
+ data->any.time = time;
+ data->any.state = state;
+ data->any.x = x;
+ data->any.y = y;
+}
+
+void actions_run_acts(GSList *acts,
+ ObUserAction uact,
+ Time time,
+ guint state,
+ gint x,
+ gint y,
+ ObFrameContext con,
+ struct _ObClient *client)
+{
+ GSList *it;
+
+ for (it = acts; it; it = g_slist_next(it)) {
+ ObActionsData data;
+ ObActionsAct *act = it->data;
+
+ data.type = act->def->type;
+ actions_setup_data(&data, uact, time, state, x, y);
+ switch (data.type) {
+ case OB_ACTION_TYPE_GLOBAL:
+ break;
+ case OB_ACTION_TYPE_CLIENT:
+ data.client.context = con;
+ data.client.c = client;
+ break;
+ default:
+ g_assert_not_reached();
+ }
+
+ /* fire the action's run function with this data */
+ act->def->run(&data, act->options);
+ }
+}