Mercurial > pidgin.yaz
diff libfaim/faim/aim.h @ 445:e4c34ca88d9b
[gaim-migrate @ 455]
Hehehehehe
Libfaim got updated, gaim got updated. btw, gaim/faim can't sign in yet,
don't ask me why. it's not my fault.
committer: Tailor Script <tailor@pidgin.im>
author | Eric Warmenhoven <eric@warmenhoven.org> |
---|---|
date | Thu, 29 Jun 2000 20:40:28 +0000 |
parents | df984d56efb4 |
children | 6d78b988b479 |
line wrap: on
line diff
--- a/libfaim/faim/aim.h Thu Jun 29 19:38:18 2000 +0000 +++ b/libfaim/faim/aim.h Thu Jun 29 20:40:28 2000 +0000 @@ -10,11 +10,11 @@ #define FAIM_VERSION_MINOR 99 #define FAIM_VERSION_MINORMINOR 0 -#include <faimconfig.h> -#include <aim_cbtypes.h> +#include <faim/faimconfig.h> +#include <faim/aim_cbtypes.h> -#ifndef FAIM_USEPTHREADS -#error pthreads are currently required. +#if !defined(FAIM_USEPTHREADS) && !defined(FAIM_USEFAKELOCKS) +#error pthreads or fakelocks are currently required. #endif #include <stdio.h> @@ -31,6 +31,18 @@ #define faim_mutex_init pthread_mutex_init #define faim_mutex_lock pthread_mutex_lock #define faim_mutex_unlock pthread_mutex_unlock +#elif defined(FAIM_USEFAKELOCKS) +/* + * For platforms without pthreads, we also assume + * we're not linking against a threaded app. Which + * means we don't have to do real locking. The + * macros below do nothing really. They're a joke. + * But they get it to compile. + */ +#define faim_mutex_t char +#define faim_mutex_init(x, y) *x = 0 +#define faim_mutex_lock(x) *x = 1; +#define faim_mutex_unlock(x) *x = 0; #endif #ifdef _WIN32 @@ -56,10 +68,18 @@ #define gethostbyname(x) gethostbyname2(x, AF_INET) #endif +#if !defined(MSG_WAITALL) +#warning FIX YOUR LIBC! MSG_WAITALL is required! +#define MSG_WAITALL 0x100 +#endif + /* * Current Maximum Length for Screen Names (not including NULL) + * + * Currently only names up to 16 characters can be registered + * however it is aparently legal for them to be larger. */ -#define MAXSNLEN 16 +#define MAXSNLEN 32 /* * Current Maximum Length for Instant Messages @@ -74,7 +94,7 @@ * with utterly oversized instant messages! * */ -#define MAXMSGLEN 7988 +#define MAXMSGLEN 7987 /* * Current Maximum Length for Chat Room Messages @@ -154,6 +174,9 @@ #define AIM_CONN_STATUS_RESOLVERR 0x0080 #define AIM_CONN_STATUS_CONNERR 0x0040 +#define AIM_FRAMETYPE_OSCAR 0x0000 +#define AIM_FRAMETYPE_OFT 0x0001 + struct aim_conn_t { int fd; int type; @@ -170,25 +193,43 @@ /* struct for incoming commands */ struct command_rx_struct { - /* byte 1 assumed to always be 0x2a */ - char type; /* type code (byte 2) */ - u_int seqnum; /* sequence number (bytes 3 and 4) */ - u_int commandlen; /* total packet len - 6 (bytes 5 and 6) */ - u_char *data; /* packet data (from 7 byte on) */ - u_int lock; /* 0 = open, !0 = locked */ - u_int handled; /* 0 = new, !0 = been handled */ - u_int nofree; /* 0 = free data on purge, 1 = only unlink */ + unsigned char hdrtype; /* defines which piece of the union to use */ + union { + struct { + char type; + unsigned short seqnum; + } oscar; + struct { + unsigned short type; + unsigned short hdr2len; + unsigned char *hdr2; /* rest of bloated header */ + } oft; + } hdr; + unsigned short commandlen; /* total payload length */ + unsigned char *data; /* packet data (from 7 byte on) */ + unsigned char lock; /* 0 = open, !0 = locked */ + unsigned char handled; /* 0 = new, !0 = been handled */ + unsigned char nofree; /* 0 = free data on purge, 1 = only unlink */ struct aim_conn_t *conn; /* the connection it came in on... */ struct command_rx_struct *next; /* ptr to next struct in list */ }; /* struct for outgoing commands */ struct command_tx_struct { - /* byte 1 assumed to be 0x2a */ - char type; /* type/family code */ - u_int seqnum; /* seqnum dynamically assigned on tx */ - u_int commandlen; /* SNAC length */ - u_char *data; /* packet data */ + unsigned char hdrtype; /* defines which piece of the union to use */ + union { + struct { + unsigned char type; + unsigned short seqnum; + } oscar; + struct { + unsigned short type; + unsigned short hdr2len; + unsigned char *hdr2; + } oft; + } hdr; + u_int commandlen; + u_char *data; u_int lock; /* 0 = open, !0 = locked */ u_int sent; /* 0 = pending, !0 = has been sent */ struct aim_conn_t *conn; @@ -318,7 +359,8 @@ */ int aim_get_command(struct aim_session_t *, struct aim_conn_t *); int aim_rxdispatch(struct aim_session_t *); - +u_long aim_debugconn_sendconnect(struct aim_session_t *sess, + struct aim_conn_t *conn); int aim_logoff(struct aim_session_t *); void aim_conn_kill(struct aim_session_t *sess, struct aim_conn_t **deadconn); @@ -349,17 +391,18 @@ char *ip, char *cookie); void aim_purge_rxqueue(struct aim_session_t *); - +void aim_rxqueue_cleanbyconn(struct aim_session_t *sess, struct aim_conn_t *conn); int aim_parse_unknown(struct aim_session_t *, struct command_rx_struct *command, ...); int aim_parse_missed_im(struct aim_session_t *, struct command_rx_struct *, ...); int aim_parse_last_bad(struct aim_session_t *, struct command_rx_struct *, ...); -struct command_tx_struct *aim_tx_new(int, struct aim_conn_t *, int); + +struct command_tx_struct *aim_tx_new(unsigned short framing, int chan, struct aim_conn_t *conn, int datalen); int aim_tx_enqueue__queuebased(struct aim_session_t *, struct command_tx_struct *); int aim_tx_enqueue__immediate(struct aim_session_t *, struct command_tx_struct *); #define aim_tx_enqueue(x, y) ((*(x->tx_enqueue))(x, y)) -int aim_tx_sendframe(struct command_tx_struct *cur); +int aim_tx_sendframe(struct aim_session_t *sess, struct command_tx_struct *cur); u_int aim_get_next_txseqnum(struct aim_conn_t *); int aim_tx_flushqueue(struct aim_session_t *); int aim_tx_printqueue(struct aim_session_t *); @@ -415,6 +458,7 @@ #define AIM_VISIBILITYCHANGE_DENYADD 0x07 #define AIM_VISIBILITYCHANGE_DENYREMOVE 0x08 +u_long aim_bos_nop(struct aim_session_t *, struct aim_conn_t *); u_long aim_bos_setidle(struct aim_session_t *, struct aim_conn_t *, u_long); u_long aim_bos_changevisibility(struct aim_session_t *, struct aim_conn_t *, int, char *); u_long aim_bos_setbuddylist(struct aim_session_t *, struct aim_conn_t *, char *); @@ -447,6 +491,7 @@ u_long aim_send_im(struct aim_session_t *, struct aim_conn_t *, char *, u_int, char *); int aim_parse_incoming_im_middle(struct aim_session_t *, struct command_rx_struct *); +int aim_parse_outgoing_im_middle(struct aim_session_t *, struct command_rx_struct *); u_long aim_seticbmparam(struct aim_session_t *, struct aim_conn_t *conn); int aim_parse_msgerror_middle(struct aim_session_t *, struct command_rx_struct *); int aim_negchan_middle(struct aim_session_t *sess, struct command_rx_struct *command); @@ -458,21 +503,16 @@ #define AIM_CAPS_CHAT 0x08 #define AIM_CAPS_GETFILE 0x10 #define AIM_CAPS_SENDFILE 0x20 + extern u_char aim_caps[6][16]; +u_short aim_getcap(unsigned char *capblock, int buflen); +int aim_putcap(unsigned char *capblock, int buflen, u_short caps); #define AIM_GETINFO_GENERALINFO 0x00001 #define AIM_GETINFO_AWAYMESSAGE 0x00003 -#define AIM_RENDEZVOUS_VOICE 0x0000 -#define AIM_RENDEZVOUS_FILETRANSFER 0x0001 -#define AIM_RENDEZVOUS_CHAT_EX3 0x0003 -#define AIM_RENDEZVOUS_CHAT_EX4 0x0004 -#define AIM_RENDEZVOUS_CHAT_EX5 0x0005 -#define AIM_RENDEZVOUS_FILETRANSFER_GET 0x0012 - struct aim_msgcookie_t { unsigned char cookie[8]; - unsigned char extended[16]; int type; void *data; time_t addtime; @@ -492,6 +532,7 @@ #define AIM_TRANSFER_DENY_DECLINE 0x0001 #define AIM_TRANSFER_DENY_NOTACCEPTING 0x0002 u_long aim_denytransfer(struct aim_session_t *sess, struct aim_conn_t *conn, char *sender, char *cookie, unsigned short code); +u_long aim_accepttransfer(struct aim_session_t *sess, struct aim_conn_t *conn, char *sender, char *cookie, unsigned short rendid); u_long aim_getinfo(struct aim_session_t *, struct aim_conn_t *, const char *, unsigned short); int aim_extractuserinfo(u_char *, struct aim_userinfo_s *);