summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog12
-rw-r--r--Makefile2
-rw-r--r--parser.c89
-rw-r--r--parser.h5
-rw-r--r--parser.l2
5 files changed, 107 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 43a4cc69..b36f5d39 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,17 @@
2015-02-25 Kaz Kylheku <kaz@kylheku.com>
+ * Makefile (OBJS): Add parser.o.
+
+ * parser.h (parser_s): Declared.
+ (parse_init): Declaration removed.
+ (parser_l_init): Declared.
+
+ * parser.l (parse_init): Function renamed to parser_l_init.
+
+ * parser.c: New file.
+
+2015-02-25 Kaz Kylheku <kaz@kylheku.com>
+
New ignerr macro.
* eval.c (me_ignerr): New static function.
diff --git a/Makefile b/Makefile
index 89ebcc32..2f1e9bef 100644
--- a/Makefile
+++ b/Makefile
@@ -45,7 +45,7 @@ OBJS-y := # make sure OBJ-y is a value variable, not a macro variable
EXTRA_OBJS-y :=
OBJS := txr.o lex.yy.o y.tab.o match.o lib.o regex.o gc.o unwind.o stream.o
-OBJS += arith.o hash.o utf8.o filter.o eval.o rand.o combi.o sysif.o
+OBJS += arith.o hash.o utf8.o filter.o eval.o parser.o rand.o combi.o sysif.o
OBJS-$(debug_support) += debug.o
OBJS-$(have_syslog) += syslog.o
OBJS-$(have_glob) += glob.o
diff --git a/parser.c b/parser.c
new file mode 100644
index 00000000..47d14fcb
--- /dev/null
+++ b/parser.c
@@ -0,0 +1,89 @@
+/* Copyright 2009-2014
+ * Kaz Kylheku <kaz@kylheku.com>
+ * Vancouver, Canada
+ * All rights reserved.
+ *
+ * Redistribution of this software in source and binary forms, with or without
+ * modification, is permitted provided that the following two conditions are met.
+ *
+ * Use of this software in any manner constitutes agreement with the disclaimer
+ * which follows the two conditions.
+ *
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in
+ * the documentation and/or other materials provided with the
+ * distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
+ * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL THE
+ * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DAMAGES, HOWEVER CAUSED,
+ * AND UNDER ANY THEORY OF LIABILITY, ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include <stdio.h>
+#include <assert.h>
+#include <limits.h>
+#include <dirent.h>
+#include <stdlib.h>
+#include <stdarg.h>
+#include <setjmp.h>
+#include <wchar.h>
+#include <signal.h>
+#include "config.h"
+#include "lib.h"
+#include "signal.h"
+#include "unwind.h"
+#include "gc.h"
+#include "regex.h"
+#include "utf8.h"
+#include "match.h"
+#include "hash.h"
+#include "eval.h"
+#include "stream.h"
+#include "parser.h"
+
+val parser_s;
+
+static void parser_mark(val obj)
+{
+ parser_t *p = coerce(parser_t *, obj->co.handle);
+ gc_mark(p->stream);
+ gc_mark(p->name);
+ gc_mark(p->prepared_msg);
+ gc_mark(p->syntax_tree);
+}
+
+static struct cobj_ops parser_ops = {
+ eq,
+ cobj_print_op,
+ cobj_destroy_free_op,
+ parser_mark,
+ cobj_hash_op,
+};
+
+val parser(val stream, val lineno)
+{
+ parser_t *p = coerce(parser_t *, chk_malloc(sizeof *p));
+ val parser;
+ p->lineno = 0;
+ p->errors = 0;
+ p->stream = nil;
+ p->name = nil;
+ p->prepared_msg = nil;
+ p->syntax_tree = nil;
+ p->scanner = 0;
+ parser = cobj(coerce(mem_t *, p), parser_s, &parser_ops);
+ p->lineno = c_num(default_arg(lineno, one));
+ p->stream = stream;
+ return parser;
+}
+
+void parse_init(void)
+{
+ parser_s = intern(lit("parser"), user_package);
+ parser_l_init();
+}
diff --git a/parser.h b/parser.h
index dfd8b29e..97748329 100644
--- a/parser.h
+++ b/parser.h
@@ -43,6 +43,7 @@ typedef void *yyscan_t;
extern const wchar_t *spec_file;
extern val form_to_ln_hash;
+extern val parser_s;
void yyerror(scanner_t *scanner, parser_t *, const char *s);
void yyerr(scanner_t *scanner, const char *s);
void yyerrorf(scanner_t *scanner, val s, ...);
@@ -53,7 +54,7 @@ int yylex_init(yyscan_t *pscanner);
int yylex_destroy(yyscan_t scanner);
parser_t *yyget_extra(yyscan_t scanner);
void yyset_extra(parser_t *, yyscan_t);
-void parse_init(void);
+void parser_l_init(void);
void open_txr_file(val spec_file, val *name, val *stream);
int parse(val stream, val name, parser_t *parser);
val source_loc(val form);
@@ -66,3 +67,5 @@ INLINE val rlcp(val to, val from)
val rlcp_tree(val to, val from);
val regex_parse(val string, val error_stream);
val lisp_parse(val source, val error_stream, val error_return_val);
+val parser(val stream, val lineno);
+void parse_init(void);
diff --git a/parser.l b/parser.l
index 0c3ba64e..cb61be41 100644
--- a/parser.l
+++ b/parser.l
@@ -951,7 +951,7 @@ val source_loc_str(val form)
lit("source location n/a"));
}
-void parse_init(void)
+void parser_l_init(void)
{
prot1(&form_to_ln_hash);
form_to_ln_hash = make_hash(t, nil, nil);