forked from xuos/xiuos
272 lines
7.9 KiB
C
272 lines
7.9 KiB
C
/*
|
|
* Copyright (c) 2022 AIIT XUOS Lab
|
|
* XiUOS is licensed under Mulan PSL v2.
|
|
* You can use this software according to the terms and conditions of the Mulan PSL v2.
|
|
* You may obtain a copy of Mulan PSL v2 at:
|
|
* http://license.coscl.org.cn/MulanPSL2
|
|
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
|
|
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
|
|
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
|
|
* See the Mulan PSL v2 for more details.
|
|
*/
|
|
|
|
/**
|
|
* @file jerry_test.c
|
|
* @brief support jerryscript
|
|
* @version 1.0
|
|
* @author AIIT XUOS Lab
|
|
* @date 2023.08.07
|
|
*/
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <transform.h>
|
|
#include "jerryscript.h"
|
|
#include "jerryscript-ext/handler.h"
|
|
|
|
bool js_parse_test1(void* parameter)
|
|
{
|
|
bool run_ok = false;
|
|
|
|
const jerry_char_t script[] = "var str = 'Hello, World!';";
|
|
|
|
/* Initialize engine */
|
|
jerry_init (JERRY_INIT_EMPTY);
|
|
|
|
/* Setup Global scope code */
|
|
jerry_value_t parsed_code = jerry_parse (NULL, 0, script, sizeof (script) - 1, JERRY_PARSE_NO_OPTS);
|
|
|
|
/* Check if there is any JS code parse error */
|
|
if (!jerry_value_is_error (parsed_code))
|
|
{
|
|
/* Execute the parsed source code in the Global scope */
|
|
jerry_value_t ret_value = jerry_run (parsed_code);
|
|
|
|
/* Check the execution return value if there is any error */
|
|
run_ok = !jerry_value_is_error (ret_value);
|
|
|
|
/* Returned value must be freed */
|
|
jerry_release_value (ret_value);
|
|
printf("jerry_run ret=%ld\n", ret_value);
|
|
}
|
|
|
|
/* Parsed source code must be freed */
|
|
jerry_release_value (parsed_code);
|
|
|
|
/* Cleanup engine */
|
|
jerry_cleanup ();
|
|
|
|
printf("run_ok is %d.\n", run_ok);
|
|
|
|
return (run_ok ? 0 : 1);
|
|
}
|
|
|
|
int js_parse_test2(void* parameter)
|
|
{
|
|
int return_value = 1;
|
|
|
|
/* Initialize engine */
|
|
jerry_init (JERRY_INIT_EMPTY);
|
|
|
|
/* Parse the 'function (a,b) { return a + b; }' function */
|
|
const char function_args[] = "a, b";
|
|
const char function_source[] = "return a * b";
|
|
|
|
jerry_value_t parsed_function = jerry_parse_function (NULL,
|
|
0,
|
|
(const jerry_char_t *) function_args,
|
|
strlen (function_args),
|
|
(const jerry_char_t *) function_source,
|
|
strlen (function_source),
|
|
JERRY_PARSE_NO_OPTS);
|
|
|
|
if (!jerry_value_is_error (parsed_function))
|
|
{
|
|
/* Run the parsed function */
|
|
jerry_value_t args[] = {
|
|
jerry_create_number (3),
|
|
jerry_create_number (55),
|
|
};
|
|
jerry_size_t argc = sizeof (args) / sizeof (args[0]);
|
|
jerry_value_t ret_value = jerry_call_function (parsed_function,
|
|
jerry_create_undefined(),
|
|
args,
|
|
argc);
|
|
|
|
/* Process result value */
|
|
if (jerry_value_is_number (ret_value)) {
|
|
double value = jerry_get_number_value (ret_value);
|
|
printf ("Function result: %lf\n", value);
|
|
|
|
return_value = !(value == (3 * 55));
|
|
}
|
|
|
|
/* Release the function arguments */
|
|
for (jerry_size_t idx = 0; idx < argc; idx++) {
|
|
jerry_release_value (args[idx]);
|
|
}
|
|
|
|
/* Returned value must be freed */
|
|
jerry_release_value (ret_value);
|
|
}
|
|
|
|
/* Parsed function must be freed */
|
|
jerry_release_value (parsed_function);
|
|
|
|
/* Cleanup engine */
|
|
jerry_cleanup ();
|
|
|
|
return return_value;
|
|
}
|
|
|
|
|
|
int js_parse_test3(void* parameter)
|
|
{
|
|
jerry_init (JERRY_INIT_EMPTY);
|
|
|
|
jerry_value_t value;
|
|
// create or acquire value
|
|
value = jerry_create_string ((const jerry_char_t *) "Demo string");
|
|
|
|
// Read the string into a byte buffer.
|
|
jerry_size_t string_size = jerry_get_string_size (value);
|
|
jerry_char_t *string_buffer_p = (jerry_char_t *) malloc (sizeof (jerry_char_t) * (string_size + 1));
|
|
|
|
jerry_size_t copied_bytes = jerry_string_to_char_buffer (value, string_buffer_p, string_size);
|
|
string_buffer_p[copied_bytes] = '\0';
|
|
|
|
jerry_release_value (value);
|
|
|
|
jerry_cleanup ();
|
|
|
|
printf ("Test string: %s\n", string_buffer_p);
|
|
free (string_buffer_p);
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
static int counter = 0;
|
|
|
|
static jerry_value_t
|
|
method_getter (const jerry_value_t this_obj,
|
|
const jerry_value_t func_obj,
|
|
const jerry_value_t args[],
|
|
const jerry_length_t argc)
|
|
{
|
|
counter++;
|
|
printf("Getter called, returning: %d\n", counter);
|
|
|
|
return jerry_create_number (counter);
|
|
}
|
|
|
|
static jerry_value_t
|
|
method_setter (const jerry_value_t this_obj,
|
|
const jerry_value_t func_obj,
|
|
const jerry_value_t args[],
|
|
const jerry_length_t argc)
|
|
{
|
|
// Note: the arguments count and type should be checked
|
|
// in this example it is ommitted!
|
|
|
|
double new_value = jerry_get_number_value (args[0]);
|
|
counter = (int) new_value;
|
|
|
|
printf("Setter called, setting: %d\n", counter);
|
|
|
|
return jerry_create_undefined ();
|
|
}
|
|
|
|
int js_parse_test4(void* parameter)
|
|
{
|
|
jerry_init (JERRY_INIT_EMPTY);
|
|
|
|
jerry_value_t global_obj_val = jerry_get_global_object ();
|
|
|
|
// configure the property
|
|
jerry_property_descriptor_t prop_desc;
|
|
jerry_init_property_descriptor_fields (&prop_desc);
|
|
|
|
// set the property descriptor fields:
|
|
|
|
prop_desc.is_get_defined = true;
|
|
prop_desc.getter = jerry_create_external_function (method_getter);
|
|
prop_desc.is_set_defined = true;
|
|
prop_desc.setter = jerry_create_external_function (method_setter);
|
|
|
|
// add the property as "my_prop" for the global object
|
|
jerry_value_t prop_name = jerry_create_string ((const jerry_char_t *) "my_prop");
|
|
jerry_value_t return_value = jerry_define_own_property (global_obj_val, prop_name, &prop_desc);
|
|
if (jerry_value_is_error (return_value))
|
|
{
|
|
// there was an error
|
|
}
|
|
|
|
// if there was no error at this point the global object should have a "my_prop" property
|
|
|
|
jerry_release_value (return_value);
|
|
jerry_release_value (prop_name);
|
|
|
|
jerry_free_property_descriptor_fields (&prop_desc);
|
|
jerry_release_value (global_obj_val);
|
|
|
|
// run an example js code to use the getter/setters
|
|
|
|
const char *src_p = "this.my_prop; this.my_prop; this.my_prop = 4; this.my_prop";
|
|
jerry_value_t eval_result = jerry_eval ((const jerry_char_t *) src_p, strlen (src_p), JERRY_PARSE_NO_OPTS);
|
|
|
|
// "eval_result" is the last result of "this.my_prop" that is "5" currently.
|
|
double result_number = jerry_get_number_value (eval_result);
|
|
printf("output: %lf\n", result_number);
|
|
|
|
jerry_cleanup ();
|
|
|
|
return result_number != 5.0;
|
|
}
|
|
|
|
int js_parse_test5(void* parameter)
|
|
{
|
|
const jerry_char_t script[] = "print ('Hello, World!');";
|
|
|
|
/* Initialize engine */
|
|
jerry_init (JERRY_INIT_EMPTY);
|
|
|
|
/* Register 'print' function from the extensions */
|
|
jerryx_handler_register_global ((const jerry_char_t *) "print",jerryx_handler_print);
|
|
|
|
/* Setup Global scope code */
|
|
jerry_value_t parsed_code = jerry_parse (NULL, 0, script, sizeof (script) - 1, JERRY_PARSE_NO_OPTS);
|
|
|
|
if (!jerry_value_is_error (parsed_code))
|
|
{
|
|
/* Execute the parsed source code in the Global scope */
|
|
jerry_value_t ret_value = jerry_run (parsed_code);
|
|
|
|
/* Returned value must be freed */
|
|
jerry_release_value (ret_value);
|
|
}
|
|
|
|
/* Parsed source code must be freed */
|
|
jerry_release_value (parsed_code);
|
|
|
|
/* Cleanup engine */
|
|
jerry_cleanup ();
|
|
return 0;
|
|
}
|
|
|
|
void jstest(void)
|
|
{
|
|
int ret;
|
|
pthread_t thread;
|
|
pthread_attr_t attr;
|
|
attr.schedparam.sched_priority = 22;
|
|
attr.stacksize = 8192;
|
|
int32 task = 0;
|
|
|
|
ret = PrivTaskCreate(&thread, &attr, (void*)js_parse_test5, NULL);
|
|
if (ret < 0) {
|
|
printf("taskcreate failed, status=%d\n", ret);
|
|
return;
|
|
}
|
|
}
|
|
PRIV_SHELL_CMD_FUNCTION(jstest, jerryscript test cmd, PRIV_SHELL_CMD_FUNC_ATTR);
|