Fix unhandled exceptions with unicode error messages (#2994)
Fixes #2993 JerryScript-DCO-1.0-Signed-off-by: Dániel Bátyai dbatyai@inf.u-szeged.hu
This commit is contained in:
committed by
Robert Fancsik
parent
a2d242eab9
commit
dfafb1aa6b
@@ -48,9 +48,9 @@ void jerry_resolve_error (jerry_value_t ret_value)
|
||||
{
|
||||
ret_value = jerry_get_value_from_error (ret_value, true);
|
||||
jerry_value_t err_str_val = jerry_value_to_string (ret_value);
|
||||
jerry_size_t err_str_size = jerry_get_string_size (err_str_val);
|
||||
jerry_size_t err_str_size = jerry_get_utf8_string_size (err_str_val);
|
||||
jerry_char_t *err_str_buf = (jerry_char_t *) balloc (err_str_size, NULL);
|
||||
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);
|
||||
err_str_buf[sz] = 0;
|
||||
printk ("Script Error: unhandled exception: %s\n", err_str_buf);
|
||||
bfree(err_str_buf);
|
||||
|
||||
@@ -55,7 +55,7 @@ DELCARE_HANDLER(print) {
|
||||
{
|
||||
if (jerry_value_is_string (args_p[cc]))
|
||||
{
|
||||
jerry_size_t size = jerry_get_string_size (args_p[0]);
|
||||
jerry_size_t size = jerry_get_utf8_string_size (args_p[0]);
|
||||
char *buffer;
|
||||
buffer = (char *) malloc(size + 1);
|
||||
|
||||
@@ -66,9 +66,9 @@ DELCARE_HANDLER(print) {
|
||||
continue;
|
||||
}
|
||||
|
||||
jerry_string_to_char_buffer (args_p[cc],
|
||||
(jerry_char_t *) buffer,
|
||||
size);
|
||||
jerry_string_to_utf8_char_buffer (args_p[cc],
|
||||
(jerry_char_t *) buffer,
|
||||
size);
|
||||
*(buffer + size) = 0;
|
||||
printf("%s ", buffer);
|
||||
free (buffer);
|
||||
|
||||
@@ -160,7 +160,7 @@ print_unhandled_exception (jerry_value_t error_value) /**< error value */
|
||||
|
||||
error_value = jerry_get_value_from_error (error_value, false);
|
||||
jerry_value_t err_str_val = jerry_value_to_string (error_value);
|
||||
jerry_size_t err_str_size = jerry_get_string_size (err_str_val);
|
||||
jerry_size_t err_str_size = jerry_get_utf8_string_size (err_str_val);
|
||||
jerry_char_t err_str_buf[256];
|
||||
|
||||
jerry_release_value (error_value);
|
||||
|
||||
@@ -132,7 +132,7 @@ print_unhandled_exception (jerry_value_t error_value) /**< error value */
|
||||
|
||||
error_value = jerry_get_value_from_error (error_value, false);
|
||||
jerry_value_t err_str_val = jerry_value_to_string (error_value);
|
||||
jerry_size_t err_str_size = jerry_get_string_size (err_str_val);
|
||||
jerry_size_t err_str_size = jerry_get_utf8_string_size (err_str_val);
|
||||
jerry_char_t err_str_buf[256];
|
||||
|
||||
jerry_release_value (error_value);
|
||||
|
||||
Reference in New Issue
Block a user