Skip to content

Commit 00ed6f7

Browse files
author
Slavey Karadzhov
committed
Refactoring of the ESP8266 target code to match the latest API.
Fixes issue #1211. JerryScript-DCO-1.0-Signed-off-by: Slavey Karadzhov [email protected]
1 parent dd3f801 commit 00ed6f7

File tree

5 files changed

+104
-122
lines changed

5 files changed

+104
-122
lines changed

targets/esp8266/include/jerry_extapi.h

Lines changed: 0 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -19,20 +19,6 @@
1919
#define JERRY_STANDALONE_EXIT_CODE_OK (0)
2020
#define JERRY_STANDALONE_EXIT_CODE_FAIL (1)
2121

22-
#define API_DATA_IS_OBJECT(val_p) \
23-
((val_p)->type == JERRY_API_DATA_TYPE_OBJECT)
24-
25-
#define API_DATA_IS_FUNCTION(val_p) \
26-
(API_DATA_IS_OBJECT(val_p) && \
27-
jerry_api_is_function((val_p)->u.v_object))
28-
29-
#define JS_VALUE_TO_NUMBER(val_p) \
30-
((val_p)->type == JERRY_API_DATA_TYPE_FLOAT32 ? \
31-
(double) ((val_p)->u.v_float32) : \
32-
(val_p)->type == JERRY_API_DATA_TYPE_FLOAT64 ? \
33-
(double) ((val_p)->u.v_float64) : \
34-
(double) ((val_p)->u.v_uint32))
35-
3622

3723
#ifdef __cplusplus
3824
extern "C" {

targets/esp8266/source/jerry_extapi.c

Lines changed: 50 additions & 53 deletions
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@
1616
#include <stdlib.h>
1717
#include <stdio.h>
1818

19-
#include "jerry-core/jerry.h"
19+
#include "jerry-core/jerry-api.h"
2020
#include "jerry_extapi.h"
2121

2222
#include "native_esp8266.h"
@@ -31,12 +31,11 @@
3131
#define __UNSED__ __attribute__((unused))
3232

3333
#define DELCARE_HANDLER(NAME) \
34-
static bool \
35-
NAME ## _handler (const jerry_api_object_t * function_obj_p __UNSED__, \
36-
const jerry_api_value_t * this_p __UNSED__, \
37-
jerry_api_value_t * ret_val_p __UNSED__, \
38-
const jerry_api_value_t args_p[], \
39-
const jerry_api_length_t args_cnt)
34+
static jerry_value_t \
35+
NAME ## _handler (const jerry_value_t function_obj_val __UNSED__, \
36+
const jerry_value_t this_val __UNSED__, \
37+
const jerry_value_t args_p[], \
38+
const jerry_length_t args_cnt)
4039

4140
#define REGISTER_HANDLER(NAME) \
4241
register_native_function ( # NAME, NAME ## _handler)
@@ -45,46 +44,46 @@ NAME ## _handler (const jerry_api_object_t * function_obj_p __UNSED__, \
4544

4645
DELCARE_HANDLER(assert) {
4746
if (args_cnt == 1
48-
&& args_p[0].type == JERRY_API_DATA_TYPE_BOOLEAN
49-
&& args_p[0].u.v_bool == true)
47+
&& jerry_value_is_boolean (args_p[0])
48+
&& jerry_get_boolean_value (args_p[0]))
5049
{
5150
printf (">> Jerry assert true\r\n");
52-
return true;
51+
return jerry_create_boolean (true);
5352
}
5453
printf ("Script assertion failed\n");
5554
exit (JERRY_STANDALONE_EXIT_CODE_FAIL);
56-
return false;
55+
return jerry_create_boolean (false);
5756
}
5857

5958

