summaryrefslogtreecommitdiff
path: root/siguix
diff options
context:
space:
mode:
authorSimon Streit <simon@netpanic.org>2023-03-15 21:22:40 +0100
committerSimon Streit <simon@netpanic.org>2023-06-19 21:36:36 +0200
commit94b35f8f57b1f01331326e890d922341c552cd2b (patch)
tree757469580af895c742d613e7d61fb0efd5dfb8d6 /siguix
parent0deb077860b20cf447c3f258d265fb5cf20b744c (diff)
siguix: Add php.
* siguix/packages/php.scm (php): New file. This file is a simple copy from the current version 8.2. Here I have changed the number to 8.1.16 and have only partially checked the test files so far. This would need more testing and see if it can be pushed upstream.
Diffstat (limited to 'siguix')
-rw-r--r--siguix/packages/php.scm441
1 files changed, 441 insertions, 0 deletions
diff --git a/siguix/packages/php.scm b/siguix/packages/php.scm
new file mode 100644
index 0000000..54ced14
--- /dev/null
+++ b/siguix/packages/php.scm
@@ -0,0 +1,441 @@
+;;; GNU Guix --- Functional package management for GNU
+;;; Copyright © 2016-2020 Julien Lepiller <julien@lepiller.eu>
+;;; Copyright © 2016 Marius Bakke <mbakke@fastmail.com>
+;;; Copyright © 2018, 2020, 2021 Tobias Geerinckx-Rice <me@tobias.gr>
+;;; Copyright © 2018 Ricardo Wurmus <rekado@elephly.net>
+;;; Copyright © 2019 Oleg Pykhalov <go.wigust@gmail.com>
+;;; Copyright © 2020 Maxim Cournoyer <maxim.cournoyer@gmail.com>
+;;; Copyright © 2021 Efraim Flashner <efraim@flashner.co.il>
+;;; Copyright © 2023 Simon Streit <simon@netpanic.org.>
+;;;
+;;; This file is part of GNU Guix.
+;;;
+;;; GNU Guix is free software; you can redistribute it and/or modify it
+;;; under the terms of the GNU General Public License as published by
+;;; the Free Software Foundation; either version 3 of the License, or (at
+;;; your option) any later version.
+;;;
+;;; GNU Guix is distributed in the hope that it will be useful, but
+;;; WITHOUT ANY WARRANTY; without even the implied warranty of
+;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;;; GNU General Public License for more details.
+;;;
+;;; You should have received a copy of the GNU General Public License
+;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
+
+(define-module (siguix packages php)
+ #:use-module (gnu packages)
+ #:use-module (gnu packages algebra)
+ #:use-module (gnu packages aspell)
+ #:use-module (gnu packages base)
+ #:use-module (gnu packages bison)
+ #:use-module (gnu packages compression)
+ #:use-module (gnu packages crypto)
+ #:use-module (gnu packages curl)
+ #:use-module (gnu packages cyrus-sasl)
+ #:use-module (gnu packages databases)
+ #:use-module (gnu packages dbm)
+ #:use-module (gnu packages fontutils)
+ #:use-module (gnu packages gd)
+ #:use-module (gnu packages gettext)
+ #:use-module (gnu packages gnupg)
+ #:use-module (gnu packages icu4c)
+ #:use-module (gnu packages image)
+ #:use-module (gnu packages linux)
+ #:use-module (gnu packages multiprecision)
+ #:use-module (gnu packages openldap)
+ #:use-module (gnu packages pcre)
+ #:use-module (gnu packages pkg-config)
+ #:use-module (gnu packages readline)
+ #:use-module (gnu packages sqlite)
+ #:use-module (gnu packages textutils)
+ #:use-module (gnu packages tls)
+ #:use-module (gnu packages web)
+ #:use-module (gnu packages xml)
+ #:use-module (gnu packages xorg)
+ #:use-module (guix packages)
+ #:use-module (guix download)
+ #:use-module (guix build-system gnu)
+ #:use-module (guix utils)
+ #:use-module ((guix licenses) #:prefix license:))
+
+(define-public php-8.1
+ (package
+ (name "php")
+ (version "8.1.16")
+ (home-page "https://www.php.net/")
+ (source (origin
+ (method url-fetch)
+ (uri (string-append home-page "distributions/"
+ "php-" version ".tar.xz"))
+ (sha256
+ (base32
+ "0n0jbj3i9981rcq19jsa1x88ikp43rgg4n1bcwwkrfaqdbci67yn"))
+ (patches
+ (search-patches "php-fix-streams-copy-length.patch"))
+ (modules '((guix build utils)))
+ (snippet
+ '(with-directory-excursion "ext"
+ (for-each delete-file-recursively
+ ;; Some of the bundled libraries have no proper upstream.
+ ;; Ideally we'd extract these out as separate packages:
+ ;;"mbstring/libmbfl"
+ ;;"date/lib"
+ ;;"bcmath/libbcmath"
+ ;;"fileinfo/libmagic" ; a patched version of libmagic
+ '("gd/libgd"
+ "pcre/pcre2lib"))))))
+ (build-system gnu-build-system)
+ (arguments
+ `(#:configure-flags
+ (let-syntax ((with (syntax-rules ()
+ ((_ option input)
+ (string-append option "="
+ (assoc-ref %build-inputs input))))))
+ (list (with "--with-bz2" "bzip2")
+ (with "--with-curl" "curl")
+ (with "--with-gdbm" "gdbm")
+ (with "--with-gettext" "libc") ; libintl.h
+ (with "--with-gmp" "gmp")
+ (with "--with-ldap" "openldap")
+ (with "--with-ldap-sasl" "cyrus-sasl")
+ (with "--with-pdo-pgsql" "postgresql")
+ (with "--with-pdo-sqlite" "sqlite")
+ (with "--with-pgsql" "postgresql")
+ ;; PHP’s Pspell extension, while retaining its current name,
+ ;; now uses the Aspell library.
+ (with "--with-pspell" "aspell")
+ (with "--with-readline" "readline")
+ (with "--with-sodium" "libsodium")
+ (with "--with-sqlite3" "sqlite")
+ (with "--with-tidy" "tidy")
+ (with "--with-xsl" "libxslt")
+ (with "--with-zlib-dir" "zlib")
+ ;; We could add "--with-snmp", but it requires netsnmp that
+ ;; we don't have a package for. It is used to build the snmp
+ ;; extension of php.
+ "--with-external-pcre"
+ "--with-external-gd"
+ "--with-iconv"
+ "--with-openssl"
+ "--with-mysqli" ; Required for, e.g. wordpress
+ "--with-pdo-mysql"
+ "--with-zip"
+ "--with-zlib"
+ "--enable-bcmath" ; Required for, e.g. Zabbix frontend
+ "--enable-calendar"
+ "--enable-dba=shared"
+ "--enable-exif"
+ "--enable-flatfile"
+ "--enable-fpm"
+ "--enable-ftp"
+ "--enable-gd"
+ "--enable-inifile"
+ "--enable-intl"
+ "--enable-mbstring"
+ "--enable-pcntl"
+ "--enable-sockets"))
+ #:phases
+ (modify-phases %standard-phases
+ (add-after 'unpack 'do-not-record-build-flags
+ (lambda _
+ ;; Prevent configure flags from being stored and causing
+ ;; unnecessary runtime dependencies.
+ (substitute* "scripts/php-config.in"
+ (("@CONFIGURE_OPTIONS@") "")
+ (("@PHP_LDFLAGS@") ""))
+ ;; This file has ISO-8859-1 encoding.
+ (with-fluids ((%default-port-encoding "ISO-8859-1"))
+ (substitute* "main/build-defs.h.in"
+ (("@CONFIGURE_COMMAND@") "(omitted)")))))
+ (add-before 'build 'patch-/bin/sh
+ (lambda _
+ (substitute* '("run-tests.php" "ext/standard/proc_open.c")
+ (("/bin/sh") (which "sh")))))
+ (add-before 'check 'prepare-tests
+ (lambda _
+ ;; Some of these files have ISO-8859-1 encoding, whereas others
+ ;; use ASCII, so we can't use a "catch-all" find-files here.
+ (with-fluids ((%default-port-encoding "ISO-8859-1"))
+ (substitute* '("ext/mbstring/tests/mb_send_mail02.phpt"
+ "ext/mbstring/tests/mb_send_mail04.phpt"
+ "ext/mbstring/tests/mb_send_mail05.phpt"
+ "ext/mbstring/tests/mb_send_mail06.phpt")
+ (("/bin/cat") (which "cat"))))
+ (substitute* '("ext/mbstring/tests/mb_send_mail01.phpt"
+ "ext/mbstring/tests/mb_send_mail03.phpt"
+ "ext/mbstring/tests/bug52681.phpt"
+ "ext/standard/tests/general_functions/bug34794.phpt"
+ "ext/standard/tests/general_functions/bug44667.phpt"
+ "ext/standard/tests/general_functions/proc_open.phpt")
+ (("/bin/cat") (which "cat")))
+
+ ;; The encoding of this file is not recognized, so we simply drop it.
+ (delete-file "ext/mbstring/tests/mb_send_mail07.phpt")
+
+ (substitute* "ext/standard/tests/streams/bug60602.phpt"
+ (("'ls'") (string-append "'" (which "ls") "'")))
+
+ ,@(if (target-arm32?)
+ ;; Drop tests known to fail on armhf.
+ '((for-each delete-file
+ (list
+ "ext/calendar/tests/unixtojd_error1.phpt"
+ "ext/opcache/tests/preload_006.phpt"
+ "ext/opcache/tests/preload_011.phpt"
+ ;; arm can be a lot slower, so a time-related test fails
+ "ext/fileinfo/tests/cve-2014-3538-nojit.phpt"
+ "ext/pcntl/tests/pcntl_unshare_01.phpt"
+ "ext/pcre/tests/bug76514.phpt"
+ "ext/pcre/tests/preg_match_error3.phpt"
+ "ext/pcre/tests/cache_limit.phpt"
+ "ext/sockets/tests/socket_getopt.phpt"
+ "ext/sockets/tests/socket_sendrecvmsg_error.phpt"
+ "ext/standard/tests/general_functions/var_export-locale.phpt"
+ "ext/standard/tests/general_functions/var_export_basic1.phpt"
+ "ext/intl/tests/timezone_getErrorCodeMessage_basic.phpt"
+ "ext/intl/tests/timezone_getOffset_error.phpt"
+ "sapi/cli/tests/cli_process_title_unix.phpt"
+ "sapi/cli/tests/upload_2G.phpt"
+ "Zend/tests/concat_003.phpt")))
+ '())
+
+ ,@(if (target-x86-32?)
+ ;; Drop tests known to fail on i686.
+ '((for-each delete-file
+ (list
+ "ext/dba/tests/dba_gdbm.phpt")))
+ '())
+
+ ,@(if (target-ppc64le?)
+ ;; Drop tests known to fail on powerpc64le.
+ '((for-each delete-file
+ (list
+ ;; phpdbg watchpoints don't work.
+ ;; Bug tracked upstream at:
+ ;; https://bugs.php.net/bug.php?id=81408
+ "sapi/phpdbg/tests/watch_001.phpt"
+ "sapi/phpdbg/tests/watch_003.phpt"
+ "sapi/phpdbg/tests/watch_004.phpt"
+ "sapi/phpdbg/tests/watch_005.phpt"
+ "sapi/phpdbg/tests/watch_006.phpt")))
+ '())
+
+ ,@(if (target-riscv64?)
+ ;; Drop tests known to fail on riscv64.
+ '((for-each delete-file
+ (list "sapi/cli/tests/upload_2G.phpt")))
+ '())
+
+ ;; Drop tests that are known to fail.
+ (for-each delete-file
+ '("ext/posix/tests/posix_getgrgid.phpt" ; Requires /etc/group.
+ "ext/posix/tests/posix_getgrnam_basic.phpt" ; Requires /etc/group.
+ "ext/sockets/tests/bug63000.phpt" ; Fails to detect OS.
+ "ext/sockets/tests/socket_shutdown.phpt" ; Requires DNS.
+ "ext/sockets/tests/socket_send.phpt" ; Likewise.
+ "ext/sockets/tests/mcast_ipv4_recv.phpt" ; Requires multicast.
+ ;; These needs /etc/services.
+ "ext/standard/tests/general_functions/getservbyname_basic.phpt"
+ "ext/standard/tests/general_functions/getservbyport_basic.phpt"
+ "ext/standard/tests/general_functions/getservbyport_variation1.phpt"
+ ;; And /etc/protocols.
+ "ext/standard/tests/network/getprotobyname_basic.phpt"
+ "ext/standard/tests/network/getprotobynumber_basic.phpt"
+ ;; And exotic locales.
+ "ext/standard/tests/strings/setlocale_basic1.phpt"
+ "ext/standard/tests/strings/setlocale_basic2.phpt"
+ "ext/standard/tests/strings/setlocale_basic3.phpt"
+ "ext/standard/tests/strings/setlocale_variation1.phpt"
+ ;; This failing test is skipped on PHP's Travis CI as it is
+ ;; supposedly inaccurate.
+ "ext/standard/tests/file/disk_free_space_basic.phpt"
+ ;; The following test erroneously expect the link
+ ;; count of a sub-directory to increase compared to
+ ;; its parent.
+ "ext/standard/tests/file/lstat_stat_variation8.phpt"
+ ;; This tests whether microseconds ‘differ enough’ and
+ ;; fails inconsistently on ‘fast’ machines.
+ "ext/date/tests/bug73837.phpt"
+
+ ;; XXX: These gd tests fails. Likely because our version
+ ;; is different from the (patched) bundled one.
+ ;; Here, gd quits immediately after "fatal libpng error"; while the
+ ;; test expects it to additionally return a "setjmp" error and warning.
+ "ext/gd/tests/bug39780_extern.phpt"
+ "ext/gd/tests/libgd00086_extern.phpt"
+ ;; Extra newline in gd-png output.
+ "ext/gd/tests/bug45799.phpt"
+ ;; Test expects generic "gd warning" but gets the actual function name.
+ "ext/gd/tests/createfromwbmp2_extern.phpt"
+ ;; This bug should have been fixed in gd 2.2.2.
+ ;; Is it a regression?
+ "ext/gd/tests/bug65148.phpt"
+ ;; This bug should have been fixed in the gd 2.2
+ ;; series. Perhaps a regression introduced by gd
+ ;; 2.3.0?
+ "ext/gd/tests/bug66590.phpt"
+ ;; This bug should have been fixed in the php-5.5
+ ;; series. Perhaps a regression introduced by gd
+ ;; 2.3.0?
+ "ext/gd/tests/bug70102.phpt"
+ ;; This bug should have been fixed in the php-5.6
+ ;; series. Perhaps a regression introduced by gd
+ ;; 2.3.0?
+ "ext/gd/tests/bug73869.phpt"
+ ;; Some WebP related tests fail.
+ "ext/gd/tests/webp_basic.phpt"
+ "ext/gd/tests/imagecreatefromstring_webp.phpt"
+ ;; TODO: Enable these when libgd is built with xpm support.
+ "ext/gd/tests/xpm2gd.phpt"
+ "ext/gd/tests/xpm2jpg.phpt"
+ "ext/gd/tests/xpm2png.phpt"
+ ;; Whitespace difference, probably caused by a very
+ ;; long store path
+ "ext/gd/tests/bug77479.phpt"
+ ;; Expected invalid XBM but got EOF before image was
+ ;; complete. It's a warning in both cases and test
+ ;; result is the same.
+ "ext/gd/tests/bug77973.phpt"
+ ;; Test expects uninitialized value to be false, but
+ ;; instead gets "resource(5) of type (gd)".
+ "ext/gd/tests/bug79067.phpt"
+ ;; The following test fails with "The image size
+ ;; differs: expected 114x115, got 117x117".
+ "ext/gd/tests/bug79068.phpt"
+ ;; AVIF support disabled
+ "ext/gd/tests/avif_decode_encode.phpt"
+ ;; Typo in expected outputs
+ "ext/gd/tests/bug72339.phpt"
+ "ext/gd/tests/bug77269.phpt" ;added
+ "ext/gd/tests/bug77272.phpt"
+ "ext/gd/tests/bug66356.phpt"
+ ;; AVIF support disabled
+ "ext/gd/tests/imagecreatefromstring_avif.phpt"
+
+ ;; XXX: These iconv tests have the expected outcome,
+ ;; but with different error messages.
+ ;; Expects "illegal character", instead gets "unknown error (84)".
+ "ext/iconv/tests/bug52211.phpt"
+ "ext/iconv/tests/bug60494.phpt"
+ ;; Expects "wrong charset", gets unknown error (22).
+ "ext/iconv/tests/iconv_strlen_error2.phpt"
+ "ext/iconv/tests/iconv_substr_error2.phpt"
+ ;; Expects conversion error, gets "error condition Termsig=11".
+ "ext/iconv/tests/iconv_strpos_error2.phpt"
+ "ext/iconv/tests/iconv_strrpos_error2.phpt"
+ ;; Expects "invalid multibyte sequence" but got
+ ;; "unknown error".
+ "ext/iconv/tests/bug76249.phpt"
+
+ ;; XXX: These test failures appear legitimate, needs investigation.
+ ;; open_basedir() restriction failure.
+ "ext/curl/tests/bug61948-unix.phpt"
+ ;; Same error reason but error code slightly different
+ "ext/curl/tests/curl_setopt_ssl.phpt"
+
+ ;; Fail because there is no "root" in the build container's
+ ;; /etc/passwd
+ ;; "sapi/fpm/tests/bug68591-conf-test-group.phpt" ;removed
+ ;; "sapi/fpm/tests/bug68591-conf-test-listen-group.phpt" ;removed
+ ;; "sapi/fpm/tests/bug68591-conf-test-listen-owner.phpt" ;removed
+
+ ;; Wrong error name
+ ;; "ext/dba/tests/dba_gdbm_creation_matrix.phpt" ;removed
+ ;; Expects a false boolean, gets empty array from glob().
+ "ext/standard/tests/file/bug41655_1.phpt"
+ "ext/standard/tests/file/glob_variation5.phpt"
+ ;; The test expects an Array, but instead get the contents(?).
+ "ext/gd/tests/bug43073.phpt"
+ ;; imagettftext() returns wrong coordinates.
+ "ext/gd/tests/bug48732-mb.phpt"
+ "ext/gd/tests/bug48732.phpt"
+ ;; Similarly for imageftbbox().
+ "ext/gd/tests/bug48801-mb.phpt"
+ "ext/gd/tests/bug48801.phpt"
+ ;; Different expected output from imagecolorallocate().
+ "ext/gd/tests/bug53504.phpt"
+ ;; Wrong image size after scaling an image.
+ "ext/gd/tests/bug73272.phpt"
+ ;; Expects iconv to detect illegal characters, instead gets
+ ;; "unknown error (84)" and heap corruption(!).
+ "ext/iconv/tests/bug48147.phpt"
+ ;; Expects illegal character ".", gets "=?utf-8?Q?."
+ "ext/iconv/tests/bug51250.phpt"
+ ;; iconv throws "buffer length exceeded" on some string checks.
+ "ext/iconv/tests/iconv_mime_encode.phpt"
+ ;; file_get_contents(): iconv stream filter
+ ;; ("ISO-8859-1"=>"UTF-8") unknown error.
+ "ext/standard/tests/file/bug43008.phpt"
+ ;; Table data not created in sqlite(?).
+ "ext/pdo_sqlite/tests/bug_42589.phpt"
+ ;; Expects an Array with 3 preg_matches; gets 0.
+ "ext/pcre/tests/bug79846.phpt"
+ ;; Expects an empty Array; gets one with " " in it.
+ "ext/pcre/tests/bug80118.phpt"
+ ;; Renicing a process fails in the build environment.
+ "ext/standard/tests/general_functions/proc_nice_basic.phpt"
+ ;; Can fail on fast machines?
+ "Zend/tests/bug74093.phpt"))
+
+ ;; Accomodate two extra openssl errors flanking the expected one:
+ ;; random number generator:RAND_{load,write}_file:Cannot open file
+ ;; This is due to an invalid $HOME, but changing it in the test
+ ;; still prints the first one & changing it globally is overkill.
+ (substitute* "ext/openssl/tests/bug80747.phpt"
+ ((".*error:%s:key size too small.*" match)
+ (string-append "%s\n" match "%s\n")))
+
+ ;; Skip tests requiring network access.
+ (setenv "SKIP_ONLINE_TESTS" "1")
+ ;; Without this variable, 'make test' passes regardless of failures.
+ (setenv "REPORT_EXIT_STATUS" "1")
+ ;; Skip tests requiring I/O facilities that are unavailable in the
+ ;; build environment
+ (setenv "SKIP_IO_CAPTURE_TESTS" "1"))))
+ #:test-target "test"))
+ (inputs
+ `(("aspell" ,aspell)
+ ("bzip2" ,bzip2)
+ ("curl" ,curl)
+ ("cyrus-sasl" ,cyrus-sasl)
+ ("gd" ,gd)
+ ("gdbm" ,gdbm)
+ ("gmp" ,gmp)
+ ("gnutls" ,gnutls)
+ ("icu4c" ,icu4c)
+ ("libgcrypt" ,libgcrypt)
+ ("libpng" ,libpng)
+ ("libsodium" ,libsodium)
+ ("libxml2" ,libxml2)
+ ("libxslt" ,libxslt)
+ ("libx11" ,libx11)
+ ("libzip" ,libzip)
+ ("oniguruma" ,oniguruma)
+ ("openldap" ,openldap)
+ ("openssl" ,openssl-1.1)
+ ("pcre" ,pcre2)
+ ("postgresql" ,postgresql)
+ ("readline" ,readline)
+ ("sqlite" ,sqlite)
+ ("tidy" ,tidy-html)
+ ("zlib" ,zlib)))
+ (native-inputs
+ `(("pkg-config" ,pkg-config)
+ ("bison" ,bison)
+ ("gettext" ,gettext-minimal)
+ ("procps" ,procps))) ; for tests
+ (synopsis "PHP programming language")
+ (description
+ "PHP (PHP Hypertext Processor) is a server-side (CGI) scripting
+language designed primarily for web development but is also used as
+a general-purpose programming language. PHP code may be embedded into
+HTML code, or it can be used in combination with various web template
+systems, web content management systems and web frameworks." )
+ (license (list
+ (license:non-copyleft "file://LICENSE") ; The PHP license.
+ (license:non-copyleft "file://Zend/LICENSE") ; The Zend license.
+ license:lgpl2.1 ; ext/mbstring/libmbfl
+ license:lgpl2.1+ ; ext/bcmath/libbcmath
+ license:bsd-2 ; ext/fileinfo/libmagic
+ license:expat)))) ; ext/date/lib