From 71c7686269a7e854ec5672e1848f6ee39167884c Mon Sep 17 00:00:00 2001 From: Leo Tenenbaum Date: Wed, 8 Jan 2020 11:19:37 -0500 Subject: more importing (also turns out export is a keyword in c++) --- binfile.c | 2 +- build.sh | 6 +++++- eval.c | 2 +- package.c | 65 ++++++++++++++++++++++++++++++++++++++++++++++++++++++----- test-all.sh | 4 ++++ test-build.sh | 8 ++++++++ toc.c | 1 + types.c | 8 ++++++-- types.h | 5 +++++ 9 files changed, 91 insertions(+), 10 deletions(-) create mode 100755 test-all.sh create mode 100755 test-build.sh diff --git a/binfile.c b/binfile.c index 04c81e9..d9730c3 100644 --- a/binfile.c +++ b/binfile.c @@ -299,7 +299,7 @@ static void binfile_test(void) { write_f32(fp, d); bool e = true; write_bool(fp, e); - F64 f = (F64)-34.69459324823; + F64 f = (F64)34.69459324823; write_f64(fp, f); fseek(fp, 0L, SEEK_SET); diff --git a/build.sh b/build.sh index da042bd..52831a1 100755 --- a/build.sh +++ b/build.sh @@ -10,9 +10,13 @@ fi ADDITIONAL_FLAGS="$CFLAGS -Wno-unused-function" if [ "$CC" = "clang" ]; then - WARNINGS='-Wall -Wextra -Wpedantic -Wshadow -Wconversion -Wimplicit-fallthrough' + WARNINGS='-Wall -Wextra -Wpedantic -Wshadow -Wconversion -Wimplicit-fallthrough -Wno-missing-braces' elif [ "$CC" = "gcc" ]; then WARNINGS='-Wall -Wextra -Wpedantic -Wshadow -Wconversion -Wno-pointer-to-int-cast' +elif [ "$CC" = "tcc" ]; then + WARNINGS='-w' +elif [ "$CC" = "g++" ]; then + WARNINGS='-w -fpermissive' else WARNINGS='' fi diff --git a/eval.c b/eval.c index 9a6fc28..2f6baa8 100644 --- a/eval.c +++ b/eval.c @@ -1276,7 +1276,7 @@ static bool eval_expr(Evaluator *ev, Expression *e, Value *v) { index_val->i64 = 0; while (index_val->i64 < len) { - void *ptr; + void *ptr = NULL; if (!eval_val_ptr_at_index(e->where, &of, (U64)index_val->i64, of_type, &ptr, NULL)) return false; if (uses_ptr) diff --git a/package.c b/package.c index 5c429b0..0bf724d 100644 --- a/package.c +++ b/package.c @@ -25,42 +25,81 @@ static void exptr_create(Exporter *ex, FILE *out, char *code) { static inline void export_u8(Exporter *ex, U8 u8) { write_u8(ex->out, u8); } +static inline U8 import_u8(Importer *i) { + return read_u8(i->in); +} static inline void export_i8(Exporter *ex, I8 i8) { write_i8(ex->out, i8); } +static inline I8 import_i8(Importer *i) { + return read_i8(i->in); +} static inline void export_u16(Exporter *ex, U16 u16) { write_u16(ex->out, u16); } +static inline U16 import_u16(Importer *i) { + return read_u16(i->in); +} static inline void export_i16(Exporter *ex, I16 i16) { write_i16(ex->out, i16); } +static inline I16 import_i16(Importer *i) { + return read_i16(i->in); +} static inline void export_u32(Exporter *ex, U32 u32) { write_u32(ex->out, u32); } +static inline U32 import_u32(Importer *i) { + return read_u32(i->in); +} static inline void export_i32(Exporter *ex, I32 i32) { write_i32(ex->out, i32); } +static inline I32 import_i32(Importer *i) { + return read_i32(i->in); +} static inline void export_u64(Exporter *ex, U64 u64) { write_u64(ex->out, u64); } +static inline U64 import_u64(Importer *i) { + return read_u64(i->in); +} static inline void export_i64(Exporter *ex, I64 i64) { write_i64(ex->out, i64); } +static inline I64 import_i64(Importer *i) { + return read_i64(i->in); +} static inline void export_f32(Exporter *ex, F32 f32) { write_f32(ex->out, f32); } +static inline F32 import_f32(Importer *i) { + return read_f32(i->in); +} static inline void export_f64(Exporter *ex, F64 f64) { write_f64(ex->out, f64); } +static inline F64 import_f64(Importer *i) { + return read_f64(i->in); +} static inline void export_bool(Exporter *ex, bool b) { write_bool(ex->out, b); } +static inline bool import_bool(Importer *i) { + return read_bool(i->in); +} static inline void export_char(Exporter *ex, char c) { write_char(ex->out, c); } +static inline bool import_char(Importer *i) { + return read_char(i->in); +} static inline void export_vlq(Exporter *ex, U64 x) { write_vlq(ex->out, x); } +static inline bool import_vlq(Importer *i) { + return read_vlq(i->in); +} static inline void export_str(Exporter *ex, const char *str, size_t len) { #ifdef TOC_DEBUG @@ -97,14 +136,15 @@ static inline void export_len(Exporter *ex, size_t len) { export_vlq(ex, (U64)len); } +static const U8 toc_package_indicator[3] = {116, 111, 112}; + /* writes the header */ static void exptr_start(Exporter *ex, const char *pkg_name, size_t pkg_name_len) { - const U8 toc[3] = {116, 111, 112}; /* "top" in ASCII */ const char *code = ex->code; ex->started = true; - export_u8(ex, toc[0]); - export_u8(ex, toc[1]); - export_u8(ex, toc[2]); + export_u8(ex, toc_package_indicator[0]); + export_u8(ex, toc_package_indicator[1]); + export_u8(ex, toc_package_indicator[2]); export_u32(ex, TOP_FMT_VERSION); assert(ftell(ex->out) == 7L); export_u64(ex, 0); /* placeholder for identifier offset in file */ @@ -606,6 +646,21 @@ static bool exptr_finish(Exporter *ex) { return true; } -static void import_pkg(Package *p, FILE *f) { +/* where = where was this imported */ +static bool import_pkg(Package *p, FILE *f, const char *fname, Location where) { + Importer i = {0}; idents_create(&p->idents); + i.pkg = p; + i.in = f; + U8 toc[3]; + toc[0] = import_u8(&i); + toc[1] = import_u8(&i); + toc[2] = import_u8(&i); + if (toc[0] != toc_package_indicator[0] || + toc[1] != toc_package_indicator[1] || + toc[2] != toc_package_indicator[2]) { + err_print(where, "%s is not a toc package file.", fname); + return false; + } + return true; } diff --git a/test-all.sh b/test-all.sh new file mode 100755 index 0000000..11243db --- /dev/null +++ b/test-all.sh @@ -0,0 +1,4 @@ +#!/bin/sh +./test-build.sh || exit 1 +./build.sh || exit 1 +tests/test.sh || exit 1 diff --git a/test-build.sh b/test-build.sh new file mode 100755 index 0000000..c10e3f5 --- /dev/null +++ b/test-build.sh @@ -0,0 +1,8 @@ +#!/bin/sh +./build.sh || exit 1 +./build.sh release || exit 1 +for CC in tcc gcc clang g++ ; do + + CC="$CC" ./build.sh || exit 1 + CC="$CC" ./build.sh release || exit 1 +done diff --git a/toc.c b/toc.c index ebeb4ff..c7cc82b 100644 --- a/toc.c +++ b/toc.c @@ -22,6 +22,7 @@ #ifdef __cplusplus #define new new_ #define this this_ +#define export export_ #elif __STDC_VERSION__ < 199901 #define inline #endif diff --git a/types.c b/types.c index 2bb38e0..cd355d4 100644 --- a/types.c +++ b/types.c @@ -894,7 +894,11 @@ static bool types_expr(Typer *tr, Expression *e) { free(filename); return false; } - import_pkg(pkg, fp); + if (!import_pkg(pkg, fp, filename, e->where)) { + free(filename); + return false; + } + free(filename); fclose(fp); } } break; @@ -1199,7 +1203,7 @@ static bool types_expr(Typer *tr, Expression *e) { arg_exprs[idx] = expr; if (params_set[idx]) { Declaration *param = fn_decl->params; - Identifier *ident; + Identifier *ident = NULL; for (Declaration *end = arr_end(fn_decl->params); param < end; ++param) { ident = param->idents; for (Identifier *iend = arr_end(param->idents); ident != iend; ++ident) { diff --git a/types.h b/types.h index 478df17..4c5add0 100644 --- a/types.h +++ b/types.h @@ -784,6 +784,11 @@ typedef struct Exporter { const char *code; } Exporter; +typedef struct Importer { + FILE *in; + Package *pkg; +} Importer; + typedef struct CGenerator { Allocator *allocr; FILE *outc; -- cgit v1.2.3