5 changed files with 206 additions and 0 deletions
@ -0,0 +1,19 @@
|
||||
#!/bin/sh |
||||
config() |
||||
{ |
||||
NEW="$1" |
||||
OLD="`dirname $NEW`/`basename $NEW .new`" |
||||
if [ ! -r $OLD ]; then |
||||
mv $NEW $OLD |
||||
elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then |
||||
rm $NEW |
||||
fi |
||||
} |
||||
|
||||
if [ -x /usr/bin/update-desktop-database ]; then |
||||
/usr/bin/update-desktop-database ./usr/share/applications >/dev/null 2>&1 |
||||
fi |
||||
|
||||
if [ -x /usr/bin/update-mime-database ]; then |
||||
/usr/bin/update-mime-database ./usr/share/mime >/dev/null 2>&1 |
||||
fi |
@ -0,0 +1,32 @@
|
||||
diff -Naur node-v12.16.0.orig/deps/npm/lib/unbuild.js node-v12.16.0/deps/npm/lib/unbuild.js
|
||||
--- node-v12.16.0.orig/deps/npm/lib/unbuild.js 2020-02-11 15:18:17.000000000 +0000
|
||||
+++ node-v12.16.0/deps/npm/lib/unbuild.js 2020-02-13 22:20:15.875730045 +0000
|
||||
@@ -101,7 +101,7 @@
|
||||
!npm.config.get('global')) {
|
||||
return cb()
|
||||
}
|
||||
- const manRoot = path.resolve(npm.config.get('prefix'), 'share', 'man')
|
||||
+ const manRoot = path.resolve(npm.config.get('prefix'), 'man')
|
||||
log.verbose('rmMans', 'man files are', pkg.man, 'in', manRoot)
|
||||
asyncMap(pkg.man, function (man, cb) {
|
||||
if (Array.isArray(man)) {
|
||||
diff -Naur node-v12.16.0.orig/tools/install.py node-v12.16.0/tools/install.py
|
||||
--- node-v12.16.0.orig/tools/install.py 2020-02-11 15:18:21.000000000 +0000
|
||||
+++ node-v12.16.0/tools/install.py 2020-02-13 22:19:18.251866168 +0000
|
||||
@@ -148,13 +148,10 @@
|
||||
# behave similarly for systemtap
|
||||
action(['src/node.stp'], 'share/systemtap/tapset/')
|
||||
|
||||
- action(['deps/v8/tools/gdbinit'], 'share/doc/node/')
|
||||
- action(['deps/v8/tools/lldb_commands.py'], 'share/doc/node/')
|
||||
+ action(['deps/v8/tools/gdbinit'], 'share/nodejs/')
|
||||
+ action(['deps/v8/tools/lldb_commands.py'], 'share/nodejs/')
|
||||
|
||||
- if 'freebsd' in sys.platform or 'openbsd' in sys.platform:
|
||||
- action(['doc/node.1'], 'man/man1/')
|
||||
- else:
|
||||
- action(['doc/node.1'], 'share/man/man1/')
|
||||
+ action(['doc/node.1'], 'man/man1/')
|
||||
|
||||
if 'true' == variables.get('node_install_npm'): npm_files(action)
|
||||
|
@ -0,0 +1 @@
|
||||
ae2dfe74485d821d4fef7cf1802acd2322cd994c853a2327c4306952f4453441 node-v12.16.0.tar.gz |
@ -0,0 +1,142 @@
|
||||
#!/bin/bash |
||||
# Build script for Slackware |
||||
# Copyright (C) 2020 Damien Goutte-Gattat |
||||
# |
||||
# Redistribution and use of this script, with or without modifications, |
||||
# is permitted provided that the following conditions are met: |
||||
# |
||||
# 1. Redistributions of this script must retain the above copyright |
||||
# notice, this list of conditions and the following disclaimer. |
||||
# |
||||
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AS IS'' AND ANY EXPRESS OR |
||||
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
||||
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
||||
# DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, |
||||
# INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
||||
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR |
||||
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |
||||
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, |
||||
# STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING |
||||
# IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
||||
# POSSIBILITY OF SUCH DAMAGE. |
||||
# |
||||
# Contact: Damien Goutte-Gattat <dgouttegattat@incenp.org> |
||||
# |
||||
# Latest nodejs sourcecode is available at: <https://nodejs.org/>. |
||||
|
||||
# Source package infos |
||||
NAMESRC=${NAMESRC:-node} |
||||
VERSION=${VERSION:-12.16.0} |
||||
ARCHIVE=${ARCHIVE:-$NAMESRC-v$VERSION.tar.gz} |
||||
WGET=${WGET:-https://nodejs.org/dist/v$VERSION/$NAMESRC-v$VERSION.tar.gz} |
||||
|
||||
# Build infos |
||||
NAMEPKG=${NAMEPKG:-nodejs} |
||||
BUILD=${BUILD:-1GGD} |
||||
ARCH=${ARCH:-$(uname -m | sed 's/^i.86$/i486/;s/^arm.*/arm/')} |
||||
JOBS=${JOBS:-1} |
||||
EXT=${EXT:-txz} |
||||
|
||||
# Directories |
||||
TMP=${TMP:-/tmp} |
||||
OUT=${OUT:-$TMP/build} |
||||
PKG=${PKG:-$OUT/$NAMEPKG} |
||||
CWD=$(pwd) |
||||
|
||||
set -e # Quit if a command returns non-zero |
||||
|
||||
# Sanity checks |
||||
if [ $UID -eq 0 ]; then |
||||
echo "You should NOT run this script as ROOT!" |
||||
exit 1 |
||||
fi |
||||
if [ ! -d $TMP ]; then |
||||
echo "$TMP does not exists or is not a directory!" |
||||
exit 1 |
||||
fi |
||||
|
||||
# Get and verify the source archive |
||||
if [ ! -r $ARCHIVE ]; then |
||||
wget -c -O $ARCHIVE.part "$WGET" |
||||
mv $ARCHIVE.part $ARCHIVE |
||||
fi |
||||
sha256sum -c $ARCHIVE.sha256 |
||||
NAME=$(tar ft $ARCHIVE | head -n 1 | cut -d / -f 1) |
||||
|
||||
# Compile |
||||
cd $TMP |
||||
echo "Building $ARCHIVE..." |
||||
tar xf $CWD/$ARCHIVE |
||||
cd $NAME |
||||
|
||||
# ----- BEGIN RANT ----- |
||||
# |
||||
# Developers (if those who wrote Node.js can be qualified as such): |
||||
# one of the purpose of a configurable build system is to allow to |
||||
# adapt a software to any peculiarity of the host system, either by |
||||
# automatically detecting said peculiarities or by offering options |
||||
# to the human running the build system. |
||||
# |
||||
# A BUILD SYSTEM THAT DOES NOT DO THAT AND INSTEAD REQUIRES THE USER |
||||
# TO EDIT RANDOM FILES IN THE SOURCE TREE TO DO SOMETHING AS TRIVIAL |
||||
# AS INSTALLING THE DOCS AT THE RIGHT PLACE IS A PIECE OF CRAP. |
||||
# |
||||
# FOR FUCK'S SAKE, THERE ARE BAZILLIONS OF BUILD SYSTEMS OUT THERE, |
||||
# INCLUDING A HANDFUL THAT GOT THOSE KIND OF DETAILS CORRECTLY. ALL |
||||
# YOU HAD TO DO WAS TO PICK ONE OF THEM INSTEAD OF COMMITTING THIS |
||||
# GARBAGE. |
||||
# |
||||
# I also expect a build system to allow me to install libraries at |
||||
# the place they are supposed to be installed on my system, that is |
||||
# under PREFIX/lib64 on my Slackware64. Yes, that's a peculiarity, |
||||
# most other GNU/Linux distributions don't use that 64 suffix, but |
||||
# so what? Again, it's one of the roles of a (proper) build system |
||||
# to cope with those things. |
||||
# |
||||
# And what is this lunacy of installing some complete sources, |
||||
# including the docs, the Git hidden files and everything, under |
||||
# the lib/ directory? |
||||
# |
||||
# I won't even try to fix all of that, I don't want to expose myself |
||||
# to any more brain damage than strictly necessary to get this crap |
||||
# running. |
||||
# |
||||
# ----- END RANT ----- |
||||
patch -p 1 < $CWD/node-v12.16.0-fix-doc-dirs.patch |
||||
./configure \ |
||||
--prefix=/usr \ |
||||
--shared-zlib \ |
||||
--shared-openssl |
||||
make -j $JOBS |
||||
make install DESTDIR=$PKG |
||||
|
||||
# Strip binaries |
||||
find $PKG | xargs file | grep "ELF \(32\|64\)-bit LSB" | cut -d : -f 1 | \ |
||||
xargs strip --strip-unneeded 2> /dev/null |
||||
|
||||
# Compress man pages |
||||
find $PKG/usr/man -type f -exec gzip -9 {} \; |
||||
|
||||
# Install the documentation |
||||
mkdir -p $PKG/usr/doc/$NAMEPKG-$VERSION |
||||
install -m 644 AUTHORS BUILDING.md CHANGELOG.md CODE_OF_CONDUCT.md \ |
||||
COLLABORATOR_GUIDE.md CONTRIBUTING.md CPP_STYLE_GUIDE.md GOVERNANCE.md \ |
||||
LICENSE README.md SECURITY.md $PKG/usr/doc/$NAMEPKG-$VERSION |
||||
|
||||
# Copy slack-desc file |
||||
install -D -m 644 $CWD/slack-desc $PKG/install/slack-desc |
||||
|
||||
# Package the tree |
||||
cd $PKG |
||||
mkdir -p $OUT |
||||
PACKAGING=" |
||||
chown root:root . -R |
||||
/sbin/makepkg -l y -c n $OUT/$NAMEPKG-$VERSION-$ARCH-$BUILD.$EXT |
||||
rm -rf $PKG |
||||
rm -rf $TMP/$NAME |
||||
" |
||||
if type -p fakeroot ; then |
||||
echo "$PACKAGING" | fakeroot |
||||
else |
||||
su -c "$PACKAGING" |
||||
fi |
@ -0,0 +1,12 @@
|
||||
|-----handy-ruler-----------------------------------------------------| |
||||
nodejs: nodejs (javascript runtime) |
||||
nodejs: |
||||
nodejs: Node.js is a JavaScript runtime built on Chrome's V8 JavaScript |
||||
nodejs: engine. |
||||
nodejs: |
||||
nodejs: |
||||
nodejs: |
||||
nodejs: |
||||
nodejs: |
||||
nodejs: |
||||
nodejs: |
Loading…
Reference in new issue