diff options
author | Dániel Bátyai <dbatyai@inf.u-szeged.hu> | 2019-07-17 14:44:18 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-07-17 14:44:18 +0200 |
commit | ec11a7b4e94d849c04c6ed0875771e4814fd0374 (patch) | |
tree | c19efcb635a477f78a89add82e56f8385587c9d9 /targets | |
parent | 6c441091b4737be5acb3afbb0430c9c31b30fae7 (diff) |
Resolve module paths relative to the current module (#2976)
The current module implementation resolves module paths relative to the
current working directory, but paths should be resolved relative to the
currently evaluated module/source.
This requires a change in the jerry_port_normalize_path port API
function, so that it also takes the current module path as an argument.
On the engine side, we now also create a module object for the main
script, so that we can properly identify the base path for other
modules.
Co-authored-by: Marko Fabo <mfabo@inf.u-szeged.hu>
JerryScript-DCO-1.0-Signed-off-by: Dániel Bátyai dbatyai@inf.u-szeged.hu
Diffstat (limited to 'targets')
-rw-r--r-- | targets/nuttx-stm32f4/jerry_main.c | 2 | ||||
-rw-r--r-- | targets/nuttx-stm32f4/jerry_port.c | 9 | ||||
-rw-r--r-- | targets/tizenrt-artik053/apps/jerryscript/jerry_main.c | 11 |
3 files changed, 14 insertions, 8 deletions
diff --git a/targets/nuttx-stm32f4/jerry_main.c b/targets/nuttx-stm32f4/jerry_main.c index af293653..36d10f38 100644 --- a/targets/nuttx-stm32f4/jerry_main.c +++ b/targets/nuttx-stm32f4/jerry_main.c @@ -173,7 +173,7 @@ print_unhandled_exception (jerry_value_t error_value) /**< error value */ } else { - jerry_size_t sz = jerry_string_to_char_buffer (err_str_val, err_str_buf, err_str_size); + jerry_size_t sz = jerry_string_to_utf8_char_buffer (err_str_val, err_str_buf, err_str_size); assert (sz == err_str_size); err_str_buf[err_str_size] = 0; diff --git a/targets/nuttx-stm32f4/jerry_port.c b/targets/nuttx-stm32f4/jerry_port.c index 4715da78..2cf86089 100644 --- a/targets/nuttx-stm32f4/jerry_port.c +++ b/targets/nuttx-stm32f4/jerry_port.c @@ -132,10 +132,13 @@ jerry_port_release_source (uint8_t *buffer_p) /**< buffer to free */ * @return length of the path written to the output buffer */ size_t -jerry_port_normalize_path (const char *in_path_p, /**< input file path */ - char *out_buf_p, /**< output buffer */ - size_t out_buf_size) /**< size of output buffer */ +jerry_port_normalize_path (const char *in_path_p, /**< input file path */ + char *out_buf_p, /**< output buffer */ + size_t out_buf_size, /**< size of output buffer */ + char *base_file_p) /**< base file path */ { + (void) base_file_p; + size_t len = strlen (in_path_p); if (len + 1 > out_buf_size) { diff --git a/targets/tizenrt-artik053/apps/jerryscript/jerry_main.c b/targets/tizenrt-artik053/apps/jerryscript/jerry_main.c index 746edb65..b407f2d1 100644 --- a/targets/tizenrt-artik053/apps/jerryscript/jerry_main.c +++ b/targets/tizenrt-artik053/apps/jerryscript/jerry_main.c @@ -145,7 +145,7 @@ print_unhandled_exception (jerry_value_t error_value) /**< error value */ } else { - jerry_size_t sz = jerry_string_to_char_buffer (err_str_val, err_str_buf, err_str_size); + jerry_size_t sz = jerry_string_to_utf8_char_buffer (err_str_val, err_str_buf, err_str_size); assert (sz == err_str_size); err_str_buf[err_str_size] = 0; @@ -575,10 +575,13 @@ jerry_port_release_source (uint8_t *buffer_p) /**< buffer to free */ * @return length of the path written to the output buffer */ size_t -jerry_port_normalize_path (const char *in_path_p, /**< input file path */ - char *out_buf_p, /**< output buffer */ - size_t out_buf_size) /**< size of output buffer */ +jerry_port_normalize_path (const char *in_path_p, /**< input file path */ + char *out_buf_p, /**< output buffer */ + size_t out_buf_size, /**< size of output buffer */ + char *base_file_p) /**< base file path */ { + (void) base_file_p; + size_t len = strlen (in_path_p); if (len + 1 > out_buf_size) { |