diff options
author | Remi Collet <fedora@famillecollet.com> | 2016-07-01 17:51:09 +0200 |
---|---|---|
committer | Remi Collet <fedora@famillecollet.com> | 2016-07-01 17:51:09 +0200 |
commit | 9b80a49b10b3a88222347737d0fb8fed5cbea9a2 (patch) | |
tree | 107f94e2bd05f837118125ad7640016827765d49 |
php-zendframework-zend-expressive-router: 1.2.0 (New package)
-rw-r--r-- | Makefile | 3 | ||||
-rw-r--r-- | composer.json | 53 | ||||
-rwxr-xr-x | makesrc.sh | 28 | ||||
-rw-r--r-- | php-zendframework-zend-expressive-router.spec | 179 |
4 files changed, 263 insertions, 0 deletions
diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..a2cd659 --- /dev/null +++ b/Makefile @@ -0,0 +1,3 @@ +SRCDIR := $(shell pwd) +NAME := $(shell basename $(SRCDIR)) +include ../../../common/Makefile diff --git a/composer.json b/composer.json new file mode 100644 index 0000000..ccf6fe6 --- /dev/null +++ b/composer.json @@ -0,0 +1,53 @@ +{ + "name": "zendframework/zend-expressive-router", + "description": "Router subcomponent for Expressive", + "type": "library", + "license": "BSD-3-Clause", + "keywords": [ + "expressive", + "http", + "middleware", + "psr", + "psr-7" + ], + "extra": { + "branch-alias": { + "dev-master": "1.2-dev", + "dev-develop": "1.3-dev" + } + }, + "require": { + "php": "^5.5 || ^7.0", + "psr/http-message": "^1.0" + }, + "require-dev": { + "phpunit/phpunit": "^4.7", + "squizlabs/php_codesniffer": "^2.3" + }, + "autoload": { + "psr-4": { + "Zend\\Expressive\\Router\\": "src/" + } + }, + "autoload-dev": { + "psr-4": { + "ZendTest\\Expressive\\Router\\": "test/" + } + }, + "suggest": { + "zendframework/zend-expressive-aurarouter": "^0.1 to use the Aura.Router routing adapter", + "zendframework/zend-expressive-fastroute": "^0.1 to use the FastRoute routing adapter", + "zendframework/zend-expressive-zendrouter": "^0.1 to use the zend-mvc routing adapter" + }, + "scripts": { + "check": [ + "@cs", + "@test" + ], + "coveralls": "coveralls", + "cs": "phpcs", + "cs-fix": "phpcbf", + "test": "phpunit", + "test-coverage": "phpunit --coverage-clover clover.xml" + } +} diff --git a/makesrc.sh b/makesrc.sh new file mode 100755 index 0000000..87d223d --- /dev/null +++ b/makesrc.sh @@ -0,0 +1,28 @@ +#!/bin/bash + +NAME=$(basename $PWD) +OWNER=$(sed -n '/^%global gh_owner/{s/.* //;p}' $NAME.spec) +PROJECT=$(sed -n '/^%global gh_project/{s/.* //;p}' $NAME.spec) +VERSION=$(sed -n '/^Version:/{s/.* //;p}' $NAME.spec) +COMMIT=$(sed -n '/^%global gh_commit/{s/.* //;p}' $NAME.spec) +SHORT=${COMMIT:0:7} + +echo -e "\nCreate git snapshot\nName=$NAME, Owner=$OWNER, Project=$PROJECT, Version=$VERSION\n" + +echo "Cloning..." +rm -rf $PROJECT-$COMMIT +git clone https://github.com/$OWNER/$PROJECT.git $PROJECT-$COMMIT + +echo "Getting commit..." +pushd $PROJECT-$COMMIT +git checkout $COMMIT +cp composer.json ../composer.json +popd + +echo "Archiving..." +tar czf $NAME-$VERSION-$SHORT.tgz --exclude .git $PROJECT-$COMMIT + +echo "Cleaning..." +rm -rf $PROJECT-$COMMIT + +echo "Done." diff --git a/php-zendframework-zend-expressive-router.spec b/php-zendframework-zend-expressive-router.spec new file mode 100644 index 0000000..695e13a --- /dev/null +++ b/php-zendframework-zend-expressive-router.spec @@ -0,0 +1,179 @@ +# remirepo/Fedora spec file for php-zendframework-zend-expressive-router +# +# Copyright (c) 2016 Remi Collet +# License: CC-BY-SA +# http://creativecommons.org/licenses/by-sa/4.0/ +# +# Please, preserve the changelog entries +# +%global bootstrap 0 +%global gh_commit ec11c758e067c3eef579cb51dcabfcbf5de2ec03 +%global gh_short %(c=%{gh_commit}; echo ${c:0:7}) +%global gh_owner zendframework +%global gh_project zend-expressive-router +%global php_home %{_datadir}/php +%global library Expressive +%global sublib Router +%if %{bootstrap} +%global with_tests 0%{?_with_tests:1} +%else +%global with_tests 0%{!?_without_tests:1} +%endif + +Name: php-%{gh_owner}-%{gh_project} +Version: 1.2.0 +Release: 1%{?dist} +Summary: %{sublib} subcomponent for %{library} + +Group: Development/Libraries +License: BSD +URL: https://framework.zend.com/ +Source0: %{gh_commit}/%{name}-%{version}-%{gh_short}.tgz +Source1: makesrc.sh + +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root +BuildArch: noarch +# Tests +%if %{with_tests} +BuildRequires: php(language) >= 5.5 +BuildRequires: php-composer(psr/http-message) >= 1.0 +BuildRequires: php-pcre +BuildRequires: php-spl +# From composer, "require-dev": { +# "phpunit/phpunit": "^4.7", +# "squizlabs/php_codesniffer": "^2.3" +BuildRequires: php-composer(phpunit/phpunit) >= 4.7 +# Autoloader +BuildRequires: php-composer(%{gh_owner}/zend-loader) >= 2.5 +# For dependencies autoloader +BuildRequires: php-zendframework-zend-loader >= 2.5.1-3 +%endif + +# From composer, "require": { +# "php": "^5.5 || ^7.0", +# "psr/http-message": "^1.0" +Requires: php(language) >= 5.5 +Requires: php-composer(psr/http-message) >= 1.0 +Requires: php-composer(psr/http-message) < 2 +# From phpcompatinfo report for version 1.2.0 +Requires: php-pcre +Requires: php-spl +%if ! %{bootstrap} +# From composer, "suggest": { +# "zendframework/zend-expressive-aurarouter": "^0.1 to use the Aura.Router routing adapter", +# "zendframework/zend-expressive-fastroute": "^0.1 to use the FastRoute routing adapter", +# "zendframework/zend-expressive-zendrouter": "^0.1 to use the zend-mvc routing adapter" +%if 0%{?fedora} >= 21 +Suggests: php-composer(%{gh_owner}/zend-expressive-aurarouter) +Suggests: php-composer(%{gh_owner}/zend-expressive-fastroute) +Suggests: php-composer(%{gh_owner}/zend-expressive-zendrouter) +%endif +# Autoloader +Requires: php-composer(%{gh_owner}/zend-loader) >= 2.5 +Requires: php-zendframework-zend-loader >= 2.5.1-3 +%endif + +Provides: php-composer(%{gh_owner}/%{gh_project}) = %{version} + + +%description +Router subcomponent for Expressive. + +This package provides the following classes and interfaces: + +* RouterInterface, a generic interface to implement for providing routing + capabilities around PSR-7 ServerRequest messages. +* Route, a value object describing routed middleware. +* RouteResult, a value object describing the results of routing. + +We currently support and provide the following routing integrations: + +* Aura.Router: php-zendframework-zend-expressive-aurarouter +* FastRoute: php-zendframework-zend-expressive-fastroute +* ZF2 MVC Router: php-zendframework-zend-expressive-zendviewrouter + +Documentation: http://zend-expressive.readthedocs.io/ + + +%prep +%setup -q -n %{gh_project}-%{gh_commit} + +mv LICENSE.md LICENSE + +: Create dependency autoloader +cat << 'EOF' | tee autoload.php +<?php +require_once '%{php_home}/Psr/Http/Message/autoload.php'; +EOF + + +%build +# Empty build section, nothing required + + +%install +rm -rf %{buildroot} + +mkdir -p %{buildroot}%{php_home}/Zend/%{library} +cp -pr src %{buildroot}%{php_home}/Zend/%{library}/%{sublib} + +install -m644 autoload.php %{buildroot}%{php_home}/Zend/%{library}-%{sublib}-autoload.php + + +%check +%if %{with_tests} +mkdir vendor +cat << 'EOF' | tee vendor/autoload.php +<?php +define('RPM_BUILDROOT', '%{buildroot}%{php_home}/Zend'); + +require_once '%{php_home}/Zend/Loader/AutoloaderFactory.php'; +Zend\Loader\AutoloaderFactory::factory(array( + 'Zend\Loader\StandardAutoloader' => array( + 'namespaces' => array( + 'ZendTest\\%{library}\\%{sublib}' => dirname(__DIR__).'/test/', + 'Zend\\%{library}\\%{sublib}' => '%{buildroot}%{php_home}/Zend/%{library}/%{sublib}' +)))); +require_once '%{php_home}/Zend/autoload.php'; +EOF + +# remirepo:11 +run=0 +ret=0 +if which php56; then + php56 %{_bindir}/phpunit --include-path=%{buildroot}%{php_home} || ret=1 + run=1 +fi +if which php71; then + php70 %{_bindir}/phpunit --include-path=%{buildroot}%{php_home} || ret=1 + run=1 +fi +if [ $run -eq 0 ]; then +%{_bindir}/phpunit --include-path=%{buildroot}%{php_home} --verbose +# remirepo:2 +fi +exit $ret +%else +: Test suite disabled +%endif + + +%clean +rm -rf %{buildroot} + + +%files +%defattr(-,root,root,-) +%{!?_licensedir:%global license %%doc} +%license LICENSE +%doc *.md +%doc composer.json +%dir %{php_home}/Zend/%{library}/%{sublib} + %{php_home}/Zend/%{library}/%{sublib} + %{php_home}/Zend/%{library}-%{sublib}-autoload.php + + +%changelog +* Fri Jul 1 2016 Remi Collet <remi@fedoraproject.org> - 1.2.0-1 +- initial package + |