mirror of
https://github.com/rkd77/elinks.git
synced 2024-11-04 08:17:17 -05:00
729 lines
21 KiB
Diff
729 lines
21 KiB
Diff
diff -Nru quickjs-2021-03-27/Makefile.dos quickjs-2021-03-27.new/Makefile.dos
|
|
--- quickjs-2021-03-27/Makefile.dos 1970-01-01 00:00:00.000000000 +0000
|
|
+++ quickjs-2021-03-27.new/Makefile.dos 2022-06-08 21:28:12.212649535 +0000
|
|
@@ -0,0 +1,473 @@
|
|
+#
|
|
+# QuickJS Javascript Engine
|
|
+#
|
|
+# Copyright (c) 2017-2021 Fabrice Bellard
|
|
+# Copyright (c) 2017-2021 Charlie Gordon
|
|
+#
|
|
+# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
+# of this software and associated documentation files (the "Software"), to deal
|
|
+# in the Software without restriction, including without limitation the rights
|
|
+# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
+# copies of the Software, and to permit persons to whom the Software is
|
|
+# furnished to do so, subject to the following conditions:
|
|
+#
|
|
+# The above copyright notice and this permission notice shall be included in
|
|
+# all copies or substantial portions of the Software.
|
|
+#
|
|
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
+# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
+# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
+# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
+# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
+# THE SOFTWARE.
|
|
+
|
|
+ifeq ($(shell uname -s),Darwin)
|
|
+CONFIG_DARWIN=y
|
|
+endif
|
|
+# Windows cross compilation from Linux
|
|
+#CONFIG_WIN32=y
|
|
+# use link time optimization (smaller and faster executables but slower build)
|
|
+#CONFIG_LTO=
|
|
+# consider warnings as errors (for development)
|
|
+#CONFIG_WERROR=y
|
|
+# force 32 bit build for some utilities
|
|
+#CONFIG_M32=y
|
|
+
|
|
+ifdef CONFIG_DARWIN
|
|
+# use clang instead of gcc
|
|
+CONFIG_CLANG=y
|
|
+CONFIG_DEFAULT_AR=y
|
|
+endif
|
|
+
|
|
+# installation directory
|
|
+prefix=/usr/local
|
|
+
|
|
+# use the gprof profiler
|
|
+#CONFIG_PROFILE=y
|
|
+# use address sanitizer
|
|
+#CONFIG_ASAN=y
|
|
+# include the code for BigInt/BigFloat/BigDecimal and math mode
|
|
+CONFIG_BIGNUM=y
|
|
+
|
|
+OBJDIR=.o
|
|
+
|
|
+ifdef CONFIG_WIN32
|
|
+ ifdef CONFIG_M32
|
|
+ CROSS_PREFIX=i686-w64-mingw32-
|
|
+ else
|
|
+ CROSS_PREFIX=x86_64-w64-mingw32-
|
|
+ endif
|
|
+ EXE=.exe
|
|
+else
|
|
+ CROSS_PREFIX=i586-pc-msdosdjgpp-
|
|
+ EXE=.exe
|
|
+endif
|
|
+ifdef CONFIG_CLANG
|
|
+ HOST_CC=clang
|
|
+ CC=$(CROSS_PREFIX)clang
|
|
+ CFLAGS=-g -Wall -MMD -MF $(OBJDIR)/$(@F).d
|
|
+ CFLAGS += -Wextra
|
|
+ CFLAGS += -Wno-sign-compare
|
|
+ CFLAGS += -Wno-missing-field-initializers
|
|
+ CFLAGS += -Wundef -Wuninitialized
|
|
+ CFLAGS += -Wunused -Wno-unused-parameter
|
|
+ CFLAGS += -Wwrite-strings
|
|
+ CFLAGS += -Wchar-subscripts -funsigned-char
|
|
+ CFLAGS += -MMD -MF $(OBJDIR)/$(@F).d
|
|
+ ifdef CONFIG_DEFAULT_AR
|
|
+ AR=$(CROSS_PREFIX)ar
|
|
+ else
|
|
+ ifdef CONFIG_LTO
|
|
+ AR=$(CROSS_PREFIX)llvm-ar
|
|
+ else
|
|
+ AR=$(CROSS_PREFIX)ar
|
|
+ endif
|
|
+ endif
|
|
+else
|
|
+ HOST_CC=gcc
|
|
+ CC=$(CROSS_PREFIX)gcc
|
|
+ CFLAGS=-g -Wall -MMD -MF $(OBJDIR)/$(@F).d
|
|
+ CFLAGS += -Wno-array-bounds -Wno-format-truncation
|
|
+ ifdef CONFIG_LTO
|
|
+ AR=$(CROSS_PREFIX)gcc-ar
|
|
+ else
|
|
+ AR=$(CROSS_PREFIX)ar
|
|
+ endif
|
|
+endif
|
|
+STRIP=$(CROSS_PREFIX)strip
|
|
+ifdef CONFIG_WERROR
|
|
+CFLAGS+=-Werror
|
|
+endif
|
|
+DEFINES:=-D_GNU_SOURCE -DCONFIG_VERSION=\"$(shell cat VERSION)\"
|
|
+ifdef CONFIG_BIGNUM
|
|
+DEFINES+=-DCONFIG_BIGNUM
|
|
+endif
|
|
+ifdef CONFIG_WIN32
|
|
+DEFINES+=-D__USE_MINGW_ANSI_STDIO # for standard snprintf behavior
|
|
+endif
|
|
+
|
|
+CFLAGS+=$(DEFINES)
|
|
+CFLAGS_DEBUG=$(CFLAGS) -O0
|
|
+CFLAGS_SMALL=$(CFLAGS) -Os
|
|
+CFLAGS_OPT=$(CFLAGS) -O2
|
|
+CFLAGS_NOLTO:=$(CFLAGS_OPT)
|
|
+LDFLAGS=-g
|
|
+ifdef CONFIG_LTO
|
|
+CFLAGS_SMALL+=-flto
|
|
+CFLAGS_OPT+=-flto
|
|
+LDFLAGS+=-flto
|
|
+endif
|
|
+ifdef CONFIG_PROFILE
|
|
+CFLAGS+=-p
|
|
+LDFLAGS+=-p
|
|
+endif
|
|
+ifdef CONFIG_ASAN
|
|
+CFLAGS+=-fsanitize=address -fno-omit-frame-pointer
|
|
+LDFLAGS+=-fsanitize=address -fno-omit-frame-pointer
|
|
+endif
|
|
+ifdef CONFIG_WIN32
|
|
+LDEXPORT=
|
|
+else
|
|
+#LDEXPORT=-rdynamic
|
|
+endif
|
|
+
|
|
+PROGS=qjs$(EXE) qjsc$(EXE)
|
|
+#run-test262
|
|
+ifneq ($(CROSS_PREFIX),)
|
|
+QJSC_CC=gcc
|
|
+QJSC=./host-qjsc
|
|
+PROGS+=$(QJSC)
|
|
+else
|
|
+QJSC_CC=$(CC)
|
|
+QJSC=./qjsc$(EXE)
|
|
+endif
|
|
+ifndef CONFIG_WIN32
|
|
+#PROGS+=qjscalc
|
|
+endif
|
|
+ifdef CONFIG_M32
|
|
+PROGS+=qjs32 qjs32_s
|
|
+endif
|
|
+PROGS+=libquickjs.a
|
|
+ifdef CONFIG_LTO
|
|
+PROGS+=libquickjs.lto.a
|
|
+endif
|
|
+
|
|
+# examples
|
|
+ifeq ($(CROSS_PREFIX),)
|
|
+ifdef CONFIG_ASAN
|
|
+PROGS+=
|
|
+else
|
|
+PROGS+=examples/hello examples/hello_module examples/test_fib
|
|
+ifndef CONFIG_DARWIN
|
|
+PROGS+=examples/fib.so examples/point.so
|
|
+endif
|
|
+endif
|
|
+endif
|
|
+
|
|
+all: $(OBJDIR) $(OBJDIR)/quickjs.check.o $(OBJDIR)/qjs.check.o $(PROGS)
|
|
+
|
|
+QJS_LIB_OBJS=$(OBJDIR)/quickjs.o $(OBJDIR)/libregexp.o $(OBJDIR)/libunicode.o $(OBJDIR)/cutils.o $(OBJDIR)/quickjs-libc.o
|
|
+
|
|
+QJS_OBJS=$(OBJDIR)/qjs.o $(OBJDIR)/repl.o $(QJS_LIB_OBJS)
|
|
+ifdef CONFIG_BIGNUM
|
|
+QJS_LIB_OBJS+=$(OBJDIR)/libbf.o
|
|
+QJS_OBJS+=$(OBJDIR)/qjscalc.o
|
|
+endif
|
|
+
|
|
+HOST_LIBS=-lm
|
|
+#-ldl
|
|
+# -lpthread
|
|
+LIBS=-lm
|
|
+ifndef CONFIG_WIN32
|
|
+#LIBS+=-ldl -lpthread
|
|
+endif
|
|
+LIBS+=$(EXTRA_LIBS)
|
|
+
|
|
+$(OBJDIR):
|
|
+ mkdir -p $(OBJDIR) $(OBJDIR)/examples $(OBJDIR)/tests
|
|
+
|
|
+qjs$(EXE): $(QJS_OBJS)
|
|
+ $(CC) $(LDFLAGS) $(LDEXPORT) -o $@ $^ $(LIBS)
|
|
+
|
|
+qjs-debug$(EXE): $(patsubst %.o, %.debug.o, $(QJS_OBJS))
|
|
+ $(CC) $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
+
|
|
+qjsc$(EXE): $(OBJDIR)/qjsc.o $(QJS_LIB_OBJS)
|
|
+ $(CC) $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
+
|
|
+ifneq ($(CROSS_PREFIX),)
|
|
+
|
|
+$(QJSC): $(OBJDIR)/qjsc.host.o \
|
|
+ $(patsubst %.o, %.host.o, $(QJS_LIB_OBJS))
|
|
+ $(HOST_CC) $(LDFLAGS) -o $@ $^ $(HOST_LIBS)
|
|
+
|
|
+endif #CROSS_PREFIX
|
|
+
|
|
+QJSC_DEFINES:=-DCONFIG_CC=\"$(QJSC_CC)\" -DCONFIG_PREFIX=\"$(prefix)\"
|
|
+ifdef CONFIG_LTO
|
|
+QJSC_DEFINES+=-DCONFIG_LTO
|
|
+endif
|
|
+QJSC_HOST_DEFINES:=-DCONFIG_CC=\"$(HOST_CC)\" -DCONFIG_PREFIX=\"$(prefix)\"
|
|
+
|
|
+$(OBJDIR)/qjsc.o: CFLAGS+=$(QJSC_DEFINES)
|
|
+$(OBJDIR)/qjsc.host.o: CFLAGS+=$(QJSC_HOST_DEFINES)
|
|
+
|
|
+qjs32: $(patsubst %.o, %.m32.o, $(QJS_OBJS))
|
|
+ $(CC) -m32 $(LDFLAGS) $(LDEXPORT) -o $@ $^ $(LIBS)
|
|
+
|
|
+qjs32_s: $(patsubst %.o, %.m32s.o, $(QJS_OBJS))
|
|
+ $(CC) -m32 $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
+ @size $@
|
|
+
|
|
+qjscalc: qjs
|
|
+ ln -sf $< $@
|
|
+
|
|
+ifdef CONFIG_LTO
|
|
+LTOEXT=.lto
|
|
+else
|
|
+LTOEXT=
|
|
+endif
|
|
+
|
|
+libquickjs$(LTOEXT).a: $(QJS_LIB_OBJS)
|
|
+ $(AR) rcs $@ $^
|
|
+
|
|
+ifdef CONFIG_LTO
|
|
+libquickjs.a: $(patsubst %.o, %.nolto.o, $(QJS_LIB_OBJS))
|
|
+ $(AR) rcs $@ $^
|
|
+endif # CONFIG_LTO
|
|
+
|
|
+repl.c: $(QJSC) repl.js
|
|
+ $(QJSC) -c -o $@ -m repl.js
|
|
+
|
|
+qjscalc.c: $(QJSC) qjscalc.js
|
|
+ $(QJSC) -fbignum -c -o $@ qjscalc.js
|
|
+
|
|
+ifneq ($(wildcard unicode/UnicodeData.txt),)
|
|
+$(OBJDIR)/libunicode.o $(OBJDIR)/libunicode.m32.o $(OBJDIR)/libunicode.m32s.o \
|
|
+ $(OBJDIR)/libunicode.nolto.o: libunicode-table.h
|
|
+
|
|
+libunicode-table.h: unicode_gen
|
|
+ ./unicode_gen unicode $@
|
|
+endif
|
|
+
|
|
+#run-test262: $(OBJDIR)/run-test262.o $(QJS_LIB_OBJS)
|
|
+# $(CC) $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
+
|
|
+#run-test262-debug: $(patsubst %.o, %.debug.o, $(OBJDIR)/run-test262.o $(QJS_LIB_OBJS))
|
|
+# $(CC) $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
+
|
|
+#run-test262-32: $(patsubst %.o, %.m32.o, $(OBJDIR)/run-test262.o $(QJS_LIB_OBJS))
|
|
+# $(CC) -m32 $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
+
|
|
+# object suffix order: nolto, [m32|m32s]
|
|
+
|
|
+$(OBJDIR)/%.o: %.c | $(OBJDIR)
|
|
+ $(CC) $(CFLAGS_OPT) -c -o $@ $<
|
|
+
|
|
+$(OBJDIR)/%.host.o: %.c | $(OBJDIR)
|
|
+ $(HOST_CC) $(CFLAGS_OPT) -c -o $@ $<
|
|
+
|
|
+$(OBJDIR)/%.pic.o: %.c | $(OBJDIR)
|
|
+ $(CC) $(CFLAGS_OPT) -fPIC -DJS_SHARED_LIBRARY -c -o $@ $<
|
|
+
|
|
+$(OBJDIR)/%.nolto.o: %.c | $(OBJDIR)
|
|
+ $(CC) $(CFLAGS_NOLTO) -c -o $@ $<
|
|
+
|
|
+$(OBJDIR)/%.m32.o: %.c | $(OBJDIR)
|
|
+ $(CC) -m32 $(CFLAGS_OPT) -c -o $@ $<
|
|
+
|
|
+$(OBJDIR)/%.m32s.o: %.c | $(OBJDIR)
|
|
+ $(CC) -m32 $(CFLAGS_SMALL) -c -o $@ $<
|
|
+
|
|
+$(OBJDIR)/%.debug.o: %.c | $(OBJDIR)
|
|
+ $(CC) $(CFLAGS_DEBUG) -c -o $@ $<
|
|
+
|
|
+$(OBJDIR)/%.check.o: %.c | $(OBJDIR)
|
|
+ $(CC) $(CFLAGS) -DCONFIG_CHECK_JSVALUE -c -o $@ $<
|
|
+
|
|
+regexp_test: libregexp.c libunicode.c cutils.c
|
|
+ $(CC) $(LDFLAGS) $(CFLAGS) -DTEST -o $@ libregexp.c libunicode.c cutils.c $(LIBS)
|
|
+
|
|
+unicode_gen: $(OBJDIR)/unicode_gen.host.o $(OBJDIR)/cutils.host.o libunicode.c unicode_gen_def.h
|
|
+ $(HOST_CC) $(LDFLAGS) $(CFLAGS) -o $@ $(OBJDIR)/unicode_gen.host.o $(OBJDIR)/cutils.host.o
|
|
+
|
|
+clean:
|
|
+ rm -f repl.c qjscalc.c out.c
|
|
+ rm -f *.a *.o *.d *~ unicode_gen regexp_test $(PROGS)
|
|
+ rm -f hello.c test_fib.c
|
|
+ rm -f examples/*.so tests/*.so
|
|
+ rm -rf $(OBJDIR)/ *.dSYM/ qjs-debug
|
|
+ rm -rf run-test262-debug run-test262-32
|
|
+
|
|
+install: all
|
|
+ mkdir -p "$(DESTDIR)$(prefix)/bin"
|
|
+ $(STRIP) qjs$(EXE) qjsc$(EXE)
|
|
+ install -m755 qjs$(EXE) qjsc$(EXE) "$(DESTDIR)$(prefix)/bin"
|
|
+# ln -sf qjs "$(DESTDIR)$(prefix)/bin/qjscalc"
|
|
+ mkdir -p "$(DESTDIR)$(prefix)/lib/quickjs"
|
|
+ install -m644 libquickjs.a "$(DESTDIR)$(prefix)/lib/quickjs"
|
|
+ifdef CONFIG_LTO
|
|
+ install -m644 libquickjs.lto.a "$(DESTDIR)$(prefix)/lib/quickjs"
|
|
+endif
|
|
+ mkdir -p "$(DESTDIR)$(prefix)/include/quickjs"
|
|
+ install -m644 quickjs.h quickjs-libc.h "$(DESTDIR)$(prefix)/include/quickjs"
|
|
+
|
|
+###############################################################################
|
|
+# examples
|
|
+
|
|
+# example of static JS compilation
|
|
+HELLO_SRCS=examples/hello.js
|
|
+HELLO_OPTS=-fno-string-normalize -fno-map -fno-promise -fno-typedarray \
|
|
+ -fno-typedarray -fno-regexp -fno-json -fno-eval -fno-proxy \
|
|
+ -fno-date -fno-module-loader
|
|
+ifdef CONFIG_BIGNUM
|
|
+HELLO_OPTS+=-fno-bigint
|
|
+endif
|
|
+
|
|
+hello.c: $(QJSC) $(HELLO_SRCS)
|
|
+ $(QJSC) -e $(HELLO_OPTS) -o $@ $(HELLO_SRCS)
|
|
+
|
|
+ifdef CONFIG_M32
|
|
+examples/hello: $(OBJDIR)/hello.m32s.o $(patsubst %.o, %.m32s.o, $(QJS_LIB_OBJS))
|
|
+ $(CC) -m32 $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
+else
|
|
+examples/hello: $(OBJDIR)/hello.o $(QJS_LIB_OBJS)
|
|
+ $(CC) $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
+endif
|
|
+
|
|
+# example of static JS compilation with modules
|
|
+HELLO_MODULE_SRCS=examples/hello_module.js
|
|
+HELLO_MODULE_OPTS=-fno-string-normalize -fno-map -fno-promise -fno-typedarray \
|
|
+ -fno-typedarray -fno-regexp -fno-json -fno-eval -fno-proxy \
|
|
+ -fno-date -m
|
|
+examples/hello_module: $(QJSC) libquickjs$(LTOEXT).a $(HELLO_MODULE_SRCS)
|
|
+ $(QJSC) $(HELLO_MODULE_OPTS) -o $@ $(HELLO_MODULE_SRCS)
|
|
+
|
|
+# use of an external C module (static compilation)
|
|
+
|
|
+test_fib.c: $(QJSC) examples/test_fib.js
|
|
+ $(QJSC) -e -M examples/fib.so,fib -m -o $@ examples/test_fib.js
|
|
+
|
|
+examples/test_fib: $(OBJDIR)/test_fib.o $(OBJDIR)/examples/fib.o libquickjs$(LTOEXT).a
|
|
+ $(CC) $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
+
|
|
+examples/fib.so: $(OBJDIR)/examples/fib.pic.o
|
|
+ $(CC) $(LDFLAGS) -shared -o $@ $^
|
|
+
|
|
+examples/point.so: $(OBJDIR)/examples/point.pic.o
|
|
+ $(CC) $(LDFLAGS) -shared -o $@ $^
|
|
+
|
|
+###############################################################################
|
|
+# documentation
|
|
+
|
|
+DOCS=doc/quickjs.pdf doc/quickjs.html doc/jsbignum.pdf doc/jsbignum.html
|
|
+
|
|
+build_doc: $(DOCS)
|
|
+
|
|
+clean_doc:
|
|
+ rm -f $(DOCS)
|
|
+
|
|
+doc/%.pdf: doc/%.texi
|
|
+ texi2pdf --clean -o $@ -q $<
|
|
+
|
|
+doc/%.html.pre: doc/%.texi
|
|
+ makeinfo --html --no-headers --no-split --number-sections -o $@ $<
|
|
+
|
|
+doc/%.html: doc/%.html.pre
|
|
+ sed -e 's|</style>|</style>\n<meta name="viewport" content="width=device-width, initial-scale=1.0">|' < $< > $@
|
|
+
|
|
+###############################################################################
|
|
+# tests
|
|
+
|
|
+ifndef CONFIG_DARWIN
|
|
+test: tests/bjson.so examples/point.so
|
|
+endif
|
|
+ifdef CONFIG_M32
|
|
+test: qjs32
|
|
+endif
|
|
+
|
|
+test: qjs
|
|
+ ./qjs tests/test_closure.js
|
|
+ ./qjs tests/test_language.js
|
|
+ ./qjs tests/test_builtin.js
|
|
+ ./qjs tests/test_loop.js
|
|
+ ./qjs tests/test_std.js
|
|
+ ./qjs tests/test_worker.js
|
|
+ifndef CONFIG_DARWIN
|
|
+ifdef CONFIG_BIGNUM
|
|
+ ./qjs --bignum tests/test_bjson.js
|
|
+else
|
|
+ ./qjs tests/test_bjson.js
|
|
+endif
|
|
+ ./qjs examples/test_point.js
|
|
+endif
|
|
+ifdef CONFIG_BIGNUM
|
|
+ ./qjs --bignum tests/test_op_overloading.js
|
|
+ ./qjs --bignum tests/test_bignum.js
|
|
+ ./qjs --qjscalc tests/test_qjscalc.js
|
|
+endif
|
|
+ifdef CONFIG_M32
|
|
+ ./qjs32 tests/test_closure.js
|
|
+ ./qjs32 tests/test_language.js
|
|
+ ./qjs32 tests/test_builtin.js
|
|
+ ./qjs32 tests/test_loop.js
|
|
+ ./qjs32 tests/test_std.js
|
|
+ ./qjs32 tests/test_worker.js
|
|
+ifdef CONFIG_BIGNUM
|
|
+ ./qjs32 --bignum tests/test_op_overloading.js
|
|
+ ./qjs32 --bignum tests/test_bignum.js
|
|
+ ./qjs32 --qjscalc tests/test_qjscalc.js
|
|
+endif
|
|
+endif
|
|
+
|
|
+stats: qjs qjs32
|
|
+ ./qjs -qd
|
|
+ ./qjs32 -qd
|
|
+
|
|
+microbench: qjs
|
|
+ ./qjs tests/microbench.js
|
|
+
|
|
+microbench-32: qjs32
|
|
+ ./qjs32 tests/microbench.js
|
|
+
|
|
+# ES5 tests (obsolete)
|
|
+#test2o: run-test262
|
|
+# time ./run-test262 -m -c test262o.conf
|
|
+
|
|
+#test2o-32: run-test262-32
|
|
+# time ./run-test262-32 -m -c test262o.conf
|
|
+
|
|
+#test2o-update: run-test262
|
|
+# ./run-test262 -u -c test262o.conf
|
|
+
|
|
+# Test262 tests
|
|
+#test2-default: run-test262
|
|
+# time ./run-test262 -m -c test262.conf
|
|
+
|
|
+#test2: run-test262
|
|
+# time ./run-test262 -m -c test262.conf -a
|
|
+
|
|
+#test2-32: run-test262-32
|
|
+# time ./run-test262-32 -m -c test262.conf -a
|
|
+
|
|
+#test2-update: run-test262
|
|
+# ./run-test262 -u -c test262.conf -a
|
|
+
|
|
+#test2-check: run-test262
|
|
+# time ./run-test262 -m -c test262.conf -E -a
|
|
+
|
|
+#testall: all test microbench test2o test2
|
|
+
|
|
+#testall-32: all test-32 microbench-32 test2o-32 test2-32
|
|
+
|
|
+#testall-complete: testall testall-32
|
|
+
|
|
+#bench-v8: qjs
|
|
+# make -C tests/bench-v8
|
|
+# ./qjs -d tests/bench-v8/combined.js
|
|
+
|
|
+#tests/bjson.so: $(OBJDIR)/tests/bjson.pic.o
|
|
+# $(CC) $(LDFLAGS) -shared -o $@ $^ $(LIBS)
|
|
+
|
|
+-include $(wildcard $(OBJDIR)/*.d)
|
|
diff -up quickjs-2024-01-13/qjs.c.djgpp quickjs-2024-01-13/qjs.c
|
|
--- quickjs-2024-01-13/qjs.c.djgpp 2024-08-21 13:29:26.360220594 +0000
|
|
+++ quickjs-2024-01-13/qjs.c 2024-08-21 13:12:30.671515118 +0000
|
|
@@ -146,7 +146,7 @@ static size_t js_trace_malloc_usable_siz
|
|
return malloc_size(ptr);
|
|
#elif defined(_WIN32)
|
|
return _msize((void *)ptr);
|
|
-#elif defined(EMSCRIPTEN)
|
|
+#elif defined(EMSCRIPTEN) || defined(__DJGPP)
|
|
return 0;
|
|
#elif defined(__linux__)
|
|
return malloc_usable_size((void *)ptr);
|
|
diff -up quickjs-2024-01-13/quickjs-libc.c.djgpp quickjs-2024-01-13/quickjs-libc.c
|
|
--- quickjs-2024-01-13/quickjs-libc.c.djgpp 2024-01-13 10:20:39.000000000 +0000
|
|
+++ quickjs-2024-01-13/quickjs-libc.c 2024-08-21 13:14:45.092458496 +0000
|
|
@@ -59,7 +59,7 @@ typedef sig_t sighandler_t;
|
|
|
|
#if !defined(_WIN32)
|
|
/* enable the os.Worker API. IT relies on POSIX threads */
|
|
-#define USE_WORKER
|
|
+//#define USE_WORKER
|
|
#endif
|
|
|
|
#ifdef USE_WORKER
|
|
@@ -691,6 +691,7 @@ static JSValue js_std_getenviron(JSConte
|
|
obj = JS_NewObject(ctx);
|
|
if (JS_IsException(obj))
|
|
return JS_EXCEPTION;
|
|
+#if 0
|
|
envp = environ;
|
|
for(idx = 0; envp[idx] != NULL; idx++) {
|
|
name = envp[idx];
|
|
@@ -708,6 +709,7 @@ static JSValue js_std_getenviron(JSConte
|
|
if (ret < 0)
|
|
goto fail;
|
|
}
|
|
+#endif
|
|
return obj;
|
|
fail:
|
|
JS_FreeValue(ctx, obj);
|
|
@@ -1918,7 +1920,7 @@ static void os_signal_handler(int sig_nu
|
|
os_pending_signals |= ((uint64_t)1 << sig_num);
|
|
}
|
|
|
|
-#if defined(_WIN32)
|
|
+#if defined(_WIN32) || defined(__DJGPP)
|
|
typedef void (*sighandler_t)(int sig_num);
|
|
#endif
|
|
|
|
@@ -2525,7 +2527,7 @@ static JSValue js_os_readdir(JSContext *
|
|
return make_obj_error(ctx, obj, err);
|
|
}
|
|
|
|
-#if !defined(_WIN32)
|
|
+#if !defined(_WIN32) && !defined(__DJGPP)
|
|
static int64_t timespec_to_ms(const struct timespec *tv)
|
|
{
|
|
return (int64_t)tv->tv_sec * 1000 + (tv->tv_nsec / 1000000);
|
|
@@ -2585,12 +2587,12 @@ static JSValue js_os_stat(JSContext *ctx
|
|
JS_DefinePropertyValueStr(ctx, obj, "size",
|
|
JS_NewInt64(ctx, st.st_size),
|
|
JS_PROP_C_W_E);
|
|
-#if !defined(_WIN32)
|
|
+#if !defined(_WIN32) && !defined(__DJGPP)
|
|
JS_DefinePropertyValueStr(ctx, obj, "blocks",
|
|
JS_NewInt64(ctx, st.st_blocks),
|
|
JS_PROP_C_W_E);
|
|
#endif
|
|
-#if defined(_WIN32)
|
|
+#if defined(_WIN32) || defined(__DJGPP)
|
|
JS_DefinePropertyValueStr(ctx, obj, "atime",
|
|
JS_NewInt64(ctx, (int64_t)st.st_atime * 1000),
|
|
JS_PROP_C_W_E);
|
|
@@ -2677,11 +2679,11 @@ static JSValue js_os_sleep(JSContext *ct
|
|
return JS_EXCEPTION;
|
|
if (delay < 0)
|
|
delay = 0;
|
|
-#if defined(_WIN32)
|
|
+#if defined(_WIN32) || defined(__DJGPP)
|
|
{
|
|
if (delay > INT32_MAX)
|
|
delay = INT32_MAX;
|
|
- Sleep(delay);
|
|
+ usleep(delay);
|
|
ret = 0;
|
|
}
|
|
#else
|
|
@@ -2897,7 +2899,7 @@ static JSValue js_os_exec(JSContext *ctx
|
|
JSValueConst options, args = argv[0];
|
|
JSValue val, ret_val;
|
|
const char **exec_argv, *file = NULL, *str, *cwd = NULL;
|
|
- char **envp = environ;
|
|
+ char **envp = NULL;//environ;
|
|
uint32_t exec_argc, i;
|
|
int ret, pid, status;
|
|
BOOL block_flag = TRUE, use_path = TRUE;
|
|
@@ -3073,6 +3075,7 @@ static JSValue js_os_exec(JSContext *ctx
|
|
for(i = 0; i < exec_argc; i++)
|
|
JS_FreeCString(ctx, exec_argv[i]);
|
|
js_free(ctx, exec_argv);
|
|
+#if 0
|
|
if (envp != environ) {
|
|
char **p;
|
|
p = envp;
|
|
@@ -3082,6 +3085,7 @@ static JSValue js_os_exec(JSContext *ctx
|
|
}
|
|
js_free(ctx, envp);
|
|
}
|
|
+#endif
|
|
return ret_val;
|
|
exception:
|
|
ret_val = JS_EXCEPTION;
|
|
@@ -3677,7 +3681,7 @@ static const JSCFunctionListEntry js_os_
|
|
OS_FLAG(SIGILL),
|
|
OS_FLAG(SIGSEGV),
|
|
OS_FLAG(SIGTERM),
|
|
-#if !defined(_WIN32)
|
|
+#if !defined(_WIN32) && !defined(__DJGPP)
|
|
OS_FLAG(SIGQUIT),
|
|
OS_FLAG(SIGPIPE),
|
|
OS_FLAG(SIGALRM),
|
|
@@ -3706,7 +3710,7 @@ static const JSCFunctionListEntry js_os_
|
|
OS_FLAG(S_IFDIR),
|
|
OS_FLAG(S_IFBLK),
|
|
OS_FLAG(S_IFREG),
|
|
-#if !defined(_WIN32)
|
|
+#if !defined(_WIN32) && !defined(__DJGPP)
|
|
OS_FLAG(S_IFSOCK),
|
|
OS_FLAG(S_IFLNK),
|
|
OS_FLAG(S_ISGID),
|
|
@@ -3716,7 +3720,7 @@ static const JSCFunctionListEntry js_os_
|
|
JS_CFUNC_DEF("utimes", 3, js_os_utimes ),
|
|
JS_CFUNC_DEF("sleep", 1, js_os_sleep ),
|
|
JS_CFUNC_DEF("realpath", 1, js_os_realpath ),
|
|
-#if !defined(_WIN32)
|
|
+#if !defined(_WIN32) && !defined(__DJGPP)
|
|
JS_CFUNC_MAGIC_DEF("lstat", 1, js_os_stat, 1 ),
|
|
JS_CFUNC_DEF("symlink", 2, js_os_symlink ),
|
|
JS_CFUNC_DEF("readlink", 1, js_os_readlink ),
|
|
diff -up quickjs-2024-01-13/quickjs.c.djgpp quickjs-2024-01-13/quickjs.c
|
|
--- quickjs-2024-01-13/quickjs.c.djgpp 2024-01-13 10:20:39.000000000 +0000
|
|
+++ quickjs-2024-01-13/quickjs.c 2024-08-21 13:18:39.088740789 +0000
|
|
@@ -30,7 +30,7 @@
|
|
#include <assert.h>
|
|
#include <sys/time.h>
|
|
#include <time.h>
|
|
-#include <fenv.h>
|
|
+//#include <fenv.h>
|
|
#include <math.h>
|
|
#if defined(__APPLE__)
|
|
#include <malloc/malloc.h>
|
|
@@ -68,7 +68,7 @@
|
|
/* define to include Atomics.* operations which depend on the OS
|
|
threads */
|
|
#if !defined(EMSCRIPTEN)
|
|
-#define CONFIG_ATOMICS
|
|
+//#define CONFIG_ATOMICS
|
|
#endif
|
|
|
|
#if !defined(EMSCRIPTEN)
|
|
@@ -1699,7 +1699,7 @@ static size_t js_def_malloc_usable_size(
|
|
return malloc_size(ptr);
|
|
#elif defined(_WIN32)
|
|
return _msize((void *)ptr);
|
|
-#elif defined(EMSCRIPTEN)
|
|
+#elif defined(EMSCRIPTEN) || defined(__DJGPP)
|
|
return 0;
|
|
#elif defined(__linux__)
|
|
return malloc_usable_size((void *)ptr);
|
|
@@ -11338,12 +11338,19 @@ static char *i64toa(char *buf_end, int64
|
|
return q;
|
|
}
|
|
|
|
+#ifndef FE_TONEAREST
|
|
+#define FE_TONEAREST 0
|
|
+#define FE_DOWNWARD 0
|
|
+#define FE_UPWARD 0
|
|
+#endif
|
|
+
|
|
+
|
|
/* buf1 contains the printf result */
|
|
static void js_ecvt1(double d, int n_digits, int *decpt, int *sign, char *buf,
|
|
int rounding_mode, char *buf1, int buf1_size)
|
|
{
|
|
- if (rounding_mode != FE_TONEAREST)
|
|
- fesetround(rounding_mode);
|
|
+// if (rounding_mode != FE_TONEAREST)
|
|
+// fesetround(rounding_mode);
|
|
snprintf(buf1, buf1_size, "%+.*e", n_digits - 1, d);
|
|
if (rounding_mode != FE_TONEAREST)
|
|
fesetround(FE_TONEAREST);
|
|
@@ -40844,6 +40851,10 @@ static JSValue js_number_isSafeInteger(J
|
|
return JS_NewBool(ctx, is_safe_integer(d));
|
|
}
|
|
|
|
+static const double DJ_INFINITY = 1e10000f;
|
|
+#undef NAN
|
|
+#define NAN (0.0f / 0.0f)
|
|
+
|
|
static const JSCFunctionListEntry js_number_funcs[] = {
|
|
/* global ParseInt and parseFloat should be defined already or delayed */
|
|
JS_ALIAS_BASE_DEF("parseInt", "parseInt", 0 ),
|
|
@@ -40855,8 +40866,8 @@ static const JSCFunctionListEntry js_num
|
|
JS_PROP_DOUBLE_DEF("MAX_VALUE", 1.7976931348623157e+308, 0 ),
|
|
JS_PROP_DOUBLE_DEF("MIN_VALUE", 5e-324, 0 ),
|
|
JS_PROP_DOUBLE_DEF("NaN", NAN, 0 ),
|
|
- JS_PROP_DOUBLE_DEF("NEGATIVE_INFINITY", -INFINITY, 0 ),
|
|
- JS_PROP_DOUBLE_DEF("POSITIVE_INFINITY", INFINITY, 0 ),
|
|
+ JS_PROP_DOUBLE_DEF("NEGATIVE_INFINITY", -DJ_INFINITY, 0 ),
|
|
+ JS_PROP_DOUBLE_DEF("POSITIVE_INFINITY", DJ_INFINITY, 0 ),
|
|
JS_PROP_DOUBLE_DEF("EPSILON", 2.220446049250313e-16, 0 ), /* ES6 */
|
|
JS_PROP_DOUBLE_DEF("MAX_SAFE_INTEGER", 9007199254740991.0, 0 ), /* ES6 */
|
|
JS_PROP_DOUBLE_DEF("MIN_SAFE_INTEGER", -9007199254740991.0, 0 ), /* ES6 */
|
|
@@ -42901,6 +42912,19 @@ void JS_AddIntrinsicStringNormalize(JSCo
|
|
|
|
/* Math */
|
|
|
|
+static double
|
|
+fmin2(double a, double b)
|
|
+{
|
|
+ return a < b ? a : b;
|
|
+}
|
|
+
|
|
+static double
|
|
+fmax2(double a, double b)
|
|
+{
|
|
+ return a > b ? a : b;
|
|
+}
|
|
+
|
|
+
|
|
/* precondition: a and b are not NaN */
|
|
static double js_fmin(double a, double b)
|
|
{
|
|
@@ -42911,7 +42935,7 @@ static double js_fmin(double a, double b
|
|
a1.u64 |= b1.u64;
|
|
return a1.d;
|
|
} else {
|
|
- return fmin(a, b);
|
|
+ return fmin2(a, b);
|
|
}
|
|
}
|
|
|
|
@@ -42925,7 +42949,7 @@ static double js_fmax(double a, double b
|
|
a1.u64 &= b1.u64;
|
|
return a1.d;
|
|
} else {
|
|
- return fmax(a, b);
|
|
+ return fmax2(a, b);
|
|
}
|
|
}
|
|
|