]> git.pld-linux.org Git - packages/adapter.git/blobdiff - adapter.awk
- Networking/Daemons/HTTP
[packages/adapter.git] / adapter.awk
index 27d639df93c3d84cc5fd457ee396ba23ab38d6f8..d2403cb1c8985bc182d8816db4df93069a8122cb 100644 (file)
@@ -1,7 +1,6 @@
 #!/usr/bin/gawk -f
 #
-# This is adapter v0.29. Adapter adapts .spec files for PLD Linux.
-# $Id$
+# Adapter adapts .spec files for PLD Linux.
 #
 # Copyright (C) 1999-2007 PLD-Team <feedback@pld-linux.org>
 # Authors:
@@ -30,6 +29,10 @@ BEGIN {
        RPM_SECTIONS = "package|build|changelog|clean|description|install|post|posttrans|postun|pre|prep|pretrans|preun|triggerin|triggerpostun|triggerun|verifyscript|check"
        SECTIONS = "^%(" RPM_SECTIONS ")"
 
+       RCSID = "$Id$"
+       rev = RCSID # TODO: parse from RCSID
+       VERSION = "0.31/" rev
+
        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)"
 
        usedigest = 0   # Enable to switch to rpm 4.4.6+ md5 digests
@@ -77,8 +80,10 @@ BEGIN {
        "rpm --eval %_examplesdir"      | getline examplesdir
        "rpm --eval %_defaultdocdir"    | getline docdir
        "rpm --eval %_kdedocdir"        | getline kdedocdir
+       "rpm --eval %_gtkdocdir"        | getline gtkdocdir
        "rpm --eval %_desktopdir" | getline desktopdir
        "rpm --eval %_pixmapsdir" | getline pixmapsdir
+       "rpm --eval %_javadir" | getline javadir
 
        "rpm --eval %perl_sitearch" | getline perl_sitearch
        "rpm --eval %perl_archlib" | getline perl_archlib
@@ -90,6 +95,7 @@ BEGIN {
        "rpm --eval %py_sitescriptdir 2>/dev/null" | getline py_sitescriptdir
        "rpm --eval %py_sitedir 2>/dev/null" | getline py_sitedir
        "rpm --eval %py_scriptdir 2>/dev/null" | getline py_scriptdir
+       "rpm --eval %py_ver 2>/dev/null" | getline py_ver
 
        "rpm --eval %ruby_archdir" | getline ruby_archdir
        "rpm --eval %ruby_ridir" | getline ruby_ridir
@@ -98,6 +104,7 @@ BEGIN {
        "rpm --eval %ruby_sitelibdir" | getline ruby_sitelibdir
 
        "rpm --eval %php_pear_dir" | getline php_pear_dir
+       "rpm --eval %php_data_dir" | getline php_data_dir
        "rpm --eval %tmpdir" | getline tmpdir
 }
 
@@ -527,7 +534,9 @@ function b_makekey(a, b,    s) {
        if ($0 ~ /^%files/)
                defattr = 1
 
-       use_files_macros()
+       if (!use_files_macros()) {
+               next
+       }
 }
 
 ##############
@@ -675,50 +684,7 @@ preamble == 1 {
                format_preamble()
                group = $0;
                sub(/^[^ \t]*[ \t]*/, "", group);
-
-               sub(/^Amusements\/Games\/Strategy\/Real Time/, "X11/Applications/Games/Strategy", group)
-               sub(/^Application\/Multimedia$/, "Applications/Multimedia", group)
-               sub(/^Applications\/Compilers$/, "Development/Languages", group)
-               sub(/^Applications\/Daemons$/, "Daemons", group)
-               sub(/^Applications\/Internet$/, "Applications/Networking", group)
-               sub(/^Applications\/Internet\/Peer to Peer/, "Applications/Networking", group)
-               sub(/^Applications\/Productivity$/, "X11/Applications", group)
-               sub(/^Database$/, "Applications/Databases", group)
-               sub(/^Development\/Code Generators$/, "Development", group)
-               sub(/^Development\/Docs$/, "Documentation", group)
-               sub(/^Development\/Documentation$/, "Documentation", group)
-               sub(/^Development\/Java/, "Development/Languages/Java", group)
-               sub(/^Development\/Libraries\/C and C\+\+$/, "Development/Libraries", group)
-               sub(/^Development\/Libraries\/Java$/, "Development/Languages/Java", group)
-               sub(/^Development\/Other/,"Development", group)
-               sub(/^Development\/Testing$/, "Development", group)
-               sub(/^Emulators$/, "Applications/Emulators", group)
-               sub(/^Games/,"Applications/Games", group)
-               sub(/^Library\/Development$/, "Development/Libraries", group)
-               sub(/^Networking\/Deamons$/, "Networking/Daemons", group)
-               sub(/^Shells/,"Applications/Shells", group)
-               sub(/^System Environment\/Base$/, "Base", group)
-               sub(/^System Environment\/Daemons$/, "Daemons", group)
-               sub(/^System Environment\/Kernel$/, "Base/Kernel", group)
-               sub(/^System Environment\/Libraries$/, "Libraries", group)
-               sub(/^System$/, "Base", group)
-               sub(/^System\/Base$/, "Base", group)
-               sub(/^System\/Libraries$/, "Libraries", group)
-               sub(/^System\/Servers$/, "Daemons", group)
-               sub(/^Text Processing\/Markup\/HTML$/, "Applications/Text", group)
-               sub(/^Text Processing\/Markup\/XML$/, "Applications/Text", group)
-               sub(/^Utilities\//,"Applications/", group)
-               sub(/^Web\/Database$/, "Applications/WWW", group)
-               sub(/^X11\/GNOME/,"X11/Applications", group)
-               sub(/^X11\/GNOME\/Applications/,"X11/Applications", group)
-               sub(/^X11\/GNOME\/Development\/Libraries/,"X11/Development/Libraries", group)
-               sub(/^X11\/Games/,"X11/Applications/Games", group)
-               sub(/^X11\/Games\/Strategy/,"X11/Applications/Games/Strategy", group)
-               sub(/^X11\/Library/,"X11/Libraries", group)
-               sub(/^X11\/Utilities/,"X11/Applications", group)
-               sub(/^X11\/XFree86/, "X11", group)
-               sub(/^X11\/Xserver$/, "X11/Servers", group)
-
+               group = replace_groupnames(group);
                $0 = "Group:\t\t" group
 
                if (group ~ /^X11/ && x11 == 0) # Is it X11 application?
@@ -816,6 +782,12 @@ preamble == 1 {
                if (l == "Apache Software License 1.1" || l == "Apache 1.1") {
                        l = "Apache v1.1"
                }
+               if (l == "GPLv2") {
+                       l = "GPL v2"
+               }
+               if (l == "GPLv2+") {
+                       l = "GPL v2+"
+               }
                $0 = "License:\t" l;
        }
 
@@ -1135,8 +1107,10 @@ function use_macros()
 
        gsub("%{_datadir}/applications", "%{_desktopdir}")
        gsub("%{_datadir}/pixmaps", "%{_pixmapsdir}")
+       gsub("%{_datadir}/java", "%{_javadir}")
 
        gsub(libdir, "%{_libdir}")
+       gsub(javadir, "%{_javadir}")
 
        gsub(bindir, "%{_bindir}")
        gsub("%{prefix}/bin", "%{_bindir}")
@@ -1175,7 +1149,9 @@ function use_macros()
                        continue;
                if ($c ~ sysconfdir "/{?modprobe.(d|conf)")
                        continue;
-               if ($c ~ sysconfdir "/{?udev/rules.d")
+               if ($c ~ sysconfdir "/{?udev")
+                       continue;
+               if ($c ~ sysconfdir "/{?hotplug")
                        continue;
                if ($c ~ sysconfdir "/{?logrotate.d")
                        continue;
@@ -1211,12 +1187,20 @@ function use_macros()
                        continue;
                if ($c ~ sysconfdir "/dbus-1")
                        continue;
+               if ($c ~ sysconfdir "/tmpwatch")
+                       continue;
                gsub(sysconfdir, "%{_sysconfdir}", $c)
        }
 
-       gsub(kdedocdir, "%{_kdedocdir}")
        gsub(docdir, "%{_docdir}")
+
+       gsub(kdedocdir, "%{_kdedocdir}")
+
+       gsub(gtkdocdir, "%{_gtkdocdir}")
+       gsub("%{_docdir}/gtk-doc/html", "%{_gtkdocdir}")
+
        gsub(php_pear_dir, "%{php_pear_dir}")
+       gsub(php_data_dir, "%{php_data_dir}")
 
        for (c = 1; c <= NF; c++) {
                if ($c ~ datadir "/automake")
@@ -1349,12 +1333,15 @@ function use_macros()
        gsub("/usr/src/linux", "%{_kernelsrcdir}")
        gsub("%{_prefix}/src/linux", "%{_kernelsrcdir}")
 
-       if (/^ant /) {
+       if (/^ant / || /^%{ant}/) {
                sub(/^ant/, "%ant")
+               sub(/^%{ant}/, "%ant")
                add_br("BuildRequires:  jpackage-utils");
                add_br("BuildRequires:  rpmbuild(macros) >= 1.300");
        }
 
+       $0 = fixedsub("%(%{__cc} -dumpversion)", "%{cc_version}", $0);
+       $0 = fixedsub("%(%{__cxx} -dumpversion)", "%{cxx_version}", $0);
 }
 
 function format_configure(line,                n, a, s) {
@@ -1381,13 +1368,13 @@ function isort(A,n,             i,j,hold) {
 }
 
 
-function use_files_macros(     i, n, t, a)
+function use_files_macros(     i, n, t, a, l)
 {
        use_macros()
 
        # skip comments
        if (/^#/) {
-               return;
+               return 1;
        }
 
        sub("^%doc %{_mandir}", "%{_mandir}")
@@ -1418,6 +1405,8 @@ function use_files_macros(        i, n, t, a)
        gsub("%{_sysconfdir}/certs", "/etc/certs")
        gsub("%{_sysconfdir}/init.d", "/etc/init.d")
        gsub("%{_sysconfdir}/dbus-1", "/etc/dbus-1")
+       gsub("%{_sysconfdir}/pki", "/etc/pki")
+       gsub("%{_sysconfdir}/tmpwatch", "/etc/tmpwatch")
 
        # /etc/init.d -> /etc/rc.d/init.d
        if (!/^\/etc\/init\.d$/) {
@@ -1505,6 +1494,32 @@ function use_files_macros(       i, n, t, a)
                $(NF + 1) = "# FIXME consider using %find_lang"
        }
 
+       # python egg-infos
+       if (match($0, "^%{py_site(script)?dir}/.+-py"py_ver".egg-info$")) {
+               # tests:
+               #%{py_sitedir}/*-py2.4.egg-info
+               #%{py_sitescriptdir}/GnuPGInterface-%{version}-py2.4.egg-info
+               #%{py_sitescriptdir}/python_mpd-%{version}-py2.4.egg-info
+               #%{py_sitescriptdir}/mechanize-0.1.6b-py2.4.egg-info
+
+               l = index($0, "/");
+               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"
+                       return 0;
+               }
+       }
+
        # atrpms
        $0 = fixedsub("%{perl_man1dir}", "%{_mandir}/man1", $0);
        $0 = fixedsub("%{perl_man3dir}", "%{_mandir}/man3", $0);
@@ -1517,6 +1532,10 @@ function use_files_macros(       i, n, t, a)
        gsub("%{_datadir}/applications", "%{_desktopdir}");
        gsub("%{_datadir}/icons", "%{_iconsdir}");
        gsub("%{_datadir}/pixmaps", "%{_pixmapsdir}");
+       gsub("%{_datadir}/pear", "%{php_pear_dir}");
+       gsub("%{_datadir}/php", "%{php_data_dir}");
+
+       return 1
 }
 
 function use_script_macros()
@@ -1600,6 +1619,10 @@ function unify_url(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)
+
        return url
 }
 
@@ -1634,7 +1657,11 @@ function demacroize(str)
 
 function kill_preamble_macros()
 {
-       if ($1 ~ /^URL:/ || $1 ~ /^Obsoletes:/) {
+       if ($1 ~ /^Obsoletes:/) {
+               # NB! assigning $2 a value breaks tabbing
+               $2 = demacroize($2);
+       }
+       if ($1 ~ /^URL:/) {
                # NB! assigning $2 a value breaks tabbing
                $2 = demacroize($2);
                $2 = unify_url($2)
@@ -1714,6 +1741,9 @@ function replace_requires()
        sub(/^gcc-c\+\+$/, "libstdc++-devel", $2);
        sub(/^chkconfig$/, "/sbin/chkconfig", $2);
 
+       # fedora
+       sub(/^iscsi-initiator-utils$/, "open-iscsi", $2);
+
        replace_php_virtual_deps()
 }
 
@@ -1747,4 +1777,62 @@ function replace_php_virtual_deps()
        }
 }
 
+function replace_groupnames(group)
+{
+       sub(/^Amusements\/Games\/Strategy\/Real Time/, "X11/Applications/Games/Strategy", group)
+       sub(/^Application\/Multimedia$/, "Applications/Multimedia", group)
+       sub(/^Applications\/Compilers$/, "Development/Languages", group)
+       sub(/^Applications\/Daemons$/, "Daemons", group)
+       sub(/^Applications\/Internet$/, "Applications/Networking", group)
+       sub(/^Applications\/Internet\/Peer to Peer/, "Applications/Networking", group)
+       sub(/^Applications\/Productivity$/, "X11/Applications", group)
+       sub(/^Database$/, "Applications/Databases", group)
+       sub(/^Development\/Code Generators$/, "Development", group)
+       sub(/^Development\/Docs$/, "Documentation", group)
+       sub(/^Development\/Documentation$/, "Documentation", group)
+       sub(/^Development\/Java/, "Development/Languages/Java", group)
+       sub(/^Development\/Libraries\/C and C\+\+$/, "Development/Libraries", group)
+       sub(/^Development\/Libraries\/Java$/, "Development/Languages/Java", group)
+       sub(/^Development\/Other/,"Development", group)
+       sub(/^Development\/Testing$/, "Development", group)
+       sub(/^Emulators$/, "Applications/Emulators", group)
+       sub(/^Games/,"Applications/Games", group)
+       sub(/^Library\/Development$/, "Development/Libraries", group)
+       sub(/^Networking\/Deamons$/, "Networking/Daemons", group)
+       sub(/^Shells/,"Applications/Shells", group)
+       sub(/^System Environment\/Base$/, "Base", group)
+       sub(/^System Environment\/Daemons$/, "Daemons", group)
+       sub(/^System Environment\/Kernel$/, "Base/Kernel", group)
+       sub(/^System Environment\/Libraries$/, "Libraries", group)
+       sub(/^System$/, "Base", group)
+       sub(/^System\/Base$/, "Base", group)
+       sub(/^System\/Libraries$/, "Libraries", group)
+       sub(/^System\/Servers$/, "Daemons", group)
+       sub(/^Text Processing\/Markup\/HTML$/, "Applications/Text", group)
+       sub(/^Text Processing\/Markup\/XML$/, "Applications/Text", group)
+       sub(/^Utilities\//,"Applications/", group)
+       sub(/^Web\/Database$/, "Applications/WWW", group)
+       sub(/^X11\/GNOME/,"X11/Applications", group)
+       sub(/^X11\/GNOME\/Applications/,"X11/Applications", group)
+       sub(/^X11\/GNOME\/Development\/Libraries/,"X11/Development/Libraries", group)
+       sub(/^X11\/Games/,"X11/Applications/Games", group)
+       sub(/^X11\/Games\/Strategy/,"X11/Applications/Games/Strategy", group)
+       sub(/^X11\/Library/,"X11/Libraries", group)
+       sub(/^X11\/Utilities/,"X11/Applications", group)
+       sub(/^X11\/XFree86/, "X11", group)
+       sub(/^X11\/Xserver$/, "X11/Servers", group)
+       sub(/^Development\/C$/, "Development/Libraries", group)
+       sub(/^Development\/Python$/, "Development/Languages/Python", group)
+       sub(/^System\/Kernel and hardware$/, "Base/Kernel", group)
+       sub(/^Application\/System$/, "Applications/System", group)
+       sub(/^Productivity\/Databases\/Servers$/, "Applications/Databases", group)
+       sub(/^Development\/Libraries\/Python$/, "Development/Languages/Python", group)
+       sub(/^Development\/Languages\/Ruby$/, "Development/Languages", group)
+       sub(/^Development\/Libraries\/TCL$/, "Development/Languages/Tcl", group);
+       sub(/^Development\/Languages\/Other$/, "Development/Languages", group);
+       sub(/^Productivity\/Networking\/Web\/Servers$/, "Networking/Daemons/HTTP", group);
+
+       return group;
+}
+
 # vim:ts=4:sw=4
This page took 0.048246 seconds and 4 git commands to generate.