]> git.pld-linux.org Git - packages/php.git/blobdiff - dep-tests.sh
Update systzdata.patch to v19
[packages/php.git] / dep-tests.sh
index c79530a89c00b12e699b63cbd7db1f40b2b5411d..062c2f81a06795a5f2b703cc4dc22281d9bfe321 100755 (executable)
@@ -3,14 +3,13 @@
 
 with_mysqlnd=mysqlnd
 
-dep_spl="pcre simplexml"
-dep_session="spl $dep_spl"
-dep_filter='pcre'
+dep_session=""
+dep_filter=''
 dep_eaccelerator='session'
-dep_mysqlnd='hash'
+dep_mysqlnd=''
 dep_mysql="$dep_mysqlnd $with_mysqlnd"
-dep_mysqli="$dep_spl spl $dep_mysqlnd $with_mysqlnd"
-dep_pdo="$dep_spl spl"
+dep_mysqli="$dep_mysqlnd $with_mysqlnd"
+dep_pdo=""
 dep_pdo_sqlite="$dep_pdo pdo"
 dep_pdo_pgsql="$dep_pdo pdo"
 dep_pdo_oci="$dep_pdo pdo"
@@ -18,17 +17,17 @@ dep_pdo_odbc="$dep_pdo pdo"
 dep_pdo_firebird="$dep_pdo pdo"
 dep_pdo_dblib="$dep_pdo pdo"
 dep_pdo_mysql="$dep_pdo pdo $dep_mysqlnd $with_mysqlnd"
-dep_simplexml="$dep_spl spl"
-dep_imap="pcre"
-dep_phar="$dep_spl spl hash"
+dep_simplexml=""
+dep_imap=""
+dep_phar=""
 dep_sqlite="$dep_pdo pdo"
-dep_fileinfo="pcre"
+dep_fileinfo=""
 dep_wddx='xml'
 dep_xmlreader='dom'
 dep_xmlrpc='xml'
 dep_xsl='dom'
-dep_snmp="$dep_spl spl snmp"
-dep_opcache='pcre'
+dep_snmp="snmp"
+dep_opcache=''
 
 php=${PHP:-$(php-config --php-binary)}
 ext_dir=${EXTENSION_DIR:-$(php-config --extension-dir)}
@@ -51,7 +50,7 @@ test_deps() {
                # special: opcache is listed as "Zend Opcache"
                [ "$ext" = "opcache" ] && ext="zend opcache"
 
-               grep -rlE '^(zend_)?extension=('$(echo "${deps# }" | tr ' ' '|')').so$' $conf_dir | LC_ALL=C sort | xargs cat > $tmpini
+               grep -rlE '^(zend_)?extension=('$(echo "${deps# }" | tr ' ' '|')')$' $conf_dir | LC_ALL=C sort | xargs cat > $tmpini
                $php -n -d extension_dir=$ext_dir -c $tmpini -r "exit(extension_loaded('${ext}') ? 0 : 1);"
                rc=$?
                if [ $rc = 0 ]; then
@@ -64,4 +63,54 @@ test_deps() {
        done
 }
 
-test_deps "$@"
+_resolve_extension_deps() {
+       local name="$1"
+
+       eval echo \$dep_$ext
+}
+
+# Prints a load order (0-based integer) for the given extension name. Extension
+# with lower load order should be loaded before exts with higher load order.
+# It's based on number of dependencies of the extension (with exception for
+# "imap"), which is flawed, but simple and good enough for now.
+#
+# _extension_load_order adopted from alpine linux:
+# https://github.com/alpinelinux/aports/blob/v3.10.1/community/php7/APKBUILD#L639-L653
+_extension_load_order() {
+       local name="$1"
+       local deps=$(eval "echo \$dep_$name")
+
+       case "$name" in
+               # XXX: This must be loaded after recode, even though it does
+               # not depend on it. So we must use this hack...
+               imap) echo 1;;
+               *) echo "${deps:=$(_resolve_extension_deps $name)}" | wc -w;;
+       esac
+}
+
+generate_ini() {
+       local load_order
+
+       rm -rf conf.d
+       install -d conf.d
+       for module in ${*:-$ext_dir/*.so}; do
+               [ -f $module ] || continue
+               extname=${module##*/}; extname=${extname%.so}
+
+               ext=extension
+               # opcache.so is zend extension
+               nm $module | grep -q zend_extension_entry && ext=zend_extension
+
+               load_order=$(_extension_load_order "$extname")
+               cat > conf.d/$(printf %02d $load_order)_$extname.ini <<-EOF
+                       ; Enable $extname $ext module
+                       $ext=$extname
+               EOF
+       done
+}
+
+if [ -n "$GENERATE_INI" ]; then
+       generate_ini "$@"
+else
+       test_deps "$@"
+fi
This page took 0.029323 seconds and 4 git commands to generate.