6059
DELCARE_HANDLER(print) {
61-
jerry_api_length_t cc;
60+
jerry_length_t cc;
6261

6362
if (args_cnt)
6463
{
6564
printf(">> print(%d) :", (int)args_cnt);
6665
for (cc=0; cc<args_cnt; cc++)
6766
{
68-
if (args_p[cc].type == JERRY_API_DATA_TYPE_STRING && args_p[cc].u.v_string)
67+
if (jerry_value_is_string (args_p[cc]))
6968
{
7069
static char buffer[128];
71-
jerry_api_size_t length, maxlength;
72-
length = -jerry_api_string_to_char_buffer (args_p[0].u.v_string, NULL, 0);
73-
maxlength = MIN(length, 126);
74-
jerry_api_string_to_char_buffer (args_p[cc].u.v_string,
75-
(jerry_api_char_t *) buffer,
76-
maxlength);
77-
*(buffer + length) = 0;
70+
jerry_size_t size, maxsize;
71+
size = jerry_get_string_size (args_p[0]);
72+
maxsize = MIN(size, 126);
73+
jerry_string_to_char_buffer (args_p[cc],
74+
(jerry_char_t *) buffer,
75+
maxsize);
76+
*(buffer + size) = 0;
7877
printf("[%s] ", buffer);
7978
}
8079
else
8180
{
82-
printf ("(%d) ", args_p[cc].type);
81+
printf ("(%d) ", args_p[cc]);
8382
}
8483
}
8584
printf ("\r\n");
8685
}
87-
return true;
86+
return jerry_create_boolean (true);
8887
}
8988

9089

@@ -97,27 +96,27 @@ DELCARE_HANDLER(gpio_dir) {
9796
return false;
9897
}
9998

100-
port = (int)JS_VALUE_TO_NUMBER (&args_p[0]);
101-
value = (int)JS_VALUE_TO_NUMBER (&args_p[1]);
99+
port = (int) jerry_get_number_value (args_p[0]);
100+
value = (int) jerry_get_number_value (args_p[1]);
102101

103102
native_gpio_dir (port, value);
104103

105-
return true;
104+
return jerry_create_boolean (true);
106105
} /* gpio_dir_handler */
107106

108107
DELCARE_HANDLER(gpio_set) {
109108
int port, value;
110109
if (args_cnt < 2)
111110
{
112-
return false;
111+
return jerry_create_boolean (false);
113112
}
114113

115-
port = (int)JS_VALUE_TO_NUMBER (&args_p[0]);
116-
value = (int)JS_VALUE_TO_NUMBER (&args_p[1]);
114+
port = (int)jerry_get_number_value (args_p[0]);
115+
value = (int)jerry_get_number_value (args_p[1]);
117116

118117
native_gpio_set (port, value);
119118

120-
return true;
119+
return jerry_create_boolean (true);
121120
} /* gpio_dir_handler */
122121

123122

@@ -128,14 +127,11 @@ DELCARE_HANDLER(gpio_get) {
128127
return false;
129128
}
130129

131-
port = (int)JS_VALUE_TO_NUMBER (&args_p[0]);
130+
port = (int) jerry_get_number_value (args_p[0]);
132131

133132
value = native_gpio_get (port) ? 1 : 0;
134133

135-
ret_val_p->type = JERRY_API_DATA_TYPE_FLOAT64;
136-
ret_val_p->u.v_float64 = (double)value;
137-
138-
return true;
134+
return jerry_create_number ((double) value);
139135
} /* gpio_dir_handler */
140136

141137

