Re: [Fedora-php-devel-list] For FPC : Change proposal to PHP Guidelines

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 14/07/09 17:38, Remi Collet wrote:

We have some pending minor issues/questions with PHP packaging we should
make clearer :

Thanks for doing this work Remi.

1/ use of /usr/share/php

=>  1 folder per library

Agreed, but I would change the word "extension" to "software" to avoid confusion with binary extensions, and re-word this a bit make the text clearer and more specific, for example:

"Non-PEAR PHP software which provides shared libraries should put its PHP source files for such shared libraries in a subfolder of /usr/share/php, named according to the name of the software. For example, a library called "Whizz_Bang" (with a RPM called php-something-Whizz-Bang) would put the PHP source files for its shared libraries in /usr/share/php/Whizz_Bang ."

2/ conditional in ABI check and in post/postun scriplet

This conditions are present to maintain compatibility with older PHP
version (5.1.6 on EL-5) and could be removed if package requires a
recent version (>  5.2)

I would suggest an easier-to-read introduction:

"To be certain that a binary extension will run correctly with a particular version of PHP, it is necessary to check that a particular package has both API and ABIs matching the installed version of PHP. The mechanism for doing this has evolved over time and is as follows:"

For the second part, I would split the specfile template into three parts as follows:

For Fedora (all current versions):
BuildRequires: php-devel
Requires:      php(zend-abi) = %{php_zend_api}
Requires:      php(api) = %{php_core_api}

For Fedora EPEL 5:
BuildRequires: php-devel
Requires:      php-api = %{php_apiver}

There is no way of checking the ABI with packages for Fedora EPEL 5.

For a spec file which is compatible with both Fedora and EPEL 5:
BuildRequires: php-devel
%if %{?php_zend_api}0
Requires:     php(zend-abi) = %{php_zend_api}
Requires:     php(api) = %{php_core_api}
%else
Requires:     php-api = %{php_apiver}
%endif

No API/ABI dependencies are available for Fedora EPEL 4 packages.

3/ ABI check
[...]
Module compiled with module API=20060613
PHP    compiled with module API=20090626

It seems clear it should be mandatory for all C extension.

Definitely.

Tim

--
Fedora-packaging mailing list
Fedora-packaging@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/fedora-packaging

[Index of Archives]     [Fedora Users]     [Fedora Desktop]     [Fedora SELinux]     [Big List of Linux Books]     [Yosemite Forum]     [KDE Users]

  Powered by Linux