summaryrefslogtreecommitdiff
path: root/src/fe-text
diff options
context:
space:
mode:
Diffstat (limited to 'src/fe-text')
-rw-r--r--src/fe-text/statusbar-config.c431
1 files changed, 275 insertions, 156 deletions
diff --git a/src/fe-text/statusbar-config.c b/src/fe-text/statusbar-config.c
index 48f4aa61..391a5768 100644
--- a/src/fe-text/statusbar-config.c
+++ b/src/fe-text/statusbar-config.c
@@ -95,8 +95,10 @@ statusbar_config_find(STATUSBAR_GROUP_REC *group, const char *name)
for (tmp = group->config_bars; tmp != NULL; tmp = tmp->next) {
STATUSBAR_CONFIG_REC *config = tmp->data;
- if (g_strcmp0(config->name, name) == 0)
- return config;
+ if ((config->name == NULL || name == NULL) ?
+ config->name == name :
+ g_ascii_strcasecmp(config->name, name) == 0)
+ return config;
}
return NULL;
@@ -273,6 +275,24 @@ static const char *sbar_get_visibility(STATUSBAR_CONFIG_REC *rec)
rec->visible == STATUSBAR_VISIBLE_INACTIVE ? "inactive" : "??";
}
+static CONFIG_NODE *sbar_node(const char *name, gboolean create)
+{
+ CONFIG_NODE *node;
+ STATUSBAR_CONFIG_REC *rec = statusbar_config_find(active_statusbar_group, name);
+ if (rec != NULL) {
+ name = rec->name;
+ } else if (!create) {
+ return NULL;
+ }
+
+ /* lookup/create the statusbar node */
+ node = iconfig_node_traverse("statusbar", TRUE);
+ node = iconfig_node_section(node, active_statusbar_group->name, NODE_TYPE_BLOCK);
+ node = iconfig_node_section(node, name, NODE_TYPE_BLOCK);
+
+ return node;
+}
+
static void statusbar_list_items(STATUSBAR_CONFIG_REC *bar)
{
GSList *tmp;
@@ -334,98 +354,133 @@ static void cmd_statusbar_list(void)
static void cmd_statusbar_print_info(const char *name)
{
- GSList *tmp;
+ STATUSBAR_CONFIG_REC *rec = statusbar_config_find(active_statusbar_group, name);
- tmp = active_statusbar_group->config_bars;
- for (; tmp != NULL; tmp = tmp->next) {
- STATUSBAR_CONFIG_REC *rec = tmp->data;
-
- if (g_ascii_strcasecmp(rec->name, name) == 0) {
- statusbar_print(rec);
- return;
- }
+ if (rec != NULL) {
+ statusbar_print(rec);
+ return;
}
printformat(NULL, NULL, MSGLEVEL_CLIENTERROR,
TXT_STATUSBAR_NOT_FOUND, name);
}
-/* SYNTAX: STATUSBAR <name> ENABLE */
-static void cmd_statusbar_enable(const char *data, void *server,
- void *item, CONFIG_NODE *node)
+/* SYNTAX: STATUSBAR ADD|MODIFY [-disable | -nodisable] [-type window|root]
+ [-placement top|bottom] [-position #] [-visible always|active|inactive] <statusbar> */
+static void cmd_statusbar_add_modify(const char *data, void *server, void *witem)
{
- iconfig_node_set_str(node, "disabled", NULL);
-}
+ GHashTable *optlist;
+ CONFIG_NODE *node;
+ char *name, *type, *placement, *visible;
+ void *free_arg;
+ int error;
-/* SYNTAX: STATUSBAR <name> DISABLE */
-static void cmd_statusbar_disable(const char *data, void *server,
- void *item, CONFIG_NODE *node)
-{
- iconfig_node_set_bool(node, "disabled", TRUE);
-}
+ if (!cmd_get_params(data, &free_arg, 1 | PARAM_FLAG_OPTIONS | PARAM_FLAG_STRIP_TRAILING_WS,
+ "statusbar add", &optlist, &name))
+ return;
-/* SYNTAX: STATUSBAR <name> RESET */
-static void cmd_statusbar_reset(const char *data, void *server,
- void *item, CONFIG_NODE *node)
-{
- CONFIG_NODE *parent;
+ if (*name == '\0') {
+ cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
+ }
- parent = iconfig_node_traverse("statusbar", TRUE);
- parent = iconfig_node_section(parent, active_statusbar_group->name,
- NODE_TYPE_BLOCK);
+ error = 0;
+
+ type = NULL;
+ data = g_hash_table_lookup(optlist, "type");
+ if (data != NULL) {
+ if (g_ascii_strcasecmp(data, "window") == 0)
+ type = "window";
+ else if (g_ascii_strcasecmp(data, "root") == 0)
+ type = "root";
+ else {
+ printformat(NULL, NULL, MSGLEVEL_CLIENTERROR, TXT_STATUSBAR_UNKNOWN_TYPE,
+ data);
+ error++;
+ }
+ }
- iconfig_node_set_str(parent, node->key, NULL);
-}
+ placement = NULL;
+ data = g_hash_table_lookup(optlist, "placement");
+ if (data != NULL) {
+ if (g_ascii_strcasecmp(data, "top") == 0)
+ placement = "top";
+ else if (g_ascii_strcasecmp(data, "bottom") == 0)
+ placement = "bottom";
+ else {
+ printformat(NULL, NULL, MSGLEVEL_CLIENTERROR,
+ TXT_STATUSBAR_UNKNOWN_PLACEMENT, data);
+ error++;
+ }
+ }
-/* SYNTAX: STATUSBAR <name> TYPE window|root */
-static void cmd_statusbar_type(const char *data, void *server,
- void *item, CONFIG_NODE *node)
-{
- if (g_ascii_strcasecmp(data, "window") == 0)
- iconfig_node_set_str(node, "type", "window");
- else if (g_ascii_strcasecmp(data, "root") == 0)
- iconfig_node_set_str(node, "type", "root");
- else {
- printformat(NULL, NULL, MSGLEVEL_CLIENTERROR,
- TXT_STATUSBAR_UNKNOWN_TYPE, data);
+ visible = NULL;
+ data = g_hash_table_lookup(optlist, "visible");
+ if (data != NULL) {
+ if (g_ascii_strcasecmp(data, "always") == 0)
+ visible = "always";
+ else if (g_ascii_strcasecmp(data, "active") == 0)
+ visible = "active";
+ else if (g_ascii_strcasecmp(data, "inactive") == 0)
+ visible = "inactive";
+ else {
+ printformat(NULL, NULL, MSGLEVEL_CLIENTERROR,
+ TXT_STATUSBAR_UNKNOWN_VISIBILITY, data);
+ error++;
+ }
}
-}
-/* SYNTAX: STATUSBAR <name> PLACEMENT top|bottom */
-static void cmd_statusbar_placement(const char *data, void *server,
- void *item, CONFIG_NODE *node)
-{
- if (g_ascii_strcasecmp(data, "top") == 0)
- iconfig_node_set_str(node, "placement", "top");
- else if (g_ascii_strcasecmp(data, "bottom") == 0)
- iconfig_node_set_str(node, "placement", "bottom");
- else {
- printformat(NULL, NULL, MSGLEVEL_CLIENTERROR,
- TXT_STATUSBAR_UNKNOWN_PLACEMENT, data);
+ if (error) {
+ cmd_params_free(free_arg);
+ return;
}
-}
-/* SYNTAX: STATUSBAR <name> POSITION <num> */
-static void cmd_statusbar_position(const char *data, void *server,
- void *item, CONFIG_NODE *node)
-{
- iconfig_node_set_int(node, "position", atoi(data));
+ node = sbar_node(name, TRUE);
+ if (g_hash_table_lookup(optlist, "nodisable"))
+ iconfig_node_set_str(node, "disabled", NULL);
+ if (g_hash_table_lookup(optlist, "disable"))
+ iconfig_node_set_bool(node, "disabled", TRUE);
+ if (type != NULL)
+ iconfig_node_set_str(node, "type", type);
+ if (placement != NULL)
+ iconfig_node_set_str(node, "placement", placement);
+ data = g_hash_table_lookup(optlist, "position");
+ if (data != NULL)
+ iconfig_node_set_int(node, "position", atoi(data));
+ if (visible != NULL)
+ iconfig_node_set_str(node, "visible", visible);
+
+ read_statusbar_config();
+ cmd_params_free(free_arg);
}
-/* SYNTAX: STATUSBAR <name> VISIBLE always|active|inactive */
-static void cmd_statusbar_visible(const char *data, void *server,
- void *item, CONFIG_NODE *node)
+/* SYNTAX: STATUSBAR RESET <statusbar> */
+static void cmd_statusbar_reset(const char *data, void *server, void *witem)
{
- if (g_ascii_strcasecmp(data, "always") == 0)
- iconfig_node_set_str(node, "visible", "always");
- else if (g_ascii_strcasecmp(data, "active") == 0)
- iconfig_node_set_str(node, "visible", "active");
- else if (g_ascii_strcasecmp(data, "inactive") == 0)
- iconfig_node_set_str(node, "visible", "inactive");
- else {
- printformat(NULL, NULL, MSGLEVEL_CLIENTERROR,
- TXT_STATUSBAR_UNKNOWN_VISIBILITY, data);
+ CONFIG_NODE *node, *parent;
+ char *name;
+ void *free_arg;
+
+ if (!cmd_get_params(data, &free_arg, 1 | PARAM_FLAG_STRIP_TRAILING_WS, &name))
+ return;
+
+ if (*name == '\0') {
+ cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
}
+
+ node = sbar_node(name, FALSE);
+ if (node == NULL) {
+ printformat(NULL, NULL, MSGLEVEL_CLIENTERROR, TXT_STATUSBAR_NOT_FOUND, name);
+ cmd_params_free(free_arg);
+ return;
+ }
+
+ parent = iconfig_node_traverse("statusbar", TRUE);
+ parent = iconfig_node_section(parent, active_statusbar_group->name, NODE_TYPE_BLOCK);
+
+ iconfig_node_set_str(parent, node->key, NULL);
+
+ read_statusbar_config();
+ cmd_params_free(free_arg);
}
static CONFIG_NODE *statusbar_items_section(CONFIG_NODE *parent)
@@ -455,45 +510,58 @@ static CONFIG_NODE *statusbar_items_section(CONFIG_NODE *parent)
node = iconfig_node_section(parent, rec->name,
NODE_TYPE_BLOCK);
if (rec->priority != 0)
- iconfig_node_set_int(node, "priority", rec->priority);
+ iconfig_node_set_int(node, "priority", rec->priority);
if (rec->right_alignment)
- iconfig_node_set_str(node, "alignment", "right");
+ iconfig_node_set_str(node, "alignment", "right");
}
- return parent;
+ return parent;
}
-/* SYNTAX: STATUSBAR <name> ADD [-before | -after <item>]
- [-priority #] [-alignment left|right] <item> */
-static void cmd_statusbar_add(const char *data, void *server,
- void *item, CONFIG_NODE *node)
+/* SYNTAX: STATUSBAR ADDITEM|MODIFYITEM [-before | -after <item>]
+ [-priority #] [-alignment left|right] <item> <statusbar> */
+static void cmd_statusbar_additem_modifyitem(const char *data, void *server, void *witem)
{
- GHashTable *optlist;
- char *name, *value;
+ CONFIG_NODE *node;
+ GHashTable *optlist;
+ char *item, *statusbar, *value;
void *free_arg;
- int index;
+ int index;
- node = statusbar_items_section(node);
- if (node == NULL)
- return;
+ if (!cmd_get_params(data, &free_arg, 2 | PARAM_FLAG_OPTIONS | PARAM_FLAG_STRIP_TRAILING_WS,
+ "statusbar additem", &optlist, &item, &statusbar))
+ return;
+
+ if (*statusbar == '\0') {
+ cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
+ }
- if (!cmd_get_params(data, &free_arg, 1 | PARAM_FLAG_OPTIONS,
- "statusbar add", &optlist, &name))
+ node = sbar_node(statusbar, FALSE);
+ if (node == NULL) {
+ printformat(NULL, NULL, MSGLEVEL_CLIENTERROR, TXT_STATUSBAR_NOT_FOUND, statusbar);
+ cmd_params_free(free_arg);
return;
+ }
+
+ node = statusbar_items_section(node);
+ if (node == NULL) {
+ cmd_params_free(free_arg);
+ return;
+ }
- /* get the index */
+ /* get the index */
index = -1;
value = g_hash_table_lookup(optlist, "before");
if (value != NULL) index = config_node_index(node, value);
value = g_hash_table_lookup(optlist, "after");
if (value != NULL) index = config_node_index(node, value)+1;
- /* create/move item */
- node = iconfig_node_section_index(node, name, index, NODE_TYPE_BLOCK);
+ /* create/move item */
+ node = iconfig_node_section_index(node, item, index, NODE_TYPE_BLOCK);
- /* set the options */
- value = g_hash_table_lookup(optlist, "priority");
- if (value != NULL) iconfig_node_set_int(node, "priority", atoi(value));
+ /* set the options */
+ value = g_hash_table_lookup(optlist, "priority");
+ if (value != NULL) iconfig_node_set_int(node, "priority", atoi(value));
value = g_hash_table_lookup(optlist, "alignment");
if (value != NULL) {
@@ -502,67 +570,115 @@ static void cmd_statusbar_add(const char *data, void *server,
"right" : NULL);
}
+ read_statusbar_config();
cmd_params_free(free_arg);
}
-/* SYNTAX: STATUSBAR <name> REMOVE <item> */
-static void cmd_statusbar_remove(const char *data, void *server,
- void *item, CONFIG_NODE *node)
+/* SYNTAX: STATUSBAR REMOVEITEM <item> <statusbar> */
+static void cmd_statusbar_removeitem(const char *data, void *server, void *witem)
{
- node = statusbar_items_section(node);
- if (node == NULL)
- return;
+ CONFIG_NODE *node;
+ char *item, *statusbar;
+ void *free_arg;
+ if (!cmd_get_params(data, &free_arg, 2 | PARAM_FLAG_STRIP_TRAILING_WS, &item, &statusbar))
+ return;
+
+ if (*statusbar == '\0') {
+ cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
+ }
+
+ node = sbar_node(statusbar, FALSE);
+ if (node == NULL) {
+ printformat(NULL, NULL, MSGLEVEL_CLIENTERROR, TXT_STATUSBAR_NOT_FOUND, statusbar);
+ cmd_params_free(free_arg);
+ return;
+ }
- if (iconfig_node_section(node, data, -1) != NULL)
- iconfig_node_set_str(node, data, NULL);
+ node = statusbar_items_section(node);
+ if (node == NULL) {
+ cmd_params_free(free_arg);
+ return;
+ }
+
+ if (iconfig_node_section(node, item, -1) != NULL)
+ iconfig_node_set_str(node, item, NULL);
else {
- printformat(NULL, NULL, MSGLEVEL_CLIENTERROR,
- TXT_STATUSBAR_ITEM_NOT_FOUND, data);
+ printformat(NULL, NULL, MSGLEVEL_CLIENTERROR, TXT_STATUSBAR_ITEM_NOT_FOUND, item);
}
+
+ read_statusbar_config();
+ cmd_params_free(free_arg);
}
-static void cmd_statusbar(const char *data)
+/* SYNTAX: STATUSBAR INFO <statusbar> */
+static void cmd_statusbar_info(const char *data)
{
- CONFIG_NODE *node;
- char *name, *cmd, *params, *signal;
void *free_arg;
-
- if (!cmd_get_params(data, &free_arg, 3 | PARAM_FLAG_GETREST,
- &name, &cmd, &params))
+ char *name;
+ if (!cmd_get_params(data, &free_arg, 1 | PARAM_FLAG_STRIP_TRAILING_WS, &name))
return;
if (*name == '\0') {
- /* list all statusbars */
- cmd_statusbar_list();
- cmd_params_free(free_arg);
- return;
+ cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
}
- if (*cmd == '\0') {
- /* print statusbar info */
- cmd_statusbar_print_info(name);
- cmd_params_free(free_arg);
- return;
- }
+ /* print statusbar info */
+ cmd_statusbar_print_info(name);
+ cmd_params_free(free_arg);
+ return;
+}
- /* lookup/create the statusbar node */
- node = iconfig_node_traverse("statusbar", TRUE);
- node = iconfig_node_section(node, active_statusbar_group->name,
- NODE_TYPE_BLOCK);
- node = iconfig_node_section(node, name, NODE_TYPE_BLOCK);
+static void cmd_statusbar(const char *data)
+{
+ char *arg1, *arg2, *params, *oldcmd;
+ void *free_arg;
- /* call the subcommand */
- signal = g_strconcat("command statusbar ", cmd, NULL);
- ascii_strdown(signal);
- if (!signal_emit(signal, 4, params, NULL, NULL, node)) {
- printformat(NULL, NULL, MSGLEVEL_CLIENTERROR,
- TXT_STATUSBAR_UNKNOWN_COMMAND, cmd);
- } else {
- read_statusbar_config();
+ if (!cmd_get_params(data, &free_arg, 3 | PARAM_FLAG_GETREST | PARAM_FLAG_STRIP_TRAILING_WS,
+ &arg1, &arg2, &params))
+ return;
+
+ /* backward compatibility layer */
+ oldcmd = NULL;
+ if (*arg1 == '\0') {
+ oldcmd = g_strdup("list");
+ } else if (g_ascii_strcasecmp(arg2, "enable") == 0) {
+ oldcmd = g_strdup_printf("add -nodisable %s %s", arg1, params);
+ } else if (g_ascii_strcasecmp(arg2, "disable") == 0) {
+ oldcmd = g_strdup_printf("add -disable %s %s", arg1, params);
+ } else if (g_ascii_strcasecmp(arg2, "reset") == 0) {
+ oldcmd = g_strdup_printf("reset %s", arg1);
+ } else if (g_ascii_strcasecmp(arg2, "type") == 0) {
+ oldcmd = g_strdup_printf("add -type %s %s", params, arg1);
+ } else if (g_ascii_strcasecmp(arg2, "placement") == 0) {
+ oldcmd = g_strdup_printf("add -placement %s %s", params, arg1);
+ } else if (g_ascii_strcasecmp(arg2, "position") == 0) {
+ oldcmd = g_strdup_printf("add -position %s %s", params, arg1);
+ } else if (g_ascii_strcasecmp(arg2, "visible") == 0) {
+ oldcmd = g_strdup_printf("add -visible %s %s", params, arg1);
+ } else if (g_ascii_strcasecmp(arg2, "add") == 0) {
+ oldcmd = g_strdup_printf("additem %s %s", params, arg1);
+ } else if (g_ascii_strcasecmp(arg2, "remove") == 0) {
+ oldcmd = g_strdup_printf("removeitem %s %s", params, arg1);
+ } else if (*arg2 == '\0') {
+ oldcmd = g_strdup_printf("statusbar %s", arg1);
+ if (command_find(oldcmd) == NULL) {
+ g_free(oldcmd);
+ oldcmd = g_strdup_printf("info %s", arg1);
+ } else {
+ g_free(oldcmd);
+ oldcmd = NULL;
+ }
}
- g_free(signal);
cmd_params_free(free_arg);
+ if (oldcmd) {
+ command_runsub("statusbar", oldcmd, NULL, NULL);
+ g_free(oldcmd);
+ } else {
+ command_runsub("statusbar", data, NULL, NULL);
+ }
+
+ return;
}
void statusbar_config_init(void)
@@ -571,18 +687,22 @@ void statusbar_config_init(void)
signal_add_last("setup reread", (SIGNAL_FUNC) read_statusbar_config);
signal_add("theme changed", (SIGNAL_FUNC) read_statusbar_config);
- command_bind("statusbar", NULL, (SIGNAL_FUNC) cmd_statusbar);
- command_bind("statusbar enable", NULL, (SIGNAL_FUNC) cmd_statusbar_enable);
- command_bind("statusbar disable", NULL, (SIGNAL_FUNC) cmd_statusbar_disable);
- command_bind("statusbar reset", NULL, (SIGNAL_FUNC) cmd_statusbar_reset);
- command_bind("statusbar add", NULL, (SIGNAL_FUNC) cmd_statusbar_add);
- command_bind("statusbar remove", NULL, (SIGNAL_FUNC) cmd_statusbar_remove);
- command_bind("statusbar type", NULL, (SIGNAL_FUNC) cmd_statusbar_type);
- command_bind("statusbar placement", NULL, (SIGNAL_FUNC) cmd_statusbar_placement);
- command_bind("statusbar position", NULL, (SIGNAL_FUNC) cmd_statusbar_position);
- command_bind("statusbar visible", NULL, (SIGNAL_FUNC) cmd_statusbar_visible);
-
- command_set_options("statusbar add", "+before +after +priority +alignment");
+ command_bind("statusbar", NULL, (SIGNAL_FUNC) cmd_statusbar);
+ command_bind("statusbar list", NULL, (SIGNAL_FUNC) cmd_statusbar_list);
+ command_bind("statusbar add", NULL, (SIGNAL_FUNC) cmd_statusbar_add_modify);
+ command_bind("statusbar modify", NULL, (SIGNAL_FUNC) cmd_statusbar_add_modify);
+ command_bind("statusbar reset", NULL, (SIGNAL_FUNC) cmd_statusbar_reset);
+ command_bind("statusbar info", NULL, (SIGNAL_FUNC) cmd_statusbar_info);
+ command_bind("statusbar additem", NULL, (SIGNAL_FUNC) cmd_statusbar_additem_modifyitem);
+ command_bind("statusbar modifyitem", NULL, (SIGNAL_FUNC) cmd_statusbar_additem_modifyitem);
+ command_bind("statusbar removeitem", NULL, (SIGNAL_FUNC) cmd_statusbar_removeitem);
+
+ command_set_options("statusbar additem", "+before +after +priority +alignment");
+ command_set_options("statusbar modifyitem", "+before +after +priority +alignment");
+ command_set_options("statusbar add",
+ "disable nodisable +type +placement +position +visible");
+ command_set_options("statusbar modify",
+ "disable nodisable +type +placement +position +visible");
}
void statusbar_config_deinit(void)
@@ -590,14 +710,13 @@ void statusbar_config_deinit(void)
signal_remove("setup reread", (SIGNAL_FUNC) read_statusbar_config);
signal_remove("theme changed", (SIGNAL_FUNC) read_statusbar_config);
- command_unbind("statusbar", (SIGNAL_FUNC) cmd_statusbar);
- command_unbind("statusbar enable", (SIGNAL_FUNC) cmd_statusbar_enable);
- command_unbind("statusbar disable", (SIGNAL_FUNC) cmd_statusbar_disable);
- command_unbind("statusbar reset", (SIGNAL_FUNC) cmd_statusbar_reset);
- command_unbind("statusbar add", (SIGNAL_FUNC) cmd_statusbar_add);
- command_unbind("statusbar remove", (SIGNAL_FUNC) cmd_statusbar_remove);
- command_unbind("statusbar type", (SIGNAL_FUNC) cmd_statusbar_type);
- command_unbind("statusbar placement", (SIGNAL_FUNC) cmd_statusbar_placement);
- command_unbind("statusbar position", (SIGNAL_FUNC) cmd_statusbar_position);
- command_unbind("statusbar visible", (SIGNAL_FUNC) cmd_statusbar_visible);
+ command_unbind("statusbar", (SIGNAL_FUNC) cmd_statusbar);
+ command_unbind("statusbar list", (SIGNAL_FUNC) cmd_statusbar_list);
+ command_unbind("statusbar add", (SIGNAL_FUNC) cmd_statusbar_add_modify);
+ command_unbind("statusbar modify", (SIGNAL_FUNC) cmd_statusbar_add_modify);
+ command_unbind("statusbar reset", (SIGNAL_FUNC) cmd_statusbar_reset);
+ command_unbind("statusbar info", (SIGNAL_FUNC) cmd_statusbar_info);
+ command_unbind("statusbar additem", (SIGNAL_FUNC) cmd_statusbar_additem_modifyitem);
+ command_unbind("statusbar modifyitem", (SIGNAL_FUNC) cmd_statusbar_additem_modifyitem);
+ command_unbind("statusbar removeitem", (SIGNAL_FUNC) cmd_statusbar_removeitem);
}