mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Merge branch 'master' into plugins
This commit is contained in:
commit
b6d7b4be05
@ -1766,7 +1766,8 @@ cmd_bookmark(gchar **args, struct cmd_help_t help)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (strcmp(cmd, "add") == 0) {
|
if (strcmp(cmd, "add") == 0) {
|
||||||
bookmark_add(jid, nick, autojoin);
|
gboolean added = bookmark_add(jid, nick, autojoin);
|
||||||
|
if (added) {
|
||||||
GString *msg = g_string_new("Bookmark added for ");
|
GString *msg = g_string_new("Bookmark added for ");
|
||||||
g_string_append(msg, jid);
|
g_string_append(msg, jid);
|
||||||
if (nick != NULL) {
|
if (nick != NULL) {
|
||||||
@ -1779,8 +1780,20 @@ cmd_bookmark(gchar **args, struct cmd_help_t help)
|
|||||||
g_string_append(msg, ".");
|
g_string_append(msg, ".");
|
||||||
cons_show(msg->str);
|
cons_show(msg->str);
|
||||||
g_string_free(msg, TRUE);
|
g_string_free(msg, TRUE);
|
||||||
|
} else {
|
||||||
|
cons_show("Bookmark updated for %s.", jid);
|
||||||
|
}
|
||||||
} else if (strcmp(cmd, "remove") == 0) {
|
} else if (strcmp(cmd, "remove") == 0) {
|
||||||
bookmark_remove(jid, autojoin);
|
gboolean removed = bookmark_remove(jid, autojoin);
|
||||||
|
if (removed) {
|
||||||
|
if (autojoin) {
|
||||||
|
cons_show("Autojoin disabled for %s.", jid);
|
||||||
|
} else {
|
||||||
|
cons_show("Bookmark removed for %s.", jid);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
cons_show("No bookmark exists for %s.", jid);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
cons_show("Usage: %s", help.usage);
|
cons_show("Usage: %s", help.usage);
|
||||||
}
|
}
|
||||||
|
@ -133,7 +133,7 @@ autocomplete_get_list(Autocomplete ac)
|
|||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
autocomplete_contains(Autocomplete ac, char *value)
|
autocomplete_contains(Autocomplete ac, const char *value)
|
||||||
{
|
{
|
||||||
GSList *curr = ac->items;
|
GSList *curr = ac->items;
|
||||||
|
|
||||||
|
@ -57,5 +57,5 @@ char * autocomplete_param_no_with_func(char *input, int *size, char *command,
|
|||||||
|
|
||||||
void autocomplete_reset(Autocomplete ac);
|
void autocomplete_reset(Autocomplete ac);
|
||||||
|
|
||||||
gboolean autocomplete_contains(Autocomplete ac, char *value);
|
gboolean autocomplete_contains(Autocomplete ac, const char *value);
|
||||||
#endif
|
#endif
|
||||||
|
@ -58,20 +58,30 @@ bookmark_request(void)
|
|||||||
xmpp_stanza_release(iq);
|
xmpp_stanza_release(iq);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static gboolean
|
||||||
_bookmark_add(const char *jid, const char *nick, gboolean autojoin)
|
_bookmark_add(const char *jid, const char *nick, gboolean autojoin)
|
||||||
{
|
{
|
||||||
|
gboolean added = TRUE;
|
||||||
|
if (autocomplete_contains(bookmark_ac, jid)) {
|
||||||
|
added = FALSE;
|
||||||
|
}
|
||||||
/* TODO: send request */
|
/* TODO: send request */
|
||||||
/* TODO: manage bookmark_list */
|
/* TODO: manage bookmark_list */
|
||||||
|
|
||||||
/* this may be command for modifying */
|
/* this may be command for modifying */
|
||||||
autocomplete_remove(bookmark_ac, jid);
|
autocomplete_remove(bookmark_ac, jid);
|
||||||
autocomplete_add(bookmark_ac, jid);
|
autocomplete_add(bookmark_ac, jid);
|
||||||
|
|
||||||
|
return added;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static gboolean
|
||||||
_bookmark_remove(const char *jid, gboolean autojoin)
|
_bookmark_remove(const char *jid, gboolean autojoin)
|
||||||
{
|
{
|
||||||
|
gboolean removed = FALSE;
|
||||||
|
if (autocomplete_contains(bookmark_ac, jid)) {
|
||||||
|
removed = TRUE;
|
||||||
|
}
|
||||||
/* TODO: manage bookmark_list */
|
/* TODO: manage bookmark_list */
|
||||||
if (autojoin) {
|
if (autojoin) {
|
||||||
/* TODO: just set autojoin=0 */
|
/* TODO: just set autojoin=0 */
|
||||||
@ -79,6 +89,8 @@ _bookmark_remove(const char *jid, gboolean autojoin)
|
|||||||
/* TODO: send request */
|
/* TODO: send request */
|
||||||
autocomplete_remove(bookmark_ac, jid);
|
autocomplete_remove(bookmark_ac, jid);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return removed;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const GList *
|
static const GList *
|
||||||
|
@ -132,8 +132,8 @@ void (*iq_set_autoping)(int seconds);
|
|||||||
Capabilities* (*caps_get)(const char * const caps_str);
|
Capabilities* (*caps_get)(const char * const caps_str);
|
||||||
void (*caps_close)(void);
|
void (*caps_close)(void);
|
||||||
|
|
||||||
void (*bookmark_add)(const char *jid, const char *nick, gboolean autojoin);
|
gboolean (*bookmark_add)(const char *jid, const char *nick, gboolean autojoin);
|
||||||
void (*bookmark_remove)(const char *jid, gboolean autojoin);
|
gboolean (*bookmark_remove)(const char *jid, gboolean autojoin);
|
||||||
const GList * (*bookmark_get_list)(void);
|
const GList * (*bookmark_get_list)(void);
|
||||||
char * (*bookmark_find)(char *search_str);
|
char * (*bookmark_find)(char *search_str);
|
||||||
void (*bookmark_autocomplete_reset)(void);
|
void (*bookmark_autocomplete_reset)(void);
|
||||||
|
@ -169,7 +169,7 @@ void cmd_bookmark_add_adds_bookmark_with_jid(void **state)
|
|||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_bookmark_add(jid, NULL, FALSE);
|
expect_and_return_bookmark_add(jid, NULL, FALSE, TRUE);
|
||||||
expect_cons_show("Bookmark added for room@conf.server.");
|
expect_cons_show("Bookmark added for room@conf.server.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
@ -189,7 +189,7 @@ void cmd_bookmark_add_adds_bookmark_with_jid_nick(void **state)
|
|||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_bookmark_add(jid, nick, FALSE);
|
expect_and_return_bookmark_add(jid, nick, FALSE, TRUE);
|
||||||
expect_cons_show("Bookmark added for room@conf.server, nickname: bob.");
|
expect_cons_show("Bookmark added for room@conf.server, nickname: bob.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
@ -208,7 +208,7 @@ void cmd_bookmark_add_adds_bookmark_with_jid_autojoin(void **state)
|
|||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_bookmark_add(jid, NULL, TRUE);
|
expect_and_return_bookmark_add(jid, NULL, TRUE, TRUE);
|
||||||
expect_cons_show("Bookmark added for room@conf.server, autojoin enabled.");
|
expect_cons_show("Bookmark added for room@conf.server, autojoin enabled.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
@ -228,7 +228,7 @@ void cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin(void **state)
|
|||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_bookmark_add(jid, nick, TRUE);
|
expect_and_return_bookmark_add(jid, nick, TRUE, TRUE);
|
||||||
expect_cons_show("Bookmark added for room@conf.server, nickname: bob, autojoin enabled.");
|
expect_cons_show("Bookmark added for room@conf.server, nickname: bob, autojoin enabled.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
@ -254,7 +254,7 @@ void cmd_bookmark_add_adds_bookmark_with_room_details(void **state)
|
|||||||
mock_current_win_type(WIN_MUC);
|
mock_current_win_type(WIN_MUC);
|
||||||
ui_current_recipient_returns(jid);
|
ui_current_recipient_returns(jid);
|
||||||
|
|
||||||
expect_bookmark_add(jid, nick, FALSE);
|
expect_and_return_bookmark_add(jid, nick, FALSE, TRUE);
|
||||||
expect_cons_show("Bookmark added for room@conf.server, nickname: bob.");
|
expect_cons_show("Bookmark added for room@conf.server, nickname: bob.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
@ -281,7 +281,7 @@ void cmd_bookmark_add_adds_bookmark_with_room_details_autojoin(void **state)
|
|||||||
mock_current_win_type(WIN_MUC);
|
mock_current_win_type(WIN_MUC);
|
||||||
ui_current_recipient_returns(jid);
|
ui_current_recipient_returns(jid);
|
||||||
|
|
||||||
expect_bookmark_add(jid, nick, TRUE);
|
expect_and_return_bookmark_add(jid, nick, TRUE, TRUE);
|
||||||
expect_cons_show("Bookmark added for room@conf.server, nickname: bob, autojoin enabled.");
|
expect_cons_show("Bookmark added for room@conf.server, nickname: bob, autojoin enabled.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
@ -290,3 +290,98 @@ void cmd_bookmark_add_adds_bookmark_with_room_details_autojoin(void **state)
|
|||||||
free(help);
|
free(help);
|
||||||
muc_close();
|
muc_close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void cmd_bookmark_remove_removes_bookmark(void **state)
|
||||||
|
{
|
||||||
|
mock_bookmark_remove();
|
||||||
|
mock_cons_show();
|
||||||
|
char *jid = "room@conf.server";
|
||||||
|
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||||
|
gchar *args[] = { "remove", jid, NULL };
|
||||||
|
|
||||||
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
|
expect_and_return_bookmark_remove(jid, FALSE, TRUE);
|
||||||
|
expect_cons_show("Bookmark removed for room@conf.server.");
|
||||||
|
|
||||||
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
|
assert_true(result);
|
||||||
|
|
||||||
|
free(help);
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmd_bookmark_remove_removes_autojoin(void **state)
|
||||||
|
{
|
||||||
|
mock_bookmark_remove();
|
||||||
|
mock_cons_show();
|
||||||
|
char *jid = "room@conf.server";
|
||||||
|
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||||
|
gchar *args[] = { "remove", jid, "autojoin", NULL };
|
||||||
|
|
||||||
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
|
expect_and_return_bookmark_remove(jid, TRUE, TRUE);
|
||||||
|
expect_cons_show("Autojoin disabled for room@conf.server.");
|
||||||
|
|
||||||
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
|
assert_true(result);
|
||||||
|
|
||||||
|
free(help);
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmd_bookmark_add_shows_message_when_upated(void **state)
|
||||||
|
{
|
||||||
|
mock_bookmark_add();
|
||||||
|
mock_cons_show();
|
||||||
|
char *jid = "room@conf.server";
|
||||||
|
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||||
|
gchar *args[] = { "add", jid, NULL };
|
||||||
|
|
||||||
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
|
expect_and_return_bookmark_add(jid, NULL, FALSE, FALSE);
|
||||||
|
expect_cons_show("Bookmark updated for room@conf.server.");
|
||||||
|
|
||||||
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
|
assert_true(result);
|
||||||
|
|
||||||
|
free(help);
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmd_bookmark_remove_shows_message_when_no_bookmark(void **state)
|
||||||
|
{
|
||||||
|
mock_bookmark_remove();
|
||||||
|
mock_cons_show();
|
||||||
|
char *jid = "room@conf.server";
|
||||||
|
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||||
|
gchar *args[] = { "remove", jid, NULL };
|
||||||
|
|
||||||
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
|
expect_and_return_bookmark_remove(jid, FALSE, FALSE);
|
||||||
|
expect_cons_show("No bookmark exists for room@conf.server.");
|
||||||
|
|
||||||
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
|
assert_true(result);
|
||||||
|
|
||||||
|
free(help);
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmd_bookmark_remove_autojoin_shows_message_when_no_bookmark(void **state)
|
||||||
|
{
|
||||||
|
mock_bookmark_remove();
|
||||||
|
mock_cons_show();
|
||||||
|
char *jid = "room@conf.server";
|
||||||
|
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||||
|
gchar *args[] = { "remove", jid, "autojoin", NULL };
|
||||||
|
|
||||||
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
|
expect_and_return_bookmark_remove(jid, TRUE, FALSE);
|
||||||
|
expect_cons_show("No bookmark exists for room@conf.server.");
|
||||||
|
|
||||||
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
|
assert_true(result);
|
||||||
|
|
||||||
|
free(help);
|
||||||
|
}
|
||||||
|
@ -13,3 +13,8 @@ void cmd_bookmark_add_adds_bookmark_with_jid_autojoin(void **state);
|
|||||||
void cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin(void **state);
|
void cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin(void **state);
|
||||||
void cmd_bookmark_add_adds_bookmark_with_room_details(void **state);
|
void cmd_bookmark_add_adds_bookmark_with_room_details(void **state);
|
||||||
void cmd_bookmark_add_adds_bookmark_with_room_details_autojoin(void **state);
|
void cmd_bookmark_add_adds_bookmark_with_room_details_autojoin(void **state);
|
||||||
|
void cmd_bookmark_remove_removes_bookmark(void **state);
|
||||||
|
void cmd_bookmark_remove_removes_autojoin(void **state);
|
||||||
|
void cmd_bookmark_add_shows_message_when_upated(void **state);
|
||||||
|
void cmd_bookmark_remove_shows_message_when_no_bookmark(void **state);
|
||||||
|
void cmd_bookmark_remove_autojoin_shows_message_when_no_bookmark(void **state);
|
||||||
|
@ -454,6 +454,11 @@ int main(int argc, char* argv[]) {
|
|||||||
unit_test(cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin),
|
unit_test(cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin),
|
||||||
unit_test(cmd_bookmark_add_adds_bookmark_with_room_details),
|
unit_test(cmd_bookmark_add_adds_bookmark_with_room_details),
|
||||||
unit_test(cmd_bookmark_add_adds_bookmark_with_room_details_autojoin),
|
unit_test(cmd_bookmark_add_adds_bookmark_with_room_details_autojoin),
|
||||||
|
unit_test(cmd_bookmark_remove_removes_bookmark),
|
||||||
|
unit_test(cmd_bookmark_remove_removes_autojoin),
|
||||||
|
unit_test(cmd_bookmark_add_shows_message_when_upated),
|
||||||
|
unit_test(cmd_bookmark_remove_shows_message_when_no_bookmark),
|
||||||
|
unit_test(cmd_bookmark_remove_autojoin_shows_message_when_no_bookmark),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -64,12 +64,21 @@ _mock_bookmark_get_list(void)
|
|||||||
return (GList *)mock();
|
return (GList *)mock();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static gboolean
|
||||||
_mock_bookmark_add(const char *jid, const char *nick, gboolean autojoin)
|
_mock_bookmark_add(const char *jid, const char *nick, gboolean autojoin)
|
||||||
{
|
{
|
||||||
check_expected(jid);
|
check_expected(jid);
|
||||||
check_expected(nick);
|
check_expected(nick);
|
||||||
check_expected(autojoin);
|
check_expected(autojoin);
|
||||||
|
return (gboolean)mock();
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
_mock_bookmark_remove(const char *jid, gboolean autojoin)
|
||||||
|
{
|
||||||
|
check_expected(jid);
|
||||||
|
check_expected(autojoin);
|
||||||
|
return (gboolean)mock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -103,6 +112,12 @@ mock_bookmark_add(void)
|
|||||||
bookmark_add = _mock_bookmark_add;
|
bookmark_add = _mock_bookmark_add;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
mock_bookmark_remove(void)
|
||||||
|
{
|
||||||
|
bookmark_remove = _mock_bookmark_remove;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
bookmark_get_list_returns(GList *bookmarks)
|
bookmark_get_list_returns(GList *bookmarks)
|
||||||
{
|
{
|
||||||
@ -181,7 +196,8 @@ presence_update_expect(resource_presence_t presence, char *msg, int idle)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
expect_bookmark_add(char *expected_jid, char *expected_nick, gboolean expected_autojoin)
|
expect_and_return_bookmark_add(char *expected_jid, char *expected_nick,
|
||||||
|
gboolean expected_autojoin, gboolean added)
|
||||||
{
|
{
|
||||||
expect_string(_mock_bookmark_add, jid, expected_jid);
|
expect_string(_mock_bookmark_add, jid, expected_jid);
|
||||||
if (expected_nick != NULL) {
|
if (expected_nick != NULL) {
|
||||||
@ -190,4 +206,16 @@ expect_bookmark_add(char *expected_jid, char *expected_nick, gboolean expected_a
|
|||||||
expect_any(_mock_bookmark_add, nick);
|
expect_any(_mock_bookmark_add, nick);
|
||||||
}
|
}
|
||||||
expect_value(_mock_bookmark_add, autojoin, expected_autojoin);
|
expect_value(_mock_bookmark_add, autojoin, expected_autojoin);
|
||||||
|
|
||||||
|
will_return(_mock_bookmark_add, added);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
expect_and_return_bookmark_remove(char *expected_jid, gboolean expected_autojoin,
|
||||||
|
gboolean removed)
|
||||||
|
{
|
||||||
|
expect_string(_mock_bookmark_remove, jid, expected_jid);
|
||||||
|
expect_value(_mock_bookmark_remove, autojoin, expected_autojoin);
|
||||||
|
|
||||||
|
will_return(_mock_bookmark_remove, removed);
|
||||||
}
|
}
|
||||||
|
@ -24,6 +24,11 @@ void presence_update_expect(resource_presence_t presence, char *msg, int idle);
|
|||||||
void bookmark_get_list_returns(GList *bookmarks);
|
void bookmark_get_list_returns(GList *bookmarks);
|
||||||
|
|
||||||
void mock_bookmark_add(void);
|
void mock_bookmark_add(void);
|
||||||
void expect_bookmark_add(char *expected_jid, char *expected_nick, gboolean expected_autojoin);
|
void expect_and_return_bookmark_add(char *expected_jid, char *expected_nick,
|
||||||
|
gboolean expected_autojoin, gboolean added);
|
||||||
|
|
||||||
|
void mock_bookmark_remove(void);
|
||||||
|
void expect_and_return_bookmark_remove(char *expected_jid, gboolean expected_autojoin,
|
||||||
|
gboolean removed);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user