diff options
author | Damien <damien.p.george@gmail.com> | 2013-12-29 18:01:01 +0000 |
---|---|---|
committer | Damien <damien.p.george@gmail.com> | 2013-12-29 18:01:01 +0000 |
commit | de690d128bbec4f53e8a7d6149738a6facae4382 (patch) | |
tree | 817a4c8ee94b7576dbfc47cd9a5de67f7c741109 /py | |
parent | b86e3f92932ec543788dc66948519d770d0e5bb0 (diff) | |
download | micropython-de690d128bbec4f53e8a7d6149738a6facae4382.tar.gz micropython-de690d128bbec4f53e8a7d6149738a6facae4382.zip |
Add unix-cpy, used to test Micro Python byte code against CPython.
Diffstat (limited to 'py')
-rw-r--r-- | py/emitcpy.c | 2 | ||||
-rw-r--r-- | py/lexerunix.c | 55 | ||||
-rw-r--r-- | py/lexerunix.h | 2 |
3 files changed, 58 insertions, 1 deletions
diff --git a/py/emitcpy.c b/py/emitcpy.c index 52f804925c..b107c0bf11 100644 --- a/py/emitcpy.c +++ b/py/emitcpy.c @@ -131,7 +131,7 @@ static void emit_cpy_import_star(emit_t *emit) { } } -static void emit_cpy_load_const_tok(emit_t *emit, py_token_kind_t tok) { +static void emit_cpy_load_const_tok(emit_t *emit, mp_token_kind_t tok) { emit_pre(emit, 1, 3); if (emit->pass == PASS_3) { printf("LOAD_CONST "); diff --git a/py/lexerunix.c b/py/lexerunix.c new file mode 100644 index 0000000000..ac07781b5a --- /dev/null +++ b/py/lexerunix.c @@ -0,0 +1,55 @@ +#include <stdint.h> +#include <stdio.h> +#include <unistd.h> +#include <fcntl.h> + +#include "misc.h" +#include "lexer.h" + +typedef struct _str_buf_t { + bool free; // free src_beg when done + const char *src_beg; // beginning of source + const char *src_cur; // current location in source + const char *src_end; // end (exclusive) of source +} str_buf_t; + +unichar str_buf_next_char(str_buf_t *sb) { + if (sb->src_cur < sb->src_end) { + return *sb->src_cur++; + } else { + return MP_LEXER_CHAR_EOF; + } +} + +void str_buf_free(str_buf_t *sb) { + if (sb) { + if (sb->free) { + m_free((char*)sb->src_beg); + } + m_free(sb); + } +} + +mp_lexer_t *mp_lexer_new_from_str_len(const char *src_name, const char *str, uint len, bool free_str) { + str_buf_t *sb = m_new(str_buf_t, 1); + sb->free = free_str; + sb->src_beg = str; + sb->src_cur = str; + sb->src_end = str + len; + return mp_lexer_new(src_name, sb, (mp_lexer_stream_next_char_t)str_buf_next_char, (mp_lexer_stream_close_t)str_buf_free); +} + +mp_lexer_t *mp_lexer_new_from_file(const char *filename) { + int fd = open(filename, O_RDONLY); + if (fd < 0) { + printf("cannot open file %s\n", filename); + return NULL; + } + uint size = lseek(fd, 0, SEEK_END); + lseek(fd, 0, SEEK_SET); + char *data = m_new(char, size); + read(fd, data, size); + close(fd); + + return mp_lexer_new_from_str_len(filename, data, size, true); +} diff --git a/py/lexerunix.h b/py/lexerunix.h new file mode 100644 index 0000000000..d86f202d53 --- /dev/null +++ b/py/lexerunix.h @@ -0,0 +1,2 @@ +mp_lexer_t *mp_lexer_new_from_str_len(const char *src_name, const char *str, uint len, bool free_str); +mp_lexer_t *mp_lexer_new_from_file(const char *filename); |