@@ -145,34 +141,35 @@ static bool
145141
register_native_function (const char* name,
146142
jerry_external_handler_t handler)
147143
{
148-
jerry_api_object_t *global_obj_p;
149-
jerry_api_object_t *reg_func_p;
150-
jerry_api_value_t reg_value;
144+
jerry_value_t global_obj_val;
145+
jerry_value_t reg_func_val;
146+
jerry_value_t prop_name_val;
147+
jerry_value_t res;
151148
bool bok;
152149

153-
global_obj_p = jerry_api_get_global ();
154-
reg_func_p = jerry_api_create_external_function (handler);
150+
global_obj_val = jerry_get_global_object ();
151+
reg_func_val = jerry_create_external_function (handler);
152+
bok = true;
155153

156-
if (!(reg_func_p != NULL
157-
&& jerry_api_is_function (reg_func_p)
158-
&& jerry_api_is_constructor (reg_func_p)))
154+
if (!(jerry_value_is_function (reg_func_val)
155+
&& jerry_value_is_constructor (reg_func_val)))
159156
{
160157
printf ("!!! create_external_function failed !!!\r\n");
161-
jerry_api_release_object (global_obj_p);
158+
jerry_release_value (reg_func_val);
159+
jerry_release_value (global_obj_val);
162160
return false;
163161
}
164162

165-
jerry_api_acquire_object (reg_func_p);
166-
reg_value.type = JERRY_API_DATA_TYPE_OBJECT;
167-
reg_value.u.v_object = reg_func_p;
168-
169-
bok = jerry_api_set_object_field_value (global_obj_p,
170-
(jerry_api_char_t *)name,
171-
&reg_value);
163+
prop_name_val = jerry_create_string ((const jerry_char_t *) name);
164+
res = jerry_set_property (global_obj_val, prop_name_val, reg_func_val);
165+
if (jerry_value_has_error_flag (res)) {
166+
bok = false;
167+
}
172168

173-
jerry_api_release_value (&reg_value);
174-
jerry_api_release_object (reg_func_p);
175-
jerry_api_release_object (global_obj_p);
169+
jerry_release_value (res);
170+
jerry_release_value (prop_name_val);
171+
jerry_release_value (reg_func_val);
172+
jerry_release_value (global_obj_val);
176173

177174
if (!bok)
178175
{

targets/esp8266/source/jerry_run.c

Lines changed: 51 additions & 53 deletions
Original file line numberDiff line numberDiff line change
@@ -16,105 +16,103 @@
1616
#include <stdlib.h>
1717
#include <stdio.h>
1818

19-
#include "jerry-core/jerry.h"
19+
#include "jerry-core/jerry-api.h"
2020
#include "jerry_extapi.h"
2121
#include "jerry_run.h"
2222

2323

2424
static const char* fn_sys_loop_name = "sysloop";
25+
jerry_value_t parsed_res;
2526

2627

2728
/*---------------------------------------------------------------------------*/
2829

2930
int js_entry (const char *source_p, const size_t source_size)
3031
{
31-
const jerry_api_char_t *jerry_src = (const jerry_api_char_t *) source_p;
32-
jerry_completion_code_t ret_code = JERRY_COMPLETION_CODE_OK;
33-
jerry_flag_t flags = JERRY_FLAG_EMPTY;
34-
jerry_api_object_t *err_obj_p = NULL;
32+
const jerry_char_t *jerry_src = (const jerry_char_t *) source_p;
33+
int ret_code = 0; /* JERRY_COMPLETION_CODE_OK */
34+
jerry_init_flag_t flags = JERRY_INIT_EMPTY;
3535

3636
jerry_init (flags);
3737

3838
js_register_functions ();
3939

40-
if (!jerry_parse ((jerry_api_char_t *)jerry_src, source_size, &err_obj_p))
41-
{
40+
parsed_res = jerry_parse ((jerry_char_t *) jerry_src, source_size, false);
41+
42+
if (jerry_value_has_error_flag (parsed_res)) {
4243
printf ("Error: jerry_parse failed\r\n");
43-
ret_code = JERRY_COMPLETION_CODE_UNHANDLED_EXCEPTION;
44-
}
45-
else
46-
{
47-
if ((flags & JERRY_FLAG_PARSE_ONLY) == 0)
48-
{
49-
jerry_api_value_t err_value = jerry_api_create_void_value ();
50-
ret_code = jerry_run (&err_value);
51-
}
44+
ret_code = JERRY_ERROR_SYNTAX;
5245
}
5346

5447
return ret_code;
5548
}
5649

5750
int js_eval (const char *source_p, const size_t source_size)
5851
{
59-
jerry_completion_code_t status;
60-
jerry_api_value_t res;
52+
int status = 0;
53+
jerry_value_t res;
6154

62-
status = jerry_api_eval ((jerry_api_char_t *) source_p,
55+
res = jerry_eval ((jerry_char_t *) source_p,
6356
source_size,
64-
false,
65-
false,
66-
&res);
57+
false);
58+
if (jerry_value_has_error_flag (res)) {
59+
status = -1;
60+
}
6761

68-
jerry_api_release_value (&res);
62+
jerry_release_value (res);
6963

7064
return status;
7165
}
7266

7367
int js_loop (uint32_t ticknow)
7468
{
75-
jerry_api_object_t *global_obj_p;
76-
jerry_api_value_t sysloop_func;
77-
jerry_api_value_t* val_args;
69+
jerry_value_t global_obj_val;
70+
jerry_value_t sysloop_func;
71+
jerry_value_t* val_args;
7872
uint16_t val_argv;
79-
jerry_api_value_t res;
80-
bool is_ok;
81-
82-
global_obj_p = jerry_api_get_global ();
83-
is_ok = jerry_api_get_object_field_value (global_obj_p,
84-
(const jerry_api_char_t*)fn_sys_loop_name,
85-
&sysloop_func);
86-
if (!is_ok)
87-
{
73+
jerry_value_t res;
74+
jerry_value_t prop_name_val;
75+
int ret_code = 0;
76+
77+
global_obj_val = jerry_get_global_object ();
78+
prop_name_val = jerry_create_string ((const jerry_char_t *) fn_sys_loop_name);
79+
sysloop_func = jerry_get_property (global_obj_val, prop_name_val);
80+
jerry_release_value (prop_name_val);
81+
82+
if (jerry_value_has_error_flag (sysloop_func)) {
8883
printf ("Error: '%s' not defined!!!\r\n", fn_sys_loop_name);
89-
jerry_api_release_object (global_obj_p);
84+
jerry_release_value (sysloop_func);
85+
jerry_release_value (global_obj_val);
9086
return -1;
9187
}
9288

93-
if (!API_DATA_IS_FUNCTION (&sysloop_func))
94-
{
89+
if (!jerry_value_is_function (sysloop_func)) {
9590
printf ("Error: '%s' is not a function!!!\r\n", fn_sys_loop_name);
96-
jerry_api_release_value (&sysloop_func);
97-
jerry_api_release_object (global_obj_p);
91+
jerry_release_value (sysloop_func);
92+
jerry_release_value (global_obj_val);
9893
return -2;
9994
}
10095

10196
val_argv = 1;
102-
val_args = (jerry_api_value_t*)malloc (sizeof (jerry_api_value_t) * val_argv);
103-
val_args[0].type = JERRY_API_DATA_TYPE_UINT32;
104-
val_args[0].u.v_uint32 = ticknow;
105-
106-
is_ok = jerry_api_call_function (sysloop_func.u.v_object,
107-
global_obj_p,
108-
&res,
109-
val_args,
110-
val_argv);
111-
jerry_api_release_value (&res);
97+
val_args = (jerry_value_t*)malloc (sizeof (jerry_value_t) * val_argv);
98+
val_args[0] = jerry_create_number (ticknow);
99+
100+
res = jerry_call_function (sysloop_func,
101+
global_obj_val,
102+
val_args,
103+
val_argv);
104+
105+
if (jerry_value_has_error_flag (res)) {
106+
ret_code = -3;
107+
}
108+
112109
free (val_args);
113110

114-
jerry_api_release_value (&sysloop_func);
115-
jerry_api_release_object (global_obj_p);
111+
jerry_release_value (res);
112+
jerry_release_value (sysloop_func);
113+
jerry_release_value (global_obj_val);
116114

117-
return 0;
115+
return ret_code;
118116
}
119117

120118
void js_exit (void)

targets/esp8266/user/Makefile

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -38,7 +38,6 @@ endif
3838
#
3939

4040
INCLUDES := $(INCLUDES) -I $(PDIR)include
41-
INCLUDES += -I ./ -I ../include
42-
PDIR := ../$(PDIR)
41+
INCLUDES += -I ./ -I ../include -I../../../
4342
sinclude $(PDIR)Makefile
4443

targets/esp8266/user/jerry_port.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
#include <stdio.h>
1818
#include <stdarg.h>
1919

20+
#include "jerry-core/jerry-port.h"
21+
2022
/**
2123
* Provide console message implementation for the engine.
2224
*/

0 commit comments

Comments
 (0)