diff options
Diffstat (limited to 'php-pecl-md4c.spec')
-rw-r--r-- | php-pecl-md4c.spec | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/php-pecl-md4c.spec b/php-pecl-md4c.spec new file mode 100644 index 0000000..d19ed5e --- /dev/null +++ b/php-pecl-md4c.spec @@ -0,0 +1,123 @@ +# remirepo spec file for php-pecl-md4c +# +# Copyright (c) 2024 Remi Collet +# License: CC-BY-SA-4.0 +# http://creativecommons.org/licenses/by-sa/4.0/ +# +# Please, preserve the changelog entries +# + +%{?scl:%scl_package php-pecl-md4c} + +%global pecl_name md4c +%global ini_name 40-%{pecl_name}.ini +%global upstream_version 1.0.0 +%global upstream_prever dev +%global upstream_rpmrel DEV +%global sources %{pecl_name}-%{upstream_version}%{?upstream_prever} + +Summary: Convert Markdown to HTML +Name: %{?scl_prefix}php-pecl-%{pecl_name} +Version: %{upstream_version}%{?upstream_prever:~%{upstream_rpmrel}} +Release: 1%{?dist}%{!?scl:%{!?nophptag:%(%{__php} -r 'echo ".".PHP_MAJOR_VERSION.".".PHP_MINOR_VERSION;')}} +# Copy/paste library http://github.com/mity/md4c is MIT +# Extension is MIT +License: MIT +URL: https://pecl.php.net/package/%{pecl_name} +Source0: https://pecl.php.net/get/%{pecl_name}-%{upstream_version}%{?upstream_prever}.tgz + +BuildRequires: make +BuildRequires: %{?dtsprefix}gcc +# See https://github.com/eklausme/php-md4c/issues/13 +BuildRequires: %{?scl_prefix}php-devel >= 8.0 +BuildRequires: %{?scl_prefix}php-pear + +Requires: %{?scl_prefix}php(zend-abi) = %{php_zend_api} +Requires: %{?scl_prefix}php(api) = %{php_core_api} + +Provides: bundled(md4c) = 0.5.2 +Provides: %{?scl_prefix}php-%{pecl_name} = %{version} +Provides: %{?scl_prefix}php-%{pecl_name}%{?_isa} = %{version} +Provides: %{?scl_prefix}php-pecl(%{pecl_name}) = %{version} +Provides: %{?scl_prefix}php-pecl(%{pecl_name})%{?_isa} = %{version} + + +%description +This extension provides one simple PHP function md4c_toHtml() to convert +Markdown or CommonMark to HTML. + +This function uses the MD4C library written in C and is currently the fastest +conversion routine, +see https://talk.commonmark.org/t/why-is-md4c-so-fast-c/2520/12 + +Package built for PHP %(%{__php} -r 'echo PHP_MAJOR_VERSION.".".PHP_MINOR_VERSION;')%{?scl: as Software Collection (%{scl})}. + + +%prep +%setup -q -c +# Don't install/register tests +sed -e 's/role="test"/role="src"/' \ + -e '/LICENSE/s/role="doc"/role="src"/' \ + -i package.xml + +# Drop in the bit of configuration +cat > %{ini_name} << 'EOF' +; Enable %{pecl_name} extension module +extension = %{pecl_name}.so +EOF + + +%build +%{?dtsenable} + +cd %{sources} +%{__phpize} +[ -f Makefile.global ] && GLOBAL=Makefile.global || GLOBAL=build/Makefile.global +sed -e 's/INSTALL_ROOT/DESTDIR/' -i $GLOBAL + +%configure \ + --enable-md4c \ + --with-php-config=%{__phpconfig} + +%make_build + + +%install +%{?dtsenable} +cd %{sources} + +: Install the extension +%make_install + +: Install the configuration file +install -D -m 644 ../%{ini_name} %{buildroot}%{php_inidir}/%{ini_name} + +: Install the package XML file +install -D -m 644 ../package.xml %{buildroot}%{pecl_xmldir}/%{name}.xml + +: Install Documentation +for i in $(grep 'role="doc"' ../package.xml | sed -e 's/^.*name="//;s/".*$//') +do install -Dpm 644 $i %{buildroot}%{pecl_docdir}/%{pecl_name}/$i +done + + +%check +: Minimal load test for NTS extension +%{__php} --no-php-ini \ + --define extension=%{buildroot}%{php_extdir}/%{pecl_name}.so \ + --modules | grep '^%{pecl_name}$' + + +%files +%license %{sources}/LICENSE* +%{pecl_xmldir}/%{name}.xml + +%config(noreplace) %{php_inidir}/%{ini_name} +%{php_extdir}/%{pecl_name}.so + + +%changelog +* Mon Dec 2 2024 Remi Collet <remi@remirepo.net> - 1.0.0~DEV-1 +- initial package, version 1.0.0dev +- open https://github.com/eklausme/php-md4c/issues/12 version inconsistency +- open https://github.com/eklausme/php-md4c/issues/13 PHP version compatibility |