diff options
-rw-r--r-- | allocator.c | 2 | ||||
-rw-r--r-- | arr.c | 2 | ||||
-rw-r--r-- | package.c | 24 | ||||
-rw-r--r-- | toc.c | 1 | ||||
-rw-r--r-- | types.c | 3 | ||||
-rw-r--r-- | types.h | 8 |
6 files changed, 31 insertions, 9 deletions
diff --git a/allocator.c b/allocator.c index 3c0aec0..2fc607d 100644 --- a/allocator.c +++ b/allocator.c @@ -8,7 +8,7 @@ static void *err_malloc(size_t bytes); static void *err_calloc(size_t n, size_t sz); static void *err_realloc(void *prev, size_t new_size); #ifdef TOC_DEBUG -/* #define NO_ALLOCATOR 1 /\* useful for debugging; valgrind (maybe) checks writing past the end of a malloc, but that won't work with an allocator *\/ */ +#define NO_ALLOCATOR 1 /* useful for debugging; valgrind (maybe) checks writing past the end of a malloc, but that won't work with an allocator */ #endif /* number of bytes a page hold, not including the header */ #define PAGE_BYTES (16384 - sizeof(Page)) @@ -186,7 +186,7 @@ You shouldn't rely on this, though, e.g. by doing #define arr_last(arr) arr_last_((void *)(arr), sizeof *(arr)) /* one past last, or NULL if empty */ #define arr_end(arr) arr_end_((void *)(arr), sizeof *(arr)) -#define arr_foreach(arr, type, var) for (type *var = arr, *JOIN(var,_foreach_end) = arr_end(arr); var < JOIN(var,_foreach_end); ++var) /* NOTE: < is useful here because currently it's possible for var_foreach_end to be NULL but var could start out not null */ +#define arr_foreach(arr, type, var) for (type *var = arr, *var##_foreach_end = arr_end(arr); var < var##_foreach_end; ++var) /* NOTE: < is useful here because currently it's possible for var_foreach_end to be NULL but var could start out not null */ #define arr_remove_last(arr) arr_remove_last_((void **)(arr)), (void)sizeof **(arr) #define arr_remove_lasta(arr, a) arr_remove_lasta_((void **)(arr), sizeof **(arr), (a)) #define arr_copya(out, in, a) do { assert(sizeof *(in) == sizeof **(out)); arr_copya_((void **)(out), (in), sizeof **(out), (a)); } while(0) @@ -7,10 +7,11 @@ static bool export_decl(Exporter *ex, Declaration *d); static bool export_block(Exporter *ex, Block *b); -static void exptr_create(Exporter *exptr, FILE *out) { - exptr->out = out; - exptr->export_locations = true; - exptr->exported_fns = NULL; +static void exptr_create(Exporter *ex, FILE *out) { + ex->out = out; + ex->export_locations = true; + ex->exported_fns = NULL; + ex->exported_structs = NULL; } @@ -412,6 +413,15 @@ static bool export_fn(Exporter *ex, FnExpr *f, Location where) { return true; } +static bool export_struct(Exporter *ex, StructDef *s, Location where) { + arr_foreach(s->fields, Field, f) { + export_ident(ex, f->name); + if (!export_type(ex, f->type, where)) + return false; + } + return true; +} + /* does NOT close the file */ static bool exptr_finish(Exporter *ex) { if (!export_len32(ex, arr_len(ex->exported_fns), "exported functions", LOCATION_NONE)) @@ -420,5 +430,11 @@ static bool exptr_finish(Exporter *ex) { if (!export_fn(ex, f->fn, f->where)) return false; } + arr_clear(&ex->exported_fns); + arr_foreach(ex->exported_structs, StructDefWithLocation, s) { + if (!export_struct(ex, s->struc, s->where)) + return false; + } + arr_clear(&ex->exported_structs); return true; } @@ -33,7 +33,6 @@ static void print_val(Value v, Type *t); /* misc */ -#define JOIN(a,b) a##b #define STRINGIFY2(x) #x #define STRINGIFY(x) STRINGIFY2(x) @@ -1930,7 +1930,8 @@ static bool types_block(Typer *tr, Block *b) { success = false; goto ret; } - b->ret_expr = e; + b->ret_expr = typer_malloc(tr, sizeof *b->ret_expr); + *b->ret_expr = *e; arr_remove_lasta(&b->stmts, tr->allocr); } } @@ -73,7 +73,7 @@ typedef U32 IdentID; /* identifier ID for cgen (anonymous variables). not to be #ifdef TOC_DEBUG #define SOURCE_LOCATION char *src_file; int src_line; #define SOURCE_LOCATION_PARAMS char *src_file, int src_line, -#define DEBUG_UNDERSCORE(x) JOIN(x,_) +#define DEBUG_UNDERSCORE(x) x##_ #else #define SOURCE_LOCATION #define SOURCE_LOCATION_PARAMS @@ -754,10 +754,16 @@ typedef struct { Location where; } FnWithLocation; +typedef struct { + StructDef *struc; + Location where; +} StructDefWithLocation; + typedef struct Exporter { FILE *out; /* .top (toc package) to output to */ bool export_locations; FnWithLocation *exported_fns; + StructDefWithLocation *exported_structs; } Exporter; typedef struct CGenerator { |