-#!/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
# 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.
# 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!/) {
# 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/) {
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 ""
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
#########
# %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")
if (/CXXFLAGS=/)
if (cflags("CXXFLAGS") == 0)
next
-
+
if (/^export /) {
if (removed["LDFLAGS"])
sub(" LDFLAGS", "")
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
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
}
}
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()
}
#############
# 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, /\//)
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
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")
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}")
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) {
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) "- "
word = substr(line, RSTART, RLENGTH)
if (length(newline) + length(word) + 1 > tw) {
print newline
-
+
if (format_indent == -1)
newline = ""
else
first_word = 0
} else
newline = newline " " word
-
+
line = substr(line, RSTART + RLENGTH)
}
if (newline ~ /[^\t ]/) {
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
+++ /dev/null
-#!/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
+++ /dev/null
-#!/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)
-}