ofpbuf: New function ofpbuf_to_string().
authorBen Pfaff <blp@nicira.com>
Thu, 11 Feb 2010 21:56:45 +0000 (13:56 -0800)
committerBen Pfaff <blp@nicira.com>
Fri, 12 Feb 2010 21:55:46 +0000 (13:55 -0800)
Useful for debugging.

From Jean Tourrilhes <jt@hpl.hp.com>.

lib/ofpbuf.c
lib/ofpbuf.h

index fd01ea8d0227b5af4e8062ff17ee367feccc4c0d..9cb2ceb80f7adc0d03b906d3b6552a78a65138d3 100644 (file)
@@ -19,6 +19,7 @@
 #include <assert.h>
 #include <stdlib.h>
 #include <string.h>
+#include "dynamic-string.h"
 #include "util.h"
 
 /* Initializes 'b' as an empty ofpbuf that contains the 'allocated' bytes of
@@ -286,3 +287,18 @@ ofpbuf_try_pull(struct ofpbuf *b, size_t size)
 {
     return b->size >= size ? ofpbuf_pull(b, size) : NULL;
 }
+
+/* Returns a string that describes some of 'b''s metadata plus a hex dump of up
+ * to 'maxbytes' from the start of the buffer. */
+char *
+ofpbuf_to_string(const struct ofpbuf *b, size_t maxbytes)
+{
+    struct ds s;
+
+    ds_init(&s);
+    ds_put_format(&s, "size=%zu, allocated=%zu, head=%zu, tail=%zu\n",
+                  b->size, b->allocated,
+                  ofpbuf_headroom(b), ofpbuf_tailroom(b));
+    ds_put_hex_dump(&s, b->data, MIN(b->size, maxbytes), 0, false);
+    return ds_cstr(&s);
+}
index b65f79ee6867f4cae0297247666066f91183afc8..9072cc47407398358affe62b2fb076b89a176f41 100644 (file)
@@ -74,6 +74,8 @@ void ofpbuf_clear(struct ofpbuf *);
 void *ofpbuf_pull(struct ofpbuf *, size_t);
 void *ofpbuf_try_pull(struct ofpbuf *, size_t);
 
+char *ofpbuf_to_string(const struct ofpbuf *, size_t maxbytes);
+
 #ifdef  __cplusplus
 }
 #endif