]> andersk Git - libfaim.git/blobdiff - aim_buddylist.c
Integrated session changes needed for Jabber transport. Lots of changes.
[libfaim.git] / aim_buddylist.c
index b9ac86a4bccdddd73dcc3f05d68c7c085cf8f182..5fdd6464b8c81ce3fd01fde2dc378c0581a98276 100644 (file)
@@ -1,5 +1,5 @@
 
-#include <aim.h>
+#include <faim/aim.h>
 
 /*
  * aim_add_buddy()
@@ -7,7 +7,9 @@
  * Adds a single buddy to your buddy list after login.
  *
  */
-u_long aim_add_buddy(struct aim_conn_t *conn, char *sn )
+u_long aim_add_buddy(struct aim_session_t *sess,
+                    struct aim_conn_t *conn, 
+                    char *sn )
 {
    struct command_tx_struct newpacket;
 
@@ -17,26 +19,26 @@ u_long aim_add_buddy(struct aim_conn_t *conn, char *sn )
    if (conn)
      newpacket.conn = conn;
    else
-     newpacket.conn = aim_getconn_type(AIM_CONN_TYPE_BOS);
+     newpacket.conn = aim_getconn_type(sess, AIM_CONN_TYPE_BOS);
 
    newpacket.lock = 1;
    newpacket.type = 0x0002;
    newpacket.commandlen = 11 + strlen( sn );
    newpacket.data = (char *)malloc( newpacket.commandlen );
 
-   aim_putsnac(newpacket.data, 0x0003, 0x0004, 0x0000, aim_snac_nextid);
+   aim_putsnac(newpacket.data, 0x0003, 0x0004, 0x0000, sess->snac_nextid);
 
    /* length of screenname */ 
    newpacket.data[10] = strlen( sn );
 
    memcpy( &(newpacket.data[11]), sn, strlen( sn ) );
 
-   aim_tx_enqueue( &newpacket );
+   aim_tx_enqueue(sess, &newpacket );
 
    {
       struct aim_snac_t snac;
     
-      snac.id = aim_snac_nextid;
+      snac.id = sess->snac_nextid;
       snac.family = 0x0003;
       snac.type = 0x0004;
       snac.flags = 0x0000;
@@ -44,13 +46,15 @@ u_long aim_add_buddy(struct aim_conn_t *conn, char *sn )
       snac.data = malloc( strlen( sn ) + 1 );
       memcpy( snac.data, sn, strlen( sn ) + 1 );
 
-      aim_newsnac( &snac );
+      aim_newsnac(sess, &snac);
    }
 
-   return( aim_snac_nextid++ );
+   return( sess->snac_nextid++ );
 }
 
-u_long aim_remove_buddy(struct aim_conn_t *conn, char *sn )
+u_long aim_remove_buddy(struct aim_session_t *sess,
+                       struct aim_conn_t *conn, 
+                       char *sn )
 {
    struct command_tx_struct newpacket;
 
@@ -60,26 +64,26 @@ u_long aim_remove_buddy(struct aim_conn_t *conn, char *sn )
    if (conn)
      newpacket.conn = conn;
    else
-     newpacket.conn = aim_getconn_type(AIM_CONN_TYPE_BOS);
+     newpacket.conn = aim_getconn_type(sess, AIM_CONN_TYPE_BOS);
 
    newpacket.lock = 1;
    newpacket.type = 0x0002;
    newpacket.commandlen = 11 + strlen(sn);
    newpacket.data = (char *)malloc( newpacket.commandlen );
 
-   aim_putsnac(newpacket.data, 0x0003, 0x0005, 0x0000, aim_snac_nextid);
+   aim_putsnac(newpacket.data, 0x0003, 0x0005, 0x0000, sess->snac_nextid);
 
    /* length of screenname */ 
    newpacket.data[10] = strlen( sn );
 
    memcpy( &(newpacket.data[11]), sn, strlen( sn ) );
 
-   aim_tx_enqueue( &newpacket );
+   aim_tx_enqueue(sess,  &newpacket );
 
    {
       struct aim_snac_t snac;
     
-      snac.id = aim_snac_nextid;
+      snac.id = sess->snac_nextid;
       snac.family = 0x0003;
       snac.type = 0x0005;
       snac.flags = 0x0000;
@@ -87,9 +91,9 @@ u_long aim_remove_buddy(struct aim_conn_t *conn, char *sn )
       snac.data = malloc( strlen( sn ) + 1 );
       memcpy( snac.data, sn, strlen( sn ) + 1 );
 
-      aim_newsnac( &snac );
+      aim_newsnac(sess, &snac );
    }
 
-   return( aim_snac_nextid++ );
+   return( sess->snac_nextid++ );
 }
 
This page took 0.036825 seconds and 4 git commands to generate.