# Conditional build:
%bcond_with static # don't use shared libraries
%bcond_without imode # don't build interactive mode
-%bcond_with curl # link with curl
-%bcond_with distver # enable distversion patch
+%bcond_without python # don't build python bindings
#
# required versions (forced to avoid SEGV with mixed db used by rpm and poldek)
-%define ver_db 4.2.50-1
-%define ver_rpm 4.3-0.20040107.34
+%define ver_db 4.3.27-1
+%define ver_rpm 4.4.9
+%define snap 20070108.22
Summary: RPM packages management helper tool
-Summary(pl): Pomocnicze narzêdzie do zarz±dzania pakietami RPM
+Summary(pl.UTF-8): Pomocnicze narzędzie do zarządzania pakietami RPM
Name: poldek
-Version: 0.18.7
-Release: 2%{?with_distver:+distver}
+Version: 0.20.1
+Release: 0.20070108.1.12
License: GPL v2
Group: Applications/System
-Source0: http://team.pld.org.pl/~mis/poldek/download/%{name}-%{version}.tar.bz2
-# Source0-md5: 42830ed55809e41059771b87131a84fd
+Source0: http://poldek.pld-linux.org/download/snapshots/%{name}-%{version}-cvs%{snap}.tar.bz2
+# Source0-md5: 47025233d8ebb7082567cbf1392cf16f
Source1: %{name}.conf
-Patch0: %{name}-etc_dir.patch
-Patch1: %{name}-retr_term.patch
-Patch2: %{name}-simplestatic.patch
-Patch3: %{name}-po.patch
-Patch4: %{name}-n_free.patch
-Patch12: %{name}-distver.patch
-URL: http://team.pld.org.pl/~mis/poldek/
-BuildRequires: automake
+Source2: %{name}-multilib.conf
+Source3: %{name}-aliases.conf
+Patch1: %{name}-vserver-packages.patch
+Patch2: %{name}-config.patch
+Patch3: %{name}-multilib.patch
+Patch4: %{name}-configure_in.patch
+Patch5: %{name}-rpm-4.4.8.patch
+Patch6: %{name}-rpm-4.4.9.patch
+Patch7: %{name}-desc_in_utf8.patch
+URL: http://poldek.pld-linux.org/
BuildRequires: autoconf
+BuildRequires: automake
BuildRequires: bzip2-devel
-%{?with_curl:BuildRequires: curl-devel >= 7.8}
+BuildRequires: check
BuildRequires: db-devel >= %{ver_db}
BuildRequires: gettext-autopoint
+BuildRequires: libtool
+BuildRequires: libxml2-devel
BuildRequires: openssl-devel >= 0.9.7d
BuildRequires: pcre-devel
+BuildRequires: perl-tools-pod
BuildRequires: popt-devel
-BuildRequires: readline-devel
+%{?with_python:BuildRequires: python-devel}
+BuildRequires: readline-devel >= 5.0
BuildRequires: rpm-devel >= %{ver_rpm}
+%{?with_python:BuildRequires: rpm-pythonprov}
+BuildRequires: xmlto
BuildRequires: zlib-devel
-BuildRequires: perl-tools-pod
%if %{with static}
BuildRequires: bzip2-static
-%{?with_curl:BuildRequires: curl-static}
BuildRequires: db-static >= %{ver_db}
BuildRequires: glibc-static
BuildRequires: libselinux-static
+BuildRequires: libxml2-static
BuildRequires: ncurses-static
BuildRequires: openssl-static
BuildRequires: pcre-static
BuildRequires: rpm-static
BuildRequires: zlib-static
%endif
+Requires(triggerpostun): awk
+Requires(triggerpostun): sed >= 4.0
+Requires: %{name}-libs = %{version}-%{release}
Requires: db >= %{ver_db}
-Requires: ed
Requires: rpm >= %{ver_rpm}
-%{?with_distver:Requires: rpm-lib(distver)}
Requires: sed
-Requires: openssl >= 0.9.7c
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
%description
%{?with_static:This version is statically linked.}
%{!?with_imode:This version hasn't got interactive mode.}
+#'vim
-%description -l pl
-poldek jest narzêdziem linii poleceñ s³u¿±cym do weryfikacji,
-instalacji (w³±czaj±c instalacjê systemu od zera), aktualizacji i
-usuwania pakietów.
+%description -l pl.UTF-8
+poldek jest narzędziem linii poleceń służącym do weryfikacji,
+instalacji (włączając instalację systemu od zera), aktualizacji i
+usuwania pakietów.
-Program mo¿e byæ u¿ywany w trybie wsadowym (jak debianowy apt-get) lub
+Program może być używany w trybie wsadowym (jak debianowy apt-get) lub
interaktywnym. Tryb interaktywny posiada interfejs readline z
-dope³nianiem komend i histori±, podobny do trybu shell perlowego
-modu³u CPAN.
+dopełnianiem komend i historią, podobny do trybu shell perlowego
+modułu CPAN.
%{?with_static:Ta wersja jest konsolidowana statycznie.}
%{!?with_imode:Ta wersja nie posiada trybu interaktywnego.}
+%package libs
+Summary: poldek libraries
+Summary(pl.UTF-8): Biblioteki poldka
+Group: Libraries
+
+%description libs
+poldek libraries.
+
+%description libs -l pl.UTF-8
+Biblioteki poldka.
+
+%package devel
+Summary: Header files for poldek libraries
+Summary(pl.UTF-8): Pliki nagłówkowe bibliotek poldka
+Group: Development/Libraries
+Requires: %{name}-libs = %{version}-%{release}
+
+%description devel
+Header files for poldek libraries.
+
+%description devel -l pl.UTF-8
+Pliki nagłówkowe bibliotek poldka.
+
+%package static
+Summary: poldek static libraries
+Summary(pl.UTF-8): Biblioteki statyczne poldka
+Group: Development/Libraries
+Requires: %{name}-devel = %{version}-%{release}
+
+%description static
+poldek static libraries.
+
+%description static -l pl.UTF-8
+Biblioteki statyczne poldka.
+
+%package -n python-poldek
+Summary: Python modules for poldek
+Summary(pl.UTF-8): Moduły języka Python dla poldka
+Group: Libraries/Python
+Requires: %{name}-libs = %{version}-%{release}
+%pyrequires_eq python-libs
+
+%description -n python-poldek
+Python modules for poldek.
+
+%description -n python-poldek -l pl.UTF-8
+Moduły języka Python dla poldka.
+
%prep
-%setup -q
-%patch0 -p1
+%setup -q -n %{name}-%{version}%{?snap:-cvs%{snap}}
%patch1 -p1
-%patch2 -p0
+%patch2 -p1
+%ifarch %{x8664}
%patch3 -p1
+%endif
%patch4 -p1
-%{?with_distver:%patch12 -p1}
+%patch5 -p1
+%patch6 -p1
+%patch7 -p1
%build
%{__autopoint}
%{__autoconf}
%{__automake}
cp -f config.sub trurlib
+
%configure \
- %{?with_static:--enable-static} \
+ %{?with_static:--enable-static --disable-shared} \
%{!?with_imode:--disable-imode} \
- %{?with_curl:--with-curl}
+ --enable-nls \
+ %{?with_python:--with-python}
%{__make}
%install
%{__make} install \
DESTDIR=$RPM_BUILD_ROOT
+%if %{with python}
+%{__make} -C python install \
+ DESTDIR=$RPM_BUILD_ROOT \
+ libdir=%{py_sitedir}
+%endif
+
%{?with_static:rm -f $RPM_BUILD_ROOT%{_bindir}/rpmvercmp}
-#
-# CHANGE IT WHEN SWITCHING poldek.conf FROM AC TO TH !!!
-#
-%ifarch i386 i586 i686 ppc sparc alpha amd64 athlon
+%ifarch i486 i686 ppc sparc alpha athlon
%define _ftp_arch %{_target_cpu}
%else
-%ifarch i486
-%define _ftp_arch i386
+%ifarch %{x8664}
+%define _ftp_arch x86_64
+%define _ftp_alt_arch i686
+%else
+%ifarch i586
+%define _ftp_arch i486
%else
%ifarch pentium2 pentium3 pentium4
%define _ftp_arch i686
%endif
%endif
%endif
+%endif
+
+%{?with_static:rm -f $RPM_BUILD_ROOT%{_bindir}/rpmvercmp}
+
+sed -e '
+ s|%%ARCH%%|%{_ftp_arch}|g
+' < %{SOURCE1} > $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/pld-source.conf
+
+%ifarch %{x8664}
+sed '
+ s|%%ARCH%%|%{_ftp_alt_arch}|g
+' < %{SOURCE2} > $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/pld-multilib-source.conf
+%endif
+
+install %{SOURCE3} $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/aliases.conf
-sed "s|%%ARCH%%|%{_ftp_arch}|g" < %{SOURCE1} > $RPM_BUILD_ROOT%{_sysconfdir}/%{name}.conf
+# get rid of non-pld sources
+rm -f $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/{rh,fedora}-source.conf
+# include them in %doc
+rm -rf configs
+cp -a conf configs
+rm -f configs/Makefile*
+
+%if %{with python}
+%py_postclean
+rm -f $RPM_BUILD_ROOT%{py_sitedir}/_poldekmod.la
+%endif
%find_lang %{name}
%clean
rm -rf $RPM_BUILD_ROOT
+%post
+[ ! -x /usr/sbin/fix-info-dir ] || /usr/sbin/fix-info-dir -c %{_infodir} >/dev/null 2>&1
+
+%postun
+[ ! -x /usr/sbin/fix-info-dir ] || /usr/sbin/fix-info-dir -c %{_infodir} >/dev/null 2>&1
+
+%post libs -p /sbin/ldconfig
+%postun libs -p /sbin/ldconfig
+
%triggerpostun -- poldek <= 0.18.3-5
-if grep -q '^promoteepoch.*yes' /etc/poldek.conf ; then
- echo -e ',s:^promoteepoch:# promoteepoch:g\n,w' | ed -s /etc/poldek.conf
+if [ -f /etc/poldek.conf ]; then
+ sed -i -e '/^promoteepoch:.*yes/s/^/#/' /etc/poldek.conf
fi
# otherwise don't touch
%ifarch i386 i586 i686 ppc sparc alpha amd64 athlon
%triggerpostun -- poldek <= 0.18.7-1
-echo -e ',s://ftp.pld-linux.org://ftp.%{_target_cpu}.ac.pld-linux.org:g\n,w' |\
- ed -s /etc/poldek.conf ||:
+if [ -f /etc/poldek.conf ]; then
+ sed -i -e 's://ftp.pld-linux.org://ftp.ac.pld-linux.org:g' /etc/poldek.conf
+fi
%endif
+%triggerpostun -- poldek < 0.19.0-1.20050613.22.0
+if [ -f /etc/poldek.conf.rpmsave ]; then
+ awk '/^source/ {
+ name = $3;
+ path = $4;
+ auto = "yes";
+ autoup = "yes";
+ type = "pdir";
+ pri = "";
+
+ if (sub(",noauto", "", name)) {
+ auto = "no";
+ }
+
+ # process pri=\d+
+ if (match(name, /,pri=[0-9]+/)) {
+ pri = substr(name, RSTART + 5, RLENGTH - 5);
+ name = substr(name, 1, RSTART - 1) substr(name, RSTART + RLENGTH);
+ }
+
+ # skip ac sources. already in new config.
+ if (name !~ /^ac(-(ready|test|supported|updates-(general|security)))?$/) {
+ print "";
+ print "[source]";
+ print "name = " name;
+ print "type = " type;
+ print "path = " path;
+ print "auto = " auto;
+ print "autoup = " autoup;
+ if (pri) {
+ print "pri = " pri;
+ }
+ }
+
+ }' < /etc/poldek.conf.rpmsave >> /etc/poldek/source.conf
+ echo "Converted old custom sources from /etc/poldek.conf.rpmsave to new poldek format in /etc/poldek/source.conf"
+
+ # copy hold=
+ hold=$(grep ^hold /etc/poldek.conf.rpmsave)
+ if [ "$hold" ]; then
+ sed -i -e "/^#hold =/s/^.*/$hold/" /etc/poldek/poldek.conf
+ fi
+fi
+
%files -f %{name}.lang
%defattr(644,root,root,755)
-%doc README* NEWS TODO *sample* conf/poldekrc*
-%attr(644,root,root) %config(noreplace) %verify(not md5 size mtime) %{_sysconfdir}/%{name}.conf
+%doc README* NEWS TODO configs/
+%dir %{_sysconfdir}/%{name}
+%config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/%{name}/*.conf
%attr(755,root,root) %{_bindir}/*
+%dir %{_libdir}/%{name}
+%attr(755,root,root) %{_libdir}/%{name}/*
%{_mandir}/man1/%{name}*
%lang(pl) %{_mandir}/pl/man1/%{name}*
+%{_infodir}/poldek.info*
+
+%if !%{with static}
+%files libs
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_libdir}/lib*.so.*.*.*
+%endif
+
+%files devel
+%defattr(644,root,root,755)
+%{!?with_static:%attr(755,root,root) %{_libdir}/lib*.so}
+%{_libdir}/lib*.la
+%{_includedir}/*
+
+%files static
+%defattr(644,root,root,755)
+%{_libdir}/lib*.a
+
+%if %{with python}
+%files -n python-poldek
+%defattr(644,root,root,755)
+%attr(755,root,root) %{py_sitedir}/_poldekmod.so
+%{py_sitescriptdir}/poldek.py[co]
+%{py_sitescriptdir}/poldekmod.py[co]
+%endif