Changeset 256899f for protocols/jabber/io.c
- Timestamp:
- 2007-11-19T23:16:18Z (16 years ago)
- Branches:
- master
- Children:
- 7df5a08
- Parents:
- cd428e4 (diff), ef5c185 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
protocols/jabber/io.c
rcd428e4 r256899f 44 44 struct jabber_data *jd = ic->proto_data; 45 45 gboolean ret; 46 47 if( jd->flags & JFLAG_XMLCONSOLE ) 48 { 49 char *msg; 50 51 msg = g_strdup_printf( "TX: %s", buf ); 52 imcb_buddy_msg( ic, JABBER_XMLCONSOLE_HANDLE, msg, 0, 0 ); 53 g_free( msg ); 54 } 46 55 47 56 if( jd->tx_len == 0 ) … … 427 436 { 428 437 struct im_connection *ic = data; 429 struct xt_node *c;430 char *s, *type = NULL, *text = NULL;431 438 int allow_reconnect = TRUE; 432 433 for( c = node->children; c; c = c->next ) 434 { 435 if( !( s = xt_find_attr( c, "xmlns" ) ) || 436 strcmp( s, XMLNS_STREAM_ERROR ) != 0 ) 437 continue; 438 439 if( strcmp( c->name, "text" ) != 0 ) 440 { 441 type = c->name; 442 } 443 /* Only use the text if it doesn't have an xml:lang attribute, 444 if it's empty or if it's set to something English. */ 445 else if( !( s = xt_find_attr( c, "xml:lang" ) ) || 446 !*s || strncmp( s, "en", 2 ) == 0 ) 447 { 448 text = c->text; 449 } 450 } 439 struct jabber_error *err; 440 441 err = jabber_error_parse( node, XMLNS_STREAM_ERROR ); 451 442 452 443 /* Tssk... */ 453 if( type == NULL )444 if( err->code == NULL ) 454 445 { 455 446 imcb_error( ic, "Unknown stream error reported by server" ); 456 447 imc_logout( ic, allow_reconnect ); 448 jabber_error_free( err ); 457 449 return XT_ABORT; 458 450 } … … 461 453 should turn off auto-reconnect to make sure we won't get some nasty 462 454 infinite loop! */ 463 if( strcmp( type, "conflict" ) == 0 )455 if( strcmp( err->code, "conflict" ) == 0 ) 464 456 { 465 457 imcb_error( ic, "Account and resource used from a different location" ); … … 468 460 else 469 461 { 470 imcb_error( ic, "Stream error: %s%s%s", type, text ? ": " : "", text ? text : "" ); 471 } 472 462 imcb_error( ic, "Stream error: %s%s%s", err->code, err->text ? ": " : "", 463 err->text ? err->text : "" ); 464 } 465 466 jabber_error_free( err ); 473 467 imc_logout( ic, allow_reconnect ); 474 468 … … 476 470 } 477 471 472 static xt_status jabber_xmlconsole( struct xt_node *node, gpointer data ) 473 { 474 struct im_connection *ic = data; 475 struct jabber_data *jd = ic->proto_data; 476 477 if( jd->flags & JFLAG_XMLCONSOLE ) 478 { 479 char *msg, *pkt; 480 481 pkt = xt_to_string( node ); 482 msg = g_strdup_printf( "RX: %s", pkt ); 483 imcb_buddy_msg( ic, JABBER_XMLCONSOLE_HANDLE, msg, 0, 0 ); 484 g_free( msg ); 485 g_free( pkt ); 486 } 487 488 return XT_NEXT; 489 } 490 478 491 static const struct xt_handler_entry jabber_handlers[] = { 492 { NULL, "stream:stream", jabber_xmlconsole }, 479 493 { "stream:stream", "<root>", jabber_end_of_stream }, 480 494 { "message", "stream:stream", jabber_pkt_message },
Note: See TracChangeset
for help on using the changeset viewer.