mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Refactored bookmarks to use option parser, allow bookmarking rooms with passwords
This commit is contained in:
parent
a519d25e4b
commit
d2662a6f17
@ -300,12 +300,19 @@ static struct cmd_t command_defs[] =
|
|||||||
NULL } } },
|
NULL } } },
|
||||||
|
|
||||||
{ "/bookmark",
|
{ "/bookmark",
|
||||||
cmd_bookmark, parse_args, 0, 4, NULL,
|
cmd_bookmark, parse_args, 1, 8, NULL,
|
||||||
{ "/bookmark [add|list|remove] [room@server] [autojoin] [nick]",
|
{ "/bookmark list|add|update|remove|join [room@server] [nick value] [password value] [autojoin on|off]", "Manage bookmarks.",
|
||||||
"Manage bookmarks.",
|
{ "/bookmark list|add|update|remove|join [room@server] [nick value] [password value] [autojoin on|off]",
|
||||||
{ "/bookmark [add|list|remove] [room@server] [autojoin] [nick]",
|
|
||||||
"-----------------------------------------------------------",
|
"-----------------------------------------------------------",
|
||||||
"Manage bookmarks.",
|
"Manage bookmarks.",
|
||||||
|
"list: List all bookmarks.",
|
||||||
|
"add: Add a bookmark for room@server with the following optional properties:",
|
||||||
|
" nick: Nickname used in the chat room",
|
||||||
|
" password: Password for private rooms, note this may be stored in plaintext on your server",
|
||||||
|
" autojoin: Whether to join the room automatically on login \"on\" or \"off\".",
|
||||||
|
"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.",
|
||||||
NULL } } },
|
NULL } } },
|
||||||
|
|
||||||
{ "/disco",
|
{ "/disco",
|
||||||
@ -1057,9 +1064,11 @@ cmd_init(void)
|
|||||||
autocomplete_add(who_ac, "any");
|
autocomplete_add(who_ac, "any");
|
||||||
|
|
||||||
bookmark_ac = autocomplete_new();
|
bookmark_ac = autocomplete_new();
|
||||||
autocomplete_add(bookmark_ac, "add");
|
|
||||||
autocomplete_add(bookmark_ac, "list");
|
autocomplete_add(bookmark_ac, "list");
|
||||||
|
autocomplete_add(bookmark_ac, "add");
|
||||||
|
autocomplete_add(bookmark_ac, "update");
|
||||||
autocomplete_add(bookmark_ac, "remove");
|
autocomplete_add(bookmark_ac, "remove");
|
||||||
|
autocomplete_add(bookmark_ac, "join");
|
||||||
|
|
||||||
otr_ac = autocomplete_new();
|
otr_ac = autocomplete_new();
|
||||||
autocomplete_add(otr_ac, "gen");
|
autocomplete_add(otr_ac, "gen");
|
||||||
@ -1651,11 +1660,15 @@ _bookmark_autocomplete(char *input, int *size)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
result = autocomplete_param_with_func(input, size, "/bookmark list", bookmark_find);
|
result = autocomplete_param_with_func(input, size, "/bookmark remove", bookmark_find);
|
||||||
if (result != NULL) {
|
if (result != NULL) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
result = autocomplete_param_with_func(input, size, "/bookmark remove", bookmark_find);
|
result = autocomplete_param_with_func(input, size, "/bookmark join", bookmark_find);
|
||||||
|
if (result != NULL) {
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
result = autocomplete_param_with_func(input, size, "/bookmark update", bookmark_find);
|
||||||
if (result != NULL) {
|
if (result != NULL) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -1734,77 +1734,76 @@ cmd_bookmark(gchar **args, struct cmd_help_t help)
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TODO: /bookmark list room@server */
|
|
||||||
|
|
||||||
if (strcmp(cmd, "list") == 0) {
|
if (strcmp(cmd, "list") == 0) {
|
||||||
const GList *bookmarks = bookmark_get_list();
|
const GList *bookmarks = bookmark_get_list();
|
||||||
cons_show_bookmarks(bookmarks);
|
cons_show_bookmarks(bookmarks);
|
||||||
} else {
|
} else {
|
||||||
gboolean autojoin = FALSE;
|
char *jid = args[1];
|
||||||
gchar *jid = NULL;
|
if (jid == NULL) {
|
||||||
gchar *nick = NULL;
|
cons_show("Usage: %s", help.usage);
|
||||||
int idx = 1;
|
cons_show("");
|
||||||
|
return TRUE;
|
||||||
while (args[idx] != NULL) {
|
|
||||||
gchar *opt = args[idx];
|
|
||||||
|
|
||||||
if (strcmp(opt, "autojoin") == 0) {
|
|
||||||
autojoin = TRUE;
|
|
||||||
} else if (jid == NULL) {
|
|
||||||
jid = opt;
|
|
||||||
} else if (nick == NULL) {
|
|
||||||
nick = opt;
|
|
||||||
} else {
|
|
||||||
cons_show("Usage: %s", help.usage);
|
|
||||||
}
|
|
||||||
|
|
||||||
++idx;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (jid == NULL) {
|
if (strcmp(cmd, "remove") == 0) {
|
||||||
win_type_t win_type = ui_current_win_type();
|
gboolean removed = bookmark_remove(jid);
|
||||||
|
if (removed) {
|
||||||
if (win_type == WIN_MUC) {
|
cons_show("Bookmark removed for %s.", jid);
|
||||||
jid = ui_current_recipient();
|
|
||||||
nick = muc_get_room_nick(jid);
|
|
||||||
} else {
|
} else {
|
||||||
|
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("Usage: %s", help.usage);
|
||||||
|
cons_show("");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strcmp(cmd, "add") == 0) {
|
if (strcmp(cmd, "add") == 0) {
|
||||||
gboolean added = bookmark_add(jid, nick, autojoin);
|
gboolean added = bookmark_add(jid, nick, password, autojoin);
|
||||||
if (added) {
|
if (added) {
|
||||||
GString *msg = g_string_new("Bookmark added for ");
|
cons_show("Bookmark added for %s.", jid);
|
||||||
g_string_append(msg, jid);
|
|
||||||
if (nick != NULL) {
|
|
||||||
g_string_append(msg, ", nickname: ");
|
|
||||||
g_string_append(msg, nick);
|
|
||||||
}
|
|
||||||
if (autojoin) {
|
|
||||||
g_string_append(msg, ", autojoin enabled");
|
|
||||||
}
|
|
||||||
g_string_append(msg, ".");
|
|
||||||
cons_show(msg->str);
|
|
||||||
g_string_free(msg, TRUE);
|
|
||||||
} else {
|
} else {
|
||||||
cons_show("Bookmark updated for %s.", jid);
|
cons_show("Bookmark already exists, use /bookmark update to edit.");
|
||||||
}
|
}
|
||||||
} else if (strcmp(cmd, "remove") == 0) {
|
} else if (strcmp(cmd, "update") == 0) {
|
||||||
gboolean removed = bookmark_remove(jid, autojoin);
|
gboolean updated = bookmark_update(jid, nick, password, autojoin);
|
||||||
if (removed) {
|
if (updated) {
|
||||||
if (autojoin) {
|
cons_show("Bookmark updated.");
|
||||||
cons_show("Autojoin disabled for %s.", jid);
|
|
||||||
} else {
|
|
||||||
cons_show("Bookmark removed for %s.", jid);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
cons_show("No bookmark exists for %s.", jid);
|
cons_show("No bookmark exists for %s.", jid);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
cons_show("Usage: %s", help.usage);
|
cons_show("Usage: %s", help.usage);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
options_destroy(options);
|
||||||
}
|
}
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -663,6 +663,9 @@ _cons_show_bookmarks(const GList *list)
|
|||||||
if (item->autojoin) {
|
if (item->autojoin) {
|
||||||
wprintw(console->win, " (autojoin)");
|
wprintw(console->win, " (autojoin)");
|
||||||
}
|
}
|
||||||
|
if (item->password != NULL) {
|
||||||
|
wprintw(console->win, " (private)");
|
||||||
|
}
|
||||||
wprintw(console->win, "\n");
|
wprintw(console->win, "\n");
|
||||||
list = g_list_next(list);
|
list = g_list_next(list);
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
#include "xmpp/stanza.h"
|
#include "xmpp/stanza.h"
|
||||||
#include "xmpp/xmpp.h"
|
#include "xmpp/xmpp.h"
|
||||||
#include "xmpp/bookmark.h"
|
#include "xmpp/bookmark.h"
|
||||||
|
#include "ui/ui.h"
|
||||||
|
|
||||||
#define BOOKMARK_TIMEOUT 5000
|
#define BOOKMARK_TIMEOUT 5000
|
||||||
/* TODO: replace with a preference */
|
/* TODO: replace with a preference */
|
||||||
@ -83,69 +84,128 @@ bookmark_request(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_bookmark_add(const char *jid, const char *nick, gboolean autojoin)
|
_bookmark_add(const char *jid, const char *nick, const char *password, const char *autojoin_str)
|
||||||
{
|
{
|
||||||
gboolean added = TRUE;
|
|
||||||
if (autocomplete_contains(bookmark_ac, jid)) {
|
if (autocomplete_contains(bookmark_ac, jid)) {
|
||||||
added = FALSE;
|
return FALSE;
|
||||||
}
|
|
||||||
|
|
||||||
/* this may be command for modifying */
|
|
||||||
Bookmark *item = malloc(sizeof(*item));
|
|
||||||
item->jid = strdup(jid);
|
|
||||||
if (nick != NULL) {
|
|
||||||
item->nick = strdup(nick);
|
|
||||||
} else {
|
} else {
|
||||||
item->nick = NULL;
|
Bookmark *item = malloc(sizeof(*item));
|
||||||
|
item->jid = strdup(jid);
|
||||||
|
if (nick != NULL) {
|
||||||
|
item->nick = strdup(nick);
|
||||||
|
} else {
|
||||||
|
item->nick = NULL;
|
||||||
|
}
|
||||||
|
if (password != NULL) {
|
||||||
|
item->password = strdup(password);
|
||||||
|
} else {
|
||||||
|
item->password = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (g_strcmp0(autojoin_str, "on") == 0) {
|
||||||
|
item->autojoin = TRUE;
|
||||||
|
} else {
|
||||||
|
item->autojoin = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
bookmark_list = g_list_append(bookmark_list, item);
|
||||||
|
autocomplete_add(bookmark_ac, jid);
|
||||||
|
_send_bookmarks();
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
}
|
}
|
||||||
item->autojoin = autojoin;
|
|
||||||
|
|
||||||
GList *found = g_list_find_custom(bookmark_list, item, _match_bookmark_by_jid);
|
|
||||||
if (found != NULL) {
|
|
||||||
bookmark_list = g_list_remove_link(bookmark_list, found);
|
|
||||||
_bookmark_item_destroy(found->data);
|
|
||||||
g_list_free(found);
|
|
||||||
}
|
|
||||||
bookmark_list = g_list_append(bookmark_list, item);
|
|
||||||
|
|
||||||
autocomplete_remove(bookmark_ac, jid);
|
|
||||||
autocomplete_add(bookmark_ac, jid);
|
|
||||||
|
|
||||||
_send_bookmarks();
|
|
||||||
|
|
||||||
return added;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_bookmark_remove(const char *jid, gboolean autojoin)
|
_bookmark_update(const char *jid, const char *nick, const char *password, const char *autojoin_str)
|
||||||
{
|
{
|
||||||
Bookmark *item = malloc(sizeof(*item));
|
Bookmark *item = malloc(sizeof(*item));
|
||||||
item->jid = strdup(jid);
|
item->jid = strdup(jid);
|
||||||
item->nick = NULL;
|
item->nick = NULL;
|
||||||
item->autojoin = autojoin;
|
item->password = NULL;
|
||||||
|
item->autojoin = FALSE;
|
||||||
|
|
||||||
|
GList *found = g_list_find_custom(bookmark_list, item, _match_bookmark_by_jid);
|
||||||
|
_bookmark_item_destroy(item);
|
||||||
|
if (found == NULL) {
|
||||||
|
return FALSE;
|
||||||
|
} else {
|
||||||
|
Bookmark *bm = found->data;
|
||||||
|
if (nick != NULL) {
|
||||||
|
free(bm->nick);
|
||||||
|
bm->nick = strdup(nick);
|
||||||
|
}
|
||||||
|
if (password != NULL) {
|
||||||
|
free(bm->password);
|
||||||
|
bm->password = strdup(password);
|
||||||
|
}
|
||||||
|
if (autojoin_str != NULL) {
|
||||||
|
if (g_strcmp0(autojoin_str, "on") == 0) {
|
||||||
|
bm->autojoin = TRUE;
|
||||||
|
} else if (g_strcmp0(autojoin_str, "off") == 0) {
|
||||||
|
bm->autojoin = FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
_send_bookmarks();
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
_bookmark_join(const char *jid)
|
||||||
|
{
|
||||||
|
Bookmark *item = malloc(sizeof(*item));
|
||||||
|
item->jid = strdup(jid);
|
||||||
|
item->nick = NULL;
|
||||||
|
item->password = NULL;
|
||||||
|
item->autojoin = FALSE;
|
||||||
|
|
||||||
|
GList *found = g_list_find_custom(bookmark_list, item, _match_bookmark_by_jid);
|
||||||
|
_bookmark_item_destroy(item);
|
||||||
|
if (found == NULL) {
|
||||||
|
return FALSE;
|
||||||
|
} else {
|
||||||
|
char *account_name = jabber_get_account_name();
|
||||||
|
ProfAccount *account = accounts_get_account(account_name);
|
||||||
|
Bookmark *item = found->data;
|
||||||
|
if (!muc_room_is_active(item->jid)) {
|
||||||
|
char *nick = item->nick;
|
||||||
|
if (nick == NULL) {
|
||||||
|
nick = account->muc_nick;
|
||||||
|
}
|
||||||
|
presence_join_room(item->jid, nick, item->password);
|
||||||
|
muc_join_room(item->jid, nick, item->password, FALSE);
|
||||||
|
account_free(account);
|
||||||
|
} else if (muc_get_roster_received(item->jid)) {
|
||||||
|
ui_room_join(item->jid, TRUE);
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
_bookmark_remove(const char *jid)
|
||||||
|
{
|
||||||
|
Bookmark *item = malloc(sizeof(*item));
|
||||||
|
item->jid = strdup(jid);
|
||||||
|
item->nick = NULL;
|
||||||
|
item->password = NULL;
|
||||||
|
item->autojoin = FALSE;
|
||||||
|
|
||||||
GList *found = g_list_find_custom(bookmark_list, item, _match_bookmark_by_jid);
|
GList *found = g_list_find_custom(bookmark_list, item, _match_bookmark_by_jid);
|
||||||
_bookmark_item_destroy(item);
|
_bookmark_item_destroy(item);
|
||||||
gboolean removed = found != NULL;
|
gboolean removed = found != NULL;
|
||||||
|
|
||||||
if (removed) {
|
if (removed) {
|
||||||
// set autojoin FALSE
|
bookmark_list = g_list_remove_link(bookmark_list, found);
|
||||||
if (autojoin) {
|
_bookmark_item_destroy(found->data);
|
||||||
Bookmark *bookmark = found->data;
|
g_list_free(found);
|
||||||
bookmark->autojoin = FALSE;
|
autocomplete_remove(bookmark_ac, jid);
|
||||||
|
|
||||||
// remove bookmark
|
|
||||||
} else {
|
|
||||||
bookmark_list = g_list_remove_link(bookmark_list, found);
|
|
||||||
_bookmark_item_destroy(found->data);
|
|
||||||
g_list_free(found);
|
|
||||||
autocomplete_remove(bookmark_ac, jid);
|
|
||||||
}
|
|
||||||
|
|
||||||
_send_bookmarks();
|
_send_bookmarks();
|
||||||
|
return TRUE;
|
||||||
|
} else {
|
||||||
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
return removed;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const GList *
|
static const GList *
|
||||||
@ -176,9 +236,11 @@ _bookmark_handle_result(xmpp_conn_t * const conn,
|
|||||||
char *id = (char *)userdata;
|
char *id = (char *)userdata;
|
||||||
xmpp_stanza_t *ptr;
|
xmpp_stanza_t *ptr;
|
||||||
xmpp_stanza_t *nick;
|
xmpp_stanza_t *nick;
|
||||||
|
xmpp_stanza_t *password_st;
|
||||||
char *name;
|
char *name;
|
||||||
char *jid;
|
char *jid;
|
||||||
char *autojoin;
|
char *autojoin;
|
||||||
|
char *password;
|
||||||
gboolean autojoin_val;
|
gboolean autojoin_val;
|
||||||
Jid *my_jid;
|
Jid *my_jid;
|
||||||
Bookmark *item;
|
Bookmark *item;
|
||||||
@ -231,6 +293,17 @@ _bookmark_handle_result(xmpp_conn_t * const conn,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
password = NULL;
|
||||||
|
password_st = xmpp_stanza_get_child_by_name(ptr, "password");
|
||||||
|
if (password_st) {
|
||||||
|
char *tmp;
|
||||||
|
tmp = xmpp_stanza_get_text(password_st);
|
||||||
|
if (tmp) {
|
||||||
|
password = strdup(tmp);
|
||||||
|
xmpp_free(ctx, tmp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
autojoin = xmpp_stanza_get_attribute(ptr, "autojoin");
|
autojoin = xmpp_stanza_get_attribute(ptr, "autojoin");
|
||||||
if (autojoin && (strcmp(autojoin, "1") == 0 || strcmp(autojoin, "true") == 0)) {
|
if (autojoin && (strcmp(autojoin, "1") == 0 || strcmp(autojoin, "true") == 0)) {
|
||||||
autojoin_val = TRUE;
|
autojoin_val = TRUE;
|
||||||
@ -242,6 +315,7 @@ _bookmark_handle_result(xmpp_conn_t * const conn,
|
|||||||
item = malloc(sizeof(*item));
|
item = malloc(sizeof(*item));
|
||||||
item->jid = strdup(jid);
|
item->jid = strdup(jid);
|
||||||
item->nick = name;
|
item->nick = name;
|
||||||
|
item->password = password;
|
||||||
item->autojoin = autojoin_val;
|
item->autojoin = autojoin_val;
|
||||||
bookmark_list = g_list_append(bookmark_list, item);
|
bookmark_list = g_list_append(bookmark_list, item);
|
||||||
|
|
||||||
@ -259,8 +333,8 @@ _bookmark_handle_result(xmpp_conn_t * const conn,
|
|||||||
log_debug("Autojoin %s with nick=%s", jid, name);
|
log_debug("Autojoin %s with nick=%s", jid, name);
|
||||||
room_jid = jid_create_from_bare_and_resource(jid, name);
|
room_jid = jid_create_from_bare_and_resource(jid, name);
|
||||||
if (!muc_room_is_active(room_jid->barejid)) {
|
if (!muc_room_is_active(room_jid->barejid)) {
|
||||||
presence_join_room(jid, name, NULL);
|
presence_join_room(jid, name, password);
|
||||||
muc_join_room(jid, name, NULL, TRUE);
|
muc_join_room(jid, name, password, TRUE);
|
||||||
}
|
}
|
||||||
jid_destroy(room_jid);
|
jid_destroy(room_jid);
|
||||||
} else {
|
} else {
|
||||||
@ -303,6 +377,7 @@ _bookmark_item_destroy(gpointer item)
|
|||||||
|
|
||||||
free(p->jid);
|
free(p->jid);
|
||||||
free(p->nick);
|
free(p->nick);
|
||||||
|
free(p->password);
|
||||||
free(p);
|
free(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -364,6 +439,18 @@ _send_bookmarks(void)
|
|||||||
xmpp_stanza_release(nick_st);
|
xmpp_stanza_release(nick_st);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (bookmark->password != NULL) {
|
||||||
|
xmpp_stanza_t *password_st = xmpp_stanza_new(ctx);
|
||||||
|
xmpp_stanza_set_name(password_st, STANZA_NAME_PASSWORD);
|
||||||
|
xmpp_stanza_t *password_text = xmpp_stanza_new(ctx);
|
||||||
|
xmpp_stanza_set_text(password_text, bookmark->password);
|
||||||
|
xmpp_stanza_add_child(password_st, password_text);
|
||||||
|
xmpp_stanza_add_child(conference, password_st);
|
||||||
|
|
||||||
|
xmpp_stanza_release(password_text);
|
||||||
|
xmpp_stanza_release(password_st);
|
||||||
|
}
|
||||||
|
|
||||||
xmpp_stanza_add_child(storage, conference);
|
xmpp_stanza_add_child(storage, conference);
|
||||||
xmpp_stanza_release(conference);
|
xmpp_stanza_release(conference);
|
||||||
|
|
||||||
@ -383,7 +470,9 @@ void
|
|||||||
bookmark_init_module(void)
|
bookmark_init_module(void)
|
||||||
{
|
{
|
||||||
bookmark_add = _bookmark_add;
|
bookmark_add = _bookmark_add;
|
||||||
|
bookmark_update = _bookmark_update;
|
||||||
bookmark_remove = _bookmark_remove;
|
bookmark_remove = _bookmark_remove;
|
||||||
|
bookmark_join = _bookmark_join;
|
||||||
bookmark_get_list = _bookmark_get_list;
|
bookmark_get_list = _bookmark_get_list;
|
||||||
bookmark_find = _bookmark_find;
|
bookmark_find = _bookmark_find;
|
||||||
bookmark_autocomplete_reset = _bookmark_autocomplete_reset;
|
bookmark_autocomplete_reset = _bookmark_autocomplete_reset;
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
struct bookmark_t {
|
struct bookmark_t {
|
||||||
char *jid;
|
char *jid;
|
||||||
char *nick;
|
char *nick;
|
||||||
|
char *password;
|
||||||
gboolean autojoin;
|
gboolean autojoin;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -59,6 +59,7 @@
|
|||||||
#define STANZA_NAME_FIELD "field"
|
#define STANZA_NAME_FIELD "field"
|
||||||
#define STANZA_NAME_STORAGE "storage"
|
#define STANZA_NAME_STORAGE "storage"
|
||||||
#define STANZA_NAME_NICK "nick"
|
#define STANZA_NAME_NICK "nick"
|
||||||
|
#define STANZA_NAME_PASSWORD "password"
|
||||||
#define STANZA_NAME_CONFERENCE "conference"
|
#define STANZA_NAME_CONFERENCE "conference"
|
||||||
#define STANZA_NAME_VALUE "value"
|
#define STANZA_NAME_VALUE "value"
|
||||||
|
|
||||||
|
@ -132,8 +132,10 @@ 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);
|
||||||
|
|
||||||
gboolean (*bookmark_add)(const char *jid, const char *nick, gboolean autojoin);
|
gboolean (*bookmark_add)(const char *jid, const char *nick, const char *password, const char *autojoin_str);
|
||||||
gboolean (*bookmark_remove)(const char *jid, gboolean autojoin);
|
gboolean (*bookmark_update)(const char *jid, const char *nick, const char *password, const char *autojoin_str);
|
||||||
|
gboolean (*bookmark_remove)(const char *jid);
|
||||||
|
gboolean (*bookmark_join)(const char *jid);
|
||||||
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);
|
||||||
|
@ -125,40 +125,6 @@ void cmd_bookmark_list_shows_bookmarks(void **state)
|
|||||||
g_list_free_full(bookmarks, (GDestroyNotify)_free_bookmark);
|
g_list_free_full(bookmarks, (GDestroyNotify)_free_bookmark);
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmd_bookmark_add_shows_usage_when_no_args_not_muc(void **state)
|
|
||||||
{
|
|
||||||
mock_cons_show();
|
|
||||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
|
||||||
help->usage = "some usage";
|
|
||||||
gchar *args[] = { "add", NULL };
|
|
||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
|
||||||
mock_current_win_type(WIN_CONSOLE);
|
|
||||||
expect_cons_show("Usage: some usage");
|
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
|
||||||
assert_true(result);
|
|
||||||
|
|
||||||
free(help);
|
|
||||||
}
|
|
||||||
|
|
||||||
void cmd_bookmark_remove_shows_message_when_no_args_not_muc(void **state)
|
|
||||||
{
|
|
||||||
mock_cons_show();
|
|
||||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
|
||||||
help->usage = "some usage";
|
|
||||||
gchar *args[] = { "remove", NULL };
|
|
||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
|
||||||
mock_current_win_type(WIN_CONSOLE);
|
|
||||||
expect_cons_show("Usage: some usage");
|
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
|
||||||
assert_true(result);
|
|
||||||
|
|
||||||
free(help);
|
|
||||||
}
|
|
||||||
|
|
||||||
void cmd_bookmark_add_adds_bookmark_with_jid(void **state)
|
void cmd_bookmark_add_adds_bookmark_with_jid(void **state)
|
||||||
{
|
{
|
||||||
mock_bookmark_add();
|
mock_bookmark_add();
|
||||||
@ -169,7 +135,7 @@ void cmd_bookmark_add_adds_bookmark_with_jid(void **state)
|
|||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_and_return_bookmark_add(jid, NULL, FALSE, TRUE);
|
expect_and_return_bookmark_add(jid, NULL, NULL, NULL, 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);
|
||||||
@ -185,12 +151,12 @@ void cmd_bookmark_add_adds_bookmark_with_jid_nick(void **state)
|
|||||||
char *jid = "room@conf.server";
|
char *jid = "room@conf.server";
|
||||||
char *nick = "bob";
|
char *nick = "bob";
|
||||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||||
gchar *args[] = { "add", jid, nick, NULL };
|
gchar *args[] = { "add", jid, "nick", nick, NULL };
|
||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_and_return_bookmark_add(jid, nick, FALSE, TRUE);
|
expect_and_return_bookmark_add(jid, nick, NULL, NULL, TRUE);
|
||||||
expect_cons_show("Bookmark added for room@conf.server, nickname: bob.");
|
expect_cons_show("Bookmark added for room@conf.server.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
assert_true(result);
|
assert_true(result);
|
||||||
@ -204,12 +170,12 @@ void cmd_bookmark_add_adds_bookmark_with_jid_autojoin(void **state)
|
|||||||
mock_cons_show();
|
mock_cons_show();
|
||||||
char *jid = "room@conf.server";
|
char *jid = "room@conf.server";
|
||||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||||
gchar *args[] = { "add", jid, "autojoin", NULL };
|
gchar *args[] = { "add", jid, "autojoin", "on", NULL };
|
||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_and_return_bookmark_add(jid, NULL, TRUE, TRUE);
|
expect_and_return_bookmark_add(jid, NULL, NULL, "on", TRUE);
|
||||||
expect_cons_show("Bookmark added for room@conf.server, autojoin enabled.");
|
expect_cons_show("Bookmark added for room@conf.server.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
assert_true(result);
|
assert_true(result);
|
||||||
@ -224,12 +190,12 @@ void cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin(void **state)
|
|||||||
char *jid = "room@conf.server";
|
char *jid = "room@conf.server";
|
||||||
char *nick = "bob";
|
char *nick = "bob";
|
||||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||||
gchar *args[] = { "add", jid, nick, "autojoin", NULL };
|
gchar *args[] = { "add", jid, "nick", nick, "autojoin", "on", NULL };
|
||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_and_return_bookmark_add(jid, nick, TRUE, TRUE);
|
expect_and_return_bookmark_add(jid, nick, NULL, "on", TRUE);
|
||||||
expect_cons_show("Bookmark added for room@conf.server, nickname: bob, autojoin enabled.");
|
expect_cons_show("Bookmark added for room@conf.server.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
assert_true(result);
|
assert_true(result);
|
||||||
@ -237,60 +203,6 @@ void cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin(void **state)
|
|||||||
free(help);
|
free(help);
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmd_bookmark_add_adds_bookmark_with_room_details(void **state)
|
|
||||||
{
|
|
||||||
mock_bookmark_add();
|
|
||||||
mock_ui_current_recipient();
|
|
||||||
mock_cons_show();
|
|
||||||
char *jid = "room@conf.server";
|
|
||||||
char *nick = "bob";
|
|
||||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
|
||||||
gchar *args[] = { "add", NULL };
|
|
||||||
|
|
||||||
muc_init();
|
|
||||||
muc_join_room(jid, nick, NULL, TRUE);
|
|
||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
|
||||||
mock_current_win_type(WIN_MUC);
|
|
||||||
ui_current_recipient_returns(jid);
|
|
||||||
|
|
||||||
expect_and_return_bookmark_add(jid, nick, FALSE, TRUE);
|
|
||||||
expect_cons_show("Bookmark added for room@conf.server, nickname: bob.");
|
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
|
||||||
assert_true(result);
|
|
||||||
|
|
||||||
free(help);
|
|
||||||
muc_close();
|
|
||||||
}
|
|
||||||
|
|
||||||
void cmd_bookmark_add_adds_bookmark_with_room_details_autojoin(void **state)
|
|
||||||
{
|
|
||||||
mock_bookmark_add();
|
|
||||||
mock_ui_current_recipient();
|
|
||||||
mock_cons_show();
|
|
||||||
char *jid = "room@conf.server";
|
|
||||||
char *nick = "bob";
|
|
||||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
|
||||||
gchar *args[] = { "add", "autojoin", NULL };
|
|
||||||
|
|
||||||
muc_init();
|
|
||||||
muc_join_room(jid, nick, NULL, TRUE);
|
|
||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
|
||||||
mock_current_win_type(WIN_MUC);
|
|
||||||
ui_current_recipient_returns(jid);
|
|
||||||
|
|
||||||
expect_and_return_bookmark_add(jid, nick, TRUE, TRUE);
|
|
||||||
expect_cons_show("Bookmark added for room@conf.server, nickname: bob, autojoin enabled.");
|
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
|
||||||
assert_true(result);
|
|
||||||
|
|
||||||
free(help);
|
|
||||||
muc_close();
|
|
||||||
}
|
|
||||||
|
|
||||||
void cmd_bookmark_remove_removes_bookmark(void **state)
|
void cmd_bookmark_remove_removes_bookmark(void **state)
|
||||||
{
|
{
|
||||||
mock_bookmark_remove();
|
mock_bookmark_remove();
|
||||||
@ -301,7 +213,7 @@ void cmd_bookmark_remove_removes_bookmark(void **state)
|
|||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_and_return_bookmark_remove(jid, FALSE, TRUE);
|
expect_and_return_bookmark_remove(jid, TRUE);
|
||||||
expect_cons_show("Bookmark removed for room@conf.server.");
|
expect_cons_show("Bookmark removed for room@conf.server.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
@ -310,44 +222,6 @@ void cmd_bookmark_remove_removes_bookmark(void **state)
|
|||||||
free(help);
|
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)
|
void cmd_bookmark_remove_shows_message_when_no_bookmark(void **state)
|
||||||
{
|
{
|
||||||
mock_bookmark_remove();
|
mock_bookmark_remove();
|
||||||
@ -358,30 +232,11 @@ void cmd_bookmark_remove_shows_message_when_no_bookmark(void **state)
|
|||||||
|
|
||||||
mock_connection_status(JABBER_CONNECTED);
|
mock_connection_status(JABBER_CONNECTED);
|
||||||
|
|
||||||
expect_and_return_bookmark_remove(jid, FALSE, FALSE);
|
expect_and_return_bookmark_remove(jid, FALSE);
|
||||||
expect_cons_show("No bookmark exists for room@conf.server.");
|
expect_cons_show("No bookmark exists for room@conf.server.");
|
||||||
|
|
||||||
gboolean result = cmd_bookmark(args, *help);
|
gboolean result = cmd_bookmark(args, *help);
|
||||||
assert_true(result);
|
assert_true(result);
|
||||||
|
|
||||||
free(help);
|
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);
|
|
||||||
}
|
|
@ -5,16 +5,9 @@ void cmd_bookmark_shows_message_when_started(void **state);
|
|||||||
void cmd_bookmark_shows_message_when_undefined(void **state);
|
void cmd_bookmark_shows_message_when_undefined(void **state);
|
||||||
void cmd_bookmark_shows_usage_when_no_args(void **state);
|
void cmd_bookmark_shows_usage_when_no_args(void **state);
|
||||||
void cmd_bookmark_list_shows_bookmarks(void **state);
|
void cmd_bookmark_list_shows_bookmarks(void **state);
|
||||||
void cmd_bookmark_add_shows_usage_when_no_args_not_muc(void **state);
|
|
||||||
void cmd_bookmark_remove_shows_message_when_no_args_not_muc(void **state);
|
|
||||||
void cmd_bookmark_add_adds_bookmark_with_jid(void **state);
|
void cmd_bookmark_add_adds_bookmark_with_jid(void **state);
|
||||||
void cmd_bookmark_add_adds_bookmark_with_jid_nick(void **state);
|
void cmd_bookmark_add_adds_bookmark_with_jid_nick(void **state);
|
||||||
void cmd_bookmark_add_adds_bookmark_with_jid_autojoin(void **state);
|
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_autojoin(void **state);
|
|
||||||
void cmd_bookmark_remove_removes_bookmark(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_shows_message_when_no_bookmark(void **state);
|
||||||
void cmd_bookmark_remove_autojoin_shows_message_when_no_bookmark(void **state);
|
|
||||||
|
@ -432,19 +432,12 @@ int main(int argc, char* argv[]) {
|
|||||||
unit_test(cmd_bookmark_shows_message_when_undefined),
|
unit_test(cmd_bookmark_shows_message_when_undefined),
|
||||||
unit_test(cmd_bookmark_shows_usage_when_no_args),
|
unit_test(cmd_bookmark_shows_usage_when_no_args),
|
||||||
unit_test(cmd_bookmark_list_shows_bookmarks),
|
unit_test(cmd_bookmark_list_shows_bookmarks),
|
||||||
unit_test(cmd_bookmark_add_shows_usage_when_no_args_not_muc),
|
|
||||||
unit_test(cmd_bookmark_remove_shows_message_when_no_args_not_muc),
|
|
||||||
unit_test(cmd_bookmark_add_adds_bookmark_with_jid),
|
unit_test(cmd_bookmark_add_adds_bookmark_with_jid),
|
||||||
unit_test(cmd_bookmark_add_adds_bookmark_with_jid_nick),
|
unit_test(cmd_bookmark_add_adds_bookmark_with_jid_nick),
|
||||||
unit_test(cmd_bookmark_add_adds_bookmark_with_jid_autojoin),
|
unit_test(cmd_bookmark_add_adds_bookmark_with_jid_autojoin),
|
||||||
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_autojoin),
|
|
||||||
unit_test(cmd_bookmark_remove_removes_bookmark),
|
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_shows_message_when_no_bookmark),
|
||||||
unit_test(cmd_bookmark_remove_autojoin_shows_message_when_no_bookmark),
|
|
||||||
|
|
||||||
#ifdef HAVE_LIBOTR
|
#ifdef HAVE_LIBOTR
|
||||||
unit_test(cmd_otr_shows_usage_when_no_args),
|
unit_test(cmd_otr_shows_usage_when_no_args),
|
||||||
|
@ -65,19 +65,19 @@ _mock_bookmark_get_list(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_mock_bookmark_add(const char *jid, const char *nick, gboolean autojoin)
|
_mock_bookmark_add(const char *jid, const char *nick, const char *password, const char *autojoin_str)
|
||||||
{
|
{
|
||||||
check_expected(jid);
|
check_expected(jid);
|
||||||
check_expected(nick);
|
check_expected(nick);
|
||||||
check_expected(autojoin);
|
check_expected(password);
|
||||||
|
check_expected(autojoin_str);
|
||||||
return (gboolean)mock();
|
return (gboolean)mock();
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_mock_bookmark_remove(const char *jid, gboolean autojoin)
|
_mock_bookmark_remove(const char *jid)
|
||||||
{
|
{
|
||||||
check_expected(jid);
|
check_expected(jid);
|
||||||
check_expected(autojoin);
|
|
||||||
return (gboolean)mock();
|
return (gboolean)mock();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -258,7 +258,7 @@ presence_update_expect(resource_presence_t presence, char *msg, int idle)
|
|||||||
|
|
||||||
void
|
void
|
||||||
expect_and_return_bookmark_add(char *expected_jid, char *expected_nick,
|
expect_and_return_bookmark_add(char *expected_jid, char *expected_nick,
|
||||||
gboolean expected_autojoin, gboolean added)
|
const char *expected_password, const char *expected_autojoin_str, 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) {
|
||||||
@ -266,17 +266,24 @@ expect_and_return_bookmark_add(char *expected_jid, char *expected_nick,
|
|||||||
} else {
|
} else {
|
||||||
expect_value(_mock_bookmark_add, nick, NULL);
|
expect_value(_mock_bookmark_add, nick, NULL);
|
||||||
}
|
}
|
||||||
expect_value(_mock_bookmark_add, autojoin, expected_autojoin);
|
if (expected_password != NULL) {
|
||||||
|
expect_string(_mock_bookmark_add, password, expected_password);
|
||||||
|
} else {
|
||||||
|
expect_value(_mock_bookmark_add, password, NULL);
|
||||||
|
}
|
||||||
|
if (expected_autojoin_str != NULL) {
|
||||||
|
expect_string(_mock_bookmark_add, autojoin_str, expected_autojoin_str);
|
||||||
|
} else {
|
||||||
|
expect_value(_mock_bookmark_add, autojoin_str, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
will_return(_mock_bookmark_add, added);
|
will_return(_mock_bookmark_add, added);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
expect_and_return_bookmark_remove(char *expected_jid, gboolean expected_autojoin,
|
expect_and_return_bookmark_remove(char *expected_jid, gboolean removed)
|
||||||
gboolean removed)
|
|
||||||
{
|
{
|
||||||
expect_string(_mock_bookmark_remove, jid, expected_jid);
|
expect_string(_mock_bookmark_remove, jid, expected_jid);
|
||||||
expect_value(_mock_bookmark_remove, autojoin, expected_autojoin);
|
|
||||||
|
|
||||||
will_return(_mock_bookmark_remove, removed);
|
will_return(_mock_bookmark_remove, removed);
|
||||||
}
|
}
|
||||||
|
@ -25,11 +25,10 @@ void bookmark_get_list_returns(GList *bookmarks);
|
|||||||
|
|
||||||
void mock_bookmark_add(void);
|
void mock_bookmark_add(void);
|
||||||
void expect_and_return_bookmark_add(char *expected_jid, char *expected_nick,
|
void expect_and_return_bookmark_add(char *expected_jid, char *expected_nick,
|
||||||
gboolean expected_autojoin, gboolean added);
|
char *expected_password, char *expected_autojoin_str, gboolean added);
|
||||||
|
|
||||||
void mock_bookmark_remove(void);
|
void mock_bookmark_remove(void);
|
||||||
void expect_and_return_bookmark_remove(char *expected_jid, gboolean expected_autojoin,
|
void expect_and_return_bookmark_remove(char *expected_jid, gboolean removed);
|
||||||
gboolean removed);
|
|
||||||
|
|
||||||
void message_send_expect(char *message, char *recipient);
|
void message_send_expect(char *message, char *recipient);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user