Commit 2e75a17b authored by Paul Sokolovsky's avatar Paul Sokolovsky

esp8266: Fix issue when current repl line was garbage-collected.

Reference it from root pointers section.
parent b1dfdaf6
...@@ -126,6 +126,7 @@ extern const struct _mp_obj_module_t onewire_module; ...@@ -126,6 +126,7 @@ extern const struct _mp_obj_module_t onewire_module;
#define MICROPY_PORT_ROOT_POINTERS \ #define MICROPY_PORT_ROOT_POINTERS \
const char *readline_hist[8]; \ const char *readline_hist[8]; \
vstr_t *repl_line; \
mp_obj_t mp_kbd_exception; \ mp_obj_t mp_kbd_exception; \
// We need to provide a declaration/definition of alloca() // We need to provide a declaration/definition of alloca()
......
...@@ -121,8 +121,11 @@ STATIC int parse_compile_execute(mp_lexer_t *lex, mp_parse_input_kind_t input_ki ...@@ -121,8 +121,11 @@ STATIC int parse_compile_execute(mp_lexer_t *lex, mp_parse_input_kind_t input_ki
#if MICROPY_REPL_EVENT_DRIVEN #if MICROPY_REPL_EVENT_DRIVEN
typedef struct _repl_t { typedef struct _repl_t {
// XXX line holds a root pointer! // This structure originally also held current REPL line,
vstr_t line; // but it was moved to MP_STATE_VM(repl_line) as containing
// root pointer. Still keep structure in case more state
// will be added later.
//vstr_t line;
bool cont_line; bool cont_line;
} repl_t; } repl_t;
...@@ -132,9 +135,9 @@ STATIC int pyexec_raw_repl_process_char(int c); ...@@ -132,9 +135,9 @@ STATIC int pyexec_raw_repl_process_char(int c);
STATIC int pyexec_friendly_repl_process_char(int c); STATIC int pyexec_friendly_repl_process_char(int c);
void pyexec_event_repl_init(void) { void pyexec_event_repl_init(void) {
vstr_init(&repl.line, 32); MP_STATE_VM(repl_line) = vstr_new_size(32);
repl.cont_line = false; repl.cont_line = false;
readline_init(&repl.line, ">>> "); readline_init(MP_STATE_VM(repl_line), ">>> ");
if (pyexec_mode_kind == PYEXEC_MODE_RAW_REPL) { if (pyexec_mode_kind == PYEXEC_MODE_RAW_REPL) {
pyexec_raw_repl_process_char(CHAR_CTRL_A); pyexec_raw_repl_process_char(CHAR_CTRL_A);
} else { } else {
...@@ -155,27 +158,27 @@ STATIC int pyexec_raw_repl_process_char(int c) { ...@@ -155,27 +158,27 @@ STATIC int pyexec_raw_repl_process_char(int c) {
return 0; return 0;
} else if (c == CHAR_CTRL_C) { } else if (c == CHAR_CTRL_C) {
// clear line // clear line
vstr_reset(&repl.line); vstr_reset(MP_STATE_VM(repl_line));
return 0; return 0;
} else if (c == CHAR_CTRL_D) { } else if (c == CHAR_CTRL_D) {
// input finished // input finished
} else { } else {
// let through any other raw 8-bit value // let through any other raw 8-bit value
vstr_add_byte(&repl.line, c); vstr_add_byte(MP_STATE_VM(repl_line), c);
return 0; return 0;
} }
// indicate reception of command // indicate reception of command
mp_hal_stdout_tx_str("OK"); mp_hal_stdout_tx_str("OK");
if (repl.line.len == 0) { if (MP_STATE_VM(repl_line)->len == 0) {
// exit for a soft reset // exit for a soft reset
mp_hal_stdout_tx_str("\r\n"); mp_hal_stdout_tx_str("\r\n");
vstr_clear(&repl.line); vstr_clear(MP_STATE_VM(repl_line));
return PYEXEC_FORCED_EXIT; return PYEXEC_FORCED_EXIT;
} }
mp_lexer_t *lex = mp_lexer_new_from_str_len(MP_QSTR__lt_stdin_gt_, repl.line.buf, repl.line.len, 0); mp_lexer_t *lex = mp_lexer_new_from_str_len(MP_QSTR__lt_stdin_gt_, MP_STATE_VM(repl_line)->buf, MP_STATE_VM(repl_line)->len, 0);
if (lex == NULL) { if (lex == NULL) {
mp_hal_stdout_tx_str("\x04MemoryError\r\n\x04"); mp_hal_stdout_tx_str("\x04MemoryError\r\n\x04");
} else { } else {
...@@ -186,7 +189,7 @@ STATIC int pyexec_raw_repl_process_char(int c) { ...@@ -186,7 +189,7 @@ STATIC int pyexec_raw_repl_process_char(int c) {
} }
reset: reset:
vstr_reset(&repl.line); vstr_reset(MP_STATE_VM(repl_line));
mp_hal_stdout_tx_str(">"); mp_hal_stdout_tx_str(">");
return 0; return 0;
...@@ -216,7 +219,7 @@ STATIC int pyexec_friendly_repl_process_char(int c) { ...@@ -216,7 +219,7 @@ STATIC int pyexec_friendly_repl_process_char(int c) {
} else if (ret == CHAR_CTRL_D) { } else if (ret == CHAR_CTRL_D) {
// exit for a soft reset // exit for a soft reset
mp_hal_stdout_tx_str("\r\n"); mp_hal_stdout_tx_str("\r\n");
vstr_clear(&repl.line); vstr_clear(MP_STATE_VM(repl_line));
return PYEXEC_FORCED_EXIT; return PYEXEC_FORCED_EXIT;
} }
...@@ -224,11 +227,11 @@ STATIC int pyexec_friendly_repl_process_char(int c) { ...@@ -224,11 +227,11 @@ STATIC int pyexec_friendly_repl_process_char(int c) {
return 0; return 0;
} }
if (!mp_repl_continue_with_input(vstr_null_terminated_str(&repl.line))) { if (!mp_repl_continue_with_input(vstr_null_terminated_str(MP_STATE_VM(repl_line)))) {
goto exec; goto exec;
} }
vstr_add_byte(&repl.line, '\n'); vstr_add_byte(MP_STATE_VM(repl_line), '\n');
repl.cont_line = true; repl.cont_line = true;
readline_note_newline("... "); readline_note_newline("... ");
return 0; return 0;
...@@ -249,14 +252,14 @@ STATIC int pyexec_friendly_repl_process_char(int c) { ...@@ -249,14 +252,14 @@ STATIC int pyexec_friendly_repl_process_char(int c) {
return 0; return 0;
} }
if (mp_repl_continue_with_input(vstr_null_terminated_str(&repl.line))) { if (mp_repl_continue_with_input(vstr_null_terminated_str(MP_STATE_VM(repl_line)))) {
vstr_add_byte(&repl.line, '\n'); vstr_add_byte(MP_STATE_VM(repl_line), '\n');
readline_note_newline("... "); readline_note_newline("... ");
return 0; return 0;
} }
exec: ; exec: ;
mp_lexer_t *lex = mp_lexer_new_from_str_len(MP_QSTR__lt_stdin_gt_, vstr_str(&repl.line), vstr_len(&repl.line), 0); mp_lexer_t *lex = mp_lexer_new_from_str_len(MP_QSTR__lt_stdin_gt_, vstr_str(MP_STATE_VM(repl_line)), vstr_len(MP_STATE_VM(repl_line)), 0);
if (lex == NULL) { if (lex == NULL) {
printf("MemoryError\n"); printf("MemoryError\n");
} else { } else {
...@@ -267,9 +270,9 @@ exec: ; ...@@ -267,9 +270,9 @@ exec: ;
} }
input_restart: input_restart:
vstr_reset(&repl.line); vstr_reset(MP_STATE_VM(repl_line));
repl.cont_line = false; repl.cont_line = false;
readline_init(&repl.line, ">>> "); readline_init(MP_STATE_VM(repl_line), ">>> ");
return 0; return 0;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment