]> git.pld-linux.org Git - packages/rpm-build-tools.git/blobdiff - adapter.awk
spelling
[packages/rpm-build-tools.git] / adapter.awk
index 2859041357425d5c79b059de512dcb9491f992b7..4cef263c992e8ac97217fa2a0e10af484dc92955 100644 (file)
@@ -2,7 +2,7 @@
 #
 # Adapter adapts .spec files for PLD Linux.
 #
-# Copyright (C) 1999-2014 PLD-Team <feedback@pld-linux.org>
+# Copyright (C) 1999-2016 PLD-Team <feedback@pld-linux.org>
 # Authors:
 #      MichaƂ Kuratczyk <kura@pld.org.pl>
 #      Sebastian Zagrodzki <s.zagrodzki@mimuw.edu.pl>
@@ -239,6 +239,23 @@ function b_makekey(a, b,   s) {
                }
        }
 
+       # capture for URL unify in perl packages
+       if ($2 == "pdir") {
+               pdir = $3
+       }
+       if ($2 == "pnam") {
+               pnam = $3
+       }
+       if ($2 == "pkgname") {
+               pkgname = $3
+       }
+       if ($2 == "pkg") {
+               pkg = $3
+       }
+       if ($2 == "module") {
+               module = $3
+       }
+
        sub(/[ \t]+$/, "")
        # do nothing further, otherwise adapter thinks we're at preamble
        print
