+//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 = "###";
+ char* offline = "N";
+ // First, dump all single commands, which are not a container for
+ // other commands
+ printf("command|offline|description\n");
+ printf("-------|-------|-----------\n");
+
+ while (cmds[i].Name)
+ {
+ 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;
+ }
+
+}