summaryrefslogtreecommitdiffstatshomepage
path: root/stmhal/lexerfatfs.c
diff options
context:
space:
mode:
Diffstat (limited to 'stmhal/lexerfatfs.c')
-rw-r--r--stmhal/lexerfatfs.c61
1 files changed, 61 insertions, 0 deletions
diff --git a/stmhal/lexerfatfs.c b/stmhal/lexerfatfs.c
new file mode 100644
index 0000000000..1910587d8e
--- /dev/null
+++ b/stmhal/lexerfatfs.c
@@ -0,0 +1,61 @@
+#include <stdint.h>
+#include <stdio.h>
+
+#if 0
+#include "ff.h"
+#endif
+
+#include "misc.h"
+#include "mpconfig.h"
+#include "qstr.h"
+#include "lexer.h"
+#include "lexerfatfs.h"
+
+#if 0
+typedef struct _mp_lexer_file_buf_t {
+ FIL fp;
+ char buf[20];
+ uint16_t len;
+ uint16_t pos;
+} mp_lexer_file_buf_t;
+
+static unichar file_buf_next_char(mp_lexer_file_buf_t *fb) {
+ if (fb->pos >= fb->len) {
+ if (fb->len < sizeof(fb->buf)) {
+ return MP_LEXER_CHAR_EOF;
+ } else {
+ UINT n;
+ f_read(&fb->fp, fb->buf, sizeof(fb->buf), &n);
+ if (n == 0) {
+ return MP_LEXER_CHAR_EOF;
+ }
+ fb->len = n;
+ fb->pos = 0;
+ }
+ }
+ return fb->buf[fb->pos++];
+}
+
+static void file_buf_close(mp_lexer_file_buf_t *fb) {
+ f_close(&fb->fp);
+ m_del_obj(mp_lexer_file_buf_t, fb);
+}
+#endif
+
+mp_lexer_t *mp_lexer_new_from_file(const char *filename) {
+#if 0
+ mp_lexer_file_buf_t *fb = m_new_obj(mp_lexer_file_buf_t);
+ FRESULT res = f_open(&fb->fp, filename, FA_READ);
+ if (res != FR_OK) {
+ m_del_obj(mp_lexer_file_buf_t, fb);
+ return NULL;
+ }
+ UINT n;
+ f_read(&fb->fp, fb->buf, sizeof(fb->buf), &n);
+ fb->len = n;
+ fb->pos = 0;
+ return mp_lexer_new(qstr_from_str(filename), fb, (mp_lexer_stream_next_char_t)file_buf_next_char, (mp_lexer_stream_close_t)file_buf_close);
+#else
+ return NULL;
+#endif
+}