diff options
author | Wilmer van der Gaast <wilmer@gaast.net> | 2010-03-26 21:57:00 -0400 |
---|---|---|
committer | Wilmer van der Gaast <wilmer@gaast.net> | 2010-03-26 21:57:00 -0400 |
commit | ebaebfe35c82460581fa6db518d8848996c9a0f4 (patch) | |
tree | 6b0aab8542a40e7af5999b940f60374d808df887 /protocols/bee.c | |
parent | 3ddb7477f51d3cf1632e2a8b6f7da4c0609a52cb (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.c | 47 |
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 ); +} |