From 74f92d484b6adff3c91b19f3c4a090ec7492db80 Mon Sep 17 00:00:00 2001 From: Remi Collet Date: Sun, 4 Nov 2012 12:14:44 +0100 Subject: php-horde-Horde-Core: new package --- Makefile | 4 + find-lang.sh | 192 +++++++++++++++++++++++++++++++++++++++++ php-horde-Horde-Core.spec | 211 ++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 407 insertions(+) create mode 100644 Makefile create mode 100755 find-lang.sh create mode 100644 php-horde-Horde-Core.spec diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..13af741 --- /dev/null +++ b/Makefile @@ -0,0 +1,4 @@ +SRCDIR := $(shell pwd) +NAME := $(shell basename $(SRCDIR)) +include ../../../common/Makefile + diff --git a/find-lang.sh b/find-lang.sh new file mode 100755 index 0000000..cfd3be9 --- /dev/null +++ b/find-lang.sh @@ -0,0 +1,192 @@ +#!/bin/sh +#findlang - automagically generate list of language specific files +#for inclusion in an rpm spec file. +#This does assume that the *.mo files are under .../locale/... +#Run with no arguments gets a usage message. + +#findlang is copyright (c) 1998 by W. L. Estes + +#Redistribution and use of this software are hereby permitted for any +#purpose as long as this notice and the above copyright notice remain +#in tact and are included with any redistribution of this file or any +#work based on this file. + +# 2004-06-20 Arkadiusz Miƛkiewicz +# * merge PLD changes, kde, all-name (mkochano,pascalek@PLD) +# 1999-10-19 Artur Frysiak +# * added support for GNOME help files +# * start support for KDE help files + +usage () { +cat <&2 +elif [ ! -d $1 ] ; then + echo $0: $1: no such directory + exit 1 +else TOP_DIR="`echo $1|sed -e 's:/$::'`" +fi +shift + +if [ -z "$1" ] ; then usage +else NAME=$1 +fi +shift + +GNOME=# +KDE=# +QT=# +MAN=# +MO= +MO_NAME=$NAME.lang +ALL_NAME=# +NO_ALL_NAME= + +while test $# -gt 0 ; do + case "${1}" in + --with-gnome ) + GNOME= + shift + ;; + --with-kde ) + KDE= + shift + ;; + --with-qt ) + QT= + shift + ;; + --with-man ) + MAN= + shift + ;; + --without-mo ) + MO=# + shift + ;; + --all-name ) + ALL_NAME= + NO_ALL_NAME=# + shift + ;; + * ) + MO_NAME=${1} + shift + ;; + esac +done + +find $TOP_DIR -type f -o -type l|sed ' +s:'"$TOP_DIR"':: +'"$ALL_NAME$MO"'s:\(.*/locale/\)\([^/_]\+\)\(.*\.mo$\):%lang(\2) \1\2\3: +'"$NO_ALL_NAME$MO"'s:\(.*/locale/\)\([^/_]\+\)\(.*/'"$NAME"'\.mo$\):%lang(\2) \1\2\3: +s:^\([^%].*\):: +s:%lang(C) :: +/^$/d' > $MO_NAME + +find $TOP_DIR -type d|sed ' +s:'"$TOP_DIR"':: +'"$NO_ALL_NAME$GNOME"'s:\(.*/gnome/help/'"$NAME"'$\):%dir \1: +'"$NO_ALL_NAME$GNOME"'s:\(.*/gnome/help/'"$NAME"'/[a-zA-Z0-9.\_\-]/.\+\):: +'"$NO_ALL_NAME$GNOME"'s:\(.*/gnome/help/'"$NAME"'\/\)\([^/_]\+\):%lang(\2) \1\2: +'"$ALL_NAME$GNOME"'s:\(.*/gnome/help/[a-zA-Z0-9.\_\-]\+$\):%dir \1: +'"$ALL_NAME$GNOME"'s:\(.*/gnome/help/[a-zA-Z0-9.\_\-]\+/[a-zA-Z0-9.\_\-]/.\+\):: +'"$ALL_NAME$GNOME"'s:\(.*/gnome/help/[a-zA-Z0-9.\_\-]\+\/\)\([^/_]\+\):%lang(\2) \1\2: +s:%lang(.*) .*/gnome/help/[a-zA-Z0-9.\_\-]\+/[a-zA-Z0-9.\_\-]\+/.*:: +s:^\([^%].*\):: +s:%lang(C) :: +/^$/d' >> $MO_NAME + +find $TOP_DIR -type d|sed ' +s:'"$TOP_DIR"':: +'"$NO_ALL_NAME$GNOME"'s:\(.*/omf/'"$NAME"'$\):%dir \1: +'"$ALL_NAME$GNOME"'s:\(.*/omf/[a-zA-Z0-9.\_\-]\+$\):%dir \1: +s:^\([^%].*\):: +/^$/d' >> $MO_NAME + +find $TOP_DIR -type f|sed ' +s:'"$TOP_DIR"':: +'"$NO_ALL_NAME$GNOME"'s:\(.*/omf/'"$NAME"'/'"$NAME"'-\([^/.]\+\)\.omf\):%lang(\2) \1: +'"$ALL_NAME$GNOME"'s:\(.*/omf/[a-zA-Z0-9.\_\-]\+/[a-zA-Z0-9.\_\-]\+-\([^/.]\+\)\.omf\):%lang(\2) \1: +s:^[^%].*:: +s:%lang(C) :: +/^$/d' >> $MO_NAME + +KDE3_HTML=`kde-config --expandvars --install html 2>/dev/null` +if [ x"$KDE3_HTML" != x -a -d "$TOP_DIR$KDE3_HTML" ]; then +find $TOP_DIR$KDE3_HTML -type d|sed ' +s:'"$TOP_DIR"':: +'"$NO_ALL_NAME$KDE"'s:\(.*/HTML/\)\([^/_]\+\)\(.*/'"$NAME"'/\):: +'"$NO_ALL_NAME$KDE"'s:\(.*/HTML/\)\([^/_]\+\)\(.*/'"$NAME"'\)$:%lang(\2) \1\2\3: +'"$ALL_NAME$KDE"'s:\(.*/HTML/\)\([^/_]\+\)\(.*/[a-zA-Z0-9.\_\-]\+/\):: +'"$ALL_NAME$KDE"'s:\(.*/HTML/\)\([^/_]\+\)\(.*/[a-zA-Z0-9.\_\-]\+$\):%lang(\2) \1\2\3: +s:^\([^%].*\):: +s:%lang(C) :: +/^$/d' >> $MO_NAME +fi + +KDE4_HTML=`kde4-config --expandvars --install html 2>/dev/null` +if [ x"$KDE4_HTML" != x -a -d "$TOP_DIR$KDE4_HTML" ]; then +find $TOP_DIR$KDE4_HTML -type d|sed ' +s:'"$TOP_DIR"':: +'"$NO_ALL_NAME$KDE"'s:\(.*/HTML/\)\([^/_]\+\)\(.*/'"$NAME"'/\):: +'"$NO_ALL_NAME$KDE"'s:\(.*/HTML/\)\([^/_]\+\)\(.*/'"$NAME"'\)$:%lang(\2) \1\2\3: +'"$ALL_NAME$KDE"'s:\(.*/HTML/\)\([^/_]\+\)\(.*/[a-zA-Z0-9.\_\-]\+/\):: +'"$ALL_NAME$KDE"'s:\(.*/HTML/\)\([^/_]\+\)\(.*/[a-zA-Z0-9.\_\-]\+$\):%lang(\2) \1\2\3: +s:^\([^%].*\):: +s:%lang(C) :: +/^$/d' >> $MO_NAME +fi + +find $TOP_DIR -type f -o -type l|sed ' +s:'"$TOP_DIR"':: +'"$NO_ALL_NAME$QT"'s:\(.*/'"$NAME"'_\([a-zA-Z]\{2\}\([_@].*\)\?\)\.qm$\):%lang(\2) \1: +'"$ALL_NAME$QT"'s:\(.*/[^/_]\+_\([a-zA-Z]\{2\}[_@].*\)\.qm$\):%lang(\2) \1: +'"$ALL_NAME$QT"'s:\(.*/[^/_]\+_\([a-zA-Z]\{2\}\)\.qm$\):%lang(\2) \1: +'"$ALL_NAME$QT"'s:^\([^%].*/[^/]\+_\([a-zA-Z]\{2\}[_@].*\)\.qm$\):%lang(\2) \1: +'"$ALL_NAME$QT"'s:^\([^%].*/[^/]\+_\([a-zA-Z]\{2\}\)\.qm$\):%lang(\2) \1: +s:^[^%].*:: +s:%lang(C) :: +/^$/d' >> $MO_NAME + +find $TOP_DIR -type d|sed ' +s:'"$TOP_DIR"':: +'"$ALL_NAME$MAN"'s:\(.*/man/\([^/_]\+\).*/man[a-z0-9]\+/\):: +'"$ALL_NAME$MAN"'s:\(.*/man/\([^/_]\+\).*/man[a-z0-9]\+$\):%lang(\2) \1/*: +s:^\([^%].*\):: +s:%lang(C) :: +/^$/d' >> $MO_NAME + +find $TOP_DIR -type f -o -type l|sed ' +s:'"$TOP_DIR"':: +'"$NO_ALL_NAME$MAN"'s:\(.*/man/\([^/_]\+\).*/man[a-z0-9]\+/'"$NAME"'\.[a-z0-9].*\):%lang(\2) \1*: +s:^\([^%].*\):: +s:%lang(C) :: +/^$/d' >> $MO_NAME + +if ! grep -q / $MO_NAME; then + echo "No translations found for ${NAME} in ${TOP_DIR}" + exit 1 +fi +exit 0 diff --git a/php-horde-Horde-Core.spec b/php-horde-Horde-Core.spec new file mode 100644 index 0000000..d3779bb --- /dev/null +++ b/php-horde-Horde-Core.spec @@ -0,0 +1,211 @@ +%{!?pear_metadir: %global pear_metadir %{pear_phpdir}} +%{!?__pear: %{expand: %%global __pear %{_bindir}/pear}} +%global pear_name Horde_Core +%global pear_channel pear.horde.org + +Name: php-pear.horde.org-Horde-Core +Version: 2.0.1 +Release: 1%{?dist} +Summary: Horde Core Framework libraries + +Group: Development/Libraries +License: LGPL-2.1 +URL: http://pear.horde.org +Source0: http://%{pear_channel}/get/%{pear_name}-%{version}.tgz +# /usr/lib/rpm/find-lang.sh from fedora 16 +Source1: find-lang.sh + +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) +BuildArch: noarch +BuildRequires: php-pear +BuildRequires: gettext +BuildRequires: php-channel(%{pear_channel}) +BuildRequires: php-pear(%{pear_channel}/Horde_Role) >= 1.0.0 +# To run unit tests +BuildRequires: php-pear(%{pear_channel}/Horde_Test) >= 2.0.0 +BuildRequires: php-pear(%{pear_channel}/Horde_Url) >= 2.0.0 +BuildRequires: php-pear(%{pear_channel}/Horde_Injector) >= 2.0.0 +BuildRequires: php-pear(%{pear_channel}/Horde_Group) >= 2.0.0 + +Requires(post): %{__pear} +Requires(postun): %{__pear} +Requires: php-channel(%{pear_channel}) +BuildRequires: php-pear(%{pear_channel}/Horde_Role) >= 1.0.0 +Requires: php-pear(%{pear_channel}/Horde_Alarm) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Alarm) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Auth) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Auth) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Autoloader) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Autoloader) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Browser) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Browser) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Cache) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Cache) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Cli) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Cli) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Compress) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Compress) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Controller) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Controller) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Data) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Data) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Date) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Date) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Exception) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Exception) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Group) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Group) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_History) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_History) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Injector) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Injector) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Lock) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Lock) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Log) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Log) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_LoginTasks) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_LoginTasks) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Mime) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Mime) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Mime_Viewer) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Mime_Viewer) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Notification) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Notification) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Perms) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Perms) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Prefs) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Prefs) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Secret) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Secret) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Serialize) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Serialize) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_SessionHandler) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_SessionHandler) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Share) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Share) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Support) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Support) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Template) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Template) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Token) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Token) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Text_Filter) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Text_Filter) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Text_Filter_Csstidy) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Text_Filter_Csstidy) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Translation) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Translation) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Url) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Url) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_Util) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_Util) >= 3.0.0 +Requires: php-pear(%{pear_channel}/Horde_View) >= 2.0.0 +Conflicts: php-pear(%{pear_channel}/Horde_View) >= 3.0.0 +# Optionnal: Horde_ActiveSync, Horde_Crypt, Horde_Editor, Horde_ElasticSearch, Horde_Form +# Horde_Http, Horde_Icalendar, Horde_Image, Horde_Imap_Client, Horde_Kolab_Server +# Horde_Kolab_Session, Horde_Kolab_Storage, Horde_Ldap, Horde_Mail, Horde_Nls +# Horde_Oauth, Horde_Routes, Horde_Service_Twitter, Horde_SpellChecker, Horde_Tree +# Horde_Vfs, Net_DNS2, Text_CAPTCHA, Text_Figlet, Text_LanguageDetect, pecl/lzf + +Provides: php-pear(%{pear_channel}/%{pear_name}) = %{version} + + +%description +These classes provide the core functionality of the Horde Application +Framework. + + +%prep +%setup -q -c -T +tar xif %{SOURCE0} + +cd %{pear_name}-%{version} + +# Don't install .po and .pot files +# Remove checksum for .mo, as we regenerate them +sed -e '/%{pear_name}.po/d' \ + -e '/LICENSE/s/role="horde"/role="doc"/' \ + -e '/%{pear_name}.mo/s/md5sum=.*name=/name=/' \ + ../package.xml >%{name}.xml + + +%build +cd %{pear_name}-%{version} + +# Regenerate the locales +for po in $(find locale -name \*.po) +do + msgfmt $po -o $(dirname $po)/$(basename $po .po).mo +done + + +%install +rm -rf %{buildroot} +cd %{pear_name}-%{version} +%{__pear} install --nodeps --packagingroot %{buildroot} %{name}.xml + +# Clean up unnecessary files +rm -rf %{buildroot}%{pear_metadir}/.??* + +# Install XML package description +mkdir -p %{buildroot}%{pear_xmldir} +install -pm 644 %{name}.xml %{buildroot}%{pear_xmldir} + +%if 0%{?fedora} > 13 +%find_lang %{pear_name} +%else +sh %{SOURCE1} %{buildroot} %{pear_name} +%endif + + +%check +cd %{pear_name}-%{version}/test/$(echo %{pear_name} | sed -e s:_:/:g) +phpunit -d date.timezone=UTC AllTests.php + + +%clean +rm -rf %{buildroot} + + +%post +%{__pear} install --nodeps --soft --force --register-only \ + %{pear_xmldir}/%{name}.xml >/dev/null || : + +%postun +if [ $1 -eq 0 ] ; then + %{__pear} uninstall --nodeps --ignore-errors --register-only \ + %{pear_channel}/%{pear_name} >/dev/null || : +fi + + +%files -f %{pear_name}-%{version}/%{pear_name}.lang +%defattr(-,root,root,-) +%doc %{pear_docdir}/%{pear_name} +%{pear_xmldir}/%{name}.xml +%{pear_phpdir}/Horde/Config +%{pear_phpdir}/Horde/Core +%{pear_phpdir}/Horde/Exception/*.php +%{pear_phpdir}/Horde/Registry +%{pear_phpdir}/Horde/Script +%{pear_phpdir}/Horde/Session +%{pear_phpdir}/Horde/Themes +%{pear_phpdir}/Horde/*.php +%{pear_phpdir}/Horde.php +%{pear_testdir}/%{pear_name} +# own locales (non standard) directories, .mo own by find_lang +%dir %{pear_datadir}/%{pear_name} +%dir %{pear_datadir}/%{pear_name}/locale +%dir %{pear_datadir}/%{pear_name}/locale/* +%dir %{pear_datadir}/%{pear_name}/locale/*/LC_MESSAGES +%{pear_datadir}/%{pear_name}/migration +# Web files +%dir %{pear_hordedir}/js +%{pear_hordedir}/js/date +%{pear_hordedir}/js/jquery.mobile +%{pear_hordedir}/js/map +%{pear_hordedir}/js/scriptaculous +%{pear_hordedir}/js/*js + +%changelog +* Sun Nov 4 2012 Remi Collet - 2.0.1-1 +- Initial package -- cgit