mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Merge remote-tracking branch 'incertia/exit-title'
Conflicts: src/command/command.c src/config/preferences.c src/config/preferences.h
This commit is contained in:
commit
0d0ed9b7ca
@ -11,3 +11,4 @@
|
||||
- Additional readline style shortcuts
|
||||
- Improved chat session handling
|
||||
- Override resource during chat and resource display settings (/resource)
|
||||
- Disable terminal title by default, additonal title on exit
|
||||
|
@ -723,10 +723,12 @@ static struct cmd_t command_defs[] =
|
||||
|
||||
{ "/titlebar",
|
||||
cmd_titlebar, parse_args, 2, 2, &cons_titlebar_setting,
|
||||
{ "/titlebar show on|off", "Show information in the window title bar.",
|
||||
{ "/titlebar show on|off",
|
||||
{ "/titlebar show|goodbye on|off", "Manage the terminal window title.",
|
||||
{ "/titlebar show|goodbye on|off",
|
||||
"---------------------",
|
||||
"Show information in the window title bar.",
|
||||
"Show or hide a title and exit message in the terminal window title.",
|
||||
"show - Show current logged in user, and unread messages in the title.",
|
||||
"goodbye - Show a message in the title when exiting profanity.",
|
||||
NULL } } },
|
||||
|
||||
{ "/mouse",
|
||||
@ -1208,6 +1210,7 @@ cmd_init(void)
|
||||
|
||||
titlebar_ac = autocomplete_new();
|
||||
autocomplete_add(titlebar_ac, "show");
|
||||
autocomplete_add(titlebar_ac, "goodbye");
|
||||
|
||||
log_ac = autocomplete_new();
|
||||
autocomplete_add(log_ac, "maxsize");
|
||||
@ -2497,6 +2500,11 @@ _titlebar_autocomplete(char *input, int *size)
|
||||
return found;
|
||||
}
|
||||
|
||||
found = autocomplete_param_with_func(input, size, "/titlebar goodbye", prefs_autocomplete_boolean_choice);
|
||||
if (found != NULL) {
|
||||
return found;
|
||||
}
|
||||
|
||||
found = autocomplete_param_with_ac(input, size, "/titlebar", titlebar_ac, FALSE);
|
||||
if (found != NULL) {
|
||||
return found;
|
||||
|
@ -3252,14 +3252,18 @@ cmd_states(gchar **args, struct cmd_help_t help)
|
||||
gboolean
|
||||
cmd_titlebar(gchar **args, struct cmd_help_t help)
|
||||
{
|
||||
if (g_strcmp0(args[0], "show") != 0) {
|
||||
if (g_strcmp0(args[0], "show") != 0 && g_strcmp0(args[0], "goodbye") != 0) {
|
||||
cons_show("Usage: %s", help.usage);
|
||||
return TRUE;
|
||||
}
|
||||
if (g_strcmp0(args[1], "off") == 0) {
|
||||
if (g_strcmp0(args[0], "show") == 0 && g_strcmp0(args[1], "off") == 0) {
|
||||
ui_clear_win_title();
|
||||
}
|
||||
return _cmd_set_boolean_preference(args[1], help, "Titlebar show", PREF_TITLEBAR_SHOW);
|
||||
if (g_strcmp0(args[0], "show") == 0) {
|
||||
return _cmd_set_boolean_preference(args[1], help, "Titlebar show", PREF_TITLEBAR_SHOW);
|
||||
} else {
|
||||
return _cmd_set_boolean_preference(args[1], help, "Titlebar goodbye", PREF_TITLEBAR_GOODBYE);
|
||||
}
|
||||
}
|
||||
|
||||
gboolean
|
||||
|
@ -511,6 +511,7 @@ _get_group(preference_t pref)
|
||||
case PREF_THEME:
|
||||
case PREF_VERCHECK:
|
||||
case PREF_TITLEBAR_SHOW:
|
||||
case PREF_TITLEBAR_GOODBYE:
|
||||
case PREF_FLASH:
|
||||
case PREF_INTYPE:
|
||||
case PREF_HISTORY:
|
||||
@ -583,6 +584,8 @@ _get_key(preference_t pref)
|
||||
return "vercheck";
|
||||
case PREF_TITLEBAR_SHOW:
|
||||
return "titlebar.show";
|
||||
case PREF_TITLEBAR_GOODBYE:
|
||||
return "titlebar.goodbye";
|
||||
case PREF_FLASH:
|
||||
return "flash";
|
||||
case PREF_INTYPE:
|
||||
|
@ -55,6 +55,7 @@ typedef enum {
|
||||
PREF_VERCHECK,
|
||||
PREF_THEME,
|
||||
PREF_TITLEBAR_SHOW,
|
||||
PREF_TITLEBAR_GOODBYE,
|
||||
PREF_FLASH,
|
||||
PREF_INTYPE,
|
||||
PREF_HISTORY,
|
||||
|
@ -292,7 +292,13 @@ _init(const int disable_tls, char *log_level)
|
||||
static void
|
||||
_shutdown(void)
|
||||
{
|
||||
ui_clear_win_title();
|
||||
if (prefs_get_boolean(PREF_TITLEBAR_SHOW)) {
|
||||
if (prefs_get_boolean(PREF_TITLEBAR_GOODBYE)) {
|
||||
ui_goodbye_title();
|
||||
} else {
|
||||
ui_clear_win_title();
|
||||
}
|
||||
}
|
||||
ui_close_all_wins();
|
||||
jabber_disconnect();
|
||||
jabber_shutdown();
|
||||
|
@ -969,6 +969,11 @@ cons_titlebar_setting(void)
|
||||
} else {
|
||||
cons_show("Titlebar show (/titlebar) : OFF");
|
||||
}
|
||||
if (prefs_get_boolean(PREF_TITLEBAR_GOODBYE)) {
|
||||
cons_show("Titlebar goodbye (/titlebar) : ON");
|
||||
} else {
|
||||
cons_show("Titlebar goodbye (/titlebar) : OFF");
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -2301,6 +2301,13 @@ ui_clear_win_title(void)
|
||||
printf("%c]0;%c", '\033', '\007');
|
||||
}
|
||||
|
||||
void
|
||||
ui_goodbye_title(void)
|
||||
{
|
||||
int result = system("/bin/echo -ne \"\033]0;Thanks for using Profanity\007\"");
|
||||
if(result == -1) log_error("Error printing title on shutdown");
|
||||
}
|
||||
|
||||
void
|
||||
ui_statusbar_new(const int win)
|
||||
{
|
||||
|
@ -191,6 +191,7 @@ void ui_handle_recipient_not_found(const char * const recipient, const char * co
|
||||
void ui_handle_recipient_error(const char * const recipient, const char * const err_msg);
|
||||
void ui_handle_error(const char * const err_msg);
|
||||
void ui_clear_win_title(void);
|
||||
void ui_goodbye_title(void);
|
||||
void ui_handle_room_join_error(const char * const roomjid, const char * const err);
|
||||
void ui_handle_room_configuration(const char * const roomjid, DataForm *form);
|
||||
void ui_handle_room_configuration_form_error(const char * const roomjid, const char * const message);
|
||||
|
@ -284,6 +284,7 @@ void ui_handle_error(const char * const err_msg)
|
||||
}
|
||||
|
||||
void ui_clear_win_title(void) {}
|
||||
void ui_goodbye_title(void) {}
|
||||
void ui_handle_room_join_error(const char * const roomjid, const char * const err) {}
|
||||
void ui_handle_room_configuration(const char * const roomjid, DataForm *form) {}
|
||||
void ui_handle_room_configuration_form_error(const char * const roomjid, const char * const message) {}
|
||||
|
Loading…
Reference in New Issue
Block a user