]> git.pld-linux.org Git - packages/rpm-build-tools.git/blobdiff - adapter.awk
- update
[packages/rpm-build-tools.git] / adapter.awk
index afb716b2094a89ed878e3491ddc105e8da2a7e3d..fd5cd795d58d7945ffb3de339c0e2ca91cd30260 100644 (file)
@@ -2,7 +2,7 @@
 #
 # Adapter adapts .spec files for PLD Linux.
 #
-# Copyright (C) 1999-2010 PLD-Team <feedback@pld-linux.org>
+# Copyright (C) 1999-2011 PLD-Team <feedback@pld-linux.org>
 # Authors:
 #      MichaƂ Kuratczyk <kura@pld.org.pl>
 #      Sebastian Zagrodzki <s.zagrodzki@mimuw.edu.pl>
@@ -66,14 +66,16 @@ BEGIN {
        system("[ -d ../PLD-doc ] && cd ../PLD-doc && ([ -f BuildRequires.txt ] || cvs up BuildRequires.txt >/dev/null)");
 
        # Temporary file for changelog section
-       changelog_file = ENVIRON["HOME"] "/tmp/adapter.changelog"
+       changelog_file = mktemp("adapter.changelogXXXXXX")
 }
 
 # There should be a comment with CVS keywords on the first line of file.
 FNR == 1 {
-       if (!/# \$Revision:/)   # If this line is already OK?
+       if (!/^# \$[R]evision: .* \$, \$[D]ate: .* \$$/) {      # If this line is already OK?
                print "# $" "Revision:$, " "$" "Date:$" # No
-       else {
+               if ( /^#.*([rR]evision|[dD]ate)/ ) # There was something similar, but incorrect
+                        next
+       } else {
                print $0                                # Yes
                next            # It is enough for first line
        }
@@ -91,6 +93,12 @@ defattr == 1 {
        defattr = 0
 }
 
+# call mktemp(1) and return the value
+function mktemp(template, tmp) {
+   "mktemp " template | getline tmp
+   return tmp
+}
+
 function b_makekey(a, b,       s) {
        s = a "" b;
        # kill bcond
@@ -236,6 +244,22 @@ function b_makekey(a, b,   s) {
 
        if ($2 ~ /^mod_name$/)
                mod_name = $3
+       if ($2 ~ /^_?pearname$/)
+               pearname = $3
+       if ($2 ~ /^_class$/)
+               pear_class = $3
+       if ($2 ~ /^_subclass$/)
+               pear_subclass = $3
+
+       # kill the _class and _subclass pear macros
+       if ($2 == "_pearname" || $2 == "pearname") {
+               if (pear_class) {
+                       gsub("%{_class}", pear_class, $3);
+               }
+               if (pear_subclass) {
+                       gsub("%{_subclass}", pear_subclass, $3);
+               }
+       }
 
        sub(/[ \t]+$/, "");
        # do nothing further, otherwise adapter thinks we're at preamble
@@ -336,6 +360,11 @@ function b_makekey(a, b,   s) {
        }
        sub("^%patch ", "%patch0 ");
 
+       # fedora extras
+       if (/^%apply/) {
+               sub("^%apply -n", "%patch");
+       }
+
        # invalid in %prep
        sub("^rm -rf \$RPM_BUILD_ROOT.*", "");
 }
@@ -580,6 +609,19 @@ function b_makekey(a, b,   s) {
                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(" &>/dev/null \\|\\| :", "");
+       }
+
+       if (/%__fe_groupadd/) {
+               sub("%__fe_groupadd", "%groupadd -g ");
+               sub(" &>/dev/null \\|\\| :", "");
+       }
+
        # %useradd and %groupadd may not be wrapped
        if (/%(useradd|groupadd).*\\$/) {
                a = $0; getline;
@@ -591,6 +633,20 @@ function b_makekey(a, b,   s) {
 
 /^%post/, (!/^%post/ && $0 ~ SECTIONS) {
        preamble = 0
+
+       # fedora extras macros
+       sub("%__chkconfig", "/sbin/chkconfig");
+
+       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("export GCONF_CONFIG_SOURCE=`gconftool-2 --get-default-source`", "")
+       if (/gconftool-2 --makefile-install-rule/) {
+               sub("gconftool-2 --makefile-install-rule %{_sysconfdir}/gconf/schemas/", "%gconf_schema_install ")
+               sub("> /dev/null", "");
+       }
+
        use_macros()
 }
 /^%preun/, (!/^%preun/ && $0 ~ SECTIONS) {
@@ -599,6 +655,14 @@ function b_makekey(a, b,   s) {
 }
 /^%postun/, (!/^%postun/ && $0 ~ SECTIONS) {
        preamble = 0
+
+       # fedora extras macros
+       if (/%__fe_userdel|%__fe_groupdel/) {
+               sub("%__fe_groupdel", "%groupremove");
+               sub("%__fe_userdel", "%userremove");
+               sub(" &>/dev/null \\|\\| :", "");
+       }
+
        use_script_macros()
 }
 /^%triggerin/, (!/^%triggerin/ && $0 ~ SECTIONS) {
@@ -645,7 +709,6 @@ preamble == 1 {
        }
 
        field = tolower($1)
-       fieldnlower = $1
        if (field ~ /summary:/ && !/etc\.$/ && !/Inc\.$/) {
                sub(/\.$/, "", $0);
        }
@@ -685,7 +748,7 @@ preamble == 1 {
        }
 
        # split (build)requires, obsoletes on commas
-       if (field ~ /(obsoletes|requires|provides|conflicts):/ && NF > 2) {
+       if (field ~ /(obsoletes|requires|provides|conflicts|suggests):/ && NF > 2) {
                value = substr($0, index($0, $2));
                $0 = format_requires($1, value);
        }
@@ -741,6 +804,15 @@ preamble == 1 {
                $1 = "URL:"
        }
 
+       # suse
+       if (field ~ /recommends:/) {
+               $1 = "Suggests:"
+       }
+
+       if ($3 == "==" && $1 !~ /%/) {
+               $3 = "="
+       }
+
        if (field ~ /license:/) {
                l = substr($0, index($0, $2));
                if (l == "Python Software Foundation License") {
@@ -764,6 +836,12 @@ preamble == 1 {
                if (l == "GPLv2+") {
                        l = "GPL v2+"
                }
+               if (l == "GPL v2 or later") {
+                       l = "GPL v2+"
+               }
+               if (l == "LGPL v2.0 only") {
+                       l = "LGPL v2"
+               }
                if (l == "LGPLv2+") {
                        l = "LGPL v2+"
                }
@@ -773,6 +851,9 @@ preamble == 1 {
                if (l == "GPLv3+") {
                        l = "GPL v3+"
                }
+               if (l == "MPLv1.1") {
+                       l = "MPL v1.1"
+               }
                $0 = "License:\t" l;
        }
 
@@ -922,7 +1003,7 @@ preamble == 1 {
 #      so don't do that.
 # - comments leading the BR/R can not be associated,
 #      so don't adapterize when the BR/R are mixed with comments
-ENVIRON["SKIP_SORTBR"] != 1 && preamble == 1 && $0 ~ PREAMBLE_TAGS, $0 ~ PREAMBLE_TAGS {
+ENVIRON["SKIP_SORTBR"] != 1 && preamble == 1 && $0 ~ PREAMBLE_TAGS ":", $0 ~ PREAMBLE_TAGS ":"{
        if ($1 ~ /Pre[Rr]eq:/) {
                sub(/Pre[Rr]eq:/, "Requires:", $1);
        }
@@ -1094,8 +1175,10 @@ function use_macros()
        gsub(py_sitescriptdir, "%{py_sitescriptdir}")
        gsub(py_sitedir, "%{py_sitedir}")
        gsub(py_scriptdir, "%{py_scriptdir}")
-       gsub("%{_libdir}/python2.4/site-packages", "%{py_sitedir}")
-       gsub("%{python_sitelib}", "%{py_sitedir}")
+
+       gsub(py3_sitescriptdir, "%{py3_sitescriptdir}")
+       gsub(py3_sitedir, "%{py3_sitedir}")
+       gsub(py3_scriptdir, "%{py3_scriptdir}")
 
        gsub(ruby_archdir, "%{ruby_archdir}")
        gsub(ruby_ridir, "%{ruby_ridir}")
@@ -1111,6 +1194,9 @@ function use_macros()
        gsub("%{_libdir}/pkgconfig", "%{_pkgconfigdir}")
        gsub(pkgconfigdir, "%{_pkgconfigdir}")
 
+       gsub("%{_datadir}/pkgconfig", "%{_npkgconfigdir}")
+       gsub(npkgconfigdir, "%{_npkgconfigdir}")
+
        gsub(libdir, "%{_libdir}")
        gsub(javadir, "%{_javadir}")
 
@@ -1183,8 +1269,14 @@ function use_macros()
                        continue;
                if ($c ~ sysconfdir "/{?samba")
                        continue;
+               if ($c ~ sysconfdir "/{?xdg")
+                       continue;
                if ($c ~ sysconfdir "/shells")
                        continue;
+               if ($c ~ sysconfdir "/inittab")
+                       continue;
+               if ($c ~ sysconfdir "/init")
+                       continue;
                if ($c ~ sysconfdir "/ppp")
                        continue;
                if ($c ~ sysconfdir "/dbus-1")
@@ -1302,6 +1394,10 @@ function use_macros()
        # fedora
        gsub("%{ruby_sitearch}", "%{ruby_sitearchdir}")
        gsub("%{python_sitearch}", "%{py_sitedir}")
+       gsub("%{python_sitelib}", "%{py_sitescriptdir}")
+
+       # alt linux
+       gsub("%_man1dir", "%{_mandir}/man1")
 
        # mandrake specs
        gsub("^%make$", "%{__make}")
@@ -1322,7 +1418,9 @@ function use_macros()
        $0 = fixedsub("%__install", "install", $0);
 
        # split configure line to multiple lines
-       if (/%configure / && !/\\$/) {
+       if (/%configure +$/) {
+               sub( / +$/, "" );
+       } else if (/%configure / && !/\\$/) {
                $0 = format_configure($0);
        }
 
@@ -1352,6 +1450,15 @@ function use_macros()
 
        $0 = fixedsub("%(%{__cc} -dumpversion)", "%{cc_version}", $0);
        $0 = fixedsub("%(%{__cxx} -dumpversion)", "%{cxx_version}", $0);
+
+       # kill the _class and _subclass pear macros
+       if (pear_class) {
+               gsub("%{_class}", pear_class);
+       }
+       if (pear_subclass) {
+               gsub("%{_subclass}", pear_subclass);
+       }
+
 }
 
 function format_configure(line,                n, a, s) {
@@ -1432,7 +1539,7 @@ function use_files_macros(        i, n, t, a, l)
                }
        }
 
-       if (/lib.+\.so/ && !/\.so$/ && !/^%attr.*/ && !/%exclude/) {
+       if (/lib.+\.so\b/ && !/\.so$/ && !/^%attr.*/ && !/%exclude/) {
                $0 = "%attr(755,root,root) " $0
        }
 
@@ -1502,6 +1609,7 @@ function use_files_macros(        i, n, t, a, l)
 
        if (/%{_mandir}/) {
                gsub("\.gz$", "*")
+               gsub("%ext_man$", "*")
        }
 
        # locale dir and no %lang -> bad
@@ -1521,13 +1629,10 @@ function use_files_macros(      i, n, t, a, l)
                t = substr($0, 0, l);
                s = substr($0, l + 1, RLENGTH - l - length("-py"py_ver".egg-info"));
                if (match(s, "[^-]+$")) {
-#printf("s[%s]; start[%d]; length[%d]\n", s, RSTART, RLENGTH);
                        if (RSTART > 1) {
                                s = substr(s, 0, RSTART - 1);
                        }
-#printf("s2[%s]\n", s);
                        print "%if \"%{py_ver}\" > \"2.4\""
-#print t "/.+.egg-info"
                        gsub(t "/.+.egg-info", t "/" s "-*.egg-info");
                        print
                        print "%endif"
@@ -1610,11 +1715,20 @@ function cflags(var)
        return 1
 }
 
+# return whole matched pattern
+function matchstr(str, pat)
+{
+       match(str, "[^/]+$");
+       return substr(str, RSTART, RLENGTH);
+}
+
 function unify_url(url)
 {
 
        # sourceforge urls
        # Docs about sourceforge mirror system: http://sourceforge.net/apps/trac/sourceforge/wiki/Mirrors
+
+       # 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)
@@ -1622,11 +1736,8 @@ function unify_url(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)
-       # new style urls, strip "files/" between and prepend dl.
-       if (match(url, "^http://sourceforge.net/projects/[^/]+/files/")) {
-               url = substr(url, 1, RLENGTH - length("files/")) substr(url, RSTART + RLENGTH);
-               sub("^http://sourceforge.net/projects/", "http://downloads.sourceforge.net/project/", url);
-       }
+
+       # 3. unify urls
        if (url ~ /sourceforge.net/) {
                sub("[?&]big_mirror=.*$", "", url);
                sub("[?&]modtime=.*$", "", url);
@@ -1635,6 +1746,18 @@ function unify_url(url)
                sub("/download$", "", url);
        }
 
+       # SF: new style urls, strip "files/" between and prepend dl.
+       if (match(url, "^http://sourceforge.net/projects/[^/]+/files/")) {
+               url = substr(url, 1, RLENGTH - length("files/")) substr(url, RSTART + RLENGTH);
+               sub("^http://sourceforge.net/projects/", "http://downloads.sourceforge.net/project/", url);
+       }
+
+       # SF unify: http://downloads.sourceforge.net/PROJECT/TARBALL
+       # http://downloads.sourceforge.net/project/PROJECT/FILE/VERSION/%{name}-%{version}.zip
+       if (match(url, "^http://downloads.sourceforge.net/project/[^/]+")) {
+               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)
 
@@ -1642,8 +1765,13 @@ function unify_url(url)
        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)
 
        return url
 }
@@ -1653,6 +1781,12 @@ function demacroize(str)
        if (mod_name) {
                sub("%{mod_name}", mod_name, str);
        }
+       if (pearname) {
+               sub("%{_pearname}", pearname, str);
+       }
+       if (pearname) {
+               sub("%{pearname}", pearname, str);
+       }
        if (name) {
                sub("%{name}", name, str);
        }
@@ -1688,6 +1822,16 @@ function kill_preamble_macros()
                $2 = demacroize($2);
                $2 = unify_url($2)
        }
+
+       # fedora extras
+       if (/%{\?FE_USERADD_REQ}/) {
+               $0 = "";
+               print "BuildRequires:   rpmbuild(macros) >= 1.202"
+               print "Provides:        user(xxx)"
+               print "Requires(postun):        /usr/sbin/userdel"
+               print "Requires(pre):  /bin/id"
+               print "Requires(pre):  /usr/sbin/useradd"
+       }
 }
 
 function get_epoch(pkg, ver,   epoch)
@@ -1741,7 +1885,6 @@ function add_br(br)
        BR[BR_count++] = br
 }
 
-
 # Load rpm macros
 # you should update the list also in adapter when making changes here
 function import_rpm_macros() {
@@ -1754,7 +1897,8 @@ function import_rpm_macros() {
                exit(rc = 1);
        }
 
-       if (!ENVIRON["ADAPTER_REVISION"] || ENVIRON["ADAPTER_REVISION"] < 1.44) {
+       # update this version dep each time some new macro export is added
+       if (!ENVIRON["ADAPTER_REVISION"] || ENVIRON["ADAPTER_REVISION"] < 1.47) {
                print "adapter shell script is outdated, please cvs up it" > "/dev/stderr"
                do_not_touch_anything = 1
                exit(rc = 1);
@@ -1782,6 +1926,7 @@ function import_rpm_macros() {
        pixmapsdir = ENVIRON["_pixmapsdir"]
        javadir = ENVIRON["_javadir"]
        pkgconfigdir = ENVIRON["_pkgconfigdir"]
+       npkgconfigdir = ENVIRON["_npkgconfigdir"]
 
        perl_sitearch = ENVIRON["perl_sitearch"]
        perl_archlib = ENVIRON["perl_archlib"]
@@ -1795,6 +1940,11 @@ function import_rpm_macros() {
        py_scriptdir = ENVIRON["py_scriptdir"]
        py_ver = ENVIRON["py_ver"]
 
+       py3_sitescriptdir = ENVIRON["py3_sitescriptdir"]
+       py3_sitedir = ENVIRON["py3_sitedir"]
+       py3_scriptdir = ENVIRON["py3_scriptdir"]
+       py3_ver = ENVIRON["py3_ver"]
+
        ruby_archdir = ENVIRON["ruby_archdir"]
        ruby_ridir = ENVIRON["ruby_ridir"]
        ruby_rubylibdir = ENVIRON["ruby_rubylibdir"]
@@ -1807,7 +1957,6 @@ function import_rpm_macros() {
        tmpdir = ENVIRON["tmpdir"]
 }
 
-
 # php virtual deps as discussed in devel-en
 function replace_php_virtual_deps() {
        pkg = $2
@@ -1837,93 +1986,6 @@ function replace_php_virtual_deps() {
        }
 }
 
-function replace_requires() {
-
-       # jpackages
-       sub(/^java-devel$/, "jdk", $2);
-       sub(/^log4j$/, "java-log4j", $2);
-       sub(/^logging-log4j$/, "java-log4j", $2);
-       sub(/^jakarta-log4j$/, "java-log4j", $2);
-       sub(/^oro$/, "java-oro", $2);
-       sub(/^jakarta-oro$/, "java-oro", $2);
-       sub(/^jakarta-ant$/, "ant", $2);
-       sub(/^xerces-j2$/, "java-xerces", $2);
-       sub(/^xerces-j$/, "java-xerces", $2);
-       sub(/^ldapjdk$/, "ldapsdk", $2);
-       sub(/^saxon-scripts$/, "saxon", $2);
-       sub(/^xalan-j2$/, "java-xalan", $2);
-       sub(/^xalan-j$/, "java-xalan", $2);
-       sub(/^gnu-regexp$/, "java-gnu-regexp", $2);
-       sub(/^gnu.regexp$/, "java-gnu-regexp", $2);
-       sub(/^jakarta-commons-httpclient$/, "java-commons-httpclient", $2);
-       sub(/^xml-commons-resolver$/, "java-xml-commons-resolver", $2);
-       sub(/^axis$/, "java-axis", $2);
-       sub(/^wsdl4j$/, "java-wsdl4j", $2);
-       sub(/^uddi4j$/, "java-uddi4j", $2);
-       sub(/^hamcrest$/, "java-hamcrest", $2);
-       sub(/^jaas$/, "java(jaas)", $2);
-       sub(/^jaf$/, "java(jaf)", $2);
-       sub(/^jaxp$/, "java(jaxp)", $2);
-       sub(/^jaxp_parser_impl$/, "java(jaxp_parser_impl)", $2);
-       sub(/^jce$/, "java(jce)", $2);
-       sub(/^jdbc-stdext$/, "java(jdbc-stdext)", $2);
-       sub(/^jmx$/, "java(jmx)", $2);
-       sub(/^jndi$/, "java(jndi)", $2);
-       sub(/^jsse$/, "java(jsse)", $2);
-       sub(/^javamail$/, "java(javamail)", $2);
-
-       # redhat virtual
-       sub(/^tftp-server$/, "tftpdaemon", $2);
-
-       sub(/^gcc-c\+\+$/, "libstdc++-devel", $2);
-       sub(/^chkconfig$/, "/sbin/chkconfig", $2);
-
-       # fedora
-       sub(/^iscsi-initiator-utils$/, "open-iscsi", $2);
-       sub(/^gnome-python2-extras$/, "python-gnome-extras", $2);
-       sub(/^gnome-python2-gtkspell$/, "python-gnome-extras-gtkspell", $2);
-       sub(/^gtk2$/, "gtk+2", $2);
-       sub(/^gtk2-devel$/, "gtk+2-devel", $2);
-       sub(/^pygtk2-devel$/, "python-pygtk-devel", $2);
-       sub(/^pygtk2$/, "python-pygtk", $2);
-       sub(/^qt4-devel$/, "qt4-build", $2);
-       sub(/^file-devel$/, "libmagic-devel", $2);
-       sub(/^gamin-python$/, "python-gamin", $2);
-       sub(/^pygobject2$/, "python-pygobject", $2);
-       sub(/^tkinter$/, "python-tkinter", $2);
-       sub(/^python-imaging$/, "python-PIL", $2);
-       sub(/^python-imaging-tk$/, "python-PIL-tk", $2);
-       sub(/^initscripts$/, "rc-scripts", $2);
-       sub(/^libXft-devel$/, "xorg-lib-libXft-devel", $2);
-       sub(/^dbus-python$/, "python-dbus", $2);
-       sub(/^python-pygtk$/, "python-pygtk-gtk", $2);
-       sub(/^notify-python$/, "python-pynotify", $2);
-
-       # debian
-       sub(/^libgconf2-dev$/, "GConf2-devel", $2);
-       sub(/^libglib2.0-dev$/, "glib2-devel", $2);
-       sub(/^libgtk2.0-dev$/, "gtk+2-devel", $2);
-       sub(/^libhunspell-dev$/, "hunspell-devel", $2);
-       sub(/^libpango1.0-dev$/, "pango-devel", $2);
-       sub(/^libxslt1-dev$/, "libxslt-devel", $2);
-       sub(/^libgl1-mesa-dev$/, "OpenGL-devel", $2);
-       sub(/^mesa-common-dev$/, "OpenGL-devel", $2);
-       sub(/^libgl1-mesa-dri$/, "OpenGL", $2);
-       sub(/^libglu1-mesa-dev$/, "OpenGL-GLU-devel", $2);
-       sub(/^libxss-dev$/, "xorg-lib-libXScrnSaver-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(/^libmcrypt-dev$/, "libmcrypt-devel", $2);
-       sub(/^libcurl4-openssl-dev$/, "curl-devel", $2);
-       sub(/^libmhash-dev$/, "mhash-devel", $2);
-       sub(/^libqt4-dev$/, "qt4-build", $2);
-       sub(/^libssl-dev$/, "openssl-devel", $2);
-
-       replace_php_virtual_deps()
-}
-
 function replace_groupnames(group) {
        group = replace(group, "Amusements/Games", "Applications/Games");
        group = replace(group, "Amusements/Games/Strategy/Real Time", "X11/Applications/Games/Strategy");
@@ -1934,12 +1996,15 @@ function replace_groupnames(group) {
        group = replace(group, "Applications/Internet", "Applications/Networking");
        group = replace(group, "Applications/Internet/Peer to Peer", "Applications/Networking");
        group = replace(group, "Applications/Productivity", "X11/Applications");
+       group = replace(group, "Applications/Security", "Applications/System");
+       group = replace(group, "Applications/Web", "Applications/WWW");
        group = replace(group, "Database", "Applications/Databases");
        group = replace(group, "Development/C", "Development/Libraries");
        group = replace(group, "Development/Code Generators", "Development");
        group = replace(group, "Development/Docs", "Documentation");
        group = replace(group, "Development/Documentation", "Documentation");
        group = replace(group, "Development/Java", "Development/Languages/Java");
+       group = replace(group, "Development/Languages/C and C++", "Libraries");
        group = replace(group, "Development/Languages/Other", "Development/Languages");;
        group = replace(group, "Development/Languages/Ruby", "Development/Languages");
        group = replace(group, "Development/Libraries/C and C++", "Development/Libraries");
@@ -1949,12 +2014,16 @@ function replace_groupnames(group) {
        group = replace(group, "Development/Other", "Development");
        group = replace(group, "Development/Python", "Development/Languages/Python");
        group = replace(group, "Development/Testing", "Development");
+       group = replace(group, "Editors", "Applications/Text");
        group = replace(group, "Emulators", "Applications/Emulators");
        group = replace(group, "File tools", "Applications/File");
        group = replace(group, "Games", "Applications/Games");
        group = replace(group, "Library/Development", "Development/Libraries");
        group = replace(group, "Networking/Deamons", "Networking/Daemons");
+       group = replace(group, "Networking/Mail", "Applications/Mail");
+       group = replace(group, "Networking/Other", "Networking");
        group = replace(group, "Productivity/Databases/Servers", "Applications/Databases");
+       group = replace(group, "Productivity/Multimedia/Other", "X11/Applications/Multimedia");
        group = replace(group, "Productivity/Networking/Web/Servers", "Networking/Daemons/HTTP");;
        group = replace(group, "Shells", "Applications/Shells");
        group = replace(group, "System Environment/Base", "Base");
@@ -1969,6 +2038,7 @@ function replace_groupnames(group) {
        group = replace(group, "System/Servers", "Daemons");
        group = replace(group, "Text Processing/Markup/HTML", "Applications/Text");
        group = replace(group, "Text Processing/Markup/XML", "Applications/Text");
+       group = replace(group, "Text tools", "Applications/Text");
        group = replace(group, "User Interface/Desktops", "X11/Applications");
        group = replace(group, "Utilities/System", "Applications/System");
        group = replace(group, "Web/Database", "Applications/WWW");
@@ -1985,4 +2055,207 @@ function replace_groupnames(group) {
        return group;
 }
 
+function replace_requires() {
+
+       sub(/^python-setuptools-devel$/, "python-distribute", $2);
+       sub(/^gcc-g77/, "gcc-fortran", $2);
+
+       # use virtual, not package name
+       sub(/^rpm-build-macros$/, "rpmbuild(macros)", $2);
+
+       # bad package.xml, see http://pear.php.net/bugs/bug.php?id=17779
+       sub(/^php-php-gtk/, "php-gtk2", $2);
+
+       # jpackages
+       sub(/^antlr3$/, "java-antlr3", $2);
+       sub(/^avalon-framework$/, "java-avalon-framework", $2);
+       sub(/^avalon-logkit$/, "java-avalon-logkit", $2);
+       sub(/^axis$/, "java-axis", $2);
+       sub(/^bsf$/, "java-bsf", $2);
+       sub(/^gnu-regexp$/, "java-gnu-regexp", $2);
+       sub(/^gnu.regexp$/, "java-gnu-regexp", $2);
+       sub(/^hamcrest$/, "java-hamcrest", $2);
+       sub(/^jaas$/, "java(jaas)", $2);
+       sub(/^jaf$/, "java(jaf)", $2);
+       sub(/^jakarta-ant$/, "ant", $2);
+       sub(/^jakarta-commons-httpclient$/, "java-commons-httpclient", $2);
+       sub(/^jakarta-log4j$/, "java-log4j", $2);
+       sub(/^jakarta-oro$/, "java-oro", $2);
+       sub(/^jakarta-servletapi$/, "java(servlet)", $2);
+       sub(/^java-devel$/, "jdk", $2);
+       sub(/^java\(JSP\)$/, "java(jsp)", $2);
+       sub(/^java\(JavaServerFaces\)$/, "java(javaserverfaces)", $2);
+       sub(/^java\(Portlet\)$/, "java(portlet)", $2);
+       sub(/^java\(Servlet\)$/, "java(servlet)", $2);
+       sub(/^javamail$/, "java(javamail)", $2);
+       sub(/^jaxp$/, "java(jaxp)", $2);
+       sub(/^jaxp_parser_impl$/, "java(jaxp_parser_impl)", $2);
+       sub(/^jaxp_transform_impl$/, "java(jaxp_transform_impl)", $2);
+       sub(/^jce$/, "java(jce)", $2);
+       sub(/^jcommon$/, "java-jcommon", $2);
+       sub(/^jdbc-stdext$/, "java(jdbc-stdext)", $2);
+       sub(/^jdepend$/, "java-jdepend", $2);
+       sub(/^jfreechart$/, "java-jfreechart", $2);
+       sub(/^jmx$/, "java(jmx)", $2);
+       sub(/^jndi$/, "java(jndi)", $2);
+       sub(/^jsch$/, "java-jsch", $2);
+       sub(/^jsse$/, "java(jsse)", $2);
+       sub(/^jta$/, "java(jta)", $2);
+       sub(/^junit$/, "java-junit", $2);
+       sub(/^ldapjdk$/, "ldapsdk", $2);
+       sub(/^log4j$/, "java-log4j", $2);
+       sub(/^logging-log4j$/, "java-log4j", $2);
+       sub(/^oro$/, "java-oro", $2);
+       sub(/^rhino$/, "java-rhino", $2);
+       sub(/^saxon-scripts$/, "saxon", $2);
+       sub(/^servlet$/, "java(servlet)", $2);
+       sub(/^uddi4j$/, "java-uddi4j", $2);
+       sub(/^wsdl4j$/, "java-wsdl4j", $2);
+       sub(/^xalan-j$/, "java-xalan", $2);
+       sub(/^xalan-j2$/, "java-xalan", $2);
+       sub(/^xerces-j$/, "java(jaxp_parser_impl)", $2);
+       sub(/^xerces-j2$/, "java(jaxp_parser_impl)", $2);
+       sub(/^java-xerces$/, "java(jaxp_parser_impl)", $2);
+       sub(/^xml-commons-apis$/, "java-xml-commons-apis", $2);
+       sub(/^xml-commons-resolver$/, "java-xml-commons-resolver", $2);
+
+       # fedora / redhat
+       sub(/^keyutils-libs-devel$/, "keyutils-devel", $2);
+       sub(/^Django$/, "python-django", $2);
+       sub(/^GitPython$/, "python-git", $2);
+       sub(/^PyQt4-devel$/, "python-PyQt4-devel", $2);
+       sub(/^PyQwt-devel$/, "python-PyQwt-devel", $2);
+       sub(/^ccid$/, "pcsc-driver-ccid", $2);
+       sub(/^chkconfig$/, "/sbin/chkconfig", $2);
+       sub(/^db4-devel$/, "db-devel", $2);
+       sub(/^dbus-python$/, "python-dbus", $2);
+       sub(/^file-devel$/, "libmagic-devel", $2);
+       sub(/^freetype2-devel$/, "freetype-devel", $2);
+       sub(/^fuse-devel$/, "libfuse-devel", $2);
+       sub(/^gamin-python$/, "python-gamin", $2);
+       sub(/^gcc-c\+\+$/, "libstdc++-devel", $2);
+       sub(/^gnome-python2-extras$/, "python-gnome-extras", $2);
+       sub(/^gnome-python2-gconf$/, "python-gnome-gconf", $2);
+       sub(/^gnome-python2-gnomekeyring$/, "python-gnome-desktop-keyring", $2);
+       sub(/^gnome-python2-gtkspell$/, "python-gnome-extras-gtkspell", $2);
+       sub(/^gtk-sharp2-devel$/, "dotnet-gtk-sharp2-devel", $2);
+       sub(/^gtk2$/, "gtk+2", $2);
+       sub(/^gtk2-devel$/, "gtk+2-devel", $2);
+       sub(/^gtk3-devel$/, "gtk+3-devel", $2);
+       sub(/^initscripts$/, "rc-scripts", $2);
+       sub(/^iproute$/, "iproute2", $2);
+       sub(/^iscsi-initiator-utils$/, "open-iscsi", $2);
+       sub(/^jakarta-commons-logging$/, "java-commons-logging", $2);
+       sub(/^libXft-devel$/, "xorg-lib-libXft-devel", $2);
+       sub(/^libXrandr-devel$/, "xorg-lib-libXrandr-devel", $2);
+       sub(/^libacl-devel$/, "acl-devel", $2);
+       sub(/^libcurl-devel$/, "curl-devel", $2);
+       sub(/^libgudev1-devel$/, "udev-glib-devel", $2);
+       sub(/^libloader$/, "java-libloader", $2);
+       sub(/^libsrtp-devel$/, "srtp-devel", $2);
+       sub(/^libtdb$/, "tdb", $2);
+       sub(/^libtdb-devel$/, "tdb-devel", $2);
+       sub(/^libtevent$/, "tevent", $2);
+       sub(/^libtevent-devel$/, "tevent-devel", $2);
+       sub(/^mod_wsgi$/, "apache-mod_wsgi", $2);
+       sub(/^notify-python$/, "python-pynotify", $2);
+       sub(/^pcsc-lite-ccid$/, "pcsc-driver-ccid", $2);
+       sub(/^pulseaudio-libs-devel$/, "pulseaudio-devel", $2);
+       sub(/^pyOpenSSL$/, "python-pyOpenSSL", $2);
+       sub(/^pyflakes$/, "python-pyflakes", $2);
+       sub(/^pygobject2$/, "python-pygobject", $2);
+       sub(/^pygtk2$/, "python-pygtk", $2);
+       sub(/^pygtk2-devel$/, "python-pygtk-devel", $2);
+       sub(/^pygtk2-libglade$/, "python-pygtk-glade", $2);
+       sub(/^pysvn$/, "python-pysvn", $2);
+       sub(/^pytalloc$/, "python-talloc", $2);
+       sub(/^pytalloc-devel$/, "python-talloc-devel", $2);
+       sub(/^python-enchant$/, "python-pyenchant", $2);
+       sub(/^python-imaging$/, "python-PIL", $2);
+       sub(/^python-imaging-tk$/, "python-PIL-tk", $2);
+       sub(/^python-pygtk$/, "python-pygtk-gtk", $2);
+       sub(/^python-recaptcha-client$/, "python-recaptcha", $2);
+       sub(/^python-twisted-core$/, "python-TwistedCore", $2);
+       sub(/^python-twisted-core$/, "python-TwistedCore", $2);
+       sub(/^python-twisted-names$/, "python-TwistedNames", $2);
+       sub(/^python2-devel$/, "python-devel", $2);
+       sub(/^pytz$/, "python-pytz", $2);
+       sub(/^qt4-devel$/, "qt4-build", $2);
+       sub(/^qt4-webkit-devel$/, "QtWebKit-devel", $2);
+       sub(/^qtlockedfile-devel$/, "QtLockedFile-devel", $2);
+       sub(/^qtsingleapplication-devel$/, "QtSingleApplication-devel", $2);
+       sub(/^rpm-python$/, "python-rpm", $2);
+       sub(/^sip-devel$/, "python-sip-devel", $2);
+       sub(/^tftp-server$/, "tftpdaemon", $2);
+       sub(/^tkinter$/, "python-tkinter", $2);
+       sub(/^xapian-bindings-python$/, "python-xapian", $2);
+       sub(/^xorg-x11-server-sdk$/, "xorg-xserver-server-devel", $2);
+       # mandriva
+       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);
+
+       # debian / ubuntu
+       sub(/^blkid-dev$/, "libblkid-devel", $2);
+       sub(/^ext2fs-dev$/, "e2fsprogs-devel", $2);
+       sub(/^libao-dev$/, "libao-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(/^libcurl4-openssl-dev$/, "curl-devel", $2);
+       sub(/^libdnet-dev$/, "libdnet-devel", $2);
+       sub(/^libesd0-dev$/, "esound-devel", $2);
+       sub(/^libfishsound1-dev$/, "libfishsound-devel", $2);
+       sub(/^libgconf2-dev$/, "GConf2-devel", $2);
+       sub(/^libgl1-mesa-dev$/, "OpenGL-devel", $2);
+       sub(/^libgl1-mesa-dri$/, "OpenGL", $2);
+       sub(/^libglib2.0-dev$/, "glib2-devel", $2);
+       sub(/^libglu1-mesa-dev$/, "OpenGL-GLU-devel", $2);
+       sub(/^libgtk2.0-dev$/, "gtk+2-devel", $2);
+       sub(/^libhunspell-dev$/, "hunspell-devel", $2);
+       sub(/^libmcrypt-dev$/, "libmcrypt-devel", $2);
+       sub(/^libmhash-dev$/, "mhash-devel", $2);
+       sub(/^liboggz1-dev$/, "libggz-devel", $2);
+       sub(/^libpango1.0-dev$/, "pango-devel", $2);
+       sub(/^libqt4-dev$/, "qt4-build", $2);
+       sub(/^libshout3-dev$/, "libshout-devel", $2);
+       sub(/^libslp-dev$/, "openslp-devel", $2);
+       sub(/^libsndfile1-dev$/, "libsndfile-devel", $2);
+       sub(/^libspeex-dev$/, "speex-devel", $2);
+       sub(/^libssl-dev$/, "openssl-devel", $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);
+
+       # altlinux
+       sub(/^libgit-devel$/, "git-core-devel", $2);
+       sub(/^libncurses-devel$/, "ncurses-devel", $2);
+       sub(/^libncursesxx-devel$/, "ncurses-c++-devel", $2);
+       sub(/^libpcre-devel$/, "pcre-devel", $2);
+       sub(/^libssl-devel$/, "openssl-devel", $2);
+
+       # suse
+       sub(/^alsa-devel$/, "alsa-lib-devel", $2);
+       sub(/^gtk-sharp2$/, "dotnet-gtk-sharp2", $2);
+       sub(/^gtkmm2-devel$/, "gtkmm-devel", $2);
+       sub(/^libexpat-devel$/, "expat-devel", $2);
+       sub(/^libffmpeg-devel$/, "ffmpeg-devel", $2);
+       sub(/^libopenssl-devel$/, "openssl-devel", $2);
+       sub(/^libpulse-devel$/, "pulseaudio-devel", $2);
+       sub(/^monodoc-core$/, "mono-monodoc", $2);
+       sub(/^python-gtk$/, "python-pygtk-gtk", $2);
+
+       replace_php_virtual_deps()
+}
+
 # vim:ts=4:sw=4
This page took 0.746826 seconds and 4 git commands to generate.