@@ -356,7 +373,7 @@ function b_makekey(a, b,    s) {
 ##########
 # %build #
 ##########
-/^%build/, (!/^%build/ && $0 ~ SECTIONS) {
+/^%build([^A-Za-z0-9_]|$)/, (!/^%build/ && $0 ~ SECTIONS) {
        preamble = 0
 
        if (did_prep == 0) {
@@ -456,6 +473,7 @@ function b_makekey(a, b,    s) {
        sub("^%{__rm} -rf %{buildroot}", "rm -rf $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
@@ -694,7 +712,7 @@ preamble == 1 {
                $0 = format_requires($1, value)
        }
 
-       # BR: tar (and others) are too common (rpm-build requires it)
+       # BR: tar (and others) are too common (rpm-build requires them)
        if (field == "buildrequires:") {
                l = substr($0, index($0, $2))
                if (l == "awk" ||
@@ -812,6 +830,9 @@ preamble == 1 {
                if (l == "MPLv1.1") {
                        l = "MPL v1.1"
                }
+               if (l == "Mozilla Public License, version 2.0") {
+                       l = "MPL v2.0"
+               }
                $0 = "License:\t" l
        }
 
@@ -848,10 +869,28 @@ preamble == 1 {
        if (field ~ /home-page:/)
                $1 = "URL:"
 
-       # proper caps
-       if (field ~ /^url:$/)
+       if (field ~ /^url:$/) {
+               # set proper caps
                $1 = "URL:"
 
+               # should not use these in URL field, for copy-paste
+               if (/%{pdir}/ || /%{pnam}/) {
+                       gsub(/%{pdir}/, pdir, $2);
+                       gsub(/%{pnam}/, pnam, $2);
+               }
+
+               if (/%{pkgname}/ && pkgname) {
+                       gsub(/%{pkgname}/, pkgname, $2);
+               }
+
+               if (/%{pkg}/ && pkg) {
+                       gsub(/%{pkg}/, pkg, $2);
+               }
+               if (/%{module}/ && module) {
+                       gsub(/%{module}/, module, $2);
+               }
+       }
+
        if (field ~ /^patch/)
                $1 = "Patch" substr(field, 6)
 
@@ -1121,6 +1160,11 @@ function use_macros()
        sub("%{_datadir}/doc", "%{_docdir}")
        sub("%{_bindir}/perl", "%{__perl}")
        sub("%{_bindir}/python", "%{__python}")
+       sub("%{__python2}", "%{__python}")
+       sub("%{nodejs_sitelib}", "%{nodejs_libdir}")
+
+       sub("%py2_build", "%py_build")
+       sub("%py2_install", "%py_install")
 
        gsub(infodir, "%{_infodir}")
 
@@ -1134,6 +1178,7 @@ function use_macros()
        gsub(py_sitescriptdir, "%{py_sitescriptdir}")
        gsub(py_sitedir, "%{py_sitedir}")
        gsub(py_scriptdir, "%{py_scriptdir}")
+       gsub("%{python2_sitelib}", "%{py_sitescriptdir}")
 
        gsub(py3_sitescriptdir, "%{py3_sitescriptdir}")
        gsub(py3_sitedir, "%{py3_sitedir}")
@@ -1289,6 +1334,8 @@ function use_macros()
        gsub(php_pear_dir, "%{php_pear_dir}")
        gsub(php_data_dir, "%{php_data_dir}")
        gsub("%{_datadir}/php", "%{php_data_dir}")
+       gsub("%{php_home}", "%{php_data_dir}")
+       gsub("%{php_extdir}", "%{php_extensiondir}")
 
        # change to %{_datadir}, with some exceptions
        for (c = 1; c <= NF; c++) {
@@ -1389,6 +1436,7 @@ function use_macros()
        gsub("%{ruby_sitearch}", "%{ruby_sitearchdir}")
        gsub("%{python_sitearch}", "%{py_sitedir}")
        gsub("%{python_sitelib}", "%{py_sitescriptdir}")
+       gsub("%{python2_sitearch}", "%{py_sitedir}")
 
        # alt linux
        gsub("%_man1dir", "%{_mandir}/man1")
@@ -1408,6 +1456,7 @@ function use_macros()
        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)
+       $0 = fixedsub("%{?buildroot}", "$RPM_BUILD_ROOT", $0)
        $0 = fixedsub("CXXFLAGS=%{rpmcflags} %configure", "CXXFLAGS=%{rpmcflags}\n%configure", $0)
        $0 = fixedsub("%__install", "install", $0)
 
@@ -1488,6 +1537,7 @@ function use_files_macros(        i, n, t, a, l)
        }
 
        sub("^%doc %{_mandir}", "%{_mandir}")
+       sub("^%license", "%doc")
 
        gsub("^%{_sbindir}", "%attr(755,root,root) %{_sbindir}")
        gsub("^%{_bindir}", "%attr(755,root,root) %{_bindir}")
@@ -1734,6 +1784,7 @@ function unify_url(url)
        if (url ~ /sourceforge.net/) {
                sub("[?&]big_mirror=.*$", "", url)
                sub("[?&]modtime=.*$", "", url)
+               sub("[?&]r=.*$", "", url)
                sub("[?]use_mirror=.*$", "", url)
                sub("[?]download$", "", url)
                sub("/download$", "", url)
@@ -2010,6 +2061,10 @@ function replace_php_virtual_deps(field) {
                }
        }
 
+       if (pkg == "php(language)") {
+               $2 = "php(core)"
+       }
+
        if (pkg == "php4") {
                $2 = "webserver(php)"
                if ($4 ~ /^[0-9]:/) {
@@ -2044,6 +2099,7 @@ function replace_groupnames(group) {
        group = replace(group, "Development/Libraries/Java", "Development/Languages/Java")
        group = replace(group, "Development/Libraries/Python", "Development/Languages/Python")
        group = replace(group, "Development/Libraries/TCL", "Development/Languages/Tcl")
+       group = replace(group, "Development/Libraries/X11", "X11/Development/Libraries")
        group = replace(group, "Development/Other", "Development")
        group = replace(group, "Development/Python", "Development/Languages/Python")
        group = replace(group, "Development/Testing", "Development")
@@ -2111,6 +2167,26 @@ function replace_pkgconfig(pkg,    cmd, path, n, i, line) {
 }
 # }}}
 
+# {{{ replace_perlmod(pkg)
+function replace_perlmod(pkg, version,   cmd, line) {
+       # do nothing if version is specified
+       if (version) {
+               return
+       }
+       cmd = "rpm -q --qf '%{N}\n' --whatprovides 'perl(" pkg ")' "
+
+       # Getline returns 0 on end-of-file, -1 on error, otherwise 1.
+       if ((cmd | getline line) <= 0) {
+               return
+       }
+
+       if (line !~ /no package provides/) {
+               # @modifies global $2
+               $2 = line
+               return
+       }
+}
+
 # {{{ replace_pythonegg(pkg)
 function replace_pythonegg(pkg,    cmd, line) {
        cmd = "rpm -q --qf '%{N}' --whatprovides 'pythonegg(" pkg ")'"
@@ -2128,6 +2204,11 @@ function replace_pythonegg(pkg,    cmd, line) {
 # }}}
 
 function replace_requires(field,   pkg) {
+       # strip %{?_isa}
+       if ($2 ~ /_isa/) {
+               $2 = fixedsub("%{?_isa}", "", $2);
+       }
+
        # pkg-config -> package names
        if (match($2, /pkgconfig\(([^)]+)\)/)) {
                pkg = substr($2, RSTART + 10, RLENGTH - 11)
@@ -2140,6 +2221,12 @@ function replace_requires(field,   pkg) {
                replace_pythonegg(pkg)
        }
 
+       # perl() -> package names
+       if (match($2, /perl\(([^)]+)\)/)) {
+               pkg = substr($2, RSTART + 5, RLENGTH - 6)
+               replace_perlmod(pkg, $3)
+       }
+
        sub(/^python-setuptools-devel$/, "python-distribute", $2)
        sub(/^gcc-g77/, "gcc-fortran", $2)
 
@@ -2240,6 +2327,7 @@ function replace_requires(field,   pkg) {
        sub(/^PyQwt-devel$/, "python-PyQwt-devel", $2)
        sub(/^PyYAML$/, "python-PyYAML", $2)
        sub(/^ccid$/, "pcsc-driver-ccid", $2)
+       sub(/^cdparanoia-devel$/, "cdparanoia-III-devel", $2)
        sub(/^chkconfig$/, "/sbin/chkconfig", $2)
        sub(/^db4-devel$/, "db-devel", $2)
        sub(/^dbus-python$/, "python-dbus", $2)
@@ -2248,6 +2336,7 @@ function replace_requires(field,   pkg) {
        sub(/^django-tagging$/, "python-django_tagging", $2)
        sub(/^elfutils-libelf-devel$/, "elfutils-devel", $2)
        sub(/^file-devel$/, "libmagic-devel", $2)
+       sub(/^firebird-devel$/, "Firebird-devel", $2)
        sub(/^freetype2-devel$/, "freetype-devel", $2)
        sub(/^fuse-devel$/, "libfuse-devel", $2)
        sub(/^gamin-python$/, "python-gamin", $2)
@@ -2266,7 +2355,9 @@ function replace_requires(field,   pkg) {
        sub(/^iproute$/, "iproute2", $2)
        sub(/^iptables-ipv6$/, "iptables", $2)
        sub(/^iscsi-initiator-utils$/, "open-iscsi", $2)
+       sub(/^kdelibs4-devel$/, "kde4-kdelibs-devel", $2)
        sub(/^keyutils-libs-devel$/, "keyutils-devel", $2)
+       sub(/^libICE-devel$/, "xorg-lib-libICE-devel", $2)
        sub(/^libSM-devel$/, "xorg-lib-libSM-devel", $2)
        sub(/^libX11-devel$/, "xorg-lib-libX11-devel", $2)
        sub(/^libXScrnSaver-devel$/, "xorg-lib-libXScrnSaver-devel", $2)
@@ -2276,7 +2367,9 @@ function replace_requires(field,   pkg) {
        sub(/^libXdamage-devel$/, "xorg-lib-libXdamage-devel", $2)
        sub(/^libXext-devel$/, "xorg-lib-libXext-devel", $2)
        sub(/^libXft-devel$/, "xorg-lib-libXft-devel", $2)
+       sub(/^libXi-devel$/, "xorg-lib-libXi-devel", $2)
        sub(/^libXinerama-devel$/, "xorg-lib-libXinerama-devel", $2)
+       sub(/^libXmu-devel$/, "xorg-lib-libXmu-devel", $2)
        sub(/^libXrandr-devel$/, "xorg-lib-libXrandr-devel", $2)
        sub(/^libXrender-devel$/, "xorg-lib-libXrender-devel", $2)
        sub(/^libXt-devel$/, "xorg-lib-libXt-devel", $2)
@@ -2285,9 +2378,11 @@ function replace_requires(field,   pkg) {
        sub(/^libXxf86misc-devel$/, "xorg-lib-libXxf86misc-devel", $2)
        sub(/^libXxf86vm-devel$/, "xorg-lib-libXxf86vm-devel", $2)
        sub(/^libacl-devel$/, "acl-devel", $2)
+       sub(/^libappstream-glib$/, "appstream-glib", $2)
        sub(/^libattr-devel$/, "attr-devel", $2)
        sub(/^libcurl-devel$/, "curl-devel", $2)
        sub(/^libgudev1-devel$/, "udev-glib-devel", $2)
+       sub(/^libicns-utils$/, "libicns", $2)
        sub(/^libmx-devel$/, "mx-devel", $2)
        sub(/^libselinux-python$/, "python-selinux", $2)
        sub(/^libsrtp-devel$/, "srtp-devel", $2)
@@ -2300,9 +2395,11 @@ function replace_requires(field,   pkg) {
        sub(/^libvirt-python$/, "python-libvirt", $2)
        sub(/^libxkbfile-devel$/, "xorg-lib-libxkbfile", $2)
        sub(/^libxml2-python$/, "python-libxml2", $2)
+       sub(/^m2crypto$/, "python-M2Crypto", $2)
        sub(/^mod_wsgi$/, "apache-mod_wsgi", $2)
        sub(/^newt-python$/, "python-snack", $2)
        sub(/^notify-python$/, "python-pynotify", $2)
+       sub(/^oxygen-icon-theme$/, "kde4-icons-oxygen", $2)
        sub(/^pcsc-lite-ccid$/, "pcsc-driver-ccid", $2)
        sub(/^pulseaudio-libs-devel$/, "pulseaudio-devel", $2)
        sub(/^pyOpenSSL$/, "python-pyOpenSSL", $2)
@@ -2311,35 +2408,47 @@ function replace_requires(field,   pkg) {
        sub(/^pygobject2$/, "python-pygobject", $2)
        sub(/^pygobject3$/, "python-pygobject3", $2)
        sub(/^pygobject3-devel$/, "python-pygobject3-common-devel", $2)
+       sub(/^pygpgme$/, "python-pygpgme", $2)
        sub(/^pygtk2$/, "python-pygtk", $2)
        sub(/^pygtk2-devel$/, "python-pygtk-devel", $2)
        sub(/^pygtk2-libglade$/, "python-pygtk-glade", $2)
        sub(/^pykickstart$/, "python-pykickstart", $2)
+       sub(/^pyliblzma$/, "python-pygpgme", $2)
        sub(/^pyparsing$/, "python-pyparsing", $2)
        sub(/^pyparted$/, "python-parted", $2)
+       sub(/^pyserial$/, "python-serial", $2)
        sub(/^pysvn$/, "python-pysvn", $2)
        sub(/^pytalloc$/, "python-talloc", $2)
        sub(/^pytalloc-devel$/, "python-talloc-devel", $2)
        sub(/^pytest$/, "python-pytest", $2)
+       sub(/^python-PyQt4-devel$/, "sip-PyQt4", $2)
        sub(/^python-crypto$/, "python-Crypto", $2)
        sub(/^python-cups$/, "python-pycups", $2)
        sub(/^python-enchant$/, "python-pyenchant", $2)
        sub(/^python-imaging$/, "python-PIL", $2)
        sub(/^python-imaging-tk$/, "python-PIL-tk", $2)
+       sub(/^python-ndg_httpsclient$/, "python-ndg-httpsclient", $2)
        sub(/^python-newt$/, "python-snack", $2)
        sub(/^python-pygtk$/, "python-pygtk-gtk", $2)
        sub(/^python-recaptcha-client$/, "python-recaptcha", $2)
-       sub(/^python-sphinx$/, "python-Sphinx", $2)
+       sub(/^python-sphinx$/, "sphinx-pdg", $2)
+       sub(/^python-sqlalchemy$/, "python-SQLAlchemy", $2)
        sub(/^python-twisted$/, "python-TwistedCore", $2)
        sub(/^python-twisted-core$/, "python-TwistedCore", $2)
        sub(/^python-twisted-names$/, "python-TwistedNames", $2)
+       sub(/^python-twisted-web$/, "python-TwistedWeb", $2)
        sub(/^python-unittest2$/, "python-modules", $2)
        sub(/^python-uuid$/, "python-modules", $2)
+       sub(/^python-xlib$/, "python-Xlib", $2)
+       sub(/^python-zope-interface$/, "Zope-Interface", $2)
+       sub(/^python-zope.component$/, "Zope-Component", $2)
+       sub(/^python-zope.interface$/, "Zope-Interface", $2)
        sub(/^python2-devel$/, "python-devel", $2)
        sub(/^pytz$/, "python-pytz", $2)
        sub(/^pyxdg$/, "python-pyxdg", $2)
        sub(/^qt4-devel$/, "qt4-build", $2)
        sub(/^qt4-webkit-devel$/, "QtWebKit-devel", $2)
+       sub(/^qtiocompressor-devel$/, "QtIOCompressor-devel", $2)
        sub(/^qtlockedfile-devel$/, "QtLockedFile-devel", $2)
        sub(/^qtsingleapplication-devel$/, "QtSingleApplication-devel", $2)
        sub(/^rpm-python$/, "python-rpm", $2)
@@ -2349,17 +2458,18 @@ function replace_requires(field,   pkg) {
        sub(/^urw-fonts$/, "fonts-Type1-urw", $2)
        sub(/^webkitgtk3-devel$/, "gtk-webkit3-devel", $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)
        # }}}
 
        # {{{ mandriva
+       sub(/^gnome-python-gconf$/, "python-gnome-gconf", $2)
+       sub(/^pygtk2.0$/, "python-pygtk-gtk", $2)
+       sub(/^python-curl$/, "python-pycurl", $2)
        sub(/^python-gobject-devel$/, "python-pygobject-devel", $2)
        sub(/^python-pyrex$/, "python-Pyrex", $2)
-       sub(/^webkitgtk-devel$/, "gtk-webkit-devel", $2)
-       sub(/^python-curl$/, "python-pycurl", $2)
        sub(/^python-webkitgtk$/, "python-pywebkitgtk", $2)
-       sub(/^pygtk2.0$/, "python-pygtk-gtk", $2)
-       sub(/^gnome-python-gconf$/, "python-gnome-gconf", $2)
+       sub(/^webkitgtk-devel$/, "gtk-webkit-devel", $2)
        # }}}
 
        # {{{ debian / ubuntu
@@ -2391,14 +2501,14 @@ function replace_requires(field,   pkg) {
        sub(/^libsndfile1-dev$/, "libsndfile-devel", $2)
        sub(/^libspeex-dev$/, "speex-devel", $2)
        sub(/^libssl-dev$/, "openssl-devel", $2)
+       sub(/^libudev$/, "udev-libs", $2)
        sub(/^libvorbis-dev$/, "libvorbis-devel", $2)
        sub(/^libxslt1-dev$/, "libxslt-devel", $2)
        sub(/^libxss-dev$/, "xorg-lib-libXScrnSaver-devel", $2)
        sub(/^mesa-common-dev$/, "OpenGL-devel", $2)
-       sub(/^libudev$/, "udev-libs", $2)
        sub(/^tcp_wrappers-devel$/, "libwrap-devel", $2)
-       sub(/^vala-tools$/, "vala", $2)
        sub(/^vala-devel$/, "vala", $2)
+       sub(/^vala-tools$/, "vala", $2)
        # }}}
 
        # {{{ altlinux
@@ -2415,7 +2525,6 @@ function replace_requires(field,   pkg) {
 
        # {{{ suse/opensuse
        sub(/^alsa-devel$/, "alsa-lib-devel", $2)
-       sub(/^libqt4-devel$/, "qt4-build, qt4-qmake, QtCore-devel", $2)
        sub(/^gtk-sharp2$/, "dotnet-gtk-sharp2", $2)
        sub(/^gtkmm2-devel$/, "gtkmm-devel", $2)
        sub(/^libexpat-devel$/, "expat-devel", $2)
@@ -2423,6 +2532,7 @@ function replace_requires(field,   pkg) {
        sub(/^libffms2-devel$/, "ffms2-devel", $2)
        sub(/^libopenssl-devel$/, "openssl-devel", $2)
        sub(/^libpulse-devel$/, "pulseaudio-devel", $2)
+       sub(/^libqt4-devel$/, "qt4-build, qt4-qmake, QtCore-devel", $2)
        sub(/^monodoc-core$/, "mono-monodoc", $2)
        sub(/^python-cairo$/, "python-pycairo", $2)
        sub(/^python-gobject$/, "python-pygobject", $2)
This page took 0.04444 seconds and 4 git commands to generate.