Move branch constant into configuration

This commit is contained in:
Eugen Wissner 2021-04-02 08:10:48 +02:00
parent 9609279541
commit 7949c74d9a
Signed by: belka
GPG Key ID: A27FDC1E8EE902C0
6 changed files with 39 additions and 267 deletions

View File

@ -109,3 +109,27 @@ Style/RedundantArgument: # (new in 1.4)
Style/SwapValues: # (new in 1.1) Style/SwapValues: # (new in 1.1)
Enabled: false Enabled: false
Gemspec/DateAssignment: # (new in 1.10)
Enabled: true
Lint/NumberedParameterAssignment: # (new in 1.9)
Enabled: true
Lint/OrAssignmentToConstant: # (new in 1.9)
Enabled: true
Lint/SymbolConversion: # (new in 1.9)
Enabled: true
Lint/TripleQuotes: # (new in 1.9)
Enabled: true
Style/HashConversion: # (new in 1.10)
Enabled: true
Style/IfWithBooleanLiteralBranches: # (new in 1.9)
Enabled: true
Style/StringChars: # (new in 1.12)
Enabled: true

View File

@ -1,14 +1,14 @@
GEM GEM
remote: https://rubygems.org/ remote: https://rubygems.org/
specs: specs:
ast (2.4.1) ast (2.4.2)
parallel (1.20.1) parallel (1.20.1)
parser (3.0.0.0) parser (3.0.0.0)
ast (~> 2.4.1) ast (~> 2.4.1)
rainbow (3.0.0) rainbow (3.0.0)
regexp_parser (2.0.3) regexp_parser (2.1.1)
rexml (3.2.4) rexml (3.2.4)
rubocop (1.8.0) rubocop (1.12.0)
parallel (~> 1.10) parallel (~> 1.10)
parser (>= 3.0.0.0) parser (>= 3.0.0.0)
rainbow (>= 2.2.2, < 4.0) rainbow (>= 2.2.2, < 4.0)
@ -17,7 +17,7 @@ GEM
rubocop-ast (>= 1.2.0, < 2.0) rubocop-ast (>= 1.2.0, < 2.0)
ruby-progressbar (~> 1.7) ruby-progressbar (~> 1.7)
unicode-display_width (>= 1.4.0, < 3.0) unicode-display_width (>= 1.4.0, < 3.0)
rubocop-ast (1.4.0) rubocop-ast (1.4.1)
parser (>= 2.7.1.5) parser (>= 2.7.1.5)
ruby-progressbar (1.11.0) ruby-progressbar (1.11.0)
unicode-display_width (2.0.0) unicode-display_width (2.0.0)
@ -29,4 +29,4 @@ DEPENDENCIES
rubocop (~> 1.7) rubocop (~> 1.7)
BUNDLED WITH BUNDLED WITH
2.1.4 2.2.3

View File

@ -11,8 +11,8 @@ require_relative 'lib/package'
require_relative 'lib/download' require_relative 'lib/download'
task :dmd do task :dmd do
version = '2.095.1' version = '2.096.0'
dub_version = '1.24.1' dub_version = '1.25.0'
dscanner_version = '0.11.0' dscanner_version = '0.11.0'
dcd_version = '0.13.1' dcd_version = '0.13.1'
tarball_name = "dmd.#{version}.linux.tar.xz" tarball_name = "dmd.#{version}.linux.tar.xz"
@ -80,7 +80,7 @@ task :dmd do
end end
task :composer do task :composer do
version = '2.0.8' version = '2.0.11'
package = Package.new 'development/composer', package = Package.new 'development/composer',
version: version, version: version,

View File

@ -2,5 +2,6 @@
CONFIG = { CONFIG = {
remote_path: 'example.com:/srv/httpd/some/path', remote_path: 'example.com:/srv/httpd/some/path',
download_url: 'https://example.com/some/path' download_url: 'https://example.com/some/path',
branch: 'user/nick/updates'
} }

View File

@ -8,8 +8,6 @@ require_relative '../config/config'
require_relative 'package' require_relative 'package'
require 'net/http' require 'net/http'
MY_BRANCH = 'user/belka/updates'
def write_download(target, response) def write_download(target, response)
checksum = Digest::MD5.new checksum = Digest::MD5.new
@ -135,11 +133,11 @@ end
def commit(package_path, version) def commit(package_path, version)
message = "#{package_path}: Updated for version #{version}" message = "#{package_path}: Updated for version #{version}"
unless system('git', '-C', 'slackbuilds', 'checkout', MY_BRANCH, unless system('git', '-C', 'slackbuilds', 'checkout', CONFIG[:branch],
err: '/dev/null') err: '/dev/null')
sh "git -C slackbuilds checkout -b #{MY_BRANCH} master" sh 'git', '-C', 'slackbuilds', 'checkout', '-b', CONFIG[:branch], 'master'
end end
sh "git -C slackbuilds add #{package_path}" sh 'git', '-C', 'slackbuilds', 'add', package_path
sh %(git -C slackbuilds commit -S -m "#{message}") sh 'git', '-C', 'slackbuilds', 'commit', '-S', '-m', message
# sh "git -C slackbuilds push origin #{branch}" # sh 'git', '-C', 'slackbuilds', 'push', 'origin', CONFIG[:branch]
end end

