From: Ian Jackson Date: Sun, 27 Nov 2016 17:55:37 +0000 (+0000) Subject: regress: hfuzzraw: Introduce P_read_dump X-Git-Tag: adns-1.6.0~56 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=adns.git;a=commitdiff_plain;h=f2e8da0bdc0c815b2fe8054b81cf1a7a15115867 regress: hfuzzraw: Introduce P_read_dump This really helps debugging. Signed-off-by: Ian Jackson --- 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; }