summaryrefslogtreecommitdiffstats
path: root/php84.spec
diff options
context:
space:
mode:
Diffstat (limited to 'php84.spec')
-rw-r--r--php84.spec317
1 files changed, 317 insertions, 0 deletions
diff --git a/php84.spec b/php84.spec
new file mode 100644
index 0000000..6679f39
--- /dev/null
+++ b/php84.spec
@@ -0,0 +1,317 @@
+# remirepo spec file for php83 SCL metapackage
+#
+# Copyright (c) 2018-2023 Remi Collet
+# License: CC-BY-SA-4.0
+# http://creativecommons.org/licenses/by-sa/4.0/
+#
+# Please, preserve the changelog entries
+#
+%global scl_name_base php
+%global scl_name_version 83
+%global scl_name_verdot 8.3
+%global scl %{scl_name_base}%{scl_name_version}
+%global macrosdir %(d=%{_rpmconfigdir}/macros.d; [ -d $d ] || d=%{_root_sysconfdir}/rpm; echo $d)
+%global install_scl 1
+
+%if 0%{?fedora} >= 20 || 0%{?rhel} >= 8
+%global rh_layout 1
+%else
+%global nfsmountable 1
+%endif
+
+%scl_package %scl
+
+# do not produce empty debuginfo package
+%global debug_package %{nil}
+
+Summary: Package that installs PHP %{scl_name_verdot}
+Name: %{scl_name}
+Version: %{scl_name_verdot}
+Release: 1%{?dist}
+License: GPL-2.0-or-later
+
+Source0: macros-build
+Source1: README
+Source2: LICENSE
+
+BuildRequires: scl-utils-build
+BuildRequires: help2man
+# Temporary work-around
+BuildRequires: iso-codes
+BuildRequires: environment-modules
+
+Requires: %{?scl_prefix}php-common%{?_isa}
+Requires: %{?scl_prefix}php-cli%{?_isa}
+Requires: %{?scl_name}-runtime%{?_isa} = %{version}-%{release}
+%if 0%{?fedora} >= 27 || 0%{?rhel} >= 8
+# this a meta-package, so commonly used SAPI / extensions:
+Recommends: %{?scl_prefix}php-fpm%{?_isa}
+Recommends: %{?scl_prefix}php-mbstring%{?_isa}
+Recommends: %{?scl_prefix}php-opcache%{?_isa}
+Recommends: %{?scl_prefix}php-pdo%{?_isa}
+Recommends: %{?scl_prefix}php-sodium%{?_isa}
+Recommends: %{?scl_prefix}php-xml%{?_isa}
+%endif
+
+%description
+This is the main package for %scl Software Collection,
+that install PHP %{scl_name_verdot} language.
+
+
+%package runtime
+Summary: Package that handles %scl Software Collection.
+Requires: scl-utils
+Requires: environment-modules
+Requires(post): %{_root_sbindir}/semanage
+Requires(post): %{_root_sbindir}/selinuxenabled
+Provides: %{?scl_name}-runtime(%{scl_vendor})
+Provides: %{?scl_name}-runtime(%{scl_vendor})%{?_isa}
+
+%description runtime
+Package shipping essential scripts to work with %scl Software Collection.
+
+
+%package build
+Summary: Package shipping basic build configuration
+Requires: scl-utils-build
+Requires: %{?scl_name}-runtime%{?_isa} = %{version}-%{release}
+
+%description build
+Package shipping essential configuration macros
+to build %scl Software Collection.
+
+
+%package scldevel
+Summary: Package shipping development files for %scl
+Requires: %{?scl_name}-runtime%{?_isa} = %{version}-%{release}
+
+%description scldevel
+Package shipping development files, especially usefull for development of
+packages depending on %scl Software Collection.
+
+
+%package syspaths
+Summary: System-wide wrappers for the %{name} package
+Requires: %{?scl_name}-runtime%{?_isa} = %{version}-%{release}
+Requires: %{?scl_name}-php-cli%{?_isa}
+Requires: %{?scl_name}-php-common%{?_isa}
+Conflicts: php-common
+Conflicts: php-cli
+Conflicts: php54-syspaths
+Conflicts: php55-syspaths
+Conflicts: php56-syspaths
+Conflicts: php70-syspaths
+Conflicts: php71-syspaths
+Conflicts: php72-syspaths
+Conflicts: php73-syspaths
+Conflicts: php74-syspaths
+Conflicts: php80-syspaths
+Conflicts: php81-syspaths
+
+%description syspaths
+System-wide wrappers for the %{name}-php-cli package.
+
+Using the %{name}-syspaths package does not require running the
+'scl enable' or 'module command. This package practically replaces the system
+default php-cli package. It provides the php, phar and php-cgi commands.
+
+Note that the php-cli and %{name}-syspaths packages conflict and cannot
+be installed on one system.
+
+
+%prep
+%setup -c -T
+
+cat <<EOF | tee enable
+export PATH=%{_bindir}:%{_sbindir}\${PATH:+:\${PATH}}
+export LD_LIBRARY_PATH=%{_libdir}\${LD_LIBRARY_PATH:+:\${LD_LIBRARY_PATH}}
+export MANPATH=%{_mandir}:\${MANPATH}
+EOF
+
+# Broken: /usr/share/Modules/bin/createmodule.sh enable | tee envmod
+# See https://bugzilla.redhat.com/show_bug.cgi?id=1197321
+cat << EOF | tee envmod
+#%%Module1.0
+prepend-path X_SCLS %{scl}
+prepend-path PATH %{_bindir}:%{_sbindir}
+prepend-path LD_LIBRARY_PATH %{_libdir}
+prepend-path MANPATH %{_mandir}
+prepend-path PKG_CONFIG_PATH %{_libdir}/pkgconfig
+EOF
+
+# generate rpm macros file for depended collections
+cat << EOF | tee scldev
+%%scl_%{scl_name_base} %{scl}
+%%scl_prefix_%{scl_name_base} %{scl_prefix}
+EOF
+
+# This section generates README file from a template and creates man page
+# from that file, expanding RPM macros in the template file.
+cat >README <<'EOF'
+%{expand:%(cat %{SOURCE1})}
+EOF
+
+# copy the license file so %%files section sees it
+cp %{SOURCE2} .
+
+: prefix in %{_prefix}
+: config in %{_sysconfdir}
+: data in %{_localstatedir}
+
+
+%build
+# generate a helper script that will be used by help2man
+cat >h2m_helper <<'EOF'
+#!/bin/bash
+[ "$1" == "--version" ] && echo "%{scl_name} Software Collection (PHP %{version})" || cat README
+EOF
+chmod a+x h2m_helper
+
+# generate the man page
+help2man -N --section 7 ./h2m_helper -o %{scl_name}.7
+
+
+%install
+install -D -m 644 enable %{buildroot}%{_scl_scripts}/enable
+install -D -m 644 envmod %{buildroot}%{_root_datadir}/Modules/modulefiles/%{scl_name}
+install -D -m 644 scldev %{buildroot}%{macrosdir}/macros.%{scl_name_base}-scldevel
+install -D -m 644 %{scl_name}.7 %{buildroot}%{_root_mandir}/man7/%{scl_name}.7
+
+install -d -m 755 %{buildroot}%{_datadir}/licenses
+install -d -m 755 %{buildroot}%{_datadir}/doc/pecl
+install -d -m 755 %{buildroot}%{_datadir}/tests/pecl
+install -d -m 755 %{buildroot}%{_localstatedir}/lib/pear/pkgxml
+
+%scl_install
+
+cat %{buildroot}%{_root_sysconfdir}/rpm/macros.%{scl}-config
+
+# Add the scl_package_override macro
+sed -e 's/@SCL@/%{scl}/g;s:@PREFIX@:/opt/%{scl_vendor}:;s/@VENDOR@/%{scl_vendor}/' %{SOURCE0} \
+ | tee -a %{buildroot}%{_root_sysconfdir}/rpm/macros.%{scl}-config
+
+# Move in correct location, if needed
+if [ "%{_root_sysconfdir}/rpm" != "%{macrosdir}" ]; then
+ mv %{buildroot}%{_root_sysconfdir}/rpm/macros.%{scl}-config \
+ %{buildroot}%{macrosdir}/macros.%{scl}-config
+fi
+
+# syspaths
+mkdir -p %{buildroot}%{_root_sysconfdir}
+ln -s %{_sysconfdir}/php.ini %{buildroot}%{_root_sysconfdir}/php.ini
+ln -s %{_sysconfdir}/php.d %{buildroot}%{_root_sysconfdir}/php.d
+mkdir -p %{buildroot}%{_root_bindir}
+ln -s %{_bindir}/php %{buildroot}%{_root_bindir}/php
+ln -s %{_bindir}/phar %{buildroot}%{_root_bindir}/phar
+ln -s %{_bindir}/php-cgi %{buildroot}%{_root_bindir}/php-cgi
+mkdir -p %{buildroot}%{_root_mandir}/man1
+ln -s %{_mandir}/man1/php.1.gz %{buildroot}%{_root_mandir}/man1/php.1.gz
+ln -s %{_mandir}/man1/phar.1.gz %{buildroot}%{_root_mandir}/man1/phar.1.gz
+ln -s %{_mandir}/man1/php-cgi.1.gz %{buildroot}%{_root_mandir}/man1/php-cgi.1.gz
+
+
+%post runtime
+# Simple copy of context from system root to SCL root.
+semanage fcontext -a -e / %{?_scl_root} &>/dev/null || :
+semanage fcontext -a -e %{_root_sysconfdir} %{_sysconfdir} &>/dev/null || :
+semanage fcontext -a -e %{_root_localstatedir} %{_localstatedir} &>/dev/null || :
+selinuxenabled && load_policy || :
+restorecon -R %{?_scl_root} &>/dev/null || :
+restorecon -R %{_sysconfdir} &>/dev/null || :
+restorecon -R %{_localstatedir} &>/dev/null || :
+
+
+%{!?_licensedir:%global license %%doc}
+
+%files
+
+
+%if 0%{?fedora} < 19 && 0%{?rhel} < 7
+%files runtime
+%else
+%files runtime -f filesystem
+%endif
+%license LICENSE
+%doc README
+%scl_files
+%{_root_mandir}/man7/%{scl_name}.*
+%{?_licensedir:%{_datadir}/licenses}
+%{_datadir}/tests
+%{_root_datadir}/Modules/modulefiles/%{scl_name}
+
+
+%files build
+%{macrosdir}/macros.%{scl}-config
+
+
+%files scldevel
+%{macrosdir}/macros.%{scl_name_base}-scldevel
+
+
+%files syspaths
+%{_root_sysconfdir}/php.ini
+%{_root_sysconfdir}/php.d
+%{_root_bindir}/php
+%{_root_bindir}/phar
+%{_root_bindir}/php-cgi
+%{_root_mandir}/man1/php.1.gz
+%{_root_mandir}/man1/phar.1.gz
+%{_root_mandir}/man1/php-cgi.1.gz
+
+
+%changelog
+* Mon Jun 5 2023 Remi Collet <remi@remirepo.net> 8.3-1
+- initial package for 8.3
+
+* Wed Apr 26 2023 Remi Collet <remi@remirepo.net> 8.2-5
+- redefine %%__phpize and %%__phpconfig
+
+* Thu Mar 9 2023 Remi Collet <remi@remirepo.net> 8.2-4
+- improve the man page
+
+* Thu Mar 9 2023 Remi Collet <remi@remirepo.net> 8.2-3
+- define %%scl_vendor and %%_scl_prefix in macros.php82-config
+- move man page out of scl tree
+
+* Wed Jun 22 2022 Remi Collet <remi@remirepo.net> 8.2-2
+- php82-syspaths conflicts with php81-syspaths
+
+* Wed May 11 2022 Remi Collet <remi@remirepo.net> 8.2-1
+- initial package for 8.2
+
+* Fri Jul 9 2021 Remi Collet <remi@remirepo.net> 8.1-2
+- add weak dependencies on commonly used SAPI and extensions:
+ fpm, mbstring, opcache, pdo, sodium and xml
+
+* Fri Jun 4 2021 Remi Collet <remi@remirepo.net> 8.1-1
+- initial package for 8.1
+
+* Thu Apr 9 2020 Remi Collet <remi@remirepo.net> 1.0-3
+- cleanup for EL
+
+* Thu Apr 9 2020 Remi Collet <remi@remirepo.net> 1.0-2
+- add conflict between php73-syspaths and php80-syspaths
+- add conflict between php74-syspaths and php80-syspaths
+
+* Thu Apr 9 2020 Remi Collet <remi@remirepo.net> 1.0-1
+- initial package for 8.0
+
+* Thu Aug 22 2019 Remi Collet <remi@remirepo.net> 1.0-2
+- fix error: Macro %%undefine is a built-in
+ see https://bugzilla.redhat.com/1744583
+
+* Mon May 20 2019 Remi Collet <remi@remirepo.net> 1.0-1
+- initial package for 7.4
+
+* Wed Feb 20 2019 Remi Collet <remi@remirepo.net> 2.0-1
+- add syspaths sub package providing system-wide wrappers
+
+* Thu Jan 17 2019 Remi Collet <remi@remirepo.net> 1.0-2
+- cleanup for EL-8
+
+* Thu Aug 23 2018 Remi Collet <remi@remirepo.net> 1.0-1
+- scl-utils 2.0.2 drop modules support
+
+* Thu Jun 7 2018 Remi Collet <remi@remirepo.net> 1.0-0.1
+- initial packaging
+