View File

@ -1,251 +0,0 @@
#!/bin/sh
# Slackware build script for gcc-d
# Copyright 2017-2018 Eugene Wissner, Dachau, Germany
#
# Based on the GCC build script by Patrick J. Volkerding, Sebeka, MN, USA
#
# All rights reserved.
#
# Redistribution and use of this script, with or without modification, 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.
PRGNAM=gcc-d
SRCNAM=gdc
VERSION=${VERSION:-2.081.2}
GCC_VERSION=8.2.0
HOST_GDC=2.076.0_b5
HOST_GCC=5.5.0
BUILD=${BUILD:-1}
TAG=${TAG:-_SBo}
if [ -z "$ARCH" ]; then
case "$(uname -m)" in
i?86) ARCH=i586 ;;
arm*) readelf /usr/bin/file -A | egrep -q "Tag_CPU.*[4,5]" && ARCH=arm || ARCH=armv7hl ;;
*) ARCH=$(uname -m) ;;
esac
export ARCH
fi
CWD=$(pwd)
TMP=${TMP:-/tmp/SBo}
PKG=$TMP/package-$PRGNAM
OUTPUT=${OUTPUT:-/tmp}
if [ "$ARCH" = "i586" ]; then
SLKCFLAGS="-O2 -march=i586 -mtune=i686"
LIBDIRSUFFIX=""
LIB_ARCH=i386
elif [ "$ARCH" = "i686" ]; then
SLKCFLAGS="-O2 -march=i686 -mtune=i686"
LIBDIRSUFFIX=""
LIB_ARCH=i386
elif [ "$ARCH" = "x86_64" ]; then
SLKCFLAGS="-O2 -fPIC"
LIBDIRSUFFIX="64"
LIB_ARCH=amd64
elif [ "$ARCH" = "armv7hl" ]; then
SLKCFLAGS="-O3 -march=armv7-a -mfpu=vfpv3-d16"
LIBDIRSUFFIX=""
LIB_ARCH=armv7hl
else
SLKCFLAGS="-O2"
LIBDIRSUFFIX=""
LIB_ARCH=$ARCH
fi
case "$ARCH" in
arm*) TARGET=$ARCH-slackware-linux-gnueabi ;;
*) TARGET=$ARCH-slackware-linux ;;
esac
if [ "$ARCH" != "x86_64" ]; then
GCC_ARCHOPTS="--with-arch=$ARCH"
else
GCC_ARCHOPTS="--disable-multilib"
fi
set -e
rm -rf $PKG
mkdir -p $TMP $PKG $OUTPUT
#
# Build bootstrap compiler
#
cd $TMP
rm -rf $SRCNAM-$HOST_GDC gcc-$HOST_GCC
tar xvf $CWD/gcc-$HOST_GCC.tar.?z*
tar xvf $CWD/$SRCNAM-$HOST_GDC.tar.?z*
# Apply patches.
cd $TMP/gcc-$HOST_GCC/gcc
cd $TMP/$SRCNAM-$HOST_GDC
sh setup-gcc.sh ../gcc-$HOST_GCC
cd $TMP/gcc-$HOST_GCC
chown -R root:root .
find -L . \
\( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 -o -perm 511 \) \
-exec chmod 755 {} \; -o \
\( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
-exec chmod 644 {} \;
rm -rf $TMP/bootstrap-gcc-d
CFLAGS="$SLKCFLAGS" \
CXXFLAGS="$SLKCFLAGS" \
../gcc-$HOST_GCC/configure \
--prefix=$TMP/bootstrap-$PRGNAM \
--enable-shared \
--disable-bootstrap \
--enable-languages=c,c++,d \
--enable-threads=posix \
--enable-checking=release \
--with-system-zlib \
--with-python-dir=/lib$LIBDIRSUFFIX/python2.7/site-packages \
--enable-libstdcxx-dual-abi \
--disable-libunwind-exceptions \
--enable-__cxa_atexit \
--enable-libssp \
--enable-lto \
--disable-install-libiberty \
--with-gnu-ld \
--verbose \
--with-arch-directory=$LIB_ARCH \
$GCC_ARCHOPTS \
--target=${TARGET} \
--build=${TARGET} \
--host=${TARGET}
make
make install
#
# Build D compiler
#
cd $TMP
rm -rf $SRCNAM-$VERSION gcc-$GCC_VERSION
tar xvf $CWD/gcc-$GCC_VERSION.tar.?z*
tar xvf $CWD/$SRCNAM-$VERSION.tar.?z*
# Apply patches.
cd $TMP/gcc-$GCC_VERSION/gcc
cd $TMP/$SRCNAM-$VERSION
sh setup-gcc.sh ../gcc-$GCC_VERSION
cd $TMP/gcc-$GCC_VERSION
chown -R root:root .
find -L . \
\( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 -o -perm 511 \) \
-exec chmod 755 {} \; -o \
\( -perm 666 -o -perm 664 -o -perm 600 -o -perm 444 -o -perm 440 -o -perm 400 \) \
-exec chmod 644 {} \;
CC="$TMP/bootstrap-$PRGNAM/bin/gcc" \
CXX="$TMP/bootstrap-$PRGNAM/bin/g++" \
CPP="$TMP/bootstrap-$PRGNAM/bin/cpp" \
GDC="$TMP/bootstrap-$PRGNAM/bin/gdc" \
LD="$TMP/bootstrap-$PRGNAM/bin/gcc" \
CFLAGS="$SLKCFLAGS" \
CXXFLAGS="$SLKCFLAGS" \
../gcc-$GCC_VERSION/configure \
--prefix=/usr \
--libdir=/usr/lib$LIBDIRSUFFIX \
--mandir=/usr/man \
--infodir=/usr/info \
--enable-shared \
--disable-bootstrap \
--enable-languages=c,c++,d \
--enable-threads=posix \
--enable-checking=release \
--with-system-zlib \
--with-python-dir=/lib$LIBDIRSUFFIX/python2.7/site-packages \
--enable-libstdcxx-dual-abi \
--disable-libunwind-exceptions \
--enable-__cxa_atexit \
--enable-libssp \
--enable-lto \
--disable-install-libiberty \
--with-gnu-ld \
--verbose \
--with-arch-directory=$LIB_ARCH \
--program-suffix="-`echo $GCC_VERSION | cut -d. -f1`" \
--with-pkgversion="GDC $VERSION" \
$GCC_ARCHOPTS \
--target=${TARGET} \
--build=${TARGET} \
--host=${TARGET}
make
make install DESTDIR=$PKG
# Remove not D related stuff, already available in GCC
find $PKG/usr/info -type f -not -name "*gdc*" -delete
rm -r $PKG/usr/man/man7
rm -r $PKG/usr/share
#rm -r $PKG/usr/include
#find $PKG/usr/libexec/gcc \
# \( -type f -or -type l \) -not -name "cc1d" \
# -delete
#find $PKG/usr/lib$LIBDIRSUFFIX/gcc -mindepth 3 \
# \( -type f -or -type l \) -not -regex ".*/d/.*" \
# -delete
#find $PKG/usr/lib$LIBDIRSUFFIX -maxdepth 1 \
# \( -type f -or -type l \) \
# -not \( -name "*phobos*" -or -name "*gdruntime*" \) \
# -delete
(
cd $PKG/usr/lib$LIBDIRSUFFIX
rm -r python2.7 *.py *.o \
libasan.{a,la,so} \
libatomic.{a,la,so,so.1} \
libcc1.* libgcc_s.* libgomp.* libitm.* liblsan.* \
libquadmath.* libsanitizer.spec libssp* \
libstdc++fs.* libstdc++.{a,la,so,so.6} \
libsupc++.* libtsan.* \
libubsan.{a,la,so}
)
find $PKG/usr -type d -empty -delete
find $PKG -print0 | xargs -0 file | grep -e "executable" -e "shared object" | grep ELF \
| cut -f 1 -d : | xargs strip --strip-unneeded 2> /dev/null || true
find $PKG/usr/man -type f -exec gzip -9 {} \;
for i in $( find $PKG/usr/man -type l ) ; do ln -s $( readlink $i ).gz $i.gz ; rm $i ; done
gzip -9 $PKG/usr/info/*.info
mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
cp $TMP/$SRCNAM-$VERSION/README.md $PKG/usr/doc/$PRGNAM-$VERSION
cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
mkdir -p $PKG/install
cat $CWD/slack-desc > $PKG/install/slack-desc
cat $CWD/doinst.sh > $PKG/install/doinst.sh
cd $PKG
/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.${PKGTYPE:-tgz}