aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--irc_commands.c1
-rw-r--r--protocols/account.c1
-rw-r--r--protocols/chat.c192
-rw-r--r--protocols/chat.h51
-rw-r--r--protocols/nogaim.c1
-rw-r--r--root_commands.c1
-rw-r--r--storage_xml.c51
7 files changed, 24 insertions, 274 deletions
diff --git a/irc_commands.c b/irc_commands.c
index 5a0843ec..30518a99 100644
--- a/irc_commands.c
+++ b/irc_commands.c
@@ -26,7 +26,6 @@
#define BITLBEE_CORE
#include "bitlbee.h"
#include "ipc.h"
-#include "chat.h"
static void irc_cmd_pass( irc_t *irc, char **cmd )
{
diff --git a/protocols/account.c b/protocols/account.c
index 0bacea74..ba309b38 100644
--- a/protocols/account.c
+++ b/protocols/account.c
@@ -26,7 +26,6 @@
#define BITLBEE_CORE
#include "bitlbee.h"
#include "account.h"
-#include "chat.h"
account_t *account_add( bee_t *bee, struct prpl *prpl, char *user, char *pass )
{
diff --git a/protocols/chat.c b/protocols/chat.c
deleted file mode 100644
index 8c5ce0bc..00000000
--- a/protocols/chat.c
+++ /dev/null
@@ -1,192 +0,0 @@
- /********************************************************************\
- * BitlBee -- An IRC to other IM-networks gateway *
- * *
- * Copyright 2002-2008 Wilmer van der Gaast and others *
- \********************************************************************/
-
-/* Keep track of chatrooms the user is interested in */
-
-/*
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License with
- the Debian GNU/Linux distribution in /usr/share/common-licenses/GPL;
- if not, write to the Free Software Foundation, Inc., 59 Temple Place,
- Suite 330, Boston, MA 02111-1307 USA
-*/
-
-#include "bitlbee.h"
-#include "chat.h"
-
-struct chat *chat_add( irc_t *irc, account_t *acc, char *handle, char *channel )
-{
- struct chat *c, *l;
- set_t *s;
-
- if( acc->prpl->chat_join == NULL || !chat_chanok( channel ) ||
- chat_chancmp( channel, irc->channel ) == 0 )
- {
- return NULL;
- }
-
- for( c = irc->chatrooms; c; c = c->next )
- {
- if( chat_chancmp( channel, c->channel ) == 0 )
- return NULL;
-
- if( acc == c->acc && g_strcasecmp( handle, c->handle ) == 0 )
- return NULL;
-
- l = c;
- }
-
- if( irc->chatrooms == NULL )
- irc->chatrooms = c = g_new0( struct chat, 1 );
- else
- l->next = c = g_new0( struct chat, 1 );
-
- c->acc = acc;
- c->handle = g_strdup( handle );
- c->channel = g_strdup( channel );
-
- s = set_add( &c->set, "auto_join", "false", set_eval_bool, c );
- /* s = set_add( &c->set, "auto_rejoin", "false", set_eval_bool, c ); */
- s = set_add( &c->set, "nick", NULL, NULL, c );
- s->flags |= SET_NULL_OK;
-
- return c;
-}
-
-struct chat *chat_byhandle( irc_t *irc, account_t *acc, char *handle )
-{
- struct chat *c;
-
- for( c = irc->chatrooms; c; c = c->next )
- {
- if( acc == c->acc && g_strcasecmp( handle, c->handle ) == 0 )
- break;
- }
-
- return c;
-}
-
-struct chat *chat_bychannel( irc_t *irc, char *channel )
-{
- struct chat *c;
-
- for( c = irc->chatrooms; c; c = c->next )
- {
- if( chat_chancmp( channel, c->channel ) == 0 )
- break;
- }
-
- return c;
-}
-
-struct chat *chat_get( irc_t *irc, char *id )
-{
- struct chat *c, *ret = NULL;
- int nr;
-
- if( sscanf( id, "%d", &nr ) == 1 && nr < 1000 )
- {
- for( c = irc->chatrooms; c; c = c->next )
- if( ( nr-- ) == 0 )
- return c;
-
- return NULL;
- }
-
- for( c = irc->chatrooms; c; c = c->next )
- {
- if( strstr( c->handle, id ) )
- {
- if( !ret )
- ret = c;
- else
- return NULL;
- }
- else if( strstr( c->channel, id ) )
- {
- if( !ret )
- ret = c;
- else
- return NULL;
- }
- }
-
- return ret;
-}
-
-int chat_del( irc_t *irc, struct chat *chat )
-{
- struct chat *c, *l = NULL;
-
- for( c = irc->chatrooms; c; c = (l=c)->next )
- if( c == chat )
- break;
-
- if( c == NULL )
- return 0;
- else if( l == NULL )
- irc->chatrooms = c->next;
- else
- l->next = c->next;
-
- while( c->set )
- set_del( &c->set, c->set->key );
-
- g_free( c->handle );
- g_free( c->channel );
- g_free( c );
-
- return 1;
-}
-
-int chat_chancmp( char *a, char *b )
-{
- if( !chat_chanok( a ) || !chat_chanok( b ) )
- return 0;
-
- if( a[0] == b[0] )
- return nick_cmp( a + 1, b + 1 );
- else
- return -1;
-}
-
-int chat_chanok( char *a )
-{
- if( strchr( CTYPES, a[0] ) != NULL )
- return nick_ok( a + 1 );
- else
- return 0;
-}
-
-int chat_join( irc_t *irc, struct chat *c, const char *password )
-{
- struct groupchat *gc;
- char *nick = set_getstr( &c->set, "nick" );
-
- if( c->acc->ic == NULL || c->acc->prpl->chat_join == NULL )
- return 0;
-
- if( nick == NULL )
- nick = irc->nick;
-
- if( ( gc = c->acc->prpl->chat_join( c->acc->ic, c->handle, nick, password ) ) )
- {
- g_free( gc->channel );
- gc->channel = g_strdup( c->channel );
- return 1;
- }
-
- return 0;
-}
diff --git a/protocols/chat.h b/protocols/chat.h
deleted file mode 100644
index 7196aea8..00000000
--- a/protocols/chat.h
+++ /dev/null
@@ -1,51 +0,0 @@
- /********************************************************************\
- * BitlBee -- An IRC to other IM-networks gateway *
- * *
- * Copyright 2002-2008 Wilmer van der Gaast and others *
- \********************************************************************/
-
-/* Keep track of chatrooms the user is interested in */
-
-/*
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License with
- the Debian GNU/Linux distribution in /usr/share/common-licenses/GPL;
- if not, write to the Free Software Foundation, Inc., 59 Temple Place,
- Suite 330, Boston, MA 02111-1307 USA
-*/
-
-#ifndef _CHAT_H
-#define _CHAT_H
-
-struct chat
-{
- account_t *acc;
-
- char *handle;
- char *channel;
- set_t *set;
-
- struct chat *next;
-};
-
-struct chat *chat_add( irc_t *irc, account_t *acc, char *handle, char *channel );
-struct chat *chat_byhandle( irc_t *irc, account_t *acc, char *handle );
-struct chat *chat_bychannel( irc_t *irc, char *channel );
-struct chat *chat_get( irc_t *irc, char *id );
-int chat_del( irc_t *irc, struct chat *chat );
-
-int chat_chancmp( char *a, char *b );
-int chat_chanok( char *a );
-
-int chat_join( irc_t *irc, struct chat *c, const char *password );
-
-#endif
diff --git a/protocols/nogaim.c b/protocols/nogaim.c
index 6ecdfe12..f88ec693 100644
--- a/protocols/nogaim.c
+++ b/protocols/nogaim.c
@@ -35,7 +35,6 @@
#include <ctype.h>
#include "nogaim.h"
-#include "chat.h"
GSList *connections;
diff --git a/root_commands.c b/root_commands.c
index 63f1c867..e075816a 100644
--- a/root_commands.c
+++ b/root_commands.c
@@ -27,7 +27,6 @@
#include "commands.h"
#include "bitlbee.h"
#include "help.h"
-#include "chat.h"
#include <string.h>
diff --git a/storage_xml.c b/storage_xml.c
index 3ce85713..73d77ade 100644
--- a/storage_xml.c
+++ b/storage_xml.c
@@ -28,7 +28,6 @@
#include "base64.h"
#include "arc.h"
#include "md5.h"
-#include "chat.h"
#if GLIB_CHECK_VERSION(2,8,0)
#include <glib/gstdio.h>
@@ -54,7 +53,7 @@ struct xml_parsedata
irc_t *irc;
char *current_setting;
account_t *current_account;
- struct chat *current_chat;
+ irc_channel_t *current_channel;
set_t **current_set_head;
char *given_nick;
char *given_pass;
@@ -175,9 +174,12 @@ static void xml_start_element( GMarkupParseContext *ctx, const gchar *element_na
if( ( setting = xml_attr( attr_names, attr_values, "name" ) ) )
{
+ /*
if( xd->current_chat != NULL )
xd->current_set_head = &xd->current_chat->set;
- else if( xd->current_account != NULL )
+ else
+ */
+ if( xd->current_account != NULL )
xd->current_set_head = &xd->current_account->set;
else
xd->current_set_head = &xd->irc->b->set;
@@ -214,7 +216,24 @@ static void xml_start_element( GMarkupParseContext *ctx, const gchar *element_na
if( xd->current_account && handle && channel )
{
- //xd->current_chat = chat_add( xd->irc, xd->current_account, handle, channel );
+ irc_channel_t *ic;
+ char *acc;
+
+ acc = g_strdup_printf( "%s(%s)",
+ xd->current_account->prpl->name,
+ xd->current_account->user );
+
+ if( ( ic = irc_channel_new( irc, channel ) ) &&
+ set_setstr( &ic->set, "chat_type", "room" ) &&
+ set_setstr( &ic->set, "account", acc ) &&
+ set_setstr( &ic->set, "room", handle ) )
+ {
+ /* Nothing else to do for now, really. */
+ }
+ else if( ic )
+ irc_channel_free( ic );
+
+ g_free( acc );
}
else
{
@@ -244,7 +263,7 @@ static void xml_end_element( GMarkupParseContext *ctx, const gchar *element_name
}
else if( g_strcasecmp( element_name, "chat" ) == 0 )
{
- xd->current_chat = NULL;
+ /* xd->current_chat = NULL; */
}
}
@@ -436,7 +455,6 @@ static storage_status_t xml_save( irc_t *irc, int overwrite )
unsigned char *pass_cr;
char *pass_b64;
int pass_len;
- struct chat *c;
pass_len = arc_encode( acc->pass, strlen( acc->pass ), (unsigned char**) &pass_cr, irc->password, 12 );
pass_b64 = base64_encode( pass_cr, pass_len );
@@ -469,27 +487,6 @@ static storage_status_t xml_save( irc_t *irc, int overwrite )
if( g_hash_table_find( acc->nicks, xml_save_nick, & fd ) )
goto write_error;
-#if 0
- for( c = irc->chatrooms; c; c = c->next )
- {
- if( c->acc != acc )
- continue;
-
- if( !xml_printf( fd, 2, "<chat handle=\"%s\" channel=\"%s\" type=\"%s\">\n",
- c->handle, c->channel, "room" ) )
- goto write_error;
-
- for( set = c->set; set; set = set->next )
- if( set->value && !( set->flags & ACC_SET_NOSAVE ) )
- if( !xml_printf( fd, 3, "<setting name=\"%s\">%s</setting>\n",
- set->key, set->value ) )
- goto write_error;
-
- if( !xml_printf( fd, 2, "</chat>\n" ) )
- goto write_error;
- }
-#endif
-
if( !xml_printf( fd, 1, "</account>\n" ) )
goto write_error;
}