|
@@ -4,13 +4,13 @@
|
|
#
|
|
#
|
|
################################################################################
|
|
################################################################################
|
|
|
|
|
|
-NODEJS_VERSION = 12.22.6
|
|
|
|
|
|
+NODEJS_VERSION = 14.17.6
|
|
NODEJS_SOURCE = node-v$(NODEJS_VERSION).tar.xz
|
|
NODEJS_SOURCE = node-v$(NODEJS_VERSION).tar.xz
|
|
NODEJS_SITE = http://nodejs.org/dist/v$(NODEJS_VERSION)
|
|
NODEJS_SITE = http://nodejs.org/dist/v$(NODEJS_VERSION)
|
|
-NODEJS_DEPENDENCIES = host-python host-nodejs c-ares \
|
|
|
|
|
|
+NODEJS_DEPENDENCIES = host-qemu host-python3 host-nodejs c-ares \
|
|
libuv zlib nghttp2 \
|
|
libuv zlib nghttp2 \
|
|
$(call qstrip,$(BR2_PACKAGE_NODEJS_MODULES_ADDITIONAL_DEPS))
|
|
$(call qstrip,$(BR2_PACKAGE_NODEJS_MODULES_ADDITIONAL_DEPS))
|
|
-HOST_NODEJS_DEPENDENCIES = host-icu host-libopenssl host-python host-zlib
|
|
|
|
|
|
+HOST_NODEJS_DEPENDENCIES = host-icu host-libopenssl host-python3 host-zlib
|
|
NODEJS_INSTALL_STAGING = YES
|
|
NODEJS_INSTALL_STAGING = YES
|
|
NODEJS_LICENSE = MIT (core code); MIT, Apache and BSD family licenses (Bundled components)
|
|
NODEJS_LICENSE = MIT (core code); MIT, Apache and BSD family licenses (Bundled components)
|
|
NODEJS_LICENSE_FILES = LICENSE
|
|
NODEJS_LICENSE_FILES = LICENSE
|
|
@@ -18,7 +18,6 @@ NODEJS_CPE_ID_VENDOR = nodejs
|
|
NODEJS_CPE_ID_PRODUCT = node.js
|
|
NODEJS_CPE_ID_PRODUCT = node.js
|
|
|
|
|
|
NODEJS_CONF_OPTS = \
|
|
NODEJS_CONF_OPTS = \
|
|
- --without-snapshot \
|
|
|
|
--shared-zlib \
|
|
--shared-zlib \
|
|
--shared-cares \
|
|
--shared-cares \
|
|
--shared-libuv \
|
|
--shared-libuv \
|
|
@@ -46,25 +45,17 @@ ifneq ($(BR2_PACKAGE_NODEJS_NPM),y)
|
|
NODEJS_CONF_OPTS += --without-npm
|
|
NODEJS_CONF_OPTS += --without-npm
|
|
endif
|
|
endif
|
|
|
|
|
|
-# nodejs build system is based on python, but only support python-2.6 or
|
|
|
|
-# python-2.7. So, we have to enforce PYTHON interpreter to be python2.
|
|
|
|
define HOST_NODEJS_CONFIGURE_CMDS
|
|
define HOST_NODEJS_CONFIGURE_CMDS
|
|
- # The build system directly calls python. Work around this by forcing python2
|
|
|
|
- # into PATH. See https://github.com/nodejs/node/issues/2735
|
|
|
|
- mkdir -p $(@D)/bin
|
|
|
|
- ln -sf $(HOST_DIR)/bin/python2 $(@D)/bin/python
|
|
|
|
-
|
|
|
|
(cd $(@D); \
|
|
(cd $(@D); \
|
|
$(HOST_CONFIGURE_OPTS) \
|
|
$(HOST_CONFIGURE_OPTS) \
|
|
PATH=$(@D)/bin:$(BR_PATH) \
|
|
PATH=$(@D)/bin:$(BR_PATH) \
|
|
- PYTHON=$(HOST_DIR)/bin/python2 \
|
|
|
|
- $(HOST_DIR)/bin/python2 ./configure \
|
|
|
|
|
|
+ PYTHON=$(HOST_DIR)/bin/python3 \
|
|
|
|
+ $(HOST_DIR)/bin/python3 ./configure \
|
|
--prefix=$(HOST_DIR) \
|
|
--prefix=$(HOST_DIR) \
|
|
- --without-snapshot \
|
|
|
|
--without-dtrace \
|
|
--without-dtrace \
|
|
--without-etw \
|
|
--without-etw \
|
|
--shared-openssl \
|
|
--shared-openssl \
|
|
- --shared-openssl-includes=$(HOST_DIR)/include/openssl \
|
|
|
|
|
|
+ --shared-openssl-includes=$(HOST_DIR)/include \
|
|
--shared-openssl-libpath=$(HOST_DIR)/lib \
|
|
--shared-openssl-libpath=$(HOST_DIR)/lib \
|
|
--shared-zlib \
|
|
--shared-zlib \
|
|
--no-cross-compiling \
|
|
--no-cross-compiling \
|
|
@@ -82,7 +73,7 @@ NODEJS_HOST_TOOLS = $(NODEJS_HOST_TOOLS_V8) $(NODEJS_HOST_TOOLS_NODE)
|
|
HOST_NODEJS_CXXFLAGS = $(HOST_CXXFLAGS) -DU_DISABLE_RENAMING=1
|
|
HOST_NODEJS_CXXFLAGS = $(HOST_CXXFLAGS) -DU_DISABLE_RENAMING=1
|
|
|
|
|
|
define HOST_NODEJS_BUILD_CMDS
|
|
define HOST_NODEJS_BUILD_CMDS
|
|
- $(HOST_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python2 \
|
|
|
|
|
|
+ $(HOST_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python3 \
|
|
$(MAKE) -C $(@D) \
|
|
$(MAKE) -C $(@D) \
|
|
$(HOST_CONFIGURE_OPTS) \
|
|
$(HOST_CONFIGURE_OPTS) \
|
|
CXXFLAGS="$(HOST_NODEJS_CXXFLAGS)" \
|
|
CXXFLAGS="$(HOST_NODEJS_CXXFLAGS)" \
|
|
@@ -92,7 +83,7 @@ define HOST_NODEJS_BUILD_CMDS
|
|
endef
|
|
endef
|
|
|
|
|
|
define HOST_NODEJS_INSTALL_CMDS
|
|
define HOST_NODEJS_INSTALL_CMDS
|
|
- $(HOST_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python2 \
|
|
|
|
|
|
+ $(HOST_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python3 \
|
|
$(MAKE) -C $(@D) install \
|
|
$(MAKE) -C $(@D) install \
|
|
$(HOST_CONFIGURE_OPTS) \
|
|
$(HOST_CONFIGURE_OPTS) \
|
|
CXXFLAGS="$(HOST_NODEJS_CXXFLAGS)" \
|
|
CXXFLAGS="$(HOST_NODEJS_CXXFLAGS)" \
|
|
@@ -152,17 +143,45 @@ ifeq ($(BR2_TOOLCHAIN_HAS_LIBATOMIC),y)
|
|
NODEJS_LDFLAGS += -latomic
|
|
NODEJS_LDFLAGS += -latomic
|
|
endif
|
|
endif
|
|
|
|
|
|
-define NODEJS_CONFIGURE_CMDS
|
|
|
|
- mkdir -p $(@D)/bin
|
|
|
|
- ln -sf $(HOST_DIR)/bin/python2 $(@D)/bin/python
|
|
|
|
|
|
+# V8's JIT infrastructure requires binaries such as mksnapshot and
|
|
|
|
+# mkpeephole to be run in the host during the build. However, these
|
|
|
|
+# binaries must have the same bit-width as the target (e.g. a x86_64
|
|
|
|
+# host targeting ARMv6 needs to produce a 32-bit binary). To work around this
|
|
|
|
+# issue, cross-compile the binaries for the target and run them on the
|
|
|
|
+# host with QEMU, much like gobject-introspection.
|
|
|
|
+define NODEJS_INSTALL_V8_QEMU_WRAPPER
|
|
|
|
+ $(INSTALL) -D -m 755 $(NODEJS_PKGDIR)/v8-qemu-wrapper.in \
|
|
|
|
+ $(@D)/out/Release/v8-qemu-wrapper
|
|
|
|
+ $(SED) "s%@QEMU_USER@%$(QEMU_USER)%g" \
|
|
|
|
+ $(@D)/out/Release/v8-qemu-wrapper
|
|
|
|
+ $(SED) "s%@TOOLCHAIN_HEADERS_VERSION@%$(BR2_TOOLCHAIN_HEADERS_AT_LEAST)%g" \
|
|
|
|
+ $(@D)/out/Release/v8-qemu-wrapper
|
|
|
|
+ $(SED) "s%@QEMU_USERMODE_ARGS@%$(call qstrip,$(BR2_PACKAGE_HOST_QEMU_USER_MODE_ARGS))%g" \
|
|
|
|
+ $(@D)/out/Release/v8-qemu-wrapper
|
|
|
|
+endef
|
|
|
|
+NODEJS_PRE_CONFIGURE_HOOKS += NODEJS_INSTALL_V8_QEMU_WRAPPER
|
|
|
|
|
|
|
|
+define NODEJS_WRAPPER_FIXUP
|
|
|
|
+ $(SED) "s%@MAYBE_WRAPPER@%'<(PRODUCT_DIR)/v8-qemu-wrapper',%g" $(@D)/node.gyp
|
|
|
|
+ $(SED) "s%@MAYBE_WRAPPER@%'<(PRODUCT_DIR)/v8-qemu-wrapper',%g" $(@D)/tools/v8_gypfiles/v8.gyp
|
|
|
|
+endef
|
|
|
|
+NODEJS_PRE_CONFIGURE_HOOKS += NODEJS_WRAPPER_FIXUP
|
|
|
|
+
|
|
|
|
+# Do not run the qemu-wrapper for the host build.
|
|
|
|
+define HOST_NODEJS_WRAPPER_FIXUP
|
|
|
|
+ $(SED) "s%@MAYBE_WRAPPER@%%g" $(@D)/node.gyp
|
|
|
|
+ $(SED) "s%@MAYBE_WRAPPER@%%g" $(@D)/tools/v8_gypfiles/v8.gyp
|
|
|
|
+endef
|
|
|
|
+HOST_NODEJS_PRE_CONFIGURE_HOOKS += HOST_NODEJS_WRAPPER_FIXUP
|
|
|
|
+
|
|
|
|
+define NODEJS_CONFIGURE_CMDS
|
|
(cd $(@D); \
|
|
(cd $(@D); \
|
|
$(TARGET_CONFIGURE_OPTS) \
|
|
$(TARGET_CONFIGURE_OPTS) \
|
|
PATH=$(@D)/bin:$(BR_PATH) \
|
|
PATH=$(@D)/bin:$(BR_PATH) \
|
|
LDFLAGS="$(NODEJS_LDFLAGS)" \
|
|
LDFLAGS="$(NODEJS_LDFLAGS)" \
|
|
LD="$(TARGET_CXX)" \
|
|
LD="$(TARGET_CXX)" \
|
|
- PYTHON=$(HOST_DIR)/bin/python2 \
|
|
|
|
- $(HOST_DIR)/bin/python2 ./configure \
|
|
|
|
|
|
+ PYTHON=$(HOST_DIR)/bin/python3 \
|
|
|
|
+ $(HOST_DIR)/bin/python3 ./configure \
|
|
--prefix=/usr \
|
|
--prefix=/usr \
|
|
--dest-cpu=$(NODEJS_CPU) \
|
|
--dest-cpu=$(NODEJS_CPU) \
|
|
$(if $(NODEJS_ARM_FP),--with-arm-float-abi=$(NODEJS_ARM_FP)) \
|
|
$(if $(NODEJS_ARM_FP),--with-arm-float-abi=$(NODEJS_ARM_FP)) \
|
|
@@ -171,19 +190,10 @@ define NODEJS_CONFIGURE_CMDS
|
|
$(if $(NODEJS_MIPS_FPU_MODE),--with-mips-fpu-mode=$(NODEJS_MIPS_FPU_MODE)) \
|
|
$(if $(NODEJS_MIPS_FPU_MODE),--with-mips-fpu-mode=$(NODEJS_MIPS_FPU_MODE)) \
|
|
$(NODEJS_CONF_OPTS) \
|
|
$(NODEJS_CONF_OPTS) \
|
|
)
|
|
)
|
|
-
|
|
|
|
- $(foreach f,$(NODEJS_HOST_TOOLS_V8), \
|
|
|
|
- $(SED) "s#<(PRODUCT_DIR)/<(EXECUTABLE_PREFIX)$(f)<(EXECUTABLE_SUFFIX)#$(HOST_DIR)/bin/$(f)#" \
|
|
|
|
- $(@D)/tools/v8_gypfiles/v8.gyp
|
|
|
|
- )
|
|
|
|
- $(foreach f,$(NODEJS_HOST_TOOLS_NODE), \
|
|
|
|
- $(SED) "s#<(PRODUCT_DIR)/<(EXECUTABLE_PREFIX)$(f)<(EXECUTABLE_SUFFIX)#$(HOST_DIR)/bin/$(f)#" \
|
|
|
|
- -i $(@D)/node.gyp
|
|
|
|
- )
|
|
|
|
endef
|
|
endef
|
|
|
|
|
|
define NODEJS_BUILD_CMDS
|
|
define NODEJS_BUILD_CMDS
|
|
- $(TARGET_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python2 \
|
|
|
|
|
|
+ $(TARGET_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python3 \
|
|
$(MAKE) -C $(@D) \
|
|
$(MAKE) -C $(@D) \
|
|
$(TARGET_CONFIGURE_OPTS) \
|
|
$(TARGET_CONFIGURE_OPTS) \
|
|
NO_LOAD=cctest.target.mk \
|
|
NO_LOAD=cctest.target.mk \
|
|
@@ -223,7 +233,7 @@ endef
|
|
endif
|
|
endif
|
|
|
|
|
|
define NODEJS_INSTALL_STAGING_CMDS
|
|
define NODEJS_INSTALL_STAGING_CMDS
|
|
- $(TARGET_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python2 \
|
|
|
|
|
|
+ $(TARGET_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python3 \
|
|
$(MAKE) -C $(@D) install \
|
|
$(MAKE) -C $(@D) install \
|
|
DESTDIR=$(STAGING_DIR) \
|
|
DESTDIR=$(STAGING_DIR) \
|
|
$(TARGET_CONFIGURE_OPTS) \
|
|
$(TARGET_CONFIGURE_OPTS) \
|
|
@@ -234,7 +244,7 @@ define NODEJS_INSTALL_STAGING_CMDS
|
|
endef
|
|
endef
|
|
|
|
|
|
define NODEJS_INSTALL_TARGET_CMDS
|
|
define NODEJS_INSTALL_TARGET_CMDS
|
|
- $(TARGET_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python2 \
|
|
|
|
|
|
+ $(TARGET_MAKE_ENV) PYTHON=$(HOST_DIR)/bin/python3 \
|
|
$(MAKE) -C $(@D) install \
|
|
$(MAKE) -C $(@D) install \
|
|
DESTDIR=$(TARGET_DIR) \
|
|
DESTDIR=$(TARGET_DIR) \
|
|
$(TARGET_CONFIGURE_OPTS) \
|
|
$(TARGET_CONFIGURE_OPTS) \
|