diff options
author | James Booth <boothj5@gmail.com> | 2015-03-10 23:35:08 +0000 |
---|---|---|
committer | James Booth <boothj5@gmail.com> | 2015-03-10 23:35:08 +0000 |
commit | e5bb12a0d6223e6c6297c1700914332942a4ca00 (patch) | |
tree | 4f2d1999166703b5d626b5bac3ec17e20b2c7f73 /src/command | |
parent | 0269129d17bf86f9db810a8a1720ff1d63ad336d (diff) | |
download | profani-tty-e5bb12a0d6223e6c6297c1700914332942a4ca00.tar.gz |
Added /time statusbar preference
Diffstat (limited to 'src/command')
-rw-r--r-- | src/command/command.c | 50 | ||||
-rw-r--r-- | src/command/commands.c | 56 |
2 files changed, 82 insertions, 24 deletions
diff --git a/src/command/command.c b/src/command/command.c index 6a5603ee..2186d224 100644 --- a/src/command/command.c +++ b/src/command/command.c @@ -102,6 +102,7 @@ static char * _role_autocomplete(const char * const input); static char * _resource_autocomplete(const char * const input); static char * _titlebar_autocomplete(const char * const input); static char * _inpblock_autocomplete(const char * const input); +static char * _time_autocomplete(const char * const input); GHashTable *commands = NULL; @@ -681,11 +682,18 @@ static struct cmd_t command_defs[] = NULL } } }, { "/time", - cmd_time, parse_args, 1, 1, &cons_time_setting, - { "/time minutes|seconds", "Time display.", - { "/time minutes|seconds", - "---------------------", - "Configure time precision for the main window.", + cmd_time, parse_args, 1, 2, &cons_time_setting, + { "/time setting|statusbar [setting]", "Time display.", + { "/time setting|statusbar [setting]", + "---------------------------------", + "Configure time display preferences.", + "", + "minutes : Use minutes precision in main window.", + "seconds : Use seconds precision in main window.", + "off : Do not show time in main window.", + "statusbar minutes : Show minutes precision in status bar.", + "statusbar seconds : Show seconds precision in status bar.", + "statusbar off : Do not show time in status bar.", NULL } } }, { "/inpblock", @@ -1180,6 +1188,7 @@ static Autocomplete form_field_multi_ac; static Autocomplete occupants_ac; static Autocomplete occupants_default_ac; static Autocomplete time_ac; +static Autocomplete time_statusbar_ac; static Autocomplete resource_ac; static Autocomplete inpblock_ac; @@ -1523,6 +1532,12 @@ cmd_init(void) autocomplete_add(time_ac, "minutes"); autocomplete_add(time_ac, "seconds"); autocomplete_add(time_ac, "off"); + autocomplete_add(time_ac, "statusbar"); + + time_statusbar_ac = autocomplete_new(); + autocomplete_add(time_statusbar_ac, "minutes"); + autocomplete_add(time_statusbar_ac, "seconds"); + autocomplete_add(time_statusbar_ac, "off"); resource_ac = autocomplete_new(); autocomplete_add(resource_ac, "set"); @@ -1587,6 +1602,7 @@ cmd_uninit(void) autocomplete_free(occupants_ac); autocomplete_free(occupants_default_ac); autocomplete_free(time_ac); + autocomplete_free(time_statusbar_ac); autocomplete_free(resource_ac); autocomplete_free(inpblock_ac); } @@ -1752,6 +1768,7 @@ cmd_reset_autocomplete() autocomplete_reset(occupants_ac); autocomplete_reset(occupants_default_ac); autocomplete_reset(time_ac); + autocomplete_reset(time_statusbar_ac); autocomplete_reset(resource_ac); autocomplete_reset(inpblock_ac); @@ -2067,8 +2084,8 @@ _cmd_complete_parameters(const char * const input) } } - gchar *cmds[] = { "/help", "/prefs", "/disco", "/close", "/wins", "/subject", "/room", "/time" }; - Autocomplete completers[] = { help_ac, prefs_ac, disco_ac, close_ac, wins_ac, subject_ac, room_ac, time_ac }; + gchar *cmds[] = { "/help", "/prefs", "/disco", "/close", "/wins", "/subject", "/room" }; + Autocomplete completers[] = { help_ac, prefs_ac, disco_ac, close_ac, wins_ac, subject_ac, room_ac }; for (i = 0; i < ARRAY_SIZE(cmds); i++) { result = autocomplete_param_with_ac(input, cmds[i], completers[i], TRUE); @@ -2103,6 +2120,7 @@ _cmd_complete_parameters(const char * const input) g_hash_table_insert(ac_funcs, "/resource", _resource_autocomplete); g_hash_table_insert(ac_funcs, "/titlebar", _titlebar_autocomplete); g_hash_table_insert(ac_funcs, "/inpblock", _inpblock_autocomplete); + g_hash_table_insert(ac_funcs, "/time", _time_autocomplete); int len = strlen(input); char parsed[len+1]; @@ -2740,6 +2758,24 @@ _occupants_autocomplete(const char * const input) } static char * +_time_autocomplete(const char * const input) +{ + char *found = NULL; + + found = autocomplete_param_with_ac(input, "/time statusbar", time_statusbar_ac, TRUE); + if (found != NULL) { + return found; + } + + found = autocomplete_param_with_ac(input, "/time", time_ac, TRUE); + if (found != NULL) { + return found; + } + + return NULL; +} + +static char * _kick_autocomplete(const char * const input) { char *result = NULL; diff --git a/src/command/commands.c b/src/command/commands.c index 2ca749fb..1851a3f4 100644 --- a/src/command/commands.c +++ b/src/command/commands.c @@ -3270,24 +3270,46 @@ cmd_wrap(gchar **args, struct cmd_help_t help) gboolean cmd_time(gchar **args, struct cmd_help_t help) { - if (g_strcmp0(args[0], "minutes") == 0) { - prefs_set_string(PREF_TIME, "minutes"); - cons_show("Time precision set to minutes."); - wins_resize_all(); - return TRUE; - } else if (g_strcmp0(args[0], "seconds") == 0) { - prefs_set_string(PREF_TIME, "seconds"); - cons_show("Time precision set to seconds."); - wins_resize_all(); - return TRUE; - } else if (g_strcmp0(args[0], "off") == 0) { - prefs_set_string(PREF_TIME, "off"); - cons_show("Time display disabled."); - wins_resize_all(); - return TRUE; + if (g_strcmp0(args[0], "statusbar") == 0) { + if (g_strcmp0(args[1], "minutes") == 0) { + prefs_set_string(PREF_TIME_STATUSBAR, "minutes"); + cons_show("Status bar time precision set to minutes."); + ui_redraw(); + return TRUE; + } else if (g_strcmp0(args[1], "seconds") == 0) { + prefs_set_string(PREF_TIME_STATUSBAR, "seconds"); + cons_show("Status bar time precision set to seconds."); + ui_redraw(); + return TRUE; + } else if (g_strcmp0(args[1], "off") == 0) { + prefs_set_string(PREF_TIME_STATUSBAR, "off"); + cons_show("Status bar time display disabled."); + ui_redraw(); + return TRUE; + } else { + cons_show("Usage: %s", help.usage); + return TRUE; + } } else { - cons_show("Usage: %s", help.usage); - return TRUE; + if (g_strcmp0(args[0], "minutes") == 0) { + prefs_set_string(PREF_TIME, "minutes"); + cons_show("Time precision set to minutes."); + wins_resize_all(); + return TRUE; + } else if (g_strcmp0(args[0], "seconds") == 0) { + prefs_set_string(PREF_TIME, "seconds"); + cons_show("Time precision set to seconds."); + wins_resize_all(); + return TRUE; + } else if (g_strcmp0(args[0], "off") == 0) { + prefs_set_string(PREF_TIME, "off"); + cons_show("Time display disabled."); + wins_resize_all(); + return TRUE; + } else { + cons_show("Usage: %s", help.usage); + return TRUE; + } } } |