From f2e8da0bdc0c815b2fe8054b81cf1a7a15115867 Mon Sep 17 00:00:00 2001 From: Ian Jackson Date: Sun, 27 Nov 2016 17:55:37 +0000 Subject: [PATCH] regress: hfuzzraw: Introduce P_read_dump This really helps debugging. Signed-off-by: Ian Jackson --- regress/hfuzzraw.c.m4 | 25 ++++++++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) diff --git a/regress/hfuzzraw.c.m4 b/regress/hfuzzraw.c.m4 index b843f15..a1a9d0f 100644 --- a/regress/hfuzzraw.c.m4 +++ b/regress/hfuzzraw.c.m4 @@ -97,13 +97,32 @@ void Tensurerecordfile(void) { if (proutstr) stdout_enable= atoi(proutstr); } -static void P_read(void *p, size_t sz) { + +static void P_read_dump(const unsigned char *p0, size_t count, ssize_t d) { + fputs(" | ",stdout); + while (count) { + fprintf(stdout,"%02x", *p0); + p0 += d; + count--; + } +} + +static void P_read(void *p, size_t sz, const char *what) { ssize_t got = fread(p,1,sz,Tinputfile); Pcheckinput(); assert(got==sz); + if (stdout_enable && sz) { + fprintf(stdout,"%s:",what); + P_read_dump(p, sz, +1); + if (sz<=16) { + P_read_dump((const unsigned char *)p+sz-1, sz, -1); + } + fputs(" |\n",stdout); + Tflushstdout(); + } } -#define P_READ(x) (P_read(&(x), sizeof((x)))) +#define P_READ(x) (P_read(&(x), sizeof((x)), #x)) static unsigned P_fdf(int fd) { assert(fd>=0 && fdmaxlen) Pformat("bad byte block len"); - P_read(buf, l); + P_read(buf, l, "bytes"); return l; } -- 2.30.2