diff options
author | Damien George <damien.p.george@gmail.com> | 2017-03-14 11:26:43 +1100 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2017-03-14 11:52:05 +1100 |
commit | 180045bce9282c4a658284e01348f57841e39cdd (patch) | |
tree | 9178dddca5ed0e0c0b5cab0a6aa72d281f48fc63 | |
parent | 25b6b62562e56fc2aaa78b72f5dfffc35bc2430c (diff) | |
download | micropython-180045bce9282c4a658284e01348f57841e39cdd.tar.gz micropython-180045bce9282c4a658284e01348f57841e39cdd.zip |
zephyr/main: Move lexer constructor to within NLR handler block.
And raise an exception when mp_lexer_new_from_file is called.
-rw-r--r-- | zephyr/main.c | 9 |
1 files changed, 2 insertions, 7 deletions
diff --git a/zephyr/main.c b/zephyr/main.c index 25bd88f768..1f8589a6c9 100644 --- a/zephyr/main.c +++ b/zephyr/main.c @@ -44,14 +44,9 @@ #include "lib/mp-readline/readline.h" void do_str(const char *src, mp_parse_input_kind_t input_kind) { - mp_lexer_t *lex = mp_lexer_new_from_str_len(MP_QSTR__lt_stdin_gt_, src, strlen(src), 0); - if (lex == NULL) { - printf("MemoryError: lexer could not allocate memory\n"); - return; - } - nlr_buf_t nlr; if (nlr_push(&nlr) == 0) { + mp_lexer_t *lex = mp_lexer_new_from_str_len(MP_QSTR__lt_stdin_gt_, src, strlen(src), 0); qstr source_name = lex->source_name; mp_parse_tree_t parse_tree = mp_parse(lex, input_kind); mp_obj_t module_fun = mp_compile(&parse_tree, source_name, MP_EMIT_OPT_NONE, true); @@ -130,7 +125,7 @@ void gc_collect(void) { } mp_lexer_t *mp_lexer_new_from_file(const char *filename) { - return NULL; + mp_raise_OSError(ENOENT); } mp_import_stat_t mp_import_stat(const char *path) { |