diff options
author | Damien George <damien.p.george@gmail.com> | 2014-01-08 15:08:08 +0000 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2014-01-08 15:08:08 +0000 |
commit | dc141db64de467b6982ec6d7edad3fcf62b994ab (patch) | |
tree | 7031340f4c70e1319b1c78b31adca329fa1f4bc3 /stm/lexerstr.c | |
parent | b97669ab9432146c1303dedfaa7b98f7ede3f8db (diff) | |
parent | e6b6af515449e67d5d3648818a191f3420d6f519 (diff) | |
download | micropython-dc141db64de467b6982ec6d7edad3fcf62b994ab.tar.gz micropython-dc141db64de467b6982ec6d7edad3fcf62b994ab.zip |
Merge branch 'master' of github.com:dpgeorge/micropython
Diffstat (limited to 'stm/lexerstr.c')
-rw-r--r-- | stm/lexerstr.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/stm/lexerstr.c b/stm/lexerstr.c new file mode 100644 index 0000000000..cc6be1d1ed --- /dev/null +++ b/stm/lexerstr.c @@ -0,0 +1,28 @@ +#include <stdint.h> +#include <stdio.h> + +#include "misc.h" +#include "lexer.h" +#include "lexerstr.h" + +unichar str_buf_next_char(mp_lexer_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(mp_lexer_str_buf_t *sb) { + if (sb->free) { + m_del(char, (char*)sb->src_beg, 0 /* don't know allocated size of src */); + } +} + +mp_lexer_t *mp_lexer_new_from_str_len(const char *src_name, const char *str, uint len, bool free_str, mp_lexer_str_buf_t *sb) { + 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); +} |