Diff for /mqtt/src/Attic/aitmqtt.c between versions 1.1.1.1.2.11 and 1.1.1.1.2.16

version 1.1.1.1.2.11, 2011/11/28 10:17:12 version 1.1.1.1.2.16, 2011/12/13 10:12:36
Line 39  mqtt_SetErr(int eno, char *estr, ...) Line 39  mqtt_SetErr(int eno, char *estr, ...)
         va_end(lst);          va_end(lst);
 }  }
   
   #pragma GCC visibility push(hidden)
   // _mqtt_readHEADER() read fixed header from MQTT message
   inline struct mqtthdr *
   _mqtt_readHEADER(mqtt_msg_t * __restrict buf, u_char cmd, int *bytes, int *len)
   {
           struct mqtthdr *hdr;
   
           if (!buf || !buf->msg_base || !buf->msg_len)
                   return NULL;
   
           hdr = (struct mqtthdr*) buf->msg_base;
           if (hdr->mqtt_msg.type != cmd) {
                   mqtt_SetErr(EINVAL, "Error:: wrong command #%d should be %d", 
                                   hdr->mqtt_msg.type, cmd);
                   return NULL;
           }
   
           *len = mqtt_decodeLen(hdr->mqtt_len, bytes);
           return hdr;
   }
   #pragma GCC visibility pop
   
 // ----------------------------------------------------------  // ----------------------------------------------------------
   
 /*  /*
Line 158  mqtt_encodeLen(u_int num) Line 180  mqtt_encodeLen(u_int num)
 /*  /*
  * mqtt_decodeLen() Decode length from MQTT packet   * mqtt_decodeLen() Decode length from MQTT packet
  *   *
 * @len = length * @len = length from MQTT header
  * @n = sizeof bytes, if !=NULL   * @n = sizeof bytes, if !=NULL
  * return: -1 error, >-1 length of message   * return: -1 error, >-1 length of message
  */   */
 inline u_int  inline u_int
mqtt_decodeLen(u_int len, char *n)mqtt_decodeLen(void * __restrict len, int * __restrict n)
 {  {
         register u_int i, dig, mul;          register u_int i, dig, mul;
         u_int ret = 0;          u_int ret = 0;
        u_char *p = (u_char*) &len;        u_char *p = (u_char*) len;
   
        if (len > 0xffffff7f)        if (!len)
                 return (u_int) -1;                  return (u_int) -1;
   
         for (mul = 1, i = 0; i < sizeof ret; i++, mul *= 0x80) {          for (mul = 1, i = 0; i < sizeof ret; i++, mul *= 0x80) {
Line 239  mqtt_str2sub(const char **csStr, u_short strnum, u_cha Line 261  mqtt_str2sub(const char **csStr, u_short strnum, u_cha
   
         for (i = 0; i < items; i++) {          for (i = 0; i < items; i++) {
                 v[i].sub_topic._size = strlen(csStr[i]);                  v[i].sub_topic._size = strlen(csStr[i]);
                v[i].sub_topic._base = strdup(csStr[i]);                v[i].sub_topic._base = (u_char*) strdup(csStr[i]);
                 if (qoses && qoses[i] < MQTT_QOS_RESERVED)                  if (qoses && qoses[i] < MQTT_QOS_RESERVED)
                         v[i].sub_ret = qoses[i];                          v[i].sub_ret = qoses[i];
         }          }
Line 265  mqtt_subFree(mqtt_subscr_t ** __restrict subs) Line 287  mqtt_subFree(mqtt_subscr_t ** __restrict subs)
                 free(v->sub_topic._base);                  free(v->sub_topic._base);
                 v->sub_topic._base = NULL;                  v->sub_topic._base = NULL;
                 v->sub_topic._size = 0;                  v->sub_topic._size = 0;
   
                   if (v->sub_value._base) {
                           free(v->sub_value._base);
                           v->sub_value._base = NULL;
                           v->sub_value._size = 0;
                   }
         }          }
   
         free(*subs);          free(*subs);
Line 281  inline mqtt_subscr_t * Line 309  inline mqtt_subscr_t *
 mqtt_subAlloc(u_short num)  mqtt_subAlloc(u_short num)
 {  {
         mqtt_subscr_t *s = NULL;          mqtt_subscr_t *s = NULL;
         register int i;  
   
         s = malloc((num + 1) * sizeof(mqtt_subscr_t));          s = malloc((num + 1) * sizeof(mqtt_subscr_t));
         if (!s) {          if (!s) {
Line 290  mqtt_subAlloc(u_short num) Line 317  mqtt_subAlloc(u_short num)
         } else          } else
                 memset(s, 0, (num + 1) * sizeof(mqtt_subscr_t));                  memset(s, 0, (num + 1) * sizeof(mqtt_subscr_t));
   
        for (i = 0; i < num; i++)        return s;
                if (!(s[i].sub_topic._base = malloc(0))) {}
                        LOGERR;
                        break;/*
                } * mqtt_subRealloc() Reallocate array from subscribe variables
  *
  * @subs = Subscribe array
  * @num = Number of elements
  * return: NULL error or subscribe array, after use must call mqtt_subFree()
  */
 inline mqtt_subscr_t *
 mqtt_subRealloc(mqtt_subscr_t * __restrict subs, u_short num)
 {
         mqtt_subscr_t *s = NULL;
 
         s = realloc(subs, (num + 1) * sizeof(mqtt_subscr_t));
         if (!s) {
                 LOGERR;
                 return NULL;
         }
   
         return s;          return s;
 }  }

Removed from v.1.1.1.1.2.11  
changed lines
  Added in v.1.1.1.1.2.16


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