]> andersk Git - libfaim.git/blobdiff - aim_buddylist.c
Small fixes.
[libfaim.git] / aim_buddylist.c
index 5fdd6464b8c81ce3fd01fde2dc378c0581a98276..6947931c49904070d0f32023aec5204fbe68bc34 100644 (file)
@@ -11,30 +11,24 @@ u_long aim_add_buddy(struct aim_session_t *sess,
                     struct aim_conn_t *conn, 
                     char *sn )
 {
-   struct command_tx_struct newpacket;
+   struct command_tx_struct *newpacket;
+   int i;
 
-   if( !sn )
-      return -1;
+   if(!sn)
+     return -1;
 
-   if (conn)
-     newpacket.conn = conn;
-   else
-     newpacket.conn = aim_getconn_type(sess, AIM_CONN_TYPE_BOS);
+   if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10+1+strlen(sn))))
+     return -1;
 
-   newpacket.lock = 1;
-   newpacket.type = 0x0002;
-   newpacket.commandlen = 11 + strlen( sn );
-   newpacket.data = (char *)malloc( newpacket.commandlen );
+   newpacket->lock = 1;
 
-   aim_putsnac(newpacket.data, 0x0003, 0x0004, 0x0000, sess->snac_nextid);
+   i = aim_putsnac(newpacket->data, 0x0003, 0x0004, 0x0000, sess->snac_nextid);
+   i += aimutil_put8(newpacket->data+i, strlen(sn));
+   i += aimutil_putstr(newpacket->data+i, sn, strlen(sn));
 
-   /* length of screenname */ 
-   newpacket.data[10] = strlen( sn );
-
-   memcpy( &(newpacket.data[11]), sn, strlen( sn ) );
-
-   aim_tx_enqueue(sess, &newpacket );
+   aim_tx_enqueue(sess, newpacket );
 
+#if 0 /* do we really need this code? */
    {
       struct aim_snac_t snac;
     
@@ -48,6 +42,7 @@ u_long aim_add_buddy(struct aim_session_t *sess,
 
       aim_newsnac(sess, &snac);
    }
+#endif
 
    return( sess->snac_nextid++ );
 }
@@ -56,29 +51,23 @@ u_long aim_remove_buddy(struct aim_session_t *sess,
                        struct aim_conn_t *conn, 
                        char *sn )
 {
-   struct command_tx_struct newpacket;
-
-   if( !sn )
-      return -1;
+   struct command_tx_struct *newpacket;
+   int i;
 
-   if (conn)
-     newpacket.conn = conn;
-   else
-     newpacket.conn = aim_getconn_type(sess, AIM_CONN_TYPE_BOS);
+   if(!sn)
+     return -1;
 
-   newpacket.lock = 1;
-   newpacket.type = 0x0002;
-   newpacket.commandlen = 11 + strlen(sn);
-   newpacket.data = (char *)malloc( newpacket.commandlen );
+   if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10+1+strlen(sn))))
+     return -1;
 
-   aim_putsnac(newpacket.data, 0x0003, 0x0005, 0x0000, sess->snac_nextid);
+   newpacket->lock = 1;
 
-   /* length of screenname */ 
-   newpacket.data[10] = strlen( sn );
+   i = aim_putsnac(newpacket->data, 0x0003, 0x0005, 0x0000, sess->snac_nextid);
 
-   memcpy( &(newpacket.data[11]), sn, strlen( sn ) );
+   i += aimutil_put8(newpacket->data+i, strlen(sn));
+   i += aimutil_putstr(newpacket->data+i, sn, strlen(sn));
 
-   aim_tx_enqueue(sess,  &newpacket );
+   aim_tx_enqueue(sess, newpacket);
 
    {
       struct aim_snac_t snac;
This page took 0.032917 seconds and 4 git commands to generate.