#
# Adapter adapts .spec files for PLD Linux.
#
-# Copyright (C) 1999-2017 PLD-Team <feedback@pld-linux.org>
+# Copyright (C) 1999-2021 PLD-Team <feedback@pld-linux.org>
# Authors:
# MichaĆ Kuratczyk <kura@pld.org.pl>
# Sebastian Zagrodzki <s.zagrodzki@mimuw.edu.pl>
RPM_SECTIONS = "package|build|changelog|clean|description|install|post|posttrans|postun|pre|prep|pretrans|preun|triggerin|triggerpostun|triggerun|verifyscript|check"
SECTIONS = "^%(" RPM_SECTIONS ")"
- VERSION="1.514"
+ VERSION="1.515"
PREAMBLE_TAGS = "(R|BR|Summary|Name|Version|Release|Epoch|License|Group|URL|BuildArch|BuildRoot|Obsoletes|Conflicts|Provides|ExclusiveArch|ExcludeArch|Pre[Rr]eq|(Build)?Requires|Suggests|Auto(Req|Prov))"
/^%package/, (!/^%package/ && $0 ~ SECTIONS) {
# FIXME: this breaks \t indenting in preamble?
gsub(/\t/, " ")
+
+ sub(/%{python3_pkgversion}/, "3", $2)
}
################
}
# invalid in %prep
- sub("^rm -rf \$RPM_BUILD_ROOT.*", "")
+ sub("^rm -rf \\$RPM_BUILD_ROOT.*", "")
}
##########
sub("^%{__rm} -rf %{buildroot}", "rm -rf $RPM_BUILD_ROOT")
sub("%buildroot", "$RPM_BUILD_ROOT")
sub("%{buildroot}", "$RPM_BUILD_ROOT")
- sub("%{\?buildroot}", "$RPM_BUILD_ROOT")
+ sub("%{\\?buildroot}", "$RPM_BUILD_ROOT")
if (/^[ \t]*rm([ \t]+-[rf]+)*[ \t]+(\${?RPM_BUILD_ROOT}?|%{?buildroot}?)/ && did_rmroot==0) {
did_rmroot=1
}
if (!/%{_lib}/) {
- sub("\$RPM_BUILD_ROOT/%", "$RPM_BUILD_ROOT%")
+ sub("\\$RPM_BUILD_ROOT/%", "$RPM_BUILD_ROOT%")
}
use_macros()
preamble = 0
if (gsub("/usr/sbin/useradd", "%useradd")) {
- sub(" 2> /dev/null \|\| :", "")
- sub(" >/dev/null 2>&1 \|\|:", "")
+ sub(" 2> /dev/null \\|\\| :", "")
+ sub(" >/dev/null 2>&1 \\|\\|:", "")
}
# fedora extras macros
if (/%__fe_useradd/) {
sub("%__fe_useradd", "%useradd -u ")
- sub(" 2> /dev/null \|\| :", "")
- sub(" >/dev/null 2>&1 \|\|:", "")
+ sub(" 2> /dev/null \\|\\| :", "")
+ sub(" >/dev/null 2>&1 \\|\\|:", "")
sub(" &>/dev/null \\|\\| :", "")
}
sub("update-desktop-database &> /dev/null \\|\\| :", "%update_desktop_database")
sub("touch --no-create %{_datadir}/icons/hicolor", "%update_icon_cache_post hicolor")
- sub("if \\[ -x %{_bindir}/gtk-update-icon-cache \\]; then\n\t%{_bindir}/gtk-update-icon-cache -q %{_datadir}/icons/hicolor \|\| :\nfi", "")
+ sub("if \\[ -x %{_bindir}/gtk-update-icon-cache \\]; then\n\t%{_bindir}/gtk-update-icon-cache -q %{_datadir}/icons/hicolor \\|\\| :\nfi", "")
sub("export GCONF_CONFIG_SOURCE=`gconftool-2 --get-default-source`", "")
if (/gconftool-2 --makefile-install-rule/) {
next
}
- replace_requires(field)
+ replace_requires()
+ }
+
+ if (field ~ /triggerpostun/) {
+ # rpm 4.16 does not have Requires(triggerpostun):
+ sub(/triggerpostun/, "post", $1)
}
if (field == "requires:" || field ~ /^requires\(/ || field == "suggests:") {
- replace_requires(field)
+ replace_requires()
}
continue
if ($c ~ sysconfdir "/apm")
continue
- if ($c ~ sysconfdir "/modules-load\.d")
+ if ($c ~ sysconfdir "/modules-load\\.d")
continue
gsub(sysconfdir, "%{_sysconfdir}", $c)
}
gsub("%optflags", "%{rpmcflags}")
gsub("%{compat_perl_vendorarch}", "%{perl_vendorarch}")
- gsub("^%{__make} install DESTDIR=\$RPM_BUILD_ROOT", "%{__make} install \\\n\tDESTDIR=$RPM_BUILD_ROOT")
+ gsub("^%{__make} install DESTDIR=\\$RPM_BUILD_ROOT", "%{__make} install \\\n\tDESTDIR=$RPM_BUILD_ROOT")
gsub("^fix-info-dir$", "[ ! -x /usr/sbin/fix-info-dir ] || /usr/sbin/fix-info-dir -c %{_infodir} >/dev/null 2>\\&1")
$0 = fixedsub("%buildroot", "$RPM_BUILD_ROOT", $0)
$0 = fixedsub("%{buildroot}", "$RPM_BUILD_ROOT", $0)
}
# replace back
- gsub("%{_sysconfdir}/cron\.d", "/etc/cron.d")
- gsub("%{_sysconfdir}/crontab\.d", "/etc/crontab.d")
- gsub("%{_sysconfdir}/logrotate\.d", "/etc/logrotate.d")
- gsub("%{_sysconfdir}/pam\.d", "/etc/pam.d")
- gsub("%{_sysconfdir}/profile\.d", "/etc/profile.d")
- gsub("%{_sysconfdir}/rc\.d", "/etc/rc.d")
+ gsub("%{_sysconfdir}/cron\\.d", "/etc/cron.d")
+ gsub("%{_sysconfdir}/crontab\\.d", "/etc/crontab.d")
+ gsub("%{_sysconfdir}/logrotate\\.d", "/etc/logrotate.d")
+ gsub("%{_sysconfdir}/pam\\.d", "/etc/pam.d")
+ gsub("%{_sysconfdir}/profile\\.d", "/etc/profile.d")
+ gsub("%{_sysconfdir}/rc\\.d", "/etc/rc.d")
gsub("%{_sysconfdir}/security", "/etc/security")
gsub("%{_sysconfdir}/skel", "/etc/skel")
gsub("%{_sysconfdir}/sysconfig", "/etc/sysconfig")
}
if (/%{_mandir}/) {
- gsub("\.gz$", "*")
+ gsub("\\.gz$", "*")
gsub("%ext_man$", "*")
}
function use_script_macros()
{
if (gsub("/sbin/service", "%service")) {
- sub(" >/dev/null 2>&1 \|\|:", "")
- sub(" 2> /dev/null \|\| :", "")
+ sub(" >/dev/null 2>&1 \\|\\|:", "")
+ sub(" 2> /dev/null \\|\\| :", "")
}
}
}
if (!/!\?debug/)
- sub("\$RPM_OPT_FLAGS", "%{rpmcflags}")
+ sub("\\$RPM_OPT_FLAGS", "%{rpmcflags}")
return 1
}
sub("#.*", "", url)
# 1. unify domains
- sub("^http://prdownloads\.sourceforge\.net/", "http://downloads.sourceforge.net/", url)
- sub("^http://download\.sf\.net/", "http://downloads.sourceforge.net/", url)
- sub("^http://download\.sourceforge\.net/", "http://downloads.sourceforge.net/", url)
- sub("^http://dl\.sourceforge\.net/", "http://downloads.sourceforge.net/", url)
- sub("^http://.*\.dl\.sourceforge\.net/", "http://downloads.sourceforge.net/", url)
- sub("^http://dl\.sf\.net/", "http://downloads.sourceforge.net/", url)
- sub("^http://downloads\.sourceforge\.net/sourceforge/", "http://downloads.sourceforge.net/", url)
+ sub("^http://prdownloads\\.sourceforge\\.net/", "http://downloads.sourceforge.net/", url)
+ sub("^http://download\\.sf\\.net/", "http://downloads.sourceforge.net/", url)
+ sub("^http://download\\.sourceforge\\.net/", "http://downloads.sourceforge.net/", url)
+ sub("^http://dl\\.sourceforge\\.net/", "http://downloads.sourceforge.net/", url)
+ sub("^http://.*\\.dl\\.sourceforge\\.net/", "http://downloads.sourceforge.net/", url)
+ sub("^http://dl\\.sf\\.net/", "http://downloads.sourceforge.net/", url)
+ sub("^http://downloads\\.sourceforge\\.net/sourceforge/", "http://downloads.sourceforge.net/", url)
# 3. unify urls
if (url ~ /sourceforge.net/) {
url = sprintf("http://downloads.sourceforge.net/%s/%s", substr(url, 42, RLENGTH - 41), matchstr(url, "[^/]+$"))
}
- sub("^ftp://ftp\.gnome\.org/", "http://ftp.gnome.org/", url)
- sub("^http://ftp\.gnome\.org/pub/gnome/", "http://ftp.gnome.org/pub/GNOME/", url)
+ sub("^ftp://ftp\\.gnome\\.org/", "http://ftp.gnome.org/", url)
+ sub("^http://ftp\\.gnome\\.org/pub/gnome/", "http://ftp.gnome.org/pub/GNOME/", url)
# apache urls
sub("^http://apache.zone-h.org/", "http://www.apache.org/dist/", url)
# gnu.org
- sub("^ftp://ftp\.gnu\.org/", "http://ftp.gnu.org/", url)
- sub("^http://ftp\.gnu\.org/pub/gnu/", "http://ftp.gnu.org/gnu/", url)
+ sub("^ftp://ftp\\.gnu\\.org/", "http://ftp.gnu.org/", url)
+ sub("^http://ftp\\.gnu\\.org/pub/gnu/", "http://ftp.gnu.org/gnu/", url)
# debian.org
- sub("^ftp://ftp\.[^.]+\.debian\.org/", "ftp://ftp.debian.org/", url)
- sub("^http://ftp\.[^.]+\.debian\.org/", "ftp://ftp.debian.org/", url)
- sub("^ftp://ftp\.debian\.org/pub/debian/", "ftp://ftp.debian.org/debian/", url)
+ sub("^ftp://ftp\\.[^.]+\\.debian\\.org/", "ftp://ftp.debian.org/", url)
+ sub("^http://ftp\\.[^.]+\\.debian\\.org/", "ftp://ftp.debian.org/", url)
+ sub("^ftp://ftp\\.debian\\.org/pub/debian/", "ftp://ftp.debian.org/debian/", url)
return url
}
# freetype = 2.0.0 -> correct
# freetype = 2.1.9 -> with epoch 1, as epoch 1 was added in 2.1.7
- shell = "grep -o '^" pkg ":[^:]\+' ../PLD-doc/BuildRequires.txt | awk '{print $NF}'"
+ shell = "grep -o '^" pkg ":[^:]\\+' ../PLD-doc/BuildRequires.txt | awk '{print $NF}'"
shell | getline epoch
return epoch
}
# }}}
# {{{ replace_requires
-function replace_requires(field, pkg) {
+function replace_requires(pkg) { # "pkg' is local variable, not an argument
# strip %{?_isa}
if ($2 ~ /_isa/) {
$2 = fixedsub("%{?_isa}", "", $2);
sub(/^mod_wsgi$/, "apache-mod_wsgi", $2)
sub(/^newt-python$/, "python-snack", $2)
sub(/^notify-python$/, "python-pynotify", $2)
+ sub(/^numpy$/, "python-numpy", $2)
+ sub(/^opencv-python$/, "python-opencv", $2)
sub(/^oxygen-icon-theme$/, "kde4-icons-oxygen", $2)
sub(/^pcsc-lite-ccid$/, "pcsc-driver-ccid", $2)
+ sub(/^protobuf-python$/, "python-protobuf", $2)
sub(/^pulseaudio-libs-devel$/, "pulseaudio-devel", $2)
sub(/^pyOpenSSL$/, "python-pyOpenSSL", $2)
sub(/^pycairo$/, "python-pycairo", $2)
sub(/^pyflakes$/, "python-pyflakes", $2)
+ sub(/^pygame$/, "python-pygame", $2)
sub(/^pygobject2$/, "python-pygobject", $2)
sub(/^pygobject3$/, "python-pygobject3", $2)
sub(/^pygobject3-devel$/, "python-pygobject3-common-devel", $2)
sub(/^qtlockedfile-devel$/, "QtLockedFile-devel", $2)
sub(/^qtsingleapplication-devel$/, "QtSingleApplication-devel", $2)
sub(/^rpm-python$/, "python-rpm", $2)
+ sub(/^scipy$/, "python-scipy", $2)
sub(/^sip-devel$/, "python-sip-devel", $2)
sub(/^tftp-server$/, "tftpdaemon", $2)
sub(/^tkinter$/, "python-tkinter", $2)
sub(/^urw-fonts$/, "fonts-Type1-urw", $2)
sub(/^webkitgtk3-devel$/, "gtk-webkit3-devel", $2)
+ sub(/^webkitgtk4$/, "gtk-webkit4", $2)
sub(/^xapian-bindings-python$/, "python-xapian", $2)
sub(/^xorg-x11-proto-devel$/, "xorg-proto-xproto-devel", $2)
sub(/^xorg-x11-server-sdk$/, "xorg-xserver-server-devel", $2)
sub(/^blkid-dev$/, "libblkid-devel", $2)
sub(/^ext2fs-dev$/, "e2fsprogs-devel", $2)
sub(/^libao-dev$/, "libao-devel", $2)
+ sub(/^libavahi-client-dev$/, "avahi-devel", $2)
sub(/^libboost-filesystem[0-9.]+-dev$/, "boost-devel", $2)
sub(/^libboost-program-options[0-9.]+-dev$/, "boost-devel", $2)
sub(/^libboost-regex[0-9.]+-dev$/, "boost-devel", $2)
sub(/^libboost-thread[0-9.]+-dev$/, "boost-devel", $2)
+ sub(/^libcups2-dev$/, "cups-devel", $2)
sub(/^libcurl4-openssl-dev$/, "curl-devel", $2)
sub(/^libdnet-dev$/, "libdnet-devel", $2)
sub(/^libesd0-dev$/, "esound-devel", $2)