From: James Chambers Date: Fri, 3 Mar 2017 22:38:51 +0000 (-0500) Subject: clean up unprintable characters in MFU dump output X-Git-Tag: v3.0.0~61^2~1 X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/commitdiff_plain/4bbf5ad17d6e75362f19ce93c99680ddf081ab66?ds=sidebyside;hp=--cc clean up unprintable characters in MFU dump output --- 4bbf5ad17d6e75362f19ce93c99680ddf081ab66 diff --git a/client/cmdhfmfu.c b/client/cmdhfmfu.c index 25a073d3..9c5f7a83 100644 --- a/client/cmdhfmfu.c +++ b/client/cmdhfmfu.c @@ -7,6 +7,7 @@ //----------------------------------------------------------------------------- // High frequency MIFARE ULTRALIGHT (C) commands //----------------------------------------------------------------------------- +#include #include "loclass/des.h" #include "cmdhfmfu.h" #include "cmdhfmf.h" @@ -1230,6 +1231,7 @@ int CmdHF14AMfUDump(const char *Cmd){ bool manualPages = false; uint8_t startPage = 0; char tempStr[50]; + char cleanASCII[4]; while(param_getchar(Cmd, cmdp) != 0x00) { @@ -1372,7 +1374,7 @@ int CmdHF14AMfUDump(const char *Cmd){ PrintAndLog("---------------------------------"); for (i = 0; i < Pages; ++i) { if ( i < 3 ) { - PrintAndLog("%02d/0x%02X | %s| | ", i+startPage, i+startPage, sprint_hex(data + i * 4, 4)); + PrintAndLog("%3d/0x%02X | %s| | ", i+startPage, i+startPage, sprint_hex(data + i * 4, 4)); continue; } switch(i){ @@ -1419,7 +1421,17 @@ int CmdHF14AMfUDump(const char *Cmd){ case 43: tmplockbit = bit2[9]; break; //auth1 default: break; } - PrintAndLog("%02d/0x%02X | %s| %d | %.4s", i+startPage, i+startPage, sprint_hex(data + i * 4, 4), tmplockbit, data+i*4); + + // convert unprintable characters and line breaks to dots + memcpy(cleanASCII, data+i*4, 4); + + for (size_t clean_i = 0; clean_i < 4; clean_i++) { + if (!isprint(cleanASCII[clean_i])) { + cleanASCII[clean_i] = '.'; + } + } + + PrintAndLog("%3d/0x%02X | %s| %d | %.4s", i+startPage, i+startPage, sprint_hex(data + i * 4, 4), tmplockbit, cleanASCII); } PrintAndLog("---------------------------------");