diff options
author | gramanas <anastasis.gramm2@gmail.com> | 2022-01-31 17:25:17 +0200 |
---|---|---|
committer | gramanas <anastasis.gramm2@gmail.com> | 2022-01-31 17:25:17 +0200 |
commit | c9605d74204f2502ba57b8e9acd21350f07bf032 (patch) | |
tree | 0f961263f97730b3388ad25a3af48b1b5b6cccfd /cookbook.c | |
parent | 53ab9ae05a579a19c626e8be0c1e2cf9244bf863 (diff) | |
download | foodtools-c9605d74204f2502ba57b8e9acd21350f07bf032.tar.gz foodtools-c9605d74204f2502ba57b8e9acd21350f07bf032.tar.bz2 foodtools-c9605d74204f2502ba57b8e9acd21350f07bf032.zip |
Move project to autoconf
Diffstat (limited to 'cookbook.c')
-rw-r--r-- | cookbook.c | 162 |
1 files changed, 0 insertions, 162 deletions
diff --git a/cookbook.c b/cookbook.c deleted file mode 100644 index ca435ec..0000000 --- a/cookbook.c +++ /dev/null @@ -1,162 +0,0 @@ -#include <getopt.h> - -#include "src/util.h" -#include "src/parser.h" -#include "src/search.h" -#include "src/eval.h" -#include "src/lib.h" - -recipe ** cookbook; - -static struct opts { - int json; - int html; - int rcp; - char query[2048]; - int eval; - int list; - int hash; - int search; - int search_strict; - int help; -} opt = { - .json = 0, - .html = 0, - .rcp = 0, - .query = "", - .eval = 1, - .list = 0, - .hash = 0, - .search = 0, - .search_strict = 0, - .help = 0, -}; - -void -print_help(char * argv0) { - printf("%s [OPTION] FILE ...\n", argv0); - printf("OPTIONS:\n"); - printf("--format json,html,rcp\n"); - printf("--to-{json,html,rcp}\n"); - printf("-j json\n"); - printf("-w html\n"); - printf("-r rcp\n"); - printf("-l, --list-ingredients\n"); - printf("-s TERMS, --search TERMS\n"); - printf("-S TERMS, --strict TERMS\n"); - printf("-n, --no-eval\n"); -} - -int -main(int argc, char * argv[]) -{ - fdebug("--- Debug mode is on ---\n"); - - int c; - - while (1) { - static struct option long_options[] = - { - /* <span class="roman">These options set a flag.</span> */ - // {"verbose", no_argument, &verbose_flag, 1}, - // {"brief", no_argument, &verbose_flag, 0}, - {"help", no_argument, 0, 'h'}, - {"no-eval", no_argument, 0, 'n'}, - {"to-json", no_argument, 0, 'j'}, - {"to-html", no_argument, 0, 'w'}, - {"to-rcp", no_argument, 0, 'r'}, - {"format", required_argument, 0, 'f'}, - {"search", required_argument, 0, 's'}, - {"strict", required_argument, 0, 'S'}, - {"hash", required_argument, 0, 'H'}, - {"list-ingredients", no_argument, 0, 'l'}, - // {"to-rcp", required_argument, 0, 'r'}, - {0, 0, 0, 0} - }; - - int option_index = 0; - - c = getopt_long (argc, argv, "jnlhrwf:s:S:H:", - long_options, &option_index); - - if (c == -1) - break; - - switch (c) { - case 0: - if (long_options[option_index].flag != 0) - break; - printf ("option %s", long_options[option_index].name); - if (optarg) - printf (" with arg %s", optarg); - printf ("\n"); - break; - case 's': - opt.search = 1; - strcpy(opt.query, optarg); - break; - case 'S': - opt.search = 1; - opt.search_strict = 1; - strcpy(opt.query, optarg); - break; - case 'H': - opt.hash = 1; - strcpy(opt.query, optarg); - break; - case 'j': - opt.json = 1; - break; - case 'w': - opt.html = 1; - break; - case 'r': - opt.rcp = 1; - break; - case 'l': - opt.list = 1; - break; - case 'h': - opt.help = 1; - break; - case 'n': - opt.eval = 0; - break; - case '?': - return -1; - break; - default: - abort (); - } - } - - if (opt.help) { - print_help(argv[0]); - return 0; - } - - char ** lib = NULL; - int n = collect_library(&lib, argv, argc, optind); - - cookbook = (recipe **)malloc(sizeof(recipe *) * n); - for (int i = 0; i < n; i++) { - cookbook[i] = parse(lib[i], NULL); - if (opt.eval) { - recipe * _r = eval(cookbook[i]); - free_recipe(cookbook[i]); - cookbook[i] = _r; - } - } - free_library(lib, n); - - for (int i = 0; i < n; i++) { - listing(cookbook[i]); - } - - for (int i = 0; i < n; i++) { - free_recipe(cookbook[i]); - } - free(cookbook); - - return 0; -} |