diff --git a/d/nodejs/doinst.sh b/d/nodejs/doinst.sh new file mode 100644 index 00000000..0613efb0 --- /dev/null +++ b/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 diff --git a/d/nodejs/node-v12.16.0-fix-doc-dirs.patch b/d/nodejs/node-v12.16.0-fix-doc-dirs.patch new file mode 100644 index 00000000..d52f5789 --- /dev/null +++ b/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) + diff --git a/d/nodejs/node-v12.16.0.tar.gz.sha256 b/d/nodejs/node-v12.16.0.tar.gz.sha256 new file mode 100644 index 00000000..6c51c2c7 --- /dev/null +++ b/d/nodejs/node-v12.16.0.tar.gz.sha256 @@ -0,0 +1 @@ +ae2dfe74485d821d4fef7cf1802acd2322cd994c853a2327c4306952f4453441 node-v12.16.0.tar.gz diff --git a/d/nodejs/nodejs.SlackBuild b/d/nodejs/nodejs.SlackBuild new file mode 100755 index 00000000..c575b459 --- /dev/null +++ b/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 +# +# Latest nodejs sourcecode is available at: . + +# 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 diff --git a/d/nodejs/slack-desc b/d/nodejs/slack-desc new file mode 100644 index 00000000..c7aed447 --- /dev/null +++ b/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: