diff options
Diffstat (limited to 'programs/src/kconfig/kconfig_parser.c')
-rw-r--r-- | programs/src/kconfig/kconfig_parser.c | 100 |
1 files changed, 100 insertions, 0 deletions
diff --git a/programs/src/kconfig/kconfig_parser.c b/programs/src/kconfig/kconfig_parser.c new file mode 100644 index 0000000..4fac8b2 --- /dev/null +++ b/programs/src/kconfig/kconfig_parser.c @@ -0,0 +1,100 @@ +#include <stdio.h> +#include <ctype.h> +#include <errno.h> +#include <fcntl.h> +#include <limits.h> +#include <stdarg.h> +#include <stdlib.h> +#include <string.h> +#include <signal.h> +#include <unistd.h> +#include <locale.h> +#include <stdbool.h> +#include "kconfig/lkc.h" +#include "symlist.h" +#include "boolexp.h" +#include "output.h" + +void kconfig_menu_walker(void (*solve) + (struct symbol * sym)); + +void solve_names(struct symbol *sym); +void solve_dep(struct symbol *sym); + +struct symlist *gsymlist; +int noname_num; + +int main(int argc, char **argv) { + + if (argc < 2) { + printf("No input file specified\n"); + return; + } + + setlocale(LC_ALL, ""); + bindtextdomain(PACKAGE, LOCALEDIR); + textdomain(PACKAGE); + + conf_parse(argv[1]); + sym_clear_all_valid(); + + gsymlist = symlist_create(); + + kconfig_menu_walker(solve_names); + kconfig_menu_walker(solve_dep); + + //symlist_print(gsymlist); + fprint_rules(gsymlist); + fprint_linker(gsymlist); +} + +void kconfig_menu_walker(void (*solve) (struct symbol * sym)) { + struct menu *menu; + struct symbol *sym; + menu = rootmenu.list; + + while (menu != NULL) { + sym = menu->sym; + if (sym != NULL) { + do { + if (sym->type == S_BOOLEAN || sym->type == S_TRISTATE) { + solve(sym); + } + } while ((sym = sym->next) != NULL); + } + // switch to menu + if (menu->list != NULL) { + menu = menu->list; + } else if (menu->next != NULL) { + menu = menu->next; + } else { + while ((menu = menu->parent) != NULL) { + if (menu->next != NULL) { + menu = menu->next; + break; + } + } + } + } +} + +void solve_names(struct symbol *sym) { + if (sym->name != NULL) { + if (symlist_find(gsymlist, sym->name) == NULL) + symlist_add(gsymlist, sym->name); + } else { + sym->name = malloc((9 + 7) * sizeof(char)); + sprintf(sym->name, "NONAMEGEN%d", noname_num++); + symlist_add(gsymlist, sym->name); + } +} + +void solve_dep(struct symbol *sym) { + if (sym->dir_dep.expr != NULL) { + struct symlist_el *el; + el = symlist_find(gsymlist, sym->name); + el->be = copy_kconfig_dep(gsymlist, sym->dir_dep.expr); + if (el->be != NULL) + el->be = boolexp_cnf(el->be); + } +} |