diff options
| author | Wilmer van der Gaast <wilmer@gaast.net> | 2010-08-21 18:27:32 +0100 | 
|---|---|---|
| committer | Wilmer van der Gaast <wilmer@gaast.net> | 2010-08-21 18:27:32 +0100 | 
| commit | 327af51a28fe292cfc4a68caa086a13175a69719 (patch) | |
| tree | 09a83946fb22e8577dede332676a7c5f4c7d5d8c | |
| parent | a366cca62d3a55db4f12a94584f7e7f8fa00db02 (diff) | |
Some general cleanup, plus fixing a bug in the memberlist parsing code:
the lists can come in in any order, so parse it *completely* before showing
auth requests.
| -rw-r--r-- | doc/CHANGES | 9 | ||||
| -rw-r--r-- | lib/ssl_gnutls.c | 4 | ||||
| -rw-r--r-- | lib/ssl_openssl.c | 4 | ||||
| -rw-r--r-- | lib/xmltree.c | 12 | ||||
| -rw-r--r-- | protocols/msn/soap.c | 19 | 
5 files changed, 33 insertions, 15 deletions
| diff --git a/doc/CHANGES b/doc/CHANGES index d313c5d3..cfd524dc 100644 --- a/doc/CHANGES +++ b/doc/CHANGES @@ -3,7 +3,7 @@ found in the bzr commit logs, for example you can try:  http://bugs.bitlbee.org/bitlbee/timeline?daysback=90&changeset=on -Version 1.3dev: +Version ...  - For the first time since 2007, a dev snapshot. Like then, this is pretty    stable already (running on testing.bitlbee.org for weeks by now), but not    all planned features for the next major release are ready yet, and there @@ -51,6 +51,11 @@ Version 1.3dev:    * Switching to libpurple should be pretty transparent. See "help purple"      for a list of supported protocols (works only in libpurple-enabled      binaries). +- Rewritten MSN module, implementing MSNP15 instead of the old MSNP8: +  * MSNP8 support from MSN was getting pretty unreliable. There were issues +    with remembering display names and adding contacts/auth requests. +  * Support for sending offline messages. +  * Support for setting and reading status messages.  - Support for file transfers, in and out. /DCC SEND a file to a contact and    it becomes a file transfer, and incoming file transfers become /DCC SENDs    to you. Note that this is mostly useful when combined with libpurple, as @@ -58,7 +63,7 @@ Version 1.3dev:  - Updated Yahoo! module to be in sync again with libyahoo2. This mostly    fixes issues with authorization requests. -Finished 6 Aug 2010 +Finished ...  Version 1.2.8:  - Now always using the AIM-style authentication method for OSCAR connections, diff --git a/lib/ssl_gnutls.c b/lib/ssl_gnutls.c index 15c23dbb..4fc7c33f 100644 --- a/lib/ssl_gnutls.c +++ b/lib/ssl_gnutls.c @@ -188,7 +188,7 @@ int ssl_read( void *conn, char *buf, int len )  	if( st == GNUTLS_E_AGAIN || st == GNUTLS_E_INTERRUPTED )  		ssl_errno = SSL_AGAIN; -	if( getenv( "BITLBEE_DEBUG" ) && st > 0 ) write( 1, buf, st ); +	if( 0 && getenv( "BITLBEE_DEBUG" ) && st > 0 ) write( 1, buf, st );  	return st;  } @@ -209,7 +209,7 @@ int ssl_write( void *conn, const char *buf, int len )  	if( st == GNUTLS_E_AGAIN || st == GNUTLS_E_INTERRUPTED )  		ssl_errno = SSL_AGAIN; -	if( getenv( "BITLBEE_DEBUG" ) && st > 0 ) write( 1, buf, st ); +	if( 0 && getenv( "BITLBEE_DEBUG" ) && st > 0 ) write( 1, buf, st );  	return st;  } diff --git a/lib/ssl_openssl.c b/lib/ssl_openssl.c index 0feed4ca..e0143791 100644 --- a/lib/ssl_openssl.c +++ b/lib/ssl_openssl.c @@ -206,7 +206,7 @@ int ssl_read( void *conn, char *buf, int len )  			ssl_errno = SSL_AGAIN;  	} -	if( getenv( "BITLBEE_DEBUG" ) && st > 0 ) write( 1, buf, st ); +	if( 0 && getenv( "BITLBEE_DEBUG" ) && st > 0 ) write( 1, buf, st );  	return st;  } @@ -223,7 +223,7 @@ int ssl_write( void *conn, const char *buf, int len )  	st = SSL_write( ((struct scd*)conn)->ssl, buf, len ); -	if( getenv( "BITLBEE_DEBUG" ) && st > 0 ) write( 1, buf, st ); +	if( 0 && getenv( "BITLBEE_DEBUG" ) && st > 0 ) write( 1, buf, st );  	ssl_errno = SSL_OK;  	if( st <= 0 ) diff --git a/lib/xmltree.c b/lib/xmltree.c index 3ec7e673..bee9007f 100644 --- a/lib/xmltree.c +++ b/lib/xmltree.c @@ -337,7 +337,11 @@ void xt_print( struct xt_node *node )  	/* Print the attributes */  	for( i = 0; node->attr[i].key; i ++ ) -		printf( " %s=\"%s\"", node->attr[i].key, g_markup_escape_text( node->attr[i].value, -1 ) ); +	{ +		char *v = g_markup_escape_text( node->attr[i].value, -1 ); +		printf( " %s=\"%s\"", node->attr[i].key, v ); +		g_free( v ); +	}  	/* /> in case there's really *nothing* inside this tag, otherwise  	   just >. */ @@ -357,7 +361,11 @@ void xt_print( struct xt_node *node )  	{  		for( i = 0; node->text[i] && isspace( node->text[i] ); i ++ );  		if( node->text[i] ) -			printf( "%s", g_markup_escape_text( node->text, -1 ) ); +		{ +			char *v = g_markup_escape_text( node->text, -1 ); +			printf( "%s", v ); +			g_free( v ); +		}  	}  	if( node->children ) diff --git a/protocols/msn/soap.c b/protocols/msn/soap.c index e67da2a1..8d276108 100644 --- a/protocols/msn/soap.c +++ b/protocols/msn/soap.c @@ -553,17 +553,11 @@ static xt_status msn_soap_memlist_member( struct xt_node *node, gpointer data )  	else if( strcmp( role, "Block" ) == 0 )  		bd->flags |= MSN_BUDDY_BL;  	else if( strcmp( role, "Reverse" ) == 0 ) -	{  		bd->flags |= MSN_BUDDY_RL; -		msn_buddy_ask( bu ); -	}  	else if( strcmp( role, "Pending" ) == 0 ) -	{  		bd->flags |= MSN_BUDDY_PL; -		msn_buddy_ask( bu ); -	} -	printf( "%s %d\n", handle, bd->flags ); +	printf( "%p %s %d\n", bu, handle, bd->flags );  	return XT_HANDLED;  } @@ -782,7 +776,18 @@ static const struct xt_handler_entry msn_soap_addressbook_parser[] = {  static int msn_soap_addressbook_handle_response( struct msn_soap_req_data *soap_req )  { +	GSList *l; +	 +	for( l = soap_req->ic->bee->users; l; l = l->next ) +	{ +		struct bee_user *bu = l->data; +		 +		if( bu->ic == soap_req->ic ) +			msn_buddy_ask( bu ); +	} +	  	msn_auth_got_contact_list( soap_req->ic ); +	  	return MSN_SOAP_OK;  } | 
