Merge branch 'quickjs-ng:master' into master

This commit is contained in:
The Ghost of FOSS' Future 2025-01-08 22:45:11 +00:00 committed by GitHub
commit c8d48b3937
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
15 changed files with 57 additions and 1819 deletions

View file

@ -370,10 +370,6 @@ if(BUILD_EXAMPLES)
target_link_libraries(test_fib qjs) target_link_libraries(test_fib qjs)
endif() endif()
add_executable(test_conv
tests/test_conv.c
)
# Install target # Install target
# #

View file

@ -58,9 +58,6 @@ $(QJS): $(BUILD_DIR)
$(QJSC): $(BUILD_DIR) $(QJSC): $(BUILD_DIR)
cmake --build $(BUILD_DIR) --target qjsc -j $(JOBS) cmake --build $(BUILD_DIR) --target qjsc -j $(JOBS)
$(BUILD_DIR)/test_conv: $(BUILD_DIR) tests/test_conv.c
cmake --build $(BUILD_DIR) --target test_conv
install: $(QJS) $(QJSC) install: $(QJS) $(QJSC)
cmake --build $(BUILD_DIR) --target install cmake --build $(BUILD_DIR) --target install
@ -99,9 +96,6 @@ cxxtest: cxxtest.cc quickjs.h
test: $(QJS) test: $(QJS)
$(RUN262) -c tests.conf $(RUN262) -c tests.conf
testconv: $(BUILD_DIR)/test_conv
$(BUILD_DIR)/test_conv
test262: $(QJS) test262: $(QJS)
$(RUN262) -m -c test262.conf -a $(RUN262) -m -c test262.conf -a

View file

