Created
November 30, 2010 21:41
-
-
Save drbobbeaty/722469 to your computer and use it in GitHub Desktop.
Simple method to dump a ZeroMQ message to a std::string.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#include <string> | |
#include <strings.h> | |
#include <stdint.h> | |
std::string hexDump( zmq::message_t & aMessage ) { | |
// I'm going to build a hex/ascii dump like you've seen so many times before | |
std::string msg; | |
std::string ascii; | |
// get the pointer to the start of the message's payload - and it's size | |
char *buff = (char *)aMessage.data(); | |
int size = aMessage.size(); | |
char *end = buff + size - 1; | |
// see if it's the trivial case | |
if (buff == NULL) { | |
msg.append("NULL"); | |
} else { | |
// get a place to hold the conversion of each byte | |
char hex[3]; | |
bzero(hex, 3); | |
// run through the valid data in the buffer | |
for (const char *p = buff; p <= end; ++p) { | |
// generate the hex code for the byte and add it | |
snprintf(hex, 3, "%02x", (uint8_t)(*p)); | |
msg.append(hex).append(" "); | |
// if it's printable, add it to the ascii part, otherwise, put a '.' | |
if (isprint(*p)) { | |
ascii.append(p, 1); | |
} else { | |
ascii.append("."); | |
} | |
// see if we have a complete line | |
if (ascii.size() >= 19) { | |
msg.append(" ").append(ascii).append("\n"); | |
ascii.clear(); | |
} | |
} | |
// if we have anything left, put it on the line as well | |
if (ascii.size() > 0) { | |
msg.append((19 - ascii.length())*3 + 1, ' ').append(ascii); | |
} | |
} | |
return msg; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
include
include <strings.h>
include <stdint.h>
std::string hexDump( zmq::message_t & aMessage ) {
// I'm going to build a hex/ascii dump like you've seen so many times before
std::string msg;
std::string ascii;
// get the pointer to the start of the message's payload - and it's size
const char _buff = (const char *) aMessage.data();
size_t size = aMessage.size();
const char *end = buff + size - 1;
// see if it's the trivial case
if (buff == NULL) {
msg.append("NULL");
} else {
// get a place to hold the conversion of each byte
char hex[3];
bzero(hex, 3);
// run through the valid data in the buffer
for (const char *p = buff; p <= end; ++p) {
// generate the hex code for the byte and add it
snprintf(hex, 3, "%02x", (uint8_t)(_p));
msg.append(hex).append(" ");
// if it's printable, add it to the ascii part, otherwise, put a '.'
if (isprint(_p)) {
ascii.append(p, 1);
} else {
ascii.append(".");
}
// see if we have a complete line
if (ascii.size() >= 19) {
msg.append(" ").append(ascii).append("\n");
ascii.clear();
}
}
// if we have anything left, put it on the line as well
if (ascii.size() > 0) {
msg.append((19 - ascii.length())_3 + 1, ' ').append(ascii);
}
}
return msg;
}