aboutsummaryrefslogtreecommitdiffstats
path: root/protocols/bee.c
diff options
context:
space:
mode:
authorWilmer van der Gaast <wilmer@gaast.net>2010-03-26 21:57:00 -0400
committerWilmer van der Gaast <wilmer@gaast.net>2010-03-26 21:57:00 -0400
commitebaebfe35c82460581fa6db518d8848996c9a0f4 (patch)
tree6b0aab8542a40e7af5999b940f60374d808df887 /protocols/bee.c
parent3ddb7477f51d3cf1632e2a8b6f7da4c0609a52cb (diff)
PING and QUIT work now, and adding some files that weren't checked in so
far.
Diffstat (limited to 'protocols/bee.c')
-rw-r--r--protocols/bee.c47
1 files changed, 47 insertions, 0 deletions
diff --git a/protocols/bee.c b/protocols/bee.c
new file mode 100644
index 00000000..c6f48901
--- /dev/null
+++ b/protocols/bee.c
@@ -0,0 +1,47 @@
+#include "bitlbee.h"
+
+bee_t *bee_new()
+{
+ bee_t *b = g_new0( bee_t, 1 );
+ set_t *s;
+
+ s = set_add( &b->set, "away", NULL, NULL/*set_eval_away_status*/, b );
+ s->flags |= SET_NULL_OK;
+ s = set_add( &b->set, "auto_connect", "true", set_eval_bool, b );
+ s = set_add( &b->set, "auto_reconnect", "true", set_eval_bool, b );
+ s = set_add( &b->set, "auto_reconnect_delay", "5*3<900", NULL/*set_eval_account_reconnect_delay*/, b );
+ s = set_add( &b->set, "debug", "false", set_eval_bool, b );
+ s = set_add( &b->set, "password", NULL, NULL/*set_eval_password*/, b );
+ s->flags |= SET_NULL_OK;
+ s = set_add( &b->set, "save_on_quit", "true", set_eval_bool, b );
+ s = set_add( &b->set, "status", NULL, NULL/*set_eval_away_status*/, b );
+ s->flags |= SET_NULL_OK;
+ s = set_add( &b->set, "strip_html", "true", NULL, b );
+
+ return b;
+}
+
+void bee_free( bee_t *b )
+{
+ while( b->accounts )
+ {
+ account_t *acc = b->accounts->data;
+
+ /*
+ if( acc->ic )
+ imc_logout( acc->ic, FALSE );
+ else if( acc->reconnect )
+ cancel_auto_reconnect( acc );
+ */
+
+ if( acc->ic == NULL )
+ {} //account_del( b, acc );
+ else
+ /* Nasty hack, but account_del() doesn't work in this
+ case and we don't want infinite loops, do we? ;-) */
+ b->accounts = g_slist_remove( b->accounts, acc );
+ }
+
+ while( b->set )
+ set_del( &b->set, b->set->key );
+}