Diff for /mqtt/src/Attic/aitmqtt.c between versions 1.1.1.1 and 1.1.1.1.2.8

version 1.1.1.1, 2011/11/07 08:47:16 version 1.1.1.1.2.8, 2011/11/22 12:02:17
Line 1 Line 1
 #include "global.h"  #include "global.h"
   
   
static int mqtt_Errno;#pragma GCC visibility push(hidden)
static char mqtt_Error[STRSIZ]; 
   
   int mqtt_Errno;
   char mqtt_Error[STRSIZ];
   
   #pragma GCC visibility pop
   
 //  //
 // Error maintenance functions ...  // Error maintenance functions ...
 //  //
Line 38  mqtt_SetErr(int eno, char *estr, ...) Line 41  mqtt_SetErr(int eno, char *estr, ...)
   
 // ----------------------------------------------------------  // ----------------------------------------------------------
   
   /*
    * mqtt_msgFree() Free MQTT message
    * @msg = Message buffer
    * @all = !=0 Destroy entire message, if MQTT Message allocated with mqtt_msgAlloc()
    * return: none
    */
   inline void
   mqtt_msgFree(mqtt_msg_t ** __restrict msg, int all)
   {
           if (msg && *msg) {
                   if ((*msg)->msg_base) {
                           free((*msg)->msg_base);
                           (*msg)->msg_base = NULL;
                   }
                   if (all) {
                           free(*msg);
                           *msg = NULL;
                   } else
                           (*msg)->msg_len ^= (*msg)->msg_len;
           }
   }
   
   /*
    * mqtt_msgAlloc() Allocate memory for MQTT Message
    * @len = >0 Allocate buffer with length
    * return: NULL error or Message, after use must call mqtt_msgFree() with all!=0
    */
   inline mqtt_msg_t *
   mqtt_msgAlloc(u_short len)
   {
           mqtt_msg_t *m = NULL;
   
           m = malloc(sizeof(mqtt_msg_t));
           if (!m) {
                   LOGERR;
                   return NULL;
           } else
                   memset(m, 0, sizeof(mqtt_msg_t));
   
           if (len) {
                   m->msg_len = len;
                   m->msg_base = malloc(m->msg_len);
                   if (!m->msg_base) {
                           LOGERR;
                           free(m);
                           return NULL;
                   } else
                           memset(m->msg_base, 0, m->msg_len);
           }
   
           return m;
   }
   
   /*
    * mqtt_msgRealloc() Reallocate MQTT message buffer
    * @msg = MQTT message
    * @len = new length
    * return: -1 error or >-1 old buffer length
    */
   inline int
   mqtt_msgRealloc(mqtt_msg_t * __restrict msg, u_short len)
   {
           void *p = NULL;
           int ret = 0;
   
           if (!msg)
                   return -1;
   
           if (len == msg->msg_len)
                   return len;
   
           p = realloc(msg->msg_base, len);
           if (!p) {
                   LOGERR;
                   return -1;
           }
   
           ret = msg->msg_len;
           msg->msg_len = len;
           msg->msg_base = p;
   
           return ret;
   }
   
   /*
    * mqtt_encodeLen() Encode number to MQTT length field
    * @num = number for encode
    * return: -1 error or >-1 length
    */
   inline u_int
   mqtt_encodeLen(u_int num)
   {
           register u_int dig, i;
           u_int ret = 0;
   
           if (num > 268435455)
                   return (u_int) -1;
   
           for (i = 0; i < sizeof ret && num > 0; i++) {
                   dig = num % 0x80;
                   num /= 0x80;
                   if (num > 0)
                           dig |= 0x80;
   
                   *((u_char*) &ret + i) = (u_char) dig;
           }
   
           return ret;
   }
   
   /*
    * mqtt_decodeLen() Decode length from MQTT packet
    * @len = length
    * @n = sizeof bytes, if !=NULL
    * return: -1 error, >-1 length of message
    */
   inline u_int
   mqtt_decodeLen(u_int len, char *n)
   {
           register u_int i, dig, mul;
           u_int ret = 0;
           u_char *p = (u_char*) &len;
   
           if (len > 0xffffff7f)
                   return (u_int) -1;
   
           for (mul = 1, i = 0; i < sizeof ret; i++, mul *= 0x80) {
                   dig = p[i];
                   ret += (dig & 0x7f) * mul;
   
                   if (!(dig & 0x80))
                           break;
           }
   
           if (n)
                   *n = (char) (i & 0x7f) + 1;
           return ret;
   }
   
   /*
    * mqtt_sizeLen Return sizeof len field
    * @len = length
    * return: -1 error, >-1 sizeof len in bytes
    */
   inline char
   mqtt_sizeLen(u_int len)
   {
           register char i;
           u_char *p = (u_char*) &len;
   
           if (len > 0xffffff7f)
                   return -1;
   
           for (i = 0; i < sizeof len; i++)
                   if (!(*(p + i) & 0x80))
                           break;
   
           return ++i;
   }
   
   /*
    * mqtt_str2sub Create MQTT subscribe variable from string(s)
    * @csStr = strings
    * @strnum = number of strings elements
    * @qoses = QoS elements applied to subscribe variable, 
    *              count of elements must be equal with csStr elements
    * return: NULL error or != subscribe variables array, must be free after use with mqtt_freeSub()
    */
   inline mqtt_subscr_t *
   mqtt_str2sub(const char **csStr, u_short strnum, u_char *qoses)
   {
           mqtt_subscr_t *v;
           register int i, items;
           const char **strs;
   
           if (!csStr)
                   return NULL;
           for (items = 0, strs = csStr; *strs; items++, strs++)
                   if (strnum && items >= strnum) {
                           items = strnum;
                           break;
                   }
   
           if (!(v = malloc((items + 1) * sizeof(mqtt_subscr_t)))) {
                   LOGERR;
                   return NULL;
           } else
                   memset(v, 0, (items + 1) * sizeof(mqtt_subscr_t));
   
           for (i = 0; i < items; i++) {
                   v[i].sub_sb.val = htons(strlen(csStr[i]));
                   v[i].sub_data = strdup(csStr[i]);
                   if (qoses && qoses[i] < MQTT_QOS_RESERVED)
                           v[i].sub_qos = qoses[i];
           }
   
           return v;
   }
   
   /*
    * mqtt_freeSub() Free array from subscribe variables
    *
    * @subs = Subscribe variables
    * @freeall = if !=0 free and subs pointer
    * return: none
    */
   inline void
   mqtt_freeSub(mqtt_subscr_t ** __restrict subs, int freeall)
   {
           mqtt_subscr_t *v;
   
           if (!subs)
                   return;
   
           for (v = *subs; v->sub_data; v++) {
                   free(v->sub_data);
                   v->sub_data = NULL;
           }
   
           if (freeall) {
                   free(*subs);
                   *subs = NULL;
           }
   }

Removed from v.1.1.1.1  
changed lines
  Added in v.1.1.1.1.2.8


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>