aboutsummaryrefslogtreecommitdiffstats
path: root/storage_xml.c
diff options
context:
space:
mode:
authorMarius Halden <marius.h@lden.org>2016-11-19 10:32:18 +0100
committerMarius Halden <marius.h@lden.org>2016-11-19 10:32:18 +0100
commit08e1027c558a25b0b4f9410048c185e89c7b347a (patch)
treec9c80be4e9984bfc52835b0eac0895f6dfc81b14 /storage_xml.c
parentad5637a3fe2f8e25a88d910041791336e0c62271 (diff)
parent11d4123fe9a4d88d475bee6c623fb80af8fdbb0b (diff)
Merge branch 'master' into patched-master
Diffstat (limited to 'storage_xml.c')
-rw-r--r--storage_xml.c21
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);