diff options
author | Remi Collet <fedora@famillecollet.com> | 2015-10-30 17:10:23 +0100 |
---|---|---|
committer | Remi Collet <fedora@famillecollet.com> | 2015-10-30 17:10:23 +0100 |
commit | fcef1e4016510423c476a4d96d66bc0853a6f3d3 (patch) | |
tree | 6a619727609f88c06879476e4f53b0449b415bce /php-nette-application.spec |
php-nette-application: 2.3.7, newpackage
Diffstat (limited to 'php-nette-application.spec')
-rw-r--r-- | php-nette-application.spec | 172 |
1 files changed, 172 insertions, 0 deletions
diff --git a/php-nette-application.spec b/php-nette-application.spec new file mode 100644 index 0000000..9642048 --- /dev/null +++ b/php-nette-application.spec @@ -0,0 +1,172 @@ +# remirepo/fedora spec file for php-nette-application +# +# Copyright (c) 2015 Remi Collet +# License: CC-BY-SA +# http://creativecommons.org/licenses/by-sa/4.0/ +# +# Please, preserve the changelog entries +# +%global gh_commit 8e87ae81c2098abd7895bfd96d9fac1cd332abc3 +#global gh_date 20150728 +%global gh_short %(c=%{gh_commit}; echo ${c:0:7}) +%global gh_owner nette +%global gh_project application +%global ns_vendor Nette +%global ns_project Application +%global php_home %{_datadir}/php +%global with_tests 0%{!?_without_tests:1} + +Name: php-%{gh_owner}-%{gh_project} +Version: 2.3.7 +%global specrel 1 +Release: %{?gh_date:0.%{specrel}.%{?prever}%{!?prever:%{gh_date}git%{gh_short}}}%{!?gh_date:%{specrel}}%{?dist} +Summary: Nette Application MVC Component + +Group: Development/Libraries +License: BSD or GPLv2 or GPLv3 +URL: https://github.com/%{gh_owner}/%{gh_project} +Source0: %{name}-%{version}-%{gh_short}.tgz +# pull a git snapshot to get test sutie +Source1: makesrc.sh + +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) +BuildArch: noarch +BuildRequires: php-composer(theseer/autoload) +%if %{with_tests} +BuildRequires: php(language) >= 5.3.1 +BuildRequires: php-composer(%{gh_owner}/component-model) >= 2.2 +BuildRequires: php-composer(%{gh_owner}/http) >= 2.2 +BuildRequires: php-composer(%{gh_owner}/reflection) >= 2.2 +BuildRequires: php-composer(%{gh_owner}/security) >= 2.2 +BuildRequires: php-composer(%{gh_owner}/utils) >= 2.2 +BuildRequires: php-pcre +BuildRequires: php-reflection +BuildRequires: php-spl +# From composer.json, "require-dev": { +# "nette/tester": "~1.3", +# "nette/di": "~2.3", +# "nette/forms": "~2.2", +# "nette/robot-loader": "~2.2", +# "latte/latte": "~2.3.0" +BuildRequires: php-composer(%{gh_owner}/tester) >= 1.3 +BuildRequires: php-composer(%{gh_owner}/di) >= 2.3 +BuildRequires: php-composer(%{gh_owner}/forms) >= 2.2 +BuildRequires: php-composer(%{gh_owner}/robot-loader) >= 2.2 +BuildRequires: php-composer(latte/latte) >= 2.3.0 +%endif + +# from composer.json, "require": { +# "php": ">=5.3.1" +# "nette/component-model": "~2.2", +# "nette/http": "~2.2", +# "nette/reflection": "~2.2", +# "nette/security": "~2.2", +# "nette/utils": "~2.2" +Requires: php(language) >= 5.3.1 +Requires: php-composer(%{gh_owner}/component-model) >= 2.2 +Requires: php-composer(%{gh_owner}/component-model) < 3 +Requires: php-composer(%{gh_owner}/http) >= 2.2 +Requires: php-composer(%{gh_owner}/http) < 3 +Requires: php-composer(%{gh_owner}/reflection) >= 2.2 +Requires: php-composer(%{gh_owner}/reflection) < 3 +Requires: php-composer(%{gh_owner}/security) >= 2.2 +Requires: php-composer(%{gh_owner}/security) < 3 +Requires: php-composer(%{gh_owner}/utils) >= 2.2 +Requires: php-composer(%{gh_owner}/utils) < 3 +# from composer.json, "suggest": { +# "nette/forms": "Allows to use Nette\\Application\\UI\\Form", +# "latte/latte": "Allows using Latte in templates" +# from phpcompatinfo report for version 2.3.3 +%if 0%{?fedora} > 21 +Suggests: php-composer(%{gh_owner}/forms) +Suggests: php-composer(latte/latte) +%endif +Requires: php-pcre +Requires: php-reflection +Requires: php-spl + +Provides: php-composer(%{gh_owner}/%{gh_project}) = %{version} + + +%description +Model-View-Controller is a software architecture that was created to +satisfy the need to separate utility code (controller) from application +logic code (model) and from code for displaying data (view) in applications +with graphical user interface. With this approach we make the application +better understandable, simplify future development and enable testing each +unit of the application separately. + +To use this library, you just have to add, in your project: + require_once '%{php_home}/%{ns_vendor}/%{ns_project}/autoload.php'; + + +%prep +%setup -q -n %{gh_project}-%{gh_commit} + + +%build +: Generate a classmap autoloader +phpab --output src/%{ns_project}/autoload.php src + +cat << 'EOF' | tee -a src/%{ns_project}/autoload.php +// Dependencies +require_once '%{php_home}/%{ns_vendor}/ComponentModel/autoload.php'; +require_once '%{php_home}/%{ns_vendor}/Http/autoload.php'; +require_once '%{php_home}/%{ns_vendor}/Reflection/autoload.php'; +require_once '%{php_home}/%{ns_vendor}/Security/autoload.php'; +require_once '%{php_home}/%{ns_vendor}/Utils/autoload.php'; +// Optional +@include_once '%{php_home}/%{ns_vendor}/Forms/autoload.php'; +@include_once '%{php_home}/Latte/autoload.php'; +EOF + + +%install +rm -rf %{buildroot} +mkdir -p %{buildroot}%{php_home}/%{ns_vendor} +cp -pr src/* %{buildroot}%{php_home}/%{ns_vendor}/ + + +%check +%if %{with_tests} +: Ignore failed test - under investigation +rm tests/Bridges.DI/ApplicationExtension.scan.phpt + +: Generate configuration +cat /etc/php.ini /etc/php.d/*ini >php.ini +export LANG=fr_FR.utf8 + +: Generate autoloader +mkdir vendor +cat << 'EOF' | tee vendor/autoload.php +<?php +require_once '%{php_home}/Tester/autoload.php'; +require_once '%{php_home}/%{ns_vendor}/DI/autoload.php'; +require_once '%{php_home}/%{ns_vendor}/RobotLoader/autoload.php'; +require_once '%{buildroot}%{php_home}/%{ns_vendor}/%{ns_project}/autoload.php'; +EOF + +: Run test suite in sources tree +nette-tester --colors 0 -p php -c ./php.ini tests -s +%else +: Test suite disabled +%endif + + +%clean +rm -rf %{buildroot} + + +%files +%defattr(-,root,root,-) +%{!?_licensedir:%global license %%doc} +%license license.md +%doc readme.md contributing.md +%doc composer.json +%{php_home}/%{ns_vendor}/%{ns_project} +%{php_home}/%{ns_vendor}/Bridges + + +%changelog +* Fri Oct 30 2015 Remi Collet <remi@fedoraproject.org> - 2.3.7-1 +- initial package
\ No newline at end of file |