]> git.pld-linux.org Git - packages/rpm-build-tools.git/commitdiff
This commit was manufactured by cvs2git to create branch 'DEVEL'. DEVEL
authorcvs2git <feedback@pld-linux.org>
Sun, 28 Jun 2009 17:04:45 +0000 (17:04 +0000)
committercvs2git <feedback@pld-linux.org>
Sun, 24 Jun 2012 12:13:13 +0000 (12:13 +0000)
Sprout from master 2004-01-06 14:27:51 UTC Jakub Bogusz <qboosh@pld-linux.org> '- updated from SPECS (HEAD)'
Cherrypick from master 2009-06-28 17:04:45 UTC Elan Ruusamäe <glen@pld-linux.org> '- v0.35':
    adapter.awk -> 1.423
Delete:
    builder.sh
    pldnotify.awk

adapter.awk
builder.sh [deleted file]
pldnotify.awk [deleted file]

index edcbed8de7486a4f7b77ae38c6270a36a8330f34..c3bde7f6614f9d73579744a863ad586c272af557 100644 (file)
@@ -1,22 +1,52 @@
-#!/bin/awk -f
+#!/usr/bin/gawk -f
 #
-# This is adapter v0.27. Adapter adapts .spec files for PLD.
+# Adapter adapts .spec files for PLD Linux.
 #
-# Copyright (C) 1999-2003 PLD-Team <feedback@pld-linux.org>
+# Copyright (C) 1999-2008 PLD-Team <feedback@pld-linux.org>
 # Authors:
-#      Micha³ Kuratczyk <kura@pld.org.pl>
+#      Michał Kuratczyk <kura@pld.org.pl>
 #      Sebastian Zagrodzki <s.zagrodzki@mimuw.edu.pl>
-#      Tomasz K³oczko <kloczek@rudy.mif.pg.gda.pl>
-#      Artur Frysiak <wiget@pld.org.pl>
+#      Tomasz Kłoczko <kloczek@rudy.mif.pg.gda.pl>
+#      Artur Frysiak <wiget@pld-linux.org>
 #      Michal Kochanowicz <mkochano@pld.org.pl>
+#      Jakub Bogusz <qboosh@pld-linux.org>
+#      Elan Ruusamäe <glen@pld-linux.org>
+#
+# See cvs log adapter{,.awk} for list of contributors
+#
 # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
 
