mirror of https://git.freebsd.org/ports.git
www/node22: Add node22 22.0.0
Node.js is a free, open-source, cross-platform JavaScript runtime environment that lets developers create servers, web apps, command line tools and scripts.main
parent
011d7d9016
commit
067dacb0c6
|
@ -475,6 +475,7 @@
|
|||
SUBDIR += node18
|
||||
SUBDIR += node20
|
||||
SUBDIR += node21
|
||||
SUBDIR += node22
|
||||
SUBDIR += nostromo
|
||||
SUBDIR += novnc
|
||||
SUBDIR += novnc-websockify
|
||||
|
|
|
@ -0,0 +1,88 @@
|
|||
PORTNAME= node
|
||||
PORTVERSION= ${NODEJS_PORTVERSION}
|
||||
DISTVERSIONPREFIX= v
|
||||
CATEGORIES= www
|
||||
MASTER_SITES= https://nodejs.org/dist/v${PORTVERSION}/
|
||||
PKGNAMESUFFIX= 22
|
||||
|
||||
MAINTAINER= sunpoet@FreeBSD.org
|
||||
COMMENT= V8 JavaScript for client and server
|
||||
WWW= https://nodejs.org/ \
|
||||
https://github.com/nodejs/node
|
||||
|
||||
LICENSE= MIT
|
||||
LICENSE_FILE= ${WRKSRC}/LICENSE
|
||||
|
||||
BROKEN_SSL= libressl libressl-devel
|
||||
BROKEN_SSL_REASON= Node.js ${PORTVERSION:R:R}.x requires OpenSSL or the BUNDLED_SSL option enabled
|
||||
ONLY_FOR_ARCHS= aarch64 amd64 armv6 armv7 i386 powerpc64 powerpc64le
|
||||
|
||||
BUILD_DEPENDS= brotli>=1.0.9,1:archivers/brotli \
|
||||
c-ares>=1.17.2:dns/c-ares \
|
||||
libnghttp2>=1.45.1:www/libnghttp2 \
|
||||
libuv>=1.42.0:devel/libuv \
|
||||
objdump:devel/binutils
|
||||
LIB_DEPENDS= libbrotlidec.so:archivers/brotli \
|
||||
libcares.so:dns/c-ares \
|
||||
libnghttp2.so:www/libnghttp2 \
|
||||
libuv.so:devel/libuv
|
||||
|
||||
USES= compiler:c++11-lib gmake localbase pkgconfig python:build shebangfix tar:xz
|
||||
|
||||
CONFIGURE_ARGS= --prefix=${PREFIX:S|^${DESTDIR}||} \
|
||||
--shared-brotli \
|
||||
--shared-cares \
|
||||
--shared-libuv \
|
||||
--shared-nghttp2 \
|
||||
--shared-zlib \
|
||||
--without-npm
|
||||
HAS_CONFIGURE= yes
|
||||
MAKE_ENV= CC.host="${CCACHE_BIN} ${CC}" \
|
||||
CFLAGS.host="${CFLAGS}" \
|
||||
CXX.host="${CCACHE_BIN} ${CXX}" \
|
||||
CXXFLAGS.host="${CXXFLAGS}" \
|
||||
LDFLAGS.host="${LDFLAGS}" \
|
||||
LINK.host="${CXX}"
|
||||
REINPLACE_ARGS= -i ''
|
||||
|
||||
CONFLICTS_INSTALL= node[0-9][0-9]
|
||||
|
||||
SHEBANG_FILES= deps/v8/third_party/inspector_protocol/*.py \
|
||||
deps/v8/tools/*.py \
|
||||
tools/*.py \
|
||||
tools/inspector_protocol/*.py
|
||||
|
||||
OPTIONS_DEFINE= BUNDLED_SSL DOCS NLS
|
||||
OPTIONS_SUB= yes
|
||||
BUNDLED_SSL_DESC= Use bundled OpenSSL implementation from node.js
|
||||
|
||||
BUNDLED_SSL_CONFIGURE_OFF= --openssl-use-def-ca-store --shared-openssl
|
||||
BUNDLED_SSL_RUN_DEPENDS_OFF= ca_root_nss>=0:security/ca_root_nss
|
||||
BUNDLED_SSL_USES_OFF= ssl
|
||||
NLS_BUILD_DEPENDS= icu>=69.1:devel/icu
|
||||
NLS_CONFIGURE_ON= --with-intl=system-icu
|
||||
NLS_LIB_DEPENDS= libicui18n.so:devel/icu
|
||||
|
||||
.include "Makefile.version"
|
||||
.include <bsd.port.options.mk>
|
||||
|
||||
.if ${PORT_OPTIONS:MBUNDLED_SSL} && ${ARCH} != amd64
|
||||
CONFIGURE_ARGS+=--openssl-no-asm
|
||||
.endif
|
||||
|
||||
post-patch:
|
||||
@${REINPLACE_CMD} -e 's|/usr/local|${LOCALBASE}|' ${WRKSRC}/tools/v8_gypfiles/v8.gyp
|
||||
|
||||
post-configure:
|
||||
# Post-process Makefile and *.mk files created by node-gyp and remove
|
||||
# all occurrences of -I${LOCALBASE}/include. C*FLAGS include this
|
||||
# before all -I../deps/* for bundled code. This can cause build
|
||||
# breakages if the dependency is installed in ${LOCALBASE}. The
|
||||
# USES+=localbase # above will ensure that we pick up includes for real
|
||||
# external dependencies.
|
||||
${FIND} ${WRKSRC}/out -type f -print0 | ${XARGS} -0 ${REINPLACE_CMD} -e "s|-I${LOCALBASE}/include||g"
|
||||
|
||||
post-install:
|
||||
${STRIP_CMD} ${STAGEDIR}${PREFIX}/bin/node
|
||||
|
||||
.include <bsd.port.mk>
|
|
@ -0,0 +1 @@
|
|||
NODEJS_PORTVERSION= 22.0.0
|
|
@ -0,0 +1,3 @@
|
|||
TIMESTAMP = 1714227788
|
||||
SHA256 (node-v22.0.0.tar.xz) = 22e28fbff31f69073b8024cb42745e5105f84041f3475b260b97d5a141039d1a
|
||||
SIZE (node-v22.0.0.tar.xz) = 44323856
|
|
@ -0,0 +1,20 @@
|
|||
--- common.gypi.orig 2023-07-20 18:27:37 UTC
|
||||
+++ common.gypi
|
||||
@@ -426,7 +426,7 @@
|
||||
'ldflags': [ '-m32' ],
|
||||
}],
|
||||
[ 'host_arch=="ppc64" and OS not in "aix os400"', {
|
||||
- 'cflags': [ '-m64', '-mminimal-toc' ],
|
||||
+ 'cflags': [ '-m64' ],
|
||||
'ldflags': [ '-m64' ],
|
||||
}],
|
||||
[ 'host_arch=="s390x" and OS=="linux"', {
|
||||
@@ -450,7 +450,7 @@
|
||||
'ldflags': [ '-m32' ],
|
||||
}],
|
||||
[ 'target_arch=="ppc64" and OS not in "aix os400"', {
|
||||
- 'cflags': [ '-m64', '-mminimal-toc' ],
|
||||
+ 'cflags': [ '-m64' ],
|
||||
'ldflags': [ '-m64' ],
|
||||
}],
|
||||
[ 'target_arch=="s390x" and OS=="linux"', {
|
|
@ -0,0 +1,11 @@
|
|||
--- deps/openssl/config/archs/linux-elf/no-asm/openssl-cl.gypi.orig 2023-05-16 06:58:19 UTC
|
||||
+++ deps/openssl/config/archs/linux-elf/no-asm/openssl-cl.gypi
|
||||
@@ -13,7 +13,7 @@
|
||||
'-Wall -O3 -fomit-frame-pointer',
|
||||
],
|
||||
'openssl_ex_libs_linux-elf': [
|
||||
- '-ldl -pthread',
|
||||
+ '-pthread',
|
||||
],
|
||||
'openssl_cli_srcs_linux-elf': [
|
||||
'openssl/apps/lib/cmp_mock_srv.c',
|
|
@ -0,0 +1,11 @@
|
|||
--- deps/openssl/config/archs/linux-elf/no-asm/openssl.gypi.orig 2023-05-16 06:58:19 UTC
|
||||
+++ deps/openssl/config/archs/linux-elf/no-asm/openssl.gypi
|
||||
@@ -977,7 +977,7 @@
|
||||
'-Wall -O3 -fomit-frame-pointer',
|
||||
],
|
||||
'openssl_ex_libs_linux-elf': [
|
||||
- '-ldl -pthread',
|
||||
+ '-pthread',
|
||||
],
|
||||
},
|
||||
'include_dirs': [
|
|
@ -0,0 +1,17 @@
|
|||
--- deps/openssl/openssl-cl_no_asm.gypi.orig 2023-10-24 10:04:40 UTC
|
||||
+++ deps/openssl/openssl-cl_no_asm.gypi
|
||||
@@ -1,4 +1,5 @@
|
||||
{
|
||||
+ 'defines': ['OPENSSL_NO_ASM'],
|
||||
'conditions': [
|
||||
['target_arch=="ppc64" and OS in ("aix", "os400")', {
|
||||
'includes': ['config/archs/aix64-gcc-as/no-asm/openssl-cl.gypi'],
|
||||
@@ -45,7 +46,7 @@
|
||||
'includes': ['config/archs/linux64-loongarch64/no-asm/openssl-cl.gypi'],
|
||||
}, {
|
||||
# Other architectures don't use assembly
|
||||
- 'includes': ['config/archs/linux-x86_64/no-asm/openssl-cl.gypi'],
|
||||
+ 'includes': ['config/archs/linux-elf/no-asm/openssl-cl.gypi'],
|
||||
}],
|
||||
],
|
||||
}
|
|
@ -0,0 +1,11 @@
|
|||
--- deps/openssl/openssl_no_asm.gypi.orig 2023-05-16 06:58:20 UTC
|
||||
+++ deps/openssl/openssl_no_asm.gypi
|
||||
@@ -44,7 +44,7 @@
|
||||
'includes': ['config/archs/linux64-riscv64/no-asm/openssl.gypi'],
|
||||
}, {
|
||||
# Other architectures don't use assembly
|
||||
- 'includes': ['config/archs/linux-x86_64/no-asm/openssl.gypi'],
|
||||
+ 'includes': ['config/archs/linux-elf/no-asm/openssl.gypi'],
|
||||
}],
|
||||
],
|
||||
}
|
|
@ -0,0 +1,13 @@
|
|||
--- deps/v8/src/base/platform/platform-freebsd.cc.orig 2023-05-16 06:58:20 UTC
|
||||
+++ deps/v8/src/base/platform/platform-freebsd.cc
|
||||
@@ -82,8 +82,8 @@ std::vector<OS::SharedLibraryAddress> OS::GetSharedLib
|
||||
lib_name = std::string(path);
|
||||
}
|
||||
result.push_back(SharedLibraryAddress(
|
||||
- lib_name, reinterpret_cast<uintptr_t>(map->kve_start),
|
||||
- reinterpret_cast<uintptr_t>(map->kve_end)));
|
||||
+ lib_name, static_cast<uintptr_t>(map->kve_start),
|
||||
+ static_cast<uintptr_t>(map->kve_end)));
|
||||
}
|
||||
|
||||
start += ssize;
|
|
@ -0,0 +1,10 @@
|
|||
--- deps/v8/src/base/small-vector.h.orig 2024-04-24 14:03:50 UTC
|
||||
+++ deps/v8/src/base/small-vector.h
|
||||
@@ -22,7 +22,6 @@ class SmallVector {
|
||||
class SmallVector {
|
||||
// Currently only support trivially copyable and trivially destructible data
|
||||
// types, as it uses memcpy to copy elements and never calls destructors.
|
||||
- ASSERT_TRIVIALLY_COPYABLE(T);
|
||||
static_assert(std::is_trivially_destructible<T>::value);
|
||||
|
||||
public:
|
|
@ -0,0 +1,18 @@
|
|||
--- deps/v8/src/codegen/arm/cpu-arm.cc.orig 2023-05-16 06:58:20 UTC
|
||||
+++ deps/v8/src/codegen/arm/cpu-arm.cc
|
||||
@@ -2,12 +2,15 @@
|
||||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
+#include "include/v8config.h"
|
||||
+
|
||||
// CPU specific code for arm independent of OS goes here.
|
||||
#ifdef __arm__
|
||||
#ifdef __QNXNTO__
|
||||
#include <sys/mman.h> // for cache flushing.
|
||||
#undef MAP_TYPE
|
||||
#elif V8_OS_FREEBSD
|
||||
+#include <sys/cdefs.h>
|
||||
#include <machine/sysarch.h> // for cache flushing
|
||||
#include <sys/types.h>
|
||||
#elif V8_OS_STARBOARD
|
|
@ -0,0 +1,20 @@
|
|||
--- deps/v8/src/codegen/ppc/constants-ppc.h.orig 2023-05-16 06:58:20 UTC
|
||||
+++ deps/v8/src/codegen/ppc/constants-ppc.h
|
||||
@@ -36,7 +36,7 @@
|
||||
#endif
|
||||
|
||||
#if !(V8_HOST_ARCH_PPC || V8_HOST_ARCH_PPC64) || !V8_TARGET_ARCH_PPC64 || \
|
||||
- V8_TARGET_LITTLE_ENDIAN || (defined(_CALL_ELF) && _CALL_ELF == 2)
|
||||
+ (defined(_CALL_ELF) && _CALL_ELF == 2)
|
||||
#define ABI_RETURNS_OBJECT_PAIRS_IN_REGS 1
|
||||
#else
|
||||
#define ABI_RETURNS_OBJECT_PAIRS_IN_REGS 0
|
||||
@@ -44,7 +44,7 @@
|
||||
|
||||
#if !(V8_HOST_ARCH_PPC || V8_HOST_ARCH_PPC64) || \
|
||||
(V8_TARGET_ARCH_PPC64 && \
|
||||
- (V8_TARGET_LITTLE_ENDIAN || (defined(_CALL_ELF) && _CALL_ELF == 2)))
|
||||
+ (defined(_CALL_ELF) && _CALL_ELF == 2))
|
||||
#define ABI_CALL_VIA_IP 1
|
||||
#else
|
||||
#define ABI_CALL_VIA_IP 0
|
|
@ -0,0 +1,13 @@
|
|||
--- deps/v8/src/libsampler/sampler.cc.orig 2023-05-16 06:58:20 UTC
|
||||
+++ deps/v8/src/libsampler/sampler.cc
|
||||
@@ -511,6 +511,10 @@ void SignalHandler::FillRegisterState(void* context, R
|
||||
state->pc = reinterpret_cast<void*>(mcontext.__gregs[_REG_PC]);
|
||||
state->sp = reinterpret_cast<void*>(mcontext.__gregs[_REG_SP]);
|
||||
state->fp = reinterpret_cast<void*>(mcontext.__gregs[_REG_FP]);
|
||||
+#elif V8_TARGET_ARCH_PPC64
|
||||
+ state->pc = reinterpret_cast<void*>(mcontext.mc_srr0);
|
||||
+ state->sp = reinterpret_cast<void*>(mcontext.mc_frame[1]);
|
||||
+ state->fp = reinterpret_cast<void*>(mcontext.mc_frame[31]);
|
||||
#endif // V8_HOST_ARCH_*
|
||||
#elif V8_OS_NETBSD
|
||||
#if V8_HOST_ARCH_IA32
|
|
@ -0,0 +1,12 @@
|
|||
--- node.gypi.orig 2023-05-16 06:58:21 UTC
|
||||
+++ node.gypi
|
||||
@@ -349,6 +349,9 @@
|
||||
[ 'node_use_openssl=="true"', {
|
||||
'defines': [ 'HAVE_OPENSSL=1' ],
|
||||
'conditions': [
|
||||
+ ['openssl_no_asm==1', {
|
||||
+ 'defines': [ 'OPENSSL_NO_ASM' ],
|
||||
+ }],
|
||||
[ 'node_shared_openssl=="false"', {
|
||||
'defines': [ 'OPENSSL_API_COMPAT=0x10100000L', ],
|
||||
'dependencies': [
|
|
@ -0,0 +1,15 @@
|
|||
--- src/crypto/crypto_util.cc.orig 2023-05-16 06:58:21 UTC
|
||||
+++ src/crypto/crypto_util.cc
|
||||
@@ -205,10 +205,12 @@ void InitCryptoOnce() {
|
||||
// No-op with OPENSSL_NO_COMP builds of OpenSSL.
|
||||
sk_SSL_COMP_zero(SSL_COMP_get_compression_methods());
|
||||
|
||||
+#if OPENSSL_VERSION_MAJOR < 3
|
||||
#ifndef OPENSSL_NO_ENGINE
|
||||
ERR_load_ENGINE_strings();
|
||||
ENGINE_load_builtin_engines();
|
||||
#endif // !OPENSSL_NO_ENGINE
|
||||
+#endif
|
||||
}
|
||||
|
||||
void GetFipsCrypto(const FunctionCallbackInfo<Value>& args) {
|
|
@ -0,0 +1,11 @@
|
|||
--- src/cares_wrap.h.orig 2023-05-16 06:58:21 UTC
|
||||
+++ src/cares_wrap.h
|
||||
@@ -23,7 +23,7 @@
|
||||
# include <netdb.h>
|
||||
#endif // __POSIX__
|
||||
|
||||
-# include <ares_nameser.h>
|
||||
+# include <arpa/nameser.h>
|
||||
|
||||
namespace node {
|
||||
namespace cares_wrap {
|
|
@ -0,0 +1,11 @@
|
|||
--- tools/v8_gypfiles/v8.gyp.orig 2023-05-16 06:58:22 UTC
|
||||
+++ tools/v8_gypfiles/v8.gyp
|
||||
@@ -1091,7 +1091,7 @@
|
||||
}],
|
||||
# Platforms that don't have Compare-And-Swap (CAS) support need to link atomic library
|
||||
# to implement atomic memory access
|
||||
- ['v8_current_cpu in ["mips64", "mips64el", "ppc", "arm", "riscv64", "loong64"]', {
|
||||
+ ['v8_current_cpu in ["mips64", "mips64el", "ppc", "riscv64", "loong64"]', {
|
||||
'link_settings': {
|
||||
'libraries': ['-latomic', ],
|
||||
},
|
|
@ -0,0 +1,2 @@
|
|||
Node.js is a free, open-source, cross-platform JavaScript runtime environment
|
||||
that lets developers create servers, web apps, command line tools and scripts.
|
|
@ -0,0 +1,7 @@
|
|||
[
|
||||
{ type: install
|
||||
message: <<EOM
|
||||
Note: If you need npm (Node Package Manager), please install www/npm.
|
||||
EOM
|
||||
}
|
||||
]
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue