summaryrefslogtreecommitdiffhomepage
path: root/main.c
diff options
context:
space:
mode:
authorJo-Philipp Wich <jo@mein.io>2021-05-14 18:45:10 +0200
committerJo-Philipp Wich <jo@mein.io>2021-05-14 18:46:31 +0200
commit1ddf5b68fa60736c1dd9ffda5eba09bbd90309e1 (patch)
tree336e3162fbef90b4f838d2effc616b4a1bb20037 /main.c
parent9951a003e53d39a8d00b13b694a3a106e161c552 (diff)
lexer: skip interpreter line in any source buffer
Skip interpreter lines in any source buffer and handle the skipping in the lexer itself, to avoid reporting wrongly shifted token offsets to the compiler, resulting in wrong error locations and source contexts. Signed-off-by: Jo-Philipp Wich <jo@mein.io>
Diffstat (limited to 'main.c')
-rw-r--r--main.c27
1 files changed, 3 insertions, 24 deletions
diff --git a/main.c b/main.c
index baea9fb..3fd1f25 100644
--- a/main.c
+++ b/main.c
@@ -102,35 +102,17 @@ register_variable(uc_value_t *scope, const char *key, uc_value_t *val)
static int
parse(uc_parse_config *config, uc_source *src,
- bool skip_shebang, uc_value_t *env, uc_value_t *modules,
+ uc_value_t *env, uc_value_t *modules,
int argc, char **argv)
{
uc_value_t *globals = NULL;
uc_function_t *entry;
uc_vm vm = { 0 };
- int c, c2, rc = 0;
+ int rc = 0;
char *err;
uc_vm_init(&vm, config);
- if (skip_shebang) {
- c = fgetc(src->fp);
- c2 = fgetc(src->fp);
-
- if (c == '#' && c2 == '!') {
- while ((c = fgetc(src->fp)) != EOF) {
- src->off++;
-
- if (c == '\n')
- break;
- }
- }
- else {
- ungetc(c2, src->fp);
- ungetc(c, src->fp);
- }
- }
-
entry = uc_compile(config, src, &err);
if (!entry) {
@@ -243,7 +225,6 @@ main(int argc, char **argv)
uc_value_t *env = NULL, *modules = NULL, *o, *p;
uc_source *source = NULL, *envfile = NULL;
char *stdin = NULL, *c;
- bool shebang = false;
int opt, rv = 0;
uc_parse_config config = {
@@ -384,8 +365,6 @@ main(int argc, char **argv)
rv = 1;
goto out;
}
-
- shebang = true;
}
if (!source) {
@@ -394,7 +373,7 @@ main(int argc, char **argv)
goto out;
}
- rv = parse(&config, source, shebang, env, modules, argc, argv);
+ rv = parse(&config, source, env, modules, argc, argv);
out:
ucv_put(modules);