summaryrefslogtreecommitdiffstatshomepage
path: root/stm/lexerstr.c
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2014-01-08 15:08:08 +0000
committerDamien George <damien.p.george@gmail.com>2014-01-08 15:08:08 +0000
commitdc141db64de467b6982ec6d7edad3fcf62b994ab (patch)
tree7031340f4c70e1319b1c78b31adca329fa1f4bc3 /stm/lexerstr.c
parentb97669ab9432146c1303dedfaa7b98f7ede3f8db (diff)
parente6b6af515449e67d5d3648818a191f3420d6f519 (diff)
downloadmicropython-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.c28
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);
+}