mirror of
https://gitlab.com/dslackw/slpkg.git
synced 2025-01-25 19:58:37 +01:00
Merge branch 'develop'
This commit is contained in:
commit
86a218e067
7 changed files with 63 additions and 7 deletions
|
@ -1,3 +1,10 @@
|
|||
3.4.3 - 19/05/2019
|
||||
Updated:
|
||||
- Update gen_repos_files.sh to version 1.94
|
||||
Fixed:
|
||||
- Downloader to recognise the char +
|
||||
- Build from sources with char + in name
|
||||
|
||||
3.4.2 - 23/01/2019
|
||||
Fixed:
|
||||
- Bugfixed delete build folder in network option
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
# slpkg 3.4.2
|
||||
# slpkg 3.4.3
|
||||
|
||||
Slpkg is a powerful software package manager that installs, updates, and removes packages on
|
||||
[Slackware](http://www.slackware.com/) based systems. It automatically computes dependencies and
|
||||
|
|
|
@ -78,7 +78,7 @@ class MetaData(object):
|
|||
|
||||
__all__ = "slpkg"
|
||||
__author__ = "dslackw"
|
||||
__version_info__ = (3, 4, 2)
|
||||
__version_info__ = (3, 4, 3)
|
||||
__version__ = "{0}.{1}.{2}".format(*__version_info__)
|
||||
__license__ = "GNU General Public License v3 (GPLv3)"
|
||||
__email__ = "d.zlatanidis@gmail.com"
|
||||
|
|
|
@ -26,6 +26,7 @@ import os
|
|||
import tarfile
|
||||
import subprocess
|
||||
|
||||
from slpkg.utils import Utils
|
||||
from slpkg.messages import Msg
|
||||
from slpkg.slack.slack_version import slack_ver
|
||||
from slpkg.__metadata__ import MetaData as _meta_
|
||||
|
@ -53,8 +54,7 @@ class Download(object):
|
|||
dwn_count = 1
|
||||
self._directory_prefix()
|
||||
for dwn in self.url:
|
||||
# get file name from url and fix passing char '+'
|
||||
self.file_name = dwn.split("/")[-1].replace("%2B", "+")
|
||||
self.file_name = Utils().fix_file_name(dwn.split("/")[-1])
|
||||
|
||||
if dwn.startswith("file:///"):
|
||||
source_dir = dwn[7:-7].replace(slack_ver(), "")
|
||||
|
|
|
@ -31,6 +31,7 @@ import tarfile
|
|||
import subprocess
|
||||
import multiprocessing
|
||||
|
||||
from slpkg.utils import Utils
|
||||
from slpkg.messages import Msg
|
||||
from slpkg.checksum import check_md5
|
||||
from slpkg.__metadata__ import MetaData as _meta_
|
||||
|
@ -44,6 +45,7 @@ class BuildPackage(object):
|
|||
def __init__(self, script, sources, path, auto):
|
||||
self.script = script
|
||||
self.sources = sources
|
||||
self._check_sources()
|
||||
self.path = path
|
||||
self.auto = auto
|
||||
self.meta = _meta_
|
||||
|
@ -89,7 +91,7 @@ class BuildPackage(object):
|
|||
src = src.replace("%20", " ")
|
||||
check_md5(self.sbo_md5[src], src)
|
||||
# copy source and fix passing char '+' from file name
|
||||
shutil.copy2(src.replace("%2B", "+"), self.path + self.prgnam)
|
||||
shutil.copy2(src, self.path + self.prgnam)
|
||||
os.chdir(self.path + self.prgnam)
|
||||
# change permissions
|
||||
subprocess.call("chmod +x {0}.SlackBuild".format(self.prgnam),
|
||||
|
@ -117,6 +119,14 @@ class BuildPackage(object):
|
|||
except KeyboardInterrupt: # (OSError, IOError):
|
||||
self.msg.pkg_not_found("\n", self.prgnam, "Wrong file", "\n")
|
||||
|
||||
def _check_sources(self):
|
||||
"""Fix filenames with char +
|
||||
"""
|
||||
new_sources = []
|
||||
for src in self.sources:
|
||||
new_sources.append(Utils().fix_file_name(src))
|
||||
self.sources = new_sources
|
||||
|
||||
def _create_md5_dict(self):
|
||||
"""Create md5 dictionary per source
|
||||
"""
|
||||
|
|
|
@ -92,6 +92,16 @@ class Utils(object):
|
|||
if line and not line.startswith("#"):
|
||||
return line
|
||||
|
||||
def fix_file_name(self, file_name):
|
||||
"""Get file name from url and fix passing char '+'
|
||||
"""
|
||||
if "%2b" in file_name:
|
||||
return file_name.replace("%2b", "+", 5)
|
||||
elif "%2B" in file_name:
|
||||
return file_name.replace("%2B", "+", 5)
|
||||
else:
|
||||
return file_name
|
||||
|
||||
def debug(self, test):
|
||||
"""Function used for print some stuff for debugging
|
||||
"""
|
||||
|
|
|
@ -28,7 +28,7 @@
|
|||
# ---------------------------------------------------------------------------
|
||||
cat <<"EOT"
|
||||
# -------------------------------------------------------------------#
|
||||
# $Id: gen_repos_files.sh,v 1.92 2014/07/31 20:27:53 root Exp root $ #
|
||||
# $Id: gen_repos_files.sh,v 1.94 2018/05/03 15:02:39 root Exp root $ #
|
||||
# -------------------------------------------------------------------#
|
||||
EOT
|
||||
|
||||
|
@ -36,7 +36,7 @@ EOT
|
|||
BASENAME=$( basename $0 )
|
||||
|
||||
# The script'""s revision number will be displayed in the RSS feed:
|
||||
REV=$( echo "$Revision: 1.92 $" | cut -d' ' -f2 )
|
||||
REV=$( echo "$Revision: 1.94 $" | cut -d' ' -f2 )
|
||||
|
||||
# The repository owner's defaults file;
|
||||
# you can override any of the default values in this file:
|
||||
|
@ -276,6 +276,7 @@ function addpkg {
|
|||
if [ "$FORCEPKG" == "yes" -o ! -f $LOCATION/$TXTFILE ]; then
|
||||
# This is a courtesy service:
|
||||
echo "--> Generating .txt file for $NAME"
|
||||
rm -f $LOCATION/$TXTFILE
|
||||
$COMPEXE -cd $PKG | tar xOf - install/slack-desc | sed -n '/^#/d;/:/p' > $LOCATION/$TXTFILE
|
||||
[ "$TOUCHUP" == "yes" ] && touch -r $PKG $LOCATION/$TXTFILE || touch -d "$UPDATEDATE" $LOCATION/$TXTFILE
|
||||
fi
|
||||
|
@ -303,6 +304,7 @@ function addpkg {
|
|||
SUGGESTS=$($COMPEXE -cd $PKG | tar xOf - install/slack-suggests 2>/dev/null|xargs -r )
|
||||
fi
|
||||
|
||||
rm -f $LOCATION/$METAFILE
|
||||
echo "PACKAGE NAME: $NAME" > $LOCATION/$METAFILE
|
||||
if [ -n "$DL_URL" ]; then
|
||||
echo "PACKAGE MIRROR: $DL_URL" >> $LOCATION/$METAFILE
|
||||
|
@ -360,6 +362,7 @@ function addman {
|
|||
# Determine the compression tool used for this package:
|
||||
COMPEXE=$( pkgcomp $PKG )
|
||||
|
||||
rm -f $LOCATION/$LSTFILE
|
||||
cat << EOF > $LOCATION/$LSTFILE
|
||||
++========================================
|
||||
||
|
||||
|
@ -402,6 +405,7 @@ function genmd5 {
|
|||
if [ "$FORCEMD5" == "yes" -o ! -f $LOCATION/$MD5FILE ]; then
|
||||
echo "--> Generating .md5 file for $NAME"
|
||||
(cd $LOCATION
|
||||
rm -f $MD5FILE
|
||||
md5sum $NAME > $MD5FILE
|
||||
)
|
||||
[ "$TOUCHUP" == "yes" ] && touch -r $PKG $LOCATION/$MD5FILE || touch -d "$UPDATEDATE" $LOCATION/$MD5FILE
|
||||
|
@ -455,6 +459,7 @@ function gen_filelist {
|
|||
LISTFILE=${2:-FILELIST.TXT}
|
||||
|
||||
( cd ${DIR}
|
||||
rm -f ${LISTFILE}
|
||||
cat <<EOT > ${LISTFILE}
|
||||
$UPDATEDATE
|
||||
|
||||
|
@ -605,6 +610,7 @@ function rss_changelog {
|
|||
# "+--------------------------+" then we just skip that.
|
||||
[ "$cline" == "+--------------------------+" ] && read cline
|
||||
PUBDATE=$(LC_ALL=C TZ=GMT date +"%a, %e %b %Y %H:%M:%S GMT" -d "$cline")
|
||||
rm -f ${RSSFILE}
|
||||
cat <<-_EOT_ > ${RSSFILE}
|
||||
<?xml version="1.0" encoding="iso-8859-1"?>
|
||||
<rss version="2.0">
|
||||
|
@ -734,6 +740,7 @@ run_repo() {
|
|||
done
|
||||
|
||||
# Make the changes visible:
|
||||
rm -f PACKAGES.TXT
|
||||
echo "PACKAGES.TXT; $UPDATEDATE" > PACKAGES.TXT
|
||||
echo "" >> PACKAGES.TXT
|
||||
if [ -n "$DL_URL" ]; then
|
||||
|
@ -742,12 +749,15 @@ run_repo() {
|
|||
cat .PACKAGES.TXT | grep -v "PACKAGE MIRROR: " >> PACKAGES.TXT
|
||||
fi
|
||||
rm -f .PACKAGES.TXT
|
||||
rm -f MANIFEST
|
||||
cat .MANIFEST > MANIFEST
|
||||
rm -f .MANIFEST
|
||||
|
||||
rm -f PACKAGES.TXT.gz MANIFEST.bz2
|
||||
bzip2 -9f MANIFEST
|
||||
gzip -9cf PACKAGES.TXT > PACKAGES.TXT.gz
|
||||
if [ "${CHANGELOG}" == "yes" -a -f ChangeLog.txt ]; then
|
||||
rm -f ChangeLog.txt.gz
|
||||
gzip -9cf ChangeLog.txt > ChangeLog.txt.gz
|
||||
fi
|
||||
|
||||
|
@ -789,6 +799,7 @@ EOF
|
|||
else
|
||||
find . -type f -print $PRUNES | grep -v CHECKSUMS | sort | xargs md5sum $1 2>/dev/null >> .CHECKSUMS.md5
|
||||
fi
|
||||
rm -f CHECKSUMS.md5 CHECKSUMS.md5.gz
|
||||
cat .CHECKSUMS.md5 > CHECKSUMS.md5
|
||||
gzip -9cf CHECKSUMS.md5 > CHECKSUMS.md5.gz
|
||||
|
||||
|
@ -871,19 +882,37 @@ else
|
|||
rm -f $TESTTMP
|
||||
exit 1
|
||||
else
|
||||
# Use the key fingerprint to determine whether GPG-KEY is outdated:
|
||||
GPG_FPR=$($GPGBIN --with-colon --with-fingerprint --list-keys "$REPOSOWNERGPG" |grep ^fpr |cut -d: -f10)
|
||||
if [ -r ${REPOSROOT}/GPG-KEY ]; then
|
||||
# If the GPG-KEY file is outdated (user may have a new key),
|
||||
# then we delete this file and re-generate it in the next step:
|
||||
if ! grep -q $GPG_FPR ${REPOSROOT}/GPG-KEY ; then
|
||||
rm -f ${REPOSROOT}/GPG-KEY
|
||||
fi
|
||||
fi
|
||||
if [ ! -r ${REPOSROOT}/GPG-KEY ]; then
|
||||
echo "Generating a "GPG-KEY" file in '$REPOSROOT',"
|
||||
echo " containing the public key information for '$REPOSOWNERGPG'..."
|
||||
$GPGBIN --list-keys "$REPOSOWNERGPG" > ${REPOSROOT}/GPG-KEY
|
||||
echo "Key fingerprint: $GPG_FPR" >> ${REPOSROOT}/GPG-KEY
|
||||
$GPGBIN -a --export "$REPOSOWNERGPG" >> ${REPOSROOT}/GPG-KEY
|
||||
chmod 444 ${REPOSROOT}/GPG-KEY
|
||||
fi
|
||||
if [ -n "$REPO_SUBDIRS" ]; then
|
||||
for SUBDIR in $REPO_SUBDIRS ; do
|
||||
if [ -r ${REPOSROOT}}/${SUBDIR}/GPG-KEY ]; then
|
||||
# If the GPG-KEY file is outdated (user may have a new key),
|
||||
# then we delete this file and re-generate it in the next step:
|
||||
if ! grep -q $GPG_FPR ${REPOSROOT}}/${SUBDIR}/GPG-KEY ; then
|
||||
rm -f ${REPOSROOT}}/${SUBDIR}/GPG-KEY
|
||||
fi
|
||||
fi
|
||||
if [ ! -r ${REPOSROOT}/${SUBDIR}/GPG-KEY ]; then
|
||||
echo "Generating a "GPG-KEY" file in '$REPOSROOT/$SUBDIR',"
|
||||
echo " containing the public key information for '$REPOSOWNERGPG'."
|
||||
$GPGBIN --list-keys "$REPOSOWNERGPG" > $REPOSROOT/$SUBDIR/GPG-KEY
|
||||
echo "Key fingerprint: $GPG_FPR" >> $REPOSROOT/$SUBDIR/GPG-KEY
|
||||
$GPGBIN -a --export "$REPOSOWNERGPG" >> $REPOSROOT/$SUBDIR/GPG-KEY
|
||||
chmod 444 ${REPOSROOT}/${SUBDIR}/GPG-KEY
|
||||
fi
|
||||
|
|
Loading…
Add table
Reference in a new issue