From 37da13321c20faceb6e313eba60f8ad924fa57c9 Mon Sep 17 00:00:00 2001 From: Gregory Nutt Date: Sun, 21 Apr 2013 11:01:46 -0600 Subject: [PATCH] kconfig2html: Perform HTL conversions and add hyperlinks for dependency expressions --- drivers/usbhost/Kconfig | 2 +- tools/kconfig2html.c | 239 +++++++++++++++++++++++++++++++++------- 2 files changed, 198 insertions(+), 43 deletions(-) diff --git a/drivers/usbhost/Kconfig b/drivers/usbhost/Kconfig index 531e94442c..8975ecf56d 100644 --- a/drivers/usbhost/Kconfig +++ b/drivers/usbhost/Kconfig @@ -87,7 +87,7 @@ config HIDKBD_RAWSCANCODES codes. This option is useful during testing. Default: ASCII conversion. config HIDKBD_ENCODED - bool "Enocode Special Keys" + bool "Encode Special Keys" default n depends on !HIDKBD_RAWSCANCODES && LIB_KBDCODEC ---help--- diff --git a/tools/kconfig2html.c b/tools/kconfig2html.c index 733361238a..6a0745674a 100644 --- a/tools/kconfig2html.c +++ b/tools/kconfig2html.c @@ -58,6 +58,8 @@ #define MAX_LEVELS 100 #define MAX_SELECT 16 #define TAB_SIZE 4 +#define VAR_SIZE 80 +#define HTML_VAR_SIZE (2*VAR_SIZE + 64) #define TMPFILE_NAME "kconfig2html-tmp.dat" @@ -371,23 +373,115 @@ static char *dequote(char *ptr) } /**************************************************************************** - * Name: htmlize + * Name: htmlize_character * * Description: - * HTML-ize a string. Convert characters: + * Transfer and HTML-ize a character. Convert characters: * * " " quotation mark - * ' ' apostrophe + * ' ' apostrophe * & & ampersand * < < less-than * > > greater-than * ****************************************************************************/ -static char *htmlize(const char *src) +static int htmlize_character(char *dest, char ch) +{ + const char *str; + + /* Transfer the character from into the destination buffer, perform the + * conversion only the the character is one of the special characters. + */ + + str = NULL; + + switch (ch) + { + case '"': + str = """; + break; + + case '\'': + str = "'"; + break; + + case '&': + str = "&"; + break; + + case '<': + str = "<"; + break; + + case '>': + str = ">"; + break; + + default: + *dest++ = ch; + *dest = '\0'; + return 1; + } + + /* Transfer a string */ + + *dest = '\0'; + strcat(dest, str); + return strlen(str); +} + +/**************************************************************************** + * Name: htmlize_text + * + * Description: + * HTML-ize a free-text string. This function preforms the conversions of + * in htmlize_character() for a text string. + * + ****************************************************************************/ + +static char *htmlize_text(const char *src) { char *dest = g_scratch; - const char *str; + + /* We may get here with the source pointer equal to NULL. Return the + * disfavor. + */ + + if (!src) + { + return NULL; + } + + /* Transfer each character from the source string into the scratch buffer */ + + for (; *src; src++) + { + /* Expand characters as necessary */ + + dest += htmlize_character(dest, *src); + } + + return g_scratch; +} + +/**************************************************************************** + * Name: htmlize_expression + * + * Description: + * HTML-ize an expression of configuration variables. This function + * preforms the same conversions as in htmlize_character(), but also + * expands and adds hyper links for configuration variables. + * + ****************************************************************************/ + +static char *htmlize_expression(const char *src) +{ + char varname[VAR_SIZE+1]; + char htmlvar[HTML_VAR_SIZE+1]; + char *dest = g_scratch; + char ch = '\0'; + char lastc; /* We may get here with the source pointer equal to NULL. Return the * disfavor. @@ -403,43 +497,85 @@ static char *htmlize(const char *src) dest = g_scratch; *dest = '\0'; - for (; *src; src++) + while (*src) { - /* Expand characters as necessary */ + /* Remember the last character and advance to the next character */ - str = NULL; - switch (*src) + lastc = ch; + ch = *src; + + /* Skip control characters and out-of-range 7-bit ASCII characters */ + + if (*src < 0x20 || *src > 0x7e) { - case '"': - str = """; - break; - - case '\'': - str = "'"; - break; - - case '&': - str = "&"; - break; - - case '<': - str = "<"; - break; - - case '>': - str = ">"; - break; - - default: - *dest++ = *src; - *dest = '\0'; - continue; + src++; + continue; } - /* Transfer a string */ + /* Output no more than one consecutive space character. This depends + * on the fact that kconfig_line has replaces all of the forms of + * whitespace with a space character. + */ - strcat(dest, str); - dest += strlen(str); + if (*src == ' ') + { + if (lastc != ' ') + { + *dest++ = *src; + *dest = '\0'; + } + + src++; + continue; + } + + /* Concatenate variable name strings. There strings probably begin + * with a uppercase letter, but here all alphanumeric values (plus '_'_ + * are concatenated. + */ + + if (isalnum(((int)*src)) || *src == '_') + { + int namlen = 0; + + do + { + /* Don't overflow the tiny variable name buffer */ + + if (namlen >= VAR_SIZE) + { + error("Configuration variable name too long\n"); + break; + } + + /* Add the next character to the name */ + + varname[namlen] = *src++; + namlen++; + varname[namlen] = '\0'; + } + while (isalnum(((int)*src)) || *src == '_'); + + /* HTML-ize the name into our bigger, local scratch buffer */ + + snprintf(htmlvar, HTML_VAR_SIZE, "CONFIG_%s", + varname, varname); + + /* Then transfer the string into the scratch buffer */ + + strcat(dest, htmlvar); + dest += strlen(htmlvar); + } + + /* All that remains are space and the punctuation characters */ + + else + { + /* Expand characters as necessary */ + + dest += htmlize_character(dest, *src); + src++; + } } return g_scratch; @@ -746,7 +882,7 @@ static char *getstring(char *ptr) } } - return htmlize(ptr); + return htmlize_text(ptr); } /**************************************************************************** @@ -1038,7 +1174,7 @@ static inline void process_help(FILE *stream) newpara = false; } - body(" %s", htmlize(ptr)); + body(" %s", htmlize_text(ptr)); } if (!newpara) @@ -1220,7 +1356,7 @@ static inline char *process_config(FILE *stream, const char *configname, exit(ERRROR_ON_AFTER_DEPENDS); } - push_dependency(g_lasts); + push_dependency(htmlize_expression(g_lasts)); config.cndependencies++; token = NULL; } @@ -1501,7 +1637,7 @@ static inline char *process_choice(FILE *stream, const char *kconfigdir) exit(ERRROR_ON_AFTER_DEPENDS); } - push_dependency(g_lasts); + push_dependency(htmlize_expression(g_lasts)); choice.cndependencies++; token = NULL; } @@ -1665,7 +1801,7 @@ static inline char *process_menu(FILE *stream, const char *kconfigdir) exit(ERRROR_ON_AFTER_DEPENDS); } - push_dependency(g_lasts); + push_dependency(htmlize_expression(g_lasts)); menu.mndependencies++; token = NULL; } @@ -1890,7 +2026,7 @@ static char *parse_kconfigfile(FILE *stream, const char *kconfigdir) case TOKEN_IF: { char *dependency = strtok_r(NULL, " ", &g_lasts); - push_dependency(dependency); + push_dependency(htmlize_expression(dependency)); token = NULL; } break; @@ -2093,6 +2229,25 @@ int main(int argc, char **argv, char **envp) g_menu_number, paranum); g_menu_number++; + /* Tell the reader that this is an auto-generated file */ + + body("

\n"); + body(" Maintaining this Document.\n"); + body(" The NuttX RTOS is highly configurable.\n"); + body(" The NuttX configuration files are maintained using the kconfig-frontends tool.\n"); + body(" That configuration tool uses Kconfig files that can be found through the NuttX source tree.\n"); + body(" Each Kconfig files contains declarations of configuration variables.\n"); + body(" Each configuration variable provides one configuration option for the NuttX RTOS.\n"); + body(" This configurable options are descrived in this document.\n"); + body("

\n"); + body("

\n"); + body(" NOTE:\n"); + body(" This documenation was auto-generated using the kconfig2html tool\n"); + body(" That tools analyzes the NuttX Kconfig and generates this HTML document.\n"); + body(" This HTML document file should not be editted manually.\n"); + body(" In order to make changes to this document, you should instead modify the Kconfig file(s) that were used to generated this document and then execute the kconfig2html again to regenerate the HTML document file.\n"); + body("

\n"); + /* Process the Kconfig files through recursive descent */ process_kconfigfile(g_kconfigroot);