diff options
author | Remi Collet <fedora@famillecollet.com> | 2016-01-07 08:52:33 +0100 |
---|---|---|
committer | Remi Collet <fedora@famillecollet.com> | 2016-01-07 08:52:33 +0100 |
commit | c45127306479f8a3605bbc98c30528674d8a0f1b (patch) | |
tree | cb19487ac9901cb89104fe4679f5152f7ba5c950 |
php-di: import from Fedora
-rwxr-xr-x | php-di-get-source.sh | 69 | ||||
-rw-r--r-- | php-di.spec | 206 |
2 files changed, 275 insertions, 0 deletions
diff --git a/php-di-get-source.sh b/php-di-get-source.sh new file mode 100755 index 0000000..ba71f5d --- /dev/null +++ b/php-di-get-source.sh @@ -0,0 +1,69 @@ +#/bin/sh + +GIT=`which git` +RPM=`which rpm` + +if [ -z "$GIT" ] +then + echo "ERROR: 'git' command not found" 1>&2 + exit 1 +elif [ -z "$RPM" ] +then + echo "ERROR: 'rpm' command not found" 1>&2 + exit 1 +fi + +function print { + echo -e "\e[0;33m>>>>> ${1}\e[0m" +} + +if [ -x "$1" ] +then + SPEC=$1 +else + SPEC=`ls *.spec | head -1` +fi + +NAME=`echo $SPEC | sed 's#\.spec##'` +VERSION=`egrep '%global\s*github_version' $SPEC | awk '{print $3}'` + +print "SPEC = $SPEC" +print "NAME = $NAME" + +GIT_OWNER=`egrep '%global\s*github_owner' $SPEC | awk '{print $3}'` +GIT_NAME=`egrep '%global\s*github_name' $SPEC | awk '{print $3}'` +GIT_COMMIT=`egrep '%global\s*github_commit' $SPEC | awk '{print $3}'` +GIT_REPO=https://github.com/${GIT_OWNER}/${GIT_NAME} +GIT_DIR=`echo $GIT_REPO | sed 's#.*/##'` + +print "GIT_OWNER = $GIT_OWNER" +print "GIT_NAME = $GIT_NAME" +print "GIT_COMMIT = $GIT_COMMIT" +print "GIT_REPO = $GIT_REPO" +print "GIT_DIR = $GIT_DIR" + +TEMP_DIR=$(mktemp --dir) + +pushd $TEMP_DIR + print "Cloning git repo..." + $GIT clone $GIT_REPO + + pushd $GIT_DIR + print "Checking out commit..." + $GIT checkout $GIT_COMMIT + popd + + TAR_DIR=${GIT_NAME}-${GIT_COMMIT} + print "TAR_DIR = $TAR_DIR" + + mv $GIT_DIR $TAR_DIR + + TAR_FILE=`$RPM --eval='%{_sourcedir}'`/${NAME}-${VERSION}-${GIT_COMMIT}.tar.gz + print "TAR_FILE = $TAR_FILE" + + [ -e $TAR_FILE ] && rm -f $TAR_FILE + tar --exclude-vcs -czf $TAR_FILE $TAR_DIR + chmod 0644 $TAR_FILE +popd + +rm -rf $TEMP_DIR diff --git a/php-di.spec b/php-di.spec new file mode 100644 index 0000000..930f9af --- /dev/null +++ b/php-di.spec @@ -0,0 +1,206 @@ +# +# Fedora spec file for php-di +# +# Copyright (c) 2016 Shawn Iwinski <shawn@iwin.ski> +# +# License: MIT +# http://opensource.org/licenses/MIT +# +# Please preserve changelog entries +# + +%global github_owner PHP-DI +%global github_name PHP-DI +%global github_version 5.2.0 +%global github_commit e20ff1b465a15548e22efcea79e06df64d9e2068 + +%global composer_vendor php-di +%global composer_project php-di + +# "php": ">=5.4.0" +%global php_min_ver 5.4.0 +# "container-interop/container-interop": "~1.0" +%global container_interop_min_ver 1.0 +%global container_interop_max_ver 2.0 +# "doctrine/annotations": "~1.2" +%global doctrine_annotations_min_ver 1.2 +%global doctrine_annotations_max_ver 2.0 +# "doctrine/cache": "~1.4" +%global doctrine_cache_min_ver 1.4 +%global doctrine_cache_max_ver 2.0 +# "mnapoli/phpunit-easymock": "~0.2.0" +%global phpunit_easymock_min_ver 0.2.0 +%global phpunit_easymock_max_ver 1.0 +# "php-di/invoker": "^1.1.1" +%global di_invoker_min_ver 1.1.1 +%global di_invoker_max_ver 2.0 +# "php-di/phpdoc-reader": "^2.0.1" +%global di_phpdoc_reader_min_ver 2.0.1 +%global di_phpdoc_reader_max_ver 3.0 +# "ocramius/proxy-manager": "~1.0" +%global proxy_manager_min_ver 1.0 +%global proxy_manager_max_ver 2.0 + +# Build using "--without tests" to disable tests +%global with_tests 0%{!?_without_tests:1} + +%{!?phpdir: %global phpdir %{_datadir}/php} + +Name: %{composer_project} +Version: %{github_version} +Release: 1%{?github_release}%{?dist} +Summary: The dependency injection container for humans + +Group: Development/Libraries +License: MIT +URL: http://php-di.org/ + +# GitHub export does not include tests. +# Run php-di-invoker-get-source.sh to create full source. +Source0: %{name}-%{github_version}-%{github_commit}.tar.gz +Source1: %{name}-get-source.sh + +BuildArch: noarch +# Tests +%if %{with_tests} +## composer.json +BuildRequires: php(language) >= %{php_min_ver} +BuildRequires: php-composer(container-interop/container-interop) >= %{container_interop_min_ver} +BuildRequires: php-composer(doctrine/annotations) >= %{doctrine_annotations_min_ver} +BuildRequires: php-composer(doctrine/cache) >= %{doctrine_cache_min_ver} +BuildRequires: php-composer(mnapoli/phpunit-easymock) >= %{phpunit_easymock_min_ver} +BuildRequires: php-composer(ocramius/proxy-manager) >= %{proxy_manager_min_ver} +BuildRequires: php-composer(php-di/invoker) >= %{di_invoker_min_ver} +BuildRequires: php-composer(php-di/phpdoc-reader) >= %{di_phpdoc_reader_min_ver} +BuildRequires: php-composer(phpunit/phpunit) +## phpcompatinfo (computed from version 5.2.0) +BuildRequires: php-json +BuildRequires: php-pcre +BuildRequires: php-reflection +BuildRequires: php-spl +## Autoloader +BuildRequires: php-composer(symfony/class-loader) +%endif + +# composer.json +Requires: php(language) >= %{php_min_ver} +Requires: php-composer(container-interop/container-interop) >= %{container_interop_min_ver} +Requires: php-composer(container-interop/container-interop) < %{container_interop_max_ver} +Requires: php-composer(php-di/invoker) >= %{di_invoker_min_ver} +Requires: php-composer(php-di/invoker) < %{di_invoker_max_ver} +Requires: php-composer(php-di/phpdoc-reader) >= %{di_phpdoc_reader_min_ver} +Requires: php-composer(php-di/phpdoc-reader) < %{di_phpdoc_reader_max_ver} +# phpcompatinfo (computed from version 5.2.0) +Requires: php-json +Requires: php-pcre +Requires: php-reflection +Requires: php-spl +# Autoloader +Requires: php-composer(symfony/class-loader) +# Weak dependencies +%if 0%{?fedora} >= 20 +Suggests: php-composer(doctrine/annotations) >= %{doctrine_annotations_min_ver} +Suggests: php-composer(doctrine/annotations) < %{doctrine_annotations_max_ver} +Suggests: php-composer(doctrine/cache) >= %{doctrine_cache_min_ver} +Suggests: php-composer(doctrine/cache) < %{doctrine_cache_max_ver} +Suggests: php-composer(mnapoli/phpunit-easymock) >= %{phpunit_easymock_min_ver} +Suggests: php-composer(mnapoli/phpunit-easymock) < %{phpunit_easymock_max_ver} +Suggests: php-composer(ocramius/proxy-manager) >= %{proxy_manager_min_ver} +Suggests: php-composer(ocramius/proxy-manager) < %{proxy_manager_max_ver} +%endif + +# php-{COMPOSER_VENDOR}-{COMPOSER_PROJECT} +Provides: php-%{composer_vendor}-%{composer_project} = %{version}-%{release} +# Composer +Provides: php-composer(%{composer_vendor}/%{composer_project}) = %{version} + +%description +%{summary}. + +Autoloader: %{phpdir}/DI/autoload.php + + +%prep +%setup -qn %{github_name}-%{github_commit} + +: Create autoloader +cat <<'AUTOLOAD' | tee src/DI/autoload.php +<?php +/** + * Autoloader for %{name} and its' dependencies + * (created by %{name}-%{version}-%{release}). + * + * @return \Symfony\Component\ClassLoader\ClassLoader + */ + +if (!isset($fedoraClassLoader) || !($fedoraClassLoader instanceof \Symfony\Component\ClassLoader\ClassLoader)) { + if (!class_exists('Symfony\\Component\\ClassLoader\\ClassLoader', false)) { + require_once '%{phpdir}/Symfony/Component/ClassLoader/ClassLoader.php'; + } + + $fedoraClassLoader = new \Symfony\Component\ClassLoader\ClassLoader(); + $fedoraClassLoader->register(); +} + +$fedoraClassLoader->addPrefix('DI\\', dirname(__DIR__)); +require_once __DIR__.'/functions.php'; + +// Required dependencies +require_once '%{phpdir}/Interop/Container/autoload.php'; +require_once '%{phpdir}/Invoker/autoload.php'; +require_once '%{phpdir}/PhpDocReader/autoload.php'; + +// Optional dependencies +@include_once '%{phpdir}/Doctrine/Common/Annotations/autoload.php'; +@include_once '%{phpdir}/Doctrine/Common/Cache/autoload.php'; +@include_once '%{phpdir}/ProxyManager/autoload.php'; + +return $fedoraClassLoader; +AUTOLOAD + + +%build +# Empty build section, nothing to build + + +%install +mkdir -p %{buildroot}%{phpdir} +cp -rp src/* %{buildroot}%{phpdir}/ + + +%check +%if %{with_tests} +: Make PSR-0 tests +mkdir -p tests-psr0/DI/Test +ln -s ../../../tests/IntegrationTest tests-psr0/DI/Test/IntegrationTest +ln -s ../../../tests/UnitTest tests-psr0/DI/Test/UnitTest + +: Create tests bootstrap +cat <<'BOOTSTRAP' | tee bootstrap.php +<?php +$fedoraClassLoader = require '%{buildroot}%{phpdir}/DI/autoload.php'; +$fedoraClassLoader->addPrefix('DI\\Test\\IntegrationTest\\', __DIR__.'/tests-psr0'); +$fedoraClassLoader->addPrefix('DI\\Test\\UnitTest\\', __DIR__.'/tests-psr0'); + +require_once '%{phpdir}/EasyMock/autoload.php'; +BOOTSTRAP + +: Run tests +%{_bindir}/phpunit --verbose --bootstrap bootstrap.php +%else +: Tests skipped +%endif + + +%files +%{!?_licensedir:%global license %%doc} +%license LICENSE +%doc change-log.md +%doc composer.json +%doc README.md +%{phpdir}/DI + + +%changelog +* Sun Jan 03 2016 Shawn Iwinski <shawn@iwin.ski> - 5.2.0-1 +- Initial package |