Browse Source

d/nodejs: Added nodejs-12.16.0.

current-20191101
Damien Goutte-Gattat 2 years ago
parent
commit
188cbf485e
  1. 19
      d/nodejs/doinst.sh
  2. 32
      d/nodejs/node-v12.16.0-fix-doc-dirs.patch
  3. 1
      d/nodejs/node-v12.16.0.tar.gz.sha256
  4. 142
      d/nodejs/nodejs.SlackBuild
  5. 12
      d/nodejs/slack-desc

19
d/nodejs/doinst.sh

@ -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

32
d/nodejs/node-v12.16.0-fix-doc-dirs.patch

@ -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)

1
d/nodejs/node-v12.16.0.tar.gz.sha256

@ -0,0 +1 @@
ae2dfe74485d821d4fef7cf1802acd2322cd994c853a2327c4306952f4453441 node-v12.16.0.tar.gz

142
d/nodejs/nodejs.SlackBuild

@ -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

12
d/nodejs/slack-desc

@ -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…
Cancel
Save