]> git.pld-linux.org Git - packages/cyrus-imapd.git/blobdiff - cyrus-imapd.spec
- up to 2.4.10; avoid -L/usr/lib
[packages/cyrus-imapd.git] / cyrus-imapd.spec
index 393e5841b61dae83fbd22f3fdc7e2fc990948107..54aaccbbd286492daf4b0dc12b6fae78cc60febc 100644 (file)
@@ -1,18 +1,18 @@
-# TODO
-# - unpackaged:
-#   /usr/lib/cyrus/cyr_synclog
-#   /usr/lib/cyrus/make_sha1
-%include       /usr/lib/rpm/macros.perl
-Summary:       High-performance mail store with imap and pop3
+# Conditional build:
+%bcond_without perl            # build with perl
+%bcond_without shared          # build with shared patch (not updated)
+
+%{?with_perl:%include  /usr/lib/rpm/macros.perl}
+Summary:       High-performance mail store with IMAP and POP3
 Summary(pl.UTF-8):     Wysoko wydajny serwer IMAP i POP3
 Summary(pt_BR.UTF-8):  Um servidor de mail de alto desempenho que suporta IMAP e POP3
 Name:          cyrus-imapd
-Version:       2.3.12p2
+Version:       2.4.10
 Release:       1
 License:       BSD-like
-Group:         Networking/Daemons
-Source0:       ftp://ftp.andrew.cmu.edu/pub/cyrus-mail/%{name}-%{version}.tar.gz
-# Source0-md5: ee2c300687994e4982c6af6aa154c742
+Group:         Networking/Daemons/POP3
+Source0:       ftp://ftp.cyrusimap.org/cyrus-imapd/%{name}-%{version}.tar.gz
+# Source0-md5: 55f08eeabf2f93281e61ba27854aea67
 Source1:       cyrus-README
 Source2:       cyrus-procmailrc
 Source3:       cyrus-deliver-wrapper.c
@@ -26,9 +26,14 @@ Source11:    %{name}.init
 Source12:      cyrus.conf
 Source13:      cyrus-sync.init
 Patch0:                %{name}-et.patch
+# http://bugzilla.cyrusimap.org/bugzilla3/show_bug.cgi?id=3095
 Patch1:                %{name}-shared.patch
+# http://bugzilla.cyrusimap.org/bugzilla3/show_bug.cgi?id=3094
 Patch2:                %{name}-verifydbver.patch
-URL:           http://cyrusimap.web.cmu.edu/imapd/
+Patch3:                gcc44.patch
+Patch4:                glibc.patch
+Patch6:                makeopt.patch
+URL:           http://www.cyrusimap.org/
 BuildRequires: autoconf >= 2.54
 BuildRequires: automake
 BuildRequires: cyrus-sasl-devel >= 1.5.27
@@ -38,18 +43,19 @@ BuildRequires:      libcom_err-devel >= 1.21
 BuildRequires: libtool
 BuildRequires: net-snmp-devel
 BuildRequires: openssl-devel >= 0.9.7d
-BuildRequires: perl-devel >= 1:5.8.0
-BuildRequires: rpm-perlprov
+%{?with_perl:BuildRequires:    perl-devel >= 1:5.8.0}
+%{?with_perl:BuildRequires:    rpm-perlprov}
 BuildRequires: rpmbuild(macros) >= 1.268
 Requires(post,preun):  /sbin/chkconfig
 Requires(postun):      /usr/sbin/userdel
 Requires(pre): /bin/id
 Requires(pre): /usr/sbin/useradd
-Requires:      %{name}-libs = %{version}-%{release}
+%{?with_shared:Requires:       %{name}-libs = %{version}-%{release}}
 Requires:      rc-scripts >= 0.4.0.18
+%{!?with_shared:Obsoletes:     %{name}-libs}
 # needed by scripts from %{_bindir}
 Requires:      pam >= 0.79.0
-Requires:      perl-%{name} = %{version}-%{release}
+%{?with_perl:Requires: perl-%{name} = %{version}-%{release}}
 Provides:      imapdaemon
 Provides:      pop3daemon
 Provides:      user(cyrus)
@@ -163,11 +169,27 @@ Perl interface to cyrus-imapd library.
 %description -n perl-%{name} -l pl.UTF-8
 Perlowy interfejs do biblioteki cyrus-imapd.
 
+%package doc
+Summary:       Cyrus-IMAP documentation
+Group:         Documentation
+
+%description doc
+Cyrus-IMAP HTML documentation.
+
 %prep
 %setup -q
+%patch6 -p1
 %patch0 -p1
+%if %{with shared}
+lsdiff --strip 1 %{PATCH1} | xargs %{__sed} -i -e '
+       s/\.o/.lo/g
+       s/\.a/.la/g
+'
 %patch1 -p1
+%endif
 %patch2 -p1
+%patch3 -p1
+%patch4 -p1
 
 rm -rf autom4te.cache
 
@@ -188,16 +210,16 @@ cd ..
 cp -f %{_datadir}/automake/config.* .
 cp -f %{_datadir}/automake/install-sh .
 %configure \
-       --with-auth=unix \
        --with-cyrus-prefix=%{_libexecdir} \
        --with-service-path=%{_libexecdir} \
        --with-com_err=/usr \
-       --with-perl=%{__perl} \
+       --%{!?with_perl:without-perl}%{?with_perl:with-perl=%{__perl}} \
        --without-libwrap \
        --enable-nntp \
        --enable-replication
-%{__make} \
-       INSTALLDIRS=vendor
+%{__make} -j1 \
+       INSTALLDIRS=vendor \
+       VERSION=%{version}
 
 %{__cc} %{rpmcflags} \
        -DLIBEXECDIR="\"%{_libexecdir}\"" %{rpmldflags} -Wall -o deliver-wrapper %{SOURCE3}
@@ -236,20 +258,22 @@ install %{SOURCE12}       $RPM_BUILD_ROOT%{_sysconfdir}/cyrus.conf
 mv -f $RPM_BUILD_ROOT%{_libexecdir}/master     $RPM_BUILD_ROOT%{_libexecdir}/cyrus-master
 mv -f $RPM_BUILD_ROOT%{_mandir}/man8/master.8  $RPM_BUILD_ROOT%{_mandir}/man8/cyrus-master.8
 rm -f $RPM_BUILD_ROOT%{_mandir}/man8/idled.8
-rm -f $RPM_BUILD_ROOT%{perl_archlib}/perllocal.pod
 
 touch $RPM_BUILD_ROOT/etc/security/blacklist.{imap,pop3}
 
-find $RPM_BUILD_ROOT%{perl_vendorarch} -name .packlist | xargs rm -v
-
 # make hashed dirs
-for i in `%{__perl} -le 'print for "a".."z"'`; do
+for i in $(%{__perl} -le 'print for "a".."z"'); do
        install -d $RPM_BUILD_ROOT%{_var}/lib/imap/user/$i
        install -d $RPM_BUILD_ROOT%{_var}/lib/imap/quota/$i
        install -d $RPM_BUILD_ROOT%{_var}/lib/imap/sieve/$i
        install -d $RPM_BUILD_ROOT%{_var}/spool/imap/$i
 done
 
+%if %{with perl}
+find $RPM_BUILD_ROOT%{perl_vendorarch} -name .packlist | xargs rm -v
+rm -f $RPM_BUILD_ROOT%{perl_archlib}/perllocal.pod
+%endif
+
 %clean
 rm -rf $RPM_BUILD_ROOT
 
@@ -287,7 +311,7 @@ fi
 %files
 %defattr(644,root,root,755)
 %doc cyrus-README cyrus-procmailrc cyrus-user-procmailrc.template
-%doc cyrus-imapd-procmail+cyrus.mc COPYRIGHT doc/*.html tools
+%doc cyrus-imapd-procmail+cyrus.mc COPYRIGHT tools
 %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/*.conf
 %attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/logrotate.d/cyrus-imapd
 %attr(440,cyrus,root) %config(noreplace) %verify(not md5 mtime size) /etc/pam.d/*
@@ -306,8 +330,12 @@ fi
 %attr(755,root,root) %{_libexecdir}/ctl_mboxlist
 %attr(755,root,root) %{_libexecdir}/cvt_cyrusdb
 %attr(755,root,root) %{_libexecdir}/cyr_dbtool
-%attr(755,root,root) %{_libexecdir}/cyrdump
+%attr(755,root,root) %{_libexecdir}/cyr_df
 %attr(755,root,root) %{_libexecdir}/cyr_expire
+%attr(755,root,root) %{_libexecdir}/cyr_sequence
+%attr(755,root,root) %{_libexecdir}/cyr_synclog
+%attr(755,root,root) %{_libexecdir}/cyr_userseen
+%attr(755,root,root) %{_libexecdir}/cyrdump
 %attr(755,root,root) %{_libexecdir}/cyrus-master
 %attr(755,root,root) %{_libexecdir}/fetchnews
 %attr(755,root,root) %{_libexecdir}/fud
@@ -315,10 +343,6 @@ fi
 %attr(755,root,root) %{_libexecdir}/ipurge
 %attr(755,root,root) %{_libexecdir}/lmtpd
 %attr(755,root,root) %{_libexecdir}/lmtpproxyd
-%attr(755,root,root) %{_libexecdir}/make_md5
-%attr(755,root,root) %{_libexecdir}/sync_client
-%attr(755,root,root) %{_libexecdir}/sync_reset
-%attr(755,root,root) %{_libexecdir}/sync_server
 %attr(755,root,root) %{_libexecdir}/mbexamine
 %attr(755,root,root) %{_libexecdir}/mbpath
 %attr(755,root,root) %{_libexecdir}/nntpd
@@ -329,13 +353,16 @@ fi
 %attr(755,root,root) %{_libexecdir}/quota
 %attr(755,root,root) %{_libexecdir}/reconstruct
 %attr(755,root,root) %{_libexecdir}/sievec
+%attr(755,root,root) %{_libexecdir}/sieved
 %attr(755,root,root) %{_libexecdir}/smmapd
 %attr(755,root,root) %{_libexecdir}/squatter
+%attr(755,root,root) %{_libexecdir}/sync_client
+%attr(755,root,root) %{_libexecdir}/sync_reset
+%attr(755,root,root) %{_libexecdir}/sync_server
 %attr(755,root,root) %{_libexecdir}/timsieved
 %attr(755,root,root) %{_libexecdir}/tls_prune
 %attr(755,root,root) %{_libexecdir}/unexpunge
 
-
 %attr(750,cyrus,mail) /var/spool/imap
 %attr(750,cyrus,mail) %dir /var/lib/imap
 %attr(750,cyrus,mail) %dir /var/lib/imap/deliverdb
@@ -352,26 +379,29 @@ fi
 
 %{_mandir}/man*/*
 
+%if %{with shared}
 %files libs
 %defattr(644,root,root,755)
-%attr(755,root,root) %{_libdir}/libcyrus.so.*.*.*
-%attr(755,root,root) %{_libdir}/libcyrus_min.so.*.*.*
-%attr(755,root,root) %ghost %{_libdir}/libcyrus.so.0
-%attr(755,root,root) %ghost %{_libdir}/libcyrus_min.so.0
+%attr(755,root,root) %{_libdir}/libcyrus-%{version}.so
+%attr(755,root,root) %{_libdir}/libcyrus_min-%{version}.so
+%endif
 
 %files devel
 %defattr(644,root,root,755)
+%{_includedir}/cyrus
+%if %{with shared}
 %attr(755,root,root) %{_libdir}/libcyrus.so
 %attr(755,root,root) %{_libdir}/libcyrus_min.so
 %{_libdir}/libcyrus.la
 %{_libdir}/libcyrus_min.la
-%{_includedir}/cyrus
 
 %files static
 %defattr(644,root,root,755)
+%endif
 %{_libdir}/libcyrus.a
 %{_libdir}/libcyrus_min.a
 
+%if %{with perl}
 %files -n perl-%{name}
 %defattr(644,root,root,755)
 %{perl_vendorarch}/Cyrus
@@ -383,3 +413,8 @@ fi
 %dir %{perl_vendorarch}/auto/Cyrus/SIEVE/managesieve
 %attr(755,root,root) %{perl_vendorarch}/auto/Cyrus/SIEVE/managesieve/managesieve.so
 %{perl_vendorarch}/auto/Cyrus/SIEVE/managesieve/managesieve.bs
+%endif
+
+%files doc
+%defattr(644,root,root,755)
+%doc doc/*.html
This page took 0.089626 seconds and 4 git commands to generate.