diff options
author | Remi Collet <fedora@famillecollet.com> | 2016-03-11 13:35:09 +0100 |
---|---|---|
committer | Remi Collet <fedora@famillecollet.com> | 2016-03-11 13:35:09 +0100 |
commit | a8e68a081758cf296f3da515bdf9ee405167cbd1 (patch) | |
tree | 3a40cc3bdc313267c9140cd2a4f6af5361792e1d |
php-sabre-uri: 1.1.0 (new package, for owncloud)
-rw-r--r-- | Makefile | 4 | ||||
-rw-r--r-- | php-sabre-uri-autoload.php | 21 | ||||
-rw-r--r-- | php-sabre-uri.spec | 122 |
3 files changed, 147 insertions, 0 deletions
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-sabre-uri-autoload.php b/php-sabre-uri-autoload.php new file mode 100644 index 0000000..084184a --- /dev/null +++ b/php-sabre-uri-autoload.php @@ -0,0 +1,21 @@ +<?php +/** + * Autoloader for sabre/uri and its dependencies + */ + +$vendorDir = '/usr/share/php'; + +// Use Symfony autoloader +if (!isset($fedoraClassLoader) || !($fedoraClassLoader instanceof \Symfony\Component\ClassLoader\ClassLoader)) { + if (!class_exists('Symfony\\Component\\ClassLoader\\ClassLoader', false)) { + require_once $vendorDir . '/Symfony/Component/ClassLoader/ClassLoader.php'; + } + + $fedoraClassLoader = new \Symfony\Component\ClassLoader\ClassLoader(); + $fedoraClassLoader->register(); +} + +$fedoraClassLoader->addPrefix('Sabre\\Uri\\', dirname(dirname(__DIR__))); + +// Function +require_once __DIR__ . '/functions.php'; diff --git a/php-sabre-uri.spec b/php-sabre-uri.spec new file mode 100644 index 0000000..46d79b7 --- /dev/null +++ b/php-sabre-uri.spec @@ -0,0 +1,122 @@ +# remirepo/fedora spec file for php-sabre-uri +# +# Copyright (c) 2016 Remi Collet +# License: CC-BY-SA +# http://creativecommons.org/licenses/by-sa/4.0/ +# +# Please, preserve the changelog entries +# +%global gh_commit 9012116434d84ef6e5e37a89dfdbfbe2204a8704 +%global gh_short %(c=%{gh_commit}; echo ${c:0:7}) +%global gh_owner fruux +%global gh_project sabre-uri +%global with_tests 0%{!?_without_tests:1} + +Name: php-%{gh_project} +Summary: Functions for making sense out of URIs +Version: 1.1.0 +Release: 1%{?dist} + +URL: https://github.com/%{gh_owner}/%{gh_project} +License: BSD +Group: Development/Libraries +Source0: https://github.com/%{gh_owner}/%{gh_project}/archive/%{gh_commit}/%{gh_project}-%{version}-%{gh_short}.tar.gz +Source1: %{name}-autoload.php + +BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root-%(%{__id_u} -n) +BuildArch: noarch +%if %{with_tests} +BuildRequires: php(language) > 5.4.7 +# From composer.json, "require-dev": { +# "sabre/cs": "~0.0.1", +# "phpunit/phpunit" : "*" +BuildRequires: php-pcre +BuildRequires: php-composer(phpunit/phpunit) +# Autoloader +BuildRequires: php-composer(symfony/class-loader) +%endif + +# From composer.json, "require" : { +# "php": ">=5.4.7" +Requires: php(language) > 5.4.7 +# From phpcompatinfo report for version 1.1.0 +Requires: php-pcre +# Autoloader +Requires: php-composer(symfony/class-loader) + +Provides: php-composer(sabre/uri) = %{version} + + +%description +sabre/uri is a lightweight library that provides several functions for +working with URIs, staying true to the rules of RFC3986. + +Partially inspired by Node.js URL library, and created to solve real +problems in PHP applications. 100% unitested and many tests are based +on examples from RFC3986. + +The library provides the following functions: +* resolve to resolve relative urls. +* normalize to aid in comparing urls. +* parse, which works like PHP's parse_url. +* build to do the exact opposite of parse. +* split to easily get the 'dirname' and 'basename' of a URL without + all the problems those two functions have. + +Autoloader: %{_datadir}/php/Sabre/Uri/autoload.php + + +%prep +%setup -q -n %{gh_project}-%{gh_commit} + +cp %{SOURCE1} lib/autoload.php + + +%build +# nothing to build + + +%install +rm -rf %{buildroot} + +# Install as a PSR-0 library +mkdir -p %{buildroot}%{_datadir}/php/Sabre +cp -pr lib %{buildroot}%{_datadir}/php/Sabre/Uri + + +%check +%if %{with_tests} +: Run upstream test suite against installed library +cd tests +%{_bindir}/phpunit \ + --bootstrap=%{buildroot}%{_datadir}/php/Sabre/Uri/autoload.php \ + --verbose + +if which php70; then + php70 %{_bindir}/phpunit \ + --bootstrap=%{buildroot}%{_datadir}/php/Sabre/Uri/autoload.php \ + --verbose +fi +%else +: Skip upstream test suite +%endif + + +%clean +rm -rf %{buildroot} + + +%files +%defattr(-,root,root,-) +%{!?_licensedir:%global license %%doc} +%license LICENSE +%doc *md +%doc composer.json +%dir %{_datadir}/php/Sabre + %{_datadir}/php/Sabre/Uri + + +%changelog +* Fri Mar 11 2016 Remi Collet <remi@fedoraproject.org> - 1.1.0 +- Initial packaging + |