--- mqtt/example/Attic/cmds.c 2011/12/05 22:17:39 1.1.2.13 +++ mqtt/example/Attic/cmds.c 2011/12/06 10:33:37 1.1.2.15 @@ -8,11 +8,12 @@ int main() { mqtt_msg_t *m; - mqtt_subscr_t s[4]; + mqtt_subscr_t s[4], *ss; mqtthdr_connflgs_t flg; - u_short ka; - int i; + u_short ka, msgID; + int i, len; char cid[BUFSIZ], user[BUFSIZ], pass[BUFSIZ], topic[BUFSIZ], message[BUFSIZ]; + struct mqtthdr *hdr; m = mqtt_msgAlloc(0); /* conn* */ @@ -39,6 +40,14 @@ main() printf("publish=%d/%d\n", m->msg_len, mqtt_msgPUBLISH(m, "AAA/bbb/CCC/ddd", 7, 0, 2, 0, "OLE!!!", 7)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + len = sizeof message; + hdr = mqtt_readPUBLISH(m, topic, sizeof topic, &msgID, message, &len); + if (!hdr) { + printf("Error:: mqtt_readPUBLISH() #%d - %s\n", mqtt_GetErrno(), mqtt_GetError()); + return 2; + } + printf("read publish: dup=%d qos=%d retain=%d\n", hdr->mqtt_msg.dup, hdr->mqtt_msg.qos, hdr->mqtt_msg.retain); + printf("++> topic=%s MessageID=%d DATA=(%d)%s\n", topic, msgID, len, message); printf("puback=%d/%d\n", m->msg_len, mqtt_msgPUBACK(m, 10)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); @@ -55,6 +64,7 @@ main() for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); printf("read pubcomp=%d\n", mqtt_readPUBCOMP(m)); + getchar(); /* sub* */ memset(s, 0, sizeof s); @@ -70,6 +80,16 @@ main() printf("subscribe=%d/%d\n", m->msg_len, mqtt_msgSUBSCRIBE(m, s, 10, 0, 0)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); + hdr = mqtt_readSUBSCRIBE(m, &msgID, &ss); + if (!hdr) { + printf("Error:: mqtt_readSUBSCRIBE() #%d - %s\n", mqtt_GetErrno(), mqtt_GetError()); + return 3; + } + printf("read subscribe: dup=%d qos=%d retain=%d\n", hdr->mqtt_msg.dup, hdr->mqtt_msg.qos, hdr->mqtt_msg.retain); + printf("++> MessageID=%d\n", msgID); + for (i = 0; ss[i].sub_topic._base; i++) + printf(" >>> QoS=%d Topic(%d)=%s\n", ss[i].sub_ret, ss[i].sub_topic._size, ss[i].sub_topic._base); + mqtt_subFree(&ss); printf("suback=%d/%d\n", m->msg_len, mqtt_msgSUBACK(m, s, 10)); for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); @@ -80,6 +100,7 @@ main() for (i = 0; i < m->msg_len; i++) printf("%d\n", ((u_char*) m->msg_base)[i]); printf("read unsuback=%d\n", mqtt_readUNSUBACK(m)); + getchar(); /* ping* */ printf("pingreq=%d/%d\n", m->msg_len, mqtt_msgPINGREQ(m));