diff --git a/src/command/command.c b/src/command/command.c index 9e8283e2..9c587324 100644 --- a/src/command/command.c +++ b/src/command/command.c @@ -304,9 +304,9 @@ static struct cmd_t command_defs[] = NULL } } }, { "/bookmark", - cmd_bookmark, parse_args, 1, 8, NULL, - { "/bookmark list|add|update|remove|join [room@server] [nick value] [password value] [autojoin on|off]", "Manage bookmarks.", - { "/bookmark list|add|update|remove|join [room@server] [nick value] [password value] [autojoin on|off]", + cmd_bookmark, parse_args, 0, 8, NULL, + { "/bookmark [list|add|update|remove|join] [room@server] [nick value] [password value] [autojoin on|off]", "Manage bookmarks.", + { "/bookmark [list|add|update|remove|join] [room@server] [nick value] [password value] [autojoin on|off]", "---------------------------------------------------------------------------------------------------", "Manage bookmarks.", "list: List all bookmarks.", @@ -317,6 +317,7 @@ static struct cmd_t command_defs[] = "update: Update any of the above properties associated with the bookmark.", "remove: Remove the bookmark for room@server.", "join: Join room@server using the properties associated with the bookmark.", + "When in a chat room, the /bookmark command with no arguments will bookmark the current room with the current settings, and set autojoin to \"on\".", NULL } } }, { "/disco", diff --git a/src/command/commands.c b/src/command/commands.c index fdb4017c..2fed4c3e 100644 --- a/src/command/commands.c +++ b/src/command/commands.c @@ -1807,86 +1807,110 @@ cmd_bookmark(gchar **args, struct cmd_help_t help) return TRUE; } - gchar *cmd = args[0]; - if (cmd == NULL) { - cons_show("Usage: %s", help.usage); - return TRUE; - } + win_type_t win_type = ui_current_win_type(); - if (strcmp(cmd, "list") == 0) { - const GList *bookmarks = bookmark_get_list(); - cons_show_bookmarks(bookmarks); - } else { - char *jid = args[1]; - if (jid == NULL) { - cons_show("Usage: %s", help.usage); - cons_show(""); - return TRUE; - } + if (win_type == WIN_MUC) { + gchar *cmd = args[0]; - if (strcmp(cmd, "remove") == 0) { - gboolean removed = bookmark_remove(jid); - if (removed) { - cons_show("Bookmark removed for %s.", jid); + // default to current nickname, password, and autojoin "on" + if (cmd == NULL) { + char *jid = ui_current_recipient(); + char *nick = muc_get_room_nick(jid); + char *password = muc_get_room_password(jid); + gboolean added = bookmark_add(jid, nick, password, "on"); + if (added) { + ui_current_print_formatted_line('!', 0, "Bookmark added for %s.", jid); } else { - cons_show("No bookmark exists for %s.", jid); + ui_current_print_formatted_line('!', 0, "Bookmark already exists for %s.", jid); } return TRUE; + } else { + ui_current_print_formatted_line('!', 0, "No arguments required for /bookmark in a chat room"); + return TRUE; } - if (strcmp(cmd, "join") == 0) { - gboolean joined = bookmark_join(jid); - if (!joined) { - cons_show("No bookmark exists for %s.", jid); - } - return TRUE; - } - - gchar *opt_keys[] = { "autojoin", "nick", "password", NULL }; - gboolean parsed; - - GHashTable *options = parse_options(&args[2], opt_keys, &parsed); - if (!parsed) { + } else { + gchar *cmd = args[0]; + if (cmd == NULL) { cons_show("Usage: %s", help.usage); - cons_show(""); return TRUE; } - char *nick = g_hash_table_lookup(options, "nick"); - char *password = g_hash_table_lookup(options, "password"); - char *autojoin = g_hash_table_lookup(options, "autojoin"); - - if (autojoin != NULL) { - if ((strcmp(autojoin, "on") != 0) && (strcmp(autojoin, "off") != 0)) { + if (strcmp(cmd, "list") == 0) { + const GList *bookmarks = bookmark_get_list(); + cons_show_bookmarks(bookmarks); + } else { + char *jid = args[1]; + if (jid == NULL) { cons_show("Usage: %s", help.usage); cons_show(""); return TRUE; } - } - if (strcmp(cmd, "add") == 0) { - if (strchr(jid, '@')==NULL) { - cons_show("Can't add bookmark with JID '%s'; should be '%s@domain.tld'", jid, jid); - } else { - gboolean added = bookmark_add(jid, nick, password, autojoin); - if (added) { - cons_show("Bookmark added for %s.", jid); + if (strcmp(cmd, "remove") == 0) { + gboolean removed = bookmark_remove(jid); + if (removed) { + cons_show("Bookmark removed for %s.", jid); } else { - cons_show("Bookmark already exists, use /bookmark update to edit."); + cons_show("No bookmark exists for %s.", jid); + } + return TRUE; + } + + if (strcmp(cmd, "join") == 0) { + gboolean joined = bookmark_join(jid); + if (!joined) { + cons_show("No bookmark exists for %s.", jid); + } + return TRUE; + } + + gchar *opt_keys[] = { "autojoin", "nick", "password", NULL }; + gboolean parsed; + + GHashTable *options = parse_options(&args[2], opt_keys, &parsed); + if (!parsed) { + cons_show("Usage: %s", help.usage); + cons_show(""); + return TRUE; + } + + char *nick = g_hash_table_lookup(options, "nick"); + char *password = g_hash_table_lookup(options, "password"); + char *autojoin = g_hash_table_lookup(options, "autojoin"); + + if (autojoin != NULL) { + if ((strcmp(autojoin, "on") != 0) && (strcmp(autojoin, "off") != 0)) { + cons_show("Usage: %s", help.usage); + cons_show(""); + return TRUE; } } - } else if (strcmp(cmd, "update") == 0) { - gboolean updated = bookmark_update(jid, nick, password, autojoin); - if (updated) { - cons_show("Bookmark updated."); - } else { - cons_show("No bookmark exists for %s.", jid); - } - } else { - cons_show("Usage: %s", help.usage); - } - options_destroy(options); + if (strcmp(cmd, "add") == 0) { + if (strchr(jid, '@')==NULL) { + cons_show("Can't add bookmark with JID '%s'; should be '%s@domain.tld'", jid, jid); + } else { + gboolean added = bookmark_add(jid, nick, password, autojoin); + if (added) { + cons_show("Bookmark added for %s.", jid); + } else { + cons_show("Bookmark already exists, use /bookmark update to edit."); + } + } + } else if (strcmp(cmd, "update") == 0) { + gboolean updated = bookmark_update(jid, nick, password, autojoin); + if (updated) { + cons_show("Bookmark updated."); + } else { + cons_show("No bookmark exists for %s.", jid); + } + } else { + cons_show("Usage: %s", help.usage); + } + + options_destroy(options); + } } return TRUE; diff --git a/tests/test_cmd_bookmark.c b/tests/test_cmd_bookmark.c index 94192774..7e0e9d0c 100644 --- a/tests/test_cmd_bookmark.c +++ b/tests/test_cmd_bookmark.c @@ -60,6 +60,7 @@ void cmd_bookmark_shows_message_when_undefined(void **state) void cmd_bookmark_shows_usage_when_no_args(void **state) { mock_cons_show(); + mock_current_win_type(WIN_CONSOLE); CommandHelp *help = malloc(sizeof(CommandHelp)); help->usage = "some usage"; gchar *args[] = { NULL }; @@ -83,6 +84,7 @@ static void _free_bookmark(Bookmark *bookmark) void cmd_bookmark_list_shows_bookmarks(void **state) { mock_cons_show_bookmarks(); + mock_current_win_type(WIN_CONSOLE); CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "list", NULL }; GList *bookmarks = NULL; @@ -130,6 +132,7 @@ void cmd_bookmark_add_shows_message_when_invalid_jid(void **state) { mock_bookmark_add(); mock_cons_show(); + mock_current_win_type(WIN_CONSOLE); char *jid = "room"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "add", jid, NULL }; @@ -148,6 +151,7 @@ void cmd_bookmark_add_adds_bookmark_with_jid(void **state) { mock_bookmark_add(); mock_cons_show(); + mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "add", jid, NULL }; @@ -167,6 +171,7 @@ void cmd_bookmark_add_adds_bookmark_with_jid_nick(void **state) { mock_bookmark_add(); mock_cons_show(); + mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; char *nick = "bob"; CommandHelp *help = malloc(sizeof(CommandHelp)); @@ -187,6 +192,7 @@ void cmd_bookmark_add_adds_bookmark_with_jid_autojoin(void **state) { mock_bookmark_add(); mock_cons_show(); + mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "add", jid, "autojoin", "on", NULL }; @@ -206,6 +212,7 @@ void cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin(void **state) { mock_bookmark_add(); mock_cons_show(); + mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; char *nick = "bob"; CommandHelp *help = malloc(sizeof(CommandHelp)); @@ -226,6 +233,7 @@ void cmd_bookmark_remove_removes_bookmark(void **state) { mock_bookmark_remove(); mock_cons_show(); + mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "remove", jid, NULL }; @@ -245,6 +253,7 @@ void cmd_bookmark_remove_shows_message_when_no_bookmark(void **state) { mock_bookmark_remove(); mock_cons_show(); + mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "remove", jid, NULL };