diff options
author | Marius Halden <marius.h@lden.org> | 2016-11-19 10:32:18 +0100 |
---|---|---|
committer | Marius Halden <marius.h@lden.org> | 2016-11-19 10:32:18 +0100 |
commit | 08e1027c558a25b0b4f9410048c185e89c7b347a (patch) | |
tree | c9c80be4e9984bfc52835b0eac0895f6dfc81b14 /storage_xml.c | |
parent | ad5637a3fe2f8e25a88d910041791336e0c62271 (diff) | |
parent | 11d4123fe9a4d88d475bee6c623fb80af8fdbb0b (diff) |
Merge branch 'master' into patched-master
Diffstat (limited to 'storage_xml.c')
-rw-r--r-- | storage_xml.c | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/storage_xml.c b/storage_xml.c index 20f3fe3c..07cdaf0f 100644 --- a/storage_xml.c +++ b/storage_xml.c @@ -59,7 +59,7 @@ static void xml_init(void) } } -static void handle_settings(struct xt_node *node, set_t **head) +static void handle_settings(struct xt_node *node, set_t **head, gboolean add_unknowns) { struct xt_node *c; struct set *s; @@ -72,6 +72,13 @@ static void handle_settings(struct xt_node *node, set_t **head) continue; } + if (add_unknowns && !set_find(head, name)) { + s = set_add(head, name, NULL, NULL, NULL); + s->flags |= ACC_SET_ONLINE_ONLY; + s->value = g_strdup(c->text); + continue; + } + if (strcmp(node->name, "account") == 0) { set_t *s = set_find(head, name); if (s && (s->flags & ACC_SET_ONLINE_ONLY)) { @@ -98,6 +105,7 @@ static xt_status handle_account(struct xt_node *node, gpointer data) struct prpl *prpl = NULL; account_t *acc; struct xt_node *c; + gboolean is_unknown = FALSE; handle = xt_find_attr(node, "handle"); pass_b64 = xt_find_attr(node, "password"); @@ -110,9 +118,10 @@ static xt_status handle_account(struct xt_node *node, gpointer data) if (protocol) { prpl = find_protocol(protocol); if (!prpl) { - irc_rootmsg(xd->irc, "Error loading user config: Protocol not found: `%s'", protocol); - return XT_ABORT; + irc_rootmsg(xd->irc, "Warning: Protocol not found: `%s'", protocol); + prpl = make_unknown_protocol(protocol); } + is_unknown = (prpl->options & PRPL_OPT_UNKNOWN_PROTOCOL) != 0; local = protocol_account_islocal(protocol); } @@ -152,7 +161,7 @@ static xt_status handle_account(struct xt_node *node, gpointer data) g_free(pass_cr); g_free(password); - handle_settings(node, &acc->set); + handle_settings(node, &acc->set, is_unknown); for (c = node->children; (c = xt_find_node(c, "buddy")); c = c->next) { char *handle, *nick; @@ -191,7 +200,7 @@ static xt_status handle_channel(struct xt_node *node, gpointer data) set_setstr(&ic->set, "type", type); } - handle_settings(node, &ic->set); + handle_settings(node, &ic->set, FALSE); return XT_HANDLED; } @@ -269,7 +278,7 @@ static storage_status_t xml_load_real(irc_t *irc, const char *my_nick, const cha ret = STORAGE_OK; } - handle_settings(node, &xd->irc->b->set); + handle_settings(node, &xd->irc->b->set, FALSE); error: xt_free(xp); |