Diff for /mqtt/src/Attic/mqtt.c between versions 1.1.1.1.2.22 and 1.1.1.1.2.24

version 1.1.1.1.2.22, 2011/12/13 08:43:51 version 1.1.1.1.2.24, 2011/12/13 09:51:35
Line 20  Usage(void) Line 20  Usage(void)
         printf( " -= MQTT Client =- Publisher/Subscriber from ELWIX\n"          printf( " -= MQTT Client =- Publisher/Subscriber from ELWIX\n"
                 "=== %s@%s === Compiled: %s ===\n\n"                  "=== %s@%s === Compiled: %s ===\n\n"
                 " Syntax: mqtt [options] <connect_to_broker[:port]> [value_for_publish]\n\n"                  " Syntax: mqtt [options] <connect_to_broker[:port]> [value_for_publish]\n\n"
                "\t-p <topic>\t\tPublish topic\n"                "\t-t <topic>\t\tPublish topic\n"
                 "\t-s <topic[|QoS]>\tSubscribe for this topic, if wish add different |QoS to topic\n"                  "\t-s <topic[|QoS]>\tSubscribe for this topic, if wish add different |QoS to topic\n"
                 "\t-q <QoS>\t\tQoS level (0-at most 1, 1-at least 1, 2-exactly 1)\n"                  "\t-q <QoS>\t\tQoS level (0-at most 1, 1-at least 1, 2-exactly 1)\n"
                 "\t-d\t\t\tSend duplicate message\n"                  "\t-d\t\t\tSend duplicate message\n"
                 "\t-r\t\t\tRetain message from broker\n"                  "\t-r\t\t\tRetain message from broker\n"
                 "\t-c <config>\t\tService config\n"                  "\t-c <config>\t\tService config\n"
                 "\t-f\t\t\t'value_for_publish' is file instead text\n"                  "\t-f\t\t\t'value_for_publish' is file instead text\n"
                "\t-P <port>\t\tDifferent port for connect (default: 1883)\n"                "\t-p <port>\t\tDifferent port for connect (default: 1883)\n"
                 "\t-U <username>\t\tUsername\n"
                 "\t-P <password>\t\tPassword\n"
                 "\t-W <topic>\t\tWill Topic\n"
                 "\t-M <message>\t\tWill Message\n"
                 "\t-D\t\t\tDaemon mode\n"                  "\t-D\t\t\tDaemon mode\n"
                 "\t-v\t\t\tVerbose (more -vvv, more verbose)\n"                  "\t-v\t\t\tVerbose (more -vvv, more verbose)\n"
                 "\t-h\t\t\tHelp! This screen\n\n",                   "\t-h\t\t\tHelp! This screen\n\n", 
Line 37  Usage(void) Line 41  Usage(void)
 static void  static void
 cleanArgs(struct tagArgs * __restrict args)  cleanArgs(struct tagArgs * __restrict args)
 {  {
           mqtt_msgFree(&args->msg, 42);
           AIT_FREE_VAL(&args->Will.Msg);
           AIT_FREE_VAL(&args->Will.Topic);
           AIT_FREE_VAL(&args->User);
           AIT_FREE_VAL(&args->Pass);
         AIT_FREE_VAL(&args->Publish);          AIT_FREE_VAL(&args->Publish);
         AIT_FREE_VAL(&args->Value);          AIT_FREE_VAL(&args->Value);
         io_freeVars(&args->Subscribes);          io_freeVars(&args->Subscribes);
Line 54  main(int argc, char **argv) Line 63  main(int argc, char **argv)
         if (!(args = malloc(sizeof(struct tagArgs)))) {          if (!(args = malloc(sizeof(struct tagArgs)))) {
                 printf("Error:: in arguments #%d - %s\n", errno, strerror(errno));                  printf("Error:: in arguments #%d - %s\n", errno, strerror(errno));
                 return 1;                  return 1;
        } else if (!(args->Subscribes = io_allocVars(1))) {        } else
                 memset(args, 0, sizeof(struct tagArgs));
         if (!(args->Subscribes = io_allocVars(1))) {
                 printf("Error:: in subscribes array #%d - %s\n", io_GetErrno(), io_GetError());                  printf("Error:: in subscribes array #%d - %s\n", io_GetErrno(), io_GetError());
                 free(args);                  free(args);
                 return 1;                  return 1;
         } else          } else
                 args->free = cleanArgs;                  args->free = cleanArgs;
   
           if (!(args->msg = mqtt_msgAlloc(USHRT_MAX))) {
                   printf("Error:: in mqtt buffer #%d - %s\n", mqtt_GetErrno(), mqtt_GetError());
                   args->free(args);
                   free(args);
                   return 1;
           }
   
         strlcpy(szCfgName, DEFAULT_CONFIG, sizeof szCfgName);          strlcpy(szCfgName, DEFAULT_CONFIG, sizeof szCfgName);
        while ((ch = getopt(argc, argv, "P:p:s:q:drc:fDvh")) != -1)        while ((ch = getopt(argc, argv, "U:P:p:t:s:q:drc:W:M:fDvh")) != -1)
                 switch (ch) {                  switch (ch) {
                           case 'M':
                                   AIT_FREE_VAL(&args->Will.Msg);
                                   AIT_SET_STR(&args->Will.Msg, optarg);
                                   break;
                           case 'W':
                                   AIT_FREE_VAL(&args->Will.Topic);
                                   AIT_SET_STR(&args->Will.Topic, optarg);
                                   break;
                           case 'U':
                                   AIT_FREE_VAL(&args->User);
                                   AIT_SET_STR(&args->User, optarg);
                                   break;
                         case 'P':                          case 'P':
                                port = (u_short) strtol(optarg, NULL, 0);                                AIT_FREE_VAL(&args->Pass);
                                 AIT_SET_STR(&args->Pass, optarg);
                                 break;                                  break;
                         case 'p':                          case 'p':
                                   port = (u_short) strtol(optarg, NULL, 0);
                                   break;
                           case 't':
                                 AIT_FREE_VAL(&args->Publish);                                  AIT_FREE_VAL(&args->Publish);
                                 AIT_SET_STR(&args->Publish, optarg);                                  AIT_SET_STR(&args->Publish, optarg);
                                 break;                                  break;
Line 144  main(int argc, char **argv) Line 178  main(int argc, char **argv)
         }          }
   
         if ((sock = InitClient()) == -1) {          if ((sock = InitClient()) == -1) {
                   UnloadConfig(&cfg);
                 args->free(args);                  args->free(args);
                 free(args);                  free(args);
                 return 2;                  return 2;
           }
   
           if (SendConnect(sock) == -1) {
                   close(sock);
                   UnloadConfig(&cfg);
                   args->free(args);
                   free(args);
                   return 3;
         }          }
   
         shutdown(sock, SHUT_RDWR);          shutdown(sock, SHUT_RDWR);

Removed from v.1.1.1.1.2.22  
changed lines
  Added in v.1.1.1.1.2.24


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