diff options
author | Clifford Wolf <clifford@clifford.at> | 2013-03-21 11:33:56 +0100 |
---|---|---|
committer | Clifford Wolf <clifford@clifford.at> | 2013-03-21 11:33:56 +0100 |
commit | 47325fb2710952ea23b1c097060335dd096bd492 (patch) | |
tree | acb9230f653b3dbcde11f737a6feaf2429f0d327 | |
parent | 69ce1191c02a4061acd48a7df4abf96d3390a6c0 (diff) | |
download | yosys-47325fb2710952ea23b1c097060335dd096bd492.tar.gz yosys-47325fb2710952ea23b1c097060335dd096bd492.tar.bz2 yosys-47325fb2710952ea23b1c097060335dd096bd492.zip |
Added help -write-tex-command-reference-manual option
-rw-r--r-- | kernel/register.cc | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/kernel/register.cc b/kernel/register.cc index a61548b64..1dd608754 100644 --- a/kernel/register.cc +++ b/kernel/register.cc @@ -22,6 +22,7 @@ #include <assert.h> #include <string.h> #include <stdlib.h> +#include <stdio.h> using namespace REGISTER_INTERN; #define MAX_REG_COUNT 1000 @@ -373,6 +374,26 @@ struct HelpPass : public Pass { log(" help -all ........ print complete command reference\n"); log("\n"); } + void escape_tex(std::string &tex) + { + size_t pos = 0; + while ((pos = tex.find('_', pos)) != std::string::npos) { + tex.replace(pos, 1, "\\_"); + pos += 2; + } + } + void write_tex(FILE *f, std::string cmd, std::string title, std::string text) + { + size_t begin = text.find_first_not_of("\n"), end = text.find_last_not_of("\n"); + if (begin != std::string::npos && end != std::string::npos && begin < end) + text = text.substr(begin, end-begin+1); + escape_tex(cmd); + escape_tex(title); + fprintf(f, "\\section{%s -- %s}\n", cmd.c_str(), title.c_str()); + fprintf(f, "\\begin{lstlisting}[numbers=left,frame=single]\n"); + fprintf(f, "%s\n\\end{lstlisting}\n\n", text.c_str()); + + } virtual void execute(std::vector<std::string> args, RTLIL::Design*) { if (args.size() == 1) { @@ -396,6 +417,23 @@ struct HelpPass : public Pass { it.second->help(); } } + // this option is undocumented as it is for internal use only + else if (args[1] == "-write-tex-command-reference-manual") { + FILE *f = fopen("command-reference-manual.tex", "wt"); + fprintf(f, "%% Generated using the yosys 'help -write-tex-command-reference-manual' command.\n\n"); + for (auto &it : REGISTER_INTERN::pass_register) { + size_t memsize; + char *memptr; + FILE *memf = open_memstream(&memptr, &memsize); + log_files.push_back(memf); + it.second->help(); + log_files.pop_back(); + fclose(memf); + write_tex(f, it.first, it.second->short_help, memptr); + free(memptr); + } + fclose(f); + } else if (REGISTER_INTERN::pass_register.count(args[1]) == 0) log("No such command: %s\n", args[1].c_str()); else |