From 280576d10df46e849490b0669312e5ad412b1e82 Mon Sep 17 00:00:00 2001 From: Remi Collet Date: Mon, 4 Apr 2016 16:38:25 +0200 Subject: php-hoa-exception: new package (wip) --- LICENSE | 29 +++++++++++ Makefile | 4 ++ php-hoa-exception-autoload.php | 24 +++++++++ php-hoa-exception.spec | 111 +++++++++++++++++++++++++++++++++++++++++ 4 files changed, 168 insertions(+) create mode 100644 LICENSE create mode 100644 Makefile create mode 100644 php-hoa-exception-autoload.php create mode 100644 php-hoa-exception.spec diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..52862ba --- /dev/null +++ b/LICENSE @@ -0,0 +1,29 @@ + New BSD License + + + +Copyright © 2007-2016, Hoa community. +All rights reserved. + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions are met: + * Redistributions of source code must retain the above copyright + notice, this list of conditions and the following disclaimer. + * Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + * Neither the name of the Hoa nor the names of its contributors may be + used to endorse or promote products derived from this software without + specific prior written permission. + +THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" +AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS AND CONTRIBUTORS BE +LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR +CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF +SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS +INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN +CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) +ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE +POSSIBILITY OF SUCH DAMAGE. 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/php-hoa-exception-autoload.php b/php-hoa-exception-autoload.php new file mode 100644 index 0000000..ab72272 --- /dev/null +++ b/php-hoa-exception-autoload.php @@ -0,0 +1,24 @@ +register(); +} + +$fedoraClassLoader->addPrefix('Hoa\\Exception\\', dirname(dirname(__DIR__))); + +// Dependencies +foreach ([ + $vendor . '/Hoa/Consistency/autoload.php' => true, + $vendor . '/Hoa/Event/autoload.php' => true, + ] as $dep => $mandatory) { + if ($mandory || file_exists($dep) require_once($dep); +} + diff --git a/php-hoa-exception.spec b/php-hoa-exception.spec new file mode 100644 index 0000000..fbc06ad --- /dev/null +++ b/php-hoa-exception.spec @@ -0,0 +1,111 @@ +# remirepo/fedora spec file for php-hoa-exception +# +# Copyright (c) 2016 Remi Collet +# License: CC-BY-SA +# http://creativecommons.org/licenses/by-sa/4.0/ +# +# Please, preserve the changelog entries +# +%global bootstrap 1 +%global gh_commit fa4a9648aef2c8ca8f4cd543429b24dc8feaa366 +%global gh_short %(c=%{gh_commit}; echo ${c:0:7}) +%global gh_owner hoaproject +%global gh_project Exception +%global php_home %{_datadir}/php +%global ns_vendor Hoa +%global ns_project Exception +%global pk_vendor hoa +%global pk_project exception +%if %{bootstrap} +%global with_tests 0%{?_with_tests:1} +%else +%global with_tests 0%{!?_without_tests:1} +%endif + +Name: php-%{pk_vendor}-%{pk_project} +Version: 1.16.01.11 +%global specrel 0 +Release: %{?gh_date:0.%{specrel}.%{?prever}%{!?prever:%{gh_date}git%{gh_short}}}%{!?gh_date:%{specrel}}%{?dist} +Summary: The %{ns_vendor}\%{ns_project} library. + +Group: Development/Libraries +License: BSD +URL: https://github.com/%{gh_owner}/%{gh_project} +Source0: https://github.com/%{gh_owner}/%{gh_project}/archive/%{gh_commit}/%{name}-%{version}-%{gh_short}.tar.gz +Source1: %{name}-autoload.php +Source2: http://hoa-project.net/LICENSE + +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) +BuildArch: noarch +%if %{with_tests} +BuildRequires: php-composer(%{pk_vendor}/consistency) >= 1.0 +BuildRequires: php-composer(%{pk_vendor}/event) >= 1.0 +# From composer.json, "require-dev": { +# "hoa/test": "~2.0" +BuildRequires: php-composer(%{pk_vendor}/test) >= 2.0 +%endif + +# from composer.json, "require": { +# "hoa/consistency": "~1.0", +# "hoa/event" : "~1.0" +Requires: php-composer(%{pk_vendor}/consistency) >= 1.0 +Requires: php-composer(%{pk_vendor}/consistency) < 2 +Requires: php-composer(%{pk_vendor}/event) >= 1.0 +Requires: php-composer(%{pk_vendor}/event) < 2 +# from phpcompatinfo report for version 1.16.01.11: +Requires: php-reflection +Requires: php-spl + +Provides: php-composer(%{pk_vendor}/%{pk_project}) = %{version} + + +%description +The %{ns_vendor}\%{ns_project} library allows to use advanced exceptions. + +It provides generic exceptions (that are sent over the hoa://Event/Exception +event channel), idle exceptions (that are not sent over an event channel), +uncaught exception handlers, errors to exceptions handler and group of +exceptions (with transactions). + +Autoloader: %{php_home}/%{ns_vendor}/%{ns_project}/autoload.php + + +%prep +%setup -q -n %{gh_project}-%{gh_commit} +cp %{SOURCE1} autoload.php +cp %{SOURCE2} LICENSE + +%build +: Nothing + +%install +rm -rf %{buildroot} +mkdir -p %{buildroot}%{php_home}/%{ns_vendor}/%{ns_project} +cp -pr *php %{buildroot}%{php_home}/%{ns_vendor}/%{ns_project}/ + + +%check +%if %{with_tests} +%else +: bootstrap build with test suite disabled +%endif + + +%clean +rm -rf %{buildroot} + + +%files +%defattr(-,root,root,-) +%{!?_licensedir:%global license %%doc} +%license LICENSE +%doc composer.json +%doc *md +%{php_home}/%{ns_vendor}/%{ns_project} + + +%changelog +* Mon Apr 4 2016 Remi Collet - 1.16.01.11-0 +- initial package +- bootstrap build + -- cgit