summaryrefslogtreecommitdiffstats
path: root/cookbook.c
diff options
context:
space:
mode:
authorgramanas <anastasis.gramm2@gmail.com>2022-01-31 17:25:17 +0200
committergramanas <anastasis.gramm2@gmail.com>2022-01-31 17:25:17 +0200
commitc9605d74204f2502ba57b8e9acd21350f07bf032 (patch)
tree0f961263f97730b3388ad25a3af48b1b5b6cccfd /cookbook.c
parent53ab9ae05a579a19c626e8be0c1e2cf9244bf863 (diff)
downloadfoodtools-c9605d74204f2502ba57b8e9acd21350f07bf032.tar.gz
foodtools-c9605d74204f2502ba57b8e9acd21350f07bf032.tar.bz2
foodtools-c9605d74204f2502ba57b8e9acd21350f07bf032.zip
Move project to autoconf
Diffstat (limited to 'cookbook.c')
-rw-r--r--cookbook.c162
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;
-}