+# TODO
+# - really long sourceX make preamble sorting totally fcked up (try snake.spec r1.1)
+# - parse ../PLD-doc/BuildRequires.txt and setup proper BR epoches?
+# - add "-nc" option to skip CVS interaction
+# - sort Summary(XX)
+# - sort Requires, BuildRequires
+# - check if %description (lang=C) contains 8bit
+# - desc wrapping is totally fucked up on global.spec,1.25, dosemu.spec,1.115-
+# - it should change: /%source([0-9]+)/i to %{SOURCE\1}
+# - extra quote on LDFLAGS line: https://bugs.launchpad.net/pld-linux/+bug/385836
+
 BEGIN {
-       preamble = 1            # Is it part of preamble? Default - yes
-       boc = 4                 # Beggining of %changelog
-       bod = 0                 # Beggining of %description
-       tw = 70                 # Descriptions width
-       
+       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.35/" 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|Auto(Req|Prov))"
+
+       usedigest = 0   # Enable to switch to rpm 4.4.6+ md5 digests
+
+       preamble = 1    # Is it part of preamble? Default - yes
+       boc = 4                 # Beginning of %changelog
+       bod = 0                 # Beginning of %description
+       tw = 70                 # Descriptions width
+
+       b_idx = 0               # index of BR/R arrays
+       BR_count = 0    # number of additional BuildRequires
+
        # If variable removed, then 1 (for removing it from export)
        removed["LDFLAGS"] = 0
        removed["CFLAGS"] = 0
@@ -24,25 +54,17 @@ BEGIN {
 
        # If 1, we are inside of comment block (started with /^#%/)
        comment_block = 0
-       
-       # File with rpm groups
-       "rpm --eval %_sourcedir" | getline groups_file
-       groups_file = groups_file "/rpm.groups"
-       system("cd `rpm --eval %_sourcedir`; cvs up rpm.groups >/dev/null")
+
+       import_rpm_macros()
+
+       packages_dir = topdir "/packages"
+       groups_file = packages_dir "/rpm.groups"
+
+       system("cd "packages_dir"; [ -f rpm.groups ] || cvs up rpm.groups > /dev/null")
+       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"
-
-       # Load rpm macros
-       "rpm --eval %_prefix"   | getline prefix
-       "rpm --eval %_bindir"   | getline bindir
-       "rpm --eval %_sbindir"  | getline sbindir
-       "rpm --eval %_libdir"   | getline libdir
-       "rpm --eval %_sysconfdir" | getline sysconfdir
-       "rpm --eval %_datadir"  | getline datadir
-       "rpm --eval %_includedir" | getline includedir
-       "rpm --eval %_mandir"   | getline mandir
-       "rpm --eval %_infodir"  | getline infodir
 }
 
 # There should be a comment with CVS keywords on the first line of file.
@@ -57,13 +79,55 @@ FNR == 1 {
 
 # If the latest line matched /%files/
 defattr == 1 {
-       if ($0 !~ /defattr/)    # If no %defattr
-               print "%defattr(644,root,root,755)"     # Add it
-       else
-               $0 = "%defattr(644,root,root,755)"      # Correct mistakes (if any)
+       if (ENVIRON["SKIP_DEFATTR"] != 1) {
+               if ($0 !~ /defattr/) {  # If no %defattr
+                       print "%defattr(644,root,root,755)"     # Add it
+               } else {
+                       $0 = "%defattr(644,root,root,755)"      # Correct mistakes (if any)
+               }
+       }
        defattr = 0
 }
 
+function b_makekey(a, b,       s) {
+       s = a "" b;
+       # kill bcond
+       gsub(/[#%]+{[!?]+[_a-zA-Z0-9]+:/, "", s);
+
+       # kill commented out items
+       gsub(/^#[ \t]*/, "", s);
+
+       # force order
+       gsub(/^Summary\(/, "11Summary(", s);
+       gsub(/^Summary/, "10Summary", s);
+
+       gsub(/^Name/, "2Name", s);
+       gsub(/^Version/, "3Version", s);
+       gsub(/^Release/, "4Release", s);
+       gsub(/^Epoch/, "5Epoch", s);
+       gsub(/^License/, "5License", s);
+       gsub(/^Group/, "6Group", s);
+       gsub(/^URL/, "7URL", s);
+
+       gsub(/^BuildRequires/, "B1BuildRequires", s);
+       gsub(/^BuildConflicts/, "B2BuildConflicts", s);
+
+       gsub(/^Suggests/, "X1Suggests", s);
+       gsub(/^Provides/, "X2Provides", s);
+       gsub(/^Obsoletes/, "X3Obsoletes", s);
+       gsub(/^Conflicts/, "X4Conflicts", s);
+       gsub(/^BuildArch/, "X5BuildArch", s);
+       gsub(/^ExclusiveArch/, "X6ExclusiveArch", s);
+       gsub(/^ExcludeArch/, "X7ExcludeArch", s);
+       gsub(/^BuildRoot/, "X9BuildRoot", s);
+
+       gsub(/^AutoProv/, "Xx1AutoProv", s);
+       gsub(/^AutoReq/, "Xx2AutoReq", s);
+
+#      printf("%s -> %s\n", a""b, s);
+       return s;
+}
+
 # Comments
 /^#/ && (description == 0) {
        if (/This file does not like to be adapterized!/) {
@@ -76,22 +140,116 @@ defattr == 1 {
 
        # Generally, comments are printed without touching
        sub(/[ \t]+$/, "")
-       print $0
-       next
+
+       if (/#[ \t]*Source.*md5/) {
+               if (usedigest == 1) {
+                       sub(/^#[ \t]*Source/, "BuildRequires:\tdigest(%SOURCE", $0)
+                       sub(/-md5[ \t]*:[ \t]*/, ") = ", $0)
+               }
+               print $0
+               next
+       }
 }
 
-# Remove defining _applnkdir (this macro has been included in rpm-3.0.4)
 /^%define/ {
-       if ($2 == "_applnkdir")
+       # Remove defining _applnkdir (this macro has been included in rpm-3.0.4)
+       if ($2 == "_applnkdir") {
                next
-       if ($2 == "date")
+       }
+       if ($2 == "date") {
                date = 1
+               if (did_files == 0) {
+                       print "%files"
+                       print ""
+                       did_files = 1
+               }
+       }
+
+       # Do not add %define of _prefix if it already is.
+       if ($2 ~ /^_prefix/) {
+               sub("^"prefix, $3, bindir)
+               sub("^"prefix, $3, sbindir)
+               sub("^"prefix, $3, libdir)
+               sub("^"prefix, $3, datadir)
+               sub("^"prefix, $3, includedir)
+               prefix = $3
+       }
+
+       if ($2 ~ /_bindir/ && !/_sbindir/)
+               bindir = $3
+       if ($2 ~ /_sbindir/)
+               sbindir = $3
+       if ($2 ~ /_libdir/) {
+               if ($3 ~ /^%\(/) {
+                       # TODO: should escape for latter checks like: ($c ~ sysconfdir "/{?cron.")
+                       libdir = "%%%%%%%%%%%%%%"
+               } else {
+                       libdir = $3
+               }
+       }
+       if ($2 ~ /_sysconfdir/) {
+               if ($3 ~ /^%\(/) {
+                       # TODO: should escape for latter checks like: ($c ~ sysconfdir "/{?cron.")
+                       sysconfdir = "%%%%%%%%%%%%%%"
+               } else {
+                       sysconfdir = $3
+               }
+       }
+       if ($2 ~ /_datadir/) {
+               if ($3 ~ /^%\(/) {
+                       # TODO: should escape for latter checks like: ($c ~ sysconfdir "/{?cron.")
+                       datadir = "%%%%%%%%%%%%%%"
+               } else {
+                       datadir = $3
+               }
+       }
+       if ($2 ~ /_includedir/)
+               includedir = $3
+       if ($2 ~ /_mandir/)
+               mandir = $3
+       if ($2 ~ /_infodir/)
+               infodir = $3
+       if ($2 ~ /_docdir/)
+               docdir = $3
+
+       # version related macros
+       if ($2 ~ /^_beta$/)
+               _beta = $3
+       if ($2 ~ /^_rc$/)
+               _rc = $3
+       if ($2 ~ /^_pre$/)
+               _pre = $3
+       if ($2 ~ /^_snap$/)
+               _snap = $3
+       if ($2 ~ /^subver$/)
+               subver = $3
+
+       # these are used usually when adapterizing external spec
+       if ($2 ~ /^name$/)
+               name = $3
+       if ($2 ~ /^version$/)
+               version = $3
+       if ($2 ~ /^release$/)
+               release = $3
+
+       if ($2 ~ /^mod_name$/)
+               mod_name = $3
+
+       sub(/[ \t]+$/, "");
+       # do nothing further, otherwise adapter thinks we're at preamble
+       print
+       next
+}
+
+# Obsolete
+/^%include.*\/usr\/lib\/rpm\/macros\.python$/ {
+       next
 }
 
 ################
 # %description #
 ################
-/^%description/, (/^%[a-z]+/ && !/^%description/) {
+/^%description/, (!/^%description/ && $0 ~ SECTIONS) {
        preamble = 0
 
        if (/^%description/) {
@@ -100,16 +258,8 @@ defattr == 1 {
                format_indent = -1
        }
 
-       # Define _prefix and _mandir if it is X11 application
-#      if (/^%description$/ && x11 == 1) {
-#              print "%define\t\t_prefix\t\t/usr/X11R6"
-#              print "%define\t\t_mandir\t\t%{_prefix}/man\n"
-#              prefix = "/usr/X11R6"
-#              x11 = 2
-#      }
-       
        # Format description
-       if (description == 1 && !/^%[a-z]+/ && !/^%description/) {
+       if (ENVIRON["SKIP_DESC"] != 1 && description == 1 && !/^%[a-z]+/ && !/^%description/) {
                if (/^[ \t]*$/) {
                        format_flush(format_line, format_indent)
                        print ""
@@ -117,15 +267,15 @@ defattr == 1 {
                        format_indent = -1
                } else if (/^[ \t]*[-\*][ \t]*/) {
                        format_flush(format_line, format_indent)
-                       match($0, /^[ \t]*/)    
+                       match($0, /^[ \t]*/)
                        format_indent = RLENGTH
                        match($0, /^[ \t]*[-\*][ \t]/)
                        format_line = substr($0, RLENGTH)
-               } else 
+               } else
                        format_line = format_line " " $0
                next
        }
+
        if (/^%[a-z]+/ && (!/^%description/ || bod == 2)) {
                if (NF > 3 && $2 == "-l") {
                        ll = $1
@@ -148,22 +298,61 @@ defattr == 1 {
 #########
 # %prep #
 #########
-/^%prep/, (/^%[a-z]+$/ && !/^%prep/) {
+/^%prep/, (!/^%prep/ && $0 ~ SECTIONS) {
        preamble = 0
-       
+       did_prep = 1
+
+       use_macros()
+
        # Add '-q' to %setup
-       if (/^%setup/ && !/-q/)
+       if (/^%setup/ && !/-q/) {
                sub(/^%setup/, "%setup -q")
+       }
+
+       if (/^%setup/ && name != "setup") {
+               $0 = fixedsub(name, "%{name}", $0);
+               $0 = fixedsub(version, "%{version}", $0);
+               if (_beta) {
+                       $0 = fixedsub(_beta, "%{_beta}", $0);
+               }
+               if (_rc) {
+                       $0 = fixedsub(_rc, "%{_rc}", $0);
+               }
+               if (_pre) {
+                       $0 = fixedsub(_pre, "%{_pre}", $0);
+               }
+               if (_snap) {
+                       $0 = fixedsub(_snap, "%{_snap}", $0);
+               }
+               if (subver) {
+                       $0 = fixedsub(subver, "%{subver}", $0);
+               }
+       }
+
+       if (/^%setup/ && /-n %{name}-%{version}( |$)/) {
+               $0 = fixedsub(" -n %{name}-%{version}", "", $0)
+       }
+       sub("^%patch ", "%patch0 ");
+
+       # invalid in %prep
+       sub("^rm -rf \$RPM_BUILD_ROOT.*", "");
 }
 
 ##########
 # %build #
 ##########
-/^%build/, (/^%[a-z]+$/ && !/^%build/) {
+/^%build/, (!/^%build/ && $0 ~ SECTIONS) {
        preamble = 0
 
+       if (did_prep == 0) {
+               print "%prep"
+               print ""
+               did_prep = 1
+       }
+
        use_macros()
-       
+       use_tabs()
+
        if (/^automake$/)
                sub(/$/, " -a -c")
 
@@ -190,7 +379,7 @@ defattr == 1 {
        if (/CXXFLAGS=/)
                if (cflags("CXXFLAGS") == 0)
                        next
-       
+
        if (/^export /) {
                if (removed["LDFLAGS"])
                        sub(" LDFLAGS", "")
@@ -202,24 +391,55 @@ defattr == 1 {
                if (/^export[ ]*$/)
                        next
        }
-                       
+
+       # quote CC
+       if (/CC=%{__cc} /) {
+               sub("CC=%{__cc}", "CC=\"%{__cc}\"")
+       }
+       
+       # use PLD Linux macros
+       $0 = fixedsub("glib-gettextize --copy --force","%{__glib_gettextize}", $0);
+       $0 = fixedsub("intltoolize --copy --force", "%{__intltoolize}", $0);
+       $0 = fixedsub("automake --add-missing --copy", "%{__automake}", $0);
+       $0 = fixedsub("automake -a --foreign --copy", "%{__automake}", $0);
+       $0 = fixedsub("automake -a -c --foreign", "%{__automake}", $0);
+       $0 = fixedsub("automake -a -c", "%{__automake}", $0);
+       $0 = fixedsub("libtoolize --force --automake --copy", "%{__libtoolize}", $0);
+       $0 = fixedsub("libtoolize -c -f --automake", "%{__libtoolize}", $0);
+
+       sub(/^aclocal$/, "%{__aclocal}");
+       sub(/^autoheader$/, "%{__autoheader}");
+       sub(/^autoconf$/, "%{__autoconf}");
+       sub(/^automake$/, "%{__automake}");
+       sub(/^libtoolize$/, "%{__libtoolize}");
+
+       # atrpms
+       $0 = fixedsub("%perl_configure", "%{__perl} Makefile.PL \\\n\tINSTALLDIRS=vendor", $0);
+       $0 = fixedsub("%perl_makecheck", "%{?with_tests:%{__make} test}", $0);
 }
 
 ##########
 # %clean #
 ##########
-/^%clean/, (/^%[a-z]+$/ && !/^%clean/) {
+/^%clean/, (!/^%clean/ && $0 ~ SECTIONS) {
        did_clean = 1
+
+       use_macros()
 }
 
 ############
 # %install #
 ############
-/^%install/, (/^%[a-z]+$/ && !/^%install/) {
-       
+/^%install/, (!/^%install/ && $0 ~ SECTIONS) {
+
        preamble = 0
-       
-       if (/^[ \t]*rm([ \t]+-[rf]+)*[ \t]+\${?RPM_BUILD_ROOT}?/ && did_rmroot==0) {
+
+       # foreign rpms
+       sub("^%{__rm} -rf %{buildroot}", "rm -rf $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
                print "rm -rf $RPM_BUILD_ROOT"
                next
@@ -229,69 +449,89 @@ defattr == 1 {
                print "rm -rf $RPM_BUILD_ROOT"
                did_rmroot=1
        }
-       
+
+       if (tmpdir) {
+               buildroot = tmpdir "/" name "-" version "-root-" ENVIRON["USER"]
+               gsub(buildroot, "$RPM_BUILD_ROOT")
+       }
+
+       if (!/%{_lib}/) {
+               sub("\$RPM_BUILD_ROOT/%", "$RPM_BUILD_ROOT%")
+       }
+
        use_macros()
-       
+
        # 'install -d' instead 'mkdir -p'
        if (/mkdir -p/)
                sub(/mkdir -p/, "install -d")
-               
+
+       # cp -a already implies cp -r
+       sub(/^cp -ar/, "cp -a")
+
        # No '-u root' or '-g root' for 'install'
        if (/^install/ && /-[ug][ \t]*root/)
                gsub(/-[ug][ \t]*root /, "")
-       
-       if (/^install/ && /-m[ \t]*644/)
-               gsub(/-m[ \t]*644 /, "")
-       
+
+       if (/^install/ && /-m[ \t]*[0-9]+/)
+               gsub(/-m[ \t]*[0-9]+ /, "")
+
        # No lines contain 'chown' or 'chgrp' if owner/group is 'root'
        if (($1 ~ /chown/ && $2 ~ /root\.root/) || ($1 ~ /chgrp/ && $2 ~ /root/))
                next
-       
+
        # No lines contain 'chmod' if it sets the modes to '644'
        if ($1 ~ /chmod/ && $2 ~ /644/)
                next
+
+       # atrpms
+       $0 = fixedsub("%perl_makeinstall", "%{__make} pure_install \\\n\tDESTDIR=$RPM_BUILD_ROOT", $0);
 }
 
 ##########
 # %files #
 ##########
-/^%files/, (/^%[a-z \-]+$/ && !/^%files/) {
+/^%files/, (!/^%files/ && $0 ~ SECTIONS) {
        preamble = 0
-       
+       did_files = 1
+
        if ($0 ~ /^%files/)
                defattr = 1
-       
-       use_macros()
-       use_files_macros()
+
+       if (!use_files_macros()) {
+               next
+       }
 }
 
 ##############
 # %changelog #
 ##############
-/^%changelog/, (/^%[a-z]+$/ && !/^%changelog/) {
+/^%changelog/, (!/^%changelog/ && $0 ~ SECTIONS) {
        preamble = 0
        has_changelog = 1
        skip = 0
        # There should be some CVS keywords on the first line of %changelog.
        if (boc == 3) {
-               if (!/PLD Team/)
-                       print "* %{date} PLD Team <feedback@pld-linux.org>" > changelog_file
-               else
+               if ($0 !~ _cvsmailfeedback) {
+                       print "* %{date} " _cvsmailfeedback > changelog_file
+               } else {
                        skip = 1
+               }
                boc = 2
        }
        if (boc == 2 && !skip) {
                if (!/All persons listed below/) {
                        printf "All persons listed below can be reached at " > changelog_file
-                       print "<cvs_login>@pld-linux.org\n" > changelog_file
-               } else
+                       print "<cvs_login>" _cvsmaildomain "\n" > changelog_file
+               } else {
                        skip = 1
+               }
                boc = 1
        }
        if (boc == 1 && !skip) {
                if (!/^$/) {
-                       if (!/\$.*Log:.*\$/)
+                       if (!/\$.*Log:.*\$/) {
                                print "$" "Log:$" > changelog_file
+                       }
                        boc = 0
                }
        }
@@ -305,28 +545,81 @@ defattr == 1 {
                boc = 3
        }
 
-       sub(/[ \t]+$/, "")
-       if (!/^%[a-z]+$/ || /changelog/)
+       sub(/[ \t]+$/, "");
+       if (!/^%[a-z]+$/ || /changelog/) {
+               # stop changelog if "real" changelog starts
+               if (boc == 0 && /^\* /) {
+                       boc = -1
+               }
+               if (boc == -1) {
+                       next;
+               }
                print > changelog_file
-       else
+       } else {
                print
+       }
        next
 }
 
 ###########
 # SCRIPTS #
 ###########
-/^%pre/, (/^%[a-z]+$/ && !/^%pre/) {
+/^%pre/, (!/^%pre/ && $0 ~ SECTIONS) {
+       preamble = 0
+
+       if (gsub("/usr/sbin/useradd", "%useradd")) {
+               sub(" 2> /dev/null \|\| :", "");
+               sub(" >/dev/null 2>&1 \|\|:", "");
+       }
+
+       # %useradd and %groupadd may not be wrapped
+       if (/%(useradd|groupadd).*\\$/) {
+               a = $0; getline;
+               sub(/^[\s\t]*/, "");
+               $0 = substr(a, 1, length(a) - 1) $0;
+       }
+       use_script_macros()
+}
+
+/^%post/, (!/^%post/ && $0 ~ SECTIONS) {
+       preamble = 0
+       use_macros()
+}
+/^%preun/, (!/^%preun/ && $0 ~ SECTIONS) {
+       preamble = 0
+       use_macros()
+}
+/^%postun/, (!/^%postun/ && $0 ~ SECTIONS) {
+       preamble = 0
+       use_script_macros()
+}
+/^%triggerin/, (!/^%triggerin/ && $0 ~ SECTIONS) {
+       preamble = 0
+       use_script_macros()
+}
+/^%triggerun/, (!/^%triggerun/ && $0 ~ SECTIONS) {
+       preamble = 0
+       use_script_macros()
+}
+/^%triggerpostun/, (!/^%triggerpostun/ && $0 ~ SECTIONS) {
+       preamble = 0
+       use_script_macros()
+}
+/^%pretrans/, (!/^%pretrans/ && $0 ~ SECTIONS) {
        preamble = 0
+       use_script_macros()
 }
-/^%post/, (/^%[a-z]+$/ && !/^%post/) {
+/^%posttrans/, (!/^%posttrans/ && $0 ~ SECTIONS) {
        preamble = 0
+       use_script_macros()
 }
-/^%preun/, (/^%[a-z]+$/ && !/^%preun/) {
+/^%verifyscript/, (!/^%verifyscript/ && $0 ~ SECTIONS) {
        preamble = 0
+       use_script_macros()
 }
-/^%postun/, (/^%[a-z]+$/ && !/^%postun/) {
+/^%check/, (!/^%check/ && $0 ~ SECTIONS) {
        preamble = 0
+       use_script_macros()
 }
 
 #############
@@ -336,68 +629,171 @@ preamble == 1 {
        # There should not be a space after the name of field
        # and before the colon.
        sub(/[ \t]*:/, ":")
-       
+
+       if (/^%perl_module_wo_prefix/) {
+               name = $2
+               version = $3
+               release = "0." fixedsub(".%{disttag}.at", "", $4)
+       }
+
        field = tolower($1)
        fieldnlower = $1
+       if (field ~ /summary:/ && !/etc\.$/ && !/Inc\.$/) {
+               sub(/\.$/, "", $0);
+       }
        if (field ~ /group(\([^)]+\)):/)
                next
        if (field ~ /group:/) {
                format_preamble()
-               sub(/^Utilities\//,"Applications/",$2)
-               sub(/^Games/,"Applications/Games",$2)
-               sub(/^X11\/Games/,"X11/Applications/Games",$2)
-               sub(/^X11\/GNOME\/Development\/Libraries/,"X11/Development/Libraries",$2)
-               sub(/^X11\/GNOME\/Applications/,"X11/Applications",$2)
-               sub(/^X11\/GNOME/,"X11/Applications",$2)
-               sub(/^X11\/Utilities/,"X11/Applications",$2)
-               sub(/^X11\/Games\/Strategy/,"X11/Applications/Games/Strategy",$2)
-               sub(/^Shells/,"Applications/Shells",$2)
-
-               sub(/^[^ \t]*[ \t]*/,"")
-               Grupa = $0
-
-               print "Group:\t\t" Grupa
-               if (Grupa ~ /^X11/ && x11 == 0) # Is it X11 application?
-                      x11 = 1
-
-               byl_plik_z_grupami = 0
+               group = $0;
+               sub(/^[^ \t]*[ \t]*/, "", group);
+               group = replace_groupnames(group);
+               $0 = "Group:\t\t" group
+
+               if (group ~ /^X11/ && x11 == 0) # Is it X11 application?
+                       x11 = 1
+
+               byl_plik_z_groupmi = 0
                byl_opis_grupy = 0
                while ((getline linia_grup < groups_file) > 0) {
-                       byl_plik_z_grupami = 1
-                       if (linia_grup == Grupa) {
+                       byl_plik_z_groupmi = 1
+                       if (linia_grup == group) {
                                byl_opis_grupy = 1
                                break
                        }
                }
 
-               if (!byl_plik_z_grupami)
+               if (!byl_plik_z_groupmi)
                        print "######\t\t" groups_file ": no such file"
                else if (!byl_opis_grupy)
                        print "######\t\t" "Unknown group!"
-               
+
                close(groups_file)
-               next
+               did_groups = 1
        }
-       
-       if (field ~ /packager:|distribution:|docdir:|prefix:/)
+
+       if (field ~ /prereq:/) {
+               sub(/Pre[Rr]eq:/, "Requires:", $1);
+       }
+
+       # split (build)requires, obsoletes on commas
+       if (field ~ /(obsoletes|requires|provides|conflicts):/ && NF > 2) {
+               value = substr($0, index($0, $2));
+               $0 = format_requires($1, value);
+       }
+
+       # BR: tar (and others) is to common (rpm-build requires it)
+       if (field ~ /^buildrequires:/) {
+               l = substr($0, index($0, $2));
+               if (l == "awk" ||
+                       l == "binutils" ||
+                       l == "bzip2" ||
+                       l == "cpio" ||
+                       l == "diffutils" ||
+                       l == "elfutils" ||
+                       l == "fileutils" ||
+                       l == "findutils" ||
+                       l == "glibc-devel" ||
+                       l == "grep" ||
+                       l == "gzip" ||
+                       l == "make" ||
+                       l == "patch" ||
+                       l == "sed" ||
+                       l == "sh-utils" ||
+                       l == "tar" ||
+                       l == "textutils") {
+                       next
+               }
+
+               replace_requires();
+       }
+
+       if (field ~ /^requires:/) {
+               replace_requires();
+       }
+
+
+       # obsolete/unwanted tags
+       if (field ~ /vendor:|packager:|distribution:|docdir:|prefix:|icon:|author:|author-email:|metadata-version:/) {
                next
-       
-       if (field ~ /buildroot:/)
+       }
+
+       if (field ~ /buildroot:/) {
                $0 = $1 "%{tmpdir}/%{name}-%{version}-root-%(id -u -n)"
+               did_build_root = 1
+       }
 
        # Use "License" instead of "Copyright" if it is (L)GPL or BSD
-       if (field ~ /copyright:/ && $2 ~ /GPL|BSD/)
+       if (field ~ /copyright:/ && $2 ~ /GPL|BSD/) {
                $1 = "License:"
-       
-       if (field ~ /name:/)
+       }
+
+       if (field ~ /license:/) {
+               l = substr($0, index($0, $2));
+               if (l == "Python Software Foundation License") {
+                       l = "PSF"
+               }
+               if (l == "Apache License 2.0" || l == "Apache 2.0" || l == "Apache License Version 2.0" || l == "Apache License, Version 2.0" || l == "Apache Software License v2") {
+                       l = "Apache v2.0"
+               }
+               if (l == "Apache Group License" || l == "Apache Software License" || l == "Apache License") {
+                       l = "Apache"
+               }
+               if (l == "Apache-style License" || l == "Apache-style Software License") {
+                       l = "Apache-like"
+               }
+               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;
+       }
+
+
+       if (field ~ /name:/) {
+               if ($2 == "%{name}" && name) {
+                       $2 = name
+               }
                name = $2
+               name_seen = 1;
+       }
 
-       if (field ~ /version:/)
+       if (field ~ /version:/) {
+               if ($2 == "%{version}" && version) {
+                       $2 = version
+               }
                version = $2
+               version_seen = 1;
+       }
+
+       if (field ~ /release:/) {
+               if ($2 == "%{release}" && release) {
+                       $2 = release
+               }
+               sub(/%atrelease /, "0.", $0)
+               release = $2
+               release_seen = 1;
+       }
+
 
        if (field ~ /serial:/)
                $1 = "Epoch:"
 
+       if (field ~ /home-page:/)
+               $1 = "URL:"
+
+       # proper caps
+       if (field ~ /^url:$/)
+               $1 = "URL:"
+
+       if (field ~ /^description:$/)
+               $1 = "\n%description\n"
+
        # Use %{name} and %{version} in the filenames in "Source:"
        if (field ~ /^source/ || field ~ /patch/) {
                n = split($2, url, /\//)
@@ -430,65 +826,155 @@ preamble == 1 {
                        sub(/\.pamd$/,"",url[n])
                }
 
+               # allow %{name} only in last url component
+               s = ""
+               for (i = 1; i <= n; i++) {
+                       url[i] = fixedsub("%{name}", name, url[i])
+                       if (s) {
+                               s = s "/" url[i]
+                       } else {
+                               s = url[i]
+                       }
+               }
+               $2 = s url[n+1]
+
                filename = url[n]
-               url[n] = fixedsub(name, "%{name}", url[n])
-               if (field ~ /source/) 
-                       url[n] = fixedsub(version, "%{version}", url[n])
+               if (name) {
+                       url[n] = fixedsub(name, "%{name}", url[n])
+               }
+               if (field ~ /source/) {
+                       if (version) {
+                               url[n] = fixedsub(version, "%{version}", url[n])
+                       }
+                       if (_beta) {
+                               url[n] = fixedsub(_beta, "%{_beta}", url[n])
+                       }
+                       if (_rc) {
+                               url[n] = fixedsub(_rc, "%{_rc}", url[n])
+                       }
+                       if (_pre) {
+                               url[n] = fixedsub(_pre, "%{_pre}", url[n])
+                       }
+                       if (_snap) {
+                               url[n] = fixedsub(_snap, "%{_snap}", url[n])
+                       }
+                       if (subver) {
+                               url[n] = fixedsub(subver, "%{subver}", url[n])
+                       }
+               }
+               # assigning to $2 kills preamble formatting
                $2 = fixedsub(filename, url[n], $2)
+
+               $2 = unify_url($2)
        }
 
+
        if (field ~ /^source:/)
-               $1 = "Source0:" 
+               $1 = "Source0:"
 
-       if (field ~ /patch:/)
+       if (field ~ /^patch:/)
                $1 = "Patch0:"
-       
+
+       kill_preamble_macros();
        format_preamble()
-       
-       if ($1 ~ /%define/) {
-               # Do not add %define of _prefix if it already is.
-               if ($2 ~ /^_prefix/) {
-                       sub("^"prefix, $3, bindir)
-                       sub("^"prefix, $3, sbindir)
-                       sub("^"prefix, $3, libdir)
-                       sub("^"prefix, $3, datadir)
-                       sub("^"prefix, $3, includedir)
-                       prefix = $3
-                       x11 = 2
-               }
-               if ($2 ~ /_bindir/ && !/_sbindir/)
-                       bindir = $3
-               if ($2 ~ /_sbindir/)
-                       sbindir = $3
-               if ($2 ~ /_libdir/)
-                       libdir = $3
-               if ($2 ~ /_sysconfdir/)
-                       sysconfdir = $3
-               if ($2 ~ /_datadir/)
-                       datadir = $3
-               if ($2 ~ /_includedir/)
-                       includedir = $3
-               if ($2 ~ /_mandir/)
-                       mandir = $3
-               if ($2 ~ /_infodir/)
-                       infodir = $3
+
+       if (field ~ /requires/) {
+               # atrpms
+               $0 = fixedsub("%{eversion}", "%{epoch}:%{version}-%{release}", $0);
        }
 }
 
+/^%bcond_/ {
+       # do nothing
+       print
+       next
+}
+
+# sort BR/R!
+#
+# NOTES:
+# - mixing BR/R and anything else confuses this (all will be sorted together)
+#      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 {
+       if ($1 ~ /Pre[Rr]eq:/) {
+               sub(/Pre[Rr]eq:/, "Requires:", $1);
+       }
+       if ($1 == "BR:" ) {
+               $1 = "BuildRequires:"
+       }
+       if ($1 == "R:" ) {
+               $1 = "Requires:"
+       }
+       format_preamble()
+#      kill_preamble_macros(); # breaks tabbing
+
+       b_idx++;
+       l = substr($0, index($0, $2));
+       b_ktmp = b_makekey($1, l);
+       b_key[b_idx] = b_ktmp;
+       b_val[b_ktmp] = $0;
+
+       next;
+}
 
-# main()  ;-)
+preamble == 1 {
+       if (b_idx > 0) {
+               isort(b_key, b_idx);
+               for (i = 1; i <= b_idx; i++) {
+                       v = b_val[b_key[i]];
+                       sub(/[ \t]+$/, "", v);
+                       print "" v;
+               }
+               b_idx = 0
+       }
+}
+
+# main() ;-)
 {
        preamble = 1
-       
+
        sub(/[ \t]+$/, "")
        print
+
+       if (name_seen == 0 && name) {
+               print "Name:\t\t" name
+               name_seen = 1
+       }
+
+       if (version_seen == 0 && version) {
+               print "Version:\t" version
+               version_seen = 1
+       }
+
+       if (release_seen == 0 && release) {
+               print "Release:\t" release
+               release_seen = 1
+       }
+
+       if (did_build_root == 0) {
+#              print "BuildRoot:\t%{tmpdir}/%{name}-%{version}-root-%(id -u -n)"
+               did_build_root = 1
+       }
+       if (did_groups == 0) {
+#              print "Group:\t\tunknown"
+               did_groups = 1
+       }
 }
 
 
 END {
        if (do_not_touch_anything)
                exit 0
-       
+
+       # TODO: need to output these in proper place
+       if (BR_count > 0) {
+               for (i = 0; i <= BR_count; i++) {
+                       print BR[i];
+               }
+       }
+
        close(changelog_file)
        while ((getline < changelog_file) > 0)
                print
@@ -504,67 +990,142 @@ END {
                print ""
                print "%define date\t%(echo `LC_ALL=\"C\" date +\"%a %b %d %Y\"`)"
        }
-       
-       if (has_changelog == 0)
+
+       if (has_changelog == 0) {
                print "%changelog"
+       }
 
-       if (boc > 2)
+       if (boc > 2) {
                print "* %{date} PLD Team <feedback@pld-linux.org>"
+       }
        if (boc > 1) {
                printf "All persons listed below can be reached at "
                print "<cvs_login>@pld-linux.org\n"
        }
-       if (boc > 0)
+       if (boc > 0) {
                print "$" "Log:$"
+       }
 }
 
-function fixedsub(s1,s2,t,      ind) {
 # substitutes fixed strings (not regexps)
-        if (ind = index(t,s1))
-                t = substr(t, 1, ind-1) s2 substr(t, ind+length(s1))
-        return t
+function fixedsub(s1,s2,t, ind) {
+       if (ind = index(t,s1))
+               t = substr(t, 1, ind-1) s2 substr(t, ind+length(s1))
+       return t
+}
+
+# replace s with s2 if it equals to s1
+function replace(s, s1, s2) {
+       if (s == s1) {
+               return s2;
+       } else {
+               return s;
+       }
 }
 
 # There should be one or two tabs after the colon.
 function format_preamble()
 {
+       if (/^#/ || /^%bcond_with/) {
+               return;
+       }
        sub(/:[ \t]*/, ":")
-       if (match($0, /[A-Za-z0-9(),#_ \t]+[ \t]*:[ \t]*/) == 1) {
-               if (RLENGTH < 8)
+       if (match($0, /[A-Za-z0-9(),#_ \t.-]+[ \t]*:[ \t]*/) == 1) {
+               if (RLENGTH < 8) {
                        sub(/:/, ":\t\t")
-               else
+               } else {
                        sub(/:/, ":\t")
+               }
        }
 }
 
 # Replace directly specified directories with macros
 function use_macros()
 {
+       # -m, --skip-macros, --no-macros -- skip macros subst
+       if (ENVIRON["SKIP_MACROS"]) {
+               return
+       }
+
+       # leave inline sed lines alone
+       if (/(%{__sed}|sed) -i -e/) {
+               return;
+       }
+
+       sub("%{_defaultdocdir}", "%{_docdir}");
+       sub("%{_bindir}/perl", "%{__perl}");
+       sub("%{_bindir}/python", "%{__python}");
+
+       gsub(infodir, "%{_infodir}")
+
+       gsub(perl_sitearch, "%{perl_sitearch}")
+       gsub(perl_archlib, "%{perl_archlib}")
+       gsub(perl_privlib, "%{perl_privlib}")
+       gsub(perl_vendorlib, "%{perl_vendorlib}")
+       gsub(perl_vendorarch, "%{perl_vendorarch}")
+       gsub(perl_sitelib, "%{perl_sitelib}")
+       
+       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(ruby_archdir, "%{ruby_archdir}")
+       gsub(ruby_ridir, "%{ruby_ridir}")
+       gsub(ruby_rubylibdir, "%{ruby_rubylibdir}")
+       gsub(ruby_sitearchdir, "%{ruby_sitearchdir}")
+       gsub(ruby_sitelibdir, "%{ruby_sitelibdir}")
+       gsub(ruby_rdocdir, "%{ruby_rdocdir}")
+
+       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}")
-       if(prefix"/bin" == bindir)
+       if (prefix"/bin" == bindir)
                gsub("%{_prefix}/bin", "%{_bindir}")
 
        for (c = 1; c <= NF; c++) {
                if ($c ~ sbindir "/fix-info-dir")
                        continue;
+               if ($c ~ sbindir "/webapp")
+                       continue;
+               if ($c ~ sbindir "/ldconfig")
+                       continue;
+               if ($c ~ sbindir "/chsh")
+                       continue;
+               if ($c ~ sbindir "/usermod")
+                       continue;
+               if ($c ~ sbindir "/chkconfig")
+                       continue;
+               if ($c ~ sbindir "/installzope(product|3package)")
+                       continue;
                gsub(sbindir, "%{_sbindir}", $c)
        }
 
        gsub("%{prefix}/sbin", "%{_sbindir}")
-       if(prefix"/sbin" == sbindir)
+       if (prefix"/sbin" == sbindir) {
                gsub("%{_prefix}/sbin", "%{_sbindir}")
-
-#      gsub(libdir, "%{_libdir}")
-#      gsub("%{prefix}/lib", "%{_libdir}")
-#      if(prefix"/lib" == libdir)
-#              gsub("%{_prefix}/lib", "%{_libdir}")
+       }
 
        for (c = 1; c <= NF; c++) {
                if ($c ~ sysconfdir "/{?cron.")
                        continue;
                if ($c ~ sysconfdir "/{?crontab.d")
                        continue;
+               if ($c ~ sysconfdir "/{?env.d")
+                       continue;
+               if ($c ~ sysconfdir "/{?modprobe.(d|conf)")
+                       continue;
+               if ($c ~ sysconfdir "/{?udev")
+                       continue;
+               if ($c ~ sysconfdir "/{?hotplug")
+                       continue;
                if ($c ~ sysconfdir "/{?logrotate.d")
                        continue;
                if ($c ~ sysconfdir "/{?pam.d")
@@ -579,22 +1140,69 @@ function use_macros()
                        continue;
                if ($c ~ sysconfdir "/{?sysconfig")
                        continue;
+               if ($c ~ sysconfdir "/{?shrc.d")
+                       continue;
+               if ($c ~ sysconfdir "/{?certs")
+                       continue;
+               if ($c ~ sysconfdir "/{?X11")
+                       continue;
+               if ($c ~ sysconfdir "/{?ld.so.conf.d")
+                       continue;
+               if ($c ~ sysconfdir "/{?rpm")
+                       continue;
+               if ($c ~ sysconfdir "/{?bash_completion.d")
+                       continue;
+               if ($c ~ sysconfdir "/{?samba")
+                       continue;
+               if ($c ~ sysconfdir "/shells")
+                       continue;
+               if ($c ~ sysconfdir "/ppp")
+                       continue;
+               if ($c ~ sysconfdir "/dbus-1")
+                       continue;
+               if ($c ~ sysconfdir "/tmpwatch")
+                       continue;
                gsub(sysconfdir, "%{_sysconfdir}", $c)
        }
 
-       gsub(datadir, "%{_datadir}")
+       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")
+                       continue;
+               if ($c ~ datadir "/unsermake")
+                       continue;
+               if ($c ~ datadir "/file/magic.mime")
+                       continue;
+               gsub(datadir, "%{_datadir}", $c)
+       }
+
        gsub("%{prefix}/share", "%{_datadir}")
-       if(prefix"/share" == datadir)
+       if (prefix"/share" == datadir)
                gsub("%{_prefix}/share", "%{_datadir}")
 
-       gsub(includedir, "%{_includedir}")
+       # CFLAGS="-I/usr/include/ncurses is usually correct.
+       if (!/-I\/usr\/include/) {
+               gsub(includedir, "%{_includedir}")
+       }
+
        gsub("%{prefix}/include", "%{_includedir}")
-       if(prefix"/include" == includedir)
+       if (prefix"/include" == includedir) {
                gsub("%{_prefix}/include", "%{_includedir}")
+       }
 
        gsub(mandir, "%{_mandir}")
-       if ($0 !~ "%{_datadir}/manual")
+       if ($0 !~ "%{_datadir}/manual") {
                gsub("%{_datadir}/man", "%{_mandir}")
+       }
        gsub("%{_prefix}/share/man", "%{_mandir}")
        gsub("%{prefix}/share/man", "%{_mandir}")
        gsub("%{prefix}/man", "%{_mandir}")
@@ -608,35 +1216,307 @@ function use_macros()
                gsub("%{_datadir}/aclocal", "%{_aclocaldir}")
        }
 
+       gsub(examplesdir, "%{_examplesdir}")
+
        if (prefix != "/") {
-               for (c = 1; c <= NF; c++) {
-                       if ($c ~ prefix "/sbin/fix-info-dir")
-                               continue;
-                       gsub(prefix, "%{_prefix}", $c)
+               # leave --with-foo=/usr alone
+               if ($0 !~ "--with.*=.*" prefix) {
+                       for (c = 1; c <= NF; c++) {
+                               if ($c ~ prefix "/sbin/fix-info-dir")
+                                       continue;
+                               if ($c ~ prefix "/sbin/webapp")
+                                       continue;
+                               if ($c ~ prefix "/sbin/chsh")
+                                       continue;
+                               if ($c ~ prefix "/sbin/usermod")
+                                       continue;
+                               if ($c ~ prefix "/sbin/installzope(product|3package)")
+                                       continue;
+                               if ($c ~ prefix "/share/automake")
+                                       continue;
+                               if ($c ~ prefix "/share/unsermake")
+                                       continue;
+                               if ($c ~ prefix "/lib/sendmail")
+                                       continue;
+                               if ($c ~ prefix "/lib/pkgconfig")
+                                       continue;
+
+                               # CFLAGS="-I/usr..." is usually correct.
+                               if (/-I\/usr/)
+                                       continue;
+                               # same for LDFLAGS="-L/usr..."
+                               if (/-L\/usr/)
+                                       continue;
+
+                               gsub(prefix, "%{_prefix}", $c)
+                       }
                }
                gsub("%{prefix}", "%{_prefix}")
        }
 
+       # replace back
+       gsub("%{_includedir}/ncurses", "/usr/include/ncurses")
+       gsub("%{_includedir}/freetype", "/usr/include/freetype")
+
        gsub("%{PACKAGE_VERSION}", "%{version}")
        gsub("%{PACKAGE_NAME}", "%{name}")
 
-       # we can move files between tge dirs below
-       if ($0 !~ "%{_applnkdir}") {
-               gsub("%{_datadir}/gnome/apps", "%{_applnkdir}")
-               gsub("%{_datadir}/applnk", "%{_applnkdir}")
-       }
-
        gsub("^make$", "%{__make}")
        gsub("^make ", "%{__make} ")
+       gsub("^gcc ", "%{__cc} ")
+       gsub("^rm --interactive=never ", "%{__rm} ")
+
+       # mandrake specs
+       gsub("^%make$", "%{__make}")
+       gsub("^%make ", "%{__make} ")
+       gsub("^%makeinstall_std", "%{__make} install \\\n\tDESTDIR=$RPM_BUILD_ROOT")
+       gsub("^%{makeinstall}", "%{__make} install \\\n\tDESTDIR=$RPM_BUILD_ROOT")
+       gsub("^%makeinstall", "%{__make} install \\\n\tDESTDIR=$RPM_BUILD_ROOT")
+       gsub("^%{__rm} -rf %{buildroot}", "rm -rf $RPM_BUILD_ROOT")
+       gsub("^%{__install}", "install")
+       gsub("%optflags", "%{rpmcflags}")
+       gsub("%{compat_perl_vendorarch}", "%{perl_vendorarch}")
+
+       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)
+       $0 = fixedsub("CXXFLAGS=%{rpmcflags} %configure", "CXXFLAGS=%{rpmcflags}\n%configure", $0);
+       $0 = fixedsub("%__install", "install", $0);
+
+       # split configure line to multiple lines
+       if (/%configure / && !/\\$/) {
+               $0 = format_configure($0);
+       }
+
+       gsub("%_bindir", "%{_bindir}")
+       gsub("%_datadir", "%{_datadir}")
+       gsub("%_iconsdir", "%{_iconsdir}")
+       gsub("%_sbindir", "%{_sbindir}")
+       gsub("%_mandir", "%{_mandir}")
+       gsub("%name", "%{name}")
+       gsub(/%__rm/, "rm");
+       gsub(/%__mkdir_p/, "install -d");
+       gsub(/%__cp/, "cp");
+       gsub(/%__ln_s/, "ln -s");
+       gsub(/%__sed/, "%{__sed}");
+       gsub(/%__cat/, "cat");
+       gsub(/%__chmod/, "chmod");
 
        gsub("/usr/src/linux", "%{_kernelsrcdir}")
        gsub("%{_prefix}/src/linux", "%{_kernelsrcdir}")
+
+       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 use_files_macros()
+
+function format_configure(line,                n, a, s) {
+       n = split(line, a, / /);
+       s = a[1] " \\\n";
+       for (i = 2; i <= n; i++) {
+               s = s "\t" a[i] " \\\n"
+       }
+       return s
+}
+
+
+# insertion sort of A[1..n]
+# copied from mawk manual
+function isort(A,n,            i,j,hold) {
+       for (i = 2; i <= n; i++) {
+               hold = A[j = i]
+               while (A[j-1] > hold) {
+                       j-- ; A[j+1] = A[j]
+               }
+               A[j] = hold
+       }
+       # sentinel A[0] = "" will be created if needed
+}
+
+
+function use_files_macros(     i, n, t, a, l)
 {
+       use_macros()
+
+       # skip comments
+       if (/^#/) {
+               return 1;
+       }
+
+       sub("^%doc %{_mandir}", "%{_mandir}")
+
        gsub("^%{_sbindir}", "%attr(755,root,root) %{_sbindir}")
        gsub("^%{_bindir}", "%attr(755,root,root) %{_bindir}")
+
+       # uid/gid nobody is not valid in %files
+       if (/%attr([^)]*nobody[^)]*)/ && !/FIXME/) {
+               $0 = $0 " # FIXME nobody user/group can't own files! -adapter.awk"
+       }
+
+       # s[gu]id programs with globs are evil
+       if (/%attr\([246]...,.*\*/ && !/FIXME/) {
+               $0 = $0 " # FIXME no globs for suid/sgid files"
+       }
+
+       # 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}/security", "/etc/security")
+       gsub("%{_sysconfdir}/skel", "/etc/skel")
+       gsub("%{_sysconfdir}/sysconfig", "/etc/sysconfig")
+       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$/) {
+                gsub("/etc/init.d", "/etc/rc.d/init.d")
+       }
+
+       if (/\/etc\/rc\.d\/init\.d\// && !/functions/) {
+               if (!/%attr.*\/etc\/rc\.d\/init\.d/) {
+                       $0 = "%attr(754,root,root) " $0
+               }
+               if (/^%attr.*\/etc\/rc\.d\/init\.d/ && !/^%attr\(754 *,/) {
+                       gsub("^%attr\\(... *,", "%attr(754,");
+               }
+       }
+
+       if (/lib.+\.so/ && !/\.so$/ && !/^%attr.*/ && !/%exclude/) {
+               $0 = "%attr(755,root,root) " $0
+       }
+
+       if (/%{perl_vendorarch}.*\.so$/ && !/^%attr.*/) {
+               $0 = "%attr(755,root,root) " $0
+       }
+
+       # /etc/sysconfig files
+       # %attr(640,root,root) %config(noreplace) %verify(not size mtime md5) /etc/sysconfig/*
+       # attr not required, allow default 644 attr
+       if (!/network-scripts/ && !/%dir/ && !/\.d$/ && !/functions/ && !/\/etc\/sysconfig\/wmstyle/) {
+               if (/\/etc\/sysconfig\// && /%config/ && !/%config\(noreplace/) {
+                       gsub("%config", "%config(noreplace)")
+               }
+
+               if (/\/etc\/sysconfig\// && !/%config\(noreplace/) {
+                       $NF = "%config(noreplace) " $NF
+               }
+
+               if (/\/etc\/sysconfig\// && /%attr\(755/) {
+                       gsub("^%attr\\(... *,", "%attr(640,");
+               }
+
+               if (/\/etc\/sysconfig\// && !/%verify/) {
+                       gsub("/etc/sysconfig", "%verify(not size mtime md5) /etc/sysconfig");
+               }
+       }
+
+       # kill leading zeros
+       if (/%attr\(0[1-9]/) {
+               gsub("%attr\\(0", "%attr(")
+       }
+
+       # kill leading whitespace
+       gsub(/^ +/, "");
+
+       # kill default attrs
+       gsub(/%dir %attr\(755,root,root\)/, "%dir");
+       gsub(/%attr\(755,root,root\) %dir/, "%dir");
+       if (!/%dir/) {
+               gsub(/%attr\(644,root,root\) /, "");
+       }
+
+       # sort %verify attrs
+       if (match($0, /%verify\(not([^)]+)\)/)) {
+               t = substr($0, RSTART, RLENGTH)
+               # kill commas: %verify(not,md5,size,mtime)
+               gsub(/,/, " ", t);
+
+               gsub(/^%verify\(not |\)$/, "", t)
+               n = split(t, a, / /)
+               isort(a, n)
+
+               s = "%verify(not"
+               for (i = 1 ; i <= n; i++) {
+                       s = s " " a[i]
+               }
+               s = s ")"
+
+               gsub(/%verify\(not[^)]+\)/, s)
+       }
+
+       if (/%{_mandir}/) {
+               gsub("\.gz$", "*")
+       }
+
+       # locale dir and no %lang -> bad
+       if (/%{_datadir}\/locale\/.*\// && !/%(dir|lang)/) {
+               $(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);
+       $0 = fixedsub("%{perl_bin}", "%{_bindir}", $0);
+
+       gsub(libdir "/pkgconfig", "%{_pkgconfigdir}");
+       gsub("%{_libdir}/pkgconfig", "%{_pkgconfigdir}");
+       gsub("%{_prefix}/lib/pkgconfig", "%{_pkgconfigdir}");
+
+       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()
+{
+       if (gsub("/sbin/service", "%service")) {
+               sub(" >/dev/null 2>&1 \|\|:", "");
+               sub(" 2> /dev/null \|\| :", "");
+       }
 }
 
 function fill(ch, n, i) {
@@ -646,7 +1526,7 @@ function fill(ch, n, i) {
 
 function format_flush(line, indent, newline, word, first_word) {
        first_word = 1
-       if (format_indent == -1) 
+       if (format_indent == -1)
                newline = ""
        else
                newline = fill(" ", format_indent) "- "
@@ -655,7 +1535,7 @@ function format_flush(line, indent, newline, word, first_word) {
                word = substr(line, RSTART, RLENGTH)
                if (length(newline) + length(word) + 1 > tw) {
                        print newline
-                       
+
                        if (format_indent == -1)
                                newline = ""
                        else
@@ -668,7 +1548,7 @@ function format_flush(line, indent, newline, word, first_word) {
                        first_word = 0
                } else
                        newline = newline " " word
-                       
+
                line = substr(line, RSTART + RLENGTH)
        }
        if (newline ~ /[^\t ]/) {
@@ -682,9 +1562,317 @@ function cflags(var)
                removed[var] = 1
                return 0
        }
-               
+
        if (!/!\?debug/)
                sub("\$RPM_OPT_FLAGS", "%{rpmcflags}")
        return 1
 }
 
+function unify_url(url)
+{
+
+       # sourceforge urls
+       # Docs about sourceforge mirror system: http://sourceforge.net/docs/B05/
+       sub("[?&]big_mirror=.*$", "", url);
+       sub("[?&]modtime=.*$", "", url);
+       sub("[?]use_mirror=.*$", "", url);
+       sub("[?]download$", "", url);
+
+       sub("^http://prdownloads\.sourceforge\.net/", "http://dl.sourceforge.net/", url)
+       sub("^http://download\.sf\.net/", "http://dl.sourceforge.net/", url)
+       sub("^http://download\.sourceforge\.net/", "http://dl.sourceforge.net/", url)
+       sub("^http://downloads\.sourceforge\.net/", "http://dl.sourceforge.net/", url)
+
+       sub("^http://.*\.dl\.sourceforge\.net/", "http://dl.sourceforge.net/", url)
+       sub("^http://dl\.sourceforge\.net/sourceforge/", "http://dl.sourceforge.net/", url)
+       sub("^http://dl\.sf\.net/", "http://dl.sourceforge.net/", 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)
+
+       return url
+}
+
+function demacroize(str)
+{
+       if (mod_name) {
+               sub("%{mod_name}", mod_name, str);
+       }
+       if (name) {
+               sub("%{name}", name, str);
+       }
+       if (version) {
+               sub("%{version}", version, str);
+       }
+       if (_beta) {
+               sub("%{_beta}", _beta, str);
+       }
+       if (_rc) {
+               sub("%{_rc}", _rc, str);
+       }
+       if (_pre) {
+               sub("%{_pre}", _pre, str);
+       }
+       if (_snap) {
+               sub("%{_snap}", _snap, str);
+       }
+       if (subver) {
+               sub("%{subver}", subver, str);
+       }
+       return str;
+}
+
+function kill_preamble_macros()
+{
+       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)
+       }
+}
+
+function get_epoch(pkg, ver,   epoch)
+{
+       return
+# should parse the BR lines more adequately:
+#      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 | getline epoch;
+       return epoch;
+}
+
+function format_requires(tag, value,   n, p, i, deps, ndeps) {
+       # skip any formatting for commented out items or some weird macros
+       if (/^#/ || /%\(/) {
+               return tag "\t" value
+       }
+       n = split(value, p, / *,? */);
+       for (i = 1; i <= n; i++) {
+               if (p[i+1] ~ /[<=>]/) {
+                       # add epoch if the version doesn't have it but BuildRequires.txt has
+                       if (p[i] ~ /^[a-z]/ && p[i+2] !~ /^[0-9]+:/) {
+                               epoch = get_epoch(p[i], p[i+2])
+                               if (epoch) {
+                                       p[i+2] = epoch ":" p[i+2];
+                               }
+                       }
+                       deps[ndeps++] = p[i] " " p[i+1] " " p[i+2];
+                       i += 2;
+               } else {
+                       deps[ndeps++] = p[i];
+               }
+       }
+       s = ""
+       for (i in deps) {
+               s = s sprintf("%s\t%s\n", tag, deps[i]);
+       }
+       return substr(s, 1, length(s)-1);
+}
+
+function use_tabs()
+{
+       # reverse vim: ts=4 sw=4 et
+       gsub(/    /, "\t");
+}
+
+function add_br(br)
+{
+       BR[BR_count++] = br
+}
+
+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);
+
+       # 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);
+
+       replace_php_virtual_deps()
+}
+
+# php virtual deps as discussed in devel-en
+function replace_php_virtual_deps()
+{
+       pkg = $2
+#      if (pkg == "php-program") {
+#              $0 = $1 "\t/usr/bin/php"
+#              return
+#      }
+
+#      if (pkg ~ /^php-[a-z]/ && pkg !~ /^php-(pear|common|cli|devel|fcgi|cgi|dirs|program|pecl-)/) {
+#              sub(/^php-/, "php(", pkg);
+#              sub(/$/, ") # verify this correctness -- it may be wanted to use specific not virtual dep", pkg);
+#              $2 = pkg
+#      }
+
+       if (pkg ~/^php$/) {
+               $2 = "webserver(php)";
+               if ($4 ~ /^[0-9]:/) {
+                       $4 = substr($4, 3);
+               }
+       }
+
+       if (pkg ~/^php4$/) {
+               $2 = "webserver(php)";
+               if ($4 ~ /^[0-9]:/) {
+                       $4 = substr($4, 3);
+               }
+       }
+}
+
+# Load rpm macros
+# you should update the list also in adapter when making changes here
+function import_rpm_macros() {
+       # File with rpm groups
+       topdir = ENVIRON["_topdir"]
+
+       if (!topdir) {
+               print "adapter.awk should not not be invoked directly, but via adapter script" > "/dev/stderr"
+               do_not_touch_anything = 1
+               exit(1);
+       }
+
+       # get cvsaddress for changelog section
+       # using rpm macros as too lazy to add ~/.adapterrc parsing support.
+       _cvsmaildomain = ENVIRON["_cvsmaildomain"]
+       _cvsmailfeedback = ENVIRON["_cvsmailfeedback"]
+
+       prefix = ENVIRON["_prefix"]
+       bindir = ENVIRON["_bindir"]
+       sbindir = ENVIRON["_sbindir"]
+       libdir = ENVIRON["_libdir"]
+       sysconfdir = ENVIRON["_sysconfdir"]
+       datadir = ENVIRON["_datadir"]
+       includedir = ENVIRON["_includedir"]
+       mandir = ENVIRON["_mandir"]
+       infodir = ENVIRON["_infodir"]
+       examplesdir = ENVIRON["_examplesdir"]
+       docdir = ENVIRON["_defaultdocdir"]
+       kdedocdir = ENVIRON["_kdedocdir"]
+       gtkdocdir = ENVIRON["_gtkdocdir"]
+       desktopdir = ENVIRON["_desktopdir"]
+       pixmapsdir = ENVIRON["_pixmapsdir"]
+       javadir = ENVIRON["_javadir"]
+
+       perl_sitearch = ENVIRON["perl_sitearch"]
+       perl_archlib = ENVIRON["perl_archlib"]
+       perl_privlib = ENVIRON["perl_privlib"]
+       perl_vendorlib = ENVIRON["perl_vendorlib"]
+       perl_vendorarch = ENVIRON["perl_vendorarch"]
+       perl_sitelib = ENVIRON["perl_sitelib"]
+
+       py_sitescriptdir = ENVIRON["py_sitescriptdir"]
+       py_sitedir = ENVIRON["py_sitedir"]
+       py_scriptdir = ENVIRON["py_scriptdir"]
+       py_ver = ENVIRON["py_ver"]
+
+       ruby_archdir = ENVIRON["ruby_archdir"]
+       ruby_ridir = ENVIRON["ruby_ridir"]
+       ruby_rubylibdir = ENVIRON["ruby_rubylibdir"]
+       ruby_sitearchdir = ENVIRON["ruby_sitearchdir"]
+       ruby_sitelibdir = ENVIRON["ruby_sitelibdir"]
+       ruby_rdocdir = ENVIRON["ruby_rdocdir"]
+
+       php_pear_dir = ENVIRON["php_pear_dir"]
+       php_data_dir = ENVIRON["php_data_dir"]
+       tmpdir = ENVIRON["tmpdir"]
+}
+
+function replace_groupnames(group) {
+       group = replace(group, "Amusements/Games/Strategy/Real Time", "X11/Applications/Games/Strategy");
+       group = replace(group, "Application/Multimedia", "Applications/Multimedia");
+       group = replace(group, "Application/System", "Applications/System");
+       group = replace(group, "Applications/Compilers", "Development/Languages");
+       group = replace(group, "Applications/Daemons", "Daemons");
+       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, "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/Other", "Development/Languages");;
+       group = replace(group, "Development/Languages/Ruby", "Development/Languages");
+       group = replace(group, "Development/Libraries/C and C++", "Development/Libraries");
+       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/Other", "Development");
+       group = replace(group, "Development/Python", "Development/Languages/Python");
+       group = replace(group, "Development/Testing", "Development");
+       group = replace(group, "Emulators", "Applications/Emulators");
+       group = replace(group, "Games", "Applications/Games");
+       group = replace(group, "Library/Development", "Development/Libraries");
+       group = replace(group, "Networking/Deamons", "Networking/Daemons");
+       group = replace(group, "Productivity/Databases/Servers", "Applications/Databases");
+       group = replace(group, "Productivity/Networking/Web/Servers", "Networking/Daemons/HTTP");;
+       group = replace(group, "Shells", "Applications/Shells");
+       group = replace(group, "System Environment/Base", "Base");
+       group = replace(group, "System Environment/Daemons", "Daemons");
+       group = replace(group, "System Environment/Kernel", "Base/Kernel");
+       group = replace(group, "System Environment/Libraries", "Libraries");
+       group = replace(group, "System", "Base");
+       group = replace(group, "System/Base", "Base");
+       group = replace(group, "System/Kernel and hardware", "Base/Kernel");
+       group = replace(group, "System/Libraries", "Libraries");
+       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, "Web/Database", "Applications/WWW");
+       group = replace(group, "X11/GNOME", "X11/Applications");
+       group = replace(group, "X11/GNOME/Applications", "X11/Applications");
+       group = replace(group, "X11/GNOME/Development/Libraries", "X11/Development/Libraries");
+       group = replace(group, "X11/Games", "X11/Applications/Games");
+       group = replace(group, "X11/Games/Strategy", "X11/Applications/Games/Strategy");
+       group = replace(group, "X11/Library", "X11/Libraries");
+       group = replace(group, "X11/Utilities", "X11/Applications");
+       group = replace(group, "X11/XFree86", "X11");
+       group = replace(group, "X11/Xserver", "X11/Servers");
+
+       return group;
+}
+
+# vim:ts=4:sw=4
diff --git a/builder.sh b/builder.sh
deleted file mode 100644 (file)
index 4df57b4..0000000
+++ /dev/null
@@ -1,1432 +0,0 @@
-#!/bin/sh
-# -----------
-# $Id$
-# Exit codes:
-#      0 - succesful
-#      1 - help displayed
-#      2 - no spec file name in cmdl parameters
-#      3 - spec file not stored in repo
-#      4 - some source, patch or icon files not stored in repo
-#      5 - package build failed
-#      6 - spec file with errors
-#      7 - wrong source in /etc/poldek.conf
-#  8 - Failed installing buildrequirements and subrequirements
-
-# Notes (todo):
-#      - builder -u fetches current version first
-#      - tries to get new version from distfiles without new md5
-#      - after fetching new version doesn't update md5
-#      - doesn't get sources for specs with %include /usr/lib/rpm/macros.python
-#        when there's no rpm-pythonprov (rpm's fault, but it's ugly anyway)
-#      - as above with %include /usr/lib/rpm/macros.perl and no rpm-perlprov
-#      - when Icon: field is present, -5 and -a5 doesn't work
-
-VERSION="\
-Build package utility from PLD CVS repository
-V 0.11 (C) 1999-2003 Free Penguins".
-PATH="/bin:/usr/bin:/usr/sbin:/sbin:/usr/X11R6/bin"
-
-COMMAND="build"
-
-SPECFILE=""
-BE_VERBOSE=""
-QUIET=""
-CLEAN=""
-DEBUG=""
-NOURLS=""
-NOCVS=""
-NOCVSSPEC=""
-NODIST=""
-UPDATE=""
-UPDATE5=""
-ADD5=""
-ALWAYS_CVSUP=${ALWAYS_CVSUP:-"yes"}
-CVSROOT=""
-
-# It can be used i.e. in log file naming.
-# See LOGFILE example.
-DATE=`date +%Y-%m-%d_%H-%M-%S`
-
-# Example: LOGFILE='../log.$PACKAGE_NAME'
-# Example: LOGFILE='../LOGS/log.$PACKAGE_NAME.$DATE'
-# Yes, you can use variable name! Note _single_ quotes!
-LOGFILE=''
-
-LOGDIR=""
-LOGDIROK=""
-LOGDIRFAIL=""
-LASTLOG_FILE=""
-
-CHMOD="no"
-CHMOD_MODE="0444"
-RPMOPTS=""
-BCOND=""
-GROUP_BCONDS="no"
-
-PATCHES=""
-SOURCES=""
-ICONS=""
-PACKAGE_RELEASE=""
-PACKAGE_VERSION=""
-PACKAGE_NAME=""
-PROTOCOL="ftp"
-WGET_RETRIES=${MAX_WGET_RETRIES:-0}
-CVS_RETRIES=${MAX_CVS_RETRIES:-1000}
-
-CVSTAG=""
-RES_FILE=""
-
-CVS_SERVER="cvs.pld-linux.org"
-DISTFILES_SERVER="://distfiles.pld-linux.org"
-
-DEF_NICE_LEVEL=0
-
-FAIL_IF_NO_SOURCES="yes"
-
-wget --help 2>&1 | grep -q ' \-\-inet ' && WGET_OPTS="$WGET_OPTS --inet"
-wget --help 2>&1 | grep -q ' \-\-retry\-connrefused ' && WGET_OPTS="$WGET_OPTS --retry-connrefused"
-
-GETURI="wget --passive-ftp -c -nd -t$WGET_RETRIES $WGET_OPTS"
-GETURI2="wget -c -nd -t$WGET_RETRIES $WGET_OPTS"
-GETLOCAL="cp -a"
-
-if (rpm --version 2>&1 | grep -q '4.0.[0-2]'); then
-       RPM="rpm"
-       RPMBUILD="rpm"
-else
-       RPM="rpm"
-       RPMBUILD="rpmbuild"
-fi
-
-POLDEK_INDEX_DIR="`$RPM --eval %_rpmdir`/"
-POLDEK_SOURCE="cvs"
-POLDEK_CMD="/usr/bin/poldek"
-
-# Here we load saved user environment used to
-# predefine options set above, or passed to builder
-# in command line.
-# This one reads global system environment settings:
-if [ -f ~/etc/builderrc ]; then
-       . ~/etc/builderrc
-fi
-# And this one cascades settings using user personal
-# builder settings.
-# Example of ~/.builderrc:
-#
-#UPDATE_POLDEK_INDEXES="yes"
-#FETCH_BUILD_REQUIRES="yes"
-#REMOVE_BUILD_REQUIRES="force"
-#GROUP_BCONDS="yes"
-#LOGFILE='../LOGS/log.$PACKAGE_NAME.$DATE'
-#
-if [ -n "$HOME_ETC" ]; then
-       USER_CFG=$HOME_ETC/.builderrc
-else
-       USER_CFG=~/.builderrc
-fi
-
-[ -f $USER_CFG ] && . $USER_CFG
-
-run_poldek()
-{
-       RES_FILE=~/tmp/poldek-exit-status.$RANDOM
-       if [ -n "$LOGFILE" ]; then
-               LOG=`eval echo $LOGFILE`
-               if [ -n "$LASTLOG_FILE" ]; then
-                       echo "LASTLOG=$LOG" > $LASTLOG_FILE
-               fi
-               (nice -n ${DEF_NICE_LEVEL} ${POLDEK_CMD} `while test $# -gt 0; do echo "$1 ";shift;done` ; echo $? > ${RES_FILE})|tee $LOG
-               return $exit_pldk
-       else
-               (nice -n ${DEF_NICE_LEVEL} ${POLDEK_CMD} `while test $# -gt 0; do echo "$1 ";shift;done` ; echo $? > ${RES_FILE}) 1>&2 >/dev/null
-               return `cat ${RES_FILE}`
-               rm -rf ${RES_FILE}
-       fi
-}
-
-# Example grep cvs /etc/poldek.conf:
-# source = cvs /home/users/yoshi/rpm/RPMS/
-if [ "$UPDATE_POLDEK_INDEXES" = "yes" ]; then
-       run_poldek -l -n ${POLDEK_SOURCE} 1>&2 > /dev/null
-       if [ ! "$?" == "0" ]; then
-               echo "Using improper source '${POLDEK_SOURCE}' in /etc/poldek.conf"
-               echo "Fix it and try to continue"
-               exit 7
-       fi
-fi
-
-#---------------------------------------------
-# functions
-
-usage()
-{
-       if [ -n "$DEBUG" ]; then set -xv; fi
-       echo "\
-Usage: builder [-D|--debug] [-V|--version] [-a|--as_anon] [-b|-ba|--build]
-
-[-bb|--build-binary] [-bs|--build-source] [-u|--try-upgrade]
-[{-B|--branch} <branch>] [{-d|--cvsroot} <cvsroot>] [-g|--get]
-[-h|--help] [--http] [{-l,--logtofile} <logfile>] [-m|--mr-proper]
-[-q|--quiet] [--date <yyyy-mm-dd> [-r <cvstag>] [{-T--tag <cvstag>]
-[-Tvs|--tag-version-stable] [-Tvn|--tag-version-nest]
-[-Ts|--tag-stable] [-Tn|--tag-nest] [-Tv|--tag-version]
-[{-Tp|--tag-prefix} <prefix>]
-[-nu|--no-urls] [-v|--verbose] [--opts <rpm opts>]
-[--with/--without <feature>] [--define <macro> <value>] <package>[.spec]
-       
--5, --update-md5    - update md5 comments in spec, implies -nd -ncs
--a5, --add-md5      - add md5 comments to URL sources, implies -nc -nd -ncs
--D, --debug         - enable script debugging mode,
--V, --version       - output builder version
--a, --as_anon       - get files via pserver as cvs@$CVS_SERVER,
--b, -ba, --build    - get all files from CVS repo or HTTP/FTP and build package
-                      from <package>.spec,
--bb, --build-binary - get all files from CVS repo or HTTP/FTP and build binary
-                      only package from <package>.spec,
--bs, --build-source - get all files from CVS repo or HTTP/FTP and only pack
-                      them into src.rpm,
--bp, --build-prep   - execute the %prep phase of <package>.spec,
--B, --branch        - add branch
--c, --clean         - clean all temporarily created files (in BUILD, SOURCES,
-                      SPECS and \$RPM_BUILD_ROOT),
--d <cvsroot>, --cvsroot <cvsroot>      
-                    - setup \$CVSROOT,
---define <macro> <value>
-                    - define a macro <macro> with value <value>,
---nodeps            - rpm won't check any dependences
--g, --get           - get <package>.spec and all related files from CVS repo
-                      or HTTP/FTP,
--h, --help          - this message,
---http              - use http instead of ftp,
--l <logfile>, --logtofile <logfile>
-                    - log all to file,
--m, --mr-proper     - only remove all files related to spec file and all work
-                      resources,
--nc, --no-cvs       - don't download sources from CVS, if source URL is given,
--ncs, --no-cvs-specs
-                    - don't check specs in CVS
--nd, --no-distfiles - don't download from distfiles
--nm, --no-mirrors   - don't download from mirror, if source URL is given,
--nu, --no-urls      - don't try to download from FTP/HTTP location,
--ns, --no-srcs      - don't download Sources
--ns0, --no-source0  - don't download Source0
---opts <rpm opts>   - additional options for rpm
--q, --quiet         - be quiet,
---date yyyy-mm-dd   - build package using resources from specified CVS date,
--r <cvstag>, --cvstag <cvstag>
-                    - build package using resources from specified CVS tag,
--R, --fetch-build-requires
-                    - fetch what is BuildRequired,
--RB, --remove-build-requires
-                    - remove all you fetched with -R or --fetch-build-requires
-                      remember, this option requires confirmation,
--FRB, --force-remove-build-requires
-                    - remove all you fetched with -R or --fetch-build-requires
-                      remember, this option works without confirmation,
--T <cvstag> , --tag <cvstag>
-                    - add cvs tag <cvstag> for files,
--Tvs, --tag-version-stable
-                    - add cvs tags STABLE and NAME-VERSION-RELESE for files,
--Tvn, --tag-version-nest
-                    - add cvs tags NEST and NAME-VERSION-RELESE for files,
--Ts, --tag-stable
-                    - add cvs tag STABLE for files,
--Tn, --tag-nest
-                    - add cvs tag NEST for files,
--Tv, --tag-version
-                    - add cvs tag NAME-VERSION-RELESE for files,
--Tp, --tag-prefix <prefix>
-                    - add <prefix> to NAME-VERSION-RELEASE tags,
--v, --verbose       - be verbose,
--u, --try-upgrade   - check version, and try to upgrade package
--un, --try-upgrade-with-float-version
-                    - as above, but allow float version
--U, --update        - refetch sources, don't use distfiles, and update md5 comments
--Upi, --update-poldek-indexes
-                    - refresh or make poldek package index files.
---with/--without <feature>
-                    - conditional build package depending on %_with_<feature>/
-                      %_without_<feature> macro switch.  You may now use
-                      --with feat1 feat2 feat3 --without feat4 feat5 --with feat6
-                      constructions. Set GROUP_BCONDS to yes to make use of it.
-"
-}
-
-cache_rpm_dump () {
-rpm_dump_cache=`
-       case "$RPMBUILD" in
-               rpm )
-                       rpm -bp --nodeps --define 'prep %dump' $BCOND $SPECFILE 2>&1
-                       ;;
-               rpmbuild )
-                       rpmbuild --nodigest --nosignature --define 'prep %dump' $BCOND $SPECFILE 2>&1
-                       ;;
-       esac`
-}
-
-rpm_dump () {
-       if [ -z "$rpm_dump_cache" ] ; then
-               echo "internal error: cache_rpm_dump not called!" 1>&2
-       fi
-       echo "$rpm_dump_cache"
-}
-
-parse_spec()
-{
-       if [ -n "$DEBUG" ]; then
-               set -x;
-               set -v;
-       fi
-
-       cd $SPECS_DIR
-
-       cache_rpm_dump
-
-       if [ "$NOSRCS" != "yes" ]; then
-               SOURCES="`rpm_dump | awk '/SOURCEURL[0-9]+/ {print $3}'`"
-       fi
-       if (rpm_dump | grep -qEi ":.*nosource.*1"); then
-               FAIL_IF_NO_SOURCES="no"
-       fi
-
-       PATCHES="`rpm_dump | awk '/PATCHURL[0-9]+/ {print $3}'`"
-       ICONS="`awk '/^Icon:/ {print $2}' ${SPECFILE}`"
-       PACKAGE_NAME="`$RPM -q --qf '%{NAME}\n' --specfile ${SPECFILE} 2> /dev/null | head -n 1`"
-       PACKAGE_VERSION="`$RPM -q --qf '%{VERSION}\n' --specfile ${SPECFILE} 2> /dev/null| head -n 1`"
-       PACKAGE_RELEASE="`$RPM -q --qf '%{RELEASE}\n' --specfile ${SPECFILE} 2> /dev/null | head -n 1`"
-
-       if [ -n "$BE_VERBOSE" ]; then
-               echo "- Sources :  `nourl $SOURCES`"
-               if [ -n "$PATCHES" ]; then
-                       echo "- Patches :  `nourl $PATCHES`"
-               else
-                       echo "- Patches :  *no patches needed*"
-               fi
-               if [ -n "$ICONS" ]; then
-                       echo "- Icon    :  `nourl $ICONS`"
-               else
-                       echo "- Icon    :  *no package icon*"
-               fi
-               echo "- Name    : $PACKAGE_NAME"
-               echo "- Version : $PACKAGE_VERSION"
-               echo "- Release : $PACKAGE_RELEASE"
-       fi
-}
-
-Exit_error()
-{
-       if [ -n "$DEBUG" ]; then
-               set -x;
-               set -v;
-       fi
-
-       cd "$__PWD"
-
-       case "$1" in
-               "err_no_spec_in_cmdl" )
-                       remove_build_requires
-                       echo "ERROR: spec file name not specified.";
-                       exit 2 ;;
-               "err_no_spec_in_repo" )
-                       remove_build_requires
-                       echo "Error: spec file not stored in CVS repo.";
-                       exit 3 ;;
-               "err_no_source_in_repo" )
-                       remove_build_requires
-                       echo "Error: some source, patch or icon files not stored in CVS repo. ($2)";
-                       exit 4 ;;
-               "err_build_fail" )
-                       remove_build_requires
-                       echo "Error: package build failed. (${2:-no more info})";
-                       exit 5 ;;
-       esac
-}
-
-init_builder()
-{
-       if [ -n "$DEBUG" ]; then
-               set -x;
-               set -v;
-       fi
-
-       SOURCE_DIR="`$RPM --eval '%{_sourcedir}'`"
-       SPECS_DIR="`$RPM --eval '%{_specdir}'`"
-
-       __PWD="`pwd`"
-}
-
-get_spec()
-{
-       if [ -n "$DEBUG" ]; then
-               set -x;
-               set -v;
-       fi
-
-       if [ "$NOCVSSPEC" != "yes" ]; then
-               cd $SPECS_DIR
-
-               OPTIONS="up "
-
-               if [ -n "$CVSROOT" ]; then
-                       OPTIONS="-d $CVSROOT $OPTIONS"
-               else
-                       if [ ! -s CVS/Root -a "$NOCVSSPEC" != "yes" ]; then
-                               echo "warning: No cvs access defined - using local .spec file"
-                               NOCVSSPEC="yes"
-                       fi
-               fi
-
-               if [ -z "$CVSDATE" -a -z "$CVSTAG" ]; then
-                       OPTIONS="$OPTIONS -A"
-               else
-                       if [ -n "$CVSDATE" ]; then
-                               OPTIONS="$OPTIONS -D $CVSDATE"
-                       fi
-                       if [ -n "$CVSTAG" ]; then
-                               OPTIONS="$OPTIONS -r $CVSTAG"
-                       fi
-               fi
-
-               result=1
-               retries_counter=0
-               while [ "$result" != "0" -a "$retries_counter" -le "$CVS_RETRIES" ]
-               do
-                       retries_counter=$(( $retries_counter + 1 ))
-                       output=$(LC_ALL=C cvs $OPTIONS $SPECFILE 2>&1)
-                       result=$?
-                       [ -n "$output" ] && echo "$output"
-                       if [ "$result" -ne "0" ]; then
-                               if (echo "$output" | grep -qE "(Cannot connect to|connect to .* failed|Connection reset by peer|Connection timed out|Unknown host)") && [ "$retries_counter" -le "$CVS_RETRIES" ]; then
-                                       echo "Trying again [$SPECFILE]... ($retries_counter)"
-                                       sleep 2
-                                       continue
-                               fi
-                               Exit_error err_no_spec_in_repo;
-                       fi
-               done
-       fi
-       if [ ! -f "$SPECFILE" ]; then
-               Exit_error err_no_spec_in_repo;
-       fi
-
-       if [ "$CHMOD" = "yes" -a -n "$SPECFILE" ]; then
-               chmod $CHMOD_MODE $SPECFILE
-       fi
-       unset OPTIONS
-       grep -E -m 1 "^#.*Revision:.*Date" $SPECFILE
-}
-
-find_mirror()
-{
-       cd "$SPECS_DIR"
-       url="$1"
-       if [ ! -f "mirrors" -a "$NOCVSSPEC" != "yes" ] ; then
-               cvs update mirrors >&2
-       fi
-
-       IFS="|"
-       while read origin mirror name rest
-       do
-               ol=`echo -n "$origin"|wc -c`
-               prefix="`echo -n "$url" | head -c $ol`"
-               if [ "$prefix" = "$origin" ] ; then
-                       suffix="`echo "$url"|cut -b $ol-`"
-                       echo -n "$mirror$suffix"
-                       return 0
-               fi
-       done < mirrors
-       echo "$url"
-}
-
-src_no ()
-{
-       cd $SPECS_DIR
-       rpm_dump | \
-       grep "SOURCEURL[0-9]*[  ]*$1""[         ]*$" | \
-       sed -e 's/.*SOURCEURL\([0-9][0-9]*\).*/\1/' | \
-       head -n 1 | xargs
-}
-
-src_md5 ()
-{
-       no=$(src_no "$1")
-       [ -z "$no" ] && return
-       cd $SPECS_DIR
-       spec_rev=$(grep $SPECFILE CVS/Entries | sed -e s:/$SPECFILE/:: -e s:/.*::)
-       if [ -z "$spec_rev" ]; then
-               spec_rev="$(head -n 1 $SPECFILE | sed -e 's/.*\$Revision: \([0-9.]*\).*/\1/')"
-       fi
-       spec="$SPECFILE[0-9.,]*,$(echo $spec_rev | sed 's/\./\\./g')"
-       md5=$(grep -s -v '^#' additional-md5sums | \
-       grep -E "[      ]$(basename "$1")[      ]+${spec}([     ,]|\$)" | \
-       sed -e 's/^\([0-9a-f]\{32\}\).*/\1/' | \
-       grep -E '^[0-9a-f]{32}$')
-       if [ X"$md5" = X"" ] ; then
-               grep -i "#[     ]*Source$no-md5[        ]*:" $SPECFILE | sed -e 's/.*://' | xargs
-       else
-               if [ $(echo "$md5" | wc -l) != 1 ] ; then
-                       echo "$SPECFILE: more then one entry in additional-md5sums for $1" 1>&2
-               fi
-               echo "$md5" | tail -n 1
-       fi
-}
-
-distfiles_url ()
-{
-       echo "$PROTOCOL$DISTFILES_SERVER/by-md5/$(src_md5 "$1" | sed -e 's|^\(.\)\(.\)|\1/\2/&|')/$(basename "$1")"
-}
-
-distfiles_attic_url ()
-{
-       echo "$PROTOCOL$DISTFILES_SERVER/Attic/by-md5/$(src_md5 "$1" | sed -e 's|^\(.\)\(.\)|\1/\2/&|')/$(basename "$1")"
-}
-
-good_md5 ()
-{
-       md5=$(src_md5 "$1")
-       [ "$md5" = "" ] || \
-       [ "$md5" = "$(md5sum $(nourl "$1") 2> /dev/null | sed -e 's/ .*//')" ]
-}
-
-get_files()
-{
-       GET_FILES="$@"
-
-       if [ -n "$DEBUG" ]; then
-               set -x;
-               set -v;
-       fi
-
-       if [ -n "$1$2$3$4$5$6$7$8$9${10}" ]; then
-               cd $SOURCE_DIR
-
-               OPTIONS="up "
-               if [ -n "$CVSROOT" ]; then
-                       OPTIONS="-d $CVSROOT $OPTIONS"
-               else
-                       if [ ! -s CVS/Root -a "$NOCVS" != "yes" ]; then
-                               echo "warning: No cvs access defined for SOURCES"
-                               NOCVS="yes"
-                       fi
-               fi
-               if [ -z "$CVSDATE" -a -z "$CVSTAG" ]; then
-                       OPTIONS="$OPTIONS -A"
-               else
-                       if [ -n "$CVSDATE" ]; then
-                               OPTIONS="$OPTIONS -D $CVSDATE"
-                       fi
-                       if [ -n "$CVSTAG" ]; then
-                               OPTIONS="$OPTIONS -r $CVSTAG"
-                       fi
-               fi
-               for i in $GET_FILES
-               do
-                       if [ -n "$UPDATE5" ]; then
-                               if [ -n "$ADD5" ]; then
-                                       [ `nourl $i` = "$i" ] && continue
-                                       grep -qiE '^#[  ]*Source'$(src_no $i)'-md5[     ]*:' $SPECS_DIR/$SPECFILE && continue
-                               else
-                                       grep -qiE '^#[  ]*Source'$(src_no $i)'-md5[     ]*:' $SPECS_DIR/$SPECFILE || continue
-                               fi
-                       fi
-                       FROM_DISTFILES=0
-                       if [ ! -f `nourl $i` ] || [ $ALWAYS_CVSUP = "yes" ]; then
-                               if echo $i | grep -vE '(http|ftp|https|cvs|svn)://' | grep -qE '\.(gz|bz2)$']; then
-                                       echo "Warning: no URL given for $i"
-                               fi
-
-                               if [ -n "$(src_md5 "$i")" ] && [ -z "$NODIST" ]; then
-                                       if good_md5 "$i"; then
-                                               echo "$(nourl "$i") having proper md5sum already exists"
-                                               continue
-                                       fi
-                                       target=$(nourl "$i")
-                                       url=$(distfiles_url "$i")
-                                       url_attic=$(distfiles_attic_url "$i")
-                                       FROM_DISTFILES=1
-                                       if [ `echo $url | grep -E '^(\.|/)'` ]; then
-                                               ${GETLOCAL} $url $target
-                                       else
-                                               if [ -z "$NOMIRRORS" ]; then
-                                                       url="`find_mirror "$url"`"
-                                               fi
-                                               ${GETURI} -O "$target" "$url" || \
-                                               if [ `echo $url | grep -E 'ftp://'` ]; then
-                                                       ${GETURI2} -O "$target" "$url"
-                                               fi
-                                       fi
-                                       if ! test -s "$target"; then
-                                               rm -f "$target"
-                                               if [ `echo $url_attic | grep -E '^(\.|/)'` ]; then
-                                                       ${GETLOCAL} $url_attic $target
-                                               else
-                                                       if [ -z "$NOMIRRORS" ]; then
-                                                               url_attic="`find_mirror "$url_attic"`"
-                                                       fi
-                                                       ${GETURI} -O "$target" "$url_attic" || \
-                                                       if [ `echo $url_attic | grep -E 'ftp://'` ]; then
-                                                               ${GETURI2} -O "$target" "$url_attic"
-                                                       fi
-                                               fi
-                                       fi
-                                       if ! test -s "$target"; then
-                                               rm -f "$target"
-                                               FROM_DISTFILES=0
-                                       fi
-                               elif [ -z "$(src_md5 "$i")" -a "$NOCVS" != "yes" ]; then
-                                       # ( echo $i | grep -qvE '(ftp|http|https)://' ); -- if CVS should be used, but URLs preferred
-                                       result=1
-                                       retries_counter=0
-                                       while [ "$result" != "0" -a "$retries_counter" -le "$CVS_RETRIES" ]
-                                       do
-                                               retries_counter=$(( $retries_counter + 1 ))
-                                               output=$(LC_ALL=C cvs $OPTIONS `nourl $i` 2>&1)
-                                               result=$?
-                                               [ -n "$output" ] && echo "$output"
-                                               if (echo "$output" | grep -qE "(Cannot connect to|connect to .* failed|Connection reset by peer|Connection timed out|Unknown host)") && [ "$result" -ne "0" -a "$retries_counter" -le "$CVS_RETRIES" ]; then
-                                                       echo "Trying again [`nourl $i`]... ($retries_counter)"
-                                                       sleep 2
-                                                       continue
-                                               else
-                                                       break
-                                               fi
-                                       done
-                               fi
-
-                               if [ -z "$NOURLS" ] && [ ! -f "`nourl $i`" -o -n "$UPDATE" ] && [ `echo $i | grep -E 'ftp://|http://|https://'` ]; then
-                                       if [ -z "$NOMIRRORS" ]; then
-                                               im="`find_mirror "$i"`"
-                                       else
-                                               im="$i"
-                                       fi
-                                       ${GETURI} "$im" || \
-                                       if [ `echo $im | grep -E 'ftp://'` ]; then
-                                               ${GETURI2} "$im"
-                                       fi
-                               fi
-
-                       fi
-                       srcno=$(src_no $i)
-                       if [ ! -f "`nourl $i`" -a "$FAIL_IF_NO_SOURCES" != "no" ]; then
-                               Exit_error err_no_source_in_repo $i;
-                       elif [ -n "$UPDATE5" ] && \
-                               ( ( [ -n "$ADD5" ] && echo $i | grep -q -E 'ftp://|http://|https://' && \
-                               [ -z "$(grep -E -i '^NoSource[  ]*:[    ]*'$i'([        ]|$)' $SPECS_DIR/$SPECFILE)" ] ) || \
-                               grep -q -i -E '^#[      ]*source'$(src_no $i)'-md5[     ]*:' $SPECS_DIR/$SPECFILE )
-                       then
-                               echo "Updating source-$srcno md5."
-                               md5=$(md5sum `nourl $i` | cut -f1 -d' ')
-                               perl -i -ne '
-                               print unless /^\s*#\s*Source'$srcno'-md5\s*:/i;
-                               print "# Source'$srcno'-md5:\t'$md5'\n"
-                               if /^Source'$srcno'\s*:\s+/;
-                               ' \
-                               $SPECS_DIR/$SPECFILE
-                       fi
-       
-                       if good_md5 "$i"; then
-                               :
-                       elif [ "$FROM_DISTFILES" = 1 ]; then
-                               # wrong md5 from distfiles: remove the file and try again
-                               # but only once ...
-                               echo "MD5 sum mismatch. Trying full fetch."
-                               FROM_DISTFILES=2
-                               rm -f $target
-                               ${GETURI} -O "$target" "$url" || \
-                               if [ `echo $url | grep -E 'ftp://'` ]; then
-                                       ${GETURI2} -O "$target" "$url"
-                               fi
-                               if ! test -s "$target"; then
-                                       rm -f "$target"
-                                       ${GETURI} -O "$target" "$url_attic" || \
-                                       if [ `echo $url_attic | grep -E 'ftp://'` ]; then
-                                               ${GETURI2} -O "$target" "$url_attic"
-                                       fi
-                               fi
-                               test -s "$target" || rm -f "$target"
-                       fi
-
-                       if good_md5 "$i"; then
-                               :
-                       else
-                               echo "MD5 sum mismatch.  Use -U to refetch sources,"
-                               echo "or -5 to update md5 sums, if you're sure files are correct."
-                               Exit_error err_no_source_in_repo $i
-                       fi
-               done
-
-               if [ "$CHMOD" = "yes" ]; then
-                       CHMOD_FILES="`nourl $GET_FILES`"
-                       if [ -n "$CHMOD_FILES" ]; then
-                               chmod $CHMOD_MODE $CHMOD_FILES
-                       fi
-               fi
-               unset OPTIONS
-       fi
-}
-
-tag_files()
-{
-       TAG_FILES="$@"
-
-       if [ -n "$DEBUG" ]; then
-               set -x;
-               set -v;
-       fi
-
-       if [ -n "$1$2$3$4$5$6$7$8$9${10}" ]; then
-               echo "Version: $PACKAGE_VERSION"
-               echo "Release: $PACKAGE_RELEASE"
-               # Check whether first character of PACKAGE_NAME is legal for tag name
-               if [ -z "${PACKAGE_NAME##[_0-9]*}" -a -z "$TAG_PREFIX" ]; then
-                       TAG_PREFIX=tag_
-               fi
-               TAGVER=$TAG_PREFIX$PACKAGE_NAME-`echo $PACKAGE_VERSION | sed -e "s/\./\_/g" -e "s/@/#/g"`-`echo $PACKAGE_RELEASE | sed -e "s/\./\_/g" -e "s/@/#/g"`
-               # Remove #kernel.version_release from TAGVER because tagging sources
-               # could occur with different kernel-headers than kernel-headers used at build time.
-               TAGVER=$(echo "$TAGVER" | sed -e 's/#.*//g')
-               if [ "$TAG_VERSION" = "yes" ]; then
-                       echo "CVS tag: $TAGVER"
-               fi
-               if [ -n "$TAG" ]; then
-                       echo "CVS tag: $TAG"
-               fi
-
-               OPTIONS="tag -F"
-               if [ -n "$CVSROOT" ]; then
-                       OPTIONS="-d $CVSROOT $OPTIONS"
-               fi
-
-               cd $SOURCE_DIR
-               for i in $TAG_FILES
-               do
-                       # don't tag files stored on distfiles
-                       [ -n "`src_md5 $i`" ] && continue
-                       if [ -f "`nourl $i`" ]; then
-                               if [ "$TAG_VERSION" = "yes" ]; then
-                                       cvs $OPTIONS $TAGVER `nourl $i`
-                               fi
-                               if [ -n "$TAG" ]; then
-                                       cvs $OPTIONS $TAG `nourl $i`
-                               fi
-                       else
-                               Exit_error err_no_source_in_repo $i
-                       fi
-               done
-
-               cd $SPECS_DIR
-               if [ "$TAG_VERSION" = "yes" ]; then
-                       cvs $OPTIONS $TAGVER $SPECFILE
-               fi
-               if [ -n "$TAG" ]; then
-                       cvs $OPTIONS $TAG $SPECFILE
-               fi
-
-               unset OPTIONS
-       fi
-}
-
-branch_files()
-{
-       TAG=$1
-       echo "CVS branch tag: $TAG"
-       shift;
-
-       TAG_FILES="$@"
-
-       if [ -n "$DEBUG" ]; then
-               set -x;
-               set -v;
-       fi
-
-       if [ -n "$1$2$3$4$5$6$7$8$9${10}" ]; then
-
-               OPTIONS="tag -b"
-               if [ -n "$CVSROOT" ]; then
-                       OPTIONS="-d $CVSROOT $OPTIONS"
-               fi
-               cd $SOURCE_DIR
-               for i in $TAG_FILES
-               do
-                       if [ -f `nourl $i` ]; then
-                               cvs $OPTIONS $TAG `nourl $i`
-                       else
-                               Exit_error err_no_source_in_repo $i
-                       fi
-               done
-               cd $SPECS_DIR
-               cvs $OPTIONS $TAG $SPECFILE
-
-               unset OPTIONS
-       fi
-}
-
-
-
-build_package()
-{
-       if [ -n "$DEBUG" ]; then
-               set -x;
-               set -v;
-       fi
-
-       cd $SPECS_DIR
-
-       if [ -n "$TRY_UPGRADE" ]; then
-               if [ -n "$FLOAT_VERSION" ]; then
-                       TNOTIFY=`./pldnotify.awk $SPECFILE -n`
-               else
-                       TNOTIFY=`./pldnotify.awk $SPECFILE`
-               fi
-
-               TNEWVER=`echo $TNOTIFY | awk '{ match($4,/\[NEW\]/); print $5 }'`
-
-               if [ -n "$TNEWVER" ]; then
-                       TOLDVER=`echo $TNOTIFY | awk '{ print $3; }'`
-                       echo "New version found, updating spec file to version " $TNEWVER
-                       cp -f $SPECFILE $SPECFILE.bak
-                       chmod +w $SPECFILE
-                       eval "perl -pi -e 's/Version:\t"$TOLDVER"/Version:\t"$TNEWVER"/gs' $SPECFILE"
-                       eval "perl -pi -e 's/Release:\t[1-9]{0,4}/Release:\t1/' $SPECFILE"
-                       parse_spec;
-                       get_files "$SOURCES $PATCHES";
-                       unset TOLDVER TNEWVER TNOTIFY
-               fi
-       fi
-       cd $SPECS_DIR
-
-       case "$COMMAND" in
-               build )
-                       BUILD_SWITCH="-ba" ;;
-               build-binary )
-                       BUILD_SWITCH="-bb" ;;
-               build-source )
-                       BUILD_SWITCH="-bs --nodeps" ;;
-               build-prep )
-                       BUILD_SWITCH="-bp --nodeps" ;;
-       esac
-       if [ -n "$LOGFILE" ]; then
-               LOG=`eval echo $LOGFILE`
-               if [ -n "$LASTLOG_FILE" ]; then
-                       echo "LASTLOG=$LOG" > $LASTLOG_FILE
-               fi
-               RES_FILE=~/tmp/$RPMBUILD-exit-status.$RANDOM
-               (time nice -n ${DEF_NICE_LEVEL} $RPMBUILD $BUILD_SWITCH -v $QUIET $CLEAN $RPMOPTS $BCOND $SPECFILE; echo $? > $RES_FILE) 2>&1 |tee $LOG
-               RETVAL=`cat $RES_FILE`
-               rm $RES_FILE
-               if [ -n "$LOGDIROK" ] && [ -n "$LOGDIRFAIL" ]; then
-                       if [ "$RETVAL" -eq "0" ]; then
-                               mv $LOG $LOGDIROK
-                       else
-                               mv $LOG $LOGDIRFAIL
-                       fi
-               fi
-       else
-               eval nice -n ${DEF_NICE_LEVEL} $RPMBUILD $BUILD_SWITCH -v $QUIET $CLEAN $RPMOPTS $BCOND $SPECFILE
-               RETVAL=$?
-       fi
-       if [ "$RETVAL" -ne "0" ]; then
-               if [ -n "$TRY_UPGRADE" ]; then
-                       echo "\n!!! Package with new version cannot be build automagically\n"
-                       mv -f $SPECFILE.bak $SPECFILE
-               fi
-               Exit_error err_build_fail;
-       fi
-       unset BUILD_SWITCH
-}
-
-nourl()
-{
-       echo "$@" | sed 's#\<\(ftp\|http\|https\|cvs\|svn\)://[^ ]*/##g'
-}
-
-
-install_required_packages()
-{
-       run_poldek -vi $1
-       return $?
-}
-
-set_bconds_values()
-{
-       AVAIL_BCONDS_WITHOUT=""
-       AVAIL_BCONDS_WITH=""
-       if `grep -q ^%bcond ${SPECFILE}`; then
-               BCOND_VERSION="NEW"
-       elif `grep -q bcond ${SPECFILE}`; then
-               BCOND_VERSION="OLD"
-       else
-               BCOND_VERSION="NONE"
-       fi
-       case "${BCOND_VERSION}" in
-                NONE)
-                       :
-                       ;;
-                OLD)
-                       echo "Warning: This spec has old style bconds. Fix it || die."
-                       for opt in `$RPMBUILD --bcond $SPECFILE |grep ^_without_`
-                       do
-                               AVAIL_BCOND_WITHOUT=`echo $opt|sed -e "s/^_without_//g"`
-                               if `echo $BCOND|grep -q -- "--without $AVAIL_BCOND_WITHOUT"`;then
-                                       AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT <$AVAIL_BCOND_WITHOUT>"
-                               else
-                                       AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT $AVAIL_BCOND_WITHOUT"
-                               fi
-                       done
-               
-                       for opt in `$RPMBUILD --bcond $SPECFILE |grep ^_with_`
-                       do
-                               AVAIL_BCOND_WITH=`echo $opt|sed -e "s/^_with_//g"`
-                               if `echo $BCOND|grep -q -- "--with $AVAIL_BCOND_WITH"`;then
-                                       AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH <$AVAIL_BCOND_WITH>"
-                               else
-                                       AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH $AVAIL_BCOND_WITH"
-                               fi
-                       done
-                       ;;
-               NEW)
-                       cond_type="" # with || without
-                       for opt in `$RPMBUILD --bcond $SPECFILE`
-                       do
-                               case "$opt" in
-                                       _without)
-                                               cond_type="without"
-                                               ;;
-                                       _with)
-                                               cond_type="with"
-                                               ;;
-                                       *)
-                                               case "$cond_type" in
-                                                       with)
-                                                               cond_type=''
-                                                               AVAIL_BCOND_WITH="$opt"
-                                                               if `echo $BCOND|grep -q -- "--with $AVAIL_BCOND_WITH"`;then
-                                                                       AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH <$AVAIL_BCOND_WITH>"
-                                                               else
-                                                                       AVAIL_BCONDS_WITH="$AVAIL_BCONDS_WITH $AVAIL_BCOND_WITH"
-                                                               fi
-                                                               ;;
-                                                       without)
-                                                               cond_type=''
-                                                               AVAIL_BCOND_WITHOUT="$opt"
-                                                               if `echo $BCOND|grep -q -- "--without $AVAIL_BCOND_WITHOUT"`;then
-                                                                       AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT <$AVAIL_BCOND_WITHOUT>"
-                                                               else
-                                                                       AVAIL_BCONDS_WITHOUT="$AVAIL_BCONDS_WITHOUT $AVAIL_BCOND_WITHOUT"
-                                                               fi
-                                                               ;;
-                                               esac
-                                               ;;
-                               esac
-                       done
-                       ;;
-       esac
-}
-
-run_sub_builder()
-{
-       package_name="${1}"
-       echo -ne "Package installation failed:\t$package_name\n"
-       #
-       # No i tutaj bym chcia³ zrobiæ sztuczn± inteligencjê, która spróbuje tego
-       # pakieta zbudowaæ. Aktualnie niewiele dziala, bo generalnie nie widze do
-       # konca algorytmu... Ale damy rade. :) Na razie po prostu sie wyjebie tak samo
-       # jakby nie bylo tego kawalka kodu.
-       #
-       # Update: Poprawi³em parê rzeczy i zaczê³o generowaæ pakiety spoza zadanej listy.
-       #         Jednym s³owem budowanie niespoldkowanych zale¿no¶ci dzia³a w paru przypadkach.
-       #
-       #
-       # y0shi.
-
-       parent_spec_name=''
-
-
-       # Istnieje taki spec? ${package}.spec
-       if [ -f "${SPECS_DIR}${package}.spec" ]; then
-               parent_spec_name=${package}.spec
-       elif [ -f "${SPECS_DIR}`echo ${package_name}|sed -e s,-devel.*,,g -e s,-static,,g`.spec" ]; then
-               parent_spec_name="`echo ${package_name}|sed -e s,-devel.*,,g -e s,-static,,g`.spec"
-       else
-               for provides_line in `grep ^Provides:.*$package  ${SPECS_DIR} -R`
-               do
-                       echo $provides_line
-               done
-       fi
-
-       if [ "${parent_spec_name}" != "" ]; then
-               sub_builder_opts=''
-               if [ "${FETCH_BUILD_REQUIRES}" == "yes" ]; then
-                       sub_builder_opts="${sub_builder_opts} -R"
-               fi
-               if [ "${REMOVE_BUILD_REQUIRES}" == "nice" ]; then
-                       sub_builder_opts="${sub_builder_opts} -RB"
-               elif [ "${REMOVE_BUILD_REQUIRES}" == "force" ]; then
-                       sub_builder_opts="${sub_builder_opts} -FRB"
-               fi
-               if [ "${UPDATE_POLDEK_INDEXES}" == "yes" ]; then
-                       sub_builder_opts="${sub_builder_opts} -Upi"
-               fi
-               cd "${SPECS_DIR}"
-               ./builder ${sub_builder_opts} ${parent_spec_name}
-       fi
-       NOT_INSTALLED_PACKAGES="$NOT_INSTALLED_PACKAGES $package_name"
-}
-
-remove_build_requires()
-{
-       if [ "$INSTALLED_PACKAGES" != "" ]; then
-               case "$REMOVE_BUILD_REQUIRES" in
-                       "force")
-                               run_poldek --noask -ve $INSTALLED_PACKAGES
-                               ;;
-                       "nice")
-                               run_poldek --ask -ve $INSTALLED_PACKAGES
-                               ;;
-                       *)
-                               echo You may want to manually remove following BuildRequires fetched:
-                               echo $INSTALLED_PACKAGES
-                               echo Try poldek -e \`cat `pwd`/.${SPECFILE}_INSTALLED_PACKAGES\`
-                               ;;
-               esac
-       fi
-}
-
-display_bconds()
-{
-       if [ "$AVAIL_BCONDS_WITH" != "" ] || [ "$AVAIL_BCONDS_WITHOUT" != "" ]; then
-               echo -ne "We are going to build $SPECFILE with the following conditional flags:\n"
-               if [ "$BCOND" != "" ]; then
-                       echo -ne "$BCOND"
-               else
-                       echo -ne "No --with || --without conditions passed to $0!"
-               fi
-               echo -ne "\n\nfrom available:\n\n"
-               echo -ne "--with   :\t$AVAIL_BCONDS_WITH\n--without:\t$AVAIL_BCONDS_WITHOUT\n\n"
-       fi
-}
-
-fetch_build_requires()
-{
-       if [ "${FETCH_BUILD_REQUIRES}" == "yes" ]; then
-               echo -ne "\nAll packages installed by fetch_build_requires() are written to:\n"
-               echo -ne "`pwd`/.${SPECFILE}_INSTALLED_PACKAGES\n"
-               echo -ne "\nIf anything fails, you may get rid of them by executing:\n"
-               echo "poldek -e \`cat `pwd`/.${SPECFILE}_INSTALLED_PACKAGES\`\n\n"
-               echo > `pwd`/.${SPECFILE}_INSTALLED_PACKAGES
-               for package_item in `cat $SPECFILE|grep -B100000 ^%changelog|grep -v ^#|grep BuildRequires|grep -v ^-|sed -e "s/^.*BuildRequires://g"|awk '{print $1}'|sed -e s,perl\(,perl-,g -e s,::,-,g -e s,\(.*\),,g -e s,%{,,g -e s,},,g|grep -v OpenGL-devel|sed -e s,sh-utils,coreutils,g -e s,fileutils,coreutils,g -e s,kgcc_package,gcc,g -e s,\),,g`
-               do
-                       package_item="`echo $package_item|sed -e s,rpmbuild,rpm-build,g |sed -e s,__perl,perl,g |sed -e s,gasp,binutils-gasp,g -e s,binutils-binutils,binutils,g -e s,apxs,apache,g|sed -e s,apache\(EAPI\)-devel,apache-devel,g -e s,kernel-headers\(netfilter\),kernel-headers,g -e s,awk,mawk,g -e s,mmawk,mawk,g -e s,motif,openmotif,g -e s,openopenmotif,openmotif,g`"
-                       GO="yes"
-                       package=`basename "$package_item"|sed -e "s/}$//g"`
-                       COND_ARCH_TST="`cat $SPECFILE|grep -B1 BuildRequires|grep -B1 $package|grep ifarch|sed -e "s/^.*ifarch//g"`"
-                       mach=`uname -m`
-               
-                       COND_TST=`cat $SPECFILE|grep BuildRequires|grep "$package"`
-                       if `echo $COND_TST|grep -q '^BuildRequires:'`; then
-                               if [ "$COND_ARCH_TST" != "" ] && [ "`echo $COND_ARCH_TST|sed -e "s/i.86/ix86/g"`" != "`echo $mach|sed -e "s/i.86/ix86/g"`" ]; then
-                                       GO="yes"
-                               fi
-                       # bcond:
-                       else
-                               COND_NAME=`echo $COND_TST|sed -e s,:BuildRequires:.*$,,g`
-                               GO=""
-                               # %{without}
-                               if `echo $COND_TST|grep -q 'without_'`; then
-                                       COND_NAME=`echo $COND_NAME|sed -e s,^.*_without_,,g`
-                                       if `echo $COND_TST|grep -q !`; then
-                                               COND_STATE="with"
-                                       else
-                                               COND_STATE="wout"
-                                       fi
-                                       if `echo $AVAIL_BCONDS_WITHOUT|grep -q "<$COND_NAME>"`; then
-                                               COND_ARGV="wout"
-                                       else
-                                               COND_ARGV="with"
-                                       fi
-                               # %{with}
-                               elif `echo $COND_TST|grep -q 'with_'`; then
-                                       COND_NAME=`echo $COND_NAME|sed -e s,^.*_with_,,g`
-                                       if `echo $COND_TST|grep -q !`; then
-                                               COND_STATE="wout"
-                                       else
-                                               COND_STATE="with"
-                                       fi                                      
-                                       if `echo $AVAIL_BCONDS_WITH|grep -q "<$COND_NAME>"`; then
-                                               COND_ARGV="with"
-                                       else
-                                               COND_ARGV="wout"
-                                       fi      
-                               fi
-                               RESULT="${COND_STATE}-${COND_ARGV}"
-                               case "$RESULT" in
-                                       "with-wout" | "wout-with" )
-                                               GO=""
-                                               ;;
-                                       "wout-wout" | "with-with" )
-                                               GO="yes"
-                                               ;;
-                                       * )
-                                               echo "Action '$RESULT' was not defined for package '$package_item'"
-                                               GO="yes"
-                                               ;;
-                               esac
-                       fi
-
-                       if [ "$GO" = "yes" ]; then
-                               if [ "`rpm -q $package|sed -e "s/$package.*/$package/g"`" != "$package" ]; then
-                                       echo "Testing if $package has subrequirements..."
-                                       run_poldek -t -i $package --dumpn=".$package-req.txt"
-                                       if [ -f ".$package-req.txt" ]; then
-                                               for package_name in `cat ".$package-req.txt"|grep -v ^#`
-                                               do
-                                                       if [ "$package_name" = "$package" ]; then
-                                                               echo -ne "Installing BuildRequired package:\t$package_name\n"
-                                                               export PROMPT_COMMAND=`echo -ne "\033]0;${SPECFILE}: Installing BuildRequired package: ${package_name}\007"`
-                                                               install_required_packages $package;
-                                                       else
-                                                               echo -ne "Installing (sub)Required package:\t$package_name\n"
-                                                               export PROMPT_COMMAND=`echo -ne "\033]0;${SPECFILE}: Installing (sub)Required package: ${package_name}\007"`
-                                                               install_required_packages $package_name;
-                                                       fi
-                                                       case $? in
-                                                               0)
-                                                                       INSTALLED_PACKAGES="$package_name $INSTALLED_PACKAGES"
-                                                                       echo $package_name >> `pwd`/.${SPECFILE}_INSTALLED_PACKAGES
-                                                                       ;;
-                                                               *)
-                                                                       echo "Attempting to run spawn sub - builder..."
-                                                                       run_sub_builder $package_name
-                                                                       if [ $? -eq 0 ]; then
-                                                                               install_required_packages $package_name;
-                                                                               case $? in
-                                                                                       0)
-                                                                                               INSTALLED_PACKAGES="$package_name $INSTALLED_PACKAGES"
-                                                                                               echo $package_name >> `pwd`/.${SPECFILE}_INSTALLED_PACKAGES
-                                                                                               ;;
-                                                                                       *)
-                                                                                               NOT_INSTALLED_PACKAGES="$package_name $NOT_INSTALLED_PACKAGES"
-                                                                                               ;;
-                                                                               esac
-                                                                       fi
-                                                                       ;;
-                                                       esac
-                                               done
-                                               rm -f ".$package-req.txt"
-                                       else
-                                               echo "Attempting to run spawn sub - builder..."
-                                               run_sub_builder $package
-                                               if [ $? -eq 0 ]; then
-                                                       install_required_packages $package;
-                                                       case $? in
-                                                               0)
-                                                                       INSTALLED_PACKAGES="$package_name $INSTALLED_PACKAGES"
-                                                                       echo $package_name >> `pwd`/.${SPECFILE}_INSTALLED_PACKAGES
-                                                                       ;;
-                                                               *)
-                                                                       NOT_INSTALLED_PACKAGES="$package_name $NOT_INSTALLED_PACKAGES"
-                                                                       ;;
-                                                       esac
-                                               fi
-                                       fi
-                               else
-                                       echo "Package $package is already installed. BuildRequirement satisfied."
-                               fi
-                       fi
-               done
-               export PROMPT_COMMAND=`echo -ne "\033]0;${SPECFILE}\007"`
-               if [ "$NOT_INSTALLED_PACKAGES" != "" ]; then
-                       echo "Nie uda³o siê zainstalowaæ nastêpuj±cych pakietów i ich zale¿no¶ci:"
-                       for pkg in "$NOT_INSTALLED_PACKAGES"
-                       do
-                               echo $pkg
-                       done
-                       remove_build_requires
-                       exit 8
-               fi
-       fi
-}
-
-#---------------------------------------------
-# main()
-
-if [ "$#" = 0 ]; then
-       usage;
-       exit 1
-fi
-
-while test $# -gt 0
-do
-       case "${1}" in
-               -5 | --update-md5 )
-                       COMMAND="get";
-                       NODIST="yes"
-                       NOCVSSPEC="yes"
-                       UPDATE5="yes"
-                       shift ;;
-               -a5 | --add-md5 )
-                       COMMAND="get";
-                       NODIST="yes"
-                       NOCVS="yes"
-                       NOCVSSPEC="yes"
-                       UPDATE5="yes"
-                       ADD5="yes"
-                       shift ;;
-               -D | --debug )
-                       DEBUG="yes"; shift ;;
-               -V | --version )
-                       COMMAND="version"; shift ;;
-               -a | --as_anon )
-                       CVSROOT=":pserver:cvs@$CVS_SERVER:/cvsroot"; shift ;;
-               -b | -ba | --build )
-                       COMMAND="build"; shift ;;
-               -bb | --build-binary )
-                       COMMAND="build-binary"; shift ;;
-               -bs | --build-source )
-                       COMMAND="build-source"; shift ;;
-               -bp | --build-prep )
-                       COMMAND="build-prep"; shift ;;
-               -B | --branch )
-                       COMMAND="branch"; shift; TAG="${1}"; shift;;
-               -c | --clean )
-                       CLEAN="--clean --rmspec --rmsource"; shift ;;
-               -d | --cvsroot )
-                       shift; CVSROOT="${1}"; shift ;;
-               -g | --get )
-                       COMMAND="get"; shift ;;
-               -h | --help )
-                       COMMAND="usage"; shift ;;
-               --http )
-                       PROTOCOL="http"; shift ;;
-               -l | --logtofile )
-                       shift; LOGFILE="${1}"; shift ;;
-               -ni| --nice )
-                       shift; DEF_NICE_LEVEL=${1}; shift ;;
-               -m | --mr-proper )
-                       COMMAND="mr-proper"; shift ;;
-               -nc | --no-cvs )
-                       NOCVS="yes"; shift ;;
-               -ncs | --no-cvs-specs )
-                       NOCVSSPEC="yes"; shift ;;
-               -nd | --no-distfiles )
-                       NODIST="yes"; shift ;;
-               -nm | --no-mirrors )
-                       NOMIRRORS="yes"; shift ;;
-               -nu | --no-urls )
-                       NOURLS="yes"; shift ;;
-               -ns | --no-srcs )
-                       NOSRCS="yes"; shift ;;
-               -ns0 | --no-source0 )
-                       NOSOURCE0="yes"; shift ;;
-               --opts )
-                       shift; RPMOPTS="${1}"; shift ;;
-               --with | --without )
-                       case $GROUP_BCONDS in
-                               "yes")
-                                       COND=${1}
-                                       shift
-                                       while ! `echo ${1}|grep -qE '(^-|spec)'`
-                                       do
-                                               BCOND="$BCOND $COND $1"
-                                               shift
-                                       done;;
-                               "no")
-                                       BCOND="$BCOND $1 $2" ; shift 2 ;;
-                       esac
-                       ;;
-               -q | --quiet )
-                       QUIET="--quiet"; shift ;;
-               --date )
-                       CVSDATE="${2}"; shift 2 ;;
-               -r | --cvstag )
-                       shift; CVSTAG="${1}"; shift ;;
-               -R | --fetch-build-requires)
-                       FETCH_BUILD_REQUIRES="yes"
-                       NOT_INSTALLED_PACKAGES=
-                       shift ;;
-               -RB | --remove-build-requires)
-                       REMOVE_BUILD_REQUIRES="nice"
-                       shift ;;
-               -FRB | --force-remove-build-requires)
-                       REMOVE_BUILD_REQUIRES="force"
-                       shift ;;
-               -Tvs | --tag-version-stable )
-                       COMMAND="tag";
-                       TAG="STABLE"
-                       TAG_VERSION="yes"
-                       shift;;
-               -Tvn | --tag-version-nest )
-                       COMMAND="tag";
-                       TAG="NEST"
-                       TAG_VERSION="yes"
-                       shift;;
-               -Ts | --tag-stable )
-                       COMMAND="tag";
-                       TAG="STABLE"
-                       TAG_VERSION="no"
-                       shift;;
-               -Tn | --tag-nest )
-                       COMMAND="tag";
-                       TAG="NEST"
-                       TAG_VERSION="no"
-                       shift;;
-               -Tv | --tag-version )
-                       COMMAND="tag";
-                       TAG=""
-                       TAG_VERSION="yes"
-                       shift;;
-               -Tp | --tag-prefix )
-                       TAG_PREFIX="$2"
-                       shift 2;;
-               -T | --tag )
-                       COMMAND="tag";
-                       shift
-                       TAG="$1"
-                       TAG_VERSION="no"
-                       shift;;
-               -U | --update )
-                       COMMAND="get"
-                       UPDATE="yes"
-                       NOCVSSPEC="yes"
-                       NODIST="yes"
-                       UPDATE5="yes"
-                       shift ;;
-               -Upi | --update-poldek-indexes )
-                       UPDATE_POLDEK_INDEXES="yes"
-                       shift ;;
-               -u | --try-upgrade )
-                       TRY_UPGRADE="1"; shift ;;
-               -un | --try-upgrade-with-float-version )
-                       TRY_UPGRADE="1"; FLOAT_VERSION="1"; shift ;;
-               -v | --verbose )
-                       BE_VERBOSE="1"; shift ;;
-               --define)
-                       shift
-                       MACRO="${1}"
-                       VALUE="${2}"
-                       shift 2
-                       RPMOPTS="${RPMOPTS} --define \"${MACRO} ${VALUE}\""
-                       ;;
-               --nodeps)
-                       shift
-                       RPMOPTS="${RPMOPTS} --nodeps"
-                       ;;
-               * )
-                       SPECFILE="`basename ${1} .spec`.spec";
-                       export PROMPT_COMMAND=`echo -ne "\033]0;${SPECFILE}\007"`
-                       shift ;;
-       esac
-done
-
-if [ -n "$DEBUG" ]; then
-       set -x;
-       set -v;
-fi
-
-case "$COMMAND" in
-       "build" | "build-binary" | "build-source" | "build-prep" )
-               init_builder;
-               if [ -n "$SPECFILE" ]; then
-               get_spec;
-               set_bconds_values;
-               display_bconds;
-               fetch_build_requires;
-               parse_spec;
-
-               if [ -n "$FAIL_IF_CHANGED_BUT_NOT_BUMPED" ]; then
-                       TAGVER=$PACKAGE_NAME-`echo $PACKAGE_VERSION | sed -e "s/\./\_/g" -e "s/@/#/g"`-`echo $PACKAGE_RELEASE | sed -e "s/\./\_/g" -e "s/@/#/g"`
-                       CURTAGREL=$(cvs status $SPECFILE | grep "Working revision:" | awk '{ print $3 }')
-                       TAGREL=$(cvs status -v $SPECFILE | grep -E "^[[:space:]]*${TAGVER}[[[:space:]]" | sed -e 's#.*(revision: ##g' -e 's#).*##g')
-
-                       if [ -n "$TAGREL" -a "$TAGREL" != "$CURTAGREL" ]; then
-                               Exit_error err_build_fail "not bumped ver-rel - was already used in rev $TAGREL"
-                       fi
-               fi
-
-               if [ -n "$ICONS" ]; then
-                       get_files $ICONS;
-                       parse_spec;
-               fi
-               if [ -n "$NOSOURCE0" ] ; then
-                       SOURCES=`echo $SOURCES | xargs | sed -e 's/[^ ]*//'`
-               fi
-               get_files "$SOURCES $PATCHES";
-               build_package;
-               if [ "$UPDATE_POLDEK_INDEXES" = "yes" ]; then
-                       run_poldek --sn ${POLDEK_SOURCE} --mkidx="${POLDEK_INDEX_DIR}/packages.dir.gz"
-                       run_poldek --sn ${POLDEK_SOURCE} --up
-               fi
-               remove_build_requires;
-       else
-               Exit_error err_no_spec_in_cmdl;
-       fi
-       ;;
-       "branch" )
-               init_builder;
-               if [ -n "$SPECFILE" ]; then
-                       get_spec;
-                       parse_spec;
-                       if [ -n "$ICONS" ]; then
-                               get_files $ICONS
-                               parse_spec;
-                       fi
-                       get_files $SOURCES $PATCHES;
-                       branch_files $TAG "$SOURCES $PATCHES $ICONS";
-               else
-                       Exit_error err_no_spec_in_cmdl;
-               fi
-               ;;
-       "get" )
-               init_builder;
-               if [ -n "$SPECFILE" ]; then
-                       get_spec;
-                       parse_spec;
-                       if [ -n "$ICONS" ]; then
-                               get_files $ICONS
-                               parse_spec;
-                       fi
-                       if [ -n "$NOSOURCE0" ] ; then
-                               SOURCES=`echo $SOURCES | xargs | sed -e 's/[^ ]*//'`
-                       fi
-                       get_files $SOURCES $PATCHES
-               else
-                       Exit_error err_no_spec_in_cmdl;
-               fi
-               ;;
-       "tag" )
-               NOURLS=1
-               NODIST=1
-               init_builder;
-               if [ -n "$SPECFILE" ]; then
-                       get_spec;
-                       parse_spec;
-                       if [ -n "$ICONS" ]; then
-                               get_files $ICONS
-                               parse_spec;
-                       fi
-                       # don't fetch sources from remote locations
-                       new_SOURCES=""
-                       for file in $SOURCES
-                       do
-                               [ -n "`src_md5 $file`" ] && continue
-                               new_SOURCES="$new_SOURCES $file"
-                       done
-                       SOURCES="$new_SOURCES"
-                       get_files $SOURCES $PATCHES;
-                       tag_files "$SOURCES $PATCHES $ICONS";
-               else
-                       Exit_error err_no_spec_in_cmdl;
-               fi
-               ;;
-       "mr-proper" )
-               $RPM --clean --rmsource --rmspec --force --nodeps $SPECFILE
-               ;;
-       "usage" )
-               usage;;
-       "version" )
-               echo "$VERSION";;
-esac
-test -f `pwd`/.${SPECFILE}_INSTALLED_PACKAGES && rm `pwd`/.${SPECFILE}_INSTALLED_PACKAGES
-cd "$__PWD"
-
-# vi:syntax=sh:ts=3:sw=4
diff --git a/pldnotify.awk b/pldnotify.awk
deleted file mode 100644 (file)
index c0da0a1..0000000
+++ /dev/null
@@ -1,368 +0,0 @@
-#!/bin/awk -f
-# $Revision$, $Date$
-function fixedsub(s1,s2,t,     ind) {
-# substitutes fixed strings (not regexps)
-       if (ind = index(t,s1)) {
-               t = substr(t, 1, ind-1) s2 substr(t, ind+length(s1))
-       }
-       return t
-}
-
-function ispre(s) {
-       if ((s~"pre")||(s~"PRE")||(s~"beta")||(s~"BETA")||(s~"alpha")||(s~"ALPHA")||(s~"rc")||(s~"RC")) {
-               if (DEBUG) print "pre-version"
-               return 1
-       } else {
-               return 0
-       }
-}
-       
-function compare_ver(v1,v2) {
-# compares version numbers
-       while (match(v1,/[a-zA-Z][0-9]|[0-9][a-zA-Z]/))
-               v1=(substr(v1,1,RSTART) "." substr(v1,RSTART+RLENGTH-1))
-       while (match(v2,/[a-zA-Z][0-9]|[0-9][a-zA-Z]/))
-               v2=(substr(v2,1,RSTART) "." substr(v2,RSTART+RLENGTH-1))
-       sub("^0*","",v1)
-       sub("^0*","",v2)
-       gsub("\.0*",".",v1)
-       gsub("\.0*",".",v2)
-       if (DEBUG) print "v1 == " v1
-       if (DEBUG) print "v2 == " v2
-       count=split(v1,v1a,"\.")
-       count2=split(v2,v2a,"\.")
-       
-       if (count<count2) mincount=count 
-       else mincount=count2
-       
-       for (i=1; i<=mincount; i++) {
-               if (v1a[i]=="") v1a[i]=0
-               if (v2a[i]=="") v2a[i]=0
-               if (DEBUG) print "i == " i
-               if (DEBUG) print "v1[i] == " v1a[i]
-               if (DEBUG) print "v2[i] == " v2a[i]
-               if ((v1a[i]~/[0-9]/)&&(v2a[i]~/[0-9]/)) {
-                       if (length(v2a[i])>length(v1a[i]))
-                               return 1
-                       else if (v2a[i]>v1a[i])
-                               return 1
-                       else if (length(v1a[i])>length(v2a[i]))
-                               return 0
-                       else if (v1a[i]>v2a[i])
-                               return 0
-               } else if ((v1a[i]~/[A-Za-z]/)&&(v2a[i]~/[A-Za-z]/)) {
-                       if (v2a[i]>v1a[i])
-                               return 1
-                       else if (v1a[i]>v2a[i])
-                               return 0
-               } else if (ispre(v1a[i]) == 1)
-                       return 1
-               else
-                       return 0
-       }
-       if ((count2==mincount)&&(count!=count2)) {
-               for (i=count2+1; i<=count; i++)
-                       if (ispre(v1a[i]) == 1)
-                               return 1
-               return 0
-       } else if (count!=count2) {
-               for (i=count+1; i<=count2; i++)
-                       if (ispre(v2a[i]) == 1)
-                               return 0
-               return 1
-       }
-       return 0
-}
-
-function compare_ver_dec(v1,v2) {
-# compares version numbers as decimal floats
-       while (match(v1,/[0-9][a-zA-Z]/))
-               v1=(substr(v1,1,RSTART) "." substr(v1,RSTART+RLENGTH-1))
-       while (match(v2,/[0-9][a-zA-Z]/))
-               v2=(substr(v2,1,RSTART) "." substr(v2,RSTART+RLENGTH-1))
-       sub("^0*","",v1)
-       sub("^0*","",v2)
-       if (DEBUG) print "v1 == " v1
-       if (DEBUG) print "v2 == " v2
-       count=split(v1,v1a,"\.")
-       count2=split(v2,v2a,"\.")
-       
-       if (count<count2) mincount=count 
-       else mincount=count2
-       
-       for (i=1; i<=mincount; i++) {
-               if (v1a[i]=="") v1a[i]=0
-               if (v2a[i]=="") v2a[i]=0
-               if (DEBUG) print "i == " i
-               if (DEBUG) print "v1[i] == " v1a[i]
-               if (DEBUG) print "v2[i] == " v2a[i]
-               if ((v1a[i]~/[0-9]/)&&(v2a[i]~/[0-9]/)) {
-                       if (i==2) {
-                               if (0+("." v2a[i])>0+("." v1a[i]))
-                                       return 1
-                               else if (0+("." v1a[i])>0+("." v2a[i]))
-                                       return 0
-                       } else {
-                               if (length(v2a[i])>length(v1a[i]))
-                                       return 1
-                               else if (v2a[i]>v1a[i])
-                                       return 1
-                               else if (length(v1a[i])>length(v2a[i]))
-                                       return 0
-                               else if (v1a[i]>v2a[i])
-                                       return 0
-                       }
-               } else if ((v1a[i]~/[A-Za-z]/)&&(v2a[i]~/[A-Za-z]/)) {
-                       if (v2a[i]>v1a[i])
-                               return 1
-                       else if (v1a[i]>v2a[i])
-                               return 0
-               } else if (ispre(v1a[i]) == 1)
-                       return 1
-               else
-                       return 0
-       }
-       if ((count2==mincount)&&(count!=count2)) {
-               for (i=count2+1; i<=count; i++)
-                       if (ispre(v1a[i]) == 1)
-                               return 1
-               return 0
-       } else if (count!=count2) {
-               for (i=count+1; i<=count2; i++)
-                       if (ispre(v2a[i]) == 1)
-                               return 0
-               return 1
-       }
-       return 0
-}
-
-function get_links(url,        errno,link,oneline,retval,odp,tmpfile) {
-# get all <A HREF=..> tags from specified URL
-       "mktemp /tmp/XXXXXX" | getline tmpfile
-       close("mktemp /tmp/XXXXXX")
-       
-       if (DEBUG) print "Retrieving: " url
-       errno=system("wget -O - \"" url "\" -t 3 -T 300 --passive-ftp > " tmpfile " 2>/dev/null" )
-       
-       if (errno==0) {
-               while (getline oneline < tmpfile)
-                       odp=(odp " " oneline)
-               if ( DEBUG ) print "Odpowiedz: " odp
-       }
-       
-       close(tmpfile)
-       system("rm -f " tmpfile)
-       urldir=url;
-       sub(/[^\/]+$/,"",urldir)
-       if ( errno==0) {
-               while ((tolower(odp) ~ /<frame[ \t]/)||(tolower(odp) ~ /href=/)) {
-                       if (tolower(odp) ~ /<frame[ \t]/) {
-                               match(tolower(odp),/<frame[ \t][^>]*>/)
-                               ramka=substr(odp,RSTART,RLENGTH)
-                               odp=substr(odp,RSTART+RLENGTH)
-                               sub(/[sS][rR][cC]=[ \t]+/,"src=",ramka);
-                               match(tolower(ramka),/src="[^"]+"/)
-                               newurl=substr(ramka,RSTART+5,RLENGTH-6)
-                               if (DEBUG) print "Ramka: " newurl
-                               if (newurl !~ /\//) {
-                                       newurl=(urldir newurl)
-                                       if (DEBUG) print "Ramka->: " newurl
-                               }
-                               retval=(retval " " get_links(newurl))
-                       } else if (tolower(odp) ~ /href=[ \t]*"[^"]+"/) {
-                               sub(/[hH][rR][eE][fF]=[ \t]+/,"href=",odp)
-                               match(tolower(odp),/href="[^"]+"/)
-                               link=substr(odp,RSTART,RLENGTH)
-                               odp=substr(odp,RSTART+RLENGTH)
-                               link=substr(link,7,length(link)-7)
-                               retval=(retval " " link)
-                       } else if (tolower(odp) ~ /href=[ \t]*[^ \t>]+/) {
-                               sub(/[hH][rR][eE][fF]=[ \t]+/,"href=",odp)
-                               match(tolower(odp),/href=[^ \t>]+/)
-                               link=substr(odp,RSTART,RLENGTH)
-                               odp=substr(odp,RSTART+RLENGTH)
-                               link=substr(link,6,length(link)-5)
-                               retval=(retval " " link)
-                       } else {
-                               retval=(retval " INTERNAL_ERROR")
-                               break
-                       }
-               }
-       } else {
-               retval=("WGET ERROR: " errno)
-       }
-       
-       
-       if (DEBUG) print "Zwracane: " retval
-       return retval
-}
-
-function subst_defines(var,defs) {
-# substitute all possible RPM macros
-       while ((var ~ /%{.*}/) || (var ~ /%[A-Za-z0-9_]+/)) {
-               oldvar=var
-               for (j in defs) {
-                       gsub("%{" j "}", defs[j], var)
-                       gsub("%" j , defs[j], var)
-               }
-               if (var==oldvar) {
-                       if ( DEBUG ) for (i in defs) print i " == " defs[i]
-                       return var
-               }
-       }
-       return var
-}
-
-function find_mirror(url) {
-
-       while (succ = (getline line < "mirrors")) {
-           if (succ==-1) { return url }
-               nf=split(line,fields,"|")
-               if (nf>1){
-                       origin=fields[1]
-                       mirror=fields[2]
-                       mname=fields[3]
-                       prefix=substr(url,1,length(origin))
-                       if (prefix==origin){
-                               if ( DEBUG ) print "Mirror znaleziony na " mname
-                               close("mirrors")
-                               return mirror substr(url,length(origin))
-                       }
-               }
-       }
-
-       return url
-}
-
-function process_source(number,lurl,name,version) {
-# fetches file list, and compares version numbers
-       if ( DEBUG ) print "Przetwarzam " lurl
-
-       if ( index(lurl,version)==0 ) {
-               if (DEBUG) print "Nie ma numeru wersji."
-               return 0
-       }
-
-       sub("://",":",lurl)
-       sub("/",":/",lurl)
-       gsub("[^/]*$",":&",lurl)
-       split(lurl,url,":")
-       acc=url[1]
-       host=url[2]
-       dir=url[3]
-       filename=url[4]
-
-       if (index(dir,version)) {
-               dir=substr(dir,1,index(dir,version)-1)
-               sub("[^/]*$","",dir)
-               sub("(\.tar\.(bz|bz2|gz)|zip)$","",filename)
-               if ( DEBUG ) print "Sprawdze katalog: " dir
-               if ( DEBUG ) print "i plik: " filename
-       }
-
-       filenameexp=filename
-       gsub("\+","\\+",filenameexp)
-       sub(version,"[A-Za-z0-9.]+",filenameexp)
-       gsub("\.","\\.",filenameexp)
-       if ( DEBUG ) print "Wzorzec: " filenameexp
-       match(filename,version)
-       prever=substr(filename,1,RSTART-1)
-       postver=substr(filename,RSTART+RLENGTH)
-       if ( DEBUG ) print "Przed numerkiem: " prever
-       if ( DEBUG ) print "i po: " postver
-       newurl=find_mirror(acc "://" host dir)  
-       #print acc "://" host dir
-       #newurl=url[1]"://"url[2]url[3]url[4]
-       #newurl=acc "://" host dir filename
-       if ( DEBUG ) print "Zagl±dam na " newurl 
-       
-       references=0
-       finished=0
-       oldversion=version
-       odp=get_links(newurl)
-       if( odp ~ "ERROR: ") {
-               print name "(" number ") " odp
-       } else {
-               if (DEBUG) print "Sciagnieta strona"
-               c=split(odp,linki)
-               for (nr=1; nr<=c; nr++) {
-                       addr=linki[nr]
-                       if (DEBUG) print "Znaleziony link: " addr
-                       if ((addr ~ filenameexp) && !(addr ~ "[-_.0-9A-Za-z~]" filenameexp)) {
-                               match(addr,filenameexp)
-                               newfilename=substr(addr,RSTART,RLENGTH)
-                               if (DEBUG) print "Hipotetyczny nowy: " newfilename
-                               newfilename=fixedsub(prever,"",newfilename)
-                               newfilename=fixedsub(postver,"",newfilename)
-                               if (DEBUG) print "Wersja: " newfilename
-                               if (newfilename ~ /\.(pkg|bin|binary)$/) continue
-                               if (NUMERIC) {
-                                       if ( compare_ver_dec(version, newfilename)==1 ) {
-                                               if (DEBUG) print "Tak, jest nowa"
-                                               version=newfilename
-                                               finished=1
-                                       }
-                               } else if ( compare_ver(version, newfilename)==1 ) {
-                                       if (DEBUG) print "Tak, jest nowa"
-                                       version=newfilename
-                                       finished=1
-                               }
-                       }
-               }
-               if (finished==0)
-                       print name "(" number ") seems ok: " oldversion
-               else
-                       print name "(" number ") [OLD] " oldversion " [NEW] " version
-       }
-}
-       
-function process_data(name,ver,rel,src) {
-# this function checks if substitutions were valid, and if true:
-# processes each URL and tries to get current file list
-       for (i in src) {
-               if ( src[i] !~ /%{.*}/ && src[i] !~ /%[A-Za-z0-9_]/ )  {
-                       if ( DEBUG ) print "Zrodlo: " src[i]
-                       process_source(i,src[i],name,ver)
-               } else {
-                       print FNAME ":" i ": niemozliwe podstawienie: " src[i]
-               }
-       }
-}
-
-BEGIN {
-       # if U want to use DEBUG, run script with "-v DEBUG=1"
-       # or uncomment the line below
-       # DEBUG = 1
-
-       errno=system("wget --help > /dev/null 2>&1")
-       if (errno) {
-               print "No wget installed!"
-               exit 1
-       }
-       if (ARGC>=3 && ARGV[2]=="-n") {
-               NUMERIC=1
-               for (i=3; i<ARGC; i++) ARGV[i-1]=ARGV[i] 
-               ARGC=ARGC-1
-       }
-}
-
-FNR==1 {
-       if ( ARGIND != 1 ) {
-               process_data(NAME,VER,REL,SRC)
-               NAME="" ; VER="" ; REL=""
-               for (i in DEFS) delete DEFS[i]
-               for (i in SRC) delete SRC[i]
-       }
-       FNAME=FILENAME
-}
-
-/^[Uu][Rr][Ll]:/&&(URL=="") { URL=subst_defines($2,DEFS) ; DEFS["url"]=URL }
-/^[Nn]ame:/&&(NAME=="") { NAME=subst_defines($2,DEFS) ; DEFS["name"]=NAME }
-/^[Vv]ersion:/&&(VER=="") { VER=subst_defines($2,DEFS) ; DEFS["version"]=VER }
-/^[Rr]elease:/&&(REL=="") { REL=subst_defines($2,DEFS) ; DEFS["release"]=REL }
-/^[Ss]ource[0-9]*:/ { if (/(ftp|http):\/\//) SRC[FNR]=subst_defines($2,DEFS) }
-/%define/ { DEFS[$2]=subst_defines($3,DEFS) }
-
-END {
-       process_data(NAME,VER,REL,SRC)
-}
This page took 0.374777 seconds and 4 git commands to generate.