summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLeo Tenenbaum <pommicket@gmail.com>2020-01-10 11:58:53 -0500
committerLeo Tenenbaum <pommicket@gmail.com>2020-01-10 11:58:53 -0500
commit54cbba58ae9c46c5cdd36d260200a5eacf791a0a (patch)
tree809797a4773e52c62d78816be823af60711e5713
parent50e64bed4bc38e949d440d83337a90b8c011a4c7 (diff)
more importing
-rw-r--r--package.c24
-rw-r--r--types.c2
-rw-r--r--types.h1
3 files changed, 22 insertions, 5 deletions
diff --git a/package.c b/package.c
index beb7b0a..a6e0880 100644
--- a/package.c
+++ b/package.c
@@ -10,6 +10,7 @@ static bool export_decl(Exporter *ex, Declaration *d);
static bool export_block(Exporter *ex, Block *b);
static bool export_expr(Exporter *ex, Expression *e);
static bool import_footer(Importer *i);
+static void import_decl(Importer *im, Declaration *d);
static void exptr_create(Exporter *ex, FILE *out) {
ex->out = out;
@@ -222,16 +223,19 @@ static bool import_pkg(Allocator *allocr, Package *p, FILE *f, const char *fname
char *code = import_str(&i, code_len);
err_ctx->str = code;
}
- long code_offset = ftell(f);
+ long decls_offset = ftell(f);
if (ident_offset > LONG_MAX) {
err_print(where, "File %s is too large.", fname);
}
fseek(f, (long)ident_offset, SEEK_SET);
+ /* read footer */
if (!import_footer(&i))
return false;
- fseek(f, code_offset, SEEK_SET);
-
-
+ fseek(f, decls_offset, SEEK_SET);
+ /* read declarations */
+ while (import_u8(&i)) {
+ import_decl(&i, arr_add(&i.decls));
+ }
free(i.ident_map);
return true;
@@ -621,6 +625,16 @@ static bool export_decl(Exporter *ex, Declaration *d) {
return true;
}
+static void import_decl(Importer *im, Declaration *d) {
+
+}
+
+/* exports a declaration. to be used by other files instead of export_decl. */
+static bool export_decl_external(Exporter *ex, Declaration *d) {
+ export_u8(ex, 1); /* indicate that there are more declarations */
+ return export_decl(ex, d);
+}
+
static bool export_stmt(Exporter *ex, Statement *s) {
export_u8(ex, (U8)s->kind);
switch (s->kind) {
@@ -682,6 +696,8 @@ static bool export_struct(Exporter *ex, StructDef *s) {
/* does NOT close the file */
static bool exptr_finish(Exporter *ex) {
+ export_u8(ex, 0); /* no more declarations */
+
long ident_offset = ftell(ex->out);
fseek(ex->out, 7L, SEEK_SET);
diff --git a/types.c b/types.c
index 4544474..c5c00b6 100644
--- a/types.c
+++ b/types.c
@@ -2199,7 +2199,7 @@ static bool types_decl(Typer *tr, Declaration *d) {
err_print(d->where, "Declaration marked for exporting, but no package output was specified.");
success = false;
} else {
- success = export_decl(tr->exptr, d);
+ success = export_decl_external(tr->exptr, d);
}
}
} else {
diff --git a/types.h b/types.h
index 605b6d2..f2d4cc3 100644
--- a/types.h
+++ b/types.h
@@ -811,6 +811,7 @@ typedef struct Importer {
Allocator *allocr;
Identifier *ident_map; /* [i] = value of identifier with ID i */
ErrCtx err_ctx;
+ Declaration *decls;
} Importer;
typedef struct CGenerator {