]> git.pld-linux.org Git - packages/rpm-build-tools.git/blobdiff - adapter.awk
- ~ is not filaname separator (id3lib case)
[packages/rpm-build-tools.git] / adapter.awk
index b493e8fa36479315b1c730b1828f75f7c6c976e6..5fae70e454f6125d72c0db5cc4de75c37b76ceed 100644 (file)
@@ -1,19 +1,19 @@
 #!/bin/awk -f
 #
-# This is adapter v0.26. Adapter adapts .spec files for PLD.
+# This is adapter v0.27. Adapter adapts .spec files for PLD.
 #
-# Copyright (C) 1999-2001 PLD-Team <feedback@pld.org.pl>
+# Copyright (C) 1999-2003 PLD-Team <feedback@pld-linux.org>
 # Authors:
 #      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>
-#      Michal Kochanowicz <mkochano@ee.pw.edu.pl>
+#      Michal Kochanowicz <mkochano@pld.org.pl>
 # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
 
 BEGIN {
        preamble = 1            # Is it part of preamble? Default - yes
-       boc = 2                 # Beggining of %changelog
+       boc = 4                 # Beggining of %changelog
        bod = 0                 # Beggining of %description
        tw = 70                 # Descriptions width
        
@@ -28,7 +28,7 @@ BEGIN {
        # 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 1>&2")
+       system("cd `rpm --eval %_sourcedir`; cvs up rpm.groups >/dev/null")
 
        # Temporary file for changelog section
        changelog_file = ENVIRON["HOME"] "/tmp/adapter.changelog"
@@ -65,7 +65,7 @@ defattr == 1 {
 }
 
 # Comments
-/^#/ {
+/^#/ && (description == 0) {
        if (/This file does not like to be adapterized!/) {
                print                   # print this message
                while (getline)         # print the rest of spec as it is
@@ -75,6 +75,7 @@ defattr == 1 {
        }
 
        # Generally, comments are printed without touching
+       sub(/[ \t]+$/, "")
        print $0
        next
 }
@@ -100,12 +101,12 @@ defattr == 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
-       }
+#      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/) {
@@ -270,27 +271,41 @@ defattr == 1 {
 /^%changelog/, (/^%[a-z]+$/ && !/^%changelog/) {
        preamble = 0
        has_changelog = 1
+       skip = 0
        # There should be some CVS keywords on the first line of %changelog.
-       if (boc == 1) {
-               if (!/PLD Team/) {
-                       print "* %{date} PLD Team <feedback@pld.org.pl>" > changelog_file
+       if (boc == 3) {
+               if (!/PLD Team/)
+                       print "* %{date} PLD Team <feedback@pld-linux.org>" > 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.org.pl\n" > changelog_file
-                       print "$" "Log:$" > changelog_file
+                       print "<cvs_login>@pld-linux.org\n" > changelog_file
+               } else
+                       skip = 1
+               boc = 1
+       }
+       if (boc == 1 && !skip) {
+               if (!/^$/) {
+                       if (!/\$.*Log:.*\$/)
+                               print "$" "Log:$" > changelog_file
+                       boc = 0
                }
-               boc = 0
        }
-       
        # Define date macro.
-       if (boc == 2) {
+       if (boc == 4) {
                if (date == 0) {
                        printf "%%define date\t%%(echo `LC_ALL=\"C\"" > changelog_file
                        print " date +\"%a %b %d %Y\"`)" > changelog_file
                        date = 1
                }
-               boc = 1
+               boc = 3
        }
 
+       sub(/[ \t]+$/, "")
        if (!/^%[a-z]+$/ || /changelog/)
                print > changelog_file
        else
@@ -324,19 +339,32 @@ preamble == 1 {
        
        field = tolower($1)
        fieldnlower = $1
-       if (Byla_grupa == 1 && field ~ /^#/)
+       if (field ~ /group(\([^)]+\)):/)
                next
-       if (Byla_grupa == 1 && field !~ /group(\([^)]+\))?:/) {
-               Byla_grupa = 0
-               print "Group:\t\t" Grupa["en"]
-               if (Grupa["en"] ~ /^X11/ && x11 == 0)   # Is it X11 application?
+       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
                byl_opis_grupy = 0
                while ((getline linia_grup < groups_file) > 0) {
                        byl_plik_z_grupami = 1
-                       if (linia_grup == Grupa["en"]) {
+                       if (linia_grup == Grupa) {
                                byl_opis_grupy = 1
                                break
                        }
@@ -346,23 +374,9 @@ preamble == 1 {
                        print "######\t\t" groups_file ": no such file"
                else if (!byl_opis_grupy)
                        print "######\t\t" "Unknown group!"
-               else
-                       while (getline linia_grup < groups_file) {
-                               if (linia_grup == "")
-                                       break
-                               split(linia_grup, g, /[\[\]:]/)
-                               sub(/^[ \t]*/,"",g[4])
-                               Grupa[g[2]]=g[4]
-                       }
                
                close(groups_file)
-
-               delete Grupa["en"]
-               for (jezyk in Grupa) {
-                       print "Group(" jezyk "):\t" Grupa[jezyk] | "sort"
-                       delete Grupa[jezyk]
-               }
-               close ("sort")
+               next
        }
        
        if (field ~ /packager:|distribution:|docdir:|prefix:/)
@@ -371,29 +385,6 @@ preamble == 1 {
        if (field ~ /buildroot:/)
                $0 = $1 "%{tmpdir}/%{name}-%{version}-root-%(id -u -n)"
 
-       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)
-
-               if (!match(fieldnlower,/\([^)]+\):/))
-                       glang="en"
-               else
-                       glang=substr(fieldnlower,RSTART+1,RLENGTH-3)
-               sub(/^[^ \t]*[ \t]*/,"")
-               Grupa[glang] = $0
-               Byla_grupa = 1
-               
-               next    # Line is already formatted and printed
-       }
-               
        # Use "License" instead of "Copyright" if it is (L)GPL or BSD
        if (field ~ /copyright:/ && $2 ~ /GPL|BSD/)
                $1 = "License:"
@@ -489,6 +480,7 @@ preamble == 1 {
 {
        preamble = 1
        
+       sub(/[ \t]+$/, "")
        print
 }
 
@@ -516,12 +508,14 @@ END {
        if (has_changelog == 0)
                print "%changelog"
 
-       if (boc > 0) {
-               print "* %{date} PLD Team <feedback@pld.org.pl>"
+       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.org.pl\n"
-               print "$" "Log:$"
+               print "<cvs_login>@pld-linux.org\n"
        }
+       if (boc > 0)
+               print "$" "Log:$"
 }
 
 function fixedsub(s1,s2,t,      ind) {
@@ -535,7 +529,7 @@ function fixedsub(s1,s2,t,      ind) {
 function format_preamble()
 {
        sub(/:[ \t]*/, ":")
-       if (match($0, /[A-Za-z0-9()#_ \t]+[ \t]*:[ \t]*/) == 1) {
+       if (match($0, /[A-Za-z0-9(),#_ \t]+[ \t]*:[ \t]*/) == 1) {
                if (RLENGTH < 8)
                        sub(/:/, ":\t\t")
                else
@@ -559,7 +553,7 @@ function use_macros()
 
        gsub("%{prefix}/sbin", "%{_sbindir}")
        if(prefix"/sbin" == sbindir)
-               gsub("%{_prefix}/sbib", "%{_sbindir}")
+               gsub("%{_prefix}/sbin", "%{_sbindir}")
 
        gsub(libdir, "%{_libdir}")
        gsub("%{prefix}/lib", "%{_libdir}")
@@ -567,7 +561,7 @@ function use_macros()
                gsub("%{_prefix}/lib", "%{_libdir}")
 
        for (c = 1; c <= NF; c++) {
-               if ($c ~ sysconfdir "/{?cron.d")
+               if ($c ~ sysconfdir "/{?cron.")
                        continue;
                if ($c ~ sysconfdir "/{?crontab.d")
                        continue;
@@ -599,7 +593,8 @@ function use_macros()
                gsub("%{_prefix}/include", "%{_includedir}")
 
        gsub(mandir, "%{_mandir}")
-       gsub("%{_datadir}/man", "%{_mandir}")
+       if ($0 !~ "%{_datadir}/manual")
+               gsub("%{_datadir}/man", "%{_mandir}")
        gsub("%{_prefix}/share/man", "%{_mandir}")
        gsub("%{prefix}/share/man", "%{_mandir}")
        gsub("%{prefix}/man", "%{_mandir}")
@@ -609,7 +604,9 @@ function use_macros()
        gsub("%{prefix}/info", "%{_infodir}")
        gsub("%{_prefix}/info", "%{_infodir}")
 
-       gsub("%{_datadir}/aclocal", "%{_aclocaldir}")
+       if (prefix !~ "/X11R6") {
+               gsub("%{_datadir}/aclocal", "%{_aclocaldir}")
+       }
 
        if (prefix != "/") {
                for (c = 1; c <= NF; c++) {
@@ -623,8 +620,11 @@ function use_macros()
        gsub("%{PACKAGE_VERSION}", "%{version}")
        gsub("%{PACKAGE_NAME}", "%{name}")
 
-       gsub("%{_datadir}/gnome/apps", "%{_applnkdir}")
-       gsub("%{_datadir}/applnk", "%{_applnkdir}")
+       # 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} ")
This page took 0.045795 seconds and 4 git commands to generate.