X-Git-Url: http://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/blobdiff_plain/fcdfc43e1ff49b58d2a0b85d5f4beee634906ca6..6f5dd6010ec48f56724029a414db1ee3594ab810:/client/cmdparser.c diff --git a/client/cmdparser.c b/client/cmdparser.c index 1afeb930..7c3c60cc 100644 --- a/client/cmdparser.c +++ b/client/cmdparser.c @@ -9,9 +9,11 @@ //----------------------------------------------------------------------------- #include +#include #include #include "ui.h" #include "cmdparser.h" +#include "proxmark3.h" void CmdsHelp(const command_t Commands[]) { @@ -20,14 +22,26 @@ void CmdsHelp(const command_t Commands[]) int i = 0; while (Commands[i].Name) { - if (!offline || Commands[i].Offline) - PrintAndLog("%-16s %s", Commands[i].Name, Commands[i].Help); + if(Commands[i].Offline) + { + PrintAndLog("%-16s \t%s", Commands[i].Name, Commands[i].Help); + }else + { + PrintAndLog("%-16s @\t%s", Commands[i].Name, Commands[i].Help); + } ++i; } } -void CmdsParse(const command_t Commands[], char *Cmd) +void CmdsParse(const command_t Commands[], const char *Cmd) { + if(strcmp( Cmd, "XX_internal_command_dump_XX") == 0) + {// Markdown dump children + dumpCommandsRecursive(Commands); + return; + } + + char cmd_name[32]; int len = 0; memset(cmd_name, 0, 32); @@ -53,11 +67,59 @@ void CmdsParse(const command_t Commands[], char *Cmd) if (Commands[i].Name) { while (Cmd[len] == ' ') ++len; - while (Cmd[strlen(Cmd) - 1] == ' ') - Cmd[strlen(Cmd) - 1] = '\0'; Commands[i].Parse(Cmd + len); } else { // show help for selected hierarchy or if command not recognised CmdsHelp(Commands); } } +//static int tablevel = 0; + +char pparent[512] = {0}; +char *parent = pparent; + +void dumpCommandsRecursive(const command_t cmds[]) +{ + if (cmds[0].Name == NULL) + return; + + int i = 0; + char* tabulation = "###"; + // First, dump all single commands, which are not a container for + // other commands + printf("command|offline|description\n"); + printf("-------|-------|-----------\n"); + + while (cmds[i].Name) + { + char* offline = "N"; + if(cmds[i].Help[0] == '{' && ++i) continue; + + if ( cmds[i].Offline) offline = "Y"; + printf("|`%s%s`|%s|`%s`|\n", parent, cmds[i].Name,offline, cmds[i].Help); + ++i; + } + printf("\n\n"); + i=0; + // Then, print the categories. These will go into subsections with their own tables + + while (cmds[i].Name) + { + if(cmds[i].Help[0] != '{' && ++i) continue; + + printf("%s %s%s\n\n %s\n\n", tabulation, parent, cmds[i].Name, cmds[i].Help); + + char currentparent[512] = {0}; + snprintf(currentparent, sizeof currentparent, "%s%s ", parent, cmds[i].Name); + char *old_parent = parent; + parent = currentparent; +// tablevel++; + // This is what causes the recursion, since commands Parse-implementation + // in turn calls the CmdsParse above. + cmds[i].Parse("XX_internal_command_dump_XX"); +// tablevel--; + parent = old_parent; + ++i; + } + +}