aboutsummaryrefslogtreecommitdiffstats
path: root/calc-example/calc.c
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2021-04-17 12:24:36 +0200
committerMattias Andrée <maandree@kth.se>2021-04-17 12:24:36 +0200
commitd37d1f54c986ff67af0e5edc62af60a4a1a21324 (patch)
treebee3bf705f8b67c3887b6846d52cafe72c6b7d68 /calc-example/calc.c
parentAdd inclusion guard to libparser.h (diff)
downloadlibparser-d37d1f54c986ff67af0e5edc62af60a4a1a21324.tar.gz
libparser-d37d1f54c986ff67af0e5edc62af60a4a1a21324.tar.bz2
libparser-d37d1f54c986ff67af0e5edc62af60a4a1a21324.tar.xz
Do not use libsimple outside of the generator
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to '')
-rw-r--r--calc-example/calc.c36
1 files changed, 18 insertions, 18 deletions
diff --git a/calc-example/calc.c b/calc-example/calc.c
index adda2ba..c5f6396 100644
--- a/calc-example/calc.c
+++ b/calc-example/calc.c
@@ -1,9 +1,9 @@
/* See LICENSE file for copyright and license details. */
+#include <stdint.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
#include <libparser.h>
-#include <libsimple.h>
-#include <libsimple-arg.h>
-
-USAGE("");
static void
@@ -107,29 +107,29 @@ main(int argc, char *argv[])
size_t size = 0;
ssize_t len;
intmax_t res;
- int exception;
+ int r;
- ARGBEGIN {
- default:
- usage();
- } ARGEND;
- if (argc)
- usage();
+ if (argc == 2 ? strcmp(argv[1], "--") : argc > 2) {
+ fprintf(stderr, "usage: %s\n", argv[0]);
+ return 1;
+ }
while ((len = getline(&line, &size, stdin)) >= 0) {
if (len && line[len - 1] == '\n')
line[--len] = '\0';
- input = libparser_parse_file(libparser_rule_table, line, (size_t)len, &exception);
- if (!input) {
- weprintf("didn't find anything to parse\n");
- free_input(input);
+ r = libparser_parse_file(libparser_rule_table, line, (size_t)len, &input);
+ if (r < 0) {
+ perror("libparser_parse_file");
+ continue;
+ } else if (!input) {
+ fprintf(stderr, "didn't find anything to parse\n");
continue;
} else if (input->end != (size_t)len) {
- weprintf("line could not be parsed, stopped at column %zu\n", input->end);
+ fprintf(stderr, "line could not be parsed, stopped at column %zu\n", input->end);
free_input(input);
continue;
- } else if (exception) {
- weprintf("premature end of line\n");
+ } else if (!r) {
+ fprintf(stderr, "premature end of line\n");
free_input(input);
continue;
}