2013-10-20 17:42:00 +01:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include "ff.h"
|
|
|
|
|
|
|
|
#include "misc.h"
|
|
|
|
#include "lexer.h"
|
2014-01-07 17:49:42 +00:00
|
|
|
#include "lexerfatfs.h"
|
2013-10-20 17:42:00 +01:00
|
|
|
|
2014-01-16 22:09:13 +00:00
|
|
|
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) {
|
2013-10-20 17:42:00 +01:00
|
|
|
if (fb->pos >= fb->len) {
|
|
|
|
if (fb->len < sizeof(fb->buf)) {
|
2013-12-21 18:17:45 +00:00
|
|
|
return MP_LEXER_CHAR_EOF;
|
2013-10-20 17:42:00 +01:00
|
|
|
} else {
|
|
|
|
UINT n;
|
|
|
|
f_read(&fb->fp, fb->buf, sizeof(fb->buf), &n);
|
2013-10-22 21:13:36 +01:00
|
|
|
if (n == 0) {
|
2013-12-21 18:17:45 +00:00
|
|
|
return MP_LEXER_CHAR_EOF;
|
2013-10-22 21:13:36 +01:00
|
|
|
}
|
2013-10-20 17:42:00 +01:00
|
|
|
fb->len = n;
|
|
|
|
fb->pos = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return fb->buf[fb->pos++];
|
|
|
|
}
|
|
|
|
|
2014-01-16 22:09:13 +00:00
|
|
|
static void file_buf_close(mp_lexer_file_buf_t *fb) {
|
2013-10-20 17:42:00 +01:00
|
|
|
f_close(&fb->fp);
|
2014-01-16 22:09:13 +00:00
|
|
|
m_del_obj(mp_lexer_file_buf_t, fb);
|
2013-10-20 17:42:00 +01:00
|
|
|
}
|
|
|
|
|
2014-01-16 22:09:13 +00:00
|
|
|
mp_lexer_t *mp_lexer_new_from_file(const char *filename) {
|
|
|
|
mp_lexer_file_buf_t *fb = m_new_obj(mp_lexer_file_buf_t);
|
2013-10-20 17:42:00 +01:00
|
|
|
FRESULT res = f_open(&fb->fp, filename, FA_READ);
|
|
|
|
if (res != FR_OK) {
|
2014-01-16 22:09:13 +00:00
|
|
|
m_del_obj(mp_lexer_file_buf_t, fb);
|
2013-10-20 17:42:00 +01:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
UINT n;
|
|
|
|
f_read(&fb->fp, fb->buf, sizeof(fb->buf), &n);
|
|
|
|
fb->len = n;
|
|
|
|
fb->pos = 0;
|
2013-12-21 18:17:45 +00:00
|
|
|
return mp_lexer_new(filename, fb, (mp_lexer_stream_next_char_t)file_buf_next_char, (mp_lexer_stream_close_t)file_buf_close);
|
2013-10-20 17:42:00 +01:00
|
|
|
}
|
2014-01-03 14:03:48 +00:00
|
|
|
|
2014-01-16 22:09:13 +00:00
|
|
|
/******************************************************************************/
|
|
|
|
// implementation of import
|
|
|
|
|
|
|
|
#include "ff.h"
|
|
|
|
|
2014-01-03 14:03:48 +00:00
|
|
|
mp_lexer_t *mp_import_open_file(qstr mod_name) {
|
2014-01-16 22:09:13 +00:00
|
|
|
vstr_t *vstr = vstr_new();
|
|
|
|
FRESULT res;
|
|
|
|
|
|
|
|
// look for module in src/
|
|
|
|
vstr_printf(vstr, "0:/src/%s.py", qstr_str(mod_name));
|
|
|
|
res = f_stat(vstr_str(vstr), NULL);
|
|
|
|
if (res == FR_OK) {
|
|
|
|
// found file
|
|
|
|
return mp_lexer_new_from_file(vstr_str(vstr)); // TODO does lexer need to copy the string? can we free it here?
|
|
|
|
}
|
|
|
|
|
|
|
|
// look for module in /
|
|
|
|
vstr_reset(vstr);
|
|
|
|
vstr_printf(vstr, "0:/%s.py", qstr_str(mod_name));
|
|
|
|
res = f_stat(vstr_str(vstr), NULL);
|
|
|
|
if (res == FR_OK) {
|
|
|
|
// found file
|
|
|
|
return mp_lexer_new_from_file(vstr_str(vstr)); // TODO does lexer need to copy the string? can we free it here?
|
|
|
|
}
|
|
|
|
|
|
|
|
// could not find file
|
|
|
|
vstr_free(vstr);
|
|
|
|
printf("import %s: could not find file in src/ or /\n", qstr_str(mod_name));
|
|
|
|
|
2014-01-03 14:03:48 +00:00
|
|
|
return NULL;
|
|
|
|
}
|