Changeset 7b23afd
- Timestamp:
- 2005-11-07T16:16:18Z (19 years ago)
- Branches:
- master
- Children:
- f7f3ada
- Parents:
- fe51bcf
- Files:
-
- 19 edited
Legend:
- Unmodified
- Added
- Removed
-
account.c
rfe51bcf r7b23afd 28 28 #include "account.h" 29 29 30 account_t *account_add( irc_t *irc, int protocol, char *user, char *pass )30 account_t *account_add( irc_t *irc, struct prpl *prpl, char *user, char *pass ) 31 31 { 32 32 account_t *a; … … 42 42 } 43 43 44 a->pr otocol = protocol;44 a->prpl = prpl; 45 45 a->user = g_strdup( user ); 46 46 a->pass = g_strdup( pass ); … … 66 66 for( a = irc->accounts; a; a = a->next ) 67 67 { 68 if( g_strcasecmp( id, proto_name[a->protocol]) == 0 )68 if( g_strcasecmp( id, a->prpl->name ) == 0 ) 69 69 { 70 70 if( !ret ) … … 124 124 } 125 125 126 if ( proto_prpl[a->protocol]->login== NULL )126 if (a->prpl == NULL ) 127 127 { 128 irc_usermsg( irc, "Support for protocol %s is not included in this BitlBee", proto_name[a->protocol]);128 irc_usermsg( irc, "Support for protocol %s is not included in this BitlBee", a->prpl->name ); 129 129 return; 130 130 } … … 134 134 u = g_new0 ( struct aim_user, 1 ); 135 135 u->irc = irc; 136 u->pr otocol = a->protocol;136 u->prpl = a->prpl; 137 137 strncpy( u->username, a->user, sizeof( u->username ) - 1 ); 138 138 strncpy( u->password, a->pass, sizeof( u->password ) - 1 ); … … 142 142 a->reconnect = 0; 143 143 144 proto_prpl[a->protocol]->login( u );144 a->prpl->login( u ); 145 145 } 146 146 -
account.h
rfe51bcf r7b23afd 29 29 typedef struct account 30 30 { 31 int protocol;31 struct prpl *prpl; 32 32 char *user; 33 33 char *pass; … … 41 41 } account_t; 42 42 43 account_t *account_add( irc_t *irc, int protocol, char *user, char *pass );43 account_t *account_add( irc_t *irc, struct prpl *prpl, char *user, char *pass ); 44 44 account_t *account_get( irc_t *irc, char *id ); 45 45 void account_del( irc_t *irc, account_t *acc ); -
bitlbee.c
rfe51bcf r7b23afd 242 242 } 243 243 244 /* DO NOT USE THIS FUNCTION IN NEW CODE. This 245 * function is here merely because the save/load code still uses 246 * ids rather then names */ 247 struct prpl *find_protocol_by_id(int id) 248 { 249 switch (id) { 250 case 1: return find_protocol("oscar"); 251 case 4: return find_protocol("msn"); 252 case 2: return find_protocol("yahoo"); 253 case 8: return find_protocol("jabber"); 254 default: break; 255 } 256 return NULL; 257 } 258 244 259 int bitlbee_load( irc_t *irc, char* password ) 245 260 { 246 261 char s[512]; 247 262 char *line; 248 int proto;263 char proto[20]; 249 264 char nick[MAX_NICK_LENGTH+1]; 250 265 FILE *fp; … … 281 296 fp = fopen( s, "r" ); 282 297 if( !fp ) return( 0 ); 283 while( fscanf( fp, "%s %d %s", s, &proto, nick ) > 0 ) 284 { 298 while( fscanf( fp, "%s %s %s", s, proto, nick ) > 0 ) 299 { 300 struct prpl *prpl; 301 302 prpl = find_protocol(proto); 303 304 /* Older files saved the protocol number rather then the protocol name */ 305 if (!prpl && atoi(proto)) { 306 prpl = find_protocol_by_id(atoi(proto)); 307 } 308 309 if (!prpl) 310 continue; 311 285 312 http_decode( s ); 286 nick_set( irc, s, pr oto, nick );313 nick_set( irc, s, prpl, nick ); 287 314 } 288 315 fclose( fp ); … … 339 366 s[169] = 0; /* Prevent any overflow (169 ~ 512 / 3) */ 340 367 http_encode( s ); 341 g_snprintf( s + strlen( s ), 510 - strlen( s ), " % d %s", n->proto, n->nick );368 g_snprintf( s + strlen( s ), 510 - strlen( s ), " %s %s", n->proto->name, n->nick ); 342 369 if( fprintf( fp, "%s\n", s ) != strlen( s ) + 1 ) 343 370 { … … 381 408 for( a = irc->accounts; a; a = a->next ) 382 409 { 383 if( a->protocol == PROTO_OSCAR || a->protocol == PROTO_ICQ || a->protocol == PROTO_TOC)410 if( !strcmp( a->prpl->name, "oscar" ) ) 384 411 g_snprintf( s, sizeof( s ), "account add oscar \"%s\" \"%s\" %s", a->user, a->pass, a->server ); 385 412 else 386 413 g_snprintf( s, sizeof( s ), "account add %s \"%s\" \"%s\" \"%s\"", 387 proto_name[a->protocol], a->user, a->pass, a->server ? a->server : "" );414 a->prpl->name, a->user, a->pass, a->server ? a->server : "" ); 388 415 389 416 line = obfucrypt( irc, s ); -
commands.c
rfe51bcf r7b23afd 185 185 if( g_strcasecmp( cmd[1], "add" ) == 0 ) 186 186 { 187 int prot;187 struct prpl *prpl; 188 188 189 189 if( cmd[2] == NULL || cmd[3] == NULL || cmd[4] == NULL ) … … 193 193 } 194 194 195 for( prot = 0; prot < PROTO_MAX; prot ++ ) 196 if( proto_name[prot] && *proto_name[prot] && g_strcasecmp( proto_name[prot], cmd[2] ) == 0 ) 197 break; 198 199 if( ( prot == PROTO_MAX ) || ( proto_prpl[prot] == NULL ) ) 195 prpl = find_protocol(cmd[2]); 196 197 if( prpl == NULL ) 200 198 { 201 199 irc_usermsg( irc, "Unknown protocol" ); … … 203 201 } 204 202 205 if( prot == PROTO_OSCAR && cmd[5] == NULL ) 206 { 207 irc_usermsg( irc, "Not enough parameters" ); 208 return( 0 ); 209 } 210 211 a = account_add( irc, prot, cmd[3], cmd[4] ); 203 a = account_add( irc, prpl, cmd[3], cmd[4] ); 212 204 213 205 if( cmd[5] ) … … 253 245 con = ""; 254 246 255 if( a->protocol == PROTO_OSCAR || a->protocol == PROTO_ICQ || a->protocol == PROTO_TOC ) 256 irc_usermsg( irc, "%2d. OSCAR, %s on %s%s", i, a->user, a->server, con ); 257 else 258 irc_usermsg( irc, "%2d. %s, %s%s", i, proto_name[a->protocol], a->user, con ); 247 irc_usermsg( irc, "%2d. %s, %s%s", i, a->prpl->name, a->user, con ); 259 248 260 249 i ++; … … 373 362 else 374 363 { 375 nick_set( irc, cmd[2], a->gc->pr otocol, cmd[3] );364 nick_set( irc, cmd[2], a->gc->prpl, cmd[3] ); 376 365 } 377 366 } … … 454 443 else if( u->send_handler == buddy_send_handler ) 455 444 { 456 nick_set( irc, u->handle, u->gc->pr otocol, cmd[2] );445 nick_set( irc, u->handle, u->gc->prpl, cmd[2] ); 457 446 } 458 447 … … 665 654 if( online == 1 ) for( u = irc->users; u; u = u->next ) if( u->gc && u->online && !u->away ) 666 655 { 667 g_snprintf( s, 63, "%s@%s (%s)", u->user, u->host, proto_name[u->gc->user->protocol]);656 g_snprintf( s, 63, "%s@%s (%s)", u->user, u->host, u->gc->user->prpl->name ); 668 657 irc_usermsg( irc, "%-16.16s %-40.40s %s", u->nick, s, "Online" ); 669 658 n_online ++; … … 672 661 if( away == 1 ) for( u = irc->users; u; u = u->next ) if( u->gc && u->online && u->away ) 673 662 { 674 g_snprintf( s, 63, "%s@%s (%s)", u->user, u->host, proto_name[u->gc->user->protocol]);663 g_snprintf( s, 63, "%s@%s (%s)", u->user, u->host, u->gc->user->prpl->name ); 675 664 irc_usermsg( irc, "%-16.16s %-40.40s %s", u->nick, s, u->away ); 676 665 n_away ++; … … 679 668 if( offline == 1 ) for( u = irc->users; u; u = u->next ) if( u->gc && !u->online ) 680 669 { 681 g_snprintf( s, 63, "%s@%s (%s)", u->user, u->host, proto_name[u->gc->user->protocol]);670 g_snprintf( s, 63, "%s@%s (%s)", u->user, u->host, u->gc->user->prpl->name ); 682 671 irc_usermsg( irc, "%-16.16s %-40.40s %s", u->nick, s, "Offline" ); 683 672 n_offline ++; … … 785 774 for( n = gc->irc->nicks; n; n = n->next ) 786 775 { 787 if( n->proto == gc->pr otocol && !user_findhandle( gc, n->handle ) )776 if( n->proto == gc->prpl && !user_findhandle( gc, n->handle ) ) 788 777 { 789 778 gc->prpl->add_buddy( gc, n->handle ); -
configure
rfe51bcf r7b23afd 14 14 datadir='$prefix/share/bitlbee/' 15 15 config='/var/lib/bitlbee/' 16 plugindir='$prefix/lib/bitlbee' 16 17 17 18 msn=1 … … 45 46 --mandir=... $mandir 46 47 --datadir=... $datadir 48 --plugindir=... $plugindir 47 49 --config=... $config 48 50 … … 73 75 datadir=`eval echo "$datadir/" | sed 's/\/\{1,\}/\//g'` 74 76 config=`eval echo "$config/" | sed 's/\/\{1,\}/\//g'` 77 plugindir=`eval echo "$plugindir/" | sed 's/\/\{1,\}/\//g'` 75 78 76 79 cat<<EOF>Makefile.settings … … 81 84 MANDIR=$mandir 82 85 DATADIR=$datadir 86 PLUGINDIR=$plugindir 83 87 CONFIG=$config 84 88 … … 101 105 #define ETCDIR "$etcdir" 102 106 #define VARDIR "$datadir" 107 #define PLUGINDIR "$plugindir" 103 108 #define ARCH "$arch" 104 109 #define CPU "$cpu" … … 141 146 if type pkg-config > /dev/null 2>/dev/null && pkg-config glib-2.0; then 142 147 cat<<EOF>>Makefile.settings 143 EFLAGS+=`pkg-config --libs glib-2.0 `144 CFLAGS+=`pkg-config --cflags glib-2.0 `148 EFLAGS+=`pkg-config --libs glib-2.0 gmodule-2.0` 149 CFLAGS+=`pkg-config --cflags glib-2.0 gmodule-2.0` 145 150 EOF 146 151 echo '#define GLIB2' >> config.h -
irc.c
rfe51bcf r7b23afd 1153 1153 if( u->gc ) 1154 1154 irc_reply( irc, 312, "%s %s.%s :%s network", u->nick, u->gc->user->username, 1155 *u->gc->user->proto_opt[0] ? u->gc->user->proto_opt[0] : "", proto_name[u->gc->user->protocol]);1155 *u->gc->user->proto_opt[0] ? u->gc->user->proto_opt[0] : "", u->gc->prpl->name ); 1156 1156 else 1157 1157 irc_reply( irc, 312, "%s %s :%s", u->nick, irc->myhost, IRCD_INFO ); -
nick.c
rfe51bcf r7b23afd 27 27 #include "bitlbee.h" 28 28 29 void nick_set( irc_t *irc, char *handle, intproto, char *nick )29 void nick_set( irc_t *irc, char *handle, struct prpl *proto, char *nick ) 30 30 { 31 31 nick_t *m = NULL, *n = irc->nicks; … … 56 56 } 57 57 58 char *nick_get( irc_t *irc, char *handle, intproto, const char *realname )58 char *nick_get( irc_t *irc, char *handle, struct prpl *proto, const char *realname ) 59 59 { 60 60 static char nick[MAX_NICK_LENGTH+1]; -
nick.h
rfe51bcf r7b23afd 27 27 { 28 28 char *handle; 29 intproto;29 struct prpl *proto; 30 30 char *nick; 31 31 struct __NICK *next; 32 32 } nick_t; 33 33 34 void nick_set( irc_t *irc, char *handle, intproto, char *nick );35 char *nick_get( irc_t *irc, char *handle, intproto, const char *realname );34 void nick_set( irc_t *irc, char *handle, struct prpl *proto, char *nick ); 35 char *nick_get( irc_t *irc, char *handle, struct prpl *proto, const char *realname ); 36 36 void nick_del( irc_t *irc, char *nick ); 37 37 void nick_strip( char *nick ); -
protocols/jabber/jabber.c
rfe51bcf r7b23afd 157 157 #define JCS_CLOSED 3 /* closed */ 158 158 159 160 static char *jabber_name()161 {162 return "Jabber";163 }164 159 165 160 #define STATE_EVT(arg) if(gjc->on_state) { (gjc->on_state)(gjc, (arg) ); } … … 2413 2408 } 2414 2409 2415 static struct prpl *my_protocol = NULL; 2416 2417 void jabber_init(struct prpl *ret) 2418 { 2410 2411 void jabber_init() 2412 { 2413 struct prpl *ret = g_new0(struct prpl, 1); 2414 2419 2415 /* the NULL's aren't required but they're nice to have */ 2420 ret->protocol = PROTO_JABBER; 2421 ret->name = jabber_name; 2416 ret->name = "jabber"; 2422 2417 ret->away_states = jabber_away_states; 2423 2418 ret->actions = jabber_actions; … … 2442 2437 ret->group_buddy = jabber_group_change; 2443 2438 2444 my_protocol = ret;2445 } 2439 register_protocol (ret); 2440 } -
protocols/msn/msn.c
rfe51bcf r7b23afd 26 26 #include "nogaim.h" 27 27 #include "msn.h" 28 29 static struct prpl *my_protocol = NULL;30 28 31 29 static void msn_login( struct aim_user *acct ) … … 375 373 } 376 374 377 void msn_init(struct prpl *ret) 378 { 379 ret->protocol = PROTO_MSN; 375 void msn_init() 376 { 377 struct prpl *ret = g_new0(struct prpl, 1); 378 ret->name = "msn"; 380 379 ret->login = msn_login; 381 380 ret->close = msn_close; … … 399 398 ret->send_typing = msn_send_typing; 400 399 401 my_protocol = ret;402 } 400 register_protocol(ret); 401 } -
protocols/nogaim.c
rfe51bcf r7b23afd 39 39 #include <iconv.h> 40 40 41 struct prpl *proto_prpl[PROTO_MAX];42 char proto_name[PROTO_MAX][8] = { "TOC", "OSCAR", "YAHOO", "ICQ", "MSN", "", "", "", "JABBER", "", "", "", "", "", "", "" };43 44 41 static char *proto_away_alias[7][5] = 45 42 { … … 58 55 GSList *connections; 59 56 57 gboolean load_plugin(char *path) 58 { 59 void (*init_function) (void); 60 61 GModule *mod = g_module_open(path, G_MODULE_BIND_LAZY); 62 63 if(!mod) { 64 log_message(LOGLVL_ERROR, "Can't find `%s', not loading", path); 65 return FALSE; 66 } 67 68 if(!g_module_symbol(mod,"init_plugin",(gpointer *) &init_function)) { 69 log_message(LOGLVL_WARNING, "Can't find function `init_plugin' in `%s'\n", path); 70 return FALSE; 71 } 72 73 init_function(); 74 75 return TRUE; 76 } 60 77 61 78 /* nogaim.c */ 62 79 80 GList *protocols = NULL; 81 82 void register_protocol (struct prpl *p) 83 { 84 protocols = g_list_append(protocols, p); 85 } 86 87 88 struct prpl *find_protocol(const char *name) 89 { 90 GList *gl; 91 for (gl = protocols; gl; gl = gl->next) 92 { 93 struct prpl *proto = gl->data; 94 if(!g_strcasecmp(proto->name, name)) 95 return proto; 96 } 97 return NULL; 98 } 99 100 /* nogaim.c */ 63 101 void nogaim_init() 64 102 { 65 proto_prpl[PROTO_MSN] = g_new0 ( struct prpl, 1 ); 103 GDir *dir; 104 GError *error = NULL; 105 66 106 #ifdef WITH_MSN 67 msn_init( proto_prpl[PROTO_MSN] ); 107 extern void msn_init(); 108 msn_init(); 68 109 #endif 69 110 70 proto_prpl[PROTO_OSCAR] = g_new0( struct prpl, 1 );71 111 #ifdef WITH_OSCAR 72 oscar_init( proto_prpl[PROTO_OSCAR] ); 112 extern void oscar_init(); 113 oscar_init(); 73 114 #endif 74 115 75 proto_prpl[PROTO_YAHOO] = g_new0( struct prpl, 1 );76 116 #ifdef WITH_YAHOO 77 byahoo_init( proto_prpl[PROTO_YAHOO] ); 117 extern void byahoo_init(); 118 byahoo_init(); 78 119 #endif 79 120 80 proto_prpl[PROTO_JABBER] = g_new0( struct prpl, 1 );81 121 #ifdef WITH_JABBER 82 jabber_init( proto_prpl[PROTO_JABBER] ); 122 extern void jabber_init(); 123 jabber_init(); 83 124 #endif 125 126 dir = g_dir_open(PLUGINDIR, 0, &error); 127 128 if (dir) { 129 const gchar *entry; 130 char *path; 131 132 while ((entry = g_dir_read_name(dir))) { 133 path = g_build_filename(PLUGINDIR, entry, NULL); 134 if(!path) { 135 log_message(LOGLVL_WARNING, "Can't build path for %s\n", entry); 136 continue; 137 } 138 139 load_plugin(path); 140 141 g_free(path); 142 } 143 144 g_dir_close(dir); 145 } 84 146 } 85 147 … … 122 184 gc->prpl->set_away( gc, s, away ); 123 185 if( set_getint( gc->irc, "debug" ) ) 124 irc_usermsg( gc->irc, "Setting away state for %s to %s", proto_name[gc->protocol], s );186 irc_usermsg( gc->irc, "Setting away state for %s to %s", gc->prpl->name, s ); 125 187 } 126 188 else … … 168 230 way for now because I don't want to touch the Gaim code too much since 169 231 it's not going to be here for too long anymore. */ 170 int handle_cmp( char *a, char *b, intprotocol )171 { 172 if( protocol == PROTO_TOC || protocol == PROTO_ICQ)232 int handle_cmp( char *a, char *b, struct prpl *protocol ) 233 { 234 if( !strcmp(protocol->name, "oscar") ) 173 235 { 174 236 /* AIM, being teh evil, thinks it's cool that users can put … … 210 272 gc = g_new0( struct gaim_connection, 1 ); 211 273 212 gc->protocol = user->protocol; 213 gc->prpl = proto_prpl[gc->protocol]; 274 gc->prpl = user->prpl; 214 275 g_snprintf( gc->username, sizeof( gc->username ), "%s", user->username ); 215 276 g_snprintf( gc->password, sizeof( gc->password ), "%s", user->password ); … … 254 315 void set_login_progress( struct gaim_connection *gc, int step, char *msg ) 255 316 { 256 irc_usermsg( gc->irc, "%s(%s) - Logging in: %s", proto_name[gc->protocol], gc->username, msg );317 irc_usermsg( gc->irc, "%s(%s) - Logging in: %s", gc->prpl->name, gc->username, msg ); 257 318 } 258 319 … … 260 321 void hide_login_progress( struct gaim_connection *gc, char *msg ) 261 322 { 262 irc_usermsg( gc->irc, "%s(%s) - Login error: %s", proto_name[gc->protocol], gc->username, msg );323 irc_usermsg( gc->irc, "%s(%s) - Login error: %s", gc->prpl->name, gc->username, msg ); 263 324 } 264 325 … … 266 327 void hide_login_progress_error( struct gaim_connection *gc, char *msg ) 267 328 { 268 irc_usermsg( gc->irc, "%s(%s) - Logged out: %s", proto_name[gc->protocol], gc->username, msg );329 irc_usermsg( gc->irc, "%s(%s) - Logged out: %s", gc->prpl->name, gc->username, msg ); 269 330 } 270 331 … … 289 350 strip_html( msg ); 290 351 291 irc_usermsg( gc->irc, "%s(%s) - %s", proto_name[gc->protocol], gc->username, msg );352 irc_usermsg( gc->irc, "%s(%s) - %s", gc->prpl->name, gc->username, msg ); 292 353 } 293 354 … … 314 375 u = user_find( gc->irc, gc->irc->nick ); 315 376 316 irc_usermsg( gc->irc, "%s(%s) - Logged in", proto_name[gc->protocol], gc->username );377 irc_usermsg( gc->irc, "%s(%s) - Logged in", gc->prpl->name, gc->username ); 317 378 318 379 gc->keepalive = g_timeout_add( 60000, send_keepalive, gc ); … … 321 382 if( u && u->away ) proto_away( gc, u->away ); 322 383 323 if( gc->protocol == PROTO_ICQ)384 if( !strcmp(gc->prpl->name, "icq") ) 324 385 { 325 386 for( u = gc->irc->users; u; u = u->next ) … … 361 422 account_t *a; 362 423 363 irc_usermsg( gc->irc, "%s(%s) - Signing off..", proto_name[gc->protocol], gc->username );424 irc_usermsg( gc->irc, "%s(%s) - Signing off..", gc->prpl->name, gc->username ); 364 425 365 426 gaim_input_remove( gc->keepalive ); … … 393 454 { 394 455 int delay = set_getint( irc, "auto_reconnect_delay" ); 395 irc_usermsg( gc->irc, "%s(%s) - Reconnecting in %d seconds..", proto_name[gc->protocol], gc->username, delay);456 irc_usermsg( gc->irc, "%s(%s) - Reconnecting in %d seconds..", gc->prpl->name, gc->username, delay); 396 457 397 458 a->reconnect = 1; … … 449 510 450 511 memset( nick, 0, MAX_NICK_LENGTH + 1 ); 451 strcpy( nick, nick_get( gc->irc, handle, gc->pr otocol, realname ) );512 strcpy( nick, nick_get( gc->irc, handle, gc->prpl, realname ) ); 452 513 453 514 u = user_add( gc->irc, nick ); … … 473 534 else 474 535 { 475 u->host = g_strdup( proto_name[gc->user->protocol]);536 u->host = g_strdup( gc->user->prpl->name ); 476 537 u->user = g_strdup( handle ); 477 538 } … … 567 628 if( set_getint( gc->irc, "debug" ) || g_strcasecmp( set_getstr( gc->irc, "handle_unknown" ), "ignore" ) != 0 ) 568 629 { 569 irc_usermsg( gc->irc, "serv_got_update() for handle %s on connection %s(%s):", handle, proto_name[gc->protocol], gc->username );630 irc_usermsg( gc->irc, "serv_got_update() for handle %s on connection %s(%s):", handle, gc->prpl->name, gc->username ); 570 631 irc_usermsg( gc->irc, "loggedin = %d, type = %d", loggedin, type ); 571 632 } … … 602 663 } 603 664 604 if( ( type & UC_UNAVAILABLE ) && ( gc->protocol == PROTO_OSCAR || gc->protocol == PROTO_TOC) )665 if( ( type & UC_UNAVAILABLE ) && ( !strcmp(gc->prpl->name, "oscar") || !strcmp(gc->prpl->name, "icq")) ) 605 666 { 606 667 u->away = g_strdup( "Away" ); 607 668 } 608 else if( ( type & UC_UNAVAILABLE ) && ( gc->protocol == PROTO_JABBER) )669 else if( ( type & UC_UNAVAILABLE ) && ( !strcmp(gc->prpl->name, "jabber") ) ) 609 670 { 610 671 if( type & UC_DND ) … … 648 709 { 649 710 if( set_getint( irc, "debug" ) ) 650 irc_usermsg( irc, "Ignoring message from unknown handle %s on connection %s(%s)", handle, proto_name[gc->protocol], gc->username );711 irc_usermsg( irc, "Ignoring message from unknown handle %s on connection %s(%s)", handle, gc->prpl->name, gc->username ); 651 712 652 713 return; … … 670 731 else 671 732 { 672 irc_usermsg( irc, "Message from unknown handle %s on connection %s(%s):", handle, proto_name[gc->protocol], gc->username );733 irc_usermsg( irc, "Message from unknown handle %s on connection %s(%s):", handle, gc->prpl->name, gc->username ); 673 734 u = user_find( irc, irc->mynick ); 674 735 } … … 836 897 837 898 /* It might be yourself! */ 838 if( handle_cmp ( handle, b->gc->user->username, b->gc->pr otocol ) == 0 )899 if( handle_cmp ( handle, b->gc->user->username, b->gc->prpl ) == 0 ) 839 900 { 840 901 u = user_find( b->gc->irc, b->gc->irc->nick ); -
protocols/nogaim.h
rfe51bcf r7b23afd 72 72 /* we need to do either oscar or TOC */ 73 73 /* we make this as an int in case if we want to add more protocols later */ 74 int protocol;75 74 struct prpl *prpl; 76 75 guint32 flags; … … 152 151 char user_info[2048]; 153 152 int options; 154 int protocol;153 struct prpl *prpl; 155 154 /* prpls can use this to save information about the user, 156 155 * like which server to connect to, etc */ … … 161 160 }; 162 161 162 struct ft 163 { 164 const char *filename; 165 166 /* Total number of bytes in file */ 167 size_t total_bytes; 168 169 /* Current number of bytes received */ 170 size_t cur_bytes; 171 }; 172 173 struct ft_request 174 { 175 const char *filename; 176 struct gaim_connection *gc; 177 }; 178 179 typedef void (*ft_recv_handler) (struct ft *, void *data, size_t len); 180 163 181 struct prpl { 164 int protocol;165 182 int options; 166 c har *(* name)();183 const char *name; 167 184 168 185 /* for ICQ and Yahoo, who have off/on per-conversation options */ … … 217 234 void (* group_buddy) (struct gaim_connection *, char *who, char *old_group, char *new_group); 218 235 236 /* file transfers */ 237 struct ft_send_req *(* req_send_file) (struct gaim_connection *, const char *file); 238 void (* send_file_part) (struct gaim_connection *, struct ft*, void *data, size_t length); 239 void (* accept_recv_file) (struct gaim_connection *, struct ft*, ft_recv_handler); 240 219 241 void (* buddy_free) (struct buddy *); 220 242 221 243 char *(* get_status_string) (struct gaim_connection *gc, int stat); 222 244 }; 223 224 #define PROTO_TOC 0225 #define PROTO_OSCAR 1226 #define PROTO_YAHOO 2227 #define PROTO_ICQ 3228 #define PROTO_MSN 4229 #define PROTO_IRC 5230 #define PROTO_FTP 6231 #define PROTO_VGATE 7232 #define PROTO_JABBER 8233 #define PROTO_NAPSTER 9234 #define PROTO_ZEPHYR 10235 #define PROTO_GADUGADU 11236 #define PROTO_MAX 16237 238 extern char proto_name[PROTO_MAX][8];239 245 240 246 #define UC_UNAVAILABLE 1 … … 247 253 248 254 G_MODULE_EXPORT GSList *get_connections(); 249 extern struct prpl *proto_prpl[16]; 255 G_MODULE_EXPORT struct prpl *find_protocol(const char *name); 256 G_MODULE_EXPORT void register_protocol(struct prpl *); 250 257 251 258 /* nogaim.c */ … … 259 266 int proto_away( struct gaim_connection *gc, char *away ); 260 267 char *set_eval_away_devoice( irc_t *irc, set_t *set, char *value ); 261 int handle_cmp( char *a, char *b, intprotocol );268 int handle_cmp( char *a, char *b, struct prpl *protocol ); 262 269 263 270 gboolean auto_reconnect( gpointer data ); … … 318 325 G_MODULE_EXPORT void info_string_append(GString *str, char *newline, char *name, char *value); 319 326 320 #ifdef WITH_MSN 321 /* msn.c */ 322 G_MODULE_EXPORT void msn_init( struct prpl *ret ); 323 #endif 324 325 #ifdef WITH_OSCAR 326 /* oscar.c */ 327 G_MODULE_EXPORT void oscar_init( struct prpl *ret ); 328 #endif 329 330 #ifdef WITH_JABBER 331 /* jabber.c */ 332 G_MODULE_EXPORT void jabber_init( struct prpl *ret ); 333 #endif 334 335 #ifdef WITH_YAHOO 336 /* yahoo.c */ 337 G_MODULE_EXPORT void byahoo_init( struct prpl *ret ); 338 #endif 327 /* file transfers */ 328 G_MODULE_EXPORT void ft_progress( struct ft *, int); 329 G_MODULE_EXPORT void ft_incoming( struct ft_request * ); 330 G_MODULE_EXPORT void ft_accepted( struct ft_request *, struct ft *); 331 G_MODULE_EXPORT void ft_denied( struct ft_request *, const char *reason); 339 332 340 333 /* prefs.c */ -
protocols/oscar/oscar.c
rfe51bcf r7b23afd 364 364 odata->icq = TRUE; 365 365 /* this is odd but it's necessary for a proper do_import and do_export */ 366 gc->protocol = PROTO_ICQ;367 366 gc->password[8] = 0; 368 367 } else { 369 gc->protocol = PROTO_TOC;370 368 gc->flags |= OPT_CONN_HTML; 371 369 } … … 2467 2465 } 2468 2466 2469 static struct prpl *my_protocol = NULL; 2470 2471 void oscar_init(struct prpl *ret) { 2472 ret-> protocol = PROTO_OSCAR;2467 void oscar_init() 2468 { 2469 struct prpl *ret = g_new0(struct prpl, 1); 2470 ret->name = "oscar"; 2473 2471 ret->away_states = oscar_away_states; 2474 2472 ret->login = oscar_login; … … 2488 2486 ret->get_status_string = oscar_get_status_string; 2489 2487 2490 my_protocol = ret;2491 } 2488 register_protocol(ret); 2489 } -
protocols/proxy.c
rfe51bcf r7b23afd 50 50 #define GAIM_ERR_COND (G_IO_HUP | G_IO_ERR | G_IO_NVAL) 51 51 52 /*FIXME*53 #ifndef _WIN3254 if (getsockopt(fd, SOL_SOCKET, SO_ERROR, &error, &len) < 0) {55 closesocket(fd);56 g_free(phb);57 return -1;58 }59 fcntl(fd, F_SETFL, 0);60 #endif*/61 62 52 char proxyhost[128] = ""; 63 53 int proxyport = 0; -
protocols/yahoo/yahoo.c
rfe51bcf r7b23afd 64 64 }; 65 65 66 static char *yahoo_name()67 {68 return "Yahoo";69 }70 71 static struct prpl *my_protocol = NULL;72 66 static GSList *byahoo_inputs = NULL; 73 67 static int byahoo_chat_id = 0; … … 396 390 } 397 391 398 void byahoo_init( struct prpl *ret)399 { 400 ret->protocol = PROTO_YAHOO;401 ret->name = yahoo_name;392 void byahoo_init( ) 393 { 394 struct prpl *ret = g_new0(struct prpl, 1); 395 ret->name = "yahoo"; 402 396 403 397 ret->login = byahoo_login; 404 398 ret->close = byahoo_close; 405 399 ret->send_im = byahoo_send_im; 406 ret->send_typing = byahoo_send_typing;407 400 ret->get_info = byahoo_get_info; 408 401 ret->away_states = byahoo_away_states; … … 412 405 ret->remove_buddy = byahoo_remove_buddy; 413 406 ret->get_status_string = byahoo_get_status_string; 407 ret->send_typing = byahoo_send_typing; 414 408 415 409 ret->chat_send = byahoo_chat_send; … … 418 412 ret->chat_open = byahoo_chat_open; 419 413 420 my_protocol = ret;414 register_protocol(ret); 421 415 } 422 416 … … 432 426 yd = gc->proto_data; 433 427 434 if( gc->protocol == PROTO_YAHOO&& yd->y2_id == id )428 if( !strcmp(gc->prpl->name, "yahoo") && yd->y2_id == id ) 435 429 return( gc ); 436 430 } -
query.c
rfe51bcf r7b23afd 149 149 { 150 150 if( q->gc ) 151 irc_usermsg( irc, "Question on %s connection (handle %s):", proto_name[q->gc->protocol], q->gc->username );151 irc_usermsg( irc, "Question on %s connection (handle %s):", q->gc->prpl->name, q->gc->username ); 152 152 else 153 153 irc_usermsg( irc, "Question:" ); -
unix.c
rfe51bcf r7b23afd 48 48 49 49 log_init( ); 50 nogaim_init( ); 51 50 51 nogaim_init(); 52 52 53 CONF_FILE = g_strdup( CONF_FILE_DEF ); 53 54 -
url.h
rfe51bcf r7b23afd 26 26 #include "bitlbee.h" 27 27 28 #define PROTO_HTTP 2 28 #define PROTO_FTP 1 29 #define PROTO_HTTP 2 29 30 #define PROTO_SOCKS4 3 30 31 #define PROTO_SOCKS5 4 -
user.c
rfe51bcf r7b23afd 146 146 while( u ) 147 147 { 148 if( u->gc == gc && u->handle && handle_cmp( u->handle, handle, gc->pr otocol) == 0 )148 if( u->gc == gc && u->handle && handle_cmp( u->handle, handle, gc->prpl) == 0 ) 149 149 break; 150 150 u = u->next;
Note: See TracChangeset
for help on using the changeset viewer.