Changes in protocols/msn/msn.c [b051d39:c6ca3ee]
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
protocols/msn/msn.c
rb051d39 rc6ca3ee 26 26 #include "nogaim.h" 27 27 #include "msn.h" 28 29 int msn_chat_id; 30 GSList *msn_connections; 31 GSList *msn_switchboards; 28 32 29 33 static char *msn_set_display_name( set_t *set, char *value ); … … 113 117 { 114 118 struct msn_switchboard *sb; 119 struct msn_data *md = ic->proto_data; 115 120 116 121 if( ( sb = msn_sb_by_handle( ic, who ) ) ) … … 121 126 { 122 127 struct msn_message *m; 128 char buf[1024]; 123 129 124 130 /* Create a message. We have to arrange a usable switchboard, and send the message later. */ … … 127 133 m->text = g_strdup( message ); 128 134 129 return msn_sb_write_msg( ic, m ); 135 /* FIXME: *CHECK* the reliability of using spare sb's! */ 136 if( ( sb = msn_sb_spare( ic ) ) ) 137 { 138 debug( "Trying to use a spare switchboard to message %s", who ); 139 140 sb->who = g_strdup( who ); 141 g_snprintf( buf, sizeof( buf ), "CAL %d %s\r\n", ++sb->trId, who ); 142 if( msn_sb_write( sb, buf, strlen( buf ) ) ) 143 { 144 /* He/She should join the switchboard soon, let's queue the message. */ 145 sb->msgq = g_slist_append( sb->msgq, m ); 146 return( 1 ); 147 } 148 } 149 150 debug( "Creating a new switchboard to message %s", who ); 151 152 /* If we reach this line, there was no spare switchboard, so let's make one. */ 153 g_snprintf( buf, sizeof( buf ), "XFR %d SB\r\n", ++md->trId ); 154 if( !msn_write( ic, buf, strlen( buf ) ) ) 155 { 156 g_free( m->who ); 157 g_free( m->text ); 158 g_free( m ); 159 160 return( 0 ); 161 } 162 163 /* And queue the message to md. We'll pick it up when the switchboard comes up. */ 164 md->msgq = g_slist_append( md->msgq, m ); 165 166 /* FIXME: If the switchboard creation fails, the message will not be sent. */ 167 168 return( 1 ); 130 169 } 131 170 … … 139 178 140 179 if( l == NULL ) 141 for( i = 0; *msn_away_state_list[i].code; i ++ ) 142 if( *msn_away_state_list[i].name ) 143 l = g_list_append( l, (void*) msn_away_state_list[i].name ); 180 for( i = 0; msn_away_state_list[i].number > -1; i ++ ) 181 l = g_list_append( l, (void*) msn_away_state_list[i].name ); 144 182 145 183 return l; … … 150 188 char buf[1024]; 151 189 struct msn_data *md = ic->proto_data; 152 153 if( state )154 md->away_state = msn_away_state_by_name( state ) ? :155 msn_away_state_list + 1;190 const struct msn_away_state *st; 191 192 if( strcmp( state, GAIM_AWAY_CUSTOM ) == 0 ) 193 st = msn_away_state_by_name( "Away" ); 156 194 else 157 md->away_state = msn_away_state_list; 158 159 g_snprintf( buf, sizeof( buf ), "CHG %d %s\r\n", ++md->trId, md->away_state->code ); 195 st = msn_away_state_by_name( state ); 196 197 if( !st ) st = msn_away_state_list; 198 md->away_state = st; 199 200 g_snprintf( buf, sizeof( buf ), "CHG %d %s\r\n", ++md->trId, st->code ); 160 201 msn_write( ic, buf, strlen( buf ) ); 161 202 } … … 215 256 { 216 257 struct msn_switchboard *sb; 258 struct msn_data *md = ic->proto_data; 259 char buf[1024]; 217 260 218 261 if( ( sb = msn_sb_by_handle( ic, who ) ) ) … … 224 267 { 225 268 struct msn_message *m; 269 270 if( ( sb = msn_sb_spare( ic ) ) ) 271 { 272 debug( "Trying to reuse an existing switchboard as a groupchat with %s", who ); 273 g_snprintf( buf, sizeof( buf ), "CAL %d %s\r\n", ++sb->trId, who ); 274 if( msn_sb_write( sb, buf, strlen( buf ) ) ) 275 return msn_sb_to_chat( sb ); 276 } 277 278 /* If the stuff above failed for some reason: */ 279 debug( "Creating a new switchboard to groupchat with %s", who ); 280 281 /* Request a new switchboard. */ 282 g_snprintf( buf, sizeof( buf ), "XFR %d SB\r\n", ++md->trId ); 283 if( !msn_write( ic, buf, strlen( buf ) ) ) 284 return( 0 ); 226 285 227 286 /* Create a magic message. This is quite hackish, but who cares? :-P */ … … 230 289 m->text = g_strdup( GROUPCHAT_SWITCHBOARD_MESSAGE ); 231 290 232 msn_sb_write_msg( ic, m ); 233 291 /* Queue the magic message and cross your fingers. */ 292 md->msgq = g_slist_append( md->msgq, m ); 293 294 /* FIXME: Can I try to return something here already? */ 234 295 return NULL; 235 296 }
Note: See TracChangeset
for help on using the changeset viewer.