Complete refactor of project file structure

Fix incorrect handing of default node parameters in SSD subscription.
Fix unable to parse some Clash rule-providers (#289).
Fix not filtering inline comments in some Surge rulesets. (#285)
Add Cron task options.
Add clean context option for persisting a JS context across the whole request.
Replace JS engine with QuickJS.
This commit is contained in:
Tindy X
2021-03-23 18:09:00 +08:00
parent ba058e4e4b
commit 3d67406af6
88 changed files with 9404 additions and 6356 deletions

View File

@@ -1,26 +1,28 @@
FROM alpine:3.12
FROM alpine:3.13
LABEL maintainer "tindy.it@gmail.com"
# build minimized
WORKDIR /
RUN apk add --no-cache --virtual .build-tools git g++ build-base linux-headers cmake python2 nodejs npm && \
RUN apk add --no-cache --virtual .build-tools git g++ build-base linux-headers cmake && \
apk add --no-cache --virtual .build-deps curl-dev rapidjson-dev libevent-dev pcre2-dev yaml-cpp-dev && \
git clone https://github.com/svaarala/duktape --depth=1 && \
cd duktape && \
make -C src-tools && \
python2 -m ensurepip && \
pip2 install PyYAML --no-cache-dir && \
python2 util/dist.py --output-directory dist && \
cd dist/src && \
cc -c -O3 -o duktape.o duktape.c && \
cc -c -O3 -o duk_module_node.o -I. ../extras/module-node/duk_module_node.c && \
ar cr libduktape.a duktape.o && \
ar cr libduktape_module.a duk_module_node.o && \
install -m0644 ./*.a /usr/lib && \
install -m0644 duk*.h /usr/include && \
install -m0644 ../extras/module-node/duk_module_node.h /usr/include && \
cd ../../.. && \
rm -rf duktape /usr/lib/python2.7 && \
git clone https://github.com/ftk/quickjspp --depth=1 && \
cd quickjspp && \
cmake -DCMAKE_BUILD_TYPE=Release . && \
make -j4 && \
install -m644 quickjs/libquickjs.a /usr/lib && \
install -m644 quickjs/quickjs.h quickjs/quickjs-libc.h /usr/include/quickjs && \
install -m644 quickjspp.hpp /usr/include && \
cd .. && \
git clone https://github.com/PerMalmberg/libcron --depth=1 && \
cd libcron && \
cmake -DCMAKE_BUILD_TYPE=Release . && \
make -j4 && \
install -m644 libcron/out/Release/liblibcron.a /usr/lib && \
install -d /usr/include/libcron/ && \
install -m644 libcron/include/libcron/* /usr/include/libcron/ && \
install -d /usr/include/date/ && \
install -m644 libcron/externals/date/include/date/* /usr/include/date/ && \
cd .. && \
git clone https://github.com/tindy2013/subconverter --depth=1 && \
cd subconverter && \
cmake -DCMAKE_BUILD_TYPE=Release . && \

View File

@@ -16,21 +16,25 @@ cmake -DCMAKE_BUILD_TYPE=Release -DYAML_CPP_BUILD_TESTS=OFF -DYAML_CPP_BUILD_TOO
make install -j2 > /dev/null
cd ..
git clone https://github.com/svaarala/duktape --depth=1
cd duktape
make -C src-tools
python2 -m ensurepip
pip2 install PyYAML
python2 util/dist.py --output-directory dist
cd dist/src
cc -c -O3 -o duktape.o duktape.c
cc -c -O3 -o duk_module_node.o -I. ../extras/module-node/duk_module_node.c
ar cr libduktape.a duktape.o
ar cr libduktape_module.a duk_module_node.o
install -m0644 ./*.a /usr/lib
install -m0644 ./duk*.h /usr/include
install -m0644 ../extras/module-node/duk_module_node.h /usr/include
cd ../../..
git clone https://github.com/ftk/quickjspp --depth=1
cd quickjspp
cmake -DCMAKE_BUILD_TYPE=Release .
make -j4
install -m644 quickjs/libquickjs.a /usr/lib
install -m644 quickjs/quickjs.h quickjs/quickjs-libc.h /usr/include/quickjs
install -m644 quickjspp.hpp /usr/include
cd ..
git clone https://github.com/PerMalmberg/libcron --depth=1
cd libcron
cmake -DCMAKE_BUILD_TYPE=Release .
make -j4
install -m644 libcron/out/Release/liblibcron.a /usr/lib
install -d /usr/include/libcron/
install -m644 libcron/include/libcron/* /usr/include/libcron/
install -d /usr/include/date/
install -m644 libcron/externals/date/include/date/* /usr/include/date/
cd ..
export PKG_CONFIG_PATH=/usr/lib64/pkgconfig
cmake -DCMAKE_BUILD_TYPE=Release .

View File

@@ -17,20 +17,23 @@ cmake -DCMAKE_BUILD_TYPE=Release -DYAML_CPP_BUILD_TESTS=OFF -DYAML_CPP_BUILD_TOO
make install -j8 > /dev/null
cd ..
git clone https://github.com/svaarala/duktape --depth=1
cd duktape
make -C src-tools
pip2 install PyYAML
python2 util/dist.py --output-directory dist
cd dist/src
cc -c -O3 -o duktape.o duktape.c
cc -c -O3 -o duk_module_node.o -I. ../extras/module-node/duk_module_node.c
ar cr libduktape.a duktape.o
ar cr libduktape_module.a duk_module_node.o
install -m0644 ./*.a /usr/local/lib
install -m0644 ./duk*.h /usr/local/include
install -m0644 ../extras/module-node/duk_module_node.h /usr/local/include
cd ../../..
git clone https://github.com/ftk/quickjspp --depth=1
cd quickjspp
cmake -DCMAKE_BUILD_TYPE=Release .
make -j4
install -m644 quickjs/quickjs.h quickjs/quickjs-libc.h /usr/local/include/quickjs
install -m644 quickjspp.hpp /usr/local/include
cd ..
git clone https://github.com/PerMalmberg/libcron --depth=1
cd libcron
cmake -DCMAKE_BUILD_TYPE=Release .
make -j4
install -d /usr/local/include/libcron/
install -m644 libcron/include/libcron/* /usr/local/include/libcron/
install -d /usr/local/include/date/
install -m644 libcron/externals/date/include/date/* /usr/local/include/date/
cd ..
cp /usr/local/lib/libevent.a .
cp /usr/local/opt/zlib/lib/libz.a .

View File

@@ -13,19 +13,26 @@ cmake -DCMAKE_BUILD_TYPE=Release -DYAML_CPP_BUILD_TESTS=OFF -DYAML_CPP_BUILD_TOO
make install -j4
cd ..
git clone https://github.com/svaarala/duktape --depth=1
cd duktape
make -C src-tools
node src-tools/index.js dist --output-directory dist
cd dist/src
gcc -c -O3 -o duktape.o duktape.c
gcc -c -O3 -o duk_module_node.o -I. ../extras/module-node/duk_module_node.c
ar cr libduktape.a duktape.o
ar cr libduktape_module.a duk_module_node.o
install -m0644 ./*.a "$MINGW_PREFIX/lib"
install -m0644 ./duk*.h "$MINGW_PREFIX/include"
install -m0644 ../extras/module-node/duk_module_node.h "$MINGW_PREFIX/include"
cd ../../..
git clone https://github.com/ftk/quickjspp --depth=1
cd quickjspp
patch quickjs/quickjs-libc.c -i ../scripts/patches/0001-quickjs-libc-add-realpath-for-Windows.patch
cmake -G "Unix Makefiles" -DCMAKE_BUILD_TYPE=Release .
make -j4
install -m644 quickjs/libquickjs.a "$MINGW_PREFIX/lib"
install -m644 quickjs/quickjs.h quickjs/quickjs-libc.h "$MINGW_PREFIX/include/quickjs"
install -m644 quickjspp.hpp "$MINGW_PREFIX/include"
cd ..
git clone https://github.com/PerMalmberg/libcron --depth=1
cd libcron
cmake -G "Unix Makefiles" -DCMAKE_BUILD_TYPE=Release .
make -j4
install -m644 libcron/out/Release/liblibcron.a "$MINGW_PREFIX/lib"
install -d "$MINGW_PREFIX/include/libcron/"
install -m644 libcron/include/libcron/* "$MINGW_PREFIX/include/libcron/"
install -d "$MINGW_PREFIX/include/date/"
install -m644 libcron/externals/date/include/date/* "$MINGW_PREFIX/include/date/"
cd ..
git clone https://github.com/Tencent/rapidjson --depth=1
cd rapidjson

View File

@@ -0,0 +1,93 @@
--- quickjs-libc.c 2021-03-23 15:04:09.604314700 +0800
+++ patched.c 2021-03-23 15:04:35.109289500 +0800
@@ -132,6 +132,29 @@
static uint64_t os_pending_signals;
static int (*os_poll_func)(JSContext *ctx);
+static char *_realpath(const char *path, char *resolved_path)
+{
+#if defined(_WIN32)
+ BOOL allocated = FALSE;
+ if(resolved_path == NULL)
+ {
+ resolved_path = (char*) malloc(PATH_MAX);
+ allocated = TRUE;
+ }
+ DWORD len = GetFullPathNameA(path, PATH_MAX, resolved_path, NULL);
+ if(!len || len >= PATH_MAX)
+ {
+ if(allocated)
+ free(resolved_path);
+ return NULL;
+ }
+ resolved_path[len] = '\0';
+ return resolved_path;
+#else
+ return realpath(path, resolved_path);
+#endif // _WIN32
+}
+
static void js_std_dbuf_init(JSContext *ctx, DynBuf *s)
{
dbuf_init2(s, JS_GetRuntime(ctx), (DynBufReallocFunc *)js_realloc_rt);
@@ -530,19 +553,19 @@
return -1;
if (!strchr(module_name, ':')) {
strcpy(buf, "file://");
-#if !defined(_WIN32)
+//#if !defined(_WIN32)
/* realpath() cannot be used with modules compiled with qjsc
because the corresponding module source code is not
necessarily present */
if (use_realpath) {
- char *res = realpath(module_name, buf + strlen(buf));
+ char *res = _realpath(module_name, buf + strlen(buf));
if (!res) {
JS_ThrowTypeError(ctx, "realpath failure");
JS_FreeCString(ctx, module_name);
return -1;
}
} else
-#endif
+//#endif
{
pstrcat(buf, sizeof(buf), module_name);
}
@@ -2588,8 +2611,6 @@
return JS_NewInt32(ctx, ret);
}
-#if !defined(_WIN32)
-
/* return [path, errorcode] */
static JSValue js_os_realpath(JSContext *ctx, JSValueConst this_val,
int argc, JSValueConst *argv)
@@ -2601,7 +2622,7 @@
path = JS_ToCString(ctx, argv[0]);
if (!path)
return JS_EXCEPTION;
- res = realpath(path, buf);
+ res = _realpath(path, buf);
JS_FreeCString(ctx, path);
if (!res) {
buf[0] = '\0';
@@ -2612,6 +2633,8 @@
return make_string_error(ctx, buf, err);
}
+#if !defined(_WIN32)
+
static JSValue js_os_symlink(JSContext *ctx, JSValueConst this_val,
int argc, JSValueConst *argv)
{
@@ -3598,9 +3621,9 @@
#endif
JS_CFUNC_MAGIC_DEF("stat", 1, js_os_stat, 0 ),
JS_CFUNC_DEF("utimes", 3, js_os_utimes ),
+ JS_CFUNC_DEF("realpath", 1, js_os_realpath ),
#if !defined(_WIN32)
JS_CFUNC_MAGIC_DEF("lstat", 1, js_os_stat, 1 ),
- JS_CFUNC_DEF("realpath", 1, js_os_realpath ),
JS_CFUNC_DEF("symlink", 2, js_os_symlink ),
JS_CFUNC_DEF("readlink", 1, js_os_readlink ),
JS_CFUNC_DEF("exec", 1, js_os_exec ),