@ -62,10 +62,6 @@ extern "C" {
# define __maybe_unused # define __maybe_unused
# define __attribute__(x) # define __attribute__(x)
# define __attribute(x) # define __attribute(x)
# include <intrin.h>
static void *__builtin_frame_address(unsigned int level) {
return (void *)((char*)_AddressOfReturnAddress() - sizeof(int *) - level * sizeof(int *));
}
#else #else
# define likely(x) __builtin_expect(!!(x), 1) # define likely(x) __builtin_expect(!!(x), 1)
# define unlikely(x) __builtin_expect(!!(x), 0) # define unlikely(x) __builtin_expect(!!(x), 0)

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

24
qjs.c
View file

@ -420,7 +420,6 @@ void help(void)
" --exe select the executable to use as the base, defaults to the current one\n" " --exe select the executable to use as the base, defaults to the current one\n"
" --memory-limit n limit the memory usage to 'n' Kbytes\n" " --memory-limit n limit the memory usage to 'n' Kbytes\n"
" --stack-size n limit the stack size to 'n' Kbytes\n" " --stack-size n limit the stack size to 'n' Kbytes\n"
" --unhandled-rejection dump unhandled promise rejections\n"
"-q --quit just instantiate the interpreter and quit\n", JS_GetVersion()); "-q --quit just instantiate the interpreter and quit\n", JS_GetVersion());
exit(1); exit(1);
} }
@ -431,6 +430,7 @@ int main(int argc, char **argv)
JSContext *ctx; JSContext *ctx;
JSValue ret = JS_UNDEFINED; JSValue ret = JS_UNDEFINED;
struct trace_malloc_data trace_data = { NULL }; struct trace_malloc_data trace_data = { NULL };
int r = 0;
int optind = 1; int optind = 1;
char *compile_file = NULL; char *compile_file = NULL;
char *exe = NULL; char *exe = NULL;
@ -445,7 +445,6 @@ int main(int argc, char **argv)
int empty_run = 0; int empty_run = 0;
int module = -1; int module = -1;
int load_std = 0; int load_std = 0;
int dump_unhandled_promise_rejection = 0;
char *include_list[32]; char *include_list[32];
int i, include_count = 0; int i, include_count = 0;
int64_t memory_limit = -1; int64_t memory_limit = -1;
@ -545,10 +544,6 @@ int main(int argc, char **argv)
load_std = 1; load_std = 1;
continue; continue;
} }
if (!strcmp(longopt, "unhandled-rejection")) {
dump_unhandled_promise_rejection = 1;
continue;
}
if (opt == 'q' || !strcmp(longopt, "quit")) { if (opt == 'q' || !strcmp(longopt, "quit")) {
empty_run++; empty_run++;
continue; continue;
@ -653,10 +648,8 @@ start:
/* loader for ES6 modules */ /* loader for ES6 modules */
JS_SetModuleLoaderFunc(rt, NULL, js_module_loader, NULL); JS_SetModuleLoaderFunc(rt, NULL, js_module_loader, NULL);
if (dump_unhandled_promise_rejection) { /* exit on unhandled promise rejections */
JS_SetHostPromiseRejectionTracker(rt, js_std_promise_rejection_tracker, JS_SetHostPromiseRejectionTracker(rt, js_std_promise_rejection_tracker, NULL);
NULL);
}
if (!empty_run) { if (!empty_run) {
js_std_add_helpers(ctx, argc - optind, argv + optind); js_std_add_helpers(ctx, argc - optind, argv + optind);
@ -752,17 +745,16 @@ start:
if (standalone || compile_file) { if (standalone || compile_file) {
if (JS_IsException(ret)) { if (JS_IsException(ret)) {
ret = JS_GetException(ctx); r = 1;
} else { } else {
JS_FreeValue(ctx, ret); JS_FreeValue(ctx, ret);
ret = js_std_loop(ctx); r = js_std_loop(ctx);
} }
} else { } else {
ret = js_std_loop(ctx); r = js_std_loop(ctx);
} }
if (!JS_IsUndefined(ret)) { if (r) {
js_std_dump_error1(ctx, ret); js_std_dump_error(ctx);
JS_FreeValue(ctx, ret);
goto fail; goto fail;
} }
} }

11
qjsc.c
View file

@ -315,7 +315,6 @@ static const char main_c_template1[] =
"int main(int argc, char **argv)\n" "int main(int argc, char **argv)\n"
"{\n" "{\n"
" int r;\n" " int r;\n"
" JSValue ret;\n"
" JSRuntime *rt;\n" " JSRuntime *rt;\n"
" JSContext *ctx;\n" " JSContext *ctx;\n"
" r = 0;\n" " r = 0;\n"
@ -325,14 +324,12 @@ static const char main_c_template1[] =
; ;
static const char main_c_template2[] = static const char main_c_template2[] =
" ret = js_std_loop(ctx);\n" " r = js_std_loop(ctx);\n"
" if (JS_IsException(ret)) {\n" " if (r) {\n"
" js_std_dump_error1(ctx, ret);\n" " js_std_dump_error(ctx);\n"
" r = 1;\n"
" }\n" " }\n"
" JS_FreeValue(ctx, ret);\n"
" JS_FreeContext(ctx);\n"
" js_std_free_handlers(rt);\n" " js_std_free_handlers(rt);\n"
" JS_FreeContext(ctx);\n"
" JS_FreeRuntime(rt);\n" " JS_FreeRuntime(rt);\n"
" return r;\n" " return r;\n"
"}\n"; "}\n";

View file

@ -161,7 +161,6 @@ typedef struct JSThreadState {
struct list_head port_list; /* list of JSWorkerMessageHandler.link */ struct list_head port_list; /* list of JSWorkerMessageHandler.link */
int eval_script_recurse; /* only used in the main thread */ int eval_script_recurse; /* only used in the main thread */
int64_t next_timer_id; /* for setTimeout / setInterval */ int64_t next_timer_id; /* for setTimeout / setInterval */
JSValue exc; /* current exception from one of our handlers */
BOOL can_js_os_poll; BOOL can_js_os_poll;
/* not used in the main thread */ /* not used in the main thread */
JSWorkerMessagePipe *recv_pipe, *send_pipe; JSWorkerMessagePipe *recv_pipe, *send_pipe;
@ -2274,12 +2273,8 @@ static int call_handler(JSContext *ctx, JSValue func)
ret = JS_Call(ctx, func1, JS_UNDEFINED, 0, NULL); ret = JS_Call(ctx, func1, JS_UNDEFINED, 0, NULL);
JS_FreeValue(ctx, func1); JS_FreeValue(ctx, func1);
r = 0; r = 0;
if (JS_IsException(ret)) { if (JS_IsException(ret))
JSRuntime *rt = JS_GetRuntime(ctx);
JSThreadState *ts = js_get_thread_state(rt);
ts->exc = JS_GetException(ctx);
r = -1; r = -1;
}
JS_FreeValue(ctx, ret); JS_FreeValue(ctx, ret);
return r; return r;
} }
@ -3543,10 +3538,10 @@ static void *worker_func(void *opaque)
js_std_dump_error(ctx); js_std_dump_error(ctx);
JS_FreeValue(ctx, val); JS_FreeValue(ctx, val);
JS_FreeValue(ctx, js_std_loop(ctx)); js_std_loop(ctx);
JS_FreeContext(ctx);
js_std_free_handlers(rt); js_std_free_handlers(rt);
JS_FreeContext(ctx);
JS_FreeRuntime(rt); JS_FreeRuntime(rt);
return NULL; return NULL;
} }
@ -4082,7 +4077,6 @@ void js_std_init_handlers(JSRuntime *rt)
init_list_head(&ts->port_list); init_list_head(&ts->port_list);
ts->next_timer_id = 1; ts->next_timer_id = 1;
ts->exc = JS_UNDEFINED;
js_set_thread_state(rt, ts); js_set_thread_state(rt, ts);
JS_AddRuntimeFinalizer(rt, js_std_finalize, ts); JS_AddRuntimeFinalizer(rt, js_std_finalize, ts);
@ -4140,7 +4134,7 @@ static void js_dump_obj(JSContext *ctx, FILE *f, JSValue val)
} }
} }
void js_std_dump_error1(JSContext *ctx, JSValue exception_val) static void js_std_dump_error1(JSContext *ctx, JSValue exception_val)
{ {
JSValue val; JSValue val;
BOOL is_error; BOOL is_error;
@ -4172,16 +4166,17 @@ void js_std_promise_rejection_tracker(JSContext *ctx, JSValue promise,
if (!is_handled) { if (!is_handled) {
fprintf(stderr, "Possibly unhandled promise rejection: "); fprintf(stderr, "Possibly unhandled promise rejection: ");
js_std_dump_error1(ctx, reason); js_std_dump_error1(ctx, reason);
fflush(stderr);
exit(1);
} }
} }
/* main loop which calls the user JS callbacks */ /* main loop which calls the user JS callbacks */
JSValue js_std_loop(JSContext *ctx) int js_std_loop(JSContext *ctx)
{ {
JSRuntime *rt = JS_GetRuntime(ctx); JSRuntime *rt = JS_GetRuntime(ctx);
JSThreadState *ts = js_get_thread_state(rt); JSThreadState *ts = js_get_thread_state(rt);
JSContext *ctx1; JSContext *ctx1;
JSValue ret;
int err; int err;
for(;;) { for(;;) {
@ -4189,10 +4184,8 @@ JSValue js_std_loop(JSContext *ctx)
for(;;) { for(;;) {
err = JS_ExecutePendingJob(JS_GetRuntime(ctx), &ctx1); err = JS_ExecutePendingJob(JS_GetRuntime(ctx), &ctx1);
if (err <= 0) { if (err <= 0) {
if (err < 0) { if (err < 0)
ts->exc = JS_GetException(ctx1);
goto done; goto done;
}
break; break;
} }
} }
@ -4201,9 +4194,7 @@ JSValue js_std_loop(JSContext *ctx)
break; break;
} }
done: done:
ret = ts->exc; return JS_HasException(ctx);
ts->exc = JS_UNDEFINED;
return ret;
} }
/* Wait for a promise and execute pending jobs while waiting for /* Wait for a promise and execute pending jobs while waiting for

View file

@ -37,12 +37,11 @@ JSModuleDef *js_init_module_std(JSContext *ctx, const char *module_name);
JSModuleDef *js_init_module_os(JSContext *ctx, const char *module_name); JSModuleDef *js_init_module_os(JSContext *ctx, const char *module_name);
JSModuleDef *js_init_module_bjson(JSContext *ctx, const char *module_name); JSModuleDef *js_init_module_bjson(JSContext *ctx, const char *module_name);
void js_std_add_helpers(JSContext *ctx, int argc, char **argv); void js_std_add_helpers(JSContext *ctx, int argc, char **argv);
JSValue js_std_loop(JSContext *ctx); int js_std_loop(JSContext *ctx);
JSValue js_std_await(JSContext *ctx, JSValue obj); JSValue js_std_await(JSContext *ctx, JSValue obj);
void js_std_init_handlers(JSRuntime *rt); void js_std_init_handlers(JSRuntime *rt);
void js_std_free_handlers(JSRuntime *rt); void js_std_free_handlers(JSRuntime *rt);
void js_std_dump_error(JSContext *ctx); void js_std_dump_error(JSContext *ctx);
void js_std_dump_error1(JSContext *ctx, JSValue exception_val);
uint8_t *js_load_file(JSContext *ctx, size_t *pbuf_len, const char *filename); uint8_t *js_load_file(JSContext *ctx, size_t *pbuf_len, const char *filename);
int js_module_set_import_meta(JSContext *ctx, JSValue func_val, int js_module_set_import_meta(JSContext *ctx, JSValue func_val,
JS_BOOL use_realpath, JS_BOOL is_main); JS_BOOL use_realpath, JS_BOOL is_main);

View file

@ -33,6 +33,7 @@
#if !defined(_MSC_VER) #if !defined(_MSC_VER)
#include <sys/time.h> #include <sys/time.h>
#if defined(_WIN32) #if defined(_WIN32)
#include <intrin.h>
#include <timezoneapi.h> #include <timezoneapi.h>
#endif #endif
#endif #endif
@ -1774,10 +1775,23 @@ static int init_class_range(JSRuntime *rt, JSClassShortDef const *tab,
return 0; return 0;
} }
/* Note: OS and CPU dependent */ /* Uses code from LLVM project. */
static inline uintptr_t js_get_stack_pointer(void) static inline uintptr_t js_get_stack_pointer(void)
{ {
#if defined(__clang__) || defined(__GNUC__)
return (uintptr_t)__builtin_frame_address(0); return (uintptr_t)__builtin_frame_address(0);
#elif defined(_MSC_VER)
return (uintptr_t)_AddressOfReturnAddress();
#else
char CharOnStack = 0;
// The volatile store here is intended to escape the local variable, to
// prevent the compiler from optimizing CharOnStack into anything other
// than a char on the stack.
//
// Tested on: MSVC 2015 - 2019, GCC 4.9 - 9, Clang 3.2 - 9, ICC 13 - 19.
char *volatile Ptr = &CharOnStack;
return (uintptr_t) Ptr;
#endif
} }
static inline BOOL js_check_stack_overflow(JSRuntime *rt, size_t alloca_size) static inline BOOL js_check_stack_overflow(JSRuntime *rt, size_t alloca_size)
@ -10086,6 +10100,13 @@ BOOL JS_SetConstructorBit(JSContext *ctx, JSValue func_obj, BOOL val)
return TRUE; return TRUE;
} }
JS_BOOL JS_IsRegExp(JSValue val)
{
if (JS_VALUE_GET_TAG(val) != JS_TAG_OBJECT)
return FALSE;
return JS_VALUE_GET_OBJ(val)->class_id == JS_CLASS_REGEXP;
}
BOOL JS_IsError(JSContext *ctx, JSValue val) BOOL JS_IsError(JSContext *ctx, JSValue val)
{ {
JSObject *p; JSObject *p;
@ -51266,6 +51287,13 @@ JSValue JS_NewDate(JSContext *ctx, double epoch_ms)
return obj; return obj;
} }
JS_BOOL JS_IsDate(JSValue v)
{
if (JS_VALUE_GET_TAG(v) != JS_TAG_OBJECT)
return FALSE;
return JS_VALUE_GET_OBJ(v)->class_id == JS_CLASS_DATE;
}
void JS_AddIntrinsicDate(JSContext *ctx) void JS_AddIntrinsicDate(JSContext *ctx)
{ {
JSValue obj; JSValue obj;

View file

@ -672,10 +672,13 @@ JS_EXTERN JS_BOOL JS_IsFunction(JSContext* ctx, JSValue val);
JS_EXTERN JS_BOOL JS_IsConstructor(JSContext* ctx, JSValue val); JS_EXTERN JS_BOOL JS_IsConstructor(JSContext* ctx, JSValue val);
JS_EXTERN JS_BOOL JS_SetConstructorBit(JSContext *ctx, JSValue func_obj, JS_BOOL val); JS_EXTERN JS_BOOL JS_SetConstructorBit(JSContext *ctx, JSValue func_obj, JS_BOOL val);
JS_EXTERN JS_BOOL JS_IsRegExp(JSValue val);
JS_EXTERN JSValue JS_NewArray(JSContext *ctx); JS_EXTERN JSValue JS_NewArray(JSContext *ctx);
JS_EXTERN int JS_IsArray(JSContext *ctx, JSValue val); JS_EXTERN int JS_IsArray(JSContext *ctx, JSValue val);
JS_EXTERN JSValue JS_NewDate(JSContext *ctx, double epoch_ms); JS_EXTERN JSValue JS_NewDate(JSContext *ctx, double epoch_ms);
JS_EXTERN JS_BOOL JS_IsDate(JSValue v);
JS_EXTERN JSValue JS_GetProperty(JSContext *ctx, JSValue this_obj, JSAtom prop); JS_EXTERN JSValue JS_GetProperty(JSContext *ctx, JSValue this_obj, JSAtom prop);
JS_EXTERN JSValue JS_GetPropertyUint32(JSContext *ctx, JSValue this_obj, JS_EXTERN JSValue JS_GetPropertyUint32(JSContext *ctx, JSValue this_obj,

View file

@ -1555,12 +1555,9 @@ static int eval_buf(JSContext *ctx, const char *buf, size_t buf_len,
} }
if (local) { if (local) {
JSValue val = js_std_loop(ctx); ret = js_std_loop(ctx);
if (JS_IsException(val)) { if (ret)
js_std_dump_error1(ctx, val); js_std_dump_error(ctx);
ret = -1;
}
JS_FreeValue(ctx, val);
} }
JS_FreeCString(ctx, error_name); JS_FreeCString(ctx, error_name);

File diff suppressed because it is too large Load diff