]> git.pld-linux.org Git - packages/rpm-build-macros.git/blobdiff - rpm.macros
- add openldap_schema_register/openldap_schema_unregister
[packages/rpm-build-macros.git] / rpm.macros
index b834e1773b15bc11d2b0225a0777fb1372fffa01..fd1d0e06201b87e5ac5b383b031c59a89fc7bcac 100644 (file)
@@ -8,9 +8,6 @@
 %kgcc          %{__cc}
 %kgcc_package  gcc
 
-%_source_payload       w9.gzdio
-%_binary_payload       w9.bzdio
-
 # Build system path macros.
 #
 %__autoconf            autoconf %{?debug:-Wall}
@@ -387,17 +384,6 @@ if [ $1 = 0 ]; then \
 fi \
 %{nil}
 
-#-----------------------------------------------------------------
-# Run ldconfig after installing/deinstalling libraries
-#
-%ldconfig_post() \
-       /sbin/ldconfig; \
-       %{nil}
-
-%ldconfig_postun() \
-       /sbin/ldconfig; \
-       %{nil}
-
 #-----------------------------------------------------------------
 # post %install sequence:
 # - autodeps exceptions
@@ -811,18 +797,17 @@ if [ "$1" = "0" ] || [ "$2" = "0" ]; then \
 
 
 # java macros. based on jpackage macros.java
-%_jvmdir               %{_prefix}/lib/jvm
-%_jvmjardir            %{_prefix}/lib/jvm-exports
-%_jvmprivdir           %{_prefix}/lib/jvm-private
-%_jvmlibdir            %{_prefix}/lib/jvm
+%_jvmdir               %{_libdir}/jvm
+%_jvmjardir            %{_libdir}/jvm-exports
+%_jvmprivdir           %{_libdir}/jvm-private
+%_jvmlibdir            %{_libdir}/jvm
 %_jvmdatadir           %{_datadir}/jvm
 %_jvmsysconfdir                %{_sysconfdir}/jvm
-%_jvmcommonlibdir      %{_prefix}/lib/jvm-commmon
-%_jvmcommondatadir     %{_datadir}/jvm-commmon
-%_jvmcommonsysconfdir  %{_sysconfdir}/jvm-commmon
-%_javadir              %{_datadir}/java
-%_jnidir               %{_prefix}/lib/java
-%_javadocdir           %{_datadir}/javadoc
+# FIXME: are these used?
+%_jvmcommonlibdir      %{_libdir}/jvm-common
+%_jvmcommondatadir     %{_datadir}/jvm-common
+%_jvmcommonsysconfdir  %{_sysconfdir}/jvm-common
+%_jnidir               %{_libdir}/java
 %java_home             %(unset JAVA_HOME; . %{_javadir}-utils/java-functions; set_jvm; echo $JAVA_HOME)
 
 %ant                   JAVA_HOME=%{java_home} ant
@@ -834,8 +819,8 @@ if [ "$1" = "0" ] || [ "$2" = "0" ]; then \
 %add_jvm_extension     JAVA_LIBDIR=%{buildroot}/%{_javadir}    %{_bindir}/jvmjar -l
 
 %jpackage_script() \
-install -d -m 755 $RPM_BUILD_ROOT%{_bindir}\
-cat > $RPM_BUILD_ROOT%{_bindir}/%5 << EOF \
+install -d $RPM_BUILD_ROOT%{_bindir}\
+cat > $RPM_BUILD_ROOT%{_bindir}/%5 << 'EOF' \
 #!/bin/sh\
 #\
 # %{name} script\
@@ -845,29 +830,147 @@ cat > $RPM_BUILD_ROOT%{_bindir}/%5 << EOF \
 . %{_javadir}-utils/java-functions\
 \
 # Source system prefs\
-if [ -f %{_sysconfdir}/java/%{name}.conf ] ; then\
+if [ -f %{_sysconfdir}/java/%{name}.conf ]; then\
     . %{_sysconfdir}/java/%{name}.conf\
 fi\
 \
 # Source user prefs\
-if [ -f \\$HOME/.%{name}rc ] ; then\
-    . \\$HOME/.%{name}rc\
+if [ -f $HOME/.%{name}rc ]; then\
+    . $HOME/.%{name}rc\
 fi\
 \
 # Configuration\
 MAIN_CLASS=%1\
 BASE_FLAGS=%2\
 BASE_OPTIONS=%3\
-BASE_JARS="%(echo %4 | sed -e 's,:, ,g')"\
+BASE_JARS="%(echo %4 | tr ':' ' ')"\
 \
 # Set parameters\
 set_jvm\
-set_classpath \\$BASE_JARS\
-set_flags \\$BASE_FLAGS\
-set_options \\$BASE_OPTIONS\
+set_classpath $BASE_JARS\
+set_flags $BASE_FLAGS\
+set_options $BASE_OPTIONS\
 \
 # Let's start\
-run "\\$@"\
+run "$@"\
 EOF
 
-# vim:ts=8 sw=8 noet
+# pear install macros written by glen@pld-linux.org.
+# All rights reserved. Permission to copy is hereby granted.. yada, yada, yada
+#
+# Usage:
+#      %%pear_package_setup [-a #] [-n FMT]
+#
+# -a #   - unpack SOURCE# instead of SOURCE0
+# -n FMT - create builddir with FMT, instead of default %%{_pearname}-%%{version}
+# -z     - unpack pear package and let pear use package.xml (not tarball) for install. use this for buggy packages.
+# -f     - force pear install. use with care.
+#
+# unpack PEAR package to %%{_builddir}/FMT. package is extracted with already
+# destination hierarchy. you should copy the tree to buildroot after
+# patching/reorganizing with %%pear_package_install.
+#
+# additionally BUILDROOT is stripped from files and files are converted to UNIX
+# line endings.
+#
+# the pear install process output is recorded to install.log, you should put it
+# to %%doc for latter debug or just information.
+#
+# additionally additional-packages.txt is produced if it was detected that the
+# package has optional dependencies. the file format is suitable of displaying
+# in %%post of a package. you should put this file to %%doc. noautocompressdoc is
+# automatically added for this file.
+#
+%pear_package_setup(a:n:zf) \
+%setup -q -c -T -n %{-n*}%{!-n:%{_pearname}-%{version}}\
+D=%{_builddir}/%{-n*}%{!-n:%{_pearname}-%{version}} \
+%{-z:tar zxf %{S:%{-a*}%{!-a:0}}; P=%{_pearname}-%{version}/package.xml; [ -f $P ] || P=package.xml} \
+pear \\\
+       -d doc_dir=/docs \\\
+       -d php_dir=%{php_pear_dir} \\\
+       -d bin_dir=%{_bindir} \\\
+       -d data_dir=%{php_pear_dir}/data \\\
+       -d test_dir=%{php_pear_dir}/tests \\\
+       install \\\
+       --installroot=${D} \\\
+       --offline \\\
+       --nodeps \\\
+       %{-f:--force} \\\
+       %{!-z:%{S:%{-a*}%{!-a:0}}}%{-z:$P} | tee install.log \
+# make post message of optional packages \
+grep 'can optionally use' install.log | sed -e 's,package "pear/,package "php-pear-,g;s,^pear/,php-pear-,' > optional-packages.txt \
+if [ -s optional-packages.txt ]; then \
+       awk -F'"' '/use package/{print $2}' optional-packages.txt | sed -e "s,_,/,g;s,php-pear-, 'pear(,;s,$,.*)'," | tr -d '\\\n' > _noautoreq \
+else \
+       rm -f optional-packages.txt \
+fi \
+rm ./%{php_pear_dir}/.{lock,filemap} \
+# undos sources \
+find . -type f -print0 | xargs -0 sed -i -e 's,\\r$,,' \
+# bug in PEAR --installroot. \
+# http://pear.php.net/bugs/bug.php?id=5448 \
+grep -rl "${D}" ./{%{_bindir},%{php_pear_dir}}/* | xargs -r sed -i -e "s,${D},," \
+%{!?_noautocompressdoc:%global _noautocompressdoc %{nil}}%{expand:%%global _noautocompressdoc %{_noautocompressdoc} optional-packages.txt} \
+%{!?_noautoprov:%global _noautoprov %{nil}}%{expand:%%global _noautoprov %{_noautoprov} 'pear(tests/.*)'} \
+%{nil}
+
+# copies exctracted PEAR package structure to buildroot.
+# also copies PEAR registry file.
+# please use this macro, for future extensions being possible.
+%pear_package_install() \
+cp -a ./%{php_pear_dir}/{.registry,*} $RPM_BUILD_ROOT%{php_pear_dir} \
+find $RPM_BUILD_ROOT%{php_pear_dir} '(' -name '*~' -o -name '*.orig' ')' | xargs -r rm -v \
+# help the developer out a little: \
+if [ -f _noautoreq ]; then \
+       echo "AutoReqdep detected:" \
+       echo "_noautoreq $(cat _noautoreq)" \
+fi \
+%{nil}
+
+
+# Register OpenLDAP schema.
+# Author: Elan Ruusamäe <glen@pld-linux.org>
+#
+# Usage:
+#   %%openldap_schema_register [-d core,nis] %{schemadir}/horde.schema
+#
+#  -d specify dependant schemas, separated by comma
+#
+%openldap_schema_register(d:) \
+for schema in %*; do \
+       if ! grep -q "$schema" /etc/openldap/slapd.conf; then \
+               %{__sed} -i -e " \
+                       /^include.*local.schema/{ \
+                               iinclude\\t     $schema\
+                       } \
+               " /etc/openldap/slapd.conf \
+       fi \
+done \
+# enable dependant schemas \
+if [ "%{-d*}" ]; then \
+       %{__sed} -i -e ' \
+       /^#include.*\\(%(echo '%{-d*}' | %{__sed} -e 's/,/\\\\|/g')\\)\\.schema/{ \
+               s/^#// \
+       }' /etc/openldap/slapd.conf \
+fi \
+%{nil}
+
+# Unregister OpenLDAP schema.
+# Author: Elan Ruusamäe <glen@pld-linux.org>
+#
+# Usage:
+#   %%openldap_schema_unregister %{schemadir}/horde.schema
+#
+%openldap_schema_unregister() \
+for schema in %*; do \
+       if grep -q "$schema" /etc/openldap/slapd.conf; then \
+               %{__sed} -i -e " \
+               /^include.*$(echo "$schema" | %{__sed} -e 's,/,\\\\/,g')/d \
+               # for symmetry it would be nice if we disable enabled schemas in post, \
+               # but we really can not do that, it would break something else. \
+               " /etc/openldap/slapd.conf \
+       fi \
+done \
+%{nil}
+
+# vim:ts=4 sw=4 noet
This page took 0.041299 seconds and 4 git commands to generate.