aboutsummaryrefslogtreecommitdiffstats
path: root/build
diff options
context:
space:
mode:
Diffstat (limited to 'build')
-rwxr-xr-xbuild/autoloaderchecker.sh3
-rw-r--r--build/build.xml4
-rwxr-xr-xbuild/buildjsdocs.sh7
-rw-r--r--build/ca-bundle-etag.txt2
-rwxr-xr-xbuild/compile-handlebars-templates.sh5
-rwxr-xr-xbuild/composerbin2799637 -> 0 bytes
-rw-r--r--build/files-checker.php22
-rw-r--r--build/gen-coverage-badge.php20
-rw-r--r--build/htaccess-checker.php21
-rwxr-xr-xbuild/image-optimization.sh32
-rw-r--r--build/integration/.gitignore2
-rw-r--r--build/integration/collaboration_features/autocomplete.feature9
-rw-r--r--build/integration/comments_features/comments-search.feature (renamed from build/integration/features/comments-search.feature)0
-rw-r--r--build/integration/comments_features/comments.feature (renamed from build/integration/features/comments.feature)0
-rw-r--r--build/integration/composer.json23
-rw-r--r--build/integration/composer.lock893
-rw-r--r--build/integration/config/behat.yml110
-rw-r--r--build/integration/dav_features/caldav.feature (renamed from build/integration/features/caldav.feature)14
-rw-r--r--build/integration/dav_features/carddav.feature (renamed from build/integration/features/carddav.feature)0
-rw-r--r--build/integration/dav_features/dav-v2.feature (renamed from build/integration/features/dav-v2.feature)25
-rw-r--r--build/integration/dav_features/webdav-related.feature (renamed from build/integration/features/webdav-related.feature)0
-rw-r--r--build/integration/features/bootstrap/AppConfiguration.php27
-rw-r--r--build/integration/features/bootstrap/Auth.php29
-rw-r--r--build/integration/features/bootstrap/Avatar.php21
-rw-r--r--build/integration/features/bootstrap/BasicStructure.php33
-rw-r--r--build/integration/features/bootstrap/CalDavContext.php174
-rw-r--r--build/integration/features/bootstrap/CapabilitiesContext.php28
-rw-r--r--build/integration/features/bootstrap/CardDavContext.php25
-rw-r--r--build/integration/features/bootstrap/ChecksumsContext.php26
-rw-r--r--build/integration/features/bootstrap/CollaborationContext.php24
-rw-r--r--build/integration/features/bootstrap/CommandLine.php25
-rw-r--r--build/integration/features/bootstrap/CommandLineContext.php30
-rw-r--r--build/integration/features/bootstrap/CommentsContext.php62
-rw-r--r--build/integration/features/bootstrap/ContactsMenu.php21
-rw-r--r--build/integration/features/bootstrap/Download.php22
-rw-r--r--build/integration/features/bootstrap/FakeSMTPHelper.php22
-rw-r--r--build/integration/features/bootstrap/FeatureContext.php25
-rw-r--r--build/integration/features/bootstrap/FederationContext.php28
-rw-r--r--build/integration/features/bootstrap/FilesDropContext.php30
-rw-r--r--build/integration/features/bootstrap/LDAPContext.php29
-rw-r--r--build/integration/features/bootstrap/Mail.php21
-rw-r--r--build/integration/features/bootstrap/Provisioning.php33
-rw-r--r--build/integration/features/bootstrap/RemoteContext.php23
-rw-r--r--build/integration/features/bootstrap/Search.php21
-rw-r--r--build/integration/features/bootstrap/SetupContext.php21
-rw-r--r--build/integration/features/bootstrap/ShareesContext.php24
-rw-r--r--build/integration/features/bootstrap/Sharing.php61
-rw-r--r--build/integration/features/bootstrap/SharingContext.php23
-rw-r--r--build/integration/features/bootstrap/TagsContext.php28
-rw-r--r--build/integration/features/bootstrap/TalkContext.php21
-rw-r--r--build/integration/features/bootstrap/Trashbin.php24
-rw-r--r--build/integration/features/bootstrap/WebDav.php132
-rw-r--r--build/integration/features/maintenance-mode.feature6
-rw-r--r--build/integration/features/ratelimiting.feature4
-rw-r--r--build/integration/files_features/checksums.feature (renamed from build/integration/features/checksums.feature)0
-rw-r--r--build/integration/files_features/download.feature (renamed from build/integration/features/download.feature)0
-rw-r--r--build/integration/files_features/external-storage.feature (renamed from build/integration/features/external-storage.feature)0
-rw-r--r--build/integration/files_features/favorites.feature (renamed from build/integration/features/favorites.feature)0
-rw-r--r--build/integration/files_features/tags.feature (renamed from build/integration/features/tags.feature)0
-rw-r--r--build/integration/files_features/transfer-ownership.feature (renamed from build/integration/features/transfer-ownership.feature)4
-rw-r--r--build/integration/files_features/trashbin.feature (renamed from build/integration/features/trashbin.feature)0
-rw-r--r--build/integration/openldap_features/openldap-uid-username.feature (renamed from build/integration/ldap_features/openldap-uid-username.feature)0
-rw-r--r--build/integration/openldap_numerical_features/openldap-numerical-id.feature (renamed from build/integration/ldap_features/openldap-numerical-id.feature)28
-rwxr-xr-xbuild/integration/run-docker.sh19
-rwxr-xr-xbuild/integration/run.sh14
-rw-r--r--build/integration/sharing_features/sharing-v1.feature18
-rw-r--r--build/integration/videoverification_features/sharing-v1-video-verification.feature (renamed from build/integration/sharing_features/sharing-v1-video-verification.feature)2
-rw-r--r--build/license.php20
-rwxr-xr-xbuild/merge-font-noto.sh18
-rwxr-xr-xbuild/openapi-checker.sh13
-rwxr-xr-xbuild/phpDocumentor.sh5
-rw-r--r--build/psalm-baseline-ocp.xml137
-rw-r--r--build/psalm-baseline.xml2205
-rw-r--r--build/psalm/AppFrameworkTainter.php23
-rw-r--r--build/psalm/OcpSinceChecker.php50
-rw-r--r--build/signed-off-checker.php21
-rw-r--r--build/stubs/SensitiveParameter.phpstub5
-rw-r--r--build/stubs/app_api.php (renamed from build/stubs/app_ecosystem_v2.php)4
-rw-r--r--build/stubs/ftp.php93
-rw-r--r--build/stubs/gd.php3075
-rw-r--r--build/stubs/imagick.php8098
-rw-r--r--build/stubs/ldap.php198
-rw-r--r--build/translation-checker.php19
-rw-r--r--build/triple-dot-checker.php22
-rwxr-xr-xbuild/update-apps.sh4
-rwxr-xr-xbuild/update.sh4
86 files changed, 3714 insertions, 12700 deletions
diff --git a/build/autoloaderchecker.sh b/build/autoloaderchecker.sh
index 09bcff0b853..2df4b003f12 100755
--- a/build/autoloaderchecker.sh
+++ b/build/autoloaderchecker.sh
@@ -1,5 +1,8 @@
#!/usr/bin/env bash
+# SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
+
COMPOSER_COMMAND="php composer.phar"
if [ -e "composer.phar" ]
diff --git a/build/build.xml b/build/build.xml
index c8c5c4efffc..a44eca134d5 100644
--- a/build/build.xml
+++ b/build/build.xml
@@ -1,4 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
+<!--
+ - SPDX-FileCopyrightText: 2014 ownCloud, Inc.
+ - SPDX-License-Identifier: AGPL-3.0-or-later
+-->
<project name="ownCloud" default="build">
<!-- the target 'build' can be used by developers for command line builds -->
diff --git a/build/buildjsdocs.sh b/build/buildjsdocs.sh
index dd2af210277..e40ecd7242b 100755
--- a/build/buildjsdocs.sh
+++ b/build/buildjsdocs.sh
@@ -1,12 +1,11 @@
#!/usr/bin/env bash
#
-# ownCloud
+# SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
+# SPDX-FileCopyrightText: 2014-2015 ownCloud, Inc.
+# SPDX-License-Identifier: AGPL-3.0-only
#
# Run JS tests
#
-# @author Vincent Petry
-# @copyright 2014 Vincent Petry <pvince81@owncloud.com>
-#
NPM="$(which npm 2>/dev/null)"
OUTPUT_DIR="jsdocs"
diff --git a/build/ca-bundle-etag.txt b/build/ca-bundle-etag.txt
index ee4049d65cb..554025be5d9 100644
--- a/build/ca-bundle-etag.txt
+++ b/build/ca-bundle-etag.txt
@@ -1 +1 @@
-"3611e-6037a5bf7b40e"
+"38116-6136426be7e2c"
diff --git a/build/compile-handlebars-templates.sh b/build/compile-handlebars-templates.sh
index 6a9397de3fa..0e990f5ede3 100755
--- a/build/compile-handlebars-templates.sh
+++ b/build/compile-handlebars-templates.sh
@@ -1,5 +1,8 @@
#!/usr/bin/env bash
-
+#
+# SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
+#
REPODIR=`git rev-parse --show-toplevel`
cd $REPODIR
diff --git a/build/composer b/build/composer
deleted file mode 100755
index a3a5d90426d..00000000000
--- a/build/composer
+++ /dev/null
Binary files differ
diff --git a/build/files-checker.php b/build/files-checker.php
index 0befaed968e..d7b683904d5 100644
--- a/build/files-checker.php
+++ b/build/files-checker.php
@@ -1,22 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2017 Morris Jobke <hey@morrisjobke.de>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
$expectedFiles = [
@@ -39,6 +24,7 @@ $expectedFiles = [
'.npmignore',
'.php-cs-fixer.dist.php',
'.pre-commit-config.yaml',
+ '.reuse',
'.scrutinizer.yml',
'.tag',
'.tx',
@@ -78,8 +64,8 @@ $expectedFiles = [
'index.php',
'jest.config.ts',
'lib',
+ 'LICENSES',
'occ',
- 'ocm-provider',
'ocs',
'ocs-provider',
'package-lock.json',
diff --git a/build/gen-coverage-badge.php b/build/gen-coverage-badge.php
index 0164951fc1c..1c19d381626 100644
--- a/build/gen-coverage-badge.php
+++ b/build/gen-coverage-badge.php
@@ -1,22 +1,8 @@
<?php
/**
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- *
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
if (!isset($argv[1])) {
diff --git a/build/htaccess-checker.php b/build/htaccess-checker.php
index 950735463c9..b0c7a1bd735 100644
--- a/build/htaccess-checker.php
+++ b/build/htaccess-checker.php
@@ -1,24 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2016 Lukas Reschke <lukas@statuscode.ch>
- *
- * @author Lukas Reschke <lukas@statuscode.ch>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
/**
diff --git a/build/image-optimization.sh b/build/image-optimization.sh
index 01af95c97b9..ddb213ea5bb 100755
--- a/build/image-optimization.sh
+++ b/build/image-optimization.sh
@@ -1,20 +1,23 @@
#!/usr/bin/env bash
-
+#
+# SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
+#
set -e
OPTIPNG=$(which optipng)
if ! [ -x "$OPTIPNG" ]; then
- echo "optipng executable not found, please install" >&2
+ echo -e "\033[0;31moptipng executable not found, please install\033[0m" >&2
exit 1
fi
JPEGOPTIM=$(which jpegoptim)
if ! [ -x "$JPEGOPTIM" ]; then
- echo "jpegoptim executable not found, please install" >&2
+ echo -e "\033[0;31mjpegoptim executable not found, please install\033[0m" >&2
exit 2
fi
SCOUR=$(which scour)
if ! [ -x "$SCOUR" ]; then
- echo "scour executable not found, please install" >&2
+ echo -e "\033[0;31mscour executable not found, please install\033[0m" >&2
exit 3
fi
@@ -37,25 +40,25 @@ function recursive_optimize_images() {
DIR_NAME=${PWD##*/}
if [[ "$DIR_NAME" == "3rdparty" ]]; then
- echo "Ignoring 3rdparty for image optimization"
+ echo -e "\033[0;36mIgnoring 3rdparty for image optimization\033[0m"
return
elif [[ "$DIR_NAME" == "build" ]]; then
- echo "Ignoring build for image optimization"
+ echo -e "\033[0;36mIgnoring build for image optimization\033[0m"
return
elif [[ "$DIR_NAME" == "cypress" ]]; then
- echo "Ignoring cypress for image optimization"
+ echo -e "\033[0;36mIgnoring cypress for image optimization\033[0m"
return
elif [[ "$DIR_NAME" == "node_modules" ]]; then
- echo "Ignoring node_modules for image optimization"
+ echo -e "\033[0;36mIgnoring node_modules for image optimization\033[0m"
return
elif [[ "$DIR_NAME" == "tests" ]]; then
- echo "Ignoring tests for image optimization"
+ echo -e "\033[0;36mIgnoring tests for image optimization\033[0m"
return
elif [[ "$DIR_NAME" == "vendor" ]]; then
- echo "Ignoring vendor for image optimization"
+ echo -e "\033[0;36mIgnoring vendor for image optimization\033[0m"
return
elif [[ "$DIR_NAME" == "vendor-bin" ]]; then
- echo "Ignoring vendor-bin for image optimization"
+ echo -e "\033[0;36mIgnoring vendor-bin for image optimization\033[0m"
return
fi
@@ -80,6 +83,11 @@ function recursive_optimize_images() {
do
[[ -e "$svg" ]] || break
+ if [[ "$svg" == "default-source.svg" ]]; then
+ echo -e "\033[0;36mIgnoring $svg image optimization\033[0m"
+ continue
+ fi
+
mv $svg $svg.opttmp
$SCOUR --create-groups \
--enable-id-stripping \
@@ -100,7 +108,7 @@ function recursive_optimize_images() {
if [[ -d "$dir" ]]; then
if git check-ignore $dir -q ; then
- echo "$dir is not shipped. Ignoring image optimization"
+ echo -e "\033[0;36m$dir is not shipped. Ignoring image optimization\033[0m"
continue
fi
diff --git a/build/integration/.gitignore b/build/integration/.gitignore
index 18b981bf7ed..c8af938d6ab 100644
--- a/build/integration/.gitignore
+++ b/build/integration/.gitignore
@@ -1,3 +1,5 @@
+# SPDX-FileCopyrightText: 2015 ownCloud, Inc.
+# SPDX-License-Identifier: AGPL-3.0-only
vendor
output
composer.lock
diff --git a/build/integration/collaboration_features/autocomplete.feature b/build/integration/collaboration_features/autocomplete.feature
index df7b81b9148..7329db79e29 100644
--- a/build/integration/collaboration_features/autocomplete.feature
+++ b/build/integration/collaboration_features/autocomplete.feature
@@ -15,12 +15,13 @@ Feature: autocomplete
| auto | users |
| autocomplete | users |
| autocomplete2 | users |
+ And user "autocomplete" has status "dnd"
When parameter "shareapi_restrict_user_enumeration_full_match" of app "core" is set to "no"
Then get autocomplete for "auto"
- | id | source |
- | auto | users |
- | autocomplete | users |
- | autocomplete2 | users |
+ | id | source | status |
+ | auto | users | "" |
+ | autocomplete | users | {"status":"dnd","message":null,"icon":null,"clearAt":null} |
+ | autocomplete2 | users | "" |
Scenario: getting autocomplete without enumeration
diff --git a/build/integration/features/comments-search.feature b/build/integration/comments_features/comments-search.feature
index a1d116ee3f4..a1d116ee3f4 100644
--- a/build/integration/features/comments-search.feature
+++ b/build/integration/comments_features/comments-search.feature
diff --git a/build/integration/features/comments.feature b/build/integration/comments_features/comments.feature
index 0f3a4cc75cf..0f3a4cc75cf 100644
--- a/build/integration/features/comments.feature
+++ b/build/integration/comments_features/comments.feature
diff --git a/build/integration/composer.json b/build/integration/composer.json
index f5e2d58233a..7ab9da29e4a 100644
--- a/build/integration/composer.json
+++ b/build/integration/composer.json
@@ -1,11 +1,16 @@
{
- "require-dev": {
- "phpunit/phpunit": "^9",
- "dms/phpunit-arraysubset-asserts": "^0.5",
- "behat/behat": "~3.13.0",
- "guzzlehttp/guzzle": "7.6.1",
- "jarnaiz/behat-junit-formatter": "^1.3",
- "sabre/dav": "4.4.0",
- "symfony/event-dispatcher": "~5.3"
- }
+ "config": {
+ "platform": {
+ "php": "8.0.2"
+ },
+ "sort-packages": true
+ },
+ "require-dev": {
+ "behat/behat": "^3.14",
+ "dms/phpunit-arraysubset-asserts": "^0.5",
+ "guzzlehttp/guzzle": "^7.8",
+ "phpunit/phpunit": "^9.6",
+ "sabre/dav": "^4.6",
+ "symfony/event-dispatcher": "^5.4"
+ }
}
diff --git a/build/integration/composer.lock b/build/integration/composer.lock
index c7d406da98a..3c5e9d634ae 100644
--- a/build/integration/composer.lock
+++ b/build/integration/composer.lock
@@ -4,21 +4,21 @@
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
"This file is @generated automatically"
],
- "content-hash": "47c1276046613ebfa35e13a6b96c7f06",
+ "content-hash": "a1099632419635a7a22336e2ccf1c8db",
"packages": [],
"packages-dev": [
{
"name": "behat/behat",
- "version": "v3.13.0",
+ "version": "v3.14.0",
"source": {
"type": "git",
"url": "https://github.com/Behat/Behat.git",
- "reference": "9dd7cdb309e464ddeab095cd1a5151c2dccba4ab"
+ "reference": "2a3832d9cb853a794af3a576f9e524ae460f3340"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/Behat/Behat/zipball/9dd7cdb309e464ddeab095cd1a5151c2dccba4ab",
- "reference": "9dd7cdb309e464ddeab095cd1a5151c2dccba4ab",
+ "url": "https://api.github.com/repos/Behat/Behat/zipball/2a3832d9cb853a794af3a576f9e524ae460f3340",
+ "reference": "2a3832d9cb853a794af3a576f9e524ae460f3340",
"shasum": ""
},
"require": {
@@ -27,18 +27,18 @@
"ext-mbstring": "*",
"php": "^7.2 || ^8.0",
"psr/container": "^1.0 || ^2.0",
- "symfony/config": "^4.4 || ^5.0 || ^6.0",
- "symfony/console": "^4.4 || ^5.0 || ^6.0",
- "symfony/dependency-injection": "^4.4 || ^5.0 || ^6.0",
- "symfony/event-dispatcher": "^4.4 || ^5.0 || ^6.0",
- "symfony/translation": "^4.4 || ^5.0 || ^6.0",
- "symfony/yaml": "^4.4 || ^5.0 || ^6.0"
+ "symfony/config": "^4.4 || ^5.0 || ^6.0 || ^7.0",
+ "symfony/console": "^4.4 || ^5.0 || ^6.0 || ^7.0",
+ "symfony/dependency-injection": "^4.4 || ^5.0 || ^6.0 || ^7.0",
+ "symfony/event-dispatcher": "^4.4 || ^5.0 || ^6.0 || ^7.0",
+ "symfony/translation": "^4.4 || ^5.0 || ^6.0 || ^7.0",
+ "symfony/yaml": "^4.4 || ^5.0 || ^6.0 || ^7.0"
},
"require-dev": {
"herrera-io/box": "~1.6.1",
"phpspec/prophecy": "^1.15",
"phpunit/phpunit": "^8.5 || ^9.0",
- "symfony/process": "^4.4 || ^5.0 || ^6.0",
+ "symfony/process": "^4.4 || ^5.0 || ^6.0 || ^7.0",
"vimeo/psalm": "^4.8"
},
"suggest": {
@@ -90,9 +90,9 @@
],
"support": {
"issues": "https://github.com/Behat/Behat/issues",
- "source": "https://github.com/Behat/Behat/tree/v3.13.0"
+ "source": "https://github.com/Behat/Behat/tree/v3.14.0"
},
- "time": "2023-04-18T15:40:53+00:00"
+ "time": "2023-12-09T13:55:02+00:00"
},
{
"name": "behat/gherkin",
@@ -322,22 +322,22 @@
},
{
"name": "guzzlehttp/guzzle",
- "version": "7.6.1",
+ "version": "7.8.1",
"source": {
"type": "git",
"url": "https://github.com/guzzle/guzzle.git",
- "reference": "8444a2bacf1960bc6a2b62ed86b8e72e11eebe51"
+ "reference": "41042bc7ab002487b876a0683fc8dce04ddce104"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/guzzle/guzzle/zipball/8444a2bacf1960bc6a2b62ed86b8e72e11eebe51",
- "reference": "8444a2bacf1960bc6a2b62ed86b8e72e11eebe51",
+ "url": "https://api.github.com/repos/guzzle/guzzle/zipball/41042bc7ab002487b876a0683fc8dce04ddce104",
+ "reference": "41042bc7ab002487b876a0683fc8dce04ddce104",
"shasum": ""
},
"require": {
"ext-json": "*",
- "guzzlehttp/promises": "^1.5",
- "guzzlehttp/psr7": "^1.9.1 || ^2.4.5",
+ "guzzlehttp/promises": "^1.5.3 || ^2.0.1",
+ "guzzlehttp/psr7": "^1.9.1 || ^2.5.1",
"php": "^7.2.5 || ^8.0",
"psr/http-client": "^1.0",
"symfony/deprecation-contracts": "^2.2 || ^3.0"
@@ -346,10 +346,11 @@
"psr/http-client-implementation": "1.0"
},
"require-dev": {
- "bamarni/composer-bin-plugin": "^1.8.1",
+ "bamarni/composer-bin-plugin": "^1.8.2",
"ext-curl": "*",
- "php-http/client-integration-tests": "^3.0",
- "phpunit/phpunit": "^8.5.29 || ^9.5.23",
+ "php-http/client-integration-tests": "dev-master#2c025848417c1135031fdf9c728ee53d0a7ceaee as 3.0.999",
+ "php-http/message-factory": "^1.1",
+ "phpunit/phpunit": "^8.5.36 || ^9.6.15",
"psr/log": "^1.1 || ^2.0 || ^3.0"
},
"suggest": {
@@ -427,7 +428,7 @@
],
"support": {
"issues": "https://github.com/guzzle/guzzle/issues",
- "source": "https://github.com/guzzle/guzzle/tree/7.6.1"
+ "source": "https://github.com/guzzle/guzzle/tree/7.8.1"
},
"funding": [
{
@@ -443,38 +444,37 @@
"type": "tidelift"
}
],
- "time": "2023-05-15T20:43:01+00:00"
+ "time": "2023-12-03T20:35:24+00:00"
},
{
"name": "guzzlehttp/promises",
- "version": "1.5.2",
+ "version": "2.0.2",
"source": {
"type": "git",
"url": "https://github.com/guzzle/promises.git",
- "reference": "b94b2807d85443f9719887892882d0329d1e2598"
+ "reference": "bbff78d96034045e58e13dedd6ad91b5d1253223"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/guzzle/promises/zipball/b94b2807d85443f9719887892882d0329d1e2598",
- "reference": "b94b2807d85443f9719887892882d0329d1e2598",
+ "url": "https://api.github.com/repos/guzzle/promises/zipball/bbff78d96034045e58e13dedd6ad91b5d1253223",
+ "reference": "bbff78d96034045e58e13dedd6ad91b5d1253223",
"shasum": ""
},
"require": {
- "php": ">=5.5"
+ "php": "^7.2.5 || ^8.0"
},
"require-dev": {
- "symfony/phpunit-bridge": "^4.4 || ^5.1"
+ "bamarni/composer-bin-plugin": "^1.8.2",
+ "phpunit/phpunit": "^8.5.36 || ^9.6.15"
},
"type": "library",
"extra": {
- "branch-alias": {
- "dev-master": "1.5-dev"
+ "bamarni-bin": {
+ "bin-links": true,
+ "forward-command": false
}
},
"autoload": {
- "files": [
- "src/functions_include.php"
- ],
"psr-4": {
"GuzzleHttp\\Promise\\": "src/"
}
@@ -511,7 +511,7 @@
],
"support": {
"issues": "https://github.com/guzzle/promises/issues",
- "source": "https://github.com/guzzle/promises/tree/1.5.2"
+ "source": "https://github.com/guzzle/promises/tree/2.0.2"
},
"funding": [
{
@@ -527,20 +527,20 @@
"type": "tidelift"
}
],
- "time": "2022-08-28T14:55:35+00:00"
+ "time": "2023-12-03T20:19:20+00:00"
},
{
"name": "guzzlehttp/psr7",
- "version": "2.5.0",
+ "version": "2.6.2",
"source": {
"type": "git",
"url": "https://github.com/guzzle/psr7.git",
- "reference": "b635f279edd83fc275f822a1188157ffea568ff6"
+ "reference": "45b30f99ac27b5ca93cb4831afe16285f57b8221"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/guzzle/psr7/zipball/b635f279edd83fc275f822a1188157ffea568ff6",
- "reference": "b635f279edd83fc275f822a1188157ffea568ff6",
+ "url": "https://api.github.com/repos/guzzle/psr7/zipball/45b30f99ac27b5ca93cb4831afe16285f57b8221",
+ "reference": "45b30f99ac27b5ca93cb4831afe16285f57b8221",
"shasum": ""
},
"require": {
@@ -554,9 +554,9 @@
"psr/http-message-implementation": "1.0"
},
"require-dev": {
- "bamarni/composer-bin-plugin": "^1.8.1",
+ "bamarni/composer-bin-plugin": "^1.8.2",
"http-interop/http-factory-tests": "^0.9",
- "phpunit/phpunit": "^8.5.29 || ^9.5.23"
+ "phpunit/phpunit": "^8.5.36 || ^9.6.15"
},
"suggest": {
"laminas/laminas-httphandlerrunner": "Emit PSR-7 responses"
@@ -627,7 +627,7 @@
],
"support": {
"issues": "https://github.com/guzzle/psr7/issues",
- "source": "https://github.com/guzzle/psr7/tree/2.5.0"
+ "source": "https://github.com/guzzle/psr7/tree/2.6.2"
},
"funding": [
{
@@ -643,50 +643,7 @@
"type": "tidelift"
}
],
- "time": "2023-04-17T16:11:26+00:00"
- },
- {
- "name": "jarnaiz/behat-junit-formatter",
- "version": "v1.3.2",
- "source": {
- "type": "git",
- "url": "https://github.com/j-arnaiz/behat-junit-formatter.git",
- "reference": "2f80b3881e04d3cf43e05ab821c0e80675a9846d"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/j-arnaiz/behat-junit-formatter/zipball/2f80b3881e04d3cf43e05ab821c0e80675a9846d",
- "reference": "2f80b3881e04d3cf43e05ab821c0e80675a9846d",
- "shasum": ""
- },
- "require": {
- "behat/behat": "~3.0",
- "php": ">=5.3.0"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-master": "v1.0.x-dev"
- }
- },
- "autoload": {
- "psr-4": {
- "jarnaiz\\JUnitFormatter\\": "src/"
- }
- },
- "notification-url": "https://packagist.org/downloads/",
- "authors": [
- {
- "name": "Jesús Arnaiz",
- "email": "j.arnaiz@gmail.com"
- }
- ],
- "description": "Behat 3 JUnit xml formatter",
- "support": {
- "issues": "https://github.com/j-arnaiz/behat-junit-formatter/issues",
- "source": "https://github.com/j-arnaiz/behat-junit-formatter/tree/master"
- },
- "time": "2016-01-26T17:05:07+00:00"
+ "time": "2023-12-03T20:05:35+00:00"
},
{
"name": "myclabs/deep-copy",
@@ -749,25 +706,27 @@
},
{
"name": "nikic/php-parser",
- "version": "v4.16.0",
+ "version": "v5.0.2",
"source": {
"type": "git",
"url": "https://github.com/nikic/PHP-Parser.git",
- "reference": "19526a33fb561ef417e822e85f08a00db4059c17"
+ "reference": "139676794dc1e9231bf7bcd123cfc0c99182cb13"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/19526a33fb561ef417e822e85f08a00db4059c17",
- "reference": "19526a33fb561ef417e822e85f08a00db4059c17",
+ "url": "https://api.github.com/repos/nikic/PHP-Parser/zipball/139676794dc1e9231bf7bcd123cfc0c99182cb13",
+ "reference": "139676794dc1e9231bf7bcd123cfc0c99182cb13",
"shasum": ""
},
"require": {
+ "ext-ctype": "*",
+ "ext-json": "*",
"ext-tokenizer": "*",
- "php": ">=7.0"
+ "php": ">=7.4"
},
"require-dev": {
"ircmaxell/php-yacc": "^0.0.7",
- "phpunit/phpunit": "^6.5 || ^7.0 || ^8.0 || ^9.0"
+ "phpunit/phpunit": "^7.0 || ^8.0 || ^9.0"
},
"bin": [
"bin/php-parse"
@@ -775,7 +734,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-master": "4.9-dev"
+ "dev-master": "5.0-dev"
}
},
"autoload": {
@@ -799,26 +758,27 @@
],
"support": {
"issues": "https://github.com/nikic/PHP-Parser/issues",
- "source": "https://github.com/nikic/PHP-Parser/tree/v4.16.0"
+ "source": "https://github.com/nikic/PHP-Parser/tree/v5.0.2"
},
- "time": "2023-06-25T14:52:30+00:00"
+ "time": "2024-03-05T20:51:40+00:00"
},
{
"name": "phar-io/manifest",
- "version": "2.0.3",
+ "version": "2.0.4",
"source": {
"type": "git",
"url": "https://github.com/phar-io/manifest.git",
- "reference": "97803eca37d319dfa7826cc2437fc020857acb53"
+ "reference": "54750ef60c58e43759730615a392c31c80e23176"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/phar-io/manifest/zipball/97803eca37d319dfa7826cc2437fc020857acb53",
- "reference": "97803eca37d319dfa7826cc2437fc020857acb53",
+ "url": "https://api.github.com/repos/phar-io/manifest/zipball/54750ef60c58e43759730615a392c31c80e23176",
+ "reference": "54750ef60c58e43759730615a392c31c80e23176",
"shasum": ""
},
"require": {
"ext-dom": "*",
+ "ext-libxml": "*",
"ext-phar": "*",
"ext-xmlwriter": "*",
"phar-io/version": "^3.0.1",
@@ -859,9 +819,15 @@
"description": "Component for reading phar.io manifest information from a PHP Archive (PHAR)",
"support": {
"issues": "https://github.com/phar-io/manifest/issues",
- "source": "https://github.com/phar-io/manifest/tree/2.0.3"
+ "source": "https://github.com/phar-io/manifest/tree/2.0.4"
},
- "time": "2021-07-20T11:28:43+00:00"
+ "funding": [
+ {
+ "url": "https://github.com/theseer",
+ "type": "github"
+ }
+ ],
+ "time": "2024-03-03T12:33:53+00:00"
},
{
"name": "phar-io/version",
@@ -916,23 +882,23 @@
},
{
"name": "phpunit/php-code-coverage",
- "version": "9.2.26",
+ "version": "9.2.31",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/php-code-coverage.git",
- "reference": "443bc6912c9bd5b409254a40f4b0f4ced7c80ea1"
+ "reference": "48c34b5d8d983006bd2adc2d0de92963b9155965"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/443bc6912c9bd5b409254a40f4b0f4ced7c80ea1",
- "reference": "443bc6912c9bd5b409254a40f4b0f4ced7c80ea1",
+ "url": "https://api.github.com/repos/sebastianbergmann/php-code-coverage/zipball/48c34b5d8d983006bd2adc2d0de92963b9155965",
+ "reference": "48c34b5d8d983006bd2adc2d0de92963b9155965",
"shasum": ""
},
"require": {
"ext-dom": "*",
"ext-libxml": "*",
"ext-xmlwriter": "*",
- "nikic/php-parser": "^4.15",
+ "nikic/php-parser": "^4.18 || ^5.0",
"php": ">=7.3",
"phpunit/php-file-iterator": "^3.0.3",
"phpunit/php-text-template": "^2.0.2",
@@ -981,7 +947,8 @@
],
"support": {
"issues": "https://github.com/sebastianbergmann/php-code-coverage/issues",
- "source": "https://github.com/sebastianbergmann/php-code-coverage/tree/9.2.26"
+ "security": "https://github.com/sebastianbergmann/php-code-coverage/security/policy",
+ "source": "https://github.com/sebastianbergmann/php-code-coverage/tree/9.2.31"
},
"funding": [
{
@@ -989,7 +956,7 @@
"type": "github"
}
],
- "time": "2023-03-06T12:58:08+00:00"
+ "time": "2024-03-02T06:37:42+00:00"
},
{
"name": "phpunit/php-file-iterator",
@@ -1234,16 +1201,16 @@
},
{
"name": "phpunit/phpunit",
- "version": "9.6.10",
+ "version": "9.6.19",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/phpunit.git",
- "reference": "a6d351645c3fe5a30f5e86be6577d946af65a328"
+ "reference": "a1a54a473501ef4cdeaae4e06891674114d79db8"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/a6d351645c3fe5a30f5e86be6577d946af65a328",
- "reference": "a6d351645c3fe5a30f5e86be6577d946af65a328",
+ "url": "https://api.github.com/repos/sebastianbergmann/phpunit/zipball/a1a54a473501ef4cdeaae4e06891674114d79db8",
+ "reference": "a1a54a473501ef4cdeaae4e06891674114d79db8",
"shasum": ""
},
"require": {
@@ -1258,7 +1225,7 @@
"phar-io/manifest": "^2.0.3",
"phar-io/version": "^3.0.2",
"php": ">=7.3",
- "phpunit/php-code-coverage": "^9.2.13",
+ "phpunit/php-code-coverage": "^9.2.28",
"phpunit/php-file-iterator": "^3.0.5",
"phpunit/php-invoker": "^3.1.1",
"phpunit/php-text-template": "^2.0.3",
@@ -1317,7 +1284,7 @@
"support": {
"issues": "https://github.com/sebastianbergmann/phpunit/issues",
"security": "https://github.com/sebastianbergmann/phpunit/security/policy",
- "source": "https://github.com/sebastianbergmann/phpunit/tree/9.6.10"
+ "source": "https://github.com/sebastianbergmann/phpunit/tree/9.6.19"
},
"funding": [
{
@@ -1333,26 +1300,31 @@
"type": "tidelift"
}
],
- "time": "2023-07-10T04:04:23+00:00"
+ "time": "2024-04-05T04:35:58+00:00"
},
{
"name": "psr/container",
- "version": "1.1.2",
+ "version": "2.0.2",
"source": {
"type": "git",
"url": "https://github.com/php-fig/container.git",
- "reference": "513e0666f7216c7459170d56df27dfcefe1689ea"
+ "reference": "c71ecc56dfe541dbd90c5360474fbc405f8d5963"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/php-fig/container/zipball/513e0666f7216c7459170d56df27dfcefe1689ea",
- "reference": "513e0666f7216c7459170d56df27dfcefe1689ea",
+ "url": "https://api.github.com/repos/php-fig/container/zipball/c71ecc56dfe541dbd90c5360474fbc405f8d5963",
+ "reference": "c71ecc56dfe541dbd90c5360474fbc405f8d5963",
"shasum": ""
},
"require": {
"php": ">=7.4.0"
},
"type": "library",
+ "extra": {
+ "branch-alias": {
+ "dev-master": "2.0.x-dev"
+ }
+ },
"autoload": {
"psr-4": {
"Psr\\Container\\": "src/"
@@ -1379,9 +1351,9 @@
],
"support": {
"issues": "https://github.com/php-fig/container/issues",
- "source": "https://github.com/php-fig/container/tree/1.1.2"
+ "source": "https://github.com/php-fig/container/tree/2.0.2"
},
- "time": "2021-11-05T16:50:12+00:00"
+ "time": "2021-11-05T16:47:00+00:00"
},
{
"name": "psr/event-dispatcher",
@@ -1435,16 +1407,16 @@
},
{
"name": "psr/http-client",
- "version": "1.0.2",
+ "version": "1.0.3",
"source": {
"type": "git",
"url": "https://github.com/php-fig/http-client.git",
- "reference": "0955afe48220520692d2d09f7ab7e0f93ffd6a31"
+ "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/php-fig/http-client/zipball/0955afe48220520692d2d09f7ab7e0f93ffd6a31",
- "reference": "0955afe48220520692d2d09f7ab7e0f93ffd6a31",
+ "url": "https://api.github.com/repos/php-fig/http-client/zipball/bb5906edc1c324c9a05aa0873d40117941e5fa90",
+ "reference": "bb5906edc1c324c9a05aa0873d40117941e5fa90",
"shasum": ""
},
"require": {
@@ -1481,9 +1453,9 @@
"psr-18"
],
"support": {
- "source": "https://github.com/php-fig/http-client/tree/1.0.2"
+ "source": "https://github.com/php-fig/http-client"
},
- "time": "2023-04-10T20:12:12+00:00"
+ "time": "2023-09-23T14:17:50+00:00"
},
{
"name": "psr/http-factory",
@@ -1595,30 +1567,30 @@
},
{
"name": "psr/log",
- "version": "1.1.4",
+ "version": "3.0.0",
"source": {
"type": "git",
"url": "https://github.com/php-fig/log.git",
- "reference": "d49695b909c3b7628b6289db5479a1c204601f11"
+ "reference": "fe5ea303b0887d5caefd3d431c3e61ad47037001"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/php-fig/log/zipball/d49695b909c3b7628b6289db5479a1c204601f11",
- "reference": "d49695b909c3b7628b6289db5479a1c204601f11",
+ "url": "https://api.github.com/repos/php-fig/log/zipball/fe5ea303b0887d5caefd3d431c3e61ad47037001",
+ "reference": "fe5ea303b0887d5caefd3d431c3e61ad47037001",
"shasum": ""
},
"require": {
- "php": ">=5.3.0"
+ "php": ">=8.0.0"
},
"type": "library",
"extra": {
"branch-alias": {
- "dev-master": "1.1.x-dev"
+ "dev-master": "3.x-dev"
}
},
"autoload": {
"psr-4": {
- "Psr\\Log\\": "Psr/Log/"
+ "Psr\\Log\\": "src"
}
},
"notification-url": "https://packagist.org/downloads/",
@@ -1639,9 +1611,9 @@
"psr-3"
],
"support": {
- "source": "https://github.com/php-fig/log/tree/1.1.4"
+ "source": "https://github.com/php-fig/log/tree/3.0.0"
},
- "time": "2021-05-03T11:20:27+00:00"
+ "time": "2021-07-14T16:46:02+00:00"
},
{
"name": "ralouphie/getallheaders",
@@ -1689,16 +1661,16 @@
},
{
"name": "sabre/dav",
- "version": "4.4.0",
+ "version": "4.6.0",
"source": {
"type": "git",
"url": "https://github.com/sabre-io/dav.git",
- "reference": "b65362abc926520eda2c57e219f022a6c288069d"
+ "reference": "554145304b4a026477d130928d16e626939b0b2a"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sabre-io/dav/zipball/b65362abc926520eda2c57e219f022a6c288069d",
- "reference": "b65362abc926520eda2c57e219f022a6c288069d",
+ "url": "https://api.github.com/repos/sabre-io/dav/zipball/554145304b4a026477d130928d16e626939b0b2a",
+ "reference": "554145304b4a026477d130928d16e626939b0b2a",
"shasum": ""
},
"require": {
@@ -1721,11 +1693,11 @@
"sabre/xml": "^2.0.1"
},
"require-dev": {
- "evert/phpdoc-md": "~0.1.0",
- "friendsofphp/php-cs-fixer": "^2.17.1",
- "monolog/monolog": "^1.18",
- "phpstan/phpstan": "^0.12",
- "phpunit/phpunit": "^7.5 || ^8.5 || ^9.0"
+ "friendsofphp/php-cs-fixer": "^2.19",
+ "monolog/monolog": "^1.27 || ^2.0",
+ "phpstan/phpstan": "^0.12 || ^1.0",
+ "phpstan/phpstan-phpunit": "^1.0",
+ "phpunit/phpunit": "^7.5 || ^8.5 || ^9.6"
},
"suggest": {
"ext-curl": "*",
@@ -1739,10 +1711,7 @@
"type": "library",
"autoload": {
"psr-4": {
- "Sabre\\DAV\\": "lib/DAV/",
- "Sabre\\CalDAV\\": "lib/CalDAV/",
- "Sabre\\DAVACL\\": "lib/DAVACL/",
- "Sabre\\CardDAV\\": "lib/CardDAV/"
+ "Sabre\\": "lib/"
}
},
"notification-url": "https://packagist.org/downloads/",
@@ -1771,7 +1740,7 @@
"issues": "https://github.com/sabre-io/dav/issues",
"source": "https://github.com/fruux/sabre-dav"
},
- "time": "2022-06-27T09:07:55+00:00"
+ "time": "2023-12-11T13:01:23+00:00"
},
{
"name": "sabre/event",
@@ -1841,16 +1810,16 @@
},
{
"name": "sabre/http",
- "version": "5.1.6",
+ "version": "5.1.10",
"source": {
"type": "git",
"url": "https://github.com/sabre-io/http.git",
- "reference": "9976ac34ced206bd6579b7b37b401de9fac98dae"
+ "reference": "f9f3d1fba8916fa2f4ec25636c4fedc26cb94e02"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sabre-io/http/zipball/9976ac34ced206bd6579b7b37b401de9fac98dae",
- "reference": "9976ac34ced206bd6579b7b37b401de9fac98dae",
+ "url": "https://api.github.com/repos/sabre-io/http/zipball/f9f3d1fba8916fa2f4ec25636c4fedc26cb94e02",
+ "reference": "f9f3d1fba8916fa2f4ec25636c4fedc26cb94e02",
"shasum": ""
},
"require": {
@@ -1900,29 +1869,32 @@
"issues": "https://github.com/sabre-io/http/issues",
"source": "https://github.com/fruux/sabre-http"
},
- "time": "2022-07-15T14:51:14+00:00"
+ "time": "2023-08-18T01:55:28+00:00"
},
{
"name": "sabre/uri",
- "version": "2.3.0",
+ "version": "2.3.3",
"source": {
"type": "git",
"url": "https://github.com/sabre-io/uri.git",
- "reference": "4e84208b86d351e8a439613f318feda7a0152b48"
+ "reference": "7e0e7dfd0b7e14346a27eabd66e843a6e7f1812b"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sabre-io/uri/zipball/4e84208b86d351e8a439613f318feda7a0152b48",
- "reference": "4e84208b86d351e8a439613f318feda7a0152b48",
+ "url": "https://api.github.com/repos/sabre-io/uri/zipball/7e0e7dfd0b7e14346a27eabd66e843a6e7f1812b",
+ "reference": "7e0e7dfd0b7e14346a27eabd66e843a6e7f1812b",
"shasum": ""
},
"require": {
"php": "^7.4 || ^8.0"
},
"require-dev": {
- "friendsofphp/php-cs-fixer": "^3.9",
- "phpstan/phpstan": "^1.8",
- "phpunit/phpunit": "^9.0"
+ "friendsofphp/php-cs-fixer": "^3.17",
+ "phpstan/extension-installer": "^1.3",
+ "phpstan/phpstan": "^1.10",
+ "phpstan/phpstan-phpunit": "^1.3",
+ "phpstan/phpstan-strict-rules": "^1.5",
+ "phpunit/phpunit": "^9.6"
},
"type": "library",
"autoload": {
@@ -1957,26 +1929,26 @@
"issues": "https://github.com/sabre-io/uri/issues",
"source": "https://github.com/fruux/sabre-uri"
},
- "time": "2022-08-17T09:51:38+00:00"
+ "time": "2023-06-09T06:54:04+00:00"
},
{
"name": "sabre/vobject",
- "version": "4.5.0",
+ "version": "4.5.4",
"source": {
"type": "git",
"url": "https://github.com/sabre-io/vobject.git",
- "reference": "d1fdc0c3587a314bdd3aac4a1e1dcacadd91858e"
+ "reference": "a6d53a3e5bec85ed3dd78868b7de0f5b4e12f772"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sabre-io/vobject/zipball/d1fdc0c3587a314bdd3aac4a1e1dcacadd91858e",
- "reference": "d1fdc0c3587a314bdd3aac4a1e1dcacadd91858e",
+ "url": "https://api.github.com/repos/sabre-io/vobject/zipball/a6d53a3e5bec85ed3dd78868b7de0f5b4e12f772",
+ "reference": "a6d53a3e5bec85ed3dd78868b7de0f5b4e12f772",
"shasum": ""
},
"require": {
"ext-mbstring": "*",
"php": "^7.1 || ^8.0",
- "sabre/xml": "^2.1"
+ "sabre/xml": "^2.1 || ^3.0 || ^4.0"
},
"require-dev": {
"friendsofphp/php-cs-fixer": "~2.17.1",
@@ -2061,20 +2033,20 @@
"issues": "https://github.com/sabre-io/vobject/issues",
"source": "https://github.com/fruux/sabre-vobject"
},
- "time": "2022-08-17T16:39:31+00:00"
+ "time": "2023-11-09T12:54:37+00:00"
},
{
"name": "sabre/xml",
- "version": "2.2.5",
+ "version": "2.2.6",
"source": {
"type": "git",
"url": "https://github.com/sabre-io/xml.git",
- "reference": "a6af111850e7536d200d9637c34885cd3c77a86c"
+ "reference": "9cde7cdab1e50893cc83b037b40cd47bfde42a2b"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sabre-io/xml/zipball/a6af111850e7536d200d9637c34885cd3c77a86c",
- "reference": "a6af111850e7536d200d9637c34885cd3c77a86c",
+ "url": "https://api.github.com/repos/sabre-io/xml/zipball/9cde7cdab1e50893cc83b037b40cd47bfde42a2b",
+ "reference": "9cde7cdab1e50893cc83b037b40cd47bfde42a2b",
"shasum": ""
},
"require": {
@@ -2130,20 +2102,20 @@
"issues": "https://github.com/sabre-io/xml/issues",
"source": "https://github.com/fruux/sabre-xml"
},
- "time": "2021-11-04T06:37:27+00:00"
+ "time": "2023-06-28T12:56:05+00:00"
},
{
"name": "sebastian/cli-parser",
- "version": "1.0.1",
+ "version": "1.0.2",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/cli-parser.git",
- "reference": "442e7c7e687e42adc03470c7b668bc4b2402c0b2"
+ "reference": "2b56bea83a09de3ac06bb18b92f068e60cc6f50b"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/cli-parser/zipball/442e7c7e687e42adc03470c7b668bc4b2402c0b2",
- "reference": "442e7c7e687e42adc03470c7b668bc4b2402c0b2",
+ "url": "https://api.github.com/repos/sebastianbergmann/cli-parser/zipball/2b56bea83a09de3ac06bb18b92f068e60cc6f50b",
+ "reference": "2b56bea83a09de3ac06bb18b92f068e60cc6f50b",
"shasum": ""
},
"require": {
@@ -2178,7 +2150,7 @@
"homepage": "https://github.com/sebastianbergmann/cli-parser",
"support": {
"issues": "https://github.com/sebastianbergmann/cli-parser/issues",
- "source": "https://github.com/sebastianbergmann/cli-parser/tree/1.0.1"
+ "source": "https://github.com/sebastianbergmann/cli-parser/tree/1.0.2"
},
"funding": [
{
@@ -2186,7 +2158,7 @@
"type": "github"
}
],
- "time": "2020-09-28T06:08:49+00:00"
+ "time": "2024-03-02T06:27:43+00:00"
},
{
"name": "sebastian/code-unit",
@@ -2375,20 +2347,20 @@
},
{
"name": "sebastian/complexity",
- "version": "2.0.2",
+ "version": "2.0.3",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/complexity.git",
- "reference": "739b35e53379900cc9ac327b2147867b8b6efd88"
+ "reference": "25f207c40d62b8b7aa32f5ab026c53561964053a"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/complexity/zipball/739b35e53379900cc9ac327b2147867b8b6efd88",
- "reference": "739b35e53379900cc9ac327b2147867b8b6efd88",
+ "url": "https://api.github.com/repos/sebastianbergmann/complexity/zipball/25f207c40d62b8b7aa32f5ab026c53561964053a",
+ "reference": "25f207c40d62b8b7aa32f5ab026c53561964053a",
"shasum": ""
},
"require": {
- "nikic/php-parser": "^4.7",
+ "nikic/php-parser": "^4.18 || ^5.0",
"php": ">=7.3"
},
"require-dev": {
@@ -2420,7 +2392,7 @@
"homepage": "https://github.com/sebastianbergmann/complexity",
"support": {
"issues": "https://github.com/sebastianbergmann/complexity/issues",
- "source": "https://github.com/sebastianbergmann/complexity/tree/2.0.2"
+ "source": "https://github.com/sebastianbergmann/complexity/tree/2.0.3"
},
"funding": [
{
@@ -2428,20 +2400,20 @@
"type": "github"
}
],
- "time": "2020-10-26T15:52:27+00:00"
+ "time": "2023-12-22T06:19:30+00:00"
},
{
"name": "sebastian/diff",
- "version": "4.0.5",
+ "version": "4.0.6",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/diff.git",
- "reference": "74be17022044ebaaecfdf0c5cd504fc9cd5a7131"
+ "reference": "ba01945089c3a293b01ba9badc29ad55b106b0bc"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/74be17022044ebaaecfdf0c5cd504fc9cd5a7131",
- "reference": "74be17022044ebaaecfdf0c5cd504fc9cd5a7131",
+ "url": "https://api.github.com/repos/sebastianbergmann/diff/zipball/ba01945089c3a293b01ba9badc29ad55b106b0bc",
+ "reference": "ba01945089c3a293b01ba9badc29ad55b106b0bc",
"shasum": ""
},
"require": {
@@ -2486,7 +2458,7 @@
],
"support": {
"issues": "https://github.com/sebastianbergmann/diff/issues",
- "source": "https://github.com/sebastianbergmann/diff/tree/4.0.5"
+ "source": "https://github.com/sebastianbergmann/diff/tree/4.0.6"
},
"funding": [
{
@@ -2494,7 +2466,7 @@
"type": "github"
}
],
- "time": "2023-05-07T05:35:17+00:00"
+ "time": "2024-03-02T06:30:58+00:00"
},
{
"name": "sebastian/environment",
@@ -2561,16 +2533,16 @@
},
{
"name": "sebastian/exporter",
- "version": "4.0.5",
+ "version": "4.0.6",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/exporter.git",
- "reference": "ac230ed27f0f98f597c8a2b6eb7ac563af5e5b9d"
+ "reference": "78c00df8f170e02473b682df15bfcdacc3d32d72"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/ac230ed27f0f98f597c8a2b6eb7ac563af5e5b9d",
- "reference": "ac230ed27f0f98f597c8a2b6eb7ac563af5e5b9d",
+ "url": "https://api.github.com/repos/sebastianbergmann/exporter/zipball/78c00df8f170e02473b682df15bfcdacc3d32d72",
+ "reference": "78c00df8f170e02473b682df15bfcdacc3d32d72",
"shasum": ""
},
"require": {
@@ -2626,7 +2598,7 @@
],
"support": {
"issues": "https://github.com/sebastianbergmann/exporter/issues",
- "source": "https://github.com/sebastianbergmann/exporter/tree/4.0.5"
+ "source": "https://github.com/sebastianbergmann/exporter/tree/4.0.6"
},
"funding": [
{
@@ -2634,20 +2606,20 @@
"type": "github"
}
],
- "time": "2022-09-14T06:03:37+00:00"
+ "time": "2024-03-02T06:33:00+00:00"
},
{
"name": "sebastian/global-state",
- "version": "5.0.5",
+ "version": "5.0.7",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/global-state.git",
- "reference": "0ca8db5a5fc9c8646244e629625ac486fa286bf2"
+ "reference": "bca7df1f32ee6fe93b4d4a9abbf69e13a4ada2c9"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/0ca8db5a5fc9c8646244e629625ac486fa286bf2",
- "reference": "0ca8db5a5fc9c8646244e629625ac486fa286bf2",
+ "url": "https://api.github.com/repos/sebastianbergmann/global-state/zipball/bca7df1f32ee6fe93b4d4a9abbf69e13a4ada2c9",
+ "reference": "bca7df1f32ee6fe93b4d4a9abbf69e13a4ada2c9",
"shasum": ""
},
"require": {
@@ -2690,7 +2662,7 @@
],
"support": {
"issues": "https://github.com/sebastianbergmann/global-state/issues",
- "source": "https://github.com/sebastianbergmann/global-state/tree/5.0.5"
+ "source": "https://github.com/sebastianbergmann/global-state/tree/5.0.7"
},
"funding": [
{
@@ -2698,24 +2670,24 @@
"type": "github"
}
],
- "time": "2022-02-14T08:28:10+00:00"
+ "time": "2024-03-02T06:35:11+00:00"
},
{
"name": "sebastian/lines-of-code",
- "version": "1.0.3",
+ "version": "1.0.4",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/lines-of-code.git",
- "reference": "c1c2e997aa3146983ed888ad08b15470a2e22ecc"
+ "reference": "e1e4a170560925c26d424b6a03aed157e7dcc5c5"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/lines-of-code/zipball/c1c2e997aa3146983ed888ad08b15470a2e22ecc",
- "reference": "c1c2e997aa3146983ed888ad08b15470a2e22ecc",
+ "url": "https://api.github.com/repos/sebastianbergmann/lines-of-code/zipball/e1e4a170560925c26d424b6a03aed157e7dcc5c5",
+ "reference": "e1e4a170560925c26d424b6a03aed157e7dcc5c5",
"shasum": ""
},
"require": {
- "nikic/php-parser": "^4.6",
+ "nikic/php-parser": "^4.18 || ^5.0",
"php": ">=7.3"
},
"require-dev": {
@@ -2747,7 +2719,7 @@
"homepage": "https://github.com/sebastianbergmann/lines-of-code",
"support": {
"issues": "https://github.com/sebastianbergmann/lines-of-code/issues",
- "source": "https://github.com/sebastianbergmann/lines-of-code/tree/1.0.3"
+ "source": "https://github.com/sebastianbergmann/lines-of-code/tree/1.0.4"
},
"funding": [
{
@@ -2755,7 +2727,7 @@
"type": "github"
}
],
- "time": "2020-11-28T06:42:11+00:00"
+ "time": "2023-12-22T06:20:34+00:00"
},
{
"name": "sebastian/object-enumerator",
@@ -2934,16 +2906,16 @@
},
{
"name": "sebastian/resource-operations",
- "version": "3.0.3",
+ "version": "3.0.4",
"source": {
"type": "git",
"url": "https://github.com/sebastianbergmann/resource-operations.git",
- "reference": "0f4443cb3a1d92ce809899753bc0d5d5a8dd19a8"
+ "reference": "05d5692a7993ecccd56a03e40cd7e5b09b1d404e"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/sebastianbergmann/resource-operations/zipball/0f4443cb3a1d92ce809899753bc0d5d5a8dd19a8",
- "reference": "0f4443cb3a1d92ce809899753bc0d5d5a8dd19a8",
+ "url": "https://api.github.com/repos/sebastianbergmann/resource-operations/zipball/05d5692a7993ecccd56a03e40cd7e5b09b1d404e",
+ "reference": "05d5692a7993ecccd56a03e40cd7e5b09b1d404e",
"shasum": ""
},
"require": {
@@ -2955,7 +2927,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-master": "3.0-dev"
+ "dev-main": "3.0-dev"
}
},
"autoload": {
@@ -2976,8 +2948,7 @@
"description": "Provides a list of PHP built-in functions that operate on resources",
"homepage": "https://www.github.com/sebastianbergmann/resource-operations",
"support": {
- "issues": "https://github.com/sebastianbergmann/resource-operations/issues",
- "source": "https://github.com/sebastianbergmann/resource-operations/tree/3.0.3"
+ "source": "https://github.com/sebastianbergmann/resource-operations/tree/3.0.4"
},
"funding": [
{
@@ -2985,7 +2956,7 @@
"type": "github"
}
],
- "time": "2020-09-28T06:45:17+00:00"
+ "time": "2024-03-14T16:00:52+00:00"
},
{
"name": "sebastian/type",
@@ -3098,35 +3069,34 @@
},
{
"name": "symfony/config",
- "version": "v5.4.21",
+ "version": "v6.0.19",
"source": {
"type": "git",
"url": "https://github.com/symfony/config.git",
- "reference": "2a6b1111d038adfa15d52c0871e540f3b352d1e4"
+ "reference": "db4fc45c24e0c3e2198e68ada9d7f90daa1f97e3"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/config/zipball/2a6b1111d038adfa15d52c0871e540f3b352d1e4",
- "reference": "2a6b1111d038adfa15d52c0871e540f3b352d1e4",
+ "url": "https://api.github.com/repos/symfony/config/zipball/db4fc45c24e0c3e2198e68ada9d7f90daa1f97e3",
+ "reference": "db4fc45c24e0c3e2198e68ada9d7f90daa1f97e3",
"shasum": ""
},
"require": {
- "php": ">=7.2.5",
+ "php": ">=8.0.2",
"symfony/deprecation-contracts": "^2.1|^3",
- "symfony/filesystem": "^4.4|^5.0|^6.0",
+ "symfony/filesystem": "^5.4|^6.0",
"symfony/polyfill-ctype": "~1.8",
- "symfony/polyfill-php80": "^1.16",
"symfony/polyfill-php81": "^1.22"
},
"conflict": {
"symfony/finder": "<4.4"
},
"require-dev": {
- "symfony/event-dispatcher": "^4.4|^5.0|^6.0",
- "symfony/finder": "^4.4|^5.0|^6.0",
- "symfony/messenger": "^4.4|^5.0|^6.0",
+ "symfony/event-dispatcher": "^5.4|^6.0",
+ "symfony/finder": "^5.4|^6.0",
+ "symfony/messenger": "^5.4|^6.0",
"symfony/service-contracts": "^1.1|^2|^3",
- "symfony/yaml": "^4.4|^5.0|^6.0"
+ "symfony/yaml": "^5.4|^6.0"
},
"suggest": {
"symfony/yaml": "To use the yaml reference dumper"
@@ -3157,7 +3127,7 @@
"description": "Helps you find, load, combine, autofill and validate configuration values of any kind",
"homepage": "https://symfony.com",
"support": {
- "source": "https://github.com/symfony/config/tree/v5.4.21"
+ "source": "https://github.com/symfony/config/tree/v6.0.19"
},
"funding": [
{
@@ -3173,50 +3143,46 @@
"type": "tidelift"
}
],
- "time": "2023-02-14T08:03:56+00:00"
+ "time": "2023-01-09T04:36:00+00:00"
},
{
"name": "symfony/console",
- "version": "v5.4.22",
+ "version": "v6.0.19",
"source": {
"type": "git",
"url": "https://github.com/symfony/console.git",
- "reference": "3cd51fd2e6c461ca678f84d419461281bd87a0a8"
+ "reference": "c3ebc83d031b71c39da318ca8b7a07ecc67507ed"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/console/zipball/3cd51fd2e6c461ca678f84d419461281bd87a0a8",
- "reference": "3cd51fd2e6c461ca678f84d419461281bd87a0a8",
+ "url": "https://api.github.com/repos/symfony/console/zipball/c3ebc83d031b71c39da318ca8b7a07ecc67507ed",
+ "reference": "c3ebc83d031b71c39da318ca8b7a07ecc67507ed",
"shasum": ""
},
"require": {
- "php": ">=7.2.5",
- "symfony/deprecation-contracts": "^2.1|^3",
+ "php": ">=8.0.2",
"symfony/polyfill-mbstring": "~1.0",
- "symfony/polyfill-php73": "^1.9",
- "symfony/polyfill-php80": "^1.16",
"symfony/service-contracts": "^1.1|^2|^3",
- "symfony/string": "^5.1|^6.0"
+ "symfony/string": "^5.4|^6.0"
},
"conflict": {
- "psr/log": ">=3",
- "symfony/dependency-injection": "<4.4",
- "symfony/dotenv": "<5.1",
- "symfony/event-dispatcher": "<4.4",
- "symfony/lock": "<4.4",
- "symfony/process": "<4.4"
+ "symfony/dependency-injection": "<5.4",
+ "symfony/dotenv": "<5.4",
+ "symfony/event-dispatcher": "<5.4",
+ "symfony/lock": "<5.4",
+ "symfony/process": "<5.4"
},
"provide": {
- "psr/log-implementation": "1.0|2.0"
+ "psr/log-implementation": "1.0|2.0|3.0"
},
"require-dev": {
- "psr/log": "^1|^2",
- "symfony/config": "^4.4|^5.0|^6.0",
- "symfony/dependency-injection": "^4.4|^5.0|^6.0",
- "symfony/event-dispatcher": "^4.4|^5.0|^6.0",
- "symfony/lock": "^4.4|^5.0|^6.0",
- "symfony/process": "^4.4|^5.0|^6.0",
- "symfony/var-dumper": "^4.4|^5.0|^6.0"
+ "psr/log": "^1|^2|^3",
+ "symfony/config": "^5.4|^6.0",
+ "symfony/dependency-injection": "^5.4|^6.0",
+ "symfony/event-dispatcher": "^5.4|^6.0",
+ "symfony/lock": "^5.4|^6.0",
+ "symfony/process": "^5.4|^6.0",
+ "symfony/var-dumper": "^5.4|^6.0"
},
"suggest": {
"psr/log": "For using the console logger",
@@ -3251,12 +3217,12 @@
"homepage": "https://symfony.com",
"keywords": [
"cli",
- "command-line",
+ "command line",
"console",
"terminal"
],
"support": {
- "source": "https://github.com/symfony/console/tree/v5.4.22"
+ "source": "https://github.com/symfony/console/tree/v6.0.19"
},
"funding": [
{
@@ -3272,45 +3238,44 @@
"type": "tidelift"
}
],
- "time": "2023-03-25T09:27:28+00:00"
+ "time": "2023-01-01T08:36:10+00:00"
},
{
"name": "symfony/dependency-injection",
- "version": "v5.4.22",
+ "version": "v6.0.20",
"source": {
"type": "git",
"url": "https://github.com/symfony/dependency-injection.git",
- "reference": "e1b7c1432efb4ad1dd89d62906187271e2601ed9"
+ "reference": "359806e1adebd1c43e18e5ea22acd14bef7fcf8c"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/dependency-injection/zipball/e1b7c1432efb4ad1dd89d62906187271e2601ed9",
- "reference": "e1b7c1432efb4ad1dd89d62906187271e2601ed9",
+ "url": "https://api.github.com/repos/symfony/dependency-injection/zipball/359806e1adebd1c43e18e5ea22acd14bef7fcf8c",
+ "reference": "359806e1adebd1c43e18e5ea22acd14bef7fcf8c",
"shasum": ""
},
"require": {
- "php": ">=7.2.5",
- "psr/container": "^1.1.1",
+ "php": ">=8.0.2",
+ "psr/container": "^1.1|^2.0",
"symfony/deprecation-contracts": "^2.1|^3",
- "symfony/polyfill-php80": "^1.16",
"symfony/polyfill-php81": "^1.22",
- "symfony/service-contracts": "^1.1.6|^2"
+ "symfony/service-contracts": "^1.1.6|^2.0|^3.0"
},
"conflict": {
"ext-psr": "<1.1|>=2",
- "symfony/config": "<5.3",
- "symfony/finder": "<4.4",
- "symfony/proxy-manager-bridge": "<4.4",
- "symfony/yaml": "<4.4.26"
+ "symfony/config": "<5.4",
+ "symfony/finder": "<5.4",
+ "symfony/proxy-manager-bridge": "<5.4",
+ "symfony/yaml": "<5.4"
},
"provide": {
- "psr/container-implementation": "1.0",
- "symfony/service-implementation": "1.0|2.0"
+ "psr/container-implementation": "1.1|2.0",
+ "symfony/service-implementation": "1.1|2.0|3.0"
},
"require-dev": {
- "symfony/config": "^5.3|^6.0",
- "symfony/expression-language": "^4.4|^5.0|^6.0",
- "symfony/yaml": "^4.4.26|^5.0|^6.0"
+ "symfony/config": "^5.4|^6.0",
+ "symfony/expression-language": "^5.4|^6.0",
+ "symfony/yaml": "^5.4|^6.0"
},
"suggest": {
"symfony/config": "",
@@ -3345,7 +3310,7 @@
"description": "Allows you to standardize and centralize the way objects are constructed in your application",
"homepage": "https://symfony.com",
"support": {
- "source": "https://github.com/symfony/dependency-injection/tree/v5.4.22"
+ "source": "https://github.com/symfony/dependency-injection/tree/v6.0.20"
},
"funding": [
{
@@ -3361,29 +3326,29 @@
"type": "tidelift"
}
],
- "time": "2023-03-10T10:02:45+00:00"
+ "time": "2023-01-30T15:41:07+00:00"
},
{
"name": "symfony/deprecation-contracts",
- "version": "v2.5.2",
+ "version": "v3.0.2",
"source": {
"type": "git",
"url": "https://github.com/symfony/deprecation-contracts.git",
- "reference": "e8b495ea28c1d97b5e0c121748d6f9b53d075c66"
+ "reference": "26954b3d62a6c5fd0ea8a2a00c0353a14978d05c"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/e8b495ea28c1d97b5e0c121748d6f9b53d075c66",
- "reference": "e8b495ea28c1d97b5e0c121748d6f9b53d075c66",
+ "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/26954b3d62a6c5fd0ea8a2a00c0353a14978d05c",
+ "reference": "26954b3d62a6c5fd0ea8a2a00c0353a14978d05c",
"shasum": ""
},
"require": {
- "php": ">=7.1"
+ "php": ">=8.0.2"
},
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "2.5-dev"
+ "dev-main": "3.0-dev"
},
"thanks": {
"name": "symfony/contracts",
@@ -3412,7 +3377,7 @@
"description": "A generic function and convention to trigger deprecation notices",
"homepage": "https://symfony.com",
"support": {
- "source": "https://github.com/symfony/deprecation-contracts/tree/v2.5.2"
+ "source": "https://github.com/symfony/deprecation-contracts/tree/v3.0.2"
},
"funding": [
{
@@ -3428,20 +3393,20 @@
"type": "tidelift"
}
],
- "time": "2022-01-02T09:53:40+00:00"
+ "time": "2022-01-02T09:55:41+00:00"
},
{
"name": "symfony/event-dispatcher",
- "version": "v5.4.22",
+ "version": "v5.4.34",
"source": {
"type": "git",
"url": "https://github.com/symfony/event-dispatcher.git",
- "reference": "1df20e45d56da29a4b1d8259dd6e950acbf1b13f"
+ "reference": "e3bca343efeb613f843c254e7718ef17c9bdf7a3"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/1df20e45d56da29a4b1d8259dd6e950acbf1b13f",
- "reference": "1df20e45d56da29a4b1d8259dd6e950acbf1b13f",
+ "url": "https://api.github.com/repos/symfony/event-dispatcher/zipball/e3bca343efeb613f843c254e7718ef17c9bdf7a3",
+ "reference": "e3bca343efeb613f843c254e7718ef17c9bdf7a3",
"shasum": ""
},
"require": {
@@ -3497,7 +3462,7 @@
"description": "Provides tools that allow your application components to communicate with each other by dispatching events and listening to them",
"homepage": "https://symfony.com",
"support": {
- "source": "https://github.com/symfony/event-dispatcher/tree/v5.4.22"
+ "source": "https://github.com/symfony/event-dispatcher/tree/v5.4.34"
},
"funding": [
{
@@ -3513,24 +3478,24 @@
"type": "tidelift"
}
],
- "time": "2023-03-17T11:31:58+00:00"
+ "time": "2023-12-27T21:12:56+00:00"
},
{
"name": "symfony/event-dispatcher-contracts",
- "version": "v2.5.2",
+ "version": "v3.0.2",
"source": {
"type": "git",
"url": "https://github.com/symfony/event-dispatcher-contracts.git",
- "reference": "f98b54df6ad059855739db6fcbc2d36995283fe1"
+ "reference": "7bc61cc2db649b4637d331240c5346dcc7708051"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/event-dispatcher-contracts/zipball/f98b54df6ad059855739db6fcbc2d36995283fe1",
- "reference": "f98b54df6ad059855739db6fcbc2d36995283fe1",
+ "url": "https://api.github.com/repos/symfony/event-dispatcher-contracts/zipball/7bc61cc2db649b4637d331240c5346dcc7708051",
+ "reference": "7bc61cc2db649b4637d331240c5346dcc7708051",
"shasum": ""
},
"require": {
- "php": ">=7.2.5",
+ "php": ">=8.0.2",
"psr/event-dispatcher": "^1"
},
"suggest": {
@@ -3539,7 +3504,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "2.5-dev"
+ "dev-main": "3.0-dev"
},
"thanks": {
"name": "symfony/contracts",
@@ -3576,7 +3541,7 @@
"standards"
],
"support": {
- "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v2.5.2"
+ "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v3.0.2"
},
"funding": [
{
@@ -3592,27 +3557,26 @@
"type": "tidelift"
}
],
- "time": "2022-01-02T09:53:40+00:00"
+ "time": "2022-01-02T09:55:41+00:00"
},
{
"name": "symfony/filesystem",
- "version": "v5.4.21",
+ "version": "v6.0.19",
"source": {
"type": "git",
"url": "https://github.com/symfony/filesystem.git",
- "reference": "e75960b1bbfd2b8c9e483e0d74811d555ca3de9f"
+ "reference": "3d49eec03fda1f0fc19b7349fbbe55ebc1004214"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/filesystem/zipball/e75960b1bbfd2b8c9e483e0d74811d555ca3de9f",
- "reference": "e75960b1bbfd2b8c9e483e0d74811d555ca3de9f",
+ "url": "https://api.github.com/repos/symfony/filesystem/zipball/3d49eec03fda1f0fc19b7349fbbe55ebc1004214",
+ "reference": "3d49eec03fda1f0fc19b7349fbbe55ebc1004214",
"shasum": ""
},
"require": {
- "php": ">=7.2.5",
+ "php": ">=8.0.2",
"symfony/polyfill-ctype": "~1.8",
- "symfony/polyfill-mbstring": "~1.8",
- "symfony/polyfill-php80": "^1.16"
+ "symfony/polyfill-mbstring": "~1.8"
},
"type": "library",
"autoload": {
@@ -3640,7 +3604,7 @@
"description": "Provides basic utilities for the filesystem",
"homepage": "https://symfony.com",
"support": {
- "source": "https://github.com/symfony/filesystem/tree/v5.4.21"
+ "source": "https://github.com/symfony/filesystem/tree/v6.0.19"
},
"funding": [
{
@@ -3656,20 +3620,20 @@
"type": "tidelift"
}
],
- "time": "2023-02-14T08:03:56+00:00"
+ "time": "2023-01-20T17:44:14+00:00"
},
{
"name": "symfony/polyfill-ctype",
- "version": "v1.27.0",
+ "version": "v1.28.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/polyfill-ctype.git",
- "reference": "5bbc823adecdae860bb64756d639ecfec17b050a"
+ "reference": "ea208ce43cbb04af6867b4fdddb1bdbf84cc28cb"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/5bbc823adecdae860bb64756d639ecfec17b050a",
- "reference": "5bbc823adecdae860bb64756d639ecfec17b050a",
+ "url": "https://api.github.com/repos/symfony/polyfill-ctype/zipball/ea208ce43cbb04af6867b4fdddb1bdbf84cc28cb",
+ "reference": "ea208ce43cbb04af6867b4fdddb1bdbf84cc28cb",
"shasum": ""
},
"require": {
@@ -3684,7 +3648,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "1.27-dev"
+ "dev-main": "1.28-dev"
},
"thanks": {
"name": "symfony/polyfill",
@@ -3722,7 +3686,7 @@
"portable"
],
"support": {
- "source": "https://github.com/symfony/polyfill-ctype/tree/v1.27.0"
+ "source": "https://github.com/symfony/polyfill-ctype/tree/v1.28.0"
},
"funding": [
{
@@ -3738,20 +3702,20 @@
"type": "tidelift"
}
],
- "time": "2022-11-03T14:55:06+00:00"
+ "time": "2023-01-26T09:26:14+00:00"
},
{
"name": "symfony/polyfill-intl-grapheme",
- "version": "v1.27.0",
+ "version": "v1.28.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/polyfill-intl-grapheme.git",
- "reference": "511a08c03c1960e08a883f4cffcacd219b758354"
+ "reference": "875e90aeea2777b6f135677f618529449334a612"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-intl-grapheme/zipball/511a08c03c1960e08a883f4cffcacd219b758354",
- "reference": "511a08c03c1960e08a883f4cffcacd219b758354",
+ "url": "https://api.github.com/repos/symfony/polyfill-intl-grapheme/zipball/875e90aeea2777b6f135677f618529449334a612",
+ "reference": "875e90aeea2777b6f135677f618529449334a612",
"shasum": ""
},
"require": {
@@ -3763,7 +3727,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "1.27-dev"
+ "dev-main": "1.28-dev"
},
"thanks": {
"name": "symfony/polyfill",
@@ -3803,7 +3767,7 @@
"shim"
],
"support": {
- "source": "https://github.com/symfony/polyfill-intl-grapheme/tree/v1.27.0"
+ "source": "https://github.com/symfony/polyfill-intl-grapheme/tree/v1.28.0"
},
"funding": [
{
@@ -3819,20 +3783,20 @@
"type": "tidelift"
}
],
- "time": "2022-11-03T14:55:06+00:00"
+ "time": "2023-01-26T09:26:14+00:00"
},
{
"name": "symfony/polyfill-intl-normalizer",
- "version": "v1.27.0",
+ "version": "v1.28.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/polyfill-intl-normalizer.git",
- "reference": "19bd1e4fcd5b91116f14d8533c57831ed00571b6"
+ "reference": "8c4ad05dd0120b6a53c1ca374dca2ad0a1c4ed92"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-intl-normalizer/zipball/19bd1e4fcd5b91116f14d8533c57831ed00571b6",
- "reference": "19bd1e4fcd5b91116f14d8533c57831ed00571b6",
+ "url": "https://api.github.com/repos/symfony/polyfill-intl-normalizer/zipball/8c4ad05dd0120b6a53c1ca374dca2ad0a1c4ed92",
+ "reference": "8c4ad05dd0120b6a53c1ca374dca2ad0a1c4ed92",
"shasum": ""
},
"require": {
@@ -3844,7 +3808,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "1.27-dev"
+ "dev-main": "1.28-dev"
},
"thanks": {
"name": "symfony/polyfill",
@@ -3887,7 +3851,7 @@
"shim"
],
"support": {
- "source": "https://github.com/symfony/polyfill-intl-normalizer/tree/v1.27.0"
+ "source": "https://github.com/symfony/polyfill-intl-normalizer/tree/v1.28.0"
},
"funding": [
{
@@ -3903,20 +3867,20 @@
"type": "tidelift"
}
],
- "time": "2022-11-03T14:55:06+00:00"
+ "time": "2023-01-26T09:26:14+00:00"
},
{
"name": "symfony/polyfill-mbstring",
- "version": "v1.27.0",
+ "version": "v1.28.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/polyfill-mbstring.git",
- "reference": "8ad114f6b39e2c98a8b0e3bd907732c207c2b534"
+ "reference": "42292d99c55abe617799667f454222c54c60e229"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/8ad114f6b39e2c98a8b0e3bd907732c207c2b534",
- "reference": "8ad114f6b39e2c98a8b0e3bd907732c207c2b534",
+ "url": "https://api.github.com/repos/symfony/polyfill-mbstring/zipball/42292d99c55abe617799667f454222c54c60e229",
+ "reference": "42292d99c55abe617799667f454222c54c60e229",
"shasum": ""
},
"require": {
@@ -3931,7 +3895,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "1.27-dev"
+ "dev-main": "1.28-dev"
},
"thanks": {
"name": "symfony/polyfill",
@@ -3970,86 +3934,7 @@
"shim"
],
"support": {
- "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.27.0"
- },
- "funding": [
- {
- "url": "https://symfony.com/sponsor",
- "type": "custom"
- },
- {
- "url": "https://github.com/fabpot",
- "type": "github"
- },
- {
- "url": "https://tidelift.com/funding/github/packagist/symfony/symfony",
- "type": "tidelift"
- }
- ],
- "time": "2022-11-03T14:55:06+00:00"
- },
- {
- "name": "symfony/polyfill-php73",
- "version": "v1.27.0",
- "source": {
- "type": "git",
- "url": "https://github.com/symfony/polyfill-php73.git",
- "reference": "9e8ecb5f92152187c4799efd3c96b78ccab18ff9"
- },
- "dist": {
- "type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-php73/zipball/9e8ecb5f92152187c4799efd3c96b78ccab18ff9",
- "reference": "9e8ecb5f92152187c4799efd3c96b78ccab18ff9",
- "shasum": ""
- },
- "require": {
- "php": ">=7.1"
- },
- "type": "library",
- "extra": {
- "branch-alias": {
- "dev-main": "1.27-dev"
- },
- "thanks": {
- "name": "symfony/polyfill",
- "url": "https://github.com/symfony/polyfill"
- }
- },
- "autoload": {
- "files": [
- "bootstrap.php"
- ],
- "psr-4": {
- "Symfony\\Polyfill\\Php73\\": ""
- },
- "classmap": [
- "Resources/stubs"
- ]
- },
- "notification-url": "https://packagist.org/downloads/",
- "license": [
- "MIT"
- ],
- "authors": [
- {
- "name": "Nicolas Grekas",
- "email": "p@tchwork.com"
- },
- {
- "name": "Symfony Community",
- "homepage": "https://symfony.com/contributors"
- }
- ],
- "description": "Symfony polyfill backporting some PHP 7.3+ features to lower PHP versions",
- "homepage": "https://symfony.com",
- "keywords": [
- "compatibility",
- "polyfill",
- "portable",
- "shim"
- ],
- "support": {
- "source": "https://github.com/symfony/polyfill-php73/tree/v1.27.0"
+ "source": "https://github.com/symfony/polyfill-mbstring/tree/v1.28.0"
},
"funding": [
{
@@ -4065,20 +3950,20 @@
"type": "tidelift"
}
],
- "time": "2022-11-03T14:55:06+00:00"
+ "time": "2023-07-28T09:04:16+00:00"
},
{
"name": "symfony/polyfill-php80",
- "version": "v1.27.0",
+ "version": "v1.28.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/polyfill-php80.git",
- "reference": "7a6ff3f1959bb01aefccb463a0f2cd3d3d2fd936"
+ "reference": "6caa57379c4aec19c0a12a38b59b26487dcfe4b5"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/7a6ff3f1959bb01aefccb463a0f2cd3d3d2fd936",
- "reference": "7a6ff3f1959bb01aefccb463a0f2cd3d3d2fd936",
+ "url": "https://api.github.com/repos/symfony/polyfill-php80/zipball/6caa57379c4aec19c0a12a38b59b26487dcfe4b5",
+ "reference": "6caa57379c4aec19c0a12a38b59b26487dcfe4b5",
"shasum": ""
},
"require": {
@@ -4087,7 +3972,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "1.27-dev"
+ "dev-main": "1.28-dev"
},
"thanks": {
"name": "symfony/polyfill",
@@ -4132,7 +4017,7 @@
"shim"
],
"support": {
- "source": "https://github.com/symfony/polyfill-php80/tree/v1.27.0"
+ "source": "https://github.com/symfony/polyfill-php80/tree/v1.28.0"
},
"funding": [
{
@@ -4148,20 +4033,20 @@
"type": "tidelift"
}
],
- "time": "2022-11-03T14:55:06+00:00"
+ "time": "2023-01-26T09:26:14+00:00"
},
{
"name": "symfony/polyfill-php81",
- "version": "v1.27.0",
+ "version": "v1.28.0",
"source": {
"type": "git",
"url": "https://github.com/symfony/polyfill-php81.git",
- "reference": "707403074c8ea6e2edaf8794b0157a0bfa52157a"
+ "reference": "7581cd600fa9fd681b797d00b02f068e2f13263b"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/polyfill-php81/zipball/707403074c8ea6e2edaf8794b0157a0bfa52157a",
- "reference": "707403074c8ea6e2edaf8794b0157a0bfa52157a",
+ "url": "https://api.github.com/repos/symfony/polyfill-php81/zipball/7581cd600fa9fd681b797d00b02f068e2f13263b",
+ "reference": "7581cd600fa9fd681b797d00b02f068e2f13263b",
"shasum": ""
},
"require": {
@@ -4170,7 +4055,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "1.27-dev"
+ "dev-main": "1.28-dev"
},
"thanks": {
"name": "symfony/polyfill",
@@ -4211,7 +4096,7 @@
"shim"
],
"support": {
- "source": "https://github.com/symfony/polyfill-php81/tree/v1.27.0"
+ "source": "https://github.com/symfony/polyfill-php81/tree/v1.28.0"
},
"funding": [
{
@@ -4227,26 +4112,25 @@
"type": "tidelift"
}
],
- "time": "2022-11-03T14:55:06+00:00"
+ "time": "2023-01-26T09:26:14+00:00"
},
{
"name": "symfony/service-contracts",
- "version": "v2.5.2",
+ "version": "v3.0.2",
"source": {
"type": "git",
"url": "https://github.com/symfony/service-contracts.git",
- "reference": "4b426aac47d6427cc1a1d0f7e2ac724627f5966c"
+ "reference": "d78d39c1599bd1188b8e26bb341da52c3c6d8a66"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/service-contracts/zipball/4b426aac47d6427cc1a1d0f7e2ac724627f5966c",
- "reference": "4b426aac47d6427cc1a1d0f7e2ac724627f5966c",
+ "url": "https://api.github.com/repos/symfony/service-contracts/zipball/d78d39c1599bd1188b8e26bb341da52c3c6d8a66",
+ "reference": "d78d39c1599bd1188b8e26bb341da52c3c6d8a66",
"shasum": ""
},
"require": {
- "php": ">=7.2.5",
- "psr/container": "^1.1",
- "symfony/deprecation-contracts": "^2.1|^3"
+ "php": ">=8.0.2",
+ "psr/container": "^2.0"
},
"conflict": {
"ext-psr": "<1.1|>=2"
@@ -4257,7 +4141,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "2.5-dev"
+ "dev-main": "3.0-dev"
},
"thanks": {
"name": "symfony/contracts",
@@ -4294,7 +4178,7 @@
"standards"
],
"support": {
- "source": "https://github.com/symfony/service-contracts/tree/v2.5.2"
+ "source": "https://github.com/symfony/service-contracts/tree/v3.0.2"
},
"funding": [
{
@@ -4310,38 +4194,37 @@
"type": "tidelift"
}
],
- "time": "2022-05-30T19:17:29+00:00"
+ "time": "2022-05-30T19:17:58+00:00"
},
{
"name": "symfony/string",
- "version": "v5.4.22",
+ "version": "v6.0.19",
"source": {
"type": "git",
"url": "https://github.com/symfony/string.git",
- "reference": "8036a4c76c0dd29e60b6a7cafcacc50cf088ea62"
+ "reference": "d9e72497367c23e08bf94176d2be45b00a9d232a"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/string/zipball/8036a4c76c0dd29e60b6a7cafcacc50cf088ea62",
- "reference": "8036a4c76c0dd29e60b6a7cafcacc50cf088ea62",
+ "url": "https://api.github.com/repos/symfony/string/zipball/d9e72497367c23e08bf94176d2be45b00a9d232a",
+ "reference": "d9e72497367c23e08bf94176d2be45b00a9d232a",
"shasum": ""
},
"require": {
- "php": ">=7.2.5",
+ "php": ">=8.0.2",
"symfony/polyfill-ctype": "~1.8",
"symfony/polyfill-intl-grapheme": "~1.0",
"symfony/polyfill-intl-normalizer": "~1.0",
- "symfony/polyfill-mbstring": "~1.0",
- "symfony/polyfill-php80": "~1.15"
+ "symfony/polyfill-mbstring": "~1.0"
},
"conflict": {
- "symfony/translation-contracts": ">=3.0"
+ "symfony/translation-contracts": "<2.0"
},
"require-dev": {
- "symfony/error-handler": "^4.4|^5.0|^6.0",
- "symfony/http-client": "^4.4|^5.0|^6.0",
- "symfony/translation-contracts": "^1.1|^2",
- "symfony/var-exporter": "^4.4|^5.0|^6.0"
+ "symfony/error-handler": "^5.4|^6.0",
+ "symfony/http-client": "^5.4|^6.0",
+ "symfony/translation-contracts": "^2.0|^3.0",
+ "symfony/var-exporter": "^5.4|^6.0"
},
"type": "library",
"autoload": {
@@ -4380,7 +4263,7 @@
"utf8"
],
"support": {
- "source": "https://github.com/symfony/string/tree/v5.4.22"
+ "source": "https://github.com/symfony/string/tree/v6.0.19"
},
"funding": [
{
@@ -4396,52 +4279,50 @@
"type": "tidelift"
}
],
- "time": "2023-03-14T06:11:53+00:00"
+ "time": "2023-01-01T08:36:10+00:00"
},
{
"name": "symfony/translation",
- "version": "v5.4.22",
+ "version": "v6.0.19",
"source": {
"type": "git",
"url": "https://github.com/symfony/translation.git",
- "reference": "9a401392f01bc385aa42760eff481d213a0cc2ba"
+ "reference": "9c24b3fdbbe9fb2ef3a6afd8bbaadfd72dad681f"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/translation/zipball/9a401392f01bc385aa42760eff481d213a0cc2ba",
- "reference": "9a401392f01bc385aa42760eff481d213a0cc2ba",
+ "url": "https://api.github.com/repos/symfony/translation/zipball/9c24b3fdbbe9fb2ef3a6afd8bbaadfd72dad681f",
+ "reference": "9c24b3fdbbe9fb2ef3a6afd8bbaadfd72dad681f",
"shasum": ""
},
"require": {
- "php": ">=7.2.5",
- "symfony/deprecation-contracts": "^2.1|^3",
+ "php": ">=8.0.2",
"symfony/polyfill-mbstring": "~1.0",
- "symfony/polyfill-php80": "^1.16",
- "symfony/translation-contracts": "^2.3"
+ "symfony/translation-contracts": "^2.3|^3.0"
},
"conflict": {
- "symfony/config": "<4.4",
- "symfony/console": "<5.3",
- "symfony/dependency-injection": "<5.0",
- "symfony/http-kernel": "<5.0",
- "symfony/twig-bundle": "<5.0",
- "symfony/yaml": "<4.4"
+ "symfony/config": "<5.4",
+ "symfony/console": "<5.4",
+ "symfony/dependency-injection": "<5.4",
+ "symfony/http-kernel": "<5.4",
+ "symfony/twig-bundle": "<5.4",
+ "symfony/yaml": "<5.4"
},
"provide": {
- "symfony/translation-implementation": "2.3"
+ "symfony/translation-implementation": "2.3|3.0"
},
"require-dev": {
"psr/log": "^1|^2|^3",
- "symfony/config": "^4.4|^5.0|^6.0",
+ "symfony/config": "^5.4|^6.0",
"symfony/console": "^5.4|^6.0",
- "symfony/dependency-injection": "^5.0|^6.0",
- "symfony/finder": "^4.4|^5.0|^6.0",
+ "symfony/dependency-injection": "^5.4|^6.0",
+ "symfony/finder": "^5.4|^6.0",
"symfony/http-client-contracts": "^1.1|^2.0|^3.0",
- "symfony/http-kernel": "^5.0|^6.0",
- "symfony/intl": "^4.4|^5.0|^6.0",
+ "symfony/http-kernel": "^5.4|^6.0",
+ "symfony/intl": "^5.4|^6.0",
"symfony/polyfill-intl-icu": "^1.21",
"symfony/service-contracts": "^1.1.2|^2|^3",
- "symfony/yaml": "^4.4|^5.0|^6.0"
+ "symfony/yaml": "^5.4|^6.0"
},
"suggest": {
"psr/log-implementation": "To use logging capability in translator",
@@ -4477,7 +4358,7 @@
"description": "Provides tools to internationalize your application",
"homepage": "https://symfony.com",
"support": {
- "source": "https://github.com/symfony/translation/tree/v5.4.22"
+ "source": "https://github.com/symfony/translation/tree/v6.0.19"
},
"funding": [
{
@@ -4493,24 +4374,24 @@
"type": "tidelift"
}
],
- "time": "2023-03-27T16:07:23+00:00"
+ "time": "2023-01-01T08:36:10+00:00"
},
{
"name": "symfony/translation-contracts",
- "version": "v2.5.2",
+ "version": "v3.0.2",
"source": {
"type": "git",
"url": "https://github.com/symfony/translation-contracts.git",
- "reference": "136b19dd05cdf0709db6537d058bcab6dd6e2dbe"
+ "reference": "acbfbb274e730e5a0236f619b6168d9dedb3e282"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/translation-contracts/zipball/136b19dd05cdf0709db6537d058bcab6dd6e2dbe",
- "reference": "136b19dd05cdf0709db6537d058bcab6dd6e2dbe",
+ "url": "https://api.github.com/repos/symfony/translation-contracts/zipball/acbfbb274e730e5a0236f619b6168d9dedb3e282",
+ "reference": "acbfbb274e730e5a0236f619b6168d9dedb3e282",
"shasum": ""
},
"require": {
- "php": ">=7.2.5"
+ "php": ">=8.0.2"
},
"suggest": {
"symfony/translation-implementation": ""
@@ -4518,7 +4399,7 @@
"type": "library",
"extra": {
"branch-alias": {
- "dev-main": "2.5-dev"
+ "dev-main": "3.0-dev"
},
"thanks": {
"name": "symfony/contracts",
@@ -4555,7 +4436,7 @@
"standards"
],
"support": {
- "source": "https://github.com/symfony/translation-contracts/tree/v2.5.2"
+ "source": "https://github.com/symfony/translation-contracts/tree/v3.0.2"
},
"funding": [
{
@@ -4571,32 +4452,31 @@
"type": "tidelift"
}
],
- "time": "2022-06-27T16:58:25+00:00"
+ "time": "2022-06-27T17:10:44+00:00"
},
{
"name": "symfony/yaml",
- "version": "v5.4.21",
+ "version": "v6.0.19",
"source": {
"type": "git",
"url": "https://github.com/symfony/yaml.git",
- "reference": "3713e20d93e46e681e51605d213027e48dab3469"
+ "reference": "deec3a812a0305a50db8ae689b183f43d915c884"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/symfony/yaml/zipball/3713e20d93e46e681e51605d213027e48dab3469",
- "reference": "3713e20d93e46e681e51605d213027e48dab3469",
+ "url": "https://api.github.com/repos/symfony/yaml/zipball/deec3a812a0305a50db8ae689b183f43d915c884",
+ "reference": "deec3a812a0305a50db8ae689b183f43d915c884",
"shasum": ""
},
"require": {
- "php": ">=7.2.5",
- "symfony/deprecation-contracts": "^2.1|^3",
+ "php": ">=8.0.2",
"symfony/polyfill-ctype": "^1.8"
},
"conflict": {
- "symfony/console": "<5.3"
+ "symfony/console": "<5.4"
},
"require-dev": {
- "symfony/console": "^5.3|^6.0"
+ "symfony/console": "^5.4|^6.0"
},
"suggest": {
"symfony/console": "For validating YAML files using the lint command"
@@ -4630,7 +4510,7 @@
"description": "Loads and dumps YAML files",
"homepage": "https://symfony.com",
"support": {
- "source": "https://github.com/symfony/yaml/tree/v5.4.21"
+ "source": "https://github.com/symfony/yaml/tree/v6.0.19"
},
"funding": [
{
@@ -4646,20 +4526,20 @@
"type": "tidelift"
}
],
- "time": "2023-02-21T19:46:44+00:00"
+ "time": "2023-01-11T11:50:03+00:00"
},
{
"name": "theseer/tokenizer",
- "version": "1.2.1",
+ "version": "1.2.3",
"source": {
"type": "git",
"url": "https://github.com/theseer/tokenizer.git",
- "reference": "34a41e998c2183e22995f158c581e7b5e755ab9e"
+ "reference": "737eda637ed5e28c3413cb1ebe8bb52cbf1ca7a2"
},
"dist": {
"type": "zip",
- "url": "https://api.github.com/repos/theseer/tokenizer/zipball/34a41e998c2183e22995f158c581e7b5e755ab9e",
- "reference": "34a41e998c2183e22995f158c581e7b5e755ab9e",
+ "url": "https://api.github.com/repos/theseer/tokenizer/zipball/737eda637ed5e28c3413cb1ebe8bb52cbf1ca7a2",
+ "reference": "737eda637ed5e28c3413cb1ebe8bb52cbf1ca7a2",
"shasum": ""
},
"require": {
@@ -4688,7 +4568,7 @@
"description": "A small library for converting tokenized PHP source code into XML and potentially other formats",
"support": {
"issues": "https://github.com/theseer/tokenizer/issues",
- "source": "https://github.com/theseer/tokenizer/tree/1.2.1"
+ "source": "https://github.com/theseer/tokenizer/tree/1.2.3"
},
"funding": [
{
@@ -4696,7 +4576,7 @@
"type": "github"
}
],
- "time": "2021-07-28T10:34:58+00:00"
+ "time": "2024-03-03T12:36:25+00:00"
}
],
"aliases": [],
@@ -4706,5 +4586,8 @@
"prefer-lowest": false,
"platform": [],
"platform-dev": [],
- "plugin-api-version": "2.3.0"
+ "platform-overrides": {
+ "php": "8.0.2"
+ },
+ "plugin-api-version": "2.6.0"
}
diff --git a/build/integration/config/behat.yml b/build/integration/config/behat.yml
index 0e577f5925e..8401b841cdd 100644
--- a/build/integration/config/behat.yml
+++ b/build/integration/config/behat.yml
@@ -1,6 +1,12 @@
default:
autoload:
'': "%paths.base%/../features/bootstrap"
+ formatters:
+ junit:
+ output_path: '%paths.base%/../output'
+ pretty:
+ output_styles:
+ comment: [ 'bright-blue' ]
suites:
default:
paths:
@@ -25,6 +31,52 @@ default:
- CommandLineContext:
baseUrl: http://localhost:8080
ocPath: ../../
+ comments:
+ paths:
+ - "%paths.base%/../comments_features"
+ contexts:
+ - FeatureContext:
+ baseUrl: http://localhost:8080/ocs/
+ admin:
+ - admin
+ - admin
+ regular_user_password: 123456
+ - CommentsContext:
+ baseUrl: http://localhost:8080
+ - TagsContext:
+ baseUrl: http://localhost:8080
+ - CardDavContext:
+ baseUrl: http://localhost:8080
+ - CalDavContext:
+ baseUrl: http://localhost:8080
+ - ChecksumsContext:
+ baseUrl: http://localhost:8080
+ - CommandLineContext:
+ baseUrl: http://localhost:8080
+ ocPath: ../../
+ dav:
+ paths:
+ - "%paths.base%/../dav_features"
+ contexts:
+ - FeatureContext:
+ baseUrl: http://localhost:8080/ocs/
+ admin:
+ - admin
+ - admin
+ regular_user_password: 123456
+ - CommentsContext:
+ baseUrl: http://localhost:8080
+ - TagsContext:
+ baseUrl: http://localhost:8080
+ - CardDavContext:
+ baseUrl: http://localhost:8080
+ - CalDavContext:
+ baseUrl: http://localhost:8080
+ - ChecksumsContext:
+ baseUrl: http://localhost:8080
+ - CommandLineContext:
+ baseUrl: http://localhost:8080
+ ocPath: ../../
federation:
paths:
- "%paths.base%/../federation_features"
@@ -35,6 +87,29 @@ default:
- admin
- admin
regular_user_password: 123456
+ files:
+ paths:
+ - "%paths.base%/../files_features"
+ contexts:
+ - FeatureContext:
+ baseUrl: http://localhost:8080/ocs/
+ admin:
+ - admin
+ - admin
+ regular_user_password: 123456
+ - CommentsContext:
+ baseUrl: http://localhost:8080
+ - TagsContext:
+ baseUrl: http://localhost:8080
+ - CardDavContext:
+ baseUrl: http://localhost:8080
+ - CalDavContext:
+ baseUrl: http://localhost:8080
+ - ChecksumsContext:
+ baseUrl: http://localhost:8080
+ - CommandLineContext:
+ baseUrl: http://localhost:8080
+ ocPath: ../../
capabilities:
paths:
- "%paths.base%/../capabilities_features"
@@ -76,6 +151,17 @@ default:
- admin
regular_user_password: 123456
- TalkContext
+ videoverification:
+ paths:
+ - "%paths.base%/../videoverification_features"
+ contexts:
+ - SharingContext:
+ baseUrl: http://localhost:8080/ocs/
+ admin:
+ - admin
+ - admin
+ regular_user_password: 123456
+ - TalkContext
setup:
paths:
- "%paths.base%/../setup_features"
@@ -106,6 +192,26 @@ default:
- admin
- admin
regular_user_password: 123456
+ openldap_numerical:
+ paths:
+ - "%paths.base%/../openldap_numerical_features"
+ contexts:
+ - LDAPContext:
+ baseUrl: http://localhost:8080
+ admin:
+ - admin
+ - admin
+ regular_user_password: 123456
+ openldap:
+ paths:
+ - "%paths.base%/../openldap_features"
+ contexts:
+ - LDAPContext:
+ baseUrl: http://localhost:8080
+ admin:
+ - admin
+ - admin
+ regular_user_password: 123456
remoteapi:
paths:
- "%paths.base%/../remoteapi_features"
@@ -118,7 +224,3 @@ default:
regular_user_password: 123456
- RemoteContext:
remote: http://localhost:8080
- extensions:
- jarnaiz\JUnitFormatter\JUnitFormatterExtension:
- filename: report.xml
- outputDir: "%paths.base%/../output/"
diff --git a/build/integration/features/caldav.feature b/build/integration/dav_features/caldav.feature
index e2cb4f8dc92..f7baf76d4bc 100644
--- a/build/integration/features/caldav.feature
+++ b/build/integration/dav_features/caldav.feature
@@ -13,7 +13,7 @@ Feature: caldav
When "user0" requests calendar "admin/MyCalendar" on the endpoint "/remote.php/dav/calendars/"
Then The CalDAV HTTP status code should be "404"
And The exception is "Sabre\DAV\Exception\NotFound"
- And The error message is "Node with name 'MyCalendar' could not be found"
+ And The error message is "Calendar with name 'MyCalendar' could not be found"
Scenario: Accessing a not shared calendar of another user via the legacy endpoint
Given user "user0" exists
@@ -22,7 +22,7 @@ Feature: caldav
When "user0" requests calendar "admin/MyCalendar" on the endpoint "/remote.php/caldav/calendars/"
Then The CalDAV HTTP status code should be "404"
And The exception is "Sabre\DAV\Exception\NotFound"
- And The error message is "Node with name 'MyCalendar' could not be found"
+ And The error message is "Calendar with name 'MyCalendar' could not be found"
Scenario: Accessing a not existing calendar of another user
Given user "user0" exists
@@ -75,3 +75,13 @@ Feature: caldav
Then The CalDAV HTTP status code should be "404"
And The exception is "Sabre\DAV\Exception\NotFound"
And The error message is "Node with name 'admin' could not be found"
+
+ Scenario: Update a principal's schedule-default-calendar-URL
+ Given user "user0" exists
+ And "user0" creates a calendar named "MyCalendar2"
+ When "user0" updates property "{urn:ietf:params:xml:ns:caldav}schedule-default-calendar-URL" to href "/remote.php/dav/calendars/user0/MyCalendar2/" of principal "users/user0" on the endpoint "/remote.php/dav/principals/"
+ Then The CalDAV response should be multi status
+ And The CalDAV response should contain a property "{urn:ietf:params:xml:ns:caldav}schedule-default-calendar-URL"
+ When "user0" requests principal "users/user0" on the endpoint "/remote.php/dav/principals/"
+ Then The CalDAV response should be multi status
+ And The CalDAV response should contain a property "{urn:ietf:params:xml:ns:caldav}schedule-default-calendar-URL" with a href value "/remote.php/dav/calendars/user0/MyCalendar2/"
diff --git a/build/integration/features/carddav.feature b/build/integration/dav_features/carddav.feature
index 9c9df6ddd94..9c9df6ddd94 100644
--- a/build/integration/features/carddav.feature
+++ b/build/integration/dav_features/carddav.feature
diff --git a/build/integration/features/dav-v2.feature b/build/integration/dav_features/dav-v2.feature
index 4dd79ec7b9e..a3ac59578e9 100644
--- a/build/integration/features/dav-v2.feature
+++ b/build/integration/dav_features/dav-v2.feature
@@ -81,8 +81,27 @@ Feature: dav-v2
When User "user0" uploads file "data/textfile.txt" to "/testquota/asdf.txt"
Then the HTTP status code should be "201"
- Scenario: Create a search query
+ Scenario: Create a search query on image
Given using new dav path
And As an "admin"
- When User "user0" uploads file "data/green-square-256.png" to "/image.png"
- When Image search should work
+ And user "user0" exists
+ And As an "user0"
+ When User "user0" uploads file "data/textfile.txt" to "/testquota/asdf.txt"
+ Then Image search should work
+ And the response should be empty
+ When User "user0" uploads file "data/green-square-256.png" to "/image.png"
+ Then Image search should work
+ And the single response should contain a property "{DAV:}getcontenttype" with value "image/png"
+
+ Scenario: Create a search query on favorite
+ Given using new dav path
+ And As an "admin"
+ And user "user0" exists
+ And As an "user0"
+ When User "user0" uploads file "data/green-square-256.png" to "/fav_image.png"
+ Then Favorite search should work
+ And the response should be empty
+ When user "user0" favorites element "/fav_image.png"
+ Then Favorite search should work
+ And the single response should contain a property "{http://owncloud.org/ns}favorite" with value "1"
+
diff --git a/build/integration/features/webdav-related.feature b/build/integration/dav_features/webdav-related.feature
index 28a0cad619b..28a0cad619b 100644
--- a/build/integration/features/webdav-related.feature
+++ b/build/integration/dav_features/webdav-related.feature
diff --git a/build/integration/features/bootstrap/AppConfiguration.php b/build/integration/features/bootstrap/AppConfiguration.php
index 740a8b169a6..5f39c58ffeb 100644
--- a/build/integration/features/bootstrap/AppConfiguration.php
+++ b/build/integration/features/bootstrap/AppConfiguration.php
@@ -1,29 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016 Joas Schilling <coding@schilljs.com>
- *
- * @author Arthur Schiwon <blizzz@arthur-schiwon.de>
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author Joas Schilling <coding@schilljs.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- * @author Sergio Bertolin <sbertolin@solidgear.es>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Hook\Scope\AfterScenarioScope;
use Behat\Behat\Hook\Scope\BeforeScenarioScope;
diff --git a/build/integration/features/bootstrap/Auth.php b/build/integration/features/bootstrap/Auth.php
index a0b02e2b64b..e620af4d530 100644
--- a/build/integration/features/bootstrap/Auth.php
+++ b/build/integration/features/bootstrap/Auth.php
@@ -1,34 +1,13 @@
<?php
/**
- * @copyright Copyright (c) 2016 Christoph Wurst <christoph@winzerhof-wurst.at>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Kesselberg <mail@danielkesselberg.de>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Phil Davis <phil.davis@inf.org>
- * @author Robin Appelman <robin@icewind.nl>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use GuzzleHttp\Client;
+use GuzzleHttp\Cookie\CookieJar;
use GuzzleHttp\Exception\ClientException;
use GuzzleHttp\Exception\ServerException;
-use GuzzleHttp\Cookie\CookieJar;
require __DIR__ . '/../../vendor/autoload.php';
diff --git a/build/integration/features/bootstrap/Avatar.php b/build/integration/features/bootstrap/Avatar.php
index 6b8e5d88092..f05d0372687 100644
--- a/build/integration/features/bootstrap/Avatar.php
+++ b/build/integration/features/bootstrap/Avatar.php
@@ -1,24 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2020, Daniel Calviño Sánchez (danxuliu@gmail.com)
- *
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Gherkin\Node\TableNode;
use PHPUnit\Framework\Assert;
diff --git a/build/integration/features/bootstrap/BasicStructure.php b/build/integration/features/bootstrap/BasicStructure.php
index e12a40ac6b4..6a1cc7e1ada 100644
--- a/build/integration/features/bootstrap/BasicStructure.php
+++ b/build/integration/features/bootstrap/BasicStructure.php
@@ -1,35 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016 Sergio Bertolin <sbertolin@solidgear.es>
- *
- * @author Arthur Schiwon <blizzz@arthur-schiwon.de>
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author Joas Schilling <coding@schilljs.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Morris Jobke <hey@morrisjobke.de>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Sergio Bertolin <sbertolin@solidgear.es>
- * @author Sergio Bertolín <sbertolin@solidgear.es>
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Gherkin\Node\TableNode;
use GuzzleHttp\Client;
diff --git a/build/integration/features/bootstrap/CalDavContext.php b/build/integration/features/bootstrap/CalDavContext.php
index 936463b579e..a9db5c89d4d 100644
--- a/build/integration/features/bootstrap/CalDavContext.php
+++ b/build/integration/features/bootstrap/CalDavContext.php
@@ -1,28 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- *
- * @author Arthur Schiwon <blizzz@arthur-schiwon.de>
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Phil Davis <phil.davis@inf.org>
- * @author Robin Appelman <robin@icewind.nl>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
require __DIR__ . '/../../vendor/autoload.php';
@@ -106,6 +86,119 @@ class CalDavContext implements \Behat\Behat\Context\Context {
}
/**
+ * @When :user requests principal :principal on the endpoint :endpoint
+ */
+ public function requestsPrincipal(string $user, string $principal, string $endpoint): void {
+ $davUrl = $this->baseUrl . $endpoint . $principal;
+
+ $password = ($user === 'admin') ? 'admin' : '123456';
+ try {
+ $this->response = $this->client->request(
+ 'PROPFIND',
+ $davUrl,
+ [
+ 'headers' => [
+ 'Content-Type' => 'application/xml; charset=UTF-8',
+ 'Depth' => 0,
+ ],
+ 'body' => '<x0:propfind xmlns:x0="DAV:"><x0:prop><x0:displayname/><x1:calendar-user-type xmlns:x1="urn:ietf:params:xml:ns:caldav"/><x1:calendar-user-address-set xmlns:x1="urn:ietf:params:xml:ns:caldav"/><x0:principal-URL/><x0:alternate-URI-set/><x2:email-address xmlns:x2="http://sabredav.org/ns"/><x3:language xmlns:x3="http://nextcloud.com/ns"/><x1:calendar-home-set xmlns:x1="urn:ietf:params:xml:ns:caldav"/><x1:schedule-inbox-URL xmlns:x1="urn:ietf:params:xml:ns:caldav"/><x1:schedule-outbox-URL xmlns:x1="urn:ietf:params:xml:ns:caldav"/><x1:schedule-default-calendar-URL xmlns:x1="urn:ietf:params:xml:ns:caldav"/><x3:resource-type xmlns:x3="http://nextcloud.com/ns"/><x3:resource-vehicle-type xmlns:x3="http://nextcloud.com/ns"/><x3:resource-vehicle-make xmlns:x3="http://nextcloud.com/ns"/><x3:resource-vehicle-model xmlns:x3="http://nextcloud.com/ns"/><x3:resource-vehicle-is-electric xmlns:x3="http://nextcloud.com/ns"/><x3:resource-vehicle-range xmlns:x3="http://nextcloud.com/ns"/><x3:resource-vehicle-seating-capacity xmlns:x3="http://nextcloud.com/ns"/><x3:resource-contact-person xmlns:x3="http://nextcloud.com/ns"/><x3:resource-contact-person-vcard xmlns:x3="http://nextcloud.com/ns"/><x3:room-type xmlns:x3="http://nextcloud.com/ns"/><x3:room-seating-capacity xmlns:x3="http://nextcloud.com/ns"/><x3:room-building-address xmlns:x3="http://nextcloud.com/ns"/><x3:room-building-story xmlns:x3="http://nextcloud.com/ns"/><x3:room-building-room-number xmlns:x3="http://nextcloud.com/ns"/><x3:room-features xmlns:x3="http://nextcloud.com/ns"/><x0:principal-collection-set/><x0:supported-report-set/></x0:prop></x0:propfind>',
+ 'auth' => [
+ $user,
+ $password,
+ ],
+ ]
+ );
+ } catch (\GuzzleHttp\Exception\ClientException $e) {
+ $this->response = $e->getResponse();
+ }
+ }
+
+ /**
+ * @Then The CalDAV response should contain a property :key
+ * @throws \Exception
+ */
+ public function theCaldavResponseShouldContainAProperty(string $key): void {
+ /** @var \Sabre\DAV\Xml\Response\MultiStatus $multiStatus */
+ $multiStatus = $this->responseXml['value'];
+ $responses = $multiStatus->getResponses()[0]->getResponseProperties();
+ if (!isset($responses[200])) {
+ throw new \Exception(
+ sprintf(
+ 'Expected code 200 got [%s]',
+ implode(',', array_keys($responses)),
+ )
+ );
+ }
+
+ $props = $responses[200];
+ if (!array_key_exists($key, $props)) {
+ throw new \Exception(
+ sprintf(
+ 'Expected property %s in %s',
+ $key,
+ json_encode($props, JSON_PRETTY_PRINT),
+ )
+ );
+ }
+ }
+
+ /**
+ * @Then The CalDAV response should contain a property :key with a href value :value
+ * @throws \Exception
+ */
+ public function theCaldavResponseShouldContainAPropertyWithHrefValue(
+ string $key,
+ string $value,
+ ): void {
+ /** @var \Sabre\DAV\Xml\Response\MultiStatus $multiStatus */
+ $multiStatus = $this->responseXml['value'];
+ $responses = $multiStatus->getResponses()[0]->getResponseProperties();
+ if (!isset($responses[200])) {
+ throw new \Exception(
+ sprintf(
+ 'Expected code 200 got [%s]',
+ implode(',', array_keys($responses)),
+ )
+ );
+ }
+
+ $props = $responses[200];
+ if (!array_key_exists($key, $props)) {
+ throw new \Exception("Cannot find property \"$key\"");
+ }
+
+ $actualValue = $props[$key]->getHref();
+ if ($actualValue !== $value) {
+ throw new \Exception("Property \"$key\" found with value \"$actualValue\", expected \"$value\"");
+ }
+ }
+
+ /**
+ * @Then The CalDAV response should be multi status
+ * @throws \Exception
+ */
+ public function theCaldavResponseShouldBeMultiStatus(): void {
+ if ($this->response->getStatusCode() !== 207) {
+ throw new \Exception(
+ sprintf(
+ 'Expected code 207 got %s',
+ $this->response->getStatusCode()
+ )
+ );
+ }
+
+ $body = $this->response->getBody()->getContents();
+ if ($body && substr($body, 0, 1) === '<') {
+ $reader = new Sabre\Xml\Reader();
+ $reader->xml($body);
+ $reader->elementMap['{DAV:}multistatus'] = \Sabre\DAV\Xml\Response\MultiStatus::class;
+ $reader->elementMap['{DAV:}response'] = \Sabre\DAV\Xml\Element\Response::class;
+ $reader->elementMap['{urn:ietf:params:xml:ns:caldav}schedule-default-calendar-URL'] = \Sabre\DAV\Xml\Property\Href::class;
+ $this->responseXml = $reader->parse();
+ }
+ }
+
+ /**
* @Then The CalDAV HTTP status code should be :code
* @param int $code
* @throws \Exception
@@ -258,4 +351,39 @@ class CalDavContext implements \Behat\Behat\Context\Context {
$this->response = $e->getResponse();
}
}
+
+ /**
+ * @Given :user updates property :key to href :value of principal :principal on the endpoint :endpoint
+ */
+ public function updatesHrefPropertyOfPrincipal(
+ string $user,
+ string $key,
+ string $value,
+ string $principal,
+ string $endpoint,
+ ): void {
+ $davUrl = $this->baseUrl . $endpoint . $principal;
+ $password = ($user === 'admin') ? 'admin' : '123456';
+
+ $propPatch = new \Sabre\DAV\Xml\Request\PropPatch();
+ $propPatch->properties = [$key => new \Sabre\DAV\Xml\Property\Href($value)];
+
+ $xml = new \Sabre\Xml\Service();
+ $body = $xml->write('{DAV:}propertyupdate', $propPatch, '/');
+
+ $this->response = $this->client->request(
+ 'PROPPATCH',
+ $davUrl,
+ [
+ 'headers' => [
+ 'Content-Type' => 'application/xml; charset=UTF-8',
+ ],
+ 'body' => $body,
+ 'auth' => [
+ $user,
+ $password,
+ ],
+ ]
+ );
+ }
}
diff --git a/build/integration/features/bootstrap/CapabilitiesContext.php b/build/integration/features/bootstrap/CapabilitiesContext.php
index 4fdfb3e41b0..79ede6ac8ba 100644
--- a/build/integration/features/bootstrap/CapabilitiesContext.php
+++ b/build/integration/features/bootstrap/CapabilitiesContext.php
@@ -1,30 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016 Sergio Bertolin <sbertolin@solidgear.es>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author Joas Schilling <coding@schilljs.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Sergio Bertolin <sbertolin@solidgear.es>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
use Behat\Behat\Context\SnippetAcceptingContext;
diff --git a/build/integration/features/bootstrap/CardDavContext.php b/build/integration/features/bootstrap/CardDavContext.php
index 80d96215eba..d5694ec619b 100644
--- a/build/integration/features/bootstrap/CardDavContext.php
+++ b/build/integration/features/bootstrap/CardDavContext.php
@@ -1,27 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Phil Davis <phil.davis@inf.org>
- * @author Robin Appelman <robin@icewind.nl>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
require __DIR__ . '/../../vendor/autoload.php';
diff --git a/build/integration/features/bootstrap/ChecksumsContext.php b/build/integration/features/bootstrap/ChecksumsContext.php
index ae44fcb1503..5661015e714 100644
--- a/build/integration/features/bootstrap/ChecksumsContext.php
+++ b/build/integration/features/bootstrap/ChecksumsContext.php
@@ -1,28 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016 Roeland Jago Douma <roeland@famdouma.nl>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Phil Davis <phil.davis@inf.org>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
require __DIR__ . '/../../vendor/autoload.php';
diff --git a/build/integration/features/bootstrap/CollaborationContext.php b/build/integration/features/bootstrap/CollaborationContext.php
index adfc357b0e1..854abe98b2f 100644
--- a/build/integration/features/bootstrap/CollaborationContext.php
+++ b/build/integration/features/bootstrap/CollaborationContext.php
@@ -3,25 +3,8 @@
declare(strict_types=1);
/**
- * @copyright Copyright (c) 2021, Joas Schilling <coding@schilljs.com>
- *
- * @author Joas Schilling <coding@schilljs.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2021 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
use Behat\Gherkin\Node\TableNode;
@@ -73,6 +56,9 @@ class CollaborationContext implements Context {
if (isset($expected['source'])) {
$data['source'] = $suggestion['source'];
}
+ if (isset($expected['status'])) {
+ $data['status'] = json_encode($suggestion['status']);
+ }
return $data;
}, $suggestions, $formData->getHash()));
}
diff --git a/build/integration/features/bootstrap/CommandLine.php b/build/integration/features/bootstrap/CommandLine.php
index cba254551e0..84b3dfd447f 100644
--- a/build/integration/features/bootstrap/CommandLine.php
+++ b/build/integration/features/bootstrap/CommandLine.php
@@ -1,27 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Vincent Petry <vincent@nextcloud.com>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
use PHPUnit\Framework\Assert;
diff --git a/build/integration/features/bootstrap/CommandLineContext.php b/build/integration/features/bootstrap/CommandLineContext.php
index afe17cd75a4..47a85885ce4 100644
--- a/build/integration/features/bootstrap/CommandLineContext.php
+++ b/build/integration/features/bootstrap/CommandLineContext.php
@@ -1,28 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Stefan Weil <sw@weilnetz.de>
- * @author Sujith H <sharidasan@owncloud.com>
- * @author Vincent Petry <vincent@nextcloud.com>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
require __DIR__ . '/../../vendor/autoload.php';
@@ -35,6 +15,8 @@ class CommandLineContext implements \Behat\Behat\Context\Context {
private $lastTransferPath;
private $featureContext;
+ private $localBaseUrl;
+ private $remoteBaseUrl;
public function __construct($ocPath, $baseUrl) {
$this->ocPath = rtrim($ocPath, '/') . '/';
@@ -69,7 +51,7 @@ class CommandLineContext implements \Behat\Behat\Context\Context {
foreach ($results as $path => $data) {
$path = rawurldecode($path);
$parts = explode(' ', $path);
- if (basename($parts[0]) !== 'transferred') {
+ if (basename($parts[0]) !== 'Transferred') {
continue;
}
if (isset($parts[2]) && $parts[2] === $sourceUser) {
diff --git a/build/integration/features/bootstrap/CommentsContext.php b/build/integration/features/bootstrap/CommentsContext.php
index ad2d752b4dd..8d7b0fe0c2f 100644
--- a/build/integration/features/bootstrap/CommentsContext.php
+++ b/build/integration/features/bootstrap/CommentsContext.php
@@ -1,28 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Julius Härtl <jus@bitgrid.net>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
require __DIR__ . '/../../vendor/autoload.php';
@@ -49,6 +29,37 @@ class CommentsContext implements \Behat\Behat\Context\Context {
}
}
+
+
+ /**
+ * get a named entry from response instead of picking a random entry from values
+ *
+ * @param string $path
+ *
+ * @return array|string
+ * @throws Exception
+ */
+ private function getValueFromNamedEntries(string $path, array $response): mixed {
+ $next = '';
+ if (str_contains($path, ' ')) {
+ [$key, $next] = explode(' ', $path, 2);
+ } else {
+ $key = $path;
+ }
+
+ foreach ($response as $entry) {
+ if ($entry['name'] === $key) {
+ if ($next !== '') {
+ return $this->getValueFromNamedEntries($next, $entry['value']);
+ } else {
+ return $entry['value'];
+ }
+ }
+ }
+
+ return null;
+ }
+
/** @AfterScenario */
public function teardownScenario() {
$client = new \GuzzleHttp\Client();
@@ -175,7 +186,7 @@ class CommentsContext implements \Behat\Behat\Context\Context {
if ($res->getStatusCode() === 207) {
$service = new Sabre\Xml\Service();
$this->response = $service->parse($res->getBody()->getContents());
- $this->commentId = (int) ($this->response[0]['value'][2]['value'][0]['value'][0]['value'] ?? 0);
+ $this->commentId = (int) ($this->getValueFromNamedEntries('{DAV:}response {DAV:}propstat {DAV:}prop {http://owncloud.org/ns}id', $this->response ?? []) ?? 0);
}
}
@@ -238,7 +249,8 @@ class CommentsContext implements \Behat\Behat\Context\Context {
* @throws \Exception
*/
public function theResponseShouldContainAPropertyWithValue($key, $value) {
- $keys = $this->response[0]['value'][2]['value'][0]['value'];
+ // $keys = $this->response[0]['value'][1]['value'][0]['value'];
+ $keys = $this->getValueFromNamedEntries('{DAV:}response {DAV:}propstat {DAV:}prop', $this->response);
$found = false;
foreach ($keys as $singleKey) {
if ($singleKey['name'] === '{http://owncloud.org/ns}' . substr($key, 3)) {
diff --git a/build/integration/features/bootstrap/ContactsMenu.php b/build/integration/features/bootstrap/ContactsMenu.php
index 0506d827a39..4fc3c03c5e9 100644
--- a/build/integration/features/bootstrap/ContactsMenu.php
+++ b/build/integration/features/bootstrap/ContactsMenu.php
@@ -1,24 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2021 Daniel Calviño Sánchez <danxuliu@gmail.com>
- *
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2021 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use PHPUnit\Framework\Assert;
diff --git a/build/integration/features/bootstrap/Download.php b/build/integration/features/bootstrap/Download.php
index e5e6dc64853..aa10830427a 100644
--- a/build/integration/features/bootstrap/Download.php
+++ b/build/integration/features/bootstrap/Download.php
@@ -1,25 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2018, Daniel Calviño Sánchez (danxuliu@gmail.com)
- *
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use PHPUnit\Framework\Assert;
diff --git a/build/integration/features/bootstrap/FakeSMTPHelper.php b/build/integration/features/bootstrap/FakeSMTPHelper.php
index 9d3b5979114..2d90494b82c 100644
--- a/build/integration/features/bootstrap/FakeSMTPHelper.php
+++ b/build/integration/features/bootstrap/FakeSMTPHelper.php
@@ -1,25 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2016 Daniel Calviño Sánchez <danxuliu@gmail.com>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
// Code below modified from https://github.com/axllent/fake-smtp/blob/f0856f8a0df6f4ca5a573cf31428c09ebc5b9ea3/fakeSMTP.php,
// which is under the MIT license (https://github.com/axllent/fake-smtp/blob/f0856f8a0df6f4ca5a573cf31428c09ebc5b9ea3/LICENSE)
diff --git a/build/integration/features/bootstrap/FeatureContext.php b/build/integration/features/bootstrap/FeatureContext.php
index a3a600d6625..638772da0b7 100644
--- a/build/integration/features/bootstrap/FeatureContext.php
+++ b/build/integration/features/bootstrap/FeatureContext.php
@@ -1,27 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016 Thomas Müller <thomas.mueller@tmit.eu>
- *
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Sergio Bertolin <sbertolin@solidgear.es>
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
use Behat\Behat\Context\SnippetAcceptingContext;
diff --git a/build/integration/features/bootstrap/FederationContext.php b/build/integration/features/bootstrap/FederationContext.php
index 423708adc10..03a03ef2fd6 100644
--- a/build/integration/features/bootstrap/FederationContext.php
+++ b/build/integration/features/bootstrap/FederationContext.php
@@ -1,30 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016 Sergio Bertolin <sbertolin@solidgear.es>
- *
- * @author Bjoern Schiessle <bjoern@schiessle.org>
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Sergio Bertolin <sbertolin@solidgear.es>
- * @author Sergio Bertolín <sbertolin@solidgear.es>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
use Behat\Behat\Context\SnippetAcceptingContext;
diff --git a/build/integration/features/bootstrap/FilesDropContext.php b/build/integration/features/bootstrap/FilesDropContext.php
index a5d4dad14e3..b611e55ea0f 100644
--- a/build/integration/features/bootstrap/FilesDropContext.php
+++ b/build/integration/features/bootstrap/FilesDropContext.php
@@ -1,27 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2016 Roeland Jago Douma <roeland@famdouma.nl>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Morris Jobke <hey@morrisjobke.de>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
use Behat\Behat\Context\SnippetAcceptingContext;
@@ -45,9 +25,8 @@ class FilesDropContext implements Context, SnippetAcceptingContext {
}
$base = substr($this->baseUrl, 0, -4);
- $fullUrl = $base . '/public.php/webdav' . $path;
+ $fullUrl = $base . "/public.php/dav/files/$token/$path";
- $options['auth'] = [$token, ''];
$options['headers'] = [
'X-REQUESTED-WITH' => 'XMLHttpRequest'
];
@@ -73,9 +52,8 @@ class FilesDropContext implements Context, SnippetAcceptingContext {
}
$base = substr($this->baseUrl, 0, -4);
- $fullUrl = $base . '/public.php/webdav/' . $folder;
+ $fullUrl = $base . "/public.php/dav/files/$token/$folder";
- $options['auth'] = [$token, ''];
$options['headers'] = [
'X-REQUESTED-WITH' => 'XMLHttpRequest'
];
diff --git a/build/integration/features/bootstrap/LDAPContext.php b/build/integration/features/bootstrap/LDAPContext.php
index e0315bce84e..f0181b36c71 100644
--- a/build/integration/features/bootstrap/LDAPContext.php
+++ b/build/integration/features/bootstrap/LDAPContext.php
@@ -1,27 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2017 Arthur Schiwon <blizzz@arthur-schiwon.de>
- *
- * @author Arthur Schiwon <blizzz@arthur-schiwon.de>
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- * @author Robin Appelman <robin@icewind.nl>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
use Behat\Gherkin\Node\TableNode;
@@ -104,7 +84,7 @@ class LDAPContext implements Context {
$this->asAn('admin');
$this->creatingAnLDAPConfigurationAt('/apps/user_ldap/api/v1/config');
$data = new TableNode([
- ['configData[ldapHost]', 'openldap'],
+ ['configData[ldapHost]', getenv('LDAP_HOST') ?: 'openldap'],
['configData[ldapPort]', '389'],
['configData[ldapBase]', 'dc=nextcloud,dc=ci'],
['configData[ldapAgentName]', 'cn=admin,dc=nextcloud,dc=ci'],
@@ -141,6 +121,9 @@ class LDAPContext implements Context {
$this->asAn('admin');
$configData = $table->getRows();
foreach ($configData as &$row) {
+ if (str_contains($row[0], 'Host') && getenv('LDAP_HOST')) {
+ $row[1] = str_replace('openldap', getenv('LDAP_HOST'), $row[1]);
+ }
$row[0] = 'configData[' . $row[0] . ']';
}
$this->settingTheLDAPConfigurationTo(new TableNode($configData));
diff --git a/build/integration/features/bootstrap/Mail.php b/build/integration/features/bootstrap/Mail.php
index c2d9e86275c..5e5a75fdc26 100644
--- a/build/integration/features/bootstrap/Mail.php
+++ b/build/integration/features/bootstrap/Mail.php
@@ -1,24 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2020, Daniel Calviño Sánchez (danxuliu@gmail.com)
- *
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
trait Mail {
// CommandLine trait is expected to be used in the class that uses this
diff --git a/build/integration/features/bootstrap/Provisioning.php b/build/integration/features/bootstrap/Provisioning.php
index 7fb4188f919..2fb1c807cc5 100644
--- a/build/integration/features/bootstrap/Provisioning.php
+++ b/build/integration/features/bootstrap/Provisioning.php
@@ -1,35 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016 Sergio Bertolin <sbertolin@solidgear.es>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author Joas Schilling <coding@schilljs.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- * @author Morris Jobke <hey@morrisjobke.de>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Sergio Bertolin <sbertolin@solidgear.es>
- * @author Sergio Bertolín <sbertolin@solidgear.es>
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- * @author Vincent Petry <vincent@nextcloud.com>
- * @author Jonas Meurer <jonas@freesources.org>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use GuzzleHttp\Client;
use GuzzleHttp\Message\ResponseInterface;
diff --git a/build/integration/features/bootstrap/RemoteContext.php b/build/integration/features/bootstrap/RemoteContext.php
index 1f5d837084f..b1605e4da25 100644
--- a/build/integration/features/bootstrap/RemoteContext.php
+++ b/build/integration/features/bootstrap/RemoteContext.php
@@ -1,26 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2017 Robin Appelman <robin@icewind.nl>
- *
- * @author Joas Schilling <coding@schilljs.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- * @author Robin Appelman <robin@icewind.nl>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
use OCP\Http\Client\IClientService;
diff --git a/build/integration/features/bootstrap/Search.php b/build/integration/features/bootstrap/Search.php
index c9d5f75a1d3..47259be769c 100644
--- a/build/integration/features/bootstrap/Search.php
+++ b/build/integration/features/bootstrap/Search.php
@@ -1,24 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2018, Daniel Calviño Sánchez (danxuliu@gmail.com)
- *
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Gherkin\Node\TableNode;
use PHPUnit\Framework\Assert;
diff --git a/build/integration/features/bootstrap/SetupContext.php b/build/integration/features/bootstrap/SetupContext.php
index 5abdb22ccfc..96cb00d8601 100644
--- a/build/integration/features/bootstrap/SetupContext.php
+++ b/build/integration/features/bootstrap/SetupContext.php
@@ -1,24 +1,7 @@
<?php
/**
- * @copyright Morris Jobke
- *
- * @author Morris Jobke <hey@morrisjobke.de>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
diff --git a/build/integration/features/bootstrap/ShareesContext.php b/build/integration/features/bootstrap/ShareesContext.php
index 70e78e24929..e152a749bfa 100644
--- a/build/integration/features/bootstrap/ShareesContext.php
+++ b/build/integration/features/bootstrap/ShareesContext.php
@@ -1,26 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016 Joas Schilling <coding@schilljs.com>
- *
- * @author Arthur Schiwon <blizzz@arthur-schiwon.de>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author Joas Schilling <coding@schilljs.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
use Behat\Behat\Context\SnippetAcceptingContext;
diff --git a/build/integration/features/bootstrap/Sharing.php b/build/integration/features/bootstrap/Sharing.php
index 2a6a509d65f..c0affcb9cda 100644
--- a/build/integration/features/bootstrap/Sharing.php
+++ b/build/integration/features/bootstrap/Sharing.php
@@ -1,35 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016 Sergio Bertolin <sbertolin@solidgear.es>
- *
- * @author Arthur Schiwon <blizzz@arthur-schiwon.de>
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author Joas Schilling <coding@schilljs.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- * @author Julius Härtl <jus@bitgrid.net>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Sergio Bertolin <sbertolin@solidgear.es>
- * @author Sergio Bertolín <sbertolin@solidgear.es>
- * @author Vincent Petry <vincent@nextcloud.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Gherkin\Node\TableNode;
use GuzzleHttp\Client;
@@ -81,7 +54,9 @@ trait Sharing {
$fd = $body->getRowsHash();
if (array_key_exists('expireDate', $fd)) {
$dateModification = $fd['expireDate'];
- $fd['expireDate'] = date('Y-m-d', strtotime($dateModification));
+ if (!empty($dateModification)) {
+ $fd['expireDate'] = date('Y-m-d', strtotime($dateModification));
+ }
}
$options['form_params'] = $fd;
}
@@ -187,8 +162,8 @@ trait Sharing {
$token = $this->lastShareData->data->token;
}
- $fullUrl = substr($this->baseUrl, 0, -4) . "public.php/webdav";
- $this->checkDownload($fullUrl, [$token, $password], 'text/plain');
+ $fullUrl = substr($this->baseUrl, 0, -4) . "public.php/dav/files/$token/";
+ $this->checkDownload($fullUrl, ['', $password], 'text/plain');
}
private function checkDownload($url, $auth = null, $mimeType = null) {
@@ -270,13 +245,13 @@ trait Sharing {
}
public function createShare($user,
- $path = null,
- $shareType = null,
- $shareWith = null,
- $publicUpload = null,
- $password = null,
- $permissions = null,
- $viewOnly = false) {
+ $path = null,
+ $shareType = null,
+ $shareWith = null,
+ $publicUpload = null,
+ $password = null,
+ $permissions = null,
+ $viewOnly = false) {
$fullUrl = $this->baseUrl . "v{$this->apiVersion}.php/apps/files_sharing/api/v{$this->sharingApiVersion}/shares";
$client = new Client();
$options = [
@@ -328,7 +303,9 @@ trait Sharing {
public function isFieldInResponse($field, $contentExpected) {
$data = simplexml_load_string($this->response->getBody())->data[0];
if ((string)$field == 'expiration') {
- $contentExpected = date('Y-m-d', strtotime($contentExpected)) . " 00:00:00";
+ if(!empty($contentExpected)) {
+ $contentExpected = date('Y-m-d', strtotime($contentExpected)) . " 00:00:00";
+ }
}
if (count($data->element) > 0) {
foreach ($data as $element) {
@@ -353,7 +330,7 @@ trait Sharing {
return is_numeric((string)$data->$field);
} elseif ($contentExpected == "AN_URL") {
return $this->isExpectedUrl((string)$data->$field, "index.php/s/");
- } elseif ($data->$field == $contentExpected) {
+ } elseif ($contentExpected == $data->$field) {
return true;
}
return false;
diff --git a/build/integration/features/bootstrap/SharingContext.php b/build/integration/features/bootstrap/SharingContext.php
index f187e89f08f..97c2a35ad84 100644
--- a/build/integration/features/bootstrap/SharingContext.php
+++ b/build/integration/features/bootstrap/SharingContext.php
@@ -1,26 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2016 John Molakvoæ <skjnldsv@protonmail.com>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
use Behat\Behat\Context\SnippetAcceptingContext;
diff --git a/build/integration/features/bootstrap/TagsContext.php b/build/integration/features/bootstrap/TagsContext.php
index ecef9c08b1e..3a2c0e41744 100644
--- a/build/integration/features/bootstrap/TagsContext.php
+++ b/build/integration/features/bootstrap/TagsContext.php
@@ -1,30 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Joas Schilling <coding@schilljs.com>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Phil Davis <phil.davis@inf.org>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Sergio Bertolin <sbertolin@solidgear.es>
- * @author Vincent Petry <vincent@nextcloud.com>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
require __DIR__ . '/../../vendor/autoload.php';
diff --git a/build/integration/features/bootstrap/TalkContext.php b/build/integration/features/bootstrap/TalkContext.php
index 5417c22a058..fe248e1af7c 100644
--- a/build/integration/features/bootstrap/TalkContext.php
+++ b/build/integration/features/bootstrap/TalkContext.php
@@ -1,24 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2020, Daniel Calviño Sánchez (danxuliu@gmail.com)
- *
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
use Behat\Behat\Context\Context;
diff --git a/build/integration/features/bootstrap/Trashbin.php b/build/integration/features/bootstrap/Trashbin.php
index 19e9b57c3fb..1b1be71bace 100644
--- a/build/integration/features/bootstrap/Trashbin.php
+++ b/build/integration/features/bootstrap/Trashbin.php
@@ -1,26 +1,8 @@
<?php
/**
- * @copyright Copyright (c) 2017, ownCloud GmbH.
- *
- * @author Daniel Calviño Sánchez <danxuliu@gmail.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Vincent Petry <vincent@nextcloud.com>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2017 ownCloud GmbH
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
use DMS\PHPUnitExtensions\ArraySubset\Assert as AssertArraySubset;
use PHPUnit\Framework\Assert;
diff --git a/build/integration/features/bootstrap/WebDav.php b/build/integration/features/bootstrap/WebDav.php
index 9c81a5817b4..c2de207284d 100644
--- a/build/integration/features/bootstrap/WebDav.php
+++ b/build/integration/features/bootstrap/WebDav.php
@@ -1,39 +1,13 @@
<?php
/**
- * @copyright Copyright (c) 2016 Sergio Bertolin <sbertolin@solidgear.es>
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author David Toledo <dtoledo@solidgear.es>
- * @author Joas Schilling <coding@schilljs.com>
- * @author John Molakvoæ <skjnldsv@protonmail.com>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Morris Jobke <hey@morrisjobke.de>
- * @author Robin Appelman <robin@icewind.nl>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Sergio Bertolin <sbertolin@solidgear.es>
- * @author Sergio Bertolín <sbertolin@solidgear.es>
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- * @author Vincent Petry <vincent@nextcloud.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
+
use GuzzleHttp\Client as GClient;
-use GuzzleHttp\Message\ResponseInterface;
use PHPUnit\Framework\Assert;
+use Psr\Http\Message\ResponseInterface;
use Sabre\DAV\Client as SClient;
use Sabre\DAV\Xml\Property\ResourceType;
@@ -43,19 +17,17 @@ require __DIR__ . '/../../vendor/autoload.php';
trait WebDav {
use Sharing;
- /** @var string */
- private $davPath = "remote.php/webdav";
- /** @var boolean */
- private $usingOldDavPath = true;
+ private string $davPath = "remote.php/webdav";
+ private bool $usingOldDavPath = true;
+ private ?array $storedETAG = null; // map with user as key and another map as value, which has path as key and etag as value
+ private ?int $storedFileID = null;
/** @var ResponseInterface */
private $response;
- /** @var array map with user as key and another map as value, which has path as key and etag as value */
- private $storedETAG = null;
- /** @var int */
- private $storedFileID = null;
-
+ private array $parsedResponse = [];
private string $s3MultipartDestination;
private string $uploadId;
+ /** @var string[] */
+ private array $parts = [];
/**
* @Given /^using dav path "([^"]*)"$/
@@ -171,11 +143,10 @@ trait WebDav {
*/
public function downloadPublicFileWithRange($range) {
$token = $this->lastShareData->data->token;
- $fullUrl = substr($this->baseUrl, 0, -4) . "public.php/webdav";
+ $fullUrl = substr($this->baseUrl, 0, -4) . "public.php/dav/files/$token";
$client = new GClient();
$options = [];
- $options['auth'] = [$token, ""];
$options['headers'] = [
'Range' => $range
];
@@ -189,7 +160,7 @@ trait WebDav {
*/
public function downloadPublicFileInsideAFolderWithRange($path, $range) {
$token = $this->lastShareData->data->token;
- $fullUrl = substr($this->baseUrl, 0, -4) . "public.php/webdav" . "$path";
+ $fullUrl = substr($this->baseUrl, 0, -4) . "public.php/dav/files/$token/$path";
$client = new GClient();
$options = [
@@ -197,7 +168,6 @@ trait WebDav {
'Range' => $range
]
];
- $options['auth'] = [$token, ""];
$this->response = $client->request("GET", $fullUrl, $options);
}
@@ -232,6 +202,24 @@ trait WebDav {
}
/**
+ * @Then /^Favorite search should work$/
+ */
+ public function searchFavorite(): void {
+ $this->searchFile(
+ $this->currentUser,
+ '<oc:favorite/>',
+ null,
+ '<d:eq>
+ <d:prop>
+ <oc:favorite/>
+ </d:prop>
+ <d:literal>yes</d:literal>
+ </d:eq>'
+ );
+ Assert::assertEquals(207, $this->response->getStatusCode());
+ }
+
+ /**
* @Then /^Downloaded content when downloading file "([^"]*)" with range "([^"]*)" should be "([^"]*)"$/
* @param string $fileSource
* @param string $range
@@ -316,18 +304,31 @@ trait WebDav {
}
/**
+ * @Then the response should be empty
+ * @throws \Exception
+ */
+ public function theResponseShouldBeEmpty(): void {
+ $response = ($this->response instanceof ResponseInterface) ? $this->convertResponseToDavEntries() : $this->response;
+ if ($response === []) {
+ return;
+ }
+
+ throw new \Exception('response is not empty');
+ }
+
+ /**
* @Then the single response should contain a property :key with value :value
* @param string $key
* @param string $expectedValue
* @throws \Exception
*/
public function theSingleResponseShouldContainAPropertyWithValue($key, $expectedValue) {
- $keys = $this->response;
- if (!array_key_exists($key, $keys)) {
+ $response = ($this->response instanceof ResponseInterface) ? $this->convertResponseToDavSingleEntry() : $this->response;
+ if (!array_key_exists($key, $response)) {
throw new \Exception("Cannot find property \"$key\" with \"$expectedValue\"");
}
- $value = $keys[$key];
+ $value = $response[$key];
if ($value instanceof ResourceType) {
$value = $value->getValue();
if (empty($value)) {
@@ -448,28 +449,28 @@ trait WebDav {
</d:prop>
<d:literal>image/png</d:literal>
</d:eq>
-
+
<d:eq>
<d:prop>
<d:getcontenttype/>
</d:prop>
<d:literal>image/jpeg</d:literal>
</d:eq>
-
+
<d:eq>
<d:prop>
<d:getcontenttype/>
</d:prop>
<d:literal>image/heic</d:literal>
</d:eq>
-
+
<d:eq>
<d:prop>
<d:getcontenttype/>
</d:prop>
<d:literal>video/mp4</d:literal>
</d:eq>
-
+
<d:eq>
<d:prop>
<d:getcontenttype/>
@@ -515,6 +516,7 @@ trait WebDav {
$this->response = $this->makeDavRequest($user, "SEARCH", '', [
'Content-Type' => 'text/xml'
], $body, '');
+
var_dump((string)$this->response->getBody());
} catch (\GuzzleHttp\Exception\ServerException $e) {
// 5xx responses cause a server exception
@@ -1094,4 +1096,32 @@ trait WebDav {
$this->theHTTPStatusCodeShouldBe(500);
}
}
+
+ /**
+ * @return array
+ * @throws Exception
+ */
+ private function convertResponseToDavSingleEntry(): array {
+ $results = $this->convertResponseToDavEntries();
+ if (count($results) > 1) {
+ throw new \Exception('result is empty or contain more than one (1) entry');
+ }
+
+ return array_shift($results);
+ }
+
+ /**
+ * @return array
+ */
+ private function convertResponseToDavEntries(): array {
+ $client = $this->getSabreClient($this->currentUser);
+ $parsedResponse = $client->parseMultiStatus((string)$this->response->getBody());
+
+ $results = [];
+ foreach ($parsedResponse as $href => $statusList) {
+ $results[$href] = $statusList[200] ?? [];
+ }
+
+ return $results;
+ }
}
diff --git a/build/integration/features/maintenance-mode.feature b/build/integration/features/maintenance-mode.feature
index 56d3b9c0fb6..e6637a5edff 100644
--- a/build/integration/features/maintenance-mode.feature
+++ b/build/integration/features/maintenance-mode.feature
@@ -39,3 +39,9 @@ Feature: maintenance-mode
Then the HTTP status code should be "503"
Then Maintenance mode is disabled
And the command was successful
+
+ Scenario: Accessing /public.php/dav with maintenance mode enabled
+ When requesting "/public.php/dav" with "GET"
+ Then the HTTP status code should be "503"
+ Then Maintenance mode is disabled
+ And the command was successful
diff --git a/build/integration/features/ratelimiting.feature b/build/integration/features/ratelimiting.feature
index bd8b2e30a73..8f23c073e69 100644
--- a/build/integration/features/ratelimiting.feature
+++ b/build/integration/features/ratelimiting.feature
@@ -1,9 +1,9 @@
Feature: ratelimiting
-
+
Background:
Given user "user0" exists
Given As an "admin"
- Given app "testing" is enabled
+ Given invoking occ with "app:enable --force testing"
Scenario: Accessing a page with only an AnonRateThrottle as user
Given user "user0" exists
diff --git a/build/integration/features/checksums.feature b/build/integration/files_features/checksums.feature
index d391e93afe8..d391e93afe8 100644
--- a/build/integration/features/checksums.feature
+++ b/build/integration/files_features/checksums.feature
diff --git a/build/integration/features/download.feature b/build/integration/files_features/download.feature
index 16d346b0150..16d346b0150 100644
--- a/build/integration/features/download.feature
+++ b/build/integration/files_features/download.feature
diff --git a/build/integration/features/external-storage.feature b/build/integration/files_features/external-storage.feature
index d92cca3c458..d92cca3c458 100644
--- a/build/integration/features/external-storage.feature
+++ b/build/integration/files_features/external-storage.feature
diff --git a/build/integration/features/favorites.feature b/build/integration/files_features/favorites.feature
index 0439ada9d60..0439ada9d60 100644
--- a/build/integration/features/favorites.feature
+++ b/build/integration/files_features/favorites.feature
diff --git a/build/integration/features/tags.feature b/build/integration/files_features/tags.feature
index 495008ffdd2..495008ffdd2 100644
--- a/build/integration/features/tags.feature
+++ b/build/integration/files_features/tags.feature
diff --git a/build/integration/features/transfer-ownership.feature b/build/integration/files_features/transfer-ownership.feature
index 22e34dcf7af..44860c195b9 100644
--- a/build/integration/features/transfer-ownership.feature
+++ b/build/integration/files_features/transfer-ownership.feature
@@ -39,7 +39,7 @@ Feature: transfer-ownership
And As an "user1"
And using received transfer folder of "user1" as dav path
Then Downloaded content when downloading file "/test/somefile.txt" with range "bytes=0-6" should be "This is"
- And transfer folder name contains "transferred from user0 -risky- ヂspḷay -na|-|e- on"
+ And transfer folder name contains "Transferred from user0 -risky- ヂspḷay -na|-|e- on"
And using old dav path
And as "user0" the folder "/test" does not exist
And using received transfer folder of "user1" as dav path
@@ -345,7 +345,7 @@ Feature: transfer-ownership
And As an "user1"
And using received transfer folder of "user1" as dav path
Then Downloaded content when downloading file "/test/somefile.txt" with range "bytes=0-6" should be "This is"
- And transfer folder name contains "transferred from user0 -risky- ヂspḷay -na|-|e- on"
+ And transfer folder name contains "Transferred from user0 -risky- ヂspḷay -na|-|e- on"
And using old dav path
And as "user0" the folder "/test" does not exist
And using received transfer folder of "user1" as dav path
diff --git a/build/integration/features/trashbin.feature b/build/integration/files_features/trashbin.feature
index 3a9c29f7cb8..3a9c29f7cb8 100644
--- a/build/integration/features/trashbin.feature
+++ b/build/integration/files_features/trashbin.feature
diff --git a/build/integration/ldap_features/openldap-uid-username.feature b/build/integration/openldap_features/openldap-uid-username.feature
index 6793273e8c7..6793273e8c7 100644
--- a/build/integration/ldap_features/openldap-uid-username.feature
+++ b/build/integration/openldap_features/openldap-uid-username.feature
diff --git a/build/integration/ldap_features/openldap-numerical-id.feature b/build/integration/openldap_numerical_features/openldap-numerical-id.feature
index 4ea63823295..75eb6827192 100644
--- a/build/integration/ldap_features/openldap-numerical-id.feature
+++ b/build/integration/openldap_numerical_features/openldap-numerical-id.feature
@@ -66,3 +66,31 @@ Scenario: Test LDAP group membership with intermediate groups not matching filte
| 50194 | 1 |
| 59376 | 1 |
| 59463 | 1 |
+
+Scenario: Test LDAP admin group mapping, empowered user
+ Given modify LDAP configuration
+ | ldapBaseGroups | ou=NumericGroups,dc=nextcloud,dc=ci |
+ | ldapGroupFilter | (objectclass=groupOfNames) |
+ | ldapGroupMemberAssocAttr | member |
+ | ldapAdminGroup | 3001 |
+ | useMemberOfToDetectMembership | 1 |
+ And cookies are reset
+ # alice, part of the promoted group
+ And Logging in using web as "92379"
+ And sending "GET" to "/cloud/groups"
+ And sending "GET" to "/cloud/groups/2000/users"
+ And Sending a "GET" to "/index.php/settings/admin/overview" with requesttoken
+ Then the HTTP status code should be "200"
+
+Scenario: Test LDAP admin group mapping, regular user (no access)
+ Given modify LDAP configuration
+ | ldapBaseGroups | ou=NumericGroups,dc=nextcloud,dc=ci |
+ | ldapGroupFilter | (objectclass=groupOfNames) |
+ | ldapGroupMemberAssocAttr | member |
+ | ldapAdminGroup | 3001 |
+ | useMemberOfToDetectMembership | 1 |
+ And cookies are reset
+ # gustaf, not part of the promoted group
+ And Logging in using web as "59376"
+ And Sending a "GET" to "/index.php/settings/admin/overview" with requesttoken
+ Then the HTTP status code should be "403"
diff --git a/build/integration/run-docker.sh b/build/integration/run-docker.sh
index 080a992eefd..f49fd3ea650 100755
--- a/build/integration/run-docker.sh
+++ b/build/integration/run-docker.sh
@@ -1,22 +1,7 @@
#!/usr/bin/env bash
-# @copyright Copyright (c) 2017, Daniel Calviño Sánchez (danxuliu@gmail.com)
-# @copyright Copyright (c) 2018, Daniel Calviño Sánchez (danxuliu@gmail.com)
-#
-# @license GNU AGPL version 3 or any later version
-#
-# This program is free software: you can redistribute it and/or modify
-# it under the terms of the GNU Affero General Public License as
-# published by the Free Software Foundation, either version 3 of the
-# License, or (at your option) any later version.
-#
-# This program 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 Affero General Public License for more details.
-#
-# You should have received a copy of the GNU Affero General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
+# SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
# Helper script to run the integration tests on a fresh Nextcloud server through
# Docker.
diff --git a/build/integration/run.sh b/build/integration/run.sh
index 45a0333038e..cef59c976af 100755
--- a/build/integration/run.sh
+++ b/build/integration/run.sh
@@ -1,5 +1,9 @@
#!/usr/bin/env bash
-
+#
+# SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+# SPDX-FileCopyrightText: 2015-2016 ownCloud, Inc.
+# SPDX-License-Identifier: AGPL-3.0-only
+#
OC_PATH=../../
OCC=${OC_PATH}occ
TAGS=""
@@ -34,10 +38,16 @@ if [ -z "$EXECUTOR_NUMBER" ]; then
fi
PORT=$((8080 + $EXECUTOR_NUMBER))
echo $PORT
-php -S localhost:$PORT -t ../.. &
+
+echo "" > phpserver.log
+
+php -S localhost:$PORT -t ../.. &> phpserver.log &
PHPPID=$!
echo $PHPPID
+# Output filtered php server logs
+tail -f phpserver.log | grep --line-buffered -v -E ":[0-9]+ Accepted$" | grep --line-buffered -v -E ":[0-9]+ Closing$" &
+
# The federated server is started and stopped by the tests themselves
PORT_FED=$((8180 + $EXECUTOR_NUMBER))
echo $PORT_FED
diff --git a/build/integration/sharing_features/sharing-v1.feature b/build/integration/sharing_features/sharing-v1.feature
index ca030bd3a31..2b5d4e89331 100644
--- a/build/integration/sharing_features/sharing-v1.feature
+++ b/build/integration/sharing_features/sharing-v1.feature
@@ -229,6 +229,24 @@ Feature: sharing
| url | AN_URL |
| mimetype | httpd/unix-directory |
+ Scenario: Creating a new share with expiration date removed, when default expiration is set
+ Given user "user0" exists
+ And user "user1" exists
+ And parameter "shareapi_default_expire_date" of app "core" is set to "yes"
+ And As an "user0"
+ When creating a share with
+ | path | welcome.txt |
+ | shareWith | user1 |
+ | shareType | 0 |
+ | expireDate | |
+ Then the OCS status code should be "100"
+ And the HTTP status code should be "200"
+ And Getting info of last share
+ Then the OCS status code should be "100"
+ And the HTTP status code should be "200"
+ And Share fields of last share match with
+ | expiration ||
+
Scenario: Creating a new public share, updating its password and getting its info
Given user "user0" exists
And As an "user0"
diff --git a/build/integration/sharing_features/sharing-v1-video-verification.feature b/build/integration/videoverification_features/sharing-v1-video-verification.feature
index cc4be425aab..0bd4ed4b0f2 100644
--- a/build/integration/sharing_features/sharing-v1-video-verification.feature
+++ b/build/integration/videoverification_features/sharing-v1-video-verification.feature
@@ -1,4 +1,6 @@
@Talk
+# SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
Feature: sharing
Background:
Given using api version "1"
diff --git a/build/license.php b/build/license.php
index 94ef4e4b02c..31b288f36eb 100644
--- a/build/license.php
+++ b/build/license.php
@@ -1,22 +1,8 @@
<?php
/**
- * @author Thomas Müller
- *
- * @copyright Copyright (c) 2015, ownCloud, Inc.
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
class Licenses {
diff --git a/build/merge-font-noto.sh b/build/merge-font-noto.sh
index ee4831dac74..603f6dba9d3 100755
--- a/build/merge-font-noto.sh
+++ b/build/merge-font-noto.sh
@@ -1,21 +1,7 @@
#!/usr/bin/env bash
-# @copyright Copyright (c) 2021, Daniel Calviño Sánchez (danxuliu@gmail.com)
-#
-# @license GNU AGPL version 3 or any later version
-#
-# This program is free software: you can redistribute it and/or modify
-# it under the terms of the GNU Affero General Public License as
-# published by the Free Software Foundation, either version 3 of the
-# License, or (at your option) any later version.
-#
-# This program 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 Affero General Public License for more details.
-#
-# You should have received a copy of the GNU Affero General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
+# SPDX-FileCopyrightText: 2021 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
# Helper script to merge several Noto fonts in a single TTF file.
#
diff --git a/build/openapi-checker.sh b/build/openapi-checker.sh
index afe55c4a269..5ad6e619ec3 100755
--- a/build/openapi-checker.sh
+++ b/build/openapi-checker.sh
@@ -1,13 +1,18 @@
#!/usr/bin/env bash
-for path in core/openapi.json apps/*/openapi.json; do
- composer exec generate-spec "$(dirname "$path")" "$path" || exit 1
+# SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
+
+for path in core apps/*; do
+ if [ ! -f "$path/.noopenapi" ] && [[ "$(git check-ignore "$path")" != "$path" ]]; then
+ composer exec generate-spec "$path" "$path/openapi.json" || exit 1
+ fi
done
files="$(git diff --name-only)"
changed=false
for file in $files; do
- if [[ $file == *"openapi.json" ]]; then
+ if [[ $file == *"openapi"*".json" ]]; then
changed=true
break
fi
@@ -15,7 +20,7 @@ done
if [ $changed = true ]
then
- git diff
+ git --no-pager diff
echo "The OpenAPI specifications are not up to date"
echo "Please run: bash build/openapi-checker.sh"
echo "And commit the result"
diff --git a/build/phpDocumentor.sh b/build/phpDocumentor.sh
index 533e5f5a5c7..452f756aecc 100755
--- a/build/phpDocumentor.sh
+++ b/build/phpDocumentor.sh
@@ -1,7 +1,10 @@
#!/bin/bash
+# SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
+
wget https://phpdoc.org/phpDocumentor.phar
mkdir -p api/
-php7.4 phpDocumentor.phar -t "./api" -d "./lib/public" --title="Nextcloud PHP API ($BRANCH)"
+php phpDocumentor.phar --target=./api --directory=./lib/public --title="Nextcloud PHP API ($BRANCH)"
diff --git a/build/psalm-baseline-ocp.xml b/build/psalm-baseline-ocp.xml
index 40b69d00d31..e48e5919468 100644
--- a/build/psalm-baseline-ocp.xml
+++ b/build/psalm-baseline-ocp.xml
@@ -1,8 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?>
-<files psalm-version="5.9.0@8b9ad1eb9e8b7d3101f949291da2b9f7767cd163">
+<files psalm-version="5.24.0@462c80e31c34e58cc4f750c656be3927e80e550e">
<file src="lib/private/legacy/OC_Template.php">
<UndefinedClass>
- <code>OC</code>
+ <code><![CDATA[OC]]></code>
</UndefinedClass>
</file>
<file src="lib/public/AppFramework/ApiController.php">
@@ -15,149 +15,84 @@
<code><![CDATA[new RouteConfig($this->container, $router, $routes)]]></code>
</InternalMethod>
<UndefinedClass>
- <code>\OC</code>
+ <code><![CDATA[\OC]]></code>
</UndefinedClass>
</file>
<file src="lib/public/AppFramework/Db/Entity.php">
<InvalidNullableReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>$column</code>
+ <code><![CDATA[$column]]></code>
</NullableReturnStatement>
</file>
<file src="lib/public/AppFramework/Http/RedirectToDefaultAppResponse.php">
<UndefinedClass>
- <code>\OC</code>
+ <code><![CDATA[\OC]]></code>
</UndefinedClass>
</file>
<file src="lib/public/AppFramework/Http/Response.php">
<UndefinedClass>
- <code>\OC</code>
- <code>\OC</code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
</UndefinedClass>
</file>
- <file src="lib/public/Cache/CappedMemoryCache.php">
- <MissingTemplateParam>
- <code>\ArrayAccess</code>
- </MissingTemplateParam>
- </file>
<file src="lib/public/Defaults.php">
<UndefinedClass>
- <code>\OC</code>
+ <code><![CDATA[\OC]]></code>
</UndefinedClass>
</file>
<file src="lib/public/Diagnostics/IQueryLogger.php">
<LessSpecificImplementedReturnType>
- <code>mixed</code>
+ <code><![CDATA[mixed]]></code>
</LessSpecificImplementedReturnType>
</file>
<file src="lib/public/EventDispatcher/GenericEvent.php">
<MissingTemplateParam>
- <code>ArrayAccess</code>
- <code>IteratorAggregate</code>
+ <code><![CDATA[ArrayAccess]]></code>
+ <code><![CDATA[IteratorAggregate]]></code>
</MissingTemplateParam>
</file>
- <file src="lib/public/Federation/Exceptions/ActionNotSupportedException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Federation/Exceptions/AuthenticationFailedException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Federation/Exceptions/BadRequestException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Federation/Exceptions/ProviderAlreadyExistsException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Federation/Exceptions/ProviderDoesNotExistsException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
<file src="lib/public/Files.php">
<FalsableReturnStatement>
- <code>\OC_App::getStorage($app)</code>
+ <code><![CDATA[\OC_App::getStorage($app)]]></code>
</FalsableReturnStatement>
<UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Files/Cache/ICacheEntry.php">
- <MissingTemplateParam>
- <code>ArrayAccess</code>
- </MissingTemplateParam>
- </file>
- <file src="lib/public/Files/LockNotAcquiredException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Files/StorageAuthException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Files/StorageBadConfigException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Files/StorageConnectionException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Files/StorageNotAvailableException.php">
- <UndefinedClass>
- <code>\OC</code>
- </UndefinedClass>
- </file>
- <file src="lib/public/Files/StorageTimeoutException.php">
- <UndefinedClass>
- <code>\OC</code>
+ <code><![CDATA[\OC]]></code>
</UndefinedClass>
</file>
<file src="lib/public/L10N/ILanguageIterator.php">
<MissingTemplateParam>
- <code>\Iterator</code>
+ <code><![CDATA[\Iterator]]></code>
</MissingTemplateParam>
</file>
<file src="lib/public/Template.php">
<UndefinedFunction>
- <code>\html_select_options($options, $selected, $params)</code>
- <code>\human_file_size($bytes)</code>
- <code>\image_path($app, $image)</code>
- <code>\mimetype_icon($mimetype)</code>
- <code>\preview_icon($path)</code>
- <code>\publicPreview_icon($path, $token)</code>
- <code>\relative_modified_date($timestamp, null, $dateOnly)</code>
+ <code><![CDATA[\html_select_options($options, $selected, $params)]]></code>
+ <code><![CDATA[\human_file_size($bytes)]]></code>
+ <code><![CDATA[\image_path($app, $image)]]></code>
+ <code><![CDATA[\mimetype_icon($mimetype)]]></code>
+ <code><![CDATA[\preview_icon($path)]]></code>
+ <code><![CDATA[\publicPreview_icon($path, $token)]]></code>
+ <code><![CDATA[\relative_modified_date($timestamp, null, $dateOnly)]]></code>
</UndefinedFunction>
</file>
<file src="lib/public/Util.php">
<UndefinedClass>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
- <code>\OC</code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
+ <code><![CDATA[\OC]]></code>
</UndefinedClass>
</file>
</files>
diff --git a/build/psalm-baseline.xml b/build/psalm-baseline.xml
index 1551261d18f..3897f5aa176 100644
--- a/build/psalm-baseline.xml
+++ b/build/psalm-baseline.xml
@@ -1,119 +1,97 @@
<?xml version="1.0" encoding="UTF-8"?>
-<files psalm-version="5.9.0@8b9ad1eb9e8b7d3101f949291da2b9f7767cd163">
+<files psalm-version="5.24.0@462c80e31c34e58cc4f750c656be3927e80e550e">
<file src="3rdparty/sabre/dav/lib/CalDAV/Calendar.php">
<MoreSpecificImplementedParamType>
- <code>$calendarData</code>
+ <code><![CDATA[$data]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="3rdparty/sabre/dav/lib/CalDAV/CalendarHome.php">
<MoreSpecificImplementedParamType>
- <code>$data</code>
+ <code><![CDATA[$data]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="3rdparty/sabre/dav/lib/CalDAV/Principal/User.php">
<MoreSpecificImplementedParamType>
- <code>$data</code>
+ <code><![CDATA[$data]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="3rdparty/sabre/dav/lib/CardDAV/AddressBook.php">
<MoreSpecificImplementedParamType>
- <code>$vcardData</code>
+ <code><![CDATA[$data]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="3rdparty/sabre/dav/lib/CardDAV/AddressBookHome.php">
<InvalidPropertyAssignmentValue>
- <code>$principalUri</code>
+ <code><![CDATA[$principalUri]]></code>
</InvalidPropertyAssignmentValue>
<MoreSpecificImplementedParamType>
- <code>$data</code>
+ <code><![CDATA[$data]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="3rdparty/sabre/dav/lib/CardDAV/Card.php">
<MoreSpecificImplementedParamType>
- <code>$cardData</code>
+ <code><![CDATA[$cardData]]></code>
</MoreSpecificImplementedParamType>
</file>
+ <file src="3rdparty/sabre/dav/lib/DAV/SimpleCollection.php">
+ <NoValue>
+ <code><![CDATA[$child]]></code>
+ <code><![CDATA[$child]]></code>
+ </NoValue>
+ </file>
<file src="3rdparty/sabre/dav/lib/DAVACL/AbstractPrincipalCollection.php">
<LessSpecificImplementedReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</LessSpecificImplementedReturnType>
</file>
- <file src="apps/admin_audit/lib/Listener/CriticalActionPerformedEventListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/comments/lib/Listener/CommentsEntityEventListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/comments/lib/Listener/LoadAdditionalScripts.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/comments/lib/Listener/LoadSidebarScripts.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/comments/lib/Notification/Listener.php">
- <LessSpecificReturnStatement>
- <code>$uids</code>
- </LessSpecificReturnStatement>
- <MoreSpecificReturnType>
- <code><![CDATA[list<string>]]></code>
- </MoreSpecificReturnType>
- </file>
- <file src="apps/contactsinteraction/lib/Listeners/ContactInteractionListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
+ <file src="3rdparty/symfony/routing/Route.php">
+ <MethodSignatureMustProvideReturnType>
+ <code><![CDATA[unserialize]]></code>
+ </MethodSignatureMustProvideReturnType>
</file>
<file src="apps/dav/appinfo/v1/caldav.php">
<UndefinedGlobalVariable>
- <code>$baseuri</code>
+ <code><![CDATA[$baseuri]]></code>
</UndefinedGlobalVariable>
</file>
<file src="apps/dav/appinfo/v1/carddav.php">
<UndefinedGlobalVariable>
- <code>$baseuri</code>
+ <code><![CDATA[$baseuri]]></code>
</UndefinedGlobalVariable>
</file>
<file src="apps/dav/appinfo/v1/publicwebdav.php">
<InternalMethod>
- <code>\OC\Files\Filesystem::logWarningWhenAddingStorageWrapper($previousLog)</code>
- <code>\OC\Files\Filesystem::logWarningWhenAddingStorageWrapper(false)</code>
+ <code><![CDATA[\OC\Files\Filesystem::logWarningWhenAddingStorageWrapper($previousLog)]]></code>
+ <code><![CDATA[\OC\Files\Filesystem::logWarningWhenAddingStorageWrapper(false)]]></code>
</InternalMethod>
<UndefinedGlobalVariable>
- <code>$baseuri</code>
+ <code><![CDATA[$baseuri]]></code>
</UndefinedGlobalVariable>
</file>
<file src="apps/dav/appinfo/v1/webdav.php">
<UndefinedGlobalVariable>
- <code>$baseuri</code>
+ <code><![CDATA[$baseuri]]></code>
</UndefinedGlobalVariable>
</file>
<file src="apps/dav/appinfo/v2/direct.php">
<UndefinedGlobalVariable>
- <code>$baseuri</code>
+ <code><![CDATA[$baseuri]]></code>
</UndefinedGlobalVariable>
</file>
<file src="apps/dav/appinfo/v2/remote.php">
<UndefinedGlobalVariable>
- <code>$baseuri</code>
+ <code><![CDATA[$baseuri]]></code>
</UndefinedGlobalVariable>
</file>
<file src="apps/dav/lib/AppInfo/Application.php">
<InvalidArgument>
- <code>CalendarDeletionDefaultUpdaterListener::class</code>
+ <code><![CDATA[registerEventListener]]></code>
</InvalidArgument>
</file>
<file src="apps/dav/lib/CalDAV/BirthdayService.php">
<UndefinedMethod>
- <code>setDateTime</code>
- <code>setDateTime</code>
+ <code><![CDATA[setDateTime]]></code>
+ <code><![CDATA[setDateTime]]></code>
</UndefinedMethod>
<UndefinedPropertyFetch>
<code><![CDATA[$existingBirthday->VEVENT->DTSTART]]></code>
@@ -122,152 +100,66 @@
<code><![CDATA[$newCalendarData->VEVENT->SUMMARY]]></code>
</UndefinedPropertyFetch>
</file>
- <file src="apps/dav/lib/CalDAV/CachedSubscription.php">
- <ParamNameMismatch>
- <code>$calendarData</code>
- </ParamNameMismatch>
- </file>
<file src="apps/dav/lib/CalDAV/CachedSubscriptionObject.php">
<NullableReturnStatement>
<code><![CDATA[$this->objectData['calendardata']]]></code>
</NullableReturnStatement>
<ParamNameMismatch>
- <code>$calendarData</code>
- <code>$calendarData</code>
+ <code><![CDATA[$calendarData]]></code>
+ <code><![CDATA[$calendarData]]></code>
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/CalDAV/CalDavBackend.php">
<InvalidNullableReturnType>
- <code>array</code>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</InvalidNullableReturnType>
<LessSpecificReturnStatement>
- <code>Reader::read($objectData)</code>
+ <code><![CDATA[Reader::read($objectData)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificImplementedParamType>
- <code>$objectData</code>
- <code>$uris</code>
- <code>$uris</code>
+ <code><![CDATA[$objectData]]></code>
+ <code><![CDATA[$uris]]></code>
+ <code><![CDATA[$uris]]></code>
</MoreSpecificImplementedParamType>
<MoreSpecificReturnType>
- <code>VCalendar</code>
+ <code><![CDATA[VCalendar]]></code>
</MoreSpecificReturnType>
<NullableReturnStatement>
- <code><![CDATA[$this->atomic(function () use ($calendarId, $syncToken, $syncLevel, $limit, $calendarType) {
- // Current synctoken
- $qb = $this->db->getQueryBuilder();
- $qb->select('synctoken')
- ->from('calendars')
- ->where(
- $qb->expr()->eq('id', $qb->createNamedParameter($calendarId))
- );
- $stmt = $qb->executeQuery();
- $currentToken = $stmt->fetchOne();
-
- if ($currentToken === false) {
- return null;
- }
-
- $result = [
- 'syncToken' => $currentToken,
- 'added' => [],
- 'modified' => [],
- 'deleted' => [],
- ];
-
- if ($syncToken) {
- $qb = $this->db->getQueryBuilder();
-
- $qb->select('uri', 'operation')
- ->from('calendarchanges')
- ->where(
- $qb->expr()->andX(
- $qb->expr()->gte('synctoken', $qb->createNamedParameter($syncToken)),
- $qb->expr()->lt('synctoken', $qb->createNamedParameter($currentToken)),
- $qb->expr()->eq('calendarid', $qb->createNamedParameter($calendarId)),
- $qb->expr()->eq('calendartype', $qb->createNamedParameter($calendarType))
- )
- )->orderBy('synctoken');
- if (is_int($limit) && $limit > 0) {
- $qb->setMaxResults($limit);
- }
-
- // Fetching all changes
- $stmt = $qb->executeQuery();
- $changes = [];
-
- // This loop ensures that any duplicates are overwritten, only the
- // last change on a node is relevant.
- while ($row = $stmt->fetch()) {
- $changes[$row['uri']] = $row['operation'];
- }
- $stmt->closeCursor();
-
- foreach ($changes as $uri => $operation) {
- switch ($operation) {
- case 1:
- $result['added'][] = $uri;
- break;
- case 2:
- $result['modified'][] = $uri;
- break;
- case 3:
- $result['deleted'][] = $uri;
- break;
- }
- }
- } else {
- // No synctoken supplied, this is the initial sync.
- $qb = $this->db->getQueryBuilder();
- $qb->select('uri')
- ->from('calendarobjects')
- ->where(
- $qb->expr()->andX(
- $qb->expr()->eq('calendarid', $qb->createNamedParameter($calendarId)),
- $qb->expr()->eq('calendartype', $qb->createNamedParameter($calendarType))
- )
- );
- $stmt = $qb->executeQuery();
- $result['added'] = $stmt->fetchAll(\PDO::FETCH_COLUMN);
- $stmt->closeCursor();
- }
- return $result;
- }, $this->db)]]></code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="apps/dav/lib/CalDAV/CalendarHome.php">
<InvalidNullableReturnType>
- <code>INode</code>
+ <code><![CDATA[INode]]></code>
</InvalidNullableReturnType>
<LessSpecificImplementedReturnType>
- <code>INode</code>
+ <code><![CDATA[INode]]></code>
</LessSpecificImplementedReturnType>
<NullableReturnStatement>
<code><![CDATA[$calendarPlugin->getCalendarInCalendarHome($this->principalInfo['uri'], $calendarUri)]]></code>
</NullableReturnStatement>
<UndefinedInterfaceMethod>
- <code>calendarSearch</code>
+ <code><![CDATA[calendarSearch]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/dav/lib/CalDAV/CalendarRoot.php">
<ParamNameMismatch>
- <code>$principal</code>
+ <code><![CDATA[$principal]]></code>
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/CalDAV/Plugin.php">
<ImplementedReturnTypeMismatch>
- <code>string|null</code>
+ <code><![CDATA[string|null]]></code>
</ImplementedReturnTypeMismatch>
</file>
<file src="apps/dav/lib/CalDAV/Principal/Collection.php">
<ParamNameMismatch>
- <code>$principalInfo</code>
+ <code><![CDATA[$principalInfo]]></code>
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/CalDAV/PublicCalendar.php">
<MoreSpecificImplementedParamType>
- <code>$paths</code>
+ <code><![CDATA[$paths]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="apps/dav/lib/CalDAV/Reminder/NotificationProvider/AbstractProvider.php">
@@ -275,47 +167,47 @@
<code><![CDATA[$vevent->DTEND]]></code>
</LessSpecificReturnStatement>
<UndefinedMethod>
- <code>hasTime</code>
- <code>isFloating</code>
- <code>isFloating</code>
+ <code><![CDATA[hasTime]]></code>
+ <code><![CDATA[isFloating]]></code>
+ <code><![CDATA[isFloating]]></code>
</UndefinedMethod>
</file>
<file src="apps/dav/lib/CalDAV/Reminder/NotificationProvider/EmailProvider.php">
<LessSpecificReturnStatement>
- <code>$emailAddresses</code>
+ <code><![CDATA[$emailAddresses]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
<code><![CDATA[array<string, array{LANG?: string}>]]></code>
</MoreSpecificReturnType>
<UndefinedMethod>
- <code>getDateTime</code>
- <code>getDateTime</code>
- <code>isFloating</code>
+ <code><![CDATA[getDateTime]]></code>
+ <code><![CDATA[getDateTime]]></code>
+ <code><![CDATA[isFloating]]></code>
</UndefinedMethod>
</file>
<file src="apps/dav/lib/CalDAV/Reminder/NotificationProviderManager.php">
<UndefinedConstant>
- <code>$provider::NOTIFICATION_TYPE</code>
+ <code><![CDATA[$provider::NOTIFICATION_TYPE]]></code>
</UndefinedConstant>
</file>
<file src="apps/dav/lib/CalDAV/Reminder/Notifier.php">
<TypeDoesNotContainType>
- <code>$diff === false</code>
+ <code><![CDATA[$diff === false]]></code>
</TypeDoesNotContainType>
</file>
<file src="apps/dav/lib/CalDAV/Reminder/ReminderService.php">
<LessSpecificReturnStatement>
- <code>$vevents</code>
- <code>VObject\Reader::read($calendarData,
- VObject\Reader::OPTION_FORGIVING)</code>
+ <code><![CDATA[$vevents]]></code>
+ <code><![CDATA[VObject\Reader::read($calendarData,
+ VObject\Reader::OPTION_FORGIVING)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>VObject\Component\VCalendar|null</code>
- <code>VObject\Component\VEvent[]</code>
+ <code><![CDATA[VObject\Component\VCalendar|null]]></code>
+ <code><![CDATA[VObject\Component\VEvent[]]]></code>
</MoreSpecificReturnType>
<UndefinedMethod>
- <code>getDateTime</code>
- <code>getDateTime</code>
+ <code><![CDATA[getDateTime]]></code>
+ <code><![CDATA[getDateTime]]></code>
</UndefinedMethod>
<UndefinedPropertyFetch>
<code><![CDATA[$valarm->parent->UID]]></code>
@@ -323,17 +215,17 @@
</file>
<file src="apps/dav/lib/CalDAV/ResourceBooking/AbstractPrincipalBackend.php">
<InvalidNullableReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</InvalidNullableReturnType>
<InvalidReturnStatement>
- <code>$principals</code>
+ <code><![CDATA[$principals]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string[]</code>
+ <code><![CDATA[string[]]]></code>
</InvalidReturnType>
<NullableReturnStatement>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="apps/dav/lib/CalDAV/Schedule/IMipPlugin.php">
@@ -342,38 +234,38 @@
</RedundantCast>
<RedundantCondition>
<code><![CDATA[!empty($modified['old']) && is_array($modified['old'])]]></code>
- <code>is_array($modified['old'])</code>
+ <code><![CDATA[is_array($modified['old'])]]></code>
</RedundantCondition>
</file>
<file src="apps/dav/lib/CalDAV/Schedule/IMipService.php">
<UndefinedMethod>
- <code>getNormalizedValue</code>
- <code>getNormalizedValue</code>
+ <code><![CDATA[getNormalizedValue]]></code>
+ <code><![CDATA[getNormalizedValue]]></code>
</UndefinedMethod>
</file>
<file src="apps/dav/lib/CalDAV/Schedule/Plugin.php">
<InvalidArgument>
- <code>[$aclPlugin, 'propFind']</code>
- <code>[$aclPlugin, 'propFind']</code>
+ <code><![CDATA[[$aclPlugin, 'propFind']]]></code>
+ <code><![CDATA[[$aclPlugin, 'propFind']]]></code>
</InvalidArgument>
<LessSpecificReturnStatement>
<code><![CDATA[$vevent->DTEND]]></code>
</LessSpecificReturnStatement>
<UndefinedInterfaceMethod>
- <code>get</code>
- <code>getChildren</code>
+ <code><![CDATA[get]]></code>
+ <code><![CDATA[getChildren]]></code>
</UndefinedInterfaceMethod>
<UndefinedMethod>
- <code>getDateTime</code>
- <code>hasTime</code>
- <code>isFloating</code>
- <code>isFloating</code>
- <code>principalSearch</code>
+ <code><![CDATA[getDateTime]]></code>
+ <code><![CDATA[hasTime]]></code>
+ <code><![CDATA[isFloating]]></code>
+ <code><![CDATA[isFloating]]></code>
+ <code><![CDATA[principalSearch]]></code>
</UndefinedMethod>
</file>
<file src="apps/dav/lib/CalDAV/Search/SearchPlugin.php">
<InvalidNullableReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidNullableReturnType>
</file>
<file src="apps/dav/lib/CalDAV/Search/Xml/Filter/ParamFilter.php">
@@ -384,22 +276,22 @@
]]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidReturnType>
</file>
<file src="apps/dav/lib/CalDAV/Search/Xml/Request/CalendarSearchReport.php">
<TypeDoesNotContainType>
- <code>!is_array($newProps['filters']['comps'])</code>
- <code>!is_array($newProps['filters']['params'])</code>
- <code>!is_array($newProps['filters']['props'])</code>
- <code>!isset($newProps['filters']['comps']) || !is_array($newProps['filters']['comps'])</code>
- <code>!isset($newProps['filters']['params']) || !is_array($newProps['filters']['params'])</code>
- <code>!isset($newProps['filters']['props']) || !is_array($newProps['filters']['props'])</code>
+ <code><![CDATA[!is_array($newProps['filters']['comps'])]]></code>
+ <code><![CDATA[!is_array($newProps['filters']['params'])]]></code>
+ <code><![CDATA[!is_array($newProps['filters']['props'])]]></code>
+ <code><![CDATA[!isset($newProps['filters']['comps']) || !is_array($newProps['filters']['comps'])]]></code>
+ <code><![CDATA[!isset($newProps['filters']['params']) || !is_array($newProps['filters']['params'])]]></code>
+ <code><![CDATA[!isset($newProps['filters']['props']) || !is_array($newProps['filters']['props'])]]></code>
</TypeDoesNotContainType>
</file>
<file src="apps/dav/lib/CalDAV/WebcalCaching/RefreshWebcalService.php">
<InvalidArgument>
- <code>$webcalData</code>
+ <code><![CDATA[$webcalData]]></code>
</InvalidArgument>
</file>
<file src="apps/dav/lib/CardDAV/AddressBookImpl.php">
@@ -408,66 +300,41 @@
<code><![CDATA[$this->getKey()]]></code>
</InvalidArgument>
<LessSpecificReturnStatement>
- <code>Reader::read($cardData)</code>
+ <code><![CDATA[Reader::read($cardData)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>VCard</code>
+ <code><![CDATA[VCard]]></code>
</MoreSpecificReturnType>
</file>
<file src="apps/dav/lib/CardDAV/AddressBookRoot.php">
<ParamNameMismatch>
- <code>$principal</code>
+ <code><![CDATA[$principal]]></code>
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/CardDAV/CardDavBackend.php">
<FalsableReturnStatement>
- <code>false</code>
+ <code><![CDATA[false]]></code>
</FalsableReturnStatement>
<LessSpecificReturnStatement>
- <code>Reader::read($cardData)</code>
+ <code><![CDATA[Reader::read($cardData)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>VCard</code>
+ <code><![CDATA[VCard]]></code>
</MoreSpecificReturnType>
<TypeDoesNotContainType>
- <code>$addressBooks[$row['id']][$readOnlyPropertyName] === 0</code>
+ <code><![CDATA[$addressBooks[$row['id']][$readOnlyPropertyName] === 0]]></code>
</TypeDoesNotContainType>
</file>
<file src="apps/dav/lib/CardDAV/MultiGetExportPlugin.php">
<InvalidNullableReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidNullableReturnType>
</file>
- <file src="apps/dav/lib/CardDAV/PhotoCache.php">
- <InvalidNullableReturnType>
- <code>string</code>
- </InvalidNullableReturnType>
- <LessSpecificReturnStatement>
- <code><![CDATA[[
- 'Content-Type' => $type,
- 'body' => $val
- ]]]></code>
- </LessSpecificReturnStatement>
- <MoreSpecificReturnType>
- <code>false|array{body: string, Content-Type: string}</code>
- </MoreSpecificReturnType>
- <NullableReturnStatement>
- <code>$type</code>
- </NullableReturnStatement>
- </file>
<file src="apps/dav/lib/CardDAV/Plugin.php">
<ImplementedReturnTypeMismatch>
- <code>string|null</code>
+ <code><![CDATA[string|null]]></code>
</ImplementedReturnTypeMismatch>
</file>
- <file src="apps/dav/lib/CardDAV/SystemAddressbook.php">
- <InvalidNullableReturnType>
- <code>getChanges</code>
- </InvalidNullableReturnType>
- <NullableReturnStatement>
- <code>null</code>
- </NullableReturnStatement>
- </file>
<file src="apps/dav/lib/CardDAV/UserAddressBooks.php">
<InvalidArgument>
<code><![CDATA[$this->principalUri]]></code>
@@ -476,91 +343,86 @@
</file>
<file src="apps/dav/lib/CardDAV/Xml/Groups.php">
<InvalidPropertyAssignmentValue>
- <code>$groups</code>
+ <code><![CDATA[$groups]]></code>
</InvalidPropertyAssignmentValue>
</file>
<file src="apps/dav/lib/Comments/CommentsPlugin.php">
<UndefinedFunction>
- <code>\Sabre\HTTP\toDate($value)</code>
+ <code><![CDATA[\Sabre\HTTP\toDate($value)]]></code>
</UndefinedFunction>
</file>
<file src="apps/dav/lib/Connector/Sabre/AnonymousOptionsPlugin.php">
<InvalidNullableReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidNullableReturnType>
</file>
<file src="apps/dav/lib/Connector/Sabre/Auth.php">
<LessSpecificReturnStatement>
- <code>$data</code>
+ <code><![CDATA[$data]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>array{bool, string}</code>
+ <code><![CDATA[array{bool, string}]]></code>
</MoreSpecificReturnType>
</file>
<file src="apps/dav/lib/Connector/Sabre/BearerAuth.php">
<UndefinedInterfaceMethod>
- <code>tryTokenLogin</code>
+ <code><![CDATA[tryTokenLogin]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/dav/lib/Connector/Sabre/Directory.php">
<InvalidPropertyAssignmentValue>
- <code>$nodes</code>
+ <code><![CDATA[$nodes]]></code>
</InvalidPropertyAssignmentValue>
<InvalidReturnStatement>
<code><![CDATA[$this->dirContent]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>\Sabre\DAV\INode[]</code>
+ <code><![CDATA[\Sabre\DAV\INode[]]]></code>
</InvalidReturnType>
<LessSpecificReturnStatement>
<code><![CDATA[$this->node]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>Folder</code>
+ <code><![CDATA[Folder]]></code>
</MoreSpecificReturnType>
<NullArgument>
- <code>null</code>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullArgument>
<ParamNameMismatch>
- <code>$fullSourcePath</code>
+ <code><![CDATA[$fullSourcePath]]></code>
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/Connector/Sabre/File.php">
<LessSpecificReturnStatement>
<code><![CDATA[$this->node]]></code>
</LessSpecificReturnStatement>
- <MoreSpecificImplementedParamType>
- <code>$data</code>
- </MoreSpecificImplementedParamType>
<MoreSpecificReturnType>
- <code>\OCP\Files\File</code>
+ <code><![CDATA[\OCP\Files\File]]></code>
</MoreSpecificReturnType>
</file>
<file src="apps/dav/lib/Connector/Sabre/FilesReportPlugin.php">
<InvalidArgument>
- <code>0</code>
- <code>200</code>
+ <code><![CDATA[0]]></code>
</InvalidArgument>
<InvalidNullableReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidNullableReturnType>
<TooManyArguments>
- <code>new PreconditionFailed('Cannot filter by non-existing tag', 0, $e)</code>
+ <code><![CDATA[new PreconditionFailed('Cannot filter by non-existing tag', 0, $e)]]></code>
</TooManyArguments>
<UndefinedClass>
- <code>\OCA\Circles\Api\v1\Circles</code>
+ <code><![CDATA[\OCA\Circles\Api\v1\Circles]]></code>
</UndefinedClass>
<UndefinedInterfaceMethod>
- <code>getById</code>
- <code>getPath</code>
+ <code><![CDATA[getPath]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/dav/lib/Connector/Sabre/Node.php">
<InvalidNullableReturnType>
- <code>int</code>
- <code>integer</code>
+ <code><![CDATA[int]]></code>
+ <code><![CDATA[integer]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
<code><![CDATA[$this->info->getId()]]></code>
@@ -569,47 +431,41 @@
</file>
<file src="apps/dav/lib/Connector/Sabre/Principal.php">
<InvalidNullableReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</InvalidNullableReturnType>
<InvalidReturnStatement>
- <code>$principals</code>
+ <code><![CDATA[$principals]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string[]</code>
+ <code><![CDATA[string[]]]></code>
</InvalidReturnType>
<InvalidScalarArgument>
- <code>$results</code>
+ <code><![CDATA[$results]]></code>
</InvalidScalarArgument>
<NullableReturnStatement>
<code><![CDATA[$this->circleToPrincipal($decodedName)
?: $this->circleToPrincipal($name)]]></code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
<UndefinedClass>
- <code>\OCA\Circles\Api\v1\Circles</code>
- <code>\OCA\Circles\Api\v1\Circles</code>
+ <code><![CDATA[\OCA\Circles\Api\v1\Circles]]></code>
+ <code><![CDATA[\OCA\Circles\Api\v1\Circles]]></code>
</UndefinedClass>
</file>
- <file src="apps/dav/lib/Connector/Sabre/QuotaPlugin.php">
- <UndefinedInterfaceMethod>
- <code>getPath</code>
- <code>getPath</code>
- </UndefinedInterfaceMethod>
- </file>
<file src="apps/dav/lib/Connector/Sabre/ServerFactory.php">
<TooManyArguments>
- <code>new \OCA\DAV\Connector\Sabre\QuotaPlugin($view, true)</code>
+ <code><![CDATA[new \OCA\DAV\Connector\Sabre\QuotaPlugin($view, true)]]></code>
</TooManyArguments>
</file>
<file src="apps/dav/lib/Connector/Sabre/ShareTypeList.php">
<InvalidArgument>
- <code>$shareType</code>
+ <code><![CDATA[$shareType]]></code>
</InvalidArgument>
</file>
<file src="apps/dav/lib/Connector/Sabre/ShareeList.php">
@@ -619,10 +475,10 @@
</file>
<file src="apps/dav/lib/Connector/Sabre/TagsPlugin.php">
<NullableReturnStatement>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
<UndefinedInterfaceMethod>
- <code>getId</code>
+ <code><![CDATA[getId]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/dav/lib/Controller/InvitationResponseController.php">
@@ -632,39 +488,39 @@
</file>
<file src="apps/dav/lib/DAV/CustomPropertiesBackend.php">
<InvalidArgument>
- <code>$whereValues</code>
+ <code><![CDATA[$whereValues]]></code>
</InvalidArgument>
</file>
<file src="apps/dav/lib/DAV/GroupPrincipalBackend.php">
<InvalidNullableReturnType>
- <code>array</code>
- <code>string</code>
+ <code><![CDATA[array]]></code>
+ <code><![CDATA[string]]></code>
</InvalidNullableReturnType>
<InvalidReturnStatement>
- <code>$principals</code>
+ <code><![CDATA[$principals]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string[]</code>
+ <code><![CDATA[string[]]]></code>
</InvalidReturnType>
<MoreSpecificImplementedParamType>
- <code>$members</code>
+ <code><![CDATA[$members]]></code>
</MoreSpecificImplementedParamType>
<NullableReturnStatement>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="apps/dav/lib/DAV/SystemPrincipalBackend.php">
<InvalidNullableReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="apps/dav/lib/Direct/Server.php">
@@ -674,13 +530,13 @@
</file>
<file src="apps/dav/lib/Files/FileSearchBackend.php">
<InvalidReturnStatement>
- <code>$value</code>
+ <code><![CDATA[$value]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>?string</code>
+ <code><![CDATA[?string]]></code>
</InvalidReturnType>
<ParamNameMismatch>
- <code>$search</code>
+ <code><![CDATA[$search]]></code>
</ParamNameMismatch>
<RedundantCondition>
<code><![CDATA[$date->getTimestamp() !== false]]></code>
@@ -695,7 +551,7 @@
<code><![CDATA[$this->backend->getArbiterPath()]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidReturnType>
</file>
<file src="apps/dav/lib/HookManager.php">
@@ -704,74 +560,14 @@
<code><![CDATA[$this->usersToDelete]]></code>
</InvalidPropertyAssignmentValue>
</file>
- <file src="apps/dav/lib/Listener/ActivityUpdaterListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/AddressbookListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/BirthdayListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/CalendarContactInteractionListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/CalendarObjectReminderUpdaterListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/CalendarPublicationListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/CalendarShareUpdateListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/CardListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/ClearPhotoCacheListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/SubscriptionListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/TrustedServerRemovedListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/dav/lib/Listener/UserPreferenceListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/dav/lib/Migration/BuildCalendarSearchIndexBackgroundJob.php">
<ParamNameMismatch>
- <code>$arguments</code>
+ <code><![CDATA[$arguments]]></code>
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/Migration/BuildSocialSearchIndexBackgroundJob.php">
<ParamNameMismatch>
- <code>$arguments</code>
+ <code><![CDATA[$arguments]]></code>
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/Search/ContactsSearchProvider.php">
@@ -796,14 +592,14 @@
<code><![CDATA[$this->l10n->l('date', $startDateTime, ['width' => 'medium'])]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidReturnType>
<UndefinedMethod>
- <code>getDateTime</code>
- <code>getDateTime</code>
- <code>hasTime</code>
- <code>isFloating</code>
- <code>isFloating</code>
+ <code><![CDATA[getDateTime]]></code>
+ <code><![CDATA[getDateTime]]></code>
+ <code><![CDATA[hasTime]]></code>
+ <code><![CDATA[isFloating]]></code>
+ <code><![CDATA[isFloating]]></code>
</UndefinedMethod>
</file>
<file src="apps/dav/lib/Search/TasksSearchProvider.php">
@@ -811,52 +607,52 @@
<code><![CDATA[$query->getCursor()]]></code>
</InvalidOperand>
<UndefinedMethod>
- <code>getDateTime</code>
- <code>getDateTime</code>
- <code>hasTime</code>
+ <code><![CDATA[getDateTime]]></code>
+ <code><![CDATA[getDateTime]]></code>
+ <code><![CDATA[hasTime]]></code>
</UndefinedMethod>
</file>
<file src="apps/dav/lib/SystemTag/SystemTagsObjectMappingCollection.php">
<ParamNameMismatch>
- <code>$tagId</code>
- <code>$tagName</code>
+ <code><![CDATA[$tagId]]></code>
+ <code><![CDATA[$tagName]]></code>
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/SystemTag/SystemTagsObjectTypeCollection.php">
<ParamNameMismatch>
- <code>$objectName</code>
+ <code><![CDATA[$objectName]]></code>
</ParamNameMismatch>
</file>
<file src="apps/dav/lib/Traits/PrincipalProxyTrait.php">
<MoreSpecificImplementedParamType>
- <code>$members</code>
+ <code><![CDATA[$members]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="apps/dav/lib/Upload/AssemblyStream.php">
<FalsableReturnStatement>
- <code>false</code>
+ <code><![CDATA[false]]></code>
</FalsableReturnStatement>
<InvalidPropertyAssignmentValue>
<code><![CDATA[$this->currentStream]]></code>
</InvalidPropertyAssignmentValue>
<InvalidReturnStatement>
- <code>$context</code>
+ <code><![CDATA[$context]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</InvalidReturnType>
<RedundantFunctionCall>
- <code>array_values</code>
+ <code><![CDATA[array_values]]></code>
</RedundantFunctionCall>
</file>
<file src="apps/dav/lib/Upload/ChunkingV2Plugin.php">
<UndefinedInterfaceMethod>
- <code>getId</code>
- <code>getId</code>
- <code>getId</code>
- <code>getInternalPath</code>
- <code>getNode</code>
- <code>getSize</code>
+ <code><![CDATA[getId]]></code>
+ <code><![CDATA[getId]]></code>
+ <code><![CDATA[getId]]></code>
+ <code><![CDATA[getInternalPath]]></code>
+ <code><![CDATA[getNode]]></code>
+ <code><![CDATA[getSize]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/dav/lib/UserMigration/ContactsMigrator.php">
@@ -869,7 +665,7 @@
]]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>array{name: string, displayName: string, description: ?string, vCards: VCard[]}</code>
+ <code><![CDATA[array{name: string, displayName: string, description: ?string, vCards: VCard[]}]]></code>
</MoreSpecificReturnType>
</file>
<file src="apps/encryption/lib/Command/FixKeyLocation.php">
@@ -879,22 +675,22 @@
</file>
<file src="apps/encryption/lib/Crypto/Crypt.php">
<TypeDoesNotContainType>
- <code>get_class($res) === 'OpenSSLAsymmetricKey'</code>
+ <code><![CDATA[get_class($res) === 'OpenSSLAsymmetricKey']]></code>
</TypeDoesNotContainType>
</file>
<file src="apps/encryption/lib/Crypto/Encryption.php">
<ImplementedParamTypeMismatch>
- <code>$position</code>
+ <code><![CDATA[$position]]></code>
</ImplementedParamTypeMismatch>
</file>
<file src="apps/encryption/lib/KeyManager.php">
<InvalidThrow>
- <code>throw $exception;</code>
+ <code><![CDATA[throw $exception;]]></code>
</InvalidThrow>
</file>
<file src="apps/encryption/lib/Session.php">
<TooManyArguments>
- <code>new Exceptions\PrivateKeyMissingException('please try to log-out and log-in again', 0)</code>
+ <code><![CDATA[new Exceptions\PrivateKeyMissingException('please try to log-out and log-in again', 0)]]></code>
</TooManyArguments>
</file>
<file src="apps/encryption/lib/Util.php">
@@ -902,100 +698,71 @@
<code><![CDATA[$this->files->getMount($path)->getStorage()]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>\OC\Files\Storage\Storage|null</code>
+ <code><![CDATA[\OC\Files\Storage\Storage|null]]></code>
</MoreSpecificReturnType>
</file>
<file src="apps/federatedfilesharing/lib/Controller/RequestHandlerController.php">
<InvalidArgument>
- <code>$id</code>
- <code>$id</code>
- <code>$id</code>
- <code>$id</code>
- <code>$id</code>
- <code>$id</code>
- <code>$remoteId</code>
+ <code><![CDATA[$id]]></code>
+ <code><![CDATA[$id]]></code>
+ <code><![CDATA[$id]]></code>
+ <code><![CDATA[$id]]></code>
+ <code><![CDATA[$id]]></code>
+ <code><![CDATA[$id]]></code>
+ <code><![CDATA[$remoteId]]></code>
</InvalidArgument>
</file>
<file src="apps/federatedfilesharing/lib/FederatedShareProvider.php">
<InvalidArgument>
- <code>$shareId</code>
- <code>$shareId</code>
- <code>$shareId</code>
- <code>$shareId</code>
- <code>(int)$data['id']</code>
+ <code><![CDATA[$shareId]]></code>
+ <code><![CDATA[$shareId]]></code>
+ <code><![CDATA[$shareId]]></code>
+ <code><![CDATA[$shareId]]></code>
+ <code><![CDATA[(int)$data['id']]]></code>
</InvalidArgument>
- <LessSpecificReturnStatement>
- <code>$nodes[0]</code>
- </LessSpecificReturnStatement>
- <MoreSpecificReturnType>
- <code>\OCP\Files\File|\OCP\Files\Folder</code>
- </MoreSpecificReturnType>
- </file>
- <file src="apps/federatedfilesharing/lib/Listeners/LoadAdditionalScriptsListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
</file>
<file src="apps/federatedfilesharing/lib/Notifications.php">
<InvalidReturnType>
- <code>bool</code>
- <code>bool</code>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
+ <code><![CDATA[bool]]></code>
+ <code><![CDATA[bool]]></code>
</InvalidReturnType>
</file>
<file src="apps/federatedfilesharing/lib/OCM/CloudFederationProviderFiles.php">
<InvalidArgument>
- <code>$id</code>
- <code>$id</code>
- <code>$id</code>
- <code>$id</code>
+ <code><![CDATA[$id]]></code>
+ <code><![CDATA[$id]]></code>
+ <code><![CDATA[$id]]></code>
+ <code><![CDATA[$id]]></code>
</InvalidArgument>
<InvalidReturnStatement>
- <code>$shareId</code>
+ <code><![CDATA[$shareId]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidReturnType>
<InvalidScalarArgument>
- <code>(int)$share['id']</code>
+ <code><![CDATA[(int)$share['id']]]></code>
</InvalidScalarArgument>
</file>
<file src="apps/federation/lib/DbHandler.php">
<LessSpecificReturnStatement>
- <code>$result</code>
+ <code><![CDATA[$result]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
<code><![CDATA[list<array{id: int, url: string, url_hash: string, shared_secret: ?string, status: int, sync_token: ?string}>]]></code>
</MoreSpecificReturnType>
</file>
- <file src="apps/federation/lib/Listener/SabrePluginAuthInitListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/federation/lib/TrustedServers.php">
- <LessSpecificReturnStatement>
- <code><![CDATA[$this->dbHandler->getAllServer()]]></code>
- </LessSpecificReturnStatement>
- <MoreSpecificReturnType>
- <code><![CDATA[list<array{id: int, url: string, url_hash: string, shared_secret: string, status: int, sync_token: string}>]]></code>
- </MoreSpecificReturnType>
- </file>
- <file src="apps/files/ajax/download.php">
- <InvalidArgument>
- <code>$files_list</code>
- </InvalidArgument>
- </file>
<file src="apps/files/lib/Activity/Provider.php">
<FalsableReturnStatement>
<code><![CDATA[$this->fileEncrypted[$fileId]]]></code>
</FalsableReturnStatement>
<LessSpecificReturnStatement>
- <code>$folder</code>
+ <code><![CDATA[$folder]]></code>
<code><![CDATA[$this->fileEncrypted[$fileId]]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>Folder</code>
+ <code><![CDATA[Folder]]></code>
</MoreSpecificReturnType>
<TypeDoesNotContainType>
<code><![CDATA[$this->fileIsEncrypted]]></code>
@@ -1016,63 +783,50 @@
</file>
<file src="apps/files/lib/Command/ScanAppData.php">
<NullArgument>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="apps/files/lib/Controller/DirectEditingController.php">
<InvalidArgument>
- <code>$templateId</code>
+ <code><![CDATA[$templateId]]></code>
</InvalidArgument>
<UndefinedInterfaceMethod>
- <code>getTemplates</code>
- <code>open</code>
+ <code><![CDATA[getTemplates]]></code>
+ <code><![CDATA[open]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/files/lib/Helper.php">
<UndefinedInterfaceMethod>
- <code>$file</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
- <code>$i</code>
+ <code><![CDATA[$file]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
+ <code><![CDATA[$i]]></code>
</UndefinedInterfaceMethod>
</file>
- <file src="apps/files/lib/Listener/LoadSidebarListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/files/lib/Listener/RenderReferenceEventListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/files/lib/Service/OwnershipTransferService.php">
- <TypeDoesNotContainType>
- <code>empty($encryptedFiles)</code>
- </TypeDoesNotContainType>
<UndefinedInterfaceMethod>
- <code>isReadyForUser</code>
+ <code><![CDATA[isReadyForUser]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/files_external/appinfo/routes.php">
<InvalidScope>
- <code>$this</code>
+ <code><![CDATA[$this]]></code>
</InvalidScope>
</file>
<file src="apps/files_external/lib/Controller/StoragesController.php">
<RedundantCast>
<code><![CDATA[(int)$e->getCode()]]></code>
- <code>(int)$status</code>
+ <code><![CDATA[(int)$status]]></code>
</RedundantCast>
</file>
<file src="apps/files_external/lib/Lib/Backend/Backend.php">
@@ -1085,7 +839,7 @@
</file>
<file src="apps/files_external/lib/Lib/Storage/SFTP.php">
<InternalMethod>
- <code>put</code>
+ <code><![CDATA[put]]></code>
</InternalMethod>
</file>
<file src="apps/files_external/lib/Lib/Storage/SMB.php">
@@ -1104,100 +858,56 @@
<code><![CDATA[$object->lastModified]]></code>
</InvalidArgument>
<InvalidNullableReturnType>
- <code>filetype</code>
- <code>fopen</code>
+ <code><![CDATA[filetype]]></code>
+ <code><![CDATA[fopen]]></code>
</InvalidNullableReturnType>
</file>
- <file src="apps/files_external/lib/Listener/GroupDeletedListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/files_external/lib/Listener/StorePasswordListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/files_external/lib/Listener/UserDeletedListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/files_external/lib/Migration/DummyUserSession.php">
<InvalidReturnType>
- <code>login</code>
+ <code><![CDATA[login]]></code>
</InvalidReturnType>
</file>
<file src="apps/files_external/lib/MountConfig.php">
<InternalMethod>
- <code>decrypt</code>
- <code>encrypt</code>
- <code>setIV</code>
- <code>setIV</code>
+ <code><![CDATA[decrypt]]></code>
+ <code><![CDATA[encrypt]]></code>
+ <code><![CDATA[setIV]]></code>
+ <code><![CDATA[setIV]]></code>
+ <code><![CDATA[setKey]]></code>
</InternalMethod>
<TooManyArguments>
- <code>test</code>
+ <code><![CDATA[test]]></code>
</TooManyArguments>
</file>
<file src="apps/files_sharing/lib/Controller/ShareAPIController.php">
<RedundantCast>
- <code>(int)$code</code>
- <code>(int)$code</code>
+ <code><![CDATA[(int)$code]]></code>
+ <code><![CDATA[(int)$code]]></code>
</RedundantCast>
<UndefinedClass>
- <code>\OCA\Circles\Api\v1\Circles</code>
- <code>\OCA\Circles\Api\v1\Circles</code>
+ <code><![CDATA[\OCA\Circles\Api\v1\Circles]]></code>
+ <code><![CDATA[\OCA\Circles\Api\v1\Circles]]></code>
</UndefinedClass>
<UndefinedDocblockClass>
<code><![CDATA[$this->getRoomShareHelper()]]></code>
<code><![CDATA[$this->getRoomShareHelper()]]></code>
<code><![CDATA[$this->getRoomShareHelper()]]></code>
- <code>\OCA\Talk\Share\Helper\ShareAPIController</code>
+ <code><![CDATA[\OCA\Talk\Share\Helper\ShareAPIController]]></code>
</UndefinedDocblockClass>
</file>
- <file src="apps/files_sharing/lib/Controller/ShareController.php">
- <InvalidArgument>
- <code>$files_list</code>
- </InvalidArgument>
- </file>
<file src="apps/files_sharing/lib/External/Manager.php">
<LessSpecificReturnStatement>
- <code>$mount</code>
+ <code><![CDATA[$mount]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>Mount</code>
+ <code><![CDATA[Mount]]></code>
</MoreSpecificReturnType>
</file>
<file src="apps/files_sharing/lib/External/Scanner.php">
<MoreSpecificImplementedParamType>
- <code>$cacheData</code>
+ <code><![CDATA[$cacheData]]></code>
</MoreSpecificImplementedParamType>
</file>
- <file src="apps/files_sharing/lib/Listener/LoadAdditionalListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/files_sharing/lib/Listener/LoadSidebarListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/files_sharing/lib/Listener/ShareInteractionListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/files_sharing/lib/Listener/UserAddedToGroupListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/files_sharing/lib/Listener/UserShareAcceptanceListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/files_sharing/lib/Middleware/SharingCheckMiddleware.php">
<InvalidArgument>
<code><![CDATA[$exception->getMessage()]]></code>
@@ -1205,26 +915,26 @@
</file>
<file src="apps/files_sharing/lib/MountProvider.php">
<RedundantFunctionCall>
- <code>array_values</code>
+ <code><![CDATA[array_values]]></code>
</RedundantFunctionCall>
</file>
<file src="apps/files_sharing/lib/ShareBackend/File.php">
<InvalidArgument>
- <code>$itemSource</code>
- <code>$itemSource</code>
+ <code><![CDATA[$itemSource]]></code>
+ <code><![CDATA[$itemSource]]></code>
</InvalidArgument>
<MoreSpecificImplementedParamType>
- <code>$shareWith</code>
+ <code><![CDATA[$shareWith]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="apps/files_sharing/lib/ShareBackend/Folder.php">
<UndefinedInterfaceMethod>
- <code>fetchRow</code>
+ <code><![CDATA[fetchRow]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/files_sharing/lib/SharedMount.php">
<InvalidReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidReturnType>
</file>
<file src="apps/files_sharing/lib/SharedStorage.php">
@@ -1232,10 +942,10 @@
<code><![CDATA[$this->sourceRootInfo]]></code>
</FalsableReturnStatement>
<InvalidNullableReturnType>
- <code>ICacheEntry</code>
+ <code><![CDATA[ICacheEntry]]></code>
</InvalidNullableReturnType>
<InvalidReturnStatement>
- <code>new FailedCache()</code>
+ <code><![CDATA[new FailedCache()]]></code>
</InvalidReturnStatement>
<NullableReturnStatement>
<code><![CDATA[$this->sourceRootInfo]]></code>
@@ -1243,23 +953,18 @@
</file>
<file src="apps/files_sharing/lib/Updater.php">
<UndefinedMethod>
- <code>moveMount</code>
+ <code><![CDATA[moveMount]]></code>
</UndefinedMethod>
</file>
<file src="apps/files_sharing/templates/public.php">
<RedundantCondition>
- <code>$_['hideFileList'] !== true</code>
+ <code><![CDATA[$_['hideFileList'] !== true]]></code>
<code><![CDATA[isset($_['hideFileList']) && $_['hideFileList'] !== true]]></code>
</RedundantCondition>
</file>
- <file src="apps/files_trashbin/lib/Listeners/LoadAdditionalScripts.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/files_trashbin/lib/Sabre/AbstractTrash.php">
<InvalidNullableReturnType>
- <code>int</code>
+ <code><![CDATA[int]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
<code><![CDATA[$this->data->getId()]]></code>
@@ -1267,88 +972,66 @@
</file>
<file src="apps/files_trashbin/lib/Sabre/AbstractTrashFolder.php">
<InvalidReturnStatement>
- <code>$entry</code>
+ <code><![CDATA[$entry]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>ITrash</code>
+ <code><![CDATA[ITrash]]></code>
</InvalidReturnType>
</file>
<file src="apps/files_trashbin/lib/Sabre/RestoreFolder.php">
<InvalidNullableReturnType>
- <code>getChild</code>
+ <code><![CDATA[getChild]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="apps/files_trashbin/lib/Sabre/RootCollection.php">
<MismatchingDocblockReturnType>
- <code>INode</code>
+ <code><![CDATA[INode]]></code>
</MismatchingDocblockReturnType>
</file>
<file src="apps/files_trashbin/lib/Sabre/TrashRoot.php">
<InvalidReturnStatement>
- <code>$entry</code>
+ <code><![CDATA[$entry]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>ITrash</code>
+ <code><![CDATA[ITrash]]></code>
</InvalidReturnType>
</file>
<file src="apps/files_trashbin/lib/Trash/LegacyTrashBackend.php">
- <RedundantCondition>
- <code>$trashFiles</code>
- </RedundantCondition>
- <TypeDoesNotContainType>
- <code>null</code>
- </TypeDoesNotContainType>
<UndefinedInterfaceMethod>
- <code>$file</code>
- <code>getById</code>
+ <code><![CDATA[$file]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/files_trashbin/lib/Trashbin.php">
<FalsableReturnStatement>
- <code>false</code>
+ <code><![CDATA[false]]></code>
</FalsableReturnStatement>
<InvalidArgument>
- <code>$timestamp</code>
+ <code><![CDATA[$timestamp]]></code>
</InvalidArgument>
<InvalidScalarArgument>
- <code>$timestamp</code>
+ <code><![CDATA[$timestamp]]></code>
</InvalidScalarArgument>
</file>
<file src="apps/files_versions/appinfo/routes.php">
<InvalidScope>
- <code>$this</code>
- <code>$this</code>
+ <code><![CDATA[$this]]></code>
+ <code><![CDATA[$this]]></code>
</InvalidScope>
</file>
- <file src="apps/files_versions/lib/Listener/FileEventsListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/files_versions/lib/Listener/LoadAdditionalListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/files_versions/lib/Listener/LoadSidebarListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/files_versions/lib/Sabre/RestoreFolder.php">
<InvalidNullableReturnType>
- <code>getChild</code>
+ <code><![CDATA[getChild]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="apps/files_versions/lib/Sabre/VersionHome.php">
<InvalidNullableReturnType>
- <code>getChild</code>
+ <code><![CDATA[getChild]]></code>
</InvalidNullableReturnType>
</file>
<file src="apps/files_versions/lib/Storage.php">
@@ -1368,31 +1051,23 @@
</file>
<file src="apps/provisioning_api/lib/Controller/UsersController.php">
<TypeDoesNotContainNull>
- <code>$groupid === null</code>
- <code>$groupid === null</code>
+ <code><![CDATA[$groupid === null]]></code>
+ <code><![CDATA[$groupid === null]]></code>
</TypeDoesNotContainNull>
</file>
- <file src="apps/provisioning_api/lib/Listener/UserDeletedListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/provisioning_api/lib/Middleware/ProvisioningApiMiddleware.php">
<InvalidReturnType>
- <code>Response</code>
+ <code><![CDATA[Response]]></code>
</InvalidReturnType>
</file>
<file src="apps/settings/lib/AppInfo/Application.php">
- <InvalidArgument>
- <code>AppPasswordCreatedActivityListener::class</code>
- </InvalidArgument>
<UndefinedInterfaceMethod>
- <code>getSettingsManager</code>
+ <code><![CDATA[getSettingsManager]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/settings/lib/Controller/AppSettingsController.php">
<UndefinedInterfaceMethod>
- <code>ignoreNextcloudRequirementForApp</code>
+ <code><![CDATA[ignoreNextcloudRequirementForApp]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/settings/lib/Hooks.php">
@@ -1400,42 +1075,21 @@
<code><![CDATA[[$user->getEMailAddress() => $user->getDisplayName()]]]></code>
</InvalidArrayOffset>
</file>
- <file src="apps/settings/lib/Listener/GroupRemovedListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/settings/lib/Listener/UserAddedToGroupActivityListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/settings/lib/Listener/UserRemovedFromGroupActivityListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/settings/lib/Settings/Admin/Security.php">
<UndefinedInterfaceMethod>
- <code>isReady</code>
+ <code><![CDATA[isReady]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="apps/settings/lib/Settings/Admin/Sharing.php">
<NullArgument>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="apps/sharebymail/lib/ShareByMailProvider.php">
<InvalidArgument>
<code><![CDATA[$share->getId()]]></code>
- <code>(int)$data['id']</code>
+ <code><![CDATA[(int)$data['id']]]></code>
</InvalidArgument>
- <LessSpecificReturnStatement>
- <code>$nodes[0]</code>
- </LessSpecificReturnStatement>
- <MoreSpecificReturnType>
- <code>\OCP\Files\File|\OCP\Files\Folder</code>
- </MoreSpecificReturnType>
</file>
<file src="apps/systemtags/lib/Activity/Listener.php">
<InvalidArgument>
@@ -1443,84 +1097,31 @@
<code><![CDATA[$event->getObjectId()]]></code>
</InvalidArgument>
</file>
- <file src="apps/theming/lib/Jobs/MigrateBackgroundImages.php">
- <OverriddenInterfaceConstant>
- <code>TIME_SENSITIVE</code>
- </OverriddenInterfaceConstant>
- </file>
- <file src="apps/theming/lib/Listener/BeforePreferenceListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/theming/lib/Listener/BeforeTemplateRenderedListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/theming/lib/Util.php">
<InvalidReturnStatement>
<code><![CDATA[array_values($color->getRgb())]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>array{0: int, 1: int, 2: int}</code>
+ <code><![CDATA[array{0: int, 1: int, 2: int}]]></code>
</InvalidReturnType>
</file>
- <file src="apps/twofactor_backupcodes/lib/Listener/ActivityPublisher.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/twofactor_backupcodes/lib/Listener/ClearNotifications.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/twofactor_backupcodes/lib/Listener/ProviderDisabled.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/twofactor_backupcodes/lib/Listener/ProviderEnabled.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/twofactor_backupcodes/lib/Listener/RegistryUpdater.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/twofactor_backupcodes/lib/Listener/UserDeleted.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/updatenotification/lib/Notification/BackgroundJob.php">
- <InvalidArgument>
- <code>false</code>
- </InvalidArgument>
- <InvalidPropertyAssignmentValue>
- <code><![CDATA[$this->users]]></code>
- </InvalidPropertyAssignmentValue>
- </file>
<file src="apps/user_ldap/ajax/getNewServerConfigPrefix.php">
<InvalidScalarArgument>
- <code>$ln + 1</code>
+ <code><![CDATA[$ln + 1]]></code>
</InvalidScalarArgument>
</file>
<file src="apps/user_ldap/appinfo/routes.php">
<InvalidScope>
- <code>$this</code>
+ <code><![CDATA[$this]]></code>
</InvalidScope>
</file>
<file src="apps/user_ldap/lib/Access.php">
<InvalidReturnStatement>
- <code>$uuid</code>
- <code>$values</code>
+ <code><![CDATA[$uuid]]></code>
+ <code><![CDATA[$values]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string[]</code>
+ <code><![CDATA[string[]]]></code>
</InvalidReturnType>
<RedundantCast>
<code><![CDATA[(int)$e->getCode()]]></code>
@@ -1528,48 +1129,43 @@
</file>
<file src="apps/user_ldap/lib/Connection.php">
<NoValue>
- <code>$subj</code>
+ <code><![CDATA[$subj]]></code>
</NoValue>
<ParadoxicalCondition>
- <code>default:
+ <code><![CDATA[default:
$subj = $key;
- break;</code>
+ break;]]></code>
</ParadoxicalCondition>
</file>
<file src="apps/user_ldap/lib/Group_LDAP.php">
<InvalidScalarArgument>
- <code>$groupID</code>
+ <code><![CDATA[$groupID]]></code>
</InvalidScalarArgument>
</file>
<file src="apps/user_ldap/lib/Group_Proxy.php">
<ParamNameMismatch>
- <code>$gid</code>
+ <code><![CDATA[$gid]]></code>
</ParamNameMismatch>
</file>
<file src="apps/user_ldap/lib/Jobs/Sync.php">
<InvalidOperand>
- <code>$i</code>
+ <code><![CDATA[$i]]></code>
</InvalidOperand>
<NullArgument>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="apps/user_ldap/lib/Mapping/AbstractMapping.php">
<RedundantCondition>
- <code>isset($qb)</code>
+ <code><![CDATA[isset($qb)]]></code>
</RedundantCondition>
<TypeDoesNotContainNull>
- <code>isset($qb)</code>
+ <code><![CDATA[isset($qb)]]></code>
</TypeDoesNotContainNull>
</file>
- <file src="apps/user_ldap/lib/Proxy.php">
- <InvalidDocblock>
- <code>protected function handleRequest($id, $method, $parameters, $passOnWhen = false) {</code>
- </InvalidDocblock>
- </file>
<file src="apps/user_ldap/lib/User/Manager.php">
<InvalidDocblock>
- <code>public function setLdapAccess(Access $access) {</code>
+ <code><![CDATA[public function setLdapAccess(Access $access) {]]></code>
</InvalidDocblock>
</file>
<file src="apps/user_ldap/lib/User/User.php">
@@ -1580,7 +1176,7 @@
<code><![CDATA[$this->refreshedFeatures]]></code>
</InvalidPropertyAssignmentValue>
<InvalidReturnType>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</InvalidReturnType>
<RedundantCondition>
<code><![CDATA[$aQuota && (count($aQuota) > 0)]]></code>
@@ -1588,53 +1184,38 @@
</file>
<file src="apps/user_ldap/lib/User_LDAP.php">
<ImplementedReturnTypeMismatch>
- <code>string|false</code>
+ <code><![CDATA[string|false]]></code>
</ImplementedReturnTypeMismatch>
<MoreSpecificImplementedParamType>
- <code>$limit</code>
- <code>$offset</code>
+ <code><![CDATA[$limit]]></code>
+ <code><![CDATA[$offset]]></code>
</MoreSpecificImplementedParamType>
<NullableReturnStatement>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
<RedundantCondition>
<code><![CDATA[$displayName && (count($displayName) > 0)]]></code>
- <code>is_string($dn)</code>
+ <code><![CDATA[is_string($dn)]]></code>
</RedundantCondition>
</file>
<file src="apps/user_ldap/lib/User_Proxy.php">
<ParamNameMismatch>
- <code>$uid</code>
+ <code><![CDATA[$uid]]></code>
</ParamNameMismatch>
</file>
<file src="apps/user_ldap/lib/Wizard.php">
<InvalidArrayOffset>
- <code>$possibleAttrs[$i]</code>
+ <code><![CDATA[$possibleAttrs[$i]]]></code>
</InvalidArrayOffset>
</file>
<file src="apps/user_status/lib/AppInfo/Application.php">
<UndefinedInterfaceMethod>
- <code>registerProvider</code>
+ <code><![CDATA[registerProvider]]></code>
</UndefinedInterfaceMethod>
</file>
- <file src="apps/user_status/lib/Listener/BeforeTemplateRenderedListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/user_status/lib/Listener/UserDeletedListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="apps/user_status/lib/Listener/UserLiveStatusListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="apps/workflowengine/lib/Check/AbstractStringCheck.php">
<NullArgument>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="apps/workflowengine/lib/Check/FileSize.php">
@@ -1642,13 +1223,13 @@
<code><![CDATA[$this->size]]></code>
</FalsableReturnStatement>
<InvalidPropertyAssignmentValue>
- <code>$size</code>
+ <code><![CDATA[$size]]></code>
</InvalidPropertyAssignmentValue>
<InvalidReturnStatement>
<code><![CDATA[$this->size]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidReturnType>
</file>
<file src="apps/workflowengine/lib/Check/FileSystemTags.php">
@@ -1658,16 +1239,16 @@
</file>
<file src="apps/workflowengine/lib/Check/RequestRemoteAddress.php">
<InvalidArgument>
- <code>$decodedValue[1]</code>
- <code>$decodedValue[1]</code>
- <code>$decodedValue[1]</code>
- <code>$decodedValue[1]</code>
+ <code><![CDATA[$decodedValue[1]]]></code>
+ <code><![CDATA[$decodedValue[1]]]></code>
+ <code><![CDATA[$decodedValue[1]]]></code>
+ <code><![CDATA[$decodedValue[1]]]></code>
</InvalidArgument>
</file>
<file src="apps/workflowengine/lib/Check/RequestTime.php">
<InvalidScalarArgument>
- <code>$hour1</code>
- <code>$minute1</code>
+ <code><![CDATA[$hour1]]></code>
+ <code><![CDATA[$minute1]]></code>
</InvalidScalarArgument>
</file>
<file src="apps/workflowengine/lib/Check/TFileCheck.php">
@@ -1677,74 +1258,46 @@
</file>
<file src="apps/workflowengine/lib/Entity/File.php">
<InvalidReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidReturnType>
- <ParamNameMismatch>
- <code>$uid</code>
- </ParamNameMismatch>
- </file>
- <file src="apps/workflowengine/lib/Listener/LoadAdditionalSettingsScriptsListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
</file>
<file src="apps/workflowengine/lib/Manager.php">
<InvalidArgument>
- <code>$missingCheck</code>
+ <code><![CDATA[$missingCheck]]></code>
</InvalidArgument>
<InvalidOperand>
- <code>$result</code>
+ <code><![CDATA[$result]]></code>
</InvalidOperand>
<InvalidReturnStatement>
- <code>$result</code>
+ <code><![CDATA[$result]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidReturnType>
</file>
<file src="apps/workflowengine/lib/Service/RuleMatcher.php">
<UndefinedInterfaceMethod>
- <code>getAllConfiguredScopesForOperation</code>
- <code>getChecks</code>
- <code>getOperations</code>
- <code>getOperations</code>
- <code>isUserScopeEnabled</code>
+ <code><![CDATA[getAllConfiguredScopesForOperation]]></code>
+ <code><![CDATA[getChecks]]></code>
+ <code><![CDATA[getOperations]]></code>
+ <code><![CDATA[getOperations]]></code>
+ <code><![CDATA[isUserScopeEnabled]]></code>
</UndefinedInterfaceMethod>
</file>
- <file src="core/BackgroundJobs/BackgroundCleanupUpdaterBackupsJob.php">
- <ParamNameMismatch>
- <code>$arguments</code>
- </ParamNameMismatch>
- </file>
<file src="core/BackgroundJobs/CheckForUserCertificates.php">
<ParamNameMismatch>
- <code>$arguments</code>
+ <code><![CDATA[$arguments]]></code>
</ParamNameMismatch>
</file>
- <file src="core/BackgroundJobs/LookupServerSendCheckBackgroundJob.php">
- <ParamNameMismatch>
- <code>$arguments</code>
- </ParamNameMismatch>
- </file>
- <file src="core/Command/App/Install.php">
- <TypeDoesNotContainType>
- <code>$result === false</code>
- </TypeDoesNotContainType>
- </file>
<file src="core/Command/App/ListApps.php">
<LessSpecificImplementedReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</LessSpecificImplementedReturnType>
</file>
- <file src="core/Command/App/Update.php">
- <RedundantCondition>
- <code>$result === true</code>
- </RedundantCondition>
- </file>
<file src="core/Command/Config/Import.php">
<InvalidScalarArgument>
- <code>0</code>
- <code>1</code>
+ <code><![CDATA[0]]></code>
+ <code><![CDATA[1]]></code>
</InvalidScalarArgument>
</file>
<file src="core/Command/Config/ListConfigs.php">
@@ -1752,31 +1305,31 @@
<code><![CDATA[$this->appConfig->getValues($app, false)]]></code>
</FalsableReturnStatement>
<TooManyArguments>
- <code>getFilteredValues</code>
+ <code><![CDATA[getFilteredValues]]></code>
</TooManyArguments>
</file>
<file src="core/Command/Db/ConvertType.php">
<InvalidScalarArgument>
- <code>0</code>
- <code>1</code>
+ <code><![CDATA[0]]></code>
+ <code><![CDATA[1]]></code>
</InvalidScalarArgument>
</file>
<file src="core/Command/Encryption/Enable.php">
<NullArgument>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="core/Command/Log/File.php">
<InvalidReturnStatement>
- <code>[0]</code>
+ <code><![CDATA[[0]]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string[]</code>
+ <code><![CDATA[string[]]]></code>
</InvalidReturnType>
</file>
<file src="core/Command/Log/Manage.php">
<InvalidArgument>
- <code>$levelNum</code>
+ <code><![CDATA[$levelNum]]></code>
</InvalidArgument>
</file>
<file src="core/Command/Maintenance/DataFingerprint.php">
@@ -1786,39 +1339,29 @@
</file>
<file src="core/Command/Maintenance/Mimetype/UpdateDB.php">
<UndefinedInterfaceMethod>
- <code>getAllMappings</code>
- <code>updateFilecache</code>
+ <code><![CDATA[getAllMappings]]></code>
+ <code><![CDATA[updateFilecache]]></code>
</UndefinedInterfaceMethod>
</file>
- <file src="core/Command/Maintenance/RepairShareOwnership.php">
- <LessSpecificReturnStatement>
- <code>$found</code>
- <code>$found</code>
- </LessSpecificReturnStatement>
- <MoreSpecificReturnType>
- <code>array{shareId: int, fileTarget: string, initiator: string, receiver: string, owner: string, mountOwner: string}[]</code>
- <code>array{shareId: int, fileTarget: string, initiator: string, receiver: string, owner: string, mountOwner: string}[]</code>
- </MoreSpecificReturnType>
- </file>
<file src="core/Command/Preview/Repair.php">
<UndefinedInterfaceMethod>
- <code>section</code>
- <code>section</code>
+ <code><![CDATA[section]]></code>
+ <code><![CDATA[section]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="core/Command/Preview/ResetRenderedTexts.php">
<InvalidReturnStatement>
- <code>[]</code>
+ <code><![CDATA[[]]]></code>
</InvalidReturnStatement>
</file>
<file src="core/Controller/ClientFlowLoginV2Controller.php">
<TypeDoesNotContainType>
- <code>!is_string($stateToken)</code>
+ <code><![CDATA[!is_string($stateToken)]]></code>
</TypeDoesNotContainType>
</file>
<file src="core/Controller/CollaborationResourcesController.php">
<UndefinedInterfaceMethod>
- <code>searchCollections</code>
+ <code><![CDATA[searchCollections]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="core/Controller/LostController.php">
@@ -1828,14 +1371,9 @@
</file>
<file src="core/Controller/UnifiedSearchController.php">
<UndefinedInterfaceMethod>
- <code>findMatchingRoute</code>
+ <code><![CDATA[findMatchingRoute]]></code>
</UndefinedInterfaceMethod>
</file>
- <file src="core/Listener/BeforeTemplateRenderedListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="core/Middleware/TwoFactorMiddleware.php">
<NoInterfaceProperties>
<code><![CDATA[$this->request->server]]></code>
@@ -1843,14 +1381,13 @@
</file>
<file src="core/routes.php">
<InvalidScope>
- <code>$this</code>
- <code>$this</code>
+ <code><![CDATA[$this]]></code>
<code><![CDATA[$this->create('core_ajax_update', '/core/ajax/update.php')]]></code>
</InvalidScope>
</file>
<file src="core/templates/layout.public.php">
<UndefinedInterfaceMethod>
- <code>getIcon</code>
+ <code><![CDATA[getIcon]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/autoloader.php">
@@ -1860,14 +1397,9 @@
</file>
<file src="lib/base.php">
<InvalidArgument>
- <code>$restrictions</code>
+ <code><![CDATA[$restrictions]]></code>
</InvalidArgument>
</file>
- <file src="lib/private/Activity/Event.php">
- <ParamNameMismatch>
- <code>$affectedUser</code>
- </ParamNameMismatch>
- </file>
<file src="lib/private/Activity/Manager.php">
<InvalidPropertyAssignmentValue>
<code><![CDATA[$this->filterClasses]]></code>
@@ -1878,57 +1410,51 @@
<code><![CDATA[$this->settings]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>ActivitySettings[]</code>
+ <code><![CDATA[ActivitySettings[]]]></code>
</MoreSpecificReturnType>
- <TypeDoesNotContainType>
- <code><![CDATA[!is_string($currentUserId) && $currentUserId !== null]]></code>
- </TypeDoesNotContainType>
</file>
<file src="lib/private/AllConfig.php">
<MoreSpecificImplementedParamType>
- <code>$key</code>
+ <code><![CDATA[$key]]></code>
</MoreSpecificImplementedParamType>
<TypeDoesNotContainType>
- <code>!is_array($userIds)</code>
+ <code><![CDATA[!is_array($userIds)]]></code>
</TypeDoesNotContainType>
</file>
<file src="lib/private/App/AppManager.php">
<LessSpecificImplementedReturnType>
- <code>array</code>
- <code>array</code>
+ <code><![CDATA[array]]></code>
+ <code><![CDATA[array]]></code>
</LessSpecificImplementedReturnType>
</file>
<file src="lib/private/App/AppStore/Fetcher/Fetcher.php">
<TooManyArguments>
- <code>fetch</code>
+ <code><![CDATA[fetch]]></code>
</TooManyArguments>
</file>
<file src="lib/private/App/DependencyAnalyzer.php">
<InvalidNullableReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>version_compare($first, $second, $operator)</code>
+ <code><![CDATA[version_compare($first, $second, $operator)]]></code>
</NullableReturnStatement>
</file>
<file src="lib/private/App/InfoParser.php">
<InvalidArrayOffset>
- <code>$array[$element][]</code>
- <code>$array[$element][]</code>
+ <code><![CDATA[$array[$element][]]]></code>
+ <code><![CDATA[$array[$element][]]]></code>
</InvalidArrayOffset>
<InvalidReturnStatement>
- <code>(string)$xml</code>
+ <code><![CDATA[(string)$xml]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/AppConfig.php">
- <FalsableReturnStatement>
- <code>$values</code>
- </FalsableReturnStatement>
<NullableReturnStatement>
- <code>$default</code>
+ <code><![CDATA[$this->fastCache[$app][$key] ?? $default]]></code>
</NullableReturnStatement>
</file>
<file src="lib/private/AppFramework/Bootstrap/Coordinator.php">
@@ -1938,22 +1464,21 @@
</file>
<file src="lib/private/AppFramework/Bootstrap/FunctionInjector.php">
<UndefinedMethod>
- <code>getName</code>
+ <code><![CDATA[getName]]></code>
</UndefinedMethod>
</file>
<file src="lib/private/AppFramework/DependencyInjection/DIContainer.php">
<ImplementedReturnTypeMismatch>
- <code>boolean|null</code>
+ <code><![CDATA[boolean|null]]></code>
</ImplementedReturnTypeMismatch>
<InvalidReturnStatement>
<code><![CDATA[$this->server]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>\OCP\IServerContainer</code>
- <code>mixed</code>
+ <code><![CDATA[\OCP\IServerContainer]]></code>
</InvalidReturnType>
<UndefinedInterfaceMethod>
- <code>getAppDataDir</code>
+ <code><![CDATA[getAppDataDir]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/AppFramework/Http/Dispatcher.php">
@@ -1961,48 +1486,41 @@
<code><![CDATA[$this->request->method]]></code>
</NoInterfaceProperties>
<NullArgument>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="lib/private/AppFramework/Http/Output.php">
<InvalidReturnStatement>
- <code>@readfile($path)</code>
- <code>http_response_code()</code>
+ <code><![CDATA[@readfile($path)]]></code>
+ <code><![CDATA[http_response_code()]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>bool</code>
- <code>int</code>
+ <code><![CDATA[bool]]></code>
+ <code><![CDATA[int]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/AppFramework/Http/Request.php">
- <MissingTemplateParam>
- <code>\ArrayAccess</code>
- </MissingTemplateParam>
<NullableReturnStatement>
- <code>$name</code>
- <code>$remoteAddress</code>
<code><![CDATA[$this->getOverwriteHost()]]></code>
- <code><![CDATA[$this->method]]></code>
- <code>$uri</code>
<code><![CDATA[isset($this->cookies[$key]) ? $this->cookies[$key] : null]]></code>
<code><![CDATA[isset($this->env[$key]) ? $this->env[$key] : null]]></code>
<code><![CDATA[isset($this->files[$key]) ? $this->files[$key] : null]]></code>
</NullableReturnStatement>
<RedundantCondition>
- <code>\is_array($params)</code>
+ <code><![CDATA[\is_array($params)]]></code>
</RedundantCondition>
<UndefinedFunction>
- <code>\Sabre\HTTP\decodePath($pathInfo)</code>
+ <code><![CDATA[\Sabre\HTTP\decodePath($pathInfo)]]></code>
</UndefinedFunction>
</file>
<file src="lib/private/AppFramework/Logger.php">
<InvalidReturnType>
- <code>log</code>
+ <code><![CDATA[log]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/AppFramework/Middleware/OCSMiddleware.php">
<InternalMethod>
- <code>setOCSVersion</code>
+ <code><![CDATA[setOCSVersion]]></code>
</InternalMethod>
</file>
<file src="lib/private/AppFramework/Middleware/Security/CORSMiddleware.php">
@@ -2016,17 +1534,17 @@
<code><![CDATA[$this->request->server]]></code>
</NoInterfaceProperties>
<UndefinedClass>
- <code>\OCA\Talk\Controller\PageController</code>
+ <code><![CDATA[\OCA\Talk\Controller\PageController]]></code>
</UndefinedClass>
</file>
<file src="lib/private/AppFramework/Routing/RouteConfig.php">
<InvalidArrayOffset>
- <code>$action['url-postfix']</code>
+ <code><![CDATA[$action['url-postfix']]]></code>
</InvalidArrayOffset>
</file>
<file src="lib/private/AppFramework/Services/AppConfig.php">
<MoreSpecificImplementedParamType>
- <code>$default</code>
+ <code><![CDATA[$default]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="lib/private/AppFramework/Utility/SimpleContainer.php">
@@ -2057,6 +1575,11 @@
try {
return $this->query($resolveName);
} catch (QueryException $e2) {
+ // Pass null if typed and nullable
+ if ($parameter->allowsNull() && ($parameterType instanceof ReflectionNamedType)) {
+ return null;
+ }
+
// don't lose the error we got while trying to query by type
throw new QueryException($e->getMessage(), (int) $e->getCode(), $e);
}
@@ -2067,10 +1590,10 @@
}, $constructor->getParameters()))]]></code>
</LessSpecificReturnStatement>
<MissingTemplateParam>
- <code>ArrayAccess</code>
+ <code><![CDATA[ArrayAccess]]></code>
</MissingTemplateParam>
<MoreSpecificReturnType>
- <code>\stdClass</code>
+ <code><![CDATA[\stdClass]]></code>
</MoreSpecificReturnType>
<RedundantCast>
<code><![CDATA[(int) $e->getCode()]]></code>
@@ -2081,97 +1604,58 @@
<code><![CDATA[$this->tar->extractInString($path)]]></code>
</UndefinedDocblockClass>
</file>
- <file src="lib/private/Authentication/Listeners/UserDeletedFilesCleanupListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
- <file src="lib/private/Authentication/Listeners/UserDeletedWebAuthnCleanupListener.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="lib/private/Authentication/LoginCredentials/Store.php">
<RedundantCondition>
- <code>$trySession</code>
+ <code><![CDATA[$trySession]]></code>
</RedundantCondition>
</file>
- <file src="lib/private/Authentication/Token/IToken.php">
- <AmbiguousConstantInheritance>
- <code>DO_NOT_REMEMBER</code>
- <code>PERMANENT_TOKEN</code>
- <code>REMEMBER</code>
- <code>TEMPORARY_TOKEN</code>
- <code>WIPE_TOKEN</code>
- </AmbiguousConstantInheritance>
- </file>
<file src="lib/private/Authentication/Token/PublicKeyToken.php">
<UndefinedMagicMethod>
- <code>getExpires</code>
- <code>getLastCheck</code>
- <code>getLoginName</code>
- <code>getName</code>
- <code>getPassword</code>
- <code>getRemember</code>
- <code>getScope</code>
- <code>setExpires</code>
- <code>setLastCheck</code>
- <code>setName</code>
- <code>setPassword</code>
- <code>setPasswordInvalid</code>
- <code>setScope</code>
- <code>setScope</code>
- <code>setToken</code>
- <code>setType</code>
+ <code><![CDATA[getExpires]]></code>
+ <code><![CDATA[getLastCheck]]></code>
+ <code><![CDATA[getLoginName]]></code>
+ <code><![CDATA[getName]]></code>
+ <code><![CDATA[getPassword]]></code>
+ <code><![CDATA[getRemember]]></code>
+ <code><![CDATA[getScope]]></code>
+ <code><![CDATA[setExpires]]></code>
+ <code><![CDATA[setLastCheck]]></code>
+ <code><![CDATA[setName]]></code>
+ <code><![CDATA[setPassword]]></code>
+ <code><![CDATA[setPasswordInvalid]]></code>
+ <code><![CDATA[setScope]]></code>
+ <code><![CDATA[setScope]]></code>
+ <code><![CDATA[setToken]]></code>
+ <code><![CDATA[setType]]></code>
</UndefinedMagicMethod>
</file>
- <file src="lib/private/Authentication/TwoFactorAuth/Db/ProviderUserAssignmentDao.php">
- <LessSpecificReturnStatement>
- <code><![CDATA[array_map(function (array $row) {
- return [
- 'provider_id' => $row['provider_id'],
- 'uid' => $row['uid'],
- 'enabled' => 1 === (int) $row['enabled'],
- ];
- }, $rows)]]></code>
- </LessSpecificReturnStatement>
- <MoreSpecificReturnType>
- <code><![CDATA[list<array{provider_id: string, uid: string, enabled: bool}>]]></code>
- </MoreSpecificReturnType>
- </file>
<file src="lib/private/Authentication/TwoFactorAuth/ProviderSet.php">
<InvalidArgument>
<code><![CDATA[$this->providers]]></code>
</InvalidArgument>
<InvalidPropertyAssignmentValue>
<code><![CDATA[$this->providers]]></code>
- <code>[]</code>
+ <code><![CDATA[[]]]></code>
</InvalidPropertyAssignmentValue>
<InvalidReturnStatement>
<code><![CDATA[$this->providers]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>IProvider[]</code>
+ <code><![CDATA[IProvider[]]]></code>
</InvalidReturnType>
<UndefinedInterfaceMethod>
<code><![CDATA[$this->providers]]></code>
</UndefinedInterfaceMethod>
</file>
- <file src="lib/private/BackgroundJob/QueuedJob.php">
- <MoreSpecificImplementedParamType>
- <code>$jobList</code>
- <code>$jobList</code>
- </MoreSpecificImplementedParamType>
- </file>
<file src="lib/private/Cache/CappedMemoryCache.php">
<MissingTemplateParam>
- <code>\ArrayAccess</code>
+ <code><![CDATA[\ArrayAccess]]></code>
</MissingTemplateParam>
</file>
<file src="lib/private/Cache/File.php">
<LessSpecificImplementedReturnType>
- <code>bool|mixed</code>
- <code>bool|mixed</code>
+ <code><![CDATA[bool|mixed]]></code>
+ <code><![CDATA[bool|mixed]]></code>
</LessSpecificImplementedReturnType>
</file>
<file src="lib/private/Calendar/Manager.php">
@@ -2193,7 +1677,7 @@
)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>ICreateFromString[]</code>
+ <code><![CDATA[ICreateFromString[]]]></code>
</MoreSpecificReturnType>
<NamedArgumentNotAllowed>
<code><![CDATA[array_map(function ($registration) use ($principalUri, $calendarUris) {
@@ -2213,25 +1697,17 @@
</file>
<file src="lib/private/Command/CallableJob.php">
<ParamNameMismatch>
- <code>$serializedCallable</code>
+ <code><![CDATA[$serializedCallable]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/Command/ClosureJob.php">
<InvalidArgument>
- <code>[LaravelClosure::class, OpisClosure::class]</code>
+ <code><![CDATA[[LaravelClosure::class]]]></code>
</InvalidArgument>
- <ParamNameMismatch>
- <code>$serializedCallable</code>
- </ParamNameMismatch>
- </file>
- <file src="lib/private/Command/CommandJob.php">
- <ParamNameMismatch>
- <code>$serializedCommand</code>
- </ParamNameMismatch>
</file>
<file src="lib/private/Comments/Manager.php">
<RedundantCast>
- <code>(string)$id</code>
+ <code><![CDATA[(string)$id]]></code>
</RedundantCast>
</file>
<file src="lib/private/Config.php">
@@ -2240,8 +1716,8 @@
<code><![CDATA[$this->set($key, $value)]]></code>
</InvalidOperand>
<UndefinedVariable>
- <code>$CONFIG</code>
- <code>$CONFIG</code>
+ <code><![CDATA[$CONFIG]]></code>
+ <code><![CDATA[$CONFIG]]></code>
</UndefinedVariable>
</file>
<file src="lib/private/Console/Application.php">
@@ -2251,123 +1727,79 @@
</file>
<file src="lib/private/ContactsManager.php">
<InvalidArgument>
- <code>$searchOptions</code>
+ <code><![CDATA[$searchOptions]]></code>
</InvalidArgument>
- <InvalidNullableReturnType>
- <code>IAddressBook</code>
- <code>array</code>
- <code>bool</code>
- </InvalidNullableReturnType>
- <NullableReturnStatement>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- </NullableReturnStatement>
- <ParamNameMismatch>
- <code>$addressBook</code>
- <code>$addressBook</code>
- </ParamNameMismatch>
- </file>
- <file src="lib/private/DB/Adapter.php">
- <InvalidReturnStatement>
- <code><![CDATA[$builder->execute()]]></code>
- </InvalidReturnStatement>
- <InvalidReturnType>
- <code>int</code>
- </InvalidReturnType>
</file>
<file src="lib/private/DB/AdapterMySQL.php">
<InternalMethod>
- <code>getParams</code>
+ <code><![CDATA[getParams]]></code>
</InternalMethod>
<InvalidArrayOffset>
- <code>$params['collation']</code>
+ <code><![CDATA[$params['collation']]]></code>
</InvalidArrayOffset>
</file>
<file src="lib/private/DB/Connection.php">
<InternalMethod>
- <code>getParams</code>
+ <code><![CDATA[getParams]]></code>
</InternalMethod>
<InvalidArgument>
- <code>$params</code>
+ <code><![CDATA[$params]]></code>
</InvalidArgument>
<InvalidArrayOffset>
- <code>$params['adapter']</code>
- <code>$params['tablePrefix']</code>
+ <code><![CDATA[$params['adapter']]]></code>
+ <code><![CDATA[$params['tablePrefix']]]></code>
</InvalidArrayOffset>
- <InvalidReturnStatement>
- <code><![CDATA[$this->adapter->lastInsertId($seqName)]]></code>
- </InvalidReturnStatement>
- <InvalidReturnType>
- <code>string</code>
- </InvalidReturnType>
- <ParamNameMismatch>
- <code>$seqName</code>
- <code>$statement</code>
- </ParamNameMismatch>
</file>
<file src="lib/private/DB/Exceptions/DbalException.php">
<RedundantCondition>
<code><![CDATA[is_int($original->getCode())]]></code>
</RedundantCondition>
<TypeDoesNotContainType>
- <code>0</code>
+ <code><![CDATA[0]]></code>
</TypeDoesNotContainType>
</file>
<file src="lib/private/DB/MigrationService.php">
- <InvalidOperand>
- <code>$offset</code>
- <code>$offset</code>
- </InvalidOperand>
<LessSpecificReturnStatement>
- <code>$s</code>
+ <code><![CDATA[$s]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>IMigrationStep</code>
+ <code><![CDATA[IMigrationStep]]></code>
</MoreSpecificReturnType>
</file>
- <file src="lib/private/DB/OracleConnection.php">
- <InvalidArrayAccess>
- <code>$key[0]</code>
- </InvalidArrayAccess>
- </file>
<file src="lib/private/DB/QueryBuilder/ExpressionBuilder/ExpressionBuilder.php">
<ImplicitToStringCast>
<code><![CDATA[$this->functionBuilder->lower($x)]]></code>
</ImplicitToStringCast>
<InvalidArgument>
- <code>$y</code>
- <code>$y</code>
+ <code><![CDATA[$y]]></code>
+ <code><![CDATA[$y]]></code>
</InvalidArgument>
</file>
<file src="lib/private/DB/QueryBuilder/ExpressionBuilder/MySqlExpressionBuilder.php">
<InternalMethod>
- <code>getParams</code>
+ <code><![CDATA[getParams]]></code>
</InternalMethod>
<InvalidArrayOffset>
- <code>$params['collation']</code>
+ <code><![CDATA[$params['collation']]]></code>
</InvalidArrayOffset>
</file>
<file src="lib/private/DB/QueryBuilder/QueryBuilder.php">
<InvalidNullableReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>$alias</code>
+ <code><![CDATA[$alias]]></code>
</NullableReturnStatement>
<ParamNameMismatch>
- <code>$groupBys</code>
- <code>$selects</code>
+ <code><![CDATA[$selects]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/DB/QueryBuilder/QuoteHelper.php">
<InvalidNullableReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>$string</code>
+ <code><![CDATA[$string]]></code>
</NullableReturnStatement>
</file>
<file src="lib/private/DateTimeFormatter.php">
@@ -2376,35 +1808,31 @@
'width' => $format,
])]]></code>
</FalsableReturnStatement>
- <InvalidDocblock>
- <code>public function formatDateSpan($timestamp, $baseTimestamp = null, \OCP\IL10N $l = null) {</code>
- <code>public function formatTimeSpan($timestamp, $baseTimestamp = null, \OCP\IL10N $l = null) {</code>
- </InvalidDocblock>
<InvalidReturnStatement>
<code><![CDATA[$l->l($type, $timestamp, [
'width' => $format,
])]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/DateTimeZone.php">
<InvalidScalarArgument>
- <code>$timestamp</code>
+ <code><![CDATA[$timestamp]]></code>
</InvalidScalarArgument>
</file>
<file src="lib/private/Diagnostics/Query.php">
<ImplementedReturnTypeMismatch>
- <code>float</code>
+ <code><![CDATA[float]]></code>
</ImplementedReturnTypeMismatch>
</file>
<file src="lib/private/Diagnostics/QueryLogger.php">
<InvalidArgument>
- <code>microtime(true)</code>
+ <code><![CDATA[microtime(true)]]></code>
</InvalidArgument>
<InvalidReturnType>
- <code>stopQuery</code>
+ <code><![CDATA[stopQuery]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/DirectEditing/Manager.php">
@@ -2412,14 +1840,14 @@
<code><![CDATA[$query->execute()]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>TemplateResponse</code>
- <code>int</code>
+ <code><![CDATA[TemplateResponse]]></code>
+ <code><![CDATA[int]]></code>
</InvalidReturnType>
<UndefinedMethod>
- <code>$template</code>
- <code>$template</code>
- <code>$template</code>
- <code>$template</code>
+ <code><![CDATA[$template]]></code>
+ <code><![CDATA[$template]]></code>
+ <code><![CDATA[$template]]></code>
+ <code><![CDATA[$template]]></code>
</UndefinedMethod>
</file>
<file src="lib/private/DirectEditing/Token.php">
@@ -2427,35 +1855,27 @@
<code><![CDATA[$this->manager->getFileForToken($this->data['user_id'], $this->data['file_id'], $this->data['file_path'])]]></code>
</LessSpecificReturnStatement>
<UndefinedMethod>
- <code>getShareForToken</code>
+ <code><![CDATA[getShareForToken]]></code>
</UndefinedMethod>
</file>
- <file src="lib/private/Encryption/File.php">
- <LessSpecificReturnStatement>
- <code><![CDATA[['users' => $uniqueUserIds, 'public' => $public]]]></code>
- </LessSpecificReturnStatement>
- <MoreSpecificReturnType>
- <code>array{users: string[], public: bool}</code>
- </MoreSpecificReturnType>
- </file>
<file src="lib/private/Encryption/Keys/Storage.php">
<InvalidNullableReturnType>
- <code>deleteUserKey</code>
+ <code><![CDATA[deleteUserKey]]></code>
</InvalidNullableReturnType>
<NullArgument>
- <code>null</code>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="lib/private/Encryption/Manager.php">
<ImplementedReturnTypeMismatch>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</ImplementedReturnTypeMismatch>
</file>
<file src="lib/private/Federation/CloudFederationProviderManager.php">
<ParamNameMismatch>
- <code>$providerId</code>
+ <code><![CDATA[$providerId]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/Files/AppData/AppData.php">
@@ -2463,61 +1883,61 @@
<code><![CDATA[$this->folder]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>Folder</code>
+ <code><![CDATA[Folder]]></code>
</MoreSpecificReturnType>
</file>
<file src="lib/private/Files/Cache/Cache.php">
<InvalidArgument>
- <code>$parentData</code>
+ <code><![CDATA[$parentData]]></code>
</InvalidArgument>
<InvalidNullableReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</InvalidNullableReturnType>
<InvalidScalarArgument>
- <code>$path</code>
- <code>\OC_Util::normalizeUnicode($path)</code>
+ <code><![CDATA[$path]]></code>
+ <code><![CDATA[\OC_Util::normalizeUnicode($path)]]></code>
</InvalidScalarArgument>
<NullableReturnStatement>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
<ParamNameMismatch>
- <code>$searchQuery</code>
+ <code><![CDATA[$searchQuery]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/Files/Cache/FailedCache.php">
<InvalidReturnStatement>
- <code>[]</code>
+ <code><![CDATA[[]]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>getIncomplete</code>
- <code>insert</code>
- <code>put</code>
+ <code><![CDATA[getIncomplete]]></code>
+ <code><![CDATA[insert]]></code>
+ <code><![CDATA[put]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Files/Cache/HomeCache.php">
<FalsableReturnStatement>
- <code>$data</code>
+ <code><![CDATA[$data]]></code>
</FalsableReturnStatement>
<MoreSpecificImplementedParamType>
- <code>$file</code>
- <code>$file</code>
+ <code><![CDATA[$file]]></code>
+ <code><![CDATA[$file]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="lib/private/Files/Cache/Scanner.php">
<InvalidArgument>
- <code>self::SCAN_RECURSIVE_INCOMPLETE</code>
+ <code><![CDATA[self::SCAN_RECURSIVE_INCOMPLETE]]></code>
</InvalidArgument>
<InvalidReturnStatement>
- <code>$existingChildren</code>
+ <code><![CDATA[$existingChildren]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>array[]</code>
+ <code><![CDATA[array[]]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Files/Cache/Storage.php">
<InvalidNullableReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
<code><![CDATA[self::getGlobalCache()->getStorageInfo($storageId)]]></code>
@@ -2530,44 +1950,39 @@
</file>
<file src="lib/private/Files/Cache/Wrapper/CacheWrapper.php">
<LessSpecificImplementedReturnType>
- <code>array</code>
- <code>array</code>
+ <code><![CDATA[array]]></code>
+ <code><![CDATA[array]]></code>
</LessSpecificImplementedReturnType>
<ParamNameMismatch>
- <code>$searchQuery</code>
+ <code><![CDATA[$searchQuery]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/Files/Config/MountProviderCollection.php">
<InvalidOperand>
- <code>$user</code>
+ <code><![CDATA[$user]]></code>
</InvalidOperand>
<RedundantCondition>
- <code>get_class($provider) !== 'OCA\Files_Sharing\MountProvider'</code>
+ <code><![CDATA[get_class($provider) !== 'OCA\Files_Sharing\MountProvider']]></code>
</RedundantCondition>
<TypeDoesNotContainType>
- <code>get_class($provider) === 'OCA\Files_Sharing\MountProvider'</code>
+ <code><![CDATA[get_class($provider) === 'OCA\Files_Sharing\MountProvider']]></code>
</TypeDoesNotContainType>
</file>
<file src="lib/private/Files/Config/UserMountCache.php">
<InvalidReturnType>
- <code>remoteStorageMounts</code>
- <code>removeUserStorageMount</code>
+ <code><![CDATA[remoteStorageMounts]]></code>
+ <code><![CDATA[removeUserStorageMount]]></code>
</InvalidReturnType>
<LessSpecificImplementedReturnType>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</LessSpecificImplementedReturnType>
<LessSpecificReturnStatement>
<code><![CDATA[$this->cacheInfoCache[$fileId]]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>array{int, string, int}</code>
+ <code><![CDATA[array{int, string, int}]]></code>
</MoreSpecificReturnType>
</file>
- <file src="lib/private/Files/FileInfo.php">
- <MissingTemplateParam>
- <code>\ArrayAccess</code>
- </MissingTemplateParam>
- </file>
<file src="lib/private/Files/Filesystem.php">
<LessSpecificReturnStatement>
<code><![CDATA[$mount->getStorage()]]></code>
@@ -2575,25 +1990,25 @@
<code><![CDATA[self::getMountManager()->findByStorageId($id)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>Mount\MountPoint[]</code>
- <code>Mount\MountPoint[]</code>
- <code>\OC\Files\Storage\Storage|null</code>
+ <code><![CDATA[Mount\MountPoint[]]]></code>
+ <code><![CDATA[Mount\MountPoint[]]]></code>
+ <code><![CDATA[\OC\Files\Storage\Storage|null]]></code>
</MoreSpecificReturnType>
<TooManyArguments>
- <code>addStorageWrapper</code>
+ <code><![CDATA[addStorageWrapper]]></code>
</TooManyArguments>
</file>
<file src="lib/private/Files/Mount/MountPoint.php">
<UndefinedInterfaceMethod>
- <code>wrap</code>
+ <code><![CDATA[wrap]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/Files/Mount/ObjectHomeMountProvider.php">
<InvalidNullableReturnType>
- <code>\OCP\Files\Mount\IMountPoint</code>
+ <code><![CDATA[\OCP\Files\Mount\IMountPoint]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="lib/private/Files/Node/File.php">
@@ -2601,41 +2016,39 @@
<code><![CDATA[$this->view->hash($type, $this->path, $raw)]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Files/Node/Folder.php">
<LessSpecificReturnStatement>
<code><![CDATA[$this->root->get($this->getFullPath($path))]]></code>
- <code><![CDATA[$this->root->getByIdInPath((int)$id, $this->getPath())]]></code>
<code><![CDATA[array_map(function (FileInfo $file) {
return $this->createNode($file->getPath(), $file);
}, $files)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificImplementedParamType>
- <code>$node</code>
+ <code><![CDATA[$node]]></code>
</MoreSpecificImplementedParamType>
<MoreSpecificReturnType>
- <code>\OC\Files\Node\Node</code>
- <code>\OC\Files\Node\Node[]</code>
- <code>\OC\Files\Node\Node[]</code>
+ <code><![CDATA[\OC\Files\Node\Node]]></code>
+ <code><![CDATA[\OC\Files\Node\Node[]]]></code>
</MoreSpecificReturnType>
</file>
<file src="lib/private/Files/Node/HookConnector.php">
<UndefinedInterfaceMethod>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/Files/Node/LazyFolder.php">
@@ -2645,30 +2058,30 @@
</file>
<file src="lib/private/Files/Node/LazyUserFolder.php">
<LessSpecificReturnStatement>
- <code>$node</code>
+ <code><![CDATA[$node]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>Folder</code>
+ <code><![CDATA[Folder]]></code>
</MoreSpecificReturnType>
</file>
<file src="lib/private/Files/Node/Node.php">
<InvalidNullableReturnType>
- <code>FileInfo</code>
+ <code><![CDATA[FileInfo]]></code>
</InvalidNullableReturnType>
<InvalidReturnType>
- <code>getChecksum</code>
+ <code><![CDATA[getChecksum]]></code>
</InvalidReturnType>
<LessSpecificReturnStatement>
<code><![CDATA[$this->parent]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>INode|IRootFolder</code>
+ <code><![CDATA[INode|IRootFolder]]></code>
</MoreSpecificReturnType>
<NullableReturnStatement>
<code><![CDATA[$this->fileInfo]]></code>
</NullableReturnStatement>
<ParamNameMismatch>
- <code>$type</code>
+ <code><![CDATA[$type]]></code>
</ParamNameMismatch>
<UndefinedInterfaceMethod>
<code><![CDATA[$this->fileInfo]]></code>
@@ -2677,7 +2090,7 @@
</file>
<file src="lib/private/Files/Node/Root.php">
<LessSpecificReturnStatement>
- <code>$folders</code>
+ <code><![CDATA[$folders]]></code>
<code><![CDATA[$this->createNode($fullPath, $fileInfo, false)]]></code>
<code><![CDATA[$this->mountManager->findByNumericId($numericId)]]></code>
<code><![CDATA[$this->mountManager->findByStorageId($storageId)]]></code>
@@ -2685,68 +2098,63 @@
<code><![CDATA[$this->user]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>MountPoint[]</code>
- <code>Node</code>
- <code>\OC\Files\Mount\MountPoint[]</code>
- <code>\OC\Files\Mount\MountPoint[]</code>
- <code>\OC\User\User</code>
+ <code><![CDATA[MountPoint[]]]></code>
+ <code><![CDATA[Node]]></code>
+ <code><![CDATA[\OC\Files\Mount\MountPoint[]]]></code>
+ <code><![CDATA[\OC\Files\Mount\MountPoint[]]]></code>
+ <code><![CDATA[\OC\User\User]]></code>
</MoreSpecificReturnType>
<NullableReturnStatement>
<code><![CDATA[$this->user]]></code>
</NullableReturnStatement>
<UndefinedMethod>
- <code>remove</code>
+ <code><![CDATA[remove]]></code>
</UndefinedMethod>
</file>
- <file src="lib/private/Files/ObjectStore/HomeObjectStoreStorage.php">
- <ImplementedReturnTypeMismatch>
- <code>false|string</code>
- </ImplementedReturnTypeMismatch>
- </file>
<file src="lib/private/Files/ObjectStore/ObjectStoreStorage.php">
<InvalidScalarArgument>
- <code>$source</code>
+ <code><![CDATA[$source]]></code>
</InvalidScalarArgument>
</file>
<file src="lib/private/Files/ObjectStore/S3ConnectionTrait.php">
<InternalClass>
- <code>ClientResolver::_default_signature_provider()</code>
- <code>ClientResolver::_default_signature_provider()</code>
+ <code><![CDATA[ClientResolver::_default_signature_provider()]]></code>
+ <code><![CDATA[ClientResolver::_default_signature_provider()]]></code>
</InternalClass>
<InternalMethod>
- <code>ClientResolver::_default_signature_provider()</code>
+ <code><![CDATA[ClientResolver::_default_signature_provider()]]></code>
</InternalMethod>
<UndefinedFunction>
- <code>Promise\promise_for(
+ <code><![CDATA[Promise\promise_for(
new Credentials($key, $secret)
- )</code>
- <code>\Aws\or_chain([self::class, 'legacySignatureProvider'], ClientResolver::_default_signature_provider())</code>
+ )]]></code>
+ <code><![CDATA[\Aws\or_chain([self::class, 'legacySignatureProvider'], ClientResolver::_default_signature_provider())]]></code>
</UndefinedFunction>
</file>
<file src="lib/private/Files/ObjectStore/S3ObjectTrait.php">
<InternalMethod>
- <code>upload</code>
+ <code><![CDATA[upload]]></code>
</InternalMethod>
<UndefinedFunction>
- <code>\Aws\serialize($command)</code>
+ <code><![CDATA[\Aws\serialize($command)]]></code>
</UndefinedFunction>
</file>
<file src="lib/private/Files/ObjectStore/S3Signature.php">
<NullArgument>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="lib/private/Files/ObjectStore/StorageObjectStore.php">
<InvalidReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Files/Storage/Common.php">
<ImplementedReturnTypeMismatch>
- <code>string|false</code>
+ <code><![CDATA[string|false]]></code>
</ImplementedReturnTypeMismatch>
<InvalidOperand>
- <code>!$permissions</code>
+ <code><![CDATA[!$permissions]]></code>
<code><![CDATA[$this->copyFromStorage($sourceStorage, $sourceInternalPath . '/' . $file, $targetInternalPath . '/' . $file)]]></code>
</InvalidOperand>
<NoInterfaceProperties>
@@ -2762,39 +2170,39 @@
</file>
<file src="lib/private/Files/Storage/DAV.php">
<InvalidClass>
- <code>ArrayCache</code>
- <code>ArrayCache</code>
+ <code><![CDATA[ArrayCache]]></code>
+ <code><![CDATA[ArrayCache]]></code>
</InvalidClass>
<InvalidReturnStatement>
<code><![CDATA[$response->getBody()]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>fopen</code>
+ <code><![CDATA[fopen]]></code>
</InvalidReturnType>
<NullableReturnStatement>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="lib/private/Files/Storage/FailedStorage.php">
<InvalidReturnStatement>
- <code>new FailedCache()</code>
- <code>true</code>
+ <code><![CDATA[new FailedCache()]]></code>
+ <code><![CDATA[true]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>getCache</code>
- <code>verifyPath</code>
+ <code><![CDATA[getCache]]></code>
+ <code><![CDATA[verifyPath]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Files/Storage/Local.php">
<ImplicitToStringCast>
- <code>$file</code>
+ <code><![CDATA[$file]]></code>
</ImplicitToStringCast>
<TypeDoesNotContainNull>
- <code>$space === false || is_null($space)</code>
- <code>is_null($space)</code>
+ <code><![CDATA[$space === false || is_null($space)]]></code>
+ <code><![CDATA[is_null($space)]]></code>
</TypeDoesNotContainNull>
<TypeDoesNotContainType>
- <code>$stat === false</code>
+ <code><![CDATA[$stat === false]]></code>
</TypeDoesNotContainType>
</file>
<file src="lib/private/Files/Storage/LocalRootStorage.php">
@@ -2805,9 +2213,9 @@
</file>
<file src="lib/private/Files/Storage/Wrapper/Encoding.php">
<InvalidArgument>
- <code>\Normalizer::FORM_C</code>
- <code>\Normalizer::FORM_C</code>
- <code>\Normalizer::FORM_D</code>
+ <code><![CDATA[\Normalizer::FORM_C]]></code>
+ <code><![CDATA[\Normalizer::FORM_C]]></code>
+ <code><![CDATA[\Normalizer::FORM_D]]></code>
</InvalidArgument>
<UndefinedInterfaceMethod>
<code><![CDATA[$this->namesCache]]></code>
@@ -2831,21 +2239,21 @@
</file>
<file src="lib/private/Files/Storage/Wrapper/Encryption.php">
<InvalidOperand>
- <code>$result</code>
- <code>$result</code>
+ <code><![CDATA[$result]]></code>
+ <code><![CDATA[$result]]></code>
<code><![CDATA[$this->copyFromStorage($sourceStorage, $sourceInternalPath . '/' . $file, $targetInternalPath . '/' . $file, false, $isRename)]]></code>
</InvalidOperand>
<InvalidReturnStatement>
- <code>$newUnencryptedSize</code>
- <code>$result</code>
+ <code><![CDATA[$newUnencryptedSize]]></code>
+ <code><![CDATA[$result]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>bool</code>
- <code>int</code>
+ <code><![CDATA[bool]]></code>
+ <code><![CDATA[int]]></code>
</InvalidReturnType>
<InvalidScalarArgument>
- <code>$lastChunkPos</code>
- <code>$size</code>
+ <code><![CDATA[$lastChunkPos]]></code>
+ <code><![CDATA[$size]]></code>
</InvalidScalarArgument>
</file>
<file src="lib/private/Files/Storage/Wrapper/Jail.php">
@@ -2853,7 +2261,7 @@
<code><![CDATA[$this->getWrapperStorage()->filetype($this->getUnjailedPath($path))]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Files/Storage/Wrapper/Wrapper.php">
@@ -2861,23 +2269,23 @@
<code><![CDATA[$this->getWrapperStorage()->test()]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>true</code>
+ <code><![CDATA[true]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Files/Stream/SeekableHttpStream.php">
<InvalidReturnType>
- <code>stream_close</code>
- <code>stream_flush</code>
+ <code><![CDATA[stream_close]]></code>
+ <code><![CDATA[stream_flush]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Files/Template/TemplateManager.php">
<RedundantCondition>
- <code>!$isDefaultTemplates</code>
+ <code><![CDATA[!$isDefaultTemplates]]></code>
</RedundantCondition>
</file>
<file src="lib/private/Files/Type/Detection.php">
<ParamNameMismatch>
- <code>$mimetype</code>
+ <code><![CDATA[$mimetype]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/Files/Type/Loader.php">
@@ -2885,25 +2293,25 @@
<code><![CDATA[$update->execute()]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>int</code>
+ <code><![CDATA[int]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Files/Utils/Scanner.php">
<LessSpecificReturnStatement>
- <code>$mounts</code>
+ <code><![CDATA[$mounts]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>\OC\Files\Mount\MountPoint[]</code>
+ <code><![CDATA[\OC\Files\Mount\MountPoint[]]]></code>
</MoreSpecificReturnType>
</file>
<file src="lib/private/Files/View.php">
<InvalidScalarArgument>
- <code>$mtime</code>
+ <code><![CDATA[$mtime]]></code>
</InvalidScalarArgument>
<UndefinedInterfaceMethod>
- <code>acquireLock</code>
- <code>changeLock</code>
- <code>releaseLock</code>
+ <code><![CDATA[acquireLock]]></code>
+ <code><![CDATA[changeLock]]></code>
+ <code><![CDATA[releaseLock]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/FullTextSearch/Model/IndexDocument.php">
@@ -2911,36 +2319,18 @@
<code><![CDATA[is_null($this->getContent())]]></code>
</TypeDoesNotContainNull>
</file>
- <file src="lib/private/Group/Database.php">
- <InvalidArrayOffset>
- <code><![CDATA[$this->groupCache[$gid]['displayname']]]></code>
- </InvalidArrayOffset>
- <InvalidPropertyAssignmentValue>
- <code><![CDATA[$this->groupCache]]></code>
- <code><![CDATA[$this->groupCache]]></code>
- <code><![CDATA[$this->groupCache]]></code>
- </InvalidPropertyAssignmentValue>
- </file>
- <file src="lib/private/Group/DisplayNameCache.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="lib/private/Group/Group.php">
<InvalidArgument>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidArgument>
<InvalidOperand>
- <code>$hide</code>
+ <code><![CDATA[$hide]]></code>
</InvalidOperand>
<LessSpecificReturnStatement>
- <code>$users</code>
+ <code><![CDATA[$users]]></code>
</LessSpecificReturnStatement>
- <MoreSpecificImplementedParamType>
- <code>$user</code>
- </MoreSpecificImplementedParamType>
<MoreSpecificReturnType>
- <code>\OC\User\User[]</code>
+ <code><![CDATA[\OC\User\User[]]]></code>
</MoreSpecificReturnType>
<RedundantCondition>
<code><![CDATA[$this->emitter]]></code>
@@ -2948,31 +2338,31 @@
<code><![CDATA[$this->emitter]]></code>
</RedundantCondition>
<UndefinedMethod>
- <code>addToGroup</code>
- <code>countUsersInGroup</code>
- <code>deleteGroup</code>
- <code>removeFromGroup</code>
+ <code><![CDATA[addToGroup]]></code>
+ <code><![CDATA[countUsersInGroup]]></code>
+ <code><![CDATA[deleteGroup]]></code>
+ <code><![CDATA[removeFromGroup]]></code>
</UndefinedMethod>
</file>
<file src="lib/private/Group/Manager.php">
<LessSpecificReturnStatement>
- <code>$groups</code>
- <code>array_values($groups)</code>
- <code>array_values($groups)</code>
+ <code><![CDATA[$groups]]></code>
+ <code><![CDATA[array_values($groups)]]></code>
+ <code><![CDATA[array_values($groups)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>\OC\Group\Group[]</code>
- <code>\OC\Group\Group[]</code>
+ <code><![CDATA[\OC\Group\Group[]]]></code>
+ <code><![CDATA[\OC\Group\Group[]]]></code>
</MoreSpecificReturnType>
<UndefinedInterfaceMethod>
- <code>createGroup</code>
- <code>getGroupDetails</code>
- <code>isAdmin</code>
+ <code><![CDATA[createGroup]]></code>
+ <code><![CDATA[getGroupDetails]]></code>
+ <code><![CDATA[isAdmin]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/Http/Client/Response.php">
<InvalidNullableReturnType>
- <code>string|resource</code>
+ <code><![CDATA[string|resource]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
<code><![CDATA[$this->stream ?
@@ -2981,19 +2371,16 @@
</NullableReturnStatement>
</file>
<file src="lib/private/Installer.php">
- <FalsableReturnStatement>
- <code>false</code>
- </FalsableReturnStatement>
<InvalidArgument>
- <code>false</code>
- <code>false</code>
+ <code><![CDATA[false]]></code>
+ <code><![CDATA[false]]></code>
</InvalidArgument>
<InvalidArrayOffset>
- <code>$app['path']</code>
- <code>$app['path']</code>
+ <code><![CDATA[$app['path']]]></code>
+ <code><![CDATA[$app['path']]]></code>
</InvalidArrayOffset>
<NullArgument>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="lib/private/IntegrityCheck/Checker.php">
@@ -3003,41 +2390,41 @@
<code><![CDATA[$x509->getDN(true)['CN']]]></code>
</InvalidArrayAccess>
<UndefinedInterfaceMethod>
- <code>getOnlyDefaultAliases</code>
+ <code><![CDATA[getOnlyDefaultAliases]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/IntegrityCheck/Iterator/ExcludeFileByNameFilterIterator.php">
<MissingTemplateParam>
- <code>ExcludeFileByNameFilterIterator</code>
+ <code><![CDATA[ExcludeFileByNameFilterIterator]]></code>
</MissingTemplateParam>
</file>
<file src="lib/private/IntegrityCheck/Iterator/ExcludeFoldersByPathFilterIterator.php">
<MissingTemplateParam>
- <code>ExcludeFoldersByPathFilterIterator</code>
+ <code><![CDATA[ExcludeFoldersByPathFilterIterator]]></code>
</MissingTemplateParam>
</file>
<file src="lib/private/L10N/Factory.php">
<ImplementedReturnTypeMismatch>
- <code>null|string</code>
+ <code><![CDATA[null|string]]></code>
</ImplementedReturnTypeMismatch>
<LessSpecificImplementedReturnType>
- <code>array|mixed</code>
+ <code><![CDATA[array|mixed]]></code>
</LessSpecificImplementedReturnType>
</file>
<file src="lib/private/LargeFileHelper.php">
<InvalidOperand>
- <code>$matches[1]</code>
+ <code><![CDATA[$matches[1]]]></code>
</InvalidOperand>
</file>
<file src="lib/private/Lockdown/Filesystem/NullCache.php">
<InvalidNullableReturnType>
- <code>get</code>
+ <code><![CDATA[get]]></code>
</InvalidNullableReturnType>
<InvalidReturnStatement>
- <code>[]</code>
+ <code><![CDATA[[]]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>getIncomplete</code>
+ <code><![CDATA[getIncomplete]]></code>
</InvalidReturnType>
<NullableReturnStatement>
<code><![CDATA[$file !== '' ? null :
@@ -3058,41 +2445,41 @@
</file>
<file src="lib/private/Lockdown/Filesystem/NullStorage.php">
<InvalidNullableReturnType>
- <code>getOwner</code>
- <code>getPermissions</code>
+ <code><![CDATA[getOwner]]></code>
+ <code><![CDATA[getPermissions]]></code>
</InvalidNullableReturnType>
<InvalidReturnStatement>
- <code>new IteratorDirectory([])</code>
- <code>new NullCache()</code>
+ <code><![CDATA[new IteratorDirectory([])]]></code>
+ <code><![CDATA[new NullCache()]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>getCache</code>
- <code>opendir</code>
+ <code><![CDATA[getCache]]></code>
+ <code><![CDATA[opendir]]></code>
</InvalidReturnType>
<NullableReturnStatement>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
<TooManyArguments>
- <code>new IteratorDirectory([])</code>
+ <code><![CDATA[new IteratorDirectory([])]]></code>
</TooManyArguments>
</file>
<file src="lib/private/Lockdown/LockdownManager.php">
<InvalidFunctionCall>
- <code>$callback()</code>
+ <code><![CDATA[$callback()]]></code>
</InvalidFunctionCall>
<InvalidPropertyAssignmentValue>
- <code>$sessionCallback</code>
+ <code><![CDATA[$sessionCallback]]></code>
</InvalidPropertyAssignmentValue>
</file>
<file src="lib/private/Log.php">
<RedundantCondition>
- <code>$request</code>
+ <code><![CDATA[$request]]></code>
</RedundantCondition>
</file>
<file src="lib/private/Log/File.php">
<TypeDoesNotContainNull>
- <code>$limit === null</code>
+ <code><![CDATA[$limit === null]]></code>
</TypeDoesNotContainNull>
</file>
<file src="lib/private/Log/LogDetails.php">
@@ -3100,11 +2487,6 @@
<code><![CDATA[is_string($request->getMethod())]]></code>
</RedundantCondition>
</file>
- <file src="lib/private/Log/Rotate.php">
- <ParamNameMismatch>
- <code>$dummy</code>
- </ParamNameMismatch>
- </file>
<file src="lib/private/Log/Systemdlog.php">
<UndefinedFunction>
<code><![CDATA[sd_journal_send('PRIORITY='.$journal_level,
@@ -3117,78 +2499,58 @@
<code><![CDATA[apcu_add($this->getPrefix() . $key, $value, $ttl)]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>bool</code>
+ <code><![CDATA[bool]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Memcache/Cache.php">
<LessSpecificImplementedReturnType>
- <code>mixed</code>
- <code>mixed</code>
- <code>mixed</code>
- <code>mixed</code>
+ <code><![CDATA[mixed]]></code>
+ <code><![CDATA[mixed]]></code>
+ <code><![CDATA[mixed]]></code>
+ <code><![CDATA[mixed]]></code>
</LessSpecificImplementedReturnType>
- <MissingTemplateParam>
- <code>\ArrayAccess</code>
- </MissingTemplateParam>
- </file>
- <file src="lib/private/Memcache/ProfilerWrapperCache.php">
- <MissingTemplateParam>
- <code>\ArrayAccess</code>
- </MissingTemplateParam>
- </file>
- <file src="lib/private/NavigationManager.php">
- <ParamNameMismatch>
- <code>$id</code>
- </ParamNameMismatch>
</file>
<file src="lib/private/Preview/BackgroundCleanupJob.php">
<InvalidReturnStatement>
- <code>[]</code>
+ <code><![CDATA[[]]]></code>
</InvalidReturnStatement>
</file>
<file src="lib/private/Preview/Generator.php">
<InvalidArgument>
- <code>$maxPreviewImage</code>
- <code>$semId</code>
+ <code><![CDATA[$maxPreviewImage]]></code>
</InvalidArgument>
- <InvalidReturnStatement>
- <code>$sem</code>
- </InvalidReturnStatement>
- <InvalidReturnType>
- <code>false|resource</code>
- </InvalidReturnType>
<LessSpecificReturnType>
- <code>null|string</code>
+ <code><![CDATA[null|string]]></code>
</LessSpecificReturnType>
<MismatchingDocblockParamType>
- <code>ISimpleFile</code>
+ <code><![CDATA[ISimpleFile]]></code>
</MismatchingDocblockParamType>
<UndefinedInterfaceMethod>
- <code>height</code>
- <code>height</code>
- <code>preciseResizeCopy</code>
- <code>resizeCopy</code>
- <code>valid</code>
- <code>width</code>
- <code>width</code>
+ <code><![CDATA[height]]></code>
+ <code><![CDATA[height]]></code>
+ <code><![CDATA[preciseResizeCopy]]></code>
+ <code><![CDATA[resizeCopy]]></code>
+ <code><![CDATA[valid]]></code>
+ <code><![CDATA[width]]></code>
+ <code><![CDATA[width]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/Preview/ProviderV1Adapter.php">
<InvalidReturnStatement>
- <code>$thumbnail === false ? null: $thumbnail</code>
+ <code><![CDATA[$thumbnail === false ? null: $thumbnail]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>?IImage</code>
+ <code><![CDATA[?IImage]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/RedisFactory.php">
<InvalidArgument>
- <code>\RedisCluster::OPT_SLAVE_FAILOVER</code>
+ <code><![CDATA[\RedisCluster::OPT_SLAVE_FAILOVER]]></code>
</InvalidArgument>
</file>
<file src="lib/private/Remote/Api/OCS.php">
<ImplementedReturnTypeMismatch>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</ImplementedReturnTypeMismatch>
</file>
<file src="lib/private/Remote/Instance.php">
@@ -3196,29 +2558,26 @@
<code><![CDATA[$request->getBody()]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>bool|string</code>
+ <code><![CDATA[bool|string]]></code>
</InvalidReturnType>
<InvalidScalarArgument>
- <code>$response</code>
+ <code><![CDATA[$response]]></code>
</InvalidScalarArgument>
</file>
<file src="lib/private/Repair/Owncloud/CleanPreviews.php">
<InvalidArgument>
- <code>false</code>
+ <code><![CDATA[false]]></code>
</InvalidArgument>
</file>
<file src="lib/private/Repair/Owncloud/CleanPreviewsBackgroundJob.php">
<ParamNameMismatch>
- <code>$arguments</code>
+ <code><![CDATA[$arguments]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/Repair/Owncloud/MoveAvatarsBackgroundJob.php">
<ParamNameMismatch>
- <code>$arguments</code>
+ <code><![CDATA[$arguments]]></code>
</ParamNameMismatch>
- <TypeDoesNotContainType>
- <code>$counter % 100 === 0</code>
- </TypeDoesNotContainType>
</file>
<file src="lib/private/Repair/RemoveLinkShares.php">
<InvalidPropertyAssignmentValue>
@@ -3227,25 +2586,20 @@
</file>
<file src="lib/private/Repair/RepairInvalidShares.php">
<ParamNameMismatch>
- <code>$out</code>
+ <code><![CDATA[$out]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/Repair/RepairMimeTypes.php">
<ParamNameMismatch>
- <code>$out</code>
- </ParamNameMismatch>
- </file>
- <file src="lib/private/Repair/SqliteAutoincrement.php">
- <ParamNameMismatch>
- <code>$out</code>
+ <code><![CDATA[$out]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/Route/Router.php">
<InvalidClass>
- <code>\OC_APP</code>
+ <code><![CDATA[\OC_APP]]></code>
</InvalidClass>
<InvalidNullableReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
<code><![CDATA[$this->collectionName]]></code>
@@ -3253,7 +2607,7 @@
</file>
<file src="lib/private/Search.php">
<RedundantCondition>
- <code>$provider instanceof Provider</code>
+ <code><![CDATA[$provider instanceof Provider]]></code>
</RedundantCondition>
</file>
<file src="lib/private/Search/Result/File.php">
@@ -3266,7 +2620,7 @@
</file>
<file src="lib/private/Security/Bruteforce/Throttler.php">
<NullArgument>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="lib/private/Security/CSP/ContentSecurityPolicyNonceManager.php">
@@ -3285,25 +2639,25 @@
<code><![CDATA[$qb->execute()]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>int</code>
- <code>int</code>
+ <code><![CDATA[int]]></code>
+ <code><![CDATA[int]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/Security/Crypto.php">
<InternalMethod>
- <code>decrypt</code>
- <code>encrypt</code>
- <code>setIV</code>
- <code>setIV</code>
- <code>setPassword</code>
- <code>setPassword</code>
+ <code><![CDATA[decrypt]]></code>
+ <code><![CDATA[encrypt]]></code>
+ <code><![CDATA[setIV]]></code>
+ <code><![CDATA[setIV]]></code>
+ <code><![CDATA[setPassword]]></code>
+ <code><![CDATA[setPassword]]></code>
</InternalMethod>
</file>
<file src="lib/private/Server.php">
<ImplementedReturnTypeMismatch>
- <code>\OCP\Calendar\Resource\IManager</code>
- <code>\OCP\Calendar\Room\IManager</code>
- <code>\OCP\Files\Folder|null</code>
+ <code><![CDATA[\OCP\Calendar\Resource\IManager]]></code>
+ <code><![CDATA[\OCP\Calendar\Room\IManager]]></code>
+ <code><![CDATA[\OCP\Files\Folder|null]]></code>
</ImplementedReturnTypeMismatch>
<LessSpecificReturnStatement>
<code><![CDATA[$this->get(IFile::class)]]></code>
@@ -3314,15 +2668,15 @@
<code><![CDATA[$this->get(\OCP\Encryption\IManager::class)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>\OC\Encryption\File</code>
- <code>\OC\Encryption\Manager</code>
- <code>\OC\Group\Manager</code>
- <code>\OC\NavigationManager</code>
- <code>\OC\User\Manager</code>
- <code>\OC\User\Session</code>
+ <code><![CDATA[\OC\Encryption\File]]></code>
+ <code><![CDATA[\OC\Encryption\Manager]]></code>
+ <code><![CDATA[\OC\Group\Manager]]></code>
+ <code><![CDATA[\OC\NavigationManager]]></code>
+ <code><![CDATA[\OC\User\Manager]]></code>
+ <code><![CDATA[\OC\User\Session]]></code>
</MoreSpecificReturnType>
<UndefinedDocblockClass>
- <code>\OC\OCSClient</code>
+ <code><![CDATA[\OC\OCSClient]]></code>
</UndefinedDocblockClass>
</file>
<file src="lib/private/ServerContainer.php">
@@ -3333,33 +2687,22 @@
<code><![CDATA[return $this->appContainers[$namespace];]]></code>
</NoValue>
</file>
- <file src="lib/private/Session/CryptoSessionData.php">
- <MissingTemplateParam>
- <code>\ArrayAccess</code>
- </MissingTemplateParam>
- </file>
<file src="lib/private/Session/Internal.php">
<MoreSpecificImplementedParamType>
- <code>$value</code>
+ <code><![CDATA[$value]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="lib/private/Session/Memory.php">
<MoreSpecificImplementedParamType>
- <code>$value</code>
+ <code><![CDATA[$value]]></code>
</MoreSpecificImplementedParamType>
</file>
- <file src="lib/private/Session/Session.php">
- <MissingTemplateParam>
- <code>\ArrayAccess</code>
- </MissingTemplateParam>
- </file>
<file src="lib/private/Setup.php">
<RedundantCondition>
- <code>$content !== ''</code>
- <code>$type === 'pdo'</code>
+ <code><![CDATA[$type === 'pdo']]></code>
</RedundantCondition>
<UndefinedVariable>
- <code>$vendor</code>
+ <code><![CDATA[$vendor]]></code>
</UndefinedVariable>
</file>
<file src="lib/private/Setup/AbstractDatabase.php">
@@ -3373,197 +2716,174 @@
<code><![CDATA[$this->dbprettyname]]></code>
</UndefinedThisPropertyFetch>
</file>
- <file src="lib/private/Share/Share.php">
- <InvalidOperand>
- <code>!self::isResharingAllowed()</code>
- </InvalidOperand>
- <UndefinedInterfaceMethod>
- <code>getParents</code>
- <code>getParents</code>
- </UndefinedInterfaceMethod>
- </file>
<file src="lib/private/Share20/DefaultShareProvider.php">
<InvalidArgument>
<code><![CDATA[$share->getId()]]></code>
<code><![CDATA[$share->getId()]]></code>
- <code>(int)$data['id']</code>
+ <code><![CDATA[(int)$data['id']]]></code>
</InvalidArgument>
<TooManyArguments>
- <code>set</code>
+ <code><![CDATA[set]]></code>
</TooManyArguments>
<UndefinedInterfaceMethod>
- <code>getParent</code>
+ <code><![CDATA[getParent]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/Share20/Manager.php">
<InvalidArgument>
- <code>$id</code>
+ <code><![CDATA[$id]]></code>
</InvalidArgument>
<TooManyArguments>
- <code>update</code>
+ <code><![CDATA[update]]></code>
</TooManyArguments>
<UndefinedClass>
- <code>\OCA\Circles\Api\v1\Circles</code>
+ <code><![CDATA[\OCA\Circles\Api\v1\Circles]]></code>
</UndefinedClass>
<UndefinedInterfaceMethod>
- <code>getChildren</code>
+ <code><![CDATA[getChildren]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/Share20/ProviderFactory.php">
<InvalidNullableReturnType>
- <code>FederatedShareProvider</code>
- <code>ShareByMailProvider</code>
+ <code><![CDATA[FederatedShareProvider]]></code>
+ <code><![CDATA[ShareByMailProvider]]></code>
</InvalidNullableReturnType>
<InvalidReturnStatement>
- <code>$provider</code>
- <code>$provider</code>
+ <code><![CDATA[$provider]]></code>
+ <code><![CDATA[$provider]]></code>
<code><![CDATA[$this->shareByCircleProvider]]></code>
</InvalidReturnStatement>
<InvalidReturnType>
- <code>getProviderForType</code>
+ <code><![CDATA[getProviderForType]]></code>
</InvalidReturnType>
<NullableReturnStatement>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
<ParamNameMismatch>
- <code>$shareProviderClass</code>
+ <code><![CDATA[$shareProviderClass]]></code>
</ParamNameMismatch>
<UndefinedClass>
- <code>\OCA\Circles\ShareByCircleProvider</code>
+ <code><![CDATA[\OCA\Circles\ShareByCircleProvider]]></code>
</UndefinedClass>
<UndefinedDocblockClass>
- <code>RoomShareProvider</code>
- <code>\OCA\Circles\ShareByCircleProvider</code>
- <code>\OCA\Talk\Share\RoomShareProvider</code>
- <code>private $roomShareProvider = null;</code>
- <code>private $shareByCircleProvider = null;</code>
+ <code><![CDATA[RoomShareProvider]]></code>
+ <code><![CDATA[\OCA\Circles\ShareByCircleProvider]]></code>
+ <code><![CDATA[\OCA\Talk\Share\RoomShareProvider]]></code>
+ <code><![CDATA[private $roomShareProvider = null;]]></code>
+ <code><![CDATA[private $shareByCircleProvider = null;]]></code>
</UndefinedDocblockClass>
- <UndefinedInterfaceMethod>
- <code>getLazyRootFolder</code>
- <code>getLazyRootFolder</code>
- <code>getLazyRootFolder</code>
- <code>getLazyRootFolder</code>
- </UndefinedInterfaceMethod>
</file>
<file src="lib/private/Share20/Share.php">
<LessSpecificReturnStatement>
<code><![CDATA[$this->node]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>getNode</code>
+ <code><![CDATA[getNode]]></code>
</MoreSpecificReturnType>
</file>
<file src="lib/private/Streamer.php">
- <InvalidArgument>
- <code>$stream</code>
- </InvalidArgument>
<UndefinedInterfaceMethod>
- <code>get</code>
+ <code><![CDATA[get]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/SubAdmin.php">
<UndefinedInterfaceMethod>
- <code>listen</code>
- <code>listen</code>
+ <code><![CDATA[listen]]></code>
+ <code><![CDATA[listen]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/Support/Subscription/Registry.php">
<UndefinedInterfaceMethod>
- <code>getSupportedApps</code>
+ <code><![CDATA[getSupportedApps]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/TagManager.php">
<InvalidNullableReturnType>
- <code>\OCP\ITags</code>
+ <code><![CDATA[\OCP\ITags]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="lib/private/Tags.php">
<InvalidScalarArgument>
- <code>$from</code>
- <code>$names</code>
+ <code><![CDATA[$from]]></code>
+ <code><![CDATA[$names]]></code>
</InvalidScalarArgument>
<MoreSpecificImplementedParamType>
- <code>$tag</code>
+ <code><![CDATA[$tag]]></code>
</MoreSpecificImplementedParamType>
</file>
<file src="lib/private/TempManager.php">
<FalsableReturnStatement>
- <code>false</code>
- <code>false</code>
+ <code><![CDATA[false]]></code>
+ <code><![CDATA[false]]></code>
</FalsableReturnStatement>
</file>
<file src="lib/private/Template/CSSResourceLocator.php">
<ParamNameMismatch>
- <code>$style</code>
- <code>$style</code>
+ <code><![CDATA[$style]]></code>
+ <code><![CDATA[$style]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/Template/JSConfigHelper.php">
<NullArgument>
- <code>null</code>
- <code>null</code>
+ <code><![CDATA[null]]></code>
+ <code><![CDATA[null]]></code>
</NullArgument>
</file>
<file src="lib/private/Template/JSResourceLocator.php">
<InvalidArgument>
- <code>false</code>
+ <code><![CDATA[false]]></code>
</InvalidArgument>
<ParamNameMismatch>
- <code>$script</code>
- <code>$script</code>
+ <code><![CDATA[$script]]></code>
+ <code><![CDATA[$script]]></code>
</ParamNameMismatch>
</file>
<file src="lib/private/TemplateLayout.php">
<InvalidParamDefault>
- <code>string</code>
- <code>string</code>
+ <code><![CDATA[string]]></code>
+ <code><![CDATA[string]]></code>
</InvalidParamDefault>
<InvalidScalarArgument>
- <code>$appName</code>
- <code>$appName</code>
+ <code><![CDATA[$appName]]></code>
+ <code><![CDATA[$appName]]></code>
</InvalidScalarArgument>
<UndefinedInterfaceMethod>
- <code>getInitialStates</code>
+ <code><![CDATA[getInitialStates]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/URLGenerator.php">
<InvalidReturnStatement>
- <code>$path</code>
+ <code><![CDATA[$path]]></code>
</InvalidReturnStatement>
</file>
<file src="lib/private/User/Database.php">
<FalsableReturnStatement>
- <code>false</code>
+ <code><![CDATA[false]]></code>
</FalsableReturnStatement>
</file>
- <file src="lib/private/User/DisplayNameCache.php">
- <MissingTemplateParam>
- <code>IEventListener</code>
- </MissingTemplateParam>
- </file>
<file src="lib/private/User/Manager.php">
<ImplementedReturnTypeMismatch>
- <code>IUser|false</code>
+ <code><![CDATA[IUser|false]]></code>
</ImplementedReturnTypeMismatch>
<InvalidArgument>
- <code>$backend</code>
+ <code><![CDATA[$backend]]></code>
</InvalidArgument>
<UndefinedInterfaceMethod>
- <code>createUser</code>
- <code>getUsersForUserValueCaseInsensitive</code>
+ <code><![CDATA[createUser]]></code>
+ <code><![CDATA[getUsersForUserValueCaseInsensitive]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/User/Session.php">
<ImplementedReturnTypeMismatch>
- <code>boolean|null</code>
+ <code><![CDATA[boolean|null]]></code>
</ImplementedReturnTypeMismatch>
<NoInterfaceProperties>
<code><![CDATA[$request->server]]></code>
@@ -3572,80 +2892,77 @@
</file>
<file src="lib/private/User/User.php">
<UndefinedInterfaceMethod>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
- <code>emit</code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
+ <code><![CDATA[emit]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/legacy/OC_API.php">
<InvalidNullableReturnType>
- <code>int</code>
+ <code><![CDATA[int]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullableReturnStatement>
</file>
<file src="lib/private/legacy/OC_App.php">
<InvalidArgument>
- <code>$groupsList</code>
+ <code><![CDATA[$groupsList]]></code>
</InvalidArgument>
<InvalidArrayOffset>
- <code>$dir['path']</code>
- <code>$dir['url']</code>
+ <code><![CDATA[$dir['path']]]></code>
+ <code><![CDATA[$dir['url']]]></code>
</InvalidArrayOffset>
<NullArgument>
- <code>null</code>
+ <code><![CDATA[null]]></code>
</NullArgument>
- <NullableReturnStatement>
- <code>null</code>
- </NullableReturnStatement>
<TypeDoesNotContainNull>
- <code>$appId === null</code>
- <code>$appId === null</code>
+ <code><![CDATA[$appId === null]]></code>
+ <code><![CDATA[$appId === null]]></code>
</TypeDoesNotContainNull>
</file>
<file src="lib/private/legacy/OC_FileChunking.php">
<UndefinedDocblockClass>
- <code>\OC\InsufficientStorageException</code>
+ <code><![CDATA[\OC\InsufficientStorageException]]></code>
</UndefinedDocblockClass>
</file>
<file src="lib/private/legacy/OC_Files.php">
<RedundantCondition>
- <code>$getType === self::ZIP_DIR</code>
- <code>$getType === self::ZIP_DIR</code>
+ <code><![CDATA[$getType === self::ZIP_DIR]]></code>
+ <code><![CDATA[$getType === self::ZIP_DIR]]></code>
</RedundantCondition>
<UndefinedInterfaceMethod>
- <code>get</code>
- <code>get</code>
+ <code><![CDATA[get]]></code>
+ <code><![CDATA[get]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/legacy/OC_Helper.php">
<InvalidArrayOffset>
- <code>$matches[0][$last_match]</code>
- <code>$matches[1][$last_match]</code>
+ <code><![CDATA[$matches[0][$last_match]]]></code>
+ <code><![CDATA[$matches[1][$last_match]]]></code>
</InvalidArrayOffset>
<InvalidScalarArgument>
- <code>$path</code>
+ <code><![CDATA[$path]]></code>
</InvalidScalarArgument>
<UndefinedInterfaceMethod>
- <code>getQuota</code>
+ <code><![CDATA[getQuota]]></code>
</UndefinedInterfaceMethod>
</file>
<file src="lib/private/legacy/OC_Template.php">
<InvalidReturnType>
- <code>bool|string</code>
+ <code><![CDATA[bool|string]]></code>
</InvalidReturnType>
</file>
<file src="lib/private/legacy/OC_User.php">
<UndefinedClass>
- <code>\Test\Util\User\Dummy</code>
+ <code><![CDATA[\Test\Util\User\Dummy]]></code>
</UndefinedClass>
</file>
<file src="lib/private/legacy/OC_Util.php">
<InvalidReturnType>
- <code>void</code>
+ <code><![CDATA[void]]></code>
</InvalidReturnType>
</file>
<file src="lib/public/AppFramework/ApiController.php">
@@ -3660,10 +2977,10 @@
</file>
<file src="lib/public/AppFramework/Db/Entity.php">
<InvalidNullableReturnType>
- <code>string</code>
+ <code><![CDATA[string]]></code>
</InvalidNullableReturnType>
<NullableReturnStatement>
- <code>$column</code>
+ <code><![CDATA[$column]]></code>
</NullableReturnStatement>
</file>
<file src="lib/public/AppFramework/Http/Response.php">
@@ -3671,51 +2988,41 @@
<code><![CDATA[array_merge($mergeWith, $this->headers)]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>array{X-Request-Id: string, Cache-Control: string, Content-Security-Policy: string, Feature-Policy: string, X-Robots-Tag: string, Last-Modified?: string, ETag?: string, ...H}</code>
+ <code><![CDATA[array{X-Request-Id: string, Cache-Control: string, Content-Security-Policy: string, Feature-Policy: string, X-Robots-Tag: string, Last-Modified?: string, ETag?: string, ...H}]]></code>
</MoreSpecificReturnType>
</file>
- <file src="lib/public/Cache/CappedMemoryCache.php">
- <MissingTemplateParam>
- <code>\ArrayAccess</code>
- </MissingTemplateParam>
- </file>
<file src="lib/public/Color.php">
<LessSpecificReturnStatement>
- <code>$step</code>
+ <code><![CDATA[$step]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>array{0: int, 1: int, 2: int}</code>
+ <code><![CDATA[array{0: int, 1: int, 2: int}]]></code>
</MoreSpecificReturnType>
</file>
<file src="lib/public/Diagnostics/IQueryLogger.php">
<LessSpecificImplementedReturnType>
- <code>mixed</code>
+ <code><![CDATA[mixed]]></code>
</LessSpecificImplementedReturnType>
</file>
<file src="lib/public/EventDispatcher/GenericEvent.php">
<MissingTemplateParam>
- <code>ArrayAccess</code>
- <code>IteratorAggregate</code>
+ <code><![CDATA[ArrayAccess]]></code>
+ <code><![CDATA[IteratorAggregate]]></code>
</MissingTemplateParam>
</file>
<file src="lib/public/Files.php">
<FalsableReturnStatement>
- <code>\OC_App::getStorage($app)</code>
+ <code><![CDATA[\OC_App::getStorage($app)]]></code>
</FalsableReturnStatement>
</file>
- <file src="lib/public/Files/Cache/ICacheEntry.php">
- <MissingTemplateParam>
- <code>ArrayAccess</code>
- </MissingTemplateParam>
- </file>
<file src="lib/public/Files/Storage.php">
<InvalidParamDefault>
- <code>array</code>
+ <code><![CDATA[array]]></code>
</InvalidParamDefault>
</file>
<file src="lib/public/L10N/ILanguageIterator.php">
<MissingTemplateParam>
- <code>\Iterator</code>
+ <code><![CDATA[\Iterator]]></code>
</MissingTemplateParam>
</file>
<file src="lib/public/Preview/BeforePreviewFetchedEvent.php">
@@ -3723,7 +3030,7 @@
<code><![CDATA[$this->mode]]></code>
</LessSpecificReturnStatement>
<MoreSpecificReturnType>
- <code>null|IPreview::MODE_FILL|IPreview::MODE_COVER</code>
+ <code><![CDATA[null|IPreview::MODE_FILL|IPreview::MODE_COVER]]></code>
</MoreSpecificReturnType>
</file>
</files>
diff --git a/build/psalm/AppFrameworkTainter.php b/build/psalm/AppFrameworkTainter.php
index 9a68885b175..448922d25a5 100644
--- a/build/psalm/AppFrameworkTainter.php
+++ b/build/psalm/AppFrameworkTainter.php
@@ -1,28 +1,9 @@
<?php
/**
- * Copyright (c) 2020 Lukas Reschke <lukas@statuscode.ch>
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
+ * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: MIT
*/
-
use Psalm\CodeLocation;
use Psalm\Plugin\EventHandler\AfterFunctionLikeAnalysisInterface;
use Psalm\Plugin\EventHandler\Event\AfterFunctionLikeAnalysisEvent;
diff --git a/build/psalm/OcpSinceChecker.php b/build/psalm/OcpSinceChecker.php
index 62b555284ac..c030678aee1 100644
--- a/build/psalm/OcpSinceChecker.php
+++ b/build/psalm/OcpSinceChecker.php
@@ -1,26 +1,10 @@
<?php
declare(strict_types=1);
-
/**
- * @copyright 2023 Daniel Kesselberg <mail@danielkesselberg.de>
- *
- * @author 2023 Daniel Kesselberg <mail@danielkesselberg.de>
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
+ * SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-only
*/
-
use PhpParser\Node\Stmt;
use PhpParser\Node\Stmt\ClassLike;
use Psalm\CodeLocation;
@@ -39,7 +23,11 @@ class OcpSinceChecker implements Psalm\Plugin\EventHandler\AfterClassLikeVisitIn
self::checkClassComment($stmt, $statementsSource);
foreach ($stmt->getMethods() as $method) {
- self::checkMethodComment($method, $statementsSource);
+ self::checkMethodOrConstantComment($method, $statementsSource, 'method');
+ }
+
+ foreach ($stmt->getConstants() as $constant) {
+ self::checkMethodOrConstantComment($constant, $statementsSource, 'constant');
}
}
@@ -76,15 +64,24 @@ class OcpSinceChecker implements Psalm\Plugin\EventHandler\AfterClassLikeVisitIn
)
);
}
+
+ if (isset($parsedDocblock->tags['depreacted'])) {
+ IssueBuffer::maybeAdd(
+ new InvalidDocblock(
+ 'Typo in @deprecated for classes/interfaces in OCP.',
+ new CodeLocation($statementsSource, $stmt)
+ )
+ );
+ }
}
- private static function checkMethodComment(Stmt $stmt, FileSource $statementsSource): void {
+ private static function checkMethodOrConstantComment(Stmt $stmt, FileSource $statementsSource, string $type): void {
$docblock = $stmt->getDocComment();
if ($docblock === null) {
IssueBuffer::maybeAdd(
new InvalidDocblock(
- 'PHPDoc is required for methods in OCP.',
+ 'PHPDoc is required for ' . $type . 's in OCP.',
new CodeLocation($statementsSource, $stmt)
),
);
@@ -106,7 +103,16 @@ class OcpSinceChecker implements Psalm\Plugin\EventHandler\AfterClassLikeVisitIn
if (!isset($parsedDocblock->tags['since'])) {
IssueBuffer::maybeAdd(
new InvalidDocblock(
- '@since is required for methods in OCP.',
+ '@since is required for ' . $type . 's in OCP.',
+ new CodeLocation($statementsSource, $stmt)
+ )
+ );
+ }
+
+ if (isset($parsedDocblock->tags['depreacted'])) {
+ IssueBuffer::maybeAdd(
+ new InvalidDocblock(
+ 'Typo in @deprecated for ' . $type . ' in OCP.',
new CodeLocation($statementsSource, $stmt)
)
);
diff --git a/build/signed-off-checker.php b/build/signed-off-checker.php
index 9620309932a..750d4757b07 100644
--- a/build/signed-off-checker.php
+++ b/build/signed-off-checker.php
@@ -1,24 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2016 Lukas Reschke <lukas@statuscode.ch>
- *
- * @author Lukas Reschke <lukas@statuscode.ch>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
/**
diff --git a/build/stubs/SensitiveParameter.phpstub b/build/stubs/SensitiveParameter.phpstub
new file mode 100644
index 00000000000..95715138927
--- /dev/null
+++ b/build/stubs/SensitiveParameter.phpstub
@@ -0,0 +1,5 @@
+<?php
+
+#[\Attribute(Attribute::TARGET_PARAMETER)]
+class SensitiveParameter {
+}
diff --git a/build/stubs/app_ecosystem_v2.php b/build/stubs/app_api.php
index d2b07c9c616..1ab63499b77 100644
--- a/build/stubs/app_ecosystem_v2.php
+++ b/build/stubs/app_api.php
@@ -1,10 +1,10 @@
<?php
-namespace OCA\AppEcosystemV2\Service;
+namespace OCA\AppAPI\Service;
use OCP\IRequest;
-class AppEcosystemV2Service {
+class AppAPIService {
/**
* @param IRequest $request
* @param bool $isDav
diff --git a/build/stubs/ftp.php b/build/stubs/ftp.php
index c2505d5a566..22e97f0f44f 100644
--- a/build/stubs/ftp.php
+++ b/build/stubs/ftp.php
@@ -16,59 +16,80 @@ namespace FTP {
namespace {
- function ftp_connect(string $hostname, int $port = 21, int $timeout = 90): FTP\Connection|resource|false {}
+ function ftp_connect(string $hostname, int $port = 21, int $timeout = 90): FTP\Connection|false {}
#ifdef HAVE_FTP_SSL
- function ftp_ssl_connect(string $hostname, int $port = 21, int $timeout = 90): FTP\Connection|resource|false {}
+ function ftp_ssl_connect(string $hostname, int $port = 21, int $timeout = 90): FTP\Connection|false {}
#endif
- function ftp_login(FTP\Connection|resource $ftp, string $username, string $password): bool {}
- function ftp_pwd(FTP\Connection|resource $ftp): string|false {}
- function ftp_cdup(FTP\Connection|resource $ftp): bool {}
- function ftp_chdir(FTP\Connection|resource $ftp, string $directory): bool {}
- function ftp_exec(FTP\Connection|resource $ftp, string $command): bool {}
- function ftp_raw(FTP\Connection|resource $ftp, string $command): ?array {}
- function ftp_mkdir(FTP\Connection|resource $ftp, string $directory): string|false {}
- function ftp_rmdir(FTP\Connection|resource $ftp, string $directory): bool {}
- function ftp_chmod(FTP\Connection|resource $ftp, int $permissions, string $filename): int|false {}
+ function ftp_login(FTP\Connection $ftp, string $username, string $password): bool {}
+ function ftp_pwd(FTP\Connection $ftp): string|false {}
+ function ftp_cdup(FTP\Connection $ftp): bool {}
+ function ftp_chdir(FTP\Connection $ftp, string $directory): bool {}
+ function ftp_exec(FTP\Connection $ftp, string $command): bool {}
+
+ /**
+ * @return array<int, string>|null
+ * @refcount 1
+ */
+ function ftp_raw(FTP\Connection $ftp, string $command): ?array {}
+ function ftp_mkdir(FTP\Connection $ftp, string $directory): string|false {}
+ function ftp_rmdir(FTP\Connection $ftp, string $directory): bool {}
+ function ftp_chmod(FTP\Connection $ftp, int $permissions, string $filename): int|false {}
/** @param string $response */
- function ftp_alloc(FTP\Connection|resource $ftp, int $size, &$response = null): bool {}
- function ftp_nlist(FTP\Connection|resource $ftp, string $directory): array|false {}
- function ftp_rawlist(FTP\Connection|resource $ftp, string $directory, bool $recursive = false): array|false {}
- function ftp_mlsd(FTP\Connection|resource $ftp, string $directory): array|false {}
- function ftp_systype(FTP\Connection|resource $ftp): string|false {}
+ function ftp_alloc(FTP\Connection $ftp, int $size, &$response = null): bool {}
+
+ /**
+ * @return array<int, string>|false
+ * @refcount 1
+ */
+ function ftp_nlist(FTP\Connection $ftp, string $directory): array|false {}
+
+ /**
+ * @return array<int, string>|false
+ * @refcount 1
+ */
+ function ftp_rawlist(FTP\Connection $ftp, string $directory, bool $recursive = false): array|false {}
+
+ /**
+ * @return array<int, array>|false
+ * @refcount 1
+ */
+ function ftp_mlsd(FTP\Connection $ftp, string $directory): array|false {}
+
+ function ftp_systype(FTP\Connection $ftp): string|false {}
/** @param resource $stream */
- function ftp_fget(FTP\Connection|resource $ftp, $stream, string $remote_filename, int $mode = FTP_BINARY, int $offset = 0): bool {}
+ function ftp_fget(FTP\Connection $ftp, $stream, string $remote_filename, int $mode = FTP_BINARY, int $offset = 0): bool {}
/** @param resource $stream */
- function ftp_nb_fget(FTP\Connection|resource $ftp, $stream, string $remote_filename, int $mode = FTP_BINARY, int $offset = 0): int {}
- function ftp_pasv(FTP\Connection|resource $ftp, bool $enable): bool {}
- function ftp_get(FTP\Connection|resource $ftp, string $local_filename, string $remote_filename, int $mode = FTP_BINARY, int $offset = 0): bool {}
- function ftp_nb_get(FTP\Connection|resource $ftp, string $local_filename, string $remote_filename, int $mode = FTP_BINARY, int $offset = 0): int {}
- function ftp_nb_continue(FTP\Connection|resource $ftp): int {}
+ function ftp_nb_fget(FTP\Connection $ftp, $stream, string $remote_filename, int $mode = FTP_BINARY, int $offset = 0): int {}
+ function ftp_pasv(FTP\Connection $ftp, bool $enable): bool {}
+ function ftp_get(FTP\Connection $ftp, string $local_filename, string $remote_filename, int $mode = FTP_BINARY, int $offset = 0): bool {}
+ function ftp_nb_get(FTP\Connection $ftp, string $local_filename, string $remote_filename, int $mode = FTP_BINARY, int $offset = 0): int|false {}
+ function ftp_nb_continue(FTP\Connection $ftp): int {}
/** @param resource $stream */
- function ftp_fput(FTP\Connection|resource $ftp, string $remote_filename, $stream, int $mode = FTP_BINARY, int $offset = 0): bool {}
+ function ftp_fput(FTP\Connection $ftp, string $remote_filename, $stream, int $mode = FTP_BINARY, int $offset = 0): bool {}
/** @param resource $stream */
- function ftp_nb_fput(FTP\Connection|resource $ftp, string $remote_filename, $stream, int $mode = FTP_BINARY, int $offset = 0): int {}
- function ftp_put(FTP\Connection|resource $ftp, string $remote_filename, string $local_filename, int $mode = FTP_BINARY, int $offset = 0): bool {}
- function ftp_append(FTP\Connection|resource $ftp, string $remote_filename, string $local_filename, int $mode = FTP_BINARY): bool {}
- function ftp_nb_put(FTP\Connection|resource $ftp, string $remote_filename, string $local_filename, int $mode = FTP_BINARY, int $offset = 0): int|false {}
- function ftp_size(FTP\Connection|resource $ftp, string $filename): int {}
- function ftp_mdtm(FTP\Connection|resource $ftp, string $filename): int {}
- function ftp_rename(FTP\Connection|resource $ftp, string $from, string $to): bool {}
- function ftp_delete(FTP\Connection|resource $ftp, string $filename): bool {}
- function ftp_site(FTP\Connection|resource $ftp, string $command): bool {}
- function ftp_close(FTP\Connection|resource $ftp): bool {}
+ function ftp_nb_fput(FTP\Connection $ftp, string $remote_filename, $stream, int $mode = FTP_BINARY, int $offset = 0): int {}
+ function ftp_put(FTP\Connection $ftp, string $remote_filename, string $local_filename, int $mode = FTP_BINARY, int $offset = 0): bool {}
+ function ftp_append(FTP\Connection $ftp, string $remote_filename, string $local_filename, int $mode = FTP_BINARY): bool {}
+ function ftp_nb_put(FTP\Connection $ftp, string $remote_filename, string $local_filename, int $mode = FTP_BINARY, int $offset = 0): int|false {}
+ function ftp_size(FTP\Connection $ftp, string $filename): int {}
+ function ftp_mdtm(FTP\Connection $ftp, string $filename): int {}
+ function ftp_rename(FTP\Connection $ftp, string $from, string $to): bool {}
+ function ftp_delete(FTP\Connection $ftp, string $filename): bool {}
+ function ftp_site(FTP\Connection $ftp, string $command): bool {}
+ function ftp_close(FTP\Connection $ftp): bool {}
/** @alias ftp_close */
- function ftp_quit(FTP\Connection|resource $ftp): bool {}
+ function ftp_quit(FTP\Connection $ftp): bool {}
/** @param int|bool $value */
- function ftp_set_option(FTP\Connection|resource $ftp, int $option, $value): bool {}
- function ftp_get_option(FTP\Connection|resource $ftp, int $option): int|bool {}
+ function ftp_set_option(FTP\Connection $ftp, int $option, $value): bool {}
+ function ftp_get_option(FTP\Connection $ftp, int $option): int|bool {}
}
diff --git a/build/stubs/gd.php b/build/stubs/gd.php
index c9784009ea8..5b48af23761 100644
--- a/build/stubs/gd.php
+++ b/build/stubs/gd.php
@@ -1,5 +1,7 @@
<?php
+/** @generate-class-entries */
+
/**
* @strict-properties
* @not-serializable
@@ -7,3015 +9,326 @@
final class GdImage {}
/**
- * Retrieve information about the currently installed GD library
- * @link https://php.net/manual/en/function.gd-info.php
- * @return array an associative array.
- * </p>
- * <p>
- * <table>
- * Elements of array returned by <b>gd_info</b>
- * <tr valign="top">
- * <td>Attribute</td>
- * <td>Meaning</td>
- * </tr>
- * <tr valign="top">
- * <td>GD Version</td>
- * <td>string value describing the installed
- * libgd version.</td>
- * </tr>
- * <tr valign="top">
- * <td>FreeType Support</td>
- * <td>boolean value. <b>TRUE</b>
- * if FreeType Support is installed.</td>
- * </tr>
- * <tr valign="top">
- * <td>FreeType Linkage</td>
- * <td>string value describing the way in which
- * FreeType was linked. Expected values are: 'with freetype',
- * 'with TTF library', and 'with unknown library'. This element will
- * only be defined if FreeType Support evaluated to
- * <b>TRUE</b>.</td>
- * </tr>
- * <tr valign="top">
- * <td>T1Lib Support</td>
- * <td>boolean value. <b>TRUE</b>
- * if T1Lib support is included.</td>
- * </tr>
- * <tr valign="top">
- * <td>GIF Read Support</td>
- * <td>boolean value. <b>TRUE</b>
- * if support for reading GIF
- * images is included.</td>
- * </tr>
- * <tr valign="top">
- * <td>GIF Create Support</td>
- * <td>boolean value. <b>TRUE</b>
- * if support for creating GIF
- * images is included.</td>
- * </tr>
- * <tr valign="top">
- * <td>JPEG Support</td>
- * <td>boolean value. <b>TRUE</b>
- * if JPEG support is included.</td>
- * </tr>
- * <tr valign="top">
- * <td>PNG Support</td>
- * <td>boolean value. <b>TRUE</b>
- * if PNG support is included.</td>
- * </tr>
- * <tr valign="top">
- * <td>WBMP Support</td>
- * <td>boolean value. <b>TRUE</b>
- * if WBMP support is included.</td>
- * </tr>
- * <tr valign="top">
- * <td>XBM Support</td>
- * <td>boolean value. <b>TRUE</b>
- * if XBM support is included.</td>
- * </tr>
- * <tr valign="top">
- * <td>WebP Support</td>
- * <td>boolean value. <b>TRUE</b>
- * if WebP support is included.</td>
- * </tr>
- * </table>
- * </p>
- * <p>
- * Previous to PHP 5.3.0, the JPEG Support attribute was named
- * JPG Support.
- */
-function gd_info () {}
-
-/**
- * Draws an arc
- * @link https://php.net/manual/en/function.imagearc.php
- * @param resource $image
- * @param int $cx <p>
- * x-coordinate of the center.
- * </p>
- * @param int $cy <p>
- * y-coordinate of the center.
- * </p>
- * @param int $width <p>
- * The arc width.
- * </p>
- * @param int $height <p>
- * The arc height.
- * </p>
- * @param int $start <p>
- * The arc start angle, in degrees.
- * </p>
- * @param int $end <p>
- * The arc end angle, in degrees.
- * 0° is located at the three-o'clock position, and the arc is drawn
- * clockwise.
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * <b>imagecolorallocate</b>.
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
-function imagearc ($image, $cx, $cy, $width, $height, $start, $end, $color) {}
-
-/**
- * Draw an ellipse
- * @link https://php.net/manual/en/function.imageellipse.php
- * @param resource $image
- * @param int $cx <p>
- * x-coordinate of the center.
- * </p>
- * @param int $cy <p>
- * y-coordinate of the center.
- * </p>
- * @param int $width <p>
- * The ellipse width.
- * </p>
- * @param int $height <p>
- * The ellipse height.
- * </p>
- * @param int $color <p>
- * The color of the ellipse. A color identifier created with
- * <b>imagecolorallocate</b>.
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
-function imageellipse ($image, $cx, $cy, $width, $height, $color) {}
-
-/**
- * Draw a character horizontally
- * @link https://php.net/manual/en/function.imagechar.php
- * @param resource $image
- * @param int $font
- * @param int $x <p>
- * x-coordinate of the start.
- * </p>
- * @param int $y <p>
- * y-coordinate of the start.
- * </p>
- * @param string $c <p>
- * The character to draw.
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * <b>imagecolorallocate</b>.
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
-function imagechar ($image, $font, $x, $y, $c, $color) {}
-
-/**
- * Draw a character vertically
- * @link https://php.net/manual/en/function.imagecharup.php
- * @param resource $image
- * @param int $font
- * @param int $x <p>
- * x-coordinate of the start.
- * </p>
- * @param int $y <p>
- * y-coordinate of the start.
- * </p>
- * @param string $c <p>
- * The character to draw.
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * <b>imagecolorallocate</b>.
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
-function imagecharup ($image, $font, $x, $y, $c, $color) {}
-
-/**
- * Get the index of the color of a pixel
- * @link https://php.net/manual/en/function.imagecolorat.php
- * @param resource $image
- * @param int $x <p>
- * x-coordinate of the point.
- * </p>
- * @param int $y <p>
- * y-coordinate of the point.
- * </p>
- * @return int|false the index of the color or <b>FALSE</b> on failure
- */
-function imagecolorat ($image, $x, $y) {}
-
-/**
- * Allocate a color for an image
- * @link https://php.net/manual/en/function.imagecolorallocate.php
- * @param resource $image
- * @param int $red <p>Value of red component.</p>
- * @param int $green <p>Value of green component.</p>
- * @param int $blue <p>Value of blue component.</p>
- * @return int|false A color identifier or <b>FALSE</b> if the allocation failed.
- */
-function imagecolorallocate ($image, $red, $green, $blue) {}
-
-/**
- * Copy the palette from one image to another
- * @link https://php.net/manual/en/function.imagepalettecopy.php
- * @param resource $destination <p>
- * The destination image resource.
- * </p>
- * @param resource $source <p>
- * The source image resource.
- * </p>
- * @return void No value is returned.
- */
-function imagepalettecopy ($destination, $source) {}
-
-/**
- * Create a new image from the image stream in the string
- * @link https://php.net/manual/en/function.imagecreatefromstring.php
- * @param string $image <p>
- * A string containing the image data.
- * </p>
- * @return resource|false An image resource will be returned on success. <b>FALSE</b> is returned if
- * the image type is unsupported, the data is not in a recognised format,
- * or the image is corrupt and cannot be loaded.
- */
-function imagecreatefromstring ($image) {}
-
-/**
- * Get the index of the closest color to the specified color
- * @link https://php.net/manual/en/function.imagecolorclosest.php
- * @param resource $image
- * @param int $red <p>Value of red component.</p>
- * @param int $green <p>Value of green component.</p>
- * @param int $blue <p>Value of blue component.</p>
- * @return int|false the index of the closest color, in the palette of the image, to
- * the specified one or <b>FALSE</b> on failure
- */
-function imagecolorclosest ($image, $red, $green, $blue) {}
-
-/**
- * Get the index of the color which has the hue, white and blackness
- * @link https://php.net/manual/en/function.imagecolorclosesthwb.php
- * @param resource $image
- * @param int $red <p>Value of red component.</p>
- * @param int $green <p>Value of green component.</p>
- * @param int $blue <p>Value of blue component.</p>
- * @return int|false an integer with the index of the color which has
- * the hue, white and blackness nearest the given color or <b>FALSE</b> on failure
- */
-function imagecolorclosesthwb ($image, $red, $green, $blue) {}
-
-/**
- * De-allocate a color for an image
- * @link https://php.net/manual/en/function.imagecolordeallocate.php
- * @param resource $image
- * @param int $color <p>
- * The color identifier.
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
-function imagecolordeallocate ($image, $color) {}
-
-/**
- * Get the index of the specified color or its closest possible alternative
- * @link https://php.net/manual/en/function.imagecolorresolve.php
- * @param resource $image
- * @param int $red <p>Value of red component.</p>
- * @param int $green <p>Value of green component.</p>
- * @param int $blue <p>Value of blue component.</p>
- * @return int|false a color index or <b>FALSE</b> on failure
- */
-function imagecolorresolve ($image, $red, $green, $blue) {}
-
-/**
- * Get the index of the specified color
- * @link https://php.net/manual/en/function.imagecolorexact.php
- * @param resource $image
- * @param int $red <p>Value of red component.</p>
- * @param int $green <p>Value of green component.</p>
- * @param int $blue <p>Value of blue component.</p>
- * @return int|false the index of the specified color in the palette, -1 if the
- * color does not exist, or <b>FALSE</b> on failure
- */
-function imagecolorexact ($image, $red, $green, $blue) {}
-
-/**
- * Set the color for the specified palette index
- * @link https://php.net/manual/en/function.imagecolorset.php
- * @param resource $image
- * @param int $index <p>
- * An index in the palette.
- * </p>
- * @param int $red <p>Value of red component.</p>
- * @param int $green <p>Value of green component.</p>
- * @param int $blue <p>Value of blue component.</p>
- * @param int $alpha [optional] <p>
- * Value of alpha component.
- * </p>
- * @return void No value is returned.
- */
-function imagecolorset ($image, $index, $red, $green, $blue, $alpha = 0) {}
-
-/**
- * Define a color as transparent
- * @link https://php.net/manual/en/function.imagecolortransparent.php
- * @param resource $image
- * @param int $color [optional] <p>
- * A color identifier created with
- * <b>imagecolorallocate</b>.
- * </p>
- * @return int|false The identifier of the new (or current, if none is specified)
- * transparent color is returned. If <i>color</i>
- * is not specified, and the image has no transparent color, the
- * returned identifier will be -1. If an error occurs, <b>FALSE</b> is returned.
- */
-function imagecolortransparent ($image, $color = null) {}
-
-/**
- * Find out the number of colors in an image's palette
- * @link https://php.net/manual/en/function.imagecolorstotal.php
- * @param resource $image <p>
- * An image resource, returned by one of the image creation functions, such
- * as <b>imagecreatefromgif</b>.
- * </p>
- * @return int|false the number of colors in the specified image's palette, 0 for
- * truecolor images, or <b>FALSE</b> on failure
- */
-function imagecolorstotal ($image) {}
-
-/**
- * Get the colors for an index
- * @link https://php.net/manual/en/function.imagecolorsforindex.php
- * @param resource $image
- * @param int $index <p>
- * The color index.
- * </p>
- * @return array|false an associative array with red, green, blue and alpha keys that
- * contain the appropriate values for the specified color index or <b>FALSE</b> on failure
- */
-function imagecolorsforindex ($image, $index) {}
-
-/**
- * Copy part of an image
- * @link https://php.net/manual/en/function.imagecopy.php
- * @param resource $dst_im <p>
- * Destination image link resource.
- * </p>
- * @param resource $src_im <p>
- * Source image link resource.
- * </p>
- * @param int $dst_x <p>
- * x-coordinate of destination point.
- * </p>
- * @param int $dst_y <p>
- * y-coordinate of destination point.
- * </p>
- * @param int $src_x <p>
- * x-coordinate of source point.
- * </p>
- * @param int $src_y <p>
- * y-coordinate of source point.
- * </p>
- * @param int $src_w <p>
- * Source width.
- * </p>
- * @param int $src_h <p>
- * Source height.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagecopy ($dst_im, $src_im, $dst_x, $dst_y, $src_x, $src_y, $src_w, $src_h) {}
-
-/**
- * Copy and merge part of an image
- * @link https://php.net/manual/en/function.imagecopymerge.php
- * @param resource $dst_im <p>
- * Destination image link resource.
- * </p>
- * @param resource $src_im <p>
- * Source image link resource.
- * </p>
- * @param int $dst_x <p>
- * x-coordinate of destination point.
- * </p>
- * @param int $dst_y <p>
- * y-coordinate of destination point.
- * </p>
- * @param int $src_x <p>
- * x-coordinate of source point.
- * </p>
- * @param int $src_y <p>
- * y-coordinate of source point.
- * </p>
- * @param int $src_w <p>
- * Source width.
- * </p>
- * @param int $src_h <p>
- * Source height.
- * </p>
- * @param int $pct <p>
- * The two images will be merged according to pct
- * which can range from 0 to 100. When pct = 0,
- * no action is taken, when 100 this function behaves identically
- * to imagecopy for pallete images, while it
- * implements alpha transparency for true colour images.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagecopymerge ($dst_im, $src_im, $dst_x, $dst_y, $src_x, $src_y, $src_w, $src_h, $pct) {}
-
-/**
- * Copy and merge part of an image with gray scale
- * @link https://php.net/manual/en/function.imagecopymergegray.php
- * @param resource $dst_im <p>
- * Destination image link resource.
- * </p>
- * @param resource $src_im <p>
- * Source image link resource.
- * </p>
- * @param int $dst_x <p>
- * x-coordinate of destination point.
- * </p>
- * @param int $dst_y <p>
- * y-coordinate of destination point.
- * </p>
- * @param int $src_x <p>
- * x-coordinate of source point.
- * </p>
- * @param int $src_y <p>
- * y-coordinate of source point.
- * </p>
- * @param int $src_w <p>
- * Source width.
- * </p>
- * @param int $src_h <p>
- * Source height.
- * </p>
- * @param int $pct <p>
- * The src_im will be changed to grayscale according
- * to pct where 0 is fully grayscale and 100 is
- * unchanged. When pct = 100 this function behaves
- * identically to imagecopy for pallete images, while
- * it implements alpha transparency for true colour images.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagecopymergegray ($dst_im, $src_im, $dst_x, $dst_y, $src_x, $src_y, $src_w, $src_h, $pct) {}
-
-/**
- * Copy and resize part of an image
- * @link https://php.net/manual/en/function.imagecopyresized.php
- * @param resource $dst_image
- * @param resource $src_image
- * @param int $dst_x <p>
- * x-coordinate of destination point.
- * </p>
- * @param int $dst_y <p>
- * y-coordinate of destination point.
- * </p>
- * @param int $src_x <p>
- * x-coordinate of source point.
- * </p>
- * @param int $src_y <p>
- * y-coordinate of source point.
- * </p>
- * @param int $dst_w <p>
- * Destination width.
- * </p>
- * @param int $dst_h <p>
- * Destination height.
- * </p>
- * @param int $src_w <p>
- * Source width.
- * </p>
- * @param int $src_h <p>
- * Source height.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagecopyresized ($dst_image, $src_image, $dst_x, $dst_y, $src_x, $src_y, $dst_w, $dst_h, $src_w, $src_h) {}
-
-/**
- * Create a new palette based image
- * @link https://php.net/manual/en/function.imagecreate.php
- * @param int $width <p>
- * The image width.
- * </p>
- * @param int $height <p>
- * The image height.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreate ($width, $height) {}
-
-/**
- * Create a new true color image
- * @link https://php.net/manual/en/function.imagecreatetruecolor.php
- * @param int $width <p>
- * Image width.
- * </p>
- * @param int $height <p>
- * Image height.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatetruecolor ($width, $height) {}
-
-/**
- * Finds whether an image is a truecolor image
- * @link https://php.net/manual/en/function.imageistruecolor.php
- * @param resource $image
- * @return bool true if the image is truecolor, false
- * otherwise.
- */
-function imageistruecolor ($image) {}
-
-/**
- * Convert a true color image to a palette image
- * @link https://php.net/manual/en/function.imagetruecolortopalette.php
- * @param resource $image
- * @param bool $dither <p>
- * Indicates if the image should be dithered - if it is true then
- * dithering will be used which will result in a more speckled image but
- * with better color approximation.
- * </p>
- * @param int $ncolors <p>
- * Sets the maximum number of colors that should be retained in the palette.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagetruecolortopalette ($image, $dither, $ncolors) {}
-
-/**
- * Set the thickness for line drawing
- * @link https://php.net/manual/en/function.imagesetthickness.php
- * @param resource $image
- * @param int $thickness <p>
- * Thickness, in pixels.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagesetthickness ($image, $thickness) {}
-
-/**
- * Draw a partial arc and fill it
- * @link https://php.net/manual/en/function.imagefilledarc.php
- * @param resource $image
- * @param int $cx <p>
- * x-coordinate of the center.
- * </p>
- * @param int $cy <p>
- * y-coordinate of the center.
- * </p>
- * @param int $width <p>
- * The arc width.
- * </p>
- * @param int $height <p>
- * The arc height.
- * </p>
- * @param int $start <p>
- * The arc start angle, in degrees.
- * </p>
- * @param int $end <p>
- * The arc end angle, in degrees.
- * 0&deg; is located at the three-o'clock position, and the arc is drawn
- * clockwise.
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * imagecolorallocate.
- * </p>
- * @param int $style <p>
- * A bitwise OR of the following possibilities:
- * IMG_ARC_PIE
- * @return bool true on success or false on failure.
- */
-function imagefilledarc ($image, $cx, $cy, $width, $height, $start, $end, $color, $style) {}
-
-/**
- * Draw a filled ellipse
- * @link https://php.net/manual/en/function.imagefilledellipse.php
- * @param resource $image
- * @param int $cx <p>
- * x-coordinate of the center.
- * </p>
- * @param int $cy <p>
- * y-coordinate of the center.
- * </p>
- * @param int $width <p>
- * The ellipse width.
- * </p>
- * @param int $height <p>
- * The ellipse height.
- * </p>
- * @param int $color <p>
- * The fill color. A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagefilledellipse ($image, $cx, $cy, $width, $height, $color) {}
-
-/**
- * Set the blending mode for an image
- * @link https://php.net/manual/en/function.imagealphablending.php
- * @param resource $image
- * @param bool $blendmode <p>
- * Whether to enable the blending mode or not. On true color images
- * the default value is true otherwise the default value is false
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagealphablending ($image, $blendmode) {}
-
-/**
- * Set the flag to save full alpha channel information (as opposed to single-color transparency) when saving PNG images
- * @link https://php.net/manual/en/function.imagesavealpha.php
- * @param resource $image
- * @param bool $saveflag <p>
- * Whether to save the alpha channel or not. Default to false.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagesavealpha ($image, $saveflag) {}
-
-/**
- * Allocate a color for an image
- * @link https://php.net/manual/en/function.imagecolorallocatealpha.php
- * @param resource $image
- * @param int $red <p>
- * Value of red component.
- * </p>
- * @param int $green <p>
- * Value of green component.
- * </p>
- * @param int $blue <p>
- * Value of blue component.
- * </p>
- * @param int $alpha <p>
- * A value between 0 and 127.
- * 0 indicates completely opaque while
- * 127 indicates completely transparent.
- * </p>
- * @return int|false A color identifier or false if the allocation failed.
- */
-function imagecolorallocatealpha ($image, $red, $green, $blue, $alpha) {}
-
-/**
- * Get the index of the specified color + alpha or its closest possible alternative
- * @link https://php.net/manual/en/function.imagecolorresolvealpha.php
- * @param resource $image
- * @param int $red <p>
- * Value of red component.
- * </p>
- * @param int $green <p>
- * Value of green component.
- * </p>
- * @param int $blue <p>
- * Value of blue component.
- * </p>
- * @param int $alpha <p>
- * A value between 0 and 127.
- * 0 indicates completely opaque while
- * 127 indicates completely transparent.
- * </p>
- * @return int|false a color index or <b>FALSE</b> on failure
- */
-function imagecolorresolvealpha ($image, $red, $green, $blue, $alpha) {}
-
-/**
- * Get the index of the closest color to the specified color + alpha
- * @link https://php.net/manual/en/function.imagecolorclosestalpha.php
- * @param resource $image
- * @param int $red <p>
- * Value of red component.
- * </p>
- * @param int $green <p>
- * Value of green component.
- * </p>
- * @param int $blue <p>
- * Value of blue component.
- * </p>
- * @param int $alpha <p>
- * A value between 0 and 127.
- * 0 indicates completely opaque while
- * 127 indicates completely transparent.
- * </p>
- * @return int|false the index of the closest color in the palette or
- * <b>FALSE</b> on failure
- */
-function imagecolorclosestalpha ($image, $red, $green, $blue, $alpha) {}
-
-/**
- * Get the index of the specified color + alpha
- * @link https://php.net/manual/en/function.imagecolorexactalpha.php
- * @param resource $image
- * @param int $red <p>
- * Value of red component.
- * </p>
- * @param int $green <p>
- * Value of green component.
- * </p>
- * @param int $blue <p>
- * Value of blue component.
- * </p>
- * @param int $alpha <p>
- * A value between 0 and 127.
- * 0 indicates completely opaque while
- * 127 indicates completely transparent.
- * </p>
- * @return int|false the index of the specified color+alpha in the palette of the
- * image, -1 if the color does not exist in the image's palette, or <b>FALSE</b>
- * on failure
- */
-function imagecolorexactalpha ($image, $red, $green, $blue, $alpha) {}
-
-/**
- * Copy and resize part of an image with resampling
- * @link https://php.net/manual/en/function.imagecopyresampled.php
- * @param resource $dst_image
- * @param resource $src_image
- * @param int $dst_x <p>
- * x-coordinate of destination point.
- * </p>
- * @param int $dst_y <p>
- * y-coordinate of destination point.
- * </p>
- * @param int $src_x <p>
- * x-coordinate of source point.
- * </p>
- * @param int $src_y <p>
- * y-coordinate of source point.
- * </p>
- * @param int $dst_w <p>
- * Destination width.
- * </p>
- * @param int $dst_h <p>
- * Destination height.
- * </p>
- * @param int $src_w <p>
- * Source width.
- * </p>
- * @param int $src_h <p>
- * Source height.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagecopyresampled ($dst_image, $src_image, $dst_x, $dst_y, $src_x, $src_y, $dst_w, $dst_h, $src_w, $src_h) {}
-
-/**
- * Rotate an image with a given angle
- * @link https://php.net/manual/en/function.imagerotate.php
- * @param resource $image
- * @param float $angle <p>
- * Rotation angle, in degrees.
- * </p>
- * @param int $bgd_color <p>
- * Specifies the color of the uncovered zone after the rotation
- * </p>
- * @param int $ignore_transparent [optional] <p>
- * If set and non-zero, transparent colors are ignored (otherwise kept).
- * </p>
- * @return resource|false the rotated image or <b>FALSE</b> on failure
- */
-function imagerotate ($image, $angle, $bgd_color, $ignore_transparent = null) {}
-
-/**
- * Should antialias functions be used or not. <br/>
- * Before 7.2.0 it's only available if PHP iscompiled with the bundled version of the GD library.
- * @link https://php.net/manual/en/function.imageantialias.php
- * @param resource $image
- * @param bool $enabled <p>
- * Whether to enable antialiasing or not.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imageantialias ($image, $enabled) {}
-
-/**
- * Set the tile image for filling
- * @link https://php.net/manual/en/function.imagesettile.php
- * @param resource $image
- * @param resource $tile <p>
- * The image resource to be used as a tile.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagesettile ($image, $tile) {}
-
-/**
- * Set the brush image for line drawing
- * @link https://php.net/manual/en/function.imagesetbrush.php
- * @param resource $image
- * @param resource $brush <p>
- * An image resource.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagesetbrush ($image, $brush) {}
-
-/**
- * Set the style for line drawing
- * @link https://php.net/manual/en/function.imagesetstyle.php
- * @param resource $image
- * @param array $style <p>
- * An array of pixel colors. You can use the
- * IMG_COLOR_TRANSPARENT constant to add a
- * transparent pixel.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagesetstyle ($image, array $style) {}
-
-/**
- * Create a new image from file or URL
- * @link https://php.net/manual/en/function.imagecreatefrompng.php
- * @param string $filename <p>
- * Path to the PNG image.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatefrompng ($filename) {}
-
-/**
- * Create a new image from file or URL
- * @link https://php.net/manual/en/function.imagecreatefromgif.php
- * @param string $filename <p>
- * Path to the GIF image.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatefromgif ($filename) {}
-
-/**
- * Create a new image from file or URL
- * @link https://php.net/manual/en/function.imagecreatefromjpeg.php
- * @param string $filename <p>
- * Path to the JPEG image.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatefromjpeg ($filename) {}
-
-/**
- * Create a new image from file or URL
- * @link https://php.net/manual/en/function.imagecreatefromwbmp.php
- * @param string $filename <p>
- * Path to the WBMP image.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatefromwbmp ($filename) {}
-
-/**
- * Create a new image from file or URL
- * @link https://php.net/manual/en/function.imagecreatefromwebp.php
- * @param string $filename <p>
- * Path to the WebP image.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- * @since 5.4
- */
-function imagecreatefromwebp ($filename) {}
-
-/**
- * Create a new image from file or URL
- * @link https://php.net/manual/en/function.imagecreatefromxbm.php
- * @param string $filename <p>
- * Path to the XBM image.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatefromxbm ($filename) {}
-
-/**
- * Create a new image from file or URL
- * @link https://php.net/manual/en/function.imagecreatefromxpm.php
- * @param string $filename <p>
- * Path to the XPM image.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatefromxpm ($filename) {}
-
-/**
- * Create a new image from GD file or URL
- * @link https://php.net/manual/en/function.imagecreatefromgd.php
- * @param string $filename <p>
- * Path to the GD file.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatefromgd ($filename) {}
-
-/**
- * Create a new image from GD2 file or URL
- * @link https://php.net/manual/en/function.imagecreatefromgd2.php
- * @param string $filename <p>
- * Path to the GD2 image.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatefromgd2 ($filename) {}
-
-/**
- * Create a new image from a given part of GD2 file or URL
- * @link https://php.net/manual/en/function.imagecreatefromgd2part.php
- * @param string $filename <p>
- * Path to the GD2 image.
- * </p>
- * @param int $srcX <p>
- * x-coordinate of source point.
- * </p>
- * @param int $srcY <p>
- * y-coordinate of source point.
- * </p>
- * @param int $width <p>
- * Source width.
- * </p>
- * @param int $height <p>
- * Source height.
- * </p>
- * @return resource|false an image resource identifier on success, false on errors.
- */
-function imagecreatefromgd2part ($filename, $srcX, $srcY, $width, $height) {}
-
-/**
- * Output a PNG image to either the browser or a file
- * @link https://php.net/manual/en/function.imagepng.php
- * @param resource $image
- * @param string $filename [optional] <p>
- * The path to save the file to. If not set or &null;, the raw image stream
- * will be outputted directly.
- * </p>
- * <p>
- * &null; is invalid if the quality and
- * filters arguments are not used.
- * </p>
- * @param int $quality [optional] <p>
- * Compression level: from 0 (no compression) to 9.
- * </p>
- * @param int $filters [optional] <p>
- * Allows reducing the PNG file size. It is a bitmask field which may be
- * set to any combination of the PNG_FILTER_XXX
- * constants. PNG_NO_FILTER or
- * PNG_ALL_FILTERS may also be used to respectively
- * disable or activate all filters.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagepng ($image, $filename = null, $quality = null, $filters = null) {}
-
-/**
- * Output a WebP image to browser or file
- * @link https://php.net/manual/en/function.imagewebp.php
- * @param resource $image
- * @param string $to [optional] <p>
- * The path to save the file to. If not set or &null;, the raw image stream
- * will be outputted directly.
- * </p>
- * @param int $quality [optional] <p>
- * quality ranges from 0 (worst quality, smaller file) to 100 (best quality, biggest file).
- * </p>
- * @return bool true on success or false on failure.
- * @since 5.4
- */
-function imagewebp ($image, $to = null, $quality = 80) {}
-
-/**
- * Output image to browser or file
- * @link https://php.net/manual/en/function.imagegif.php
- * @param resource $image
- * @param string $filename [optional] <p>
- * The path to save the file to. If not set or &null;, the raw image stream
- * will be outputted directly.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagegif ($image, $filename = null) {}
-
-/**
- * Output image to browser or file
- * @link https://php.net/manual/en/function.imagejpeg.php
- * @param resource $image
- * @param string $filename [optional] <p>
- * The path to save the file to. If not set or &null;, the raw image stream
- * will be outputted directly.
- * </p>
- * <p>
- * To skip this argument in order to provide the
- * quality parameter, use &null;.
- * </p>
- * @param int $quality [optional] <p>
- * quality is optional, and ranges from 0 (worst
- * quality, smaller file) to 100 (best quality, biggest file). The
- * default is the default IJG quality value (about 75).
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagejpeg ($image, $filename = null, $quality = null) {}
-
-/**
- * Output image to browser or file
- * @link https://php.net/manual/en/function.imagewbmp.php
- * @param resource $image
- * @param string $filename [optional] <p>
- * The path to save the file to. If not set or &null;, the raw image stream
- * will be outputted directly.
- * </p>
- * @param int $foreground [optional] <p>
- * You can set the foreground color with this parameter by setting an
- * identifier obtained from imagecolorallocate.
- * The default foreground color is black.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagewbmp ($image, $filename = null, $foreground = null) {}
-
-/**
- * Output GD image to browser or file. <br/>
- * Since 7.2.0 allows to output truecolor images.
- * @link https://php.net/manual/en/function.imagegd.php
- * @param resource $image
- * @param string $filename [optional] <p>
- * The path to save the file to. If not set or &null;, the raw image stream
- * will be outputted directly.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagegd ($image, $filename = null) {}
-
-/**
- * Output GD2 image to browser or file
- * @link https://php.net/manual/en/function.imagegd2.php
- * @param resource $image
- * @param string $filename [optional] <p>
- * The path to save the file to. If not set or &null;, the raw image stream
- * will be outputted directly.
- * </p>
- * @param int $chunk_size [optional] <p>
- * Chunk size.
- * </p>
- * @param int $type [optional] <p>
- * Either IMG_GD2_RAW or
- * IMG_GD2_COMPRESSED. Default is
- * IMG_GD2_RAW.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagegd2 ($image, $filename = null, $chunk_size = null, $type = null) {}
-
-/**
- * Destroy an image
- * @link https://php.net/manual/en/function.imagedestroy.php
- * @param resource $image
- * @return bool true on success or false on failure.
- */
-function imagedestroy ($image) {}
-
-/**
- * Apply a gamma correction to a GD image
- * @link https://php.net/manual/en/function.imagegammacorrect.php
- * @param resource $image
- * @param float $inputgamma <p>
- * The input gamma.
- * </p>
- * @param float $outputgamma <p>
- * The output gamma.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagegammacorrect ($image, $inputgamma, $outputgamma) {}
-
-/**
- * Flood fill
- * @link https://php.net/manual/en/function.imagefill.php
- * @param resource $image
- * @param int $x <p>
- * x-coordinate of start point.
- * </p>
- * @param int $y <p>
- * y-coordinate of start point.
- * </p>
- * @param int $color <p>
- * The fill color. A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagefill ($image, $x, $y, $color) {}
-
-/**
- * Draw a filled polygon
- * @link https://php.net/manual/en/function.imagefilledpolygon.php
- * @param resource $image
- * @param array $points <p>
- * An array containing the x and y
- * coordinates of the polygons vertices consecutively.
- * </p>
- * @param int $num_points [optional] <p>
- * Total number of vertices, which must be at least 3.
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagefilledpolygon ($image, array $points, $num_points, $color) {}
-
-/**
- * Draw a filled rectangle
- * @link https://php.net/manual/en/function.imagefilledrectangle.php
- * @param resource $image
- * @param int $x1 <p>
- * x-coordinate for point 1.
- * </p>
- * @param int $y1 <p>
- * y-coordinate for point 1.
- * </p>
- * @param int $x2 <p>
- * x-coordinate for point 2.
- * </p>
- * @param int $y2 <p>
- * y-coordinate for point 2.
- * </p>
- * @param int $color <p>
- * The fill color. A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagefilledrectangle ($image, $x1, $y1, $x2, $y2, $color) {}
-
-/**
- * Flood fill to specific color
- * @link https://php.net/manual/en/function.imagefilltoborder.php
- * @param resource $image
- * @param int $x <p>
- * x-coordinate of start.
- * </p>
- * @param int $y <p>
- * y-coordinate of start.
- * </p>
- * @param int $border <p>
- * The border color. A color identifier created with
- * imagecolorallocate.
- * </p>
- * @param int $color <p>
- * The fill color. A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagefilltoborder ($image, $x, $y, $border, $color) {}
-
-/**
- * Get font width
- * @link https://php.net/manual/en/function.imagefontwidth.php
- * @param int $font
- * @return int the width of the pixel
- */
-function imagefontwidth ($font) {}
-
-/**
- * Get font height
- * @link https://php.net/manual/en/function.imagefontheight.php
- * @param int $font
- * @return int the height of the pixel.
- */
-function imagefontheight ($font) {}
-
-/**
- * Enable or disable interlace
- * @link https://php.net/manual/en/function.imageinterlace.php
- * @param resource $image
- * @param int $interlace [optional] <p>
- * If non-zero, the image will be interlaced, else the interlace bit is
- * turned off.
- * </p>
- * @return int|false 1 if the interlace bit is set for the image,
- * 0 if it is not, or <b>FALSE</b> on failure
- */
-function imageinterlace ($image, $interlace = null) {}
-
-/**
- * Draw a line
- * @link https://php.net/manual/en/function.imageline.php
- * @param resource $image
- * @param int $x1 <p>
- * x-coordinate for first point.
- * </p>
- * @param int $y1 <p>
- * y-coordinate for first point.
- * </p>
- * @param int $x2 <p>
- * x-coordinate for second point.
- * </p>
- * @param int $y2 <p>
- * y-coordinate for second point.
- * </p>
- * @param int $color <p>
- * The line color. A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imageline ($image, $x1, $y1, $x2, $y2, $color) {}
-
-/**
- * Load a new font
- * @link https://php.net/manual/en/function.imageloadfont.php
- * @param string $file <p>
- * The font file format is currently binary and architecture
- * dependent. This means you should generate the font files on the
- * same type of CPU as the machine you are running PHP on.
- * </p>
- * <p>
- * <table>
- * Font file format
- * <tr valign="top">
- * <td>byte position</td>
- * <td>C data type</td>
- * <td>description</td>
- * </tr>
- * <tr valign="top">
- * <td>byte 0-3</td>
- * <td>int</td>
- * <td>number of characters in the font</td>
- * </tr>
- * <tr valign="top">
- * <td>byte 4-7</td>
- * <td>int</td>
- * <td>
- * value of first character in the font (often 32 for space)
- * </td>
- * </tr>
- * <tr valign="top">
- * <td>byte 8-11</td>
- * <td>int</td>
- * <td>pixel width of each character</td>
- * </tr>
- * <tr valign="top">
- * <td>byte 12-15</td>
- * <td>int</td>
- * <td>pixel height of each character</td>
- * </tr>
- * <tr valign="top">
- * <td>byte 16-</td>
- * <td>char</td>
- * <td>
- * array with character data, one byte per pixel in each
- * character, for a total of (nchars*width*height) bytes.
- * </td>
- * </tr>
- * </table>
- * </p>
- * @return int|false The font identifier which is always bigger than 5 to avoid conflicts with
- * built-in fonts or false on errors.
- */
-function imageloadfont ($file) {}
-
-/**
- * Draws a polygon
- * @link https://php.net/manual/en/function.imagepolygon.php
- * @param resource $image
- * @param array $points <p>
- * An array containing the polygon's vertices, e.g.:
- * <tr valign="top">
- * <td>points[0]</td>
- * <td>= x0</td>
- * </tr>
- * <tr valign="top">
- * <td>points[1]</td>
- * <td>= y0</td>
- * </tr>
- * <tr valign="top">
- * <td>points[2]</td>
- * <td>= x1</td>
- * </tr>
- * <tr valign="top">
- * <td>points[3]</td>
- * <td>= y1</td>
- * </tr>
- * </p>
- * @param int $num_points [optional] <p>
- * Total number of points (vertices).
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagepolygon ($image, array $points, $num_points, $color) {}
-
-/**
- * Draw a rectangle
- * @link https://php.net/manual/en/function.imagerectangle.php
- * @param resource $image
- * @param int $x1 <p>
- * Upper left x coordinate.
- * </p>
- * @param int $y1 <p>
- * Upper left y coordinate
- * 0, 0 is the top left corner of the image.
- * </p>
- * @param int $x2 <p>
- * Bottom right x coordinate.
- * </p>
- * @param int $y2 <p>
- * Bottom right y coordinate.
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagerectangle ($image, $x1, $y1, $x2, $y2, $color) {}
-
-/**
- * Set a single pixel
- * @link https://php.net/manual/en/function.imagesetpixel.php
- * @param resource $image
- * @param int $x <p>
- * x-coordinate.
- * </p>
- * @param int $y <p>
- * y-coordinate.
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagesetpixel ($image, $x, $y, $color) {}
-
-/**
- * Draw a string horizontally
- * @link https://php.net/manual/en/function.imagestring.php
- * @param resource $image
- * @param int $font
- * @param int $x <p>
- * x-coordinate of the upper left corner.
- * </p>
- * @param int $y <p>
- * y-coordinate of the upper left corner.
- * </p>
- * @param string $string <p>
- * The string to be written.
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagestring ($image, $font, $x, $y, $string, $color) {}
-
-/**
- * Draw a string vertically
- * @link https://php.net/manual/en/function.imagestringup.php
- * @param resource $image
- * @param int $font
- * @param int $x <p>
- * x-coordinate of the upper left corner.
- * </p>
- * @param int $y <p>
- * y-coordinate of the upper left corner.
- * </p>
- * @param string $string <p>
- * The string to be written.
- * </p>
- * @param int $color <p>
- * A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagestringup ($image, $font, $x, $y, $string, $color) {}
-
-/**
- * Get image width
- * @link https://php.net/manual/en/function.imagesx.php
- * @param resource $image
- * @return int|false Return the width of the image or false on
- * errors.
- */
-function imagesx ($image) {}
-
-/**
- * Get image height
- * @link https://php.net/manual/en/function.imagesy.php
- * @param resource $image
- * @return int|false Return the height of the image or false on
- * errors.
- */
-function imagesy ($image) {}
-
-/**
- * Draw a dashed line
- * @link https://php.net/manual/en/function.imagedashedline.php
- * @param resource $image
- * @param int $x1 <p>
- * Upper left x coordinate.
- * </p>
- * @param int $y1 <p>
- * Upper left y coordinate 0, 0 is the top left corner of the image.
- * </p>
- * @param int $x2 <p>
- * Bottom right x coordinate.
- * </p>
- * @param int $y2 <p>
- * Bottom right y coordinate.
- * </p>
- * @param int $color <p>
- * The fill color. A color identifier created with
- * imagecolorallocate.
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- * @deprecated Use combination of imagesetstyle() and imageline() instead
- */
-function imagedashedline ($image, $x1, $y1, $x2, $y2, $color) {}
-
-/**
- * Give the bounding box of a text using TrueType fonts
- * @link https://php.net/manual/en/function.imagettfbbox.php
- * @param float $size <p>
- * The font size. Depending on your version of GD, this should be
- * specified as the pixel size (GD1) or point size (GD2).
- * </p>
- * @param float $angle <p>
- * Angle in degrees in which text will be measured.
- * </p>
- * @param string $fontfile <p>
- * The name of the TrueType font file (can be a URL). Depending on
- * which version of the GD library that PHP is using, it may attempt to
- * search for files that do not begin with a leading '/' by appending
- * '.ttf' to the filename and searching along a library-defined font path.
- * </p>
- * @param string $text <p>
- * The string to be measured.
- * </p>
- * @return array|false imagettfbbox returns an array with 8
- * elements representing four points making the bounding box of the
- * text on success and false on error.
- * <tr valign="top">
- * <td>key</td>
- * <td>contents</td>
- * </tr>
- * <tr valign="top">
- * <td>0</td>
- * <td>lower left corner, X position</td>
- * </tr>
- * <tr valign="top">
- * <td>1</td>
- * <td>lower left corner, Y position</td>
- * </tr>
- * <tr valign="top">
- * <td>2</td>
- * <td>lower right corner, X position</td>
- * </tr>
- * <tr valign="top">
- * <td>3</td>
- * <td>lower right corner, Y position</td>
- * </tr>
- * <tr valign="top">
- * <td>4</td>
- * <td>upper right corner, X position</td>
- * </tr>
- * <tr valign="top">
- * <td>5</td>
- * <td>upper right corner, Y position</td>
- * </tr>
- * <tr valign="top">
- * <td>6</td>
- * <td>upper left corner, X position</td>
- * </tr>
- * <tr valign="top">
- * <td>7</td>
- * <td>upper left corner, Y position</td>
- * </tr>
- * </p>
- * <p>
- * The points are relative to the text regardless of the
- * angle, so "upper left" means in the top left-hand
- * corner seeing the text horizontally.
- */
-function imagettfbbox ($size, $angle, $fontfile, $text) {}
-
-/**
- * Write text to the image using TrueType fonts
- * @link https://php.net/manual/en/function.imagettftext.php
- * @param resource $image
- * @param float $size <p>
- * The font size. Depending on your version of GD, this should be
- * specified as the pixel size (GD1) or point size (GD2).
- * </p>
- * @param float $angle <p>
- * The angle in degrees, with 0 degrees being left-to-right reading text.
- * Higher values represent a counter-clockwise rotation. For example, a
- * value of 90 would result in bottom-to-top reading text.
- * </p>
- * @param int $x <p>
- * The coordinates given by x and
- * y will define the basepoint of the first
- * character (roughly the lower-left corner of the character). This
- * is different from the imagestring, where
- * x and y define the
- * upper-left corner of the first character. For example, "top left"
- * is 0, 0.
- * </p>
- * @param int $y <p>
- * The y-ordinate. This sets the position of the fonts baseline, not the
- * very bottom of the character.
- * </p>
- * @param int $color <p>
- * The color index. Using the negative of a color index has the effect of
- * turning off antialiasing. See imagecolorallocate.
- * </p>
- * @param string $fontfile <p>
- * The path to the TrueType font you wish to use.
- * </p>
- * <p>
- * Depending on which version of the GD library PHP is using, when
- * fontfile does not begin with a leading
- * / then .ttf will be appended
- * to the filename and the library will attempt to search for that
- * filename along a library-defined font path.
- * </p>
- * <p>
- * When using versions of the GD library lower than 2.0.18, a space character,
- * rather than a semicolon, was used as the 'path separator' for different font files.
- * Unintentional use of this feature will result in the warning message:
- * Warning: Could not find/open font. For these affected versions, the
- * only solution is moving the font to a path which does not contain spaces.
- * </p>
- * <p>
- * In many cases where a font resides in the same directory as the script using it
- * the following trick will alleviate any include problems.
- * </p>
- * <pre>
- * <?php
- * // Set the enviroment variable for GD
- * putenv('GDFONTPATH=' . realpath('.'));
- *
- * // Name the font to be used (note the lack of the .ttf extension)
- * $font = 'SomeFont';
- * ?>
- * </pre>
- * <p>
- * <strong>Note:</strong>
- * <code>open_basedir</code> does <em>not</em> apply to fontfile.
- * </p>
- * @param string $text <p>
- * The text string in UTF-8 encoding.
- * </p>
- * <p>
- * May include decimal numeric character references (of the form:
- * &amp;#8364;) to access characters in a font beyond position 127.
- * The hexadecimal format (like &amp;#xA9;) is supported.
- * Strings in UTF-8 encoding can be passed directly.
- * </p>
- * <p>
- * Named entities, such as &amp;copy;, are not supported. Consider using
- * html_entity_decode
- * to decode these named entities into UTF-8 strings (html_entity_decode()
- * supports this as of PHP 5.0.0).
- * </p>
- * <p>
- * If a character is used in the string which is not supported by the
- * font, a hollow rectangle will replace the character.
- * </p>
- * @return array|false an array with 8 elements representing four points making the
- * bounding box of the text. The order of the points is lower left, lower
- * right, upper right, upper left. The points are relative to the text
- * regardless of the angle, so "upper left" means in the top left-hand
- * corner when you see the text horizontally.
- * Returns false on error.
- */
-function imagettftext ($image, $size, $angle, $x, $y, $color, $fontfile, $text) {}
-
-/**
- * Give the bounding box of a text using fonts via freetype2
- * @link https://php.net/manual/en/function.imageftbbox.php
- * @param float $size <p>
- * The font size. Depending on your version of GD, this should be
- * specified as the pixel size (GD1) or point size (GD2).
- * </p>
- * @param float $angle <p>
- * Angle in degrees in which text will be
- * measured.
- * </p>
- * @param string $fontfile <p>
- * The name of the TrueType font file (can be a URL). Depending on
- * which version of the GD library that PHP is using, it may attempt to
- * search for files that do not begin with a leading '/' by appending
- * '.ttf' to the filename and searching along a library-defined font path.
- * </p>
- * @param string $text <p>
- * The string to be measured.
- * </p>
- * @param array $extrainfo [optional] <p>
- * <table>
- * Possible array indexes for extrainfo
- * <tr valign="top">
- * <td>Key</td>
- * <td>Type</td>
- * <td>Meaning</td>
- * </tr>
- * <tr valign="top">
- * <td>linespacing</td>
- * <td>float</td>
- * <td>Defines drawing linespacing</td>
- * </tr>
- * </table>
- * </p>
- * @return array|false imageftbbox returns an array with 8
- * elements representing four points making the bounding box of the
- * text:
- * <tr valign="top">
- * <td>0</td>
- * <td>lower left corner, X position</td>
- * </tr>
- * <tr valign="top">
- * <td>1</td>
- * <td>lower left corner, Y position</td>
- * </tr>
- * <tr valign="top">
- * <td>2</td>
- * <td>lower right corner, X position</td>
- * </tr>
- * <tr valign="top">
- * <td>3</td>
- * <td>lower right corner, Y position</td>
- * </tr>
- * <tr valign="top">
- * <td>4</td>
- * <td>upper right corner, X position</td>
- * </tr>
- * <tr valign="top">
- * <td>5</td>
- * <td>upper right corner, Y position</td>
- * </tr>
- * <tr valign="top">
- * <td>6</td>
- * <td>upper left corner, X position</td>
- * </tr>
- * <tr valign="top">
- * <td>7</td>
- * <td>upper left corner, Y position</td>
- * </tr>
- * </p>
- * <p>
- * The points are relative to the text regardless of the
- * angle, so "upper left" means in the top left-hand
- * corner seeing the text horizontally.
- * Returns false on error.
- */
-function imageftbbox ($size, $angle, $fontfile, $text, $extrainfo = null ) {}
-
-/**
- * Write text to the image using fonts using FreeType 2
- * @link https://php.net/manual/en/function.imagefttext.php
- * @param resource $image
- * @param float $size <p>
- * The font size to use in points.
- * </p>
- * @param float $angle <p>
- * The angle in degrees, with 0 degrees being left-to-right reading text.
- * Higher values represent a counter-clockwise rotation. For example, a
- * value of 90 would result in bottom-to-top reading text.
- * </p>
- * @param int $x <p>
- * The coordinates given by x and
- * y will define the basepoint of the first
- * character (roughly the lower-left corner of the character). This
- * is different from the imagestring, where
- * x and y define the
- * upper-left corner of the first character. For example, "top left"
- * is 0, 0.
- * </p>
- * @param int $y <p>
- * The y-ordinate. This sets the position of the fonts baseline, not the
- * very bottom of the character.
- * </p>
- * @param int $color <p>
- * The index of the desired color for the text, see
- * imagecolorexact.
- * </p>
- * @param string $fontfile <p>
- * The path to the TrueType font you wish to use.
- * </p>
- * <p>
- * Depending on which version of the GD library PHP is using, when
- * fontfile does not begin with a leading
- * / then .ttf will be appended
- * to the filename and the library will attempt to search for that
- * filename along a library-defined font path.
- * </p>
- * <p>
- * When using versions of the GD library lower than 2.0.18, a space character,
- * rather than a semicolon, was used as the 'path separator' for different font files.
- * Unintentional use of this feature will result in the warning message:
- * Warning: Could not find/open font. For these affected versions, the
- * only solution is moving the font to a path which does not contain spaces.
- * </p>
- * <p>
- * In many cases where a font resides in the same directory as the script using it
- * the following trick will alleviate any include problems.
- * </p>
- * <pre>
- * <?php
- * // Set the enviroment variable for GD
- * putenv('GDFONTPATH=' . realpath('.'));
- *
- * // Name the font to be used (note the lack of the .ttf extension)
- * $font = 'SomeFont';
- * ?>
- * </pre>
- * <p>
- * <strong>Note:</strong>
- * <code>open_basedir</code> does <em>not</em> apply to fontfile.
- * </p>
- * @param string $text <p>
- * Text to be inserted into image.
- * </p>
- * @param array $extrainfo [optional] <p>
- * <table>
- * Possible array indexes for extrainfo
- * <tr valign="top">
- * <td>Key</td>
- * <td>Type</td>
- * <td>Meaning</td>
- * </tr>
- * <tr valign="top">
- * <td>linespacing</td>
- * <td>float</td>
- * <td>Defines drawing linespacing</td>
- * </tr>
- * </table>
- * </p>
- * @return array|false This function returns an array defining the four points of the box, starting in the lower left and moving counter-clockwise:
- * <tr valign="top">
- * <td>0</td>
- * <td>lower left x-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>1</td>
- * <td>lower left y-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>2</td>
- * <td>lower right x-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>3</td>
- * <td>lower right y-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>4</td>
- * <td>upper right x-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>5</td>
- * <td>upper right y-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>6</td>
- * <td>upper left x-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>7</td>
- * <td>upper left y-coordinate</td>
- * </tr>
- * Returns false on error.
+ * @strict-properties
+ * @not-serializable
*/
-function imagefttext ($image, $size, $angle, $x, $y, $color, $fontfile, $text, $extrainfo = null ) {}
+final class GdFont {}
/**
- * Load a PostScript Type 1 font from file
- * @link https://php.net/manual/en/function.imagepsloadfont.php
- * @param string $filename <p>
- * Path to the Postscript font file.
- * </p>
- * @return resource|false In the case everything went right, a valid font index will be returned and
- * can be used for further purposes. Otherwise the function returns false.
- * @removed 7.0 This function was REMOVED in PHP 7.0.0.
+ * @return array<string, string|bool>
+ * @refcount 1
*/
-function imagepsloadfont ($filename) {}
+function gd_info(): array {}
-/**
- * Free memory used by a PostScript Type 1 font
- * @link https://php.net/manual/en/function.imagepsfreefont.php
- * @param resource $font_index <p>
- * A font resource, returned by imagepsloadfont.
- * </p>
- * @return bool true on success or false on failure.
- * @removed 7.0
- */
-function imagepsfreefont ($font_index) {}
+function imageloadfont(string $filename): GdFont|false {}
-/**
- * Change the character encoding vector of a font
- * @link https://php.net/manual/en/function.imagepsencodefont.php
- * @param resource $font_index <p>
- * A font resource, returned by imagepsloadfont.
- * </p>
- * @param string $encodingfile <p>
- * The exact format of this file is described in T1libs documentation.
- * T1lib comes with two ready-to-use files,
- * IsoLatin1.enc and
- * IsoLatin2.enc.
- * </p>
- * @return bool true on success or false on failure.
- * @removed 7.0
- */
-function imagepsencodefont ($font_index, $encodingfile) {}
+function imagesetstyle(GdImage $image, array $style): bool {}
-/**
- * Extend or condense a font
- * @link https://php.net/manual/en/function.imagepsextendfont.php
- * @param resource $font_index <p>
- * A font resource, returned by imagepsloadfont.
- * </p>
- * @param float $extend <p>
- * Extension value, must be greater than 0.
- * </p>
- * @return bool true on success or false on failure.
- * @removed 7.0
- */
-function imagepsextendfont ($font_index, $extend) {}
+/** @refcount 1 */
+function imagecreatetruecolor(int $width, int $height): GdImage|false {}
-/**
- * Slant a font
- * @link https://php.net/manual/en/function.imagepsslantfont.php
- * @param resource $font_index <p>
- * A font resource, returned by imagepsloadfont.
- * </p>
- * @param float $slant <p>
- * Slant level.
- * </p>
- * @return bool true on success or false on failure.
- * @removed 7.0 This function was REMOVED in PHP 7.0.0.
- */
-function imagepsslantfont ($font_index, $slant) {}
+function imageistruecolor(GdImage $image): bool {}
-/**
- * Draws a text over an image using PostScript Type1 fonts
- * @link https://php.net/manual/en/function.imagepstext.php
- * @param resource $image
- * @param string $text <p>
- * The text to be written.
- * </p>
- * @param resource $font_index <p>
- * A font resource, returned by imagepsloadfont.
- * </p>
- * @param int $size <p>
- * size is expressed in pixels.
- * </p>
- * @param int $foreground <p>
- * The color in which the text will be painted.
- * </p>
- * @param int $background <p>
- * The color to which the text will try to fade in with antialiasing.
- * No pixels with the color background are
- * actually painted, so the background image does not need to be of solid
- * color.
- * </p>
- * @param int $x <p>
- * x-coordinate for the lower-left corner of the first character.
- * </p>
- * @param int $y <p>
- * y-coordinate for the lower-left corner of the first character.
- * </p>
- * @param int $space [optional] <p>
- * Allows you to change the default value of a space in a font. This
- * amount is added to the normal value and can also be negative.
- * Expressed in character space units, where 1 unit is 1/1000th of an
- * em-square.
- * </p>
- * @param int $tightness [optional] <p>
- * tightness allows you to control the amount
- * of white space between characters. This amount is added to the
- * normal character width and can also be negative.
- * Expressed in character space units, where 1 unit is 1/1000th of an
- * em-square.
- * </p>
- * @param float $angle [optional] <p>
- * angle is in degrees.
- * </p>
- * @param int $antialias_steps [optional] <p>
- * Allows you to control the number of colours used for antialiasing
- * text. Allowed values are 4 and 16. The higher value is recommended
- * for text sizes lower than 20, where the effect in text quality is
- * quite visible. With bigger sizes, use 4. It's less computationally
- * intensive.
- * </p>
- * @return array|false This function returns an array containing the following elements:
- * <tr valign="top">
- * <td>0</td>
- * <td>lower left x-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>1</td>
- * <td>lower left y-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>2</td>
- * <td>upper right x-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>3</td>
- * <td>upper right y-coordinate</td>
- * </tr>
- * Returns false on error.
- * @removed 7.0 This function was REMOVED in PHP 7.0.0.
- */
-function imagepstext ($image, $text, $font_index, $size, $foreground, $background, $x, $y, $space = null, $tightness = null, $angle = null, $antialias_steps = null) {}
+function imagetruecolortopalette(GdImage $image, bool $dither, int $num_colors): bool {}
-/**
- * Give the bounding box of a text rectangle using PostScript Type1 fonts
- * @link https://php.net/manual/en/function.imagepsbbox.php
- * @param string $text <p>
- * The text to be written.
- * </p>
- * @param resource $font
- * @param int $size <p>
- * size is expressed in pixels.
- * </p>
- * @return array|false an array containing the following elements:
- * <tr valign="top">
- * <td>0</td>
- * <td>left x-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>1</td>
- * <td>upper y-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>2</td>
- * <td>right x-coordinate</td>
- * </tr>
- * <tr valign="top">
- * <td>3</td>
- * <td>lower y-coordinate</td>
- * </tr>
- * Returns false on error.
- * @removed 7.0
- */
-function imagepsbbox ($text, $font, $size) {}
+function imagepalettetotruecolor(GdImage $image): bool {}
-/**
- * Return the image types supported by this PHP build
- * @link https://php.net/manual/en/function.imagetypes.php
- * @return int a bit-field corresponding to the image formats supported by the
- * version of GD linked into PHP. The following bits are returned,
- * IMG_BMP | IMG_GIF | IMG_JPG | IMG_PNG | IMG_WBMP | IMG_XPM | IMG_WEBP
- */
-function imagetypes () {}
+function imagecolormatch(GdImage $image1, GdImage $image2): bool {}
-/**
- * Convert JPEG image file to WBMP image file
- * @link https://php.net/manual/en/function.jpeg2wbmp.php
- * @param string $jpegname <p>
- * Path to JPEG file.
- * </p>
- * @param string $wbmpname <p>
- * Path to destination WBMP file.
- * </p>
- * @param int $dest_height <p>
- * Destination image height.
- * </p>
- * @param int $dest_width <p>
- * Destination image width.
- * </p>
- * @param int $threshold <p>
- * Threshold value, between 0 and 8 (inclusive).
- * </p>
- * @return bool true on success or false on failure.
- * @deprecated 7.2 Use imagecreatefromjpeg() and imagewbmp() instead
- * @removed 8.0
- */
-function jpeg2wbmp ($jpegname, $wbmpname, $dest_height, $dest_width, $threshold) {}
+function imagesetthickness(GdImage $image, int $thickness): bool {}
-/**
- * Convert PNG image file to WBMP image file
- * @link https://php.net/manual/en/function.png2wbmp.php
- * @param string $pngname <p>
- * Path to PNG file.
- * </p>
- * @param string $wbmpname <p>
- * Path to destination WBMP file.
- * </p>
- * @param int $dest_height <p>
- * Destination image height.
- * </p>
- * @param int $dest_width <p>
- * Destination image width.
- * </p>
- * @param int $threshold <p>
- * Threshold value, between 0 and 8 (inclusive).
- * </p>
- * @return bool true on success or false on failure.
- * @deprecated 7.2 Use imagecreatefrompng() and imagewbmp() instead
- * @removed 8.0
- */
-function png2wbmp ($pngname, $wbmpname, $dest_height, $dest_width, $threshold) {}
+function imagefilledellipse(GdImage $image, int $center_x, int $center_y, int $width, int $height, int $color): bool {}
-/**
- * Output image to browser or file
- * @link https://php.net/manual/en/function.image2wbmp.php
- * @param resource $image
- * @param string $filename [optional] <p>
- * Path to the saved file. If not given, the raw image stream will be
- * outputted directly.
- * </p>
- * @param int $threshold [optional] <p>
- * Threshold value, between 0 and 255 (inclusive).
- * </p>
- * @return bool true on success or false on failure.
- * @deprecated 7.3 Use imagewbmp() instead
- * @removed 8.0
- */
-function image2wbmp ($image, $filename = null, $threshold = null) {}
+function imagefilledarc(GdImage $image, int $center_x, int $center_y, int $width, int $height, int $start_angle, int $end_angle, int $color, int $style): bool {}
-/**
- * Set the alpha blending flag to use the bundled libgd layering effects
- * @link https://php.net/manual/en/function.imagelayereffect.php
- * @param resource $image
- * @param int $effect <p>
- * One of the following constants:
- * IMG_EFFECT_REPLACE
- * Use pixel replacement (equivalent of passing true to
- * imagealphablending)
- * @return bool true on success or false on failure.
- */
-function imagelayereffect ($image, $effect) {}
+function imagealphablending(GdImage $image, bool $enable): bool {}
-/**
- * Makes the colors of the palette version of an image more closely match the true color version
- * @link https://php.net/manual/en/function.imagecolormatch.php
- * @param $image1 resource <p>
- * A truecolor image link resource.
- * </p>
- * @param $image2 resource <p>
- * A palette image link resource pointing to an image that has the same
- * size as image1.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagecolormatch ($image1, $image2) {}
+function imagesavealpha(GdImage $image, bool $enable): bool {}
-/**
- * Output XBM image to browser or file
- * @link https://php.net/manual/en/function.imagexbm.php
- * @param resource $image
- * @param string $filename <p>
- * The path to save the file to. If not set or &null;, the raw image stream
- * will be outputted directly.
- * </p>
- * @param int $foreground [optional] <p>
- * You can set the foreground color with this parameter by setting an
- * identifier obtained from imagecolorallocate.
- * The default foreground color is black.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imagexbm ($image, $filename, $foreground = null) {}
+function imagelayereffect(GdImage $image, int $effect): bool {}
-/**
- * Applies a filter to an image
- * @link https://php.net/manual/en/function.imagefilter.php
- * @param resource $image
- * @param int $filtertype <p>
- * filtertype can be one of the following:
- * IMG_FILTER_NEGATE: Reverses all colors of
- * the image.
- * @param int $arg1 [optional] <p>
- * IMG_FILTER_BRIGHTNESS: Brightness level.
- * @param int $arg2 [optional] <p>
- * IMG_FILTER_COLORIZE: Value of green component.
- * @param int $arg3 [optional] <p>
- * IMG_FILTER_COLORIZE: Value of blue component.
- * @param int $arg4 [optional] <p>
- * IMG_FILTER_COLORIZE: Alpha channel, A value
- * between 0 and 127. 0 indicates completely opaque while 127 indicates
- * completely transparent.
- * @return bool true on success or false on failure.
- */
-function imagefilter ($image, $filtertype, $arg1 = null, $arg2 = null, $arg3 = null, $arg4 = null) {}
+function imagecolorallocatealpha(GdImage $image, int $red, int $green, int $blue, int $alpha): int|false {}
-/**
- * Apply a 3x3 convolution matrix, using coefficient and offset
- * @link https://php.net/manual/en/function.imageconvolution.php
- * @param resource $image
- * @param array $matrix <p>
- * A 3x3 matrix: an array of three arrays of three floats.
- * </p>
- * @param float $div <p>
- * The divisor of the result of the convolution, used for normalization.
- * </p>
- * @param float $offset <p>
- * Color offset.
- * </p>
- * @return bool true on success or false on failure.
- */
-function imageconvolution ($image, array $matrix, $div, $offset) {}
+function imagecolorresolvealpha(GdImage $image, int $red, int $green, int $blue, int $alpha): int {}
-/**
- * @param resource $im An image resource, returned by one of the image creation functions, such as {@see imagecreatetruecolor()}.
- * @param int $res_x [optional] The horizontal resolution in DPI.
- * @param int $res_y [optional] The vertical resolution in DPI.
- * @return array|bool When used as getter (that is without the optional parameters), it returns <b>TRUE</b> on success, or <b>FALSE</b> on failure. When used as setter (that is with one or both optional parameters given), it returns an indexed array of the horizontal and vertical resolution on success, or <b>FALSE</b> on failure.
- * @link https://php.net/manual/en/function.imageresolution.php
- * @since 7.2
- */
-function imageresolution ($im, $res_x = 96, $res_y = 96) {}
+function imagecolorclosestalpha(GdImage $image, int $red, int $green, int $blue, int $alpha): int {}
+function imagecolorexactalpha(GdImage $image, int $red, int $green, int $blue, int $alpha): int {}
-/**
- * <b>imagesetclip()</b> sets the current clipping rectangle, i.e. the area beyond which no pixels will be drawn.
- * @param resource $im An image resource, returned by one of the image creation functions, such as {@see imagecreatetruecolor()}.
- * @param int $x1 The x-coordinate of the upper left corner.
- * @param int $y1 The y-coordinate of the upper left corner.
- * @param int $x2 The x-coordinate of the lower right corner.
- * @param int $y2 The y-coordinate of the lower right corner.
- * @return bool Returns <b>TRUE</b> on success or <b>FALSE</b> on failure.
- * @link https://php.net/manual/en/function.imagesetclip.php
- * @see imagegetclip()
- * @since 7.2
- */
-function imagesetclip ($im, $x1, $y1, $x2, $y2) {}
+function imagecopyresampled(GdImage $dst_image, GdImage $src_image, int $dst_x, int $dst_y, int $src_x, int $src_y, int $dst_width, int $dst_height, int $src_width, int $src_height): bool {}
-/**
- * <b>imagegetclip()</b> retrieves the current clipping rectangle, i.e. the area beyond which no pixels will be drawn.
- * @param resource $im An image resource, returned by one of the image creation functions, such as {@see imagecreatetruecolor()}
- * @return array|false an indexed array with the coordinates of the clipping rectangle which has the following entries:
- * <ul>
- * <li>x-coordinate of the upper left corner</li>
- * <li>y-coordinate of the upper left corner</li>
- * <li>x-coordinate of the lower right corner</li>
- * <li>y-coordinate of the lower right corner</li>
- * </ul>
- * Returns <b>FALSE</b> on error.
- * @link https://php.net/manual/en/function.imagegetclip.php
- * @see imagesetclip()
- * @since 7.2
- */
-function imagegetclip ($im) {}
+#ifdef PHP_WIN32
-/**
- * <b>imageopenpolygon()</b> draws an open polygon on the given <b>image.</b> Contrary to {@see imagepolygon()}, no line is drawn between the last and the first point.
- * @param resource $image An image resource, returned by one of the image creation functions, such as {@see imagecreatetruecolor()}.
- * @param array $points An array containing the polygon's vertices, e.g.:
- * <pre>
- * points[0] = x0
- * points[1] = y0
- * points[2] = x1
- * points[3] = y1
- * </pre>
- * @param int $num_points [optional] Total number of points (vertices).
- * @param int $color A color identifier created with {@see imagecolorallocate()}.
- * @return bool Returns <b>TRUE</b> on success or <b>FALSE</b> on failure.
- * @link https://php.net/manual/en/function.imageopenpolygon.php
- * @since 7.2
- * @see imageplygon()
- */
-function imageopenpolygon ($image , $points, $num_points, $color) {}
+/** @refcount 1 */
+function imagegrabwindow(int $handle, bool $client_area = false): GdImage|false {}
-/**
- * <b>imagecreatefrombmp()</b> returns an image identifier representing the image obtained from the given filename.
- * <b>TIP</b> A URL can be used as a filename with this function if the fopen wrappers have been enabled. See {@see fopen()} for more details on how to specify the filename. See the Supported Protocols and Wrappers for links to information about what abilities the various wrappers have, notes on their usage, and information on any predefined variables they may provide.
- * @param string $filename Path to the BMP image.
- * @return resource|false Returns an image resource identifier on success, <b>FALSE</b> on errors.
- * @link https://php.net/manual/en/function.imagecreatefrombmp.php
- * @since 7.2
- */
-function imagecreatefrombmp($filename){}
+/** @refcount 1 */
+function imagegrabscreen(): GdImage|false {}
-/**
- * Outputs or saves a BMP version of the given <b>image</b>.
- * @param resource $image An image resource, returned by one of the image creation functions, such as {@see imagecreatetruecolor()}.
- * @param mixed $to The path or an open stream resource (which is automatically being closed after this function returns) to save the file to. If not set or <b>NULL</b>, the raw image stream will be outputted directly.
- * <br />
- * <b>Note:</b> <b>NULL</b> is invalid if the <b>compressed</b> arguments is not used.
- * @param bool $compressed Whether the BMP should be compressed with run-length encoding (RLE), or not.
- * @return bool Returns <b>TRUE</b> on success or <b>FALSE</b> on failure.
- * <br />
- * <b>Caution</b> However, if libgd fails to output the image, this function returns <b>TRUE</b>.
- * @link https://php.net/manual/en/function.imagebmp.php
- * @since 7.2
- */
-function imagebmp ($image, $to = null, $compressed = true) {}
+#endif
-/**
- * @param string $filename
- * @return resource|false
- */
-function imagecreatefromtga($filename) {}
+// TODO: $ignore_transparent is ignored???
+/** @refcount 1 */
+function imagerotate(GdImage $image, float $angle, int $background_color, bool $ignore_transparent = false): GdImage|false {}
-/**
- * Captures the whole screen
- *
- * https://www.php.net/manual/en/function.imagegrabscreen.php
- *
- * @return resource|false
- */
-function imagegrabscreen() {}
+function imagesettile(GdImage $image, GdImage $tile): bool {}
-/**
- * Captures a window
- *
- * @link https://www.php.net/manual/en/function.imagegrabwindow.php
- *
- * @param int $handle
- * @param int|null $client_area
- * @return resource|false
- */
-function imagegrabwindow($handle, $client_area = null) {}
+function imagesetbrush(GdImage $image, GdImage $brush): bool {}
-/**
- * Used as a return value by {@see imagetypes()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-gif
- */
-define ('IMG_GIF', 1);
+/** @refcount 1 */
+function imagecreate(int $width, int $height): GdImage|false {}
-/**
- * Used as a return value by {@see imagetypes()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-jpg
- */
-define ('IMG_JPG', 2);
+function imagetypes(): int {}
-/**
- * Used as a return value by {@see imagetypes()}
- * <p>
- * This constant has the same value as {@see IMG_JPG}
- * </p>
- * @link https://php.net/manual/en/image.constants.php#constant.img-jpeg
- */
-define ('IMG_JPEG', 2);
+/** @refcount 1 */
+function imagecreatefromstring(string $data): GdImage|false {}
-/**
- * Used as a return value by {@see imagetypes()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-png
- */
-define ('IMG_PNG', 4);
+#ifdef HAVE_GD_AVIF
+/** @refcount 1 */
+function imagecreatefromavif(string $filename): GdImage|false {}
+#endif
-/**
- * Used as a return value by {@see imagetypes()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-wbmp
- */
-define ('IMG_WBMP', 8);
+/** @refcount 1 */
+function imagecreatefromgif(string $filename): GdImage|false {}
-/**
- * Used as a return value by {@see imagetypes()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-xpm
- */
-define ('IMG_XPM', 16);
+#ifdef HAVE_GD_JPG
+/** @refcount 1 */
+function imagecreatefromjpeg(string $filename): GdImage|false {}
+#endif
-/**
- * Used as a return value by {@see imagetypes()}
- * @since 5.6.25
- * @since 7.0.10
- * @link https://php.net/manual/en/image.constants.php#constant.img-webp
- */
-define('IMG_WEBP', 32);
+#ifdef HAVE_GD_PNG
+/** @refcount 1 */
+function imagecreatefrompng(string $filename): GdImage|false {}
+#endif
-/**
- * Used as a return value by {@see imagetypes()}
- * @since 7.2
- * @link https://php.net/manual/en/image.constants.php#constant.img-bmp
- */
-define('IMG_BMP', 64);
+#ifdef HAVE_GD_WEBP
+/** @refcount 1 */
+function imagecreatefromwebp(string $filename): GdImage|false {}
+#endif
-/**
- * Special color option which can be used instead of color allocated with
- * {@see imagecolorallocate()} or {@see imagecolorallocatealpha()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-color-tiled
- */
-define ('IMG_COLOR_TILED', -5);
+/** @refcount 1 */
+function imagecreatefromxbm(string $filename): GdImage|false {}
-/**
- * Special color option which can be used instead of color allocated with
- * {@see imagecolorallocate()} or {@see imagecolorallocatealpha()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-color-styled
- */
-define ('IMG_COLOR_STYLED', -2);
+#ifdef HAVE_GD_XPM
+/** @refcount 1 */
+function imagecreatefromxpm(string $filename): GdImage|false {}
+#endif
-/**
- * Special color option which can be used instead of color allocated with
- * {@see imagecolorallocate()} or {@see imagecolorallocatealpha()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-color-brushed
- */
-define ('IMG_COLOR_BRUSHED', -3);
+/** @refcount 1 */
+function imagecreatefromwbmp(string $filename): GdImage|false {}
-/**
- * Special color option which can be used instead of color allocated with
- * {@see imagecolorallocate()} or {@see imagecolorallocatealpha()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-color-styledbrushed
- */
-define ('IMG_COLOR_STYLEDBRUSHED', -4);
+/** @refcount 1 */
+function imagecreatefromgd(string $filename): GdImage|false {}
-/**
- * Special color option which can be used instead of color allocated with
- * {@see imagecolorallocate()} or {@see imagecolorallocatealpha()}
- * @link https://php.net/manual/en/image.constants.php#constant.img-color-transparent
- */
-define ('IMG_COLOR_TRANSPARENT', -6);
+/** @refcount 1 */
+function imagecreatefromgd2(string $filename): GdImage|false {}
-/**
- * A style constant used by the {@see imagefilledarc()} function.
- * <p>
- * This constant has the same value as {@see IMG_ARC_PIE}
- * </p>
- * @link https://php.net/manual/en/image.constants.php#constant.img-arc-rounded
- */
-define ('IMG_ARC_ROUNDED', 0);
+/** @refcount 1 */
+function imagecreatefromgd2part(string $filename, int $x, int $y, int $width, int $height): GdImage|false {}
-/**
- * A style constant used by the {@see imagefilledarc()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-arc-pie
- */
-define ('IMG_ARC_PIE', 0);
+#ifdef HAVE_GD_BMP
+/** @refcount 1 */
+function imagecreatefrombmp(string $filename): GdImage|false {}
+#endif
-/**
- * A style constant used by the {@see imagefilledarc()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-arc-chord
- */
-define ('IMG_ARC_CHORD', 1);
+#ifdef HAVE_GD_TGA
+function imagecreatefromtga(string $filename): GdImage|false {}
+#endif
-/**
- * A style constant used by the {@see imagefilledarc()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-arc-nofill
- */
-define ('IMG_ARC_NOFILL', 2);
+function imagexbm(GdImage $image, ?string $filename, ?int $foreground_color = null): bool {}
-/**
- * A style constant used by the {@see imagefilledarc()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-arc-edged
- */
-define ('IMG_ARC_EDGED', 4);
+#ifdef HAVE_GD_AVIF
+/** @param resource|string|null $file */
+function imageavif(GdImage $image, $file = null, int $quality = -1, int $speed = -1): bool {}
+#endif
-/**
- * A type constant used by the {@see imagegd2()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-gd2-raw
- */
-define ('IMG_GD2_RAW', 1);
+/** @param resource|string|null $file */
+function imagegif(GdImage $image, $file = null): bool {}
-/**
- * A type constant used by the {@see imagegd2()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-gd2-compressed
- */
-define ('IMG_GD2_COMPRESSED', 2);
+#ifdef HAVE_GD_PNG
+/** @param resource|string|null $file */
+function imagepng(GdImage $image, $file = null, int $quality = -1, int $filters = -1): bool {}
+#endif
-/**
- * Alpha blending effect used by the {@see imagelayereffect()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-effect-replace
- */
-define ('IMG_EFFECT_REPLACE', 0);
+#ifdef HAVE_GD_WEBP
+/** @param resource|string|null $file */
+function imagewebp(GdImage $image, $file = null, int $quality = -1): bool {}
+#endif
-/**
- * Alpha blending effect used by the {@see imagelayereffect()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-effect-alphablend
- */
-define ('IMG_EFFECT_ALPHABLEND', 1);
+#ifdef HAVE_GD_JPG
+/** @param resource|string|null $file */
+function imagejpeg(GdImage $image, $file = null, int $quality = -1): bool {}
+#endif
-/**
- * Alpha blending effect used by the {@see imagelayereffect()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-effect-normal
- */
-define ('IMG_EFFECT_NORMAL', 2);
+/** @param resource|string|null $file */
+function imagewbmp(GdImage $image, $file = null, ?int $foreground_color = null): bool {}
-/**
- * Alpha blending effect used by the {@see imagelayereffect()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-effect-overlay
- */
-define ('IMG_EFFECT_OVERLAY', 3);
+function imagegd(GdImage $image, ?string $file = null): bool {}
-/**
- * Alpha blending effect used by the {@see imagelayereffect()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-effect-multiply
- * @since 7.2
- */
-define ('IMG_EFFECT_MULTIPLY', 4);
+function imagegd2(GdImage $image, ?string $file = null, int $chunk_size = UNKNOWN, int $mode = UNKNOWN): bool {}
-/**
- * When the bundled version of GD is used this is 1 otherwise
- * it's set to 0.
- * @link https://php.net/manual/en/image.constants.php
- */
-define ('GD_BUNDLED', 1);
+#ifdef HAVE_GD_BMP
+/** @param resource|string|null $file */
+function imagebmp(GdImage $image, $file = null, bool $compressed = true): bool {}
+#endif
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-negate
- */
-define ('IMG_FILTER_NEGATE', 0);
+function imagedestroy(GdImage $image): bool {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-grayscale
- */
-define ('IMG_FILTER_GRAYSCALE', 1);
+function imagecolorallocate(GdImage $image, int $red, int $green, int $blue): int|false {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-brightness
- */
-define ('IMG_FILTER_BRIGHTNESS', 2);
+function imagepalettecopy(GdImage $dst, GdImage $src): void {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-contrast
- */
-define ('IMG_FILTER_CONTRAST', 3);
+function imagecolorat(GdImage $image, int $x, int $y): int|false {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-colorize
- */
-define ('IMG_FILTER_COLORIZE', 4);
+function imagecolorclosest(GdImage $image, int $red, int $green, int $blue): int {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-edgedetect
- */
-define ('IMG_FILTER_EDGEDETECT', 5);
+function imagecolorclosesthwb(GdImage $image, int $red, int $green, int $blue): int {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-gaussian-blur
- */
-define ('IMG_FILTER_GAUSSIAN_BLUR', 7);
+function imagecolordeallocate(GdImage $image, int $color): bool {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-selective-blur
- */
-define ('IMG_FILTER_SELECTIVE_BLUR', 8);
+function imagecolorresolve(GdImage $image, int $red, int $green, int $blue): int {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-emboss
- */
-define ('IMG_FILTER_EMBOSS', 6);
+function imagecolorexact(GdImage $image, int $red, int $green, int $blue): int {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-mean-removal
- */
-define ('IMG_FILTER_MEAN_REMOVAL', 9);
+/** @return false|null */
+function imagecolorset(GdImage $image, int $color, int $red, int $green, int $blue, int $alpha = 0): ?bool {}
/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-smooth
+ * @return array<string, int>
+ * @refcount 1
*/
-define ('IMG_FILTER_SMOOTH', 10);
+function imagecolorsforindex(GdImage $image, int $color): array {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-pixelate
- */
-define ('IMG_FILTER_PIXELATE', 11);
+function imagegammacorrect(GdImage $image, float $input_gamma, float $output_gamma): bool {}
-/**
- * Special GD filter used by the {@see imagefilter()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.img-filter-scatter
- * @since 7.4
- */
-define ('IMG_FILTER_SCATTER', 12);
+function imagesetpixel(GdImage $image, int $x, int $y, int $color): bool {}
-/**
- * The GD version PHP was compiled against.
- * @since 5.2.4
- * @link https://php.net/manual/en/image.constants.php#constant.gd-version
- */
-define ('GD_VERSION', "2.0.35");
+function imageline(GdImage $image, int $x1, int $y1, int $x2, int $y2, int $color): bool {}
-/**
- * The GD major version PHP was compiled against.
- * @since 5.2.4
- * @link https://php.net/manual/en/image.constants.php#constant.gd-major-version
- */
-define ('GD_MAJOR_VERSION', 2);
+function imagedashedline(GdImage $image, int $x1, int $y1, int $x2, int $y2, int $color): bool {}
-/**
- * The GD minor version PHP was compiled against.
- * @since 5.2.4
- * @link https://php.net/manual/en/image.constants.php#constant.gd-minor-version
- */
-define ('GD_MINOR_VERSION', 0);
+function imagerectangle(GdImage $image, int $x1, int $y1, int $x2, int $y2, int $color): bool {}
-/**
- * The GD release version PHP was compiled against.
- * @since 5.2.4
- * @link https://php.net/manual/en/image.constants.php#constant.gd-release-version
- */
-define ('GD_RELEASE_VERSION', 35);
+function imagefilledrectangle(GdImage $image, int $x1, int $y1, int $x2, int $y2, int $color): bool {}
-/**
- * The GD "extra" version (beta/rc..) PHP was compiled against.
- * @since 5.2.4
- * @link https://php.net/manual/en/image.constants.php#constant.gd-extra-version
- */
-define ('GD_EXTRA_VERSION', "");
+function imagearc(GdImage $image, int $center_x, int $center_y, int $width, int $height, int $start_angle, int $end_angle, int $color): bool {}
+function imageellipse(GdImage $image, int $center_x, int $center_y, int $width, int $height, int $color): bool {}
-/**
- * A special PNG filter, used by the {@see imagepng()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.png-no-filter
- */
-define ('PNG_NO_FILTER', 0);
+function imagefilltoborder(GdImage $image, int $x, int $y, int $border_color, int $color): bool {}
-/**
- * A special PNG filter, used by the {@see imagepng()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.png-filter-none
- */
-define ('PNG_FILTER_NONE', 8);
+function imagefill(GdImage $image, int $x, int $y, int $color): bool {}
-/**
- * A special PNG filter, used by the {@see imagepng()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.png-filter-sub
- */
-define ('PNG_FILTER_SUB', 16);
+function imagecolorstotal(GdImage $image): int {}
-/**
- * A special PNG filter, used by the {@see imagepng()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.png-filter-up
- */
-define ('PNG_FILTER_UP', 32);
+function imagecolortransparent(GdImage $image, ?int $color = null): int {}
-/**
- * A special PNG filter, used by the {@see imagepng()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.png-filter-avg
- */
-define ('PNG_FILTER_AVG', 64);
+function imageinterlace(GdImage $image, ?bool $enable = null): bool {}
-/**
- * A special PNG filter, used by the {@see imagepng()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.png-filter-paeth
- */
-define ('PNG_FILTER_PAETH', 128);
+function imagepolygon(GdImage $image, array $points, int $num_points_or_color, ?int $color = null): bool {}
-/**
- * A special PNG filter, used by the {@see imagepng()} function.
- * @link https://php.net/manual/en/image.constants.php#constant.png-all-filters
- */
-define ('PNG_ALL_FILTERS', 248);
+function imageopenpolygon(GdImage $image, array $points, int $num_points_or_color, ?int $color = null): bool {}
-/**
- * An affine transformation type constant used by the {@see imageaffinematrixget()} function.
- * @since 5.5
- * @link https://php.net/manual/en/image.constants.php#constant.img-affine-translate
- */
-define('IMG_AFFINE_TRANSLATE', 0);
+function imagefilledpolygon(GdImage $image, array $points, int $num_points_or_color, ?int $color = null): bool {}
-/**
- * An affine transformation type constant used by the {@see imageaffinematrixget()} function.
- * @since 5.5
- * @link https://php.net/manual/en/image.constants.php#constant.img-affine-scale
- */
-define('IMG_AFFINE_SCALE', 1);
+function imagefontwidth(GdFont|int $font): int {}
-/**
- * An affine transformation type constant used by the {@see imageaffinematrixget()} function.
- * @since 5.5
- * @link https://php.net/manual/en/image.constants.php#constant.img-affine-rotate
- */
-define('IMG_AFFINE_ROTATE', 2);
+function imagefontheight(GdFont|int $font): int {}
-/**
- * An affine transformation type constant used by the {@see imageaffinematrixget()} function.
- * @since 5.5
- * @link https://php.net/manual/en/image.constants.php#constant.img-affine-shear-horizontal
- */
-define('IMG_AFFINE_SHEAR_HORIZONTAL', 3);
+function imagechar(GdImage $image, GdFont|int $font, int $x, int $y, string $char, int $color): bool {}
-/**
- * An affine transformation type constant used by the {@see imageaffinematrixget()} function.
- * @since 5.5
- * @link https://php.net/manual/en/image.constants.php#constant.img-affine-shear-vertical
- */
-define('IMG_AFFINE_SHEAR_VERTICAL', 4);
+function imagecharup(GdImage $image, GdFont|int $font, int $x, int $y, string $char, int $color): bool {}
-/**
- * Same as {@see IMG_CROP_TRANSPARENT}. Before PHP 7.4.0, the bundled libgd fell back to
- * {@see IMG_CROP_SIDES}, if the image had no transparent color.
- * Used together with {@see imagecropauto()}.
- * @since 5.5
- */
-define('IMG_CROP_DEFAULT', 0);
+function imagestring(GdImage $image, GdFont|int $font, int $x, int $y, string $string, int $color): bool {}
-/**
- * Crops out a transparent background.
- * Used together with {@see imagecropauto()}.
- * @since 5.5
- */
-define('IMG_CROP_TRANSPARENT', 1);
+function imagestringup(GdImage $image, GdFont|int $font, int $x, int $y, string $string, int $color): bool {}
-/**
- * Crops out a black background.
- * Used together with {@see imagecropauto()}.
- * @since 5.5
- */
-define('IMG_CROP_BLACK', 2);
+function imagecopy(GdImage $dst_image, GdImage $src_image, int $dst_x, int $dst_y, int $src_x, int $src_y, int $src_width, int $src_height): bool {}
-/**
- * Crops out a white background.
- * Used together with {@see imagecropauto()}.
- * @since 5.5
- */
-define('IMG_CROP_WHITE', 3);
+function imagecopymerge(GdImage $dst_image, GdImage $src_image, int $dst_x, int $dst_y, int $src_x, int $src_y, int $src_width, int $src_height, int $pct): bool {}
-/**
- * Uses the 4 corners of the image to attempt to detect the background to crop.
- * Used together with {@see imagecropauto()}.
- * @since 5.5
- */
-define('IMG_CROP_SIDES', 4);
+function imagecopymergegray(GdImage $dst_image, GdImage $src_image, int $dst_x, int $dst_y, int $src_x, int $src_y, int $src_width, int $src_height, int $pct): bool {}
-/**
- * Crops an image using the given <b>threshold</b> and <b>color</b>.
- * Used together with {@see imagecropauto()}.
- * @since 5.5
- */
-define('IMG_CROP_THRESHOLD', 5);
+function imagecopyresized(GdImage $dst_image, GdImage $src_image, int $dst_x, int $dst_y, int $src_x, int $src_y, int $dst_width, int $dst_height, int $src_width, int $src_height): bool {}
-/**
- * Used together with {@see imageflip()}
- * @since 5.5
- * @link https://php.net/manual/en/image.constants.php#constant.img-flip-both
- */
-define('IMG_FLIP_BOTH', 3);
+function imagesx(GdImage $image): int {}
-/**
- * Used together with {@see imageflip()}
- * @since 5.5
- * @link https://php.net/manual/en/image.constants.php#constant.img-flip-horizontal
- */
-define('IMG_FLIP_HORIZONTAL', 1);
+function imagesy(GdImage $image): int {}
-/**
- * Used together with {@see imageflip()}
- * @since 5.5
- * @link https://php.net/manual/en/image.constants.php#constant.img-flip-vertical
- */
-define('IMG_FLIP_VERTICAL', 2);
+function imagesetclip(GdImage $image, int $x1, int $y1, int $x2, int $y2): bool {}
/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-bell
- * @since 5.5
+ * @return array<int, int>
+ * @refcount 1
*/
-define('IMG_BELL', 1);
+function imagegetclip(GdImage $image): array {}
+#ifdef HAVE_GD_FREETYPE
/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-bessel
- * @since 5.5
+ * @return array<int, int>|false
+ * @refcount 1
*/
-define('IMG_BESSEL', 2);
+function imageftbbox(float $size, float $angle, string $font_filename, string $string, array $options = []): array|false {}
/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-bicubic
- * @since 5.5
+ * @return array<int, int>|false
+ * @refcount 1
*/
-define('IMG_BICUBIC', 4);
+function imagefttext(GdImage $image, float $size, float $angle, int $x, int $y, int $color, string $font_filename, string $text, array $options = []): array|false {}
/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-bicubic-fixed
- * @since 5.5
+ * @return array<int, int>|false
+ * @alias imageftbbox
*/
-define('IMG_BICUBIC_FIXED', 5);
+function imagettfbbox(float $size, float $angle, string $font_filename, string $string, array $options = []): array|false {}
/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-bilinear-fixed
- * @since 5.5
+ * @return array<int, int>|false
+ * @alias imagefttext
*/
-define('IMG_BILINEAR_FIXED', 3);
+function imagettftext(GdImage $image, float $size, float $angle, int $x, int $y, int $color, string $font_filename, string $text, array $options = []): array|false {}
+#endif
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-blackman
- * @since 5.5
- */
-define('IMG_BLACKMAN', 6);
-
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-box
- * @since 5.5
- */
-define('IMG_BOX', 7);
-
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-bspline
- * @since 5.5
- */
-define('IMG_BSPLINE', 8);
+/** @param array|int|float|bool $args */
+function imagefilter(GdImage $image, int $filter, ...$args): bool {}
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-catmullrom
- * @since 5.5
- */
-define('IMG_CATMULLROM', 9);
-
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-gaussian
- * @since 5.5
- */
-define('IMG_GAUSSIAN', 10);
-
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-generalized-cubic
- * @since 5.5
- */
-define('IMG_GENERALIZED_CUBIC', 11);
+function imageconvolution(GdImage $image, array $matrix, float $divisor, float $offset): bool {}
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-hermite
- * @since 5.5
- */
-define('IMG_HERMITE', 12);
+function imageflip(GdImage $image, int $mode): bool {}
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-hamming
- * @since 5.5
- */
-define('IMG_HAMMING', 13);
+function imageantialias(GdImage $image, bool $enable): bool {}
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-hanning
- * @since 5.5
- */
-define('IMG_HANNING', 14);
+/** @refcount 1 */
+function imagecrop(GdImage $image, array $rectangle): GdImage|false {}
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-mitchell
- * @since 5.5
- */
-define('IMG_MITCHELL', 15);
+/** @refcount 1 */
+function imagecropauto(GdImage $image, int $mode = IMG_CROP_DEFAULT, float $threshold = 0.5, int $color = -1): GdImage|false {}
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-power
- * @since 5.5
- */
-define('IMG_POWER', 17);
+/** @refcount 1 */
+function imagescale(GdImage $image, int $width, int $height = -1, int $mode = IMG_BILINEAR_FIXED): GdImage|false {}
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-quadratic
- * @since 5.5
- */
-define('IMG_QUADRATIC', 18);
+/** @refcount 1 */
+function imageaffine(GdImage $image, array $affine, ?array $clip = null): GdImage|false {}
/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-sinc
- * @since 5.5
+ * @param array|float $options
+ * @refcount 1
+ * @return array<int, float>|false
*/
-define('IMG_SINC', 19);
+function imageaffinematrixget(int $type, $options): array|false {}
/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-nearest-neighbour
- * @since 5.5
+ * @return array<int, float>|false
+ * @refcount 1
*/
-define('IMG_NEAREST_NEIGHBOUR', 16);
+function imageaffinematrixconcat(array $matrix1, array $matrix2): array|false {}
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-weighted4
- * @since 5.5
- */
-define('IMG_WEIGHTED4', 21);
-
-/**
- * Used together with {@see imagesetinterpolation()}.
- * @link https://php.net/manual/en/image.constants.php#constant.img-triangle
- * @since 5.5
- */
-define('IMG_TRIANGLE', 20);
-
-define('IMG_TGA', 128);
-
-/**
- * Return an image containing the affine tramsformed src image, using an optional clipping area
- * @link https://www.php.net/manual/en/function.imageaffine.php
- * @param resource $image <p>An image resource, returned by one of the image creation functions,
- * such as {@link https://www.php.net/manual/en/function.imagecreatetruecolor.php imagecreatetruecolor()}.</p>
- * @param array $affine <p>Array with keys 0 to 5.</p>
- * @param array $clip [optional] <p>Array with keys "x", "y", "width" and "height".</p>
- * @return resource|bool Return affined image resource on success or FALSE on failure.
- */
-function imageaffine($image, $affine, $clip = null) {}
-
-/**
- * Concat two matrices (as in doing many ops in one go)
- * @link https://www.php.net/manual/en/function.imageaffinematrixconcat.php
- * @param array $m1 <p>Array with keys 0 to 5.</p>
- * @param array $m2 <p>Array with keys 0 to 5.</p>
- * @return array|bool Array with keys 0 to 5 and float values or <b>FALSE</b> on failure.
- * @since 5.5
- */
-function imageaffinematrixconcat(array $m1, array $m2) {}
-
-/**
- * Return an image containing the affine tramsformed src image, using an optional clipping area
- * @link https://www.php.net/manual/en/function.imageaffinematrixget.php
- * @param int $type <p> One of <b>IMG_AFFINE_*</b> constants.
- * @param mixed $options [optional]
- * @return array|bool Array with keys 0 to 5 and float values or <b>FALSE</b> on failure.
- * @since 5.5
- */
-
-function imageaffinematrixget ($type, $options = null) {}
-
-/**
- * Crop an image using the given coordinates and size, x, y, width and height
- * @link https://www.php.net/manual/en/function.imagecrop.php
- * @param resource $image <p>
- * An image resource, returned by one of the image creation functions, such as {@link https://www.php.net/manual/en/function.imagecreatetruecolor.php imagecreatetruecolor()}.
- * </p>
- * @param array $rect <p>Array with keys "x", "y", "width" and "height".</p>
- * @return resource|bool Return cropped image resource on success or FALSE on failure.
- * @since 5.5
- */
-function imagecrop ($image, $rect) {}
-
-/**
- * Crop an image automatically using one of the available modes
- * @link https://www.php.net/manual/en/function.imagecropauto.php
- * @param resource $image <p>
- * An image resource, returned by one of the image creation functions, such as {@link https://www.php.net/manual/en/function.imagecreatetruecolor.php imagecreatetruecolor()}.
- * </p>
- * @param int $mode [optional] <p>
- * One of <b>IMG_CROP_*</b> constants.
- * </p>
- * @param float $threshold [optional] <p>
- * Used <b>IMG_CROP_THRESHOLD</b> mode.
- * </p>
- * @param int $color [optional]
- * <p>
- * Used in <b>IMG_CROP_THRESHOLD</b> mode.
- * </p>
- * @return resource|bool Return cropped image resource on success or <b>FALSE</b> on failure.
- * @since 5.5
- */
-function imagecropauto ($image, $mode = IMG_CROP_DEFAULT, $threshold = .5, $color = -1) {}
-
-/**
- * Flips an image using a given mode
- * @link https://www.php.net/manual/en/function.imageflip.php
- * @param resource $image <p>
- * An image resource, returned by one of the image creation functions, such as {@link https://www.php.net/manual/en/function.imagecreatetruecolor.php imagecreatetruecolor()}.
- * </p>
- * @param int $mode <p>
- * Flip mode, this can be one of the <b>IMG_FLIP_*</b> constants:
- * </p>
- * <table>
- * <thead>
- * <tr>
- * <th>Constant</th>
- * <th>Meaning</th>
- * </tr>
- * </thead>
- * <tr>
- * <td><b>IMG_FLIP_HORIZONTAL</b></td>
- * <td>
- * Flips the image horizontally.
- * </td>
- * </tr>
- * <tr>
- * <td><b>IMG_FLIP_VERTICAL</b></td>
- * <td>
- * Flips the image vertically.
- * </td>
- * </tr>
- * <tr>
- * <td><b>IMG_FLIP_BOTH</b></td>
- * <td>
- * Flips the image both horizontally and vertically.
- * </td>
- * </tr>
- * </tbody>
- * </table>
- * @return bool Returns <b>TRUE</b> on success or <b>FALSE</b> on failure.
- * @since 5.5
- */
-function imageflip ($image, $mode) {}
-
-/**
- * Converts a palette based image to true color
- * @link https://www.php.net/manual/en/function.imagepalettetotruecolor.php
- * @param resource $image <p>
- * An image resource, returnd by one of the image creation functions, such as {@link https://www.php.net/manual/en/function.imagecreatetruecolor.php imagecreatetruecolor()}.
- * </p>
- * @return bool Returns <b>TRUE</b> if the convertion was complete, or if the source image already is a true color image, otherwise <b>FALSE</b> is returned.
- * @since 5.5
- */
-function imagepalettetotruecolor ($image) {}
-
-/**
- * @since 5.5
- * Scale an image using the given new width and height
- * @link https://www.php.net/manual/en/function.imagescale.php
- * @param resource $image <p>
- * An image resource, returnd by one of the image creation functions, such as {@link https://www.php.net/manual/en/function.imagecreatetruecolor.php imagecreatetruecolor()}.
- * </p>
- * @param int $new_width
- * @param int $new_height [optional]
- * @param int $mode [optional] One of <b>IMG_NEAREST_NEIGHBOUR</b>, <b>IMG_BILINEAR_FIXED</b>, <b>IMG_BICUBIC</b>, <b>IMG_BICUBIC_FIXED</b> or anything else (will use two pass).
- * @return resource|bool Return scaled image resource on success or <b>FALSE</b> on failure.
- */
+function imagegetinterpolation(GdImage $image): int {}
-function imagescale ($image, $new_width, $new_height = -1, $mode = IMG_BILINEAR_FIXED) {}
+function imagesetinterpolation(GdImage $image, int $method = IMG_BILINEAR_FIXED): bool {}
/**
- * Set the interpolation method
- * @link https://www.php.net/manual/en/function.imagesetinterpolation.php
- * @param resource $image <p>
- * An image resource, returned by one of the image creation functions, such as {@link https://www.php.net/manual/en/function.imagecreatetruecolor.php imagecreatetruecolor()}.
- * </p>
- * @param int $method <p>
- * The interpolation method, which can be one of the following:
- * <ul>
- * <li>
- * IMG_BELL: Bell filter.
- * </li>
- * <li>
- * IMG_BESSEL: Bessel filter.
- * </li>
- * <li>
- * IMG_BICUBIC: Bicubic interpolation.
- * </li>
- * <li>
- * IMG_BICUBIC_FIXED: Fixed point implementation of the bicubic interpolation.
- * </li>
- * <li>
- * IMG_BILINEAR_FIXED: Fixed point implementation of the bilinear interpolation (<em>default (also on image creation)</em>).
- * </li>
- * <li>
- * IMG_BLACKMAN: Blackman window function.
- * </li>
- * <li>
- * IMG_BOX: Box blur filter.
- * </li>
- * <li>
- * IMG_BSPLINE: Spline interpolation.
- * </li>
- * <li>
- * IMG_CATMULLROM: Cubbic Hermite spline interpolation.
- * </li>
- * <li>
- * IMG_GAUSSIAN: Gaussian function.
- * </li>
- * <li>
- * IMG_GENERALIZED_CUBIC: Generalized cubic spline fractal interpolation.
- * </li>
- * <li>
- * IMG_HERMITE: Hermite interpolation.
- * </li>
- * <li>
- * IMG_HAMMING: Hamming filter.
- * </li>
- * <li>
- * IMG_HANNING: Hanning filter.
- * </li>
- * <li>
- * IMG_MITCHELL: Mitchell filter.
- * </li>
- * <li>
- * IMG_POWER: Power interpolation.
- * </li>
- * <li>
- * IMG_QUADRATIC: Inverse quadratic interpolation.
- * </li>
- * <li>
- * IMG_SINC: Sinc function.
- * </li>
- * <li>
- * IMG_NEAREST_NEIGHBOUR: Nearest neighbour interpolation.
- * </li>
- * <li>
- * IMG_WEIGHTED4: Weighting filter.
- * </li>
- * <li>
- * IMG_TRIANGLE: Triangle interpolation.
- * </li>
- * </ul>
- * </p>
- * @return bool Returns TRUE on success or FALSE on failure.
- * @since 5.5
+ * @return array<int, int>|true
+ * @refcount 1
*/
-function imagesetinterpolation ($image, $method = IMG_BILINEAR_FIXED) {}
+function imageresolution(GdImage $image, ?int $resolution_x = null, ?int $resolution_y = null): array|bool {}
diff --git a/build/stubs/imagick.php b/build/stubs/imagick.php
index 147e8b34dbd..7fe3ed8246f 100644
--- a/build/stubs/imagick.php
+++ b/build/stubs/imagick.php
@@ -1,6744 +1,1386 @@
<?php
-// Start of imagick v.3.4.3
+/** @generate-function-entries */
-class ImagickException extends Exception {
-}
+class Imagick
+{
+#if MagickLibVersion > 0x628
+ public function optimizeImageLayers(): bool {}
-class ImagickDrawException extends Exception {
-}
+ // METRIC_*
+ public function compareImageLayers(int $metric): Imagick {}
-class ImagickPixelIteratorException extends Exception {
-}
+ public function pingImageBlob(string $image): bool {}
-class ImagickPixelException extends Exception {
-}
+ public function pingImageFile(resource $filehandle, ?string $filename = null): bool {}
-/**
- * @method Imagick clone() (PECL imagick 2.0.0)<br/>Makes an exact copy of the Imagick object
- * @link https://php.net/manual/en/class.imagick.php
- */
-class Imagick implements Iterator, Countable {
- const COLOR_BLACK = 11;
- const COLOR_BLUE = 12;
- const COLOR_CYAN = 13;
- const COLOR_GREEN = 14;
- const COLOR_RED = 15;
- const COLOR_YELLOW = 16;
- const COLOR_MAGENTA = 17;
- const COLOR_OPACITY = 18;
- const COLOR_ALPHA = 19;
- const COLOR_FUZZ = 20;
- const IMAGICK_EXTNUM = 30403;
- const IMAGICK_EXTVER = "3.4.3";
- const QUANTUM_RANGE = 65535;
- const USE_ZEND_MM = 0;
- const COMPOSITE_DEFAULT = 40;
- const COMPOSITE_UNDEFINED = 0;
- const COMPOSITE_NO = 1;
- const COMPOSITE_ADD = 2;
- const COMPOSITE_ATOP = 3;
- const COMPOSITE_BLEND = 4;
- const COMPOSITE_BUMPMAP = 5;
- const COMPOSITE_CLEAR = 7;
- const COMPOSITE_COLORBURN = 8;
- const COMPOSITE_COLORDODGE = 9;
- const COMPOSITE_COLORIZE = 10;
- const COMPOSITE_COPYBLACK = 11;
- const COMPOSITE_COPYBLUE = 12;
- const COMPOSITE_COPY = 13;
- const COMPOSITE_COPYCYAN = 14;
- const COMPOSITE_COPYGREEN = 15;
- const COMPOSITE_COPYMAGENTA = 16;
- const COMPOSITE_COPYOPACITY = 17;
- const COMPOSITE_COPYRED = 18;
- const COMPOSITE_COPYYELLOW = 19;
- const COMPOSITE_DARKEN = 20;
- const COMPOSITE_DSTATOP = 21;
- const COMPOSITE_DST = 22;
- const COMPOSITE_DSTIN = 23;
- const COMPOSITE_DSTOUT = 24;
- const COMPOSITE_DSTOVER = 25;
- const COMPOSITE_DIFFERENCE = 26;
- const COMPOSITE_DISPLACE = 27;
- const COMPOSITE_DISSOLVE = 28;
- const COMPOSITE_EXCLUSION = 29;
- const COMPOSITE_HARDLIGHT = 30;
- const COMPOSITE_HUE = 31;
- const COMPOSITE_IN = 32;
- const COMPOSITE_LIGHTEN = 33;
- const COMPOSITE_LUMINIZE = 35;
- const COMPOSITE_MINUS = 36;
- const COMPOSITE_MODULATE = 37;
- const COMPOSITE_MULTIPLY = 38;
- const COMPOSITE_OUT = 39;
- const COMPOSITE_OVER = 40;
- const COMPOSITE_OVERLAY = 41;
- const COMPOSITE_PLUS = 42;
- const COMPOSITE_REPLACE = 43;
- const COMPOSITE_SATURATE = 44;
- const COMPOSITE_SCREEN = 45;
- const COMPOSITE_SOFTLIGHT = 46;
- const COMPOSITE_SRCATOP = 47;
- const COMPOSITE_SRC = 48;
- const COMPOSITE_SRCIN = 49;
- const COMPOSITE_SRCOUT = 50;
- const COMPOSITE_SRCOVER = 51;
- const COMPOSITE_SUBTRACT = 52;
- const COMPOSITE_THRESHOLD = 53;
- const COMPOSITE_XOR = 54;
- const COMPOSITE_CHANGEMASK = 6;
- const COMPOSITE_LINEARLIGHT = 34;
- const COMPOSITE_DIVIDE = 55;
- const COMPOSITE_DISTORT = 56;
- const COMPOSITE_BLUR = 57;
- const COMPOSITE_PEGTOPLIGHT = 58;
- const COMPOSITE_VIVIDLIGHT = 59;
- const COMPOSITE_PINLIGHT = 60;
- const COMPOSITE_LINEARDODGE = 61;
- const COMPOSITE_LINEARBURN = 62;
- const COMPOSITE_MATHEMATICS = 63;
- const COMPOSITE_MODULUSADD = 2;
- const COMPOSITE_MODULUSSUBTRACT = 52;
- const COMPOSITE_MINUSDST = 36;
- const COMPOSITE_DIVIDEDST = 55;
- const COMPOSITE_DIVIDESRC = 64;
- const COMPOSITE_MINUSSRC = 65;
- const COMPOSITE_DARKENINTENSITY = 66;
- const COMPOSITE_LIGHTENINTENSITY = 67;
- const MONTAGEMODE_FRAME = 1;
- const MONTAGEMODE_UNFRAME = 2;
- const MONTAGEMODE_CONCATENATE = 3;
- const STYLE_NORMAL = 1;
- const STYLE_ITALIC = 2;
- const STYLE_OBLIQUE = 3;
- const STYLE_ANY = 4;
- const FILTER_UNDEFINED = 0;
- const FILTER_POINT = 1;
- const FILTER_BOX = 2;
- const FILTER_TRIANGLE = 3;
- const FILTER_HERMITE = 4;
- const FILTER_HANNING = 5;
- const FILTER_HAMMING = 6;
- const FILTER_BLACKMAN = 7;
- const FILTER_GAUSSIAN = 8;
- const FILTER_QUADRATIC = 9;
- const FILTER_CUBIC = 10;
- const FILTER_CATROM = 11;
- const FILTER_MITCHELL = 12;
- const FILTER_LANCZOS = 22;
- const FILTER_BESSEL = 13;
- const FILTER_SINC = 14;
- const FILTER_KAISER = 16;
- const FILTER_WELSH = 17;
- const FILTER_PARZEN = 18;
- const FILTER_LAGRANGE = 21;
- const FILTER_SENTINEL = 31;
- const FILTER_BOHMAN = 19;
- const FILTER_BARTLETT = 20;
- const FILTER_JINC = 13;
- const FILTER_SINCFAST = 15;
- const FILTER_ROBIDOUX = 26;
- const FILTER_LANCZOSSHARP = 23;
- const FILTER_LANCZOS2 = 24;
- const FILTER_LANCZOS2SHARP = 25;
- const FILTER_ROBIDOUXSHARP = 27;
- const FILTER_COSINE = 28;
- const FILTER_SPLINE = 29;
- const FILTER_LANCZOSRADIUS = 30;
- const IMGTYPE_UNDEFINED = 0;
- const IMGTYPE_BILEVEL = 1;
- const IMGTYPE_GRAYSCALE = 2;
- const IMGTYPE_GRAYSCALEMATTE = 3;
- const IMGTYPE_PALETTE = 4;
- const IMGTYPE_PALETTEMATTE = 5;
- const IMGTYPE_TRUECOLOR = 6;
- const IMGTYPE_TRUECOLORMATTE = 7;
- const IMGTYPE_COLORSEPARATION = 8;
- const IMGTYPE_COLORSEPARATIONMATTE = 9;
- const IMGTYPE_OPTIMIZE = 10;
- const IMGTYPE_PALETTEBILEVELMATTE = 11;
- const RESOLUTION_UNDEFINED = 0;
- const RESOLUTION_PIXELSPERINCH = 1;
- const RESOLUTION_PIXELSPERCENTIMETER = 2;
- const COMPRESSION_UNDEFINED = 0;
- const COMPRESSION_NO = 1;
- const COMPRESSION_BZIP = 2;
- const COMPRESSION_FAX = 6;
- const COMPRESSION_GROUP4 = 7;
- const COMPRESSION_JPEG = 8;
- const COMPRESSION_JPEG2000 = 9;
- const COMPRESSION_LOSSLESSJPEG = 10;
- const COMPRESSION_LZW = 11;
- const COMPRESSION_RLE = 12;
- const COMPRESSION_ZIP = 13;
- const COMPRESSION_DXT1 = 3;
- const COMPRESSION_DXT3 = 4;
- const COMPRESSION_DXT5 = 5;
- const COMPRESSION_ZIPS = 14;
- const COMPRESSION_PIZ = 15;
- const COMPRESSION_PXR24 = 16;
- const COMPRESSION_B44 = 17;
- const COMPRESSION_B44A = 18;
- const COMPRESSION_LZMA = 19;
- const COMPRESSION_JBIG1 = 20;
- const COMPRESSION_JBIG2 = 21;
- const PAINT_POINT = 1;
- const PAINT_REPLACE = 2;
- const PAINT_FLOODFILL = 3;
- const PAINT_FILLTOBORDER = 4;
- const PAINT_RESET = 5;
- const GRAVITY_NORTHWEST = 1;
- const GRAVITY_NORTH = 2;
- const GRAVITY_NORTHEAST = 3;
- const GRAVITY_WEST = 4;
- const GRAVITY_CENTER = 5;
- const GRAVITY_EAST = 6;
- const GRAVITY_SOUTHWEST = 7;
- const GRAVITY_SOUTH = 8;
- const GRAVITY_SOUTHEAST = 9;
- const GRAVITY_FORGET = 0;
- const GRAVITY_STATIC = 10;
- const STRETCH_NORMAL = 1;
- const STRETCH_ULTRACONDENSED = 2;
- const STRETCH_EXTRACONDENSED = 3;
- const STRETCH_CONDENSED = 4;
- const STRETCH_SEMICONDENSED = 5;
- const STRETCH_SEMIEXPANDED = 6;
- const STRETCH_EXPANDED = 7;
- const STRETCH_EXTRAEXPANDED = 8;
- const STRETCH_ULTRAEXPANDED = 9;
- const STRETCH_ANY = 10;
- const ALIGN_UNDEFINED = 0;
- const ALIGN_LEFT = 1;
- const ALIGN_CENTER = 2;
- const ALIGN_RIGHT = 3;
- const DECORATION_NO = 1;
- const DECORATION_UNDERLINE = 2;
- const DECORATION_OVERLINE = 3;
- const DECORATION_LINETROUGH = 4;
- const DECORATION_LINETHROUGH = 4;
- const NOISE_UNIFORM = 1;
- const NOISE_GAUSSIAN = 2;
- const NOISE_MULTIPLICATIVEGAUSSIAN = 3;
- const NOISE_IMPULSE = 4;
- const NOISE_LAPLACIAN = 5;
- const NOISE_POISSON = 6;
- const NOISE_RANDOM = 7;
- const CHANNEL_UNDEFINED = 0;
- const CHANNEL_RED = 1;
- const CHANNEL_GRAY = 1;
- const CHANNEL_CYAN = 1;
- const CHANNEL_GREEN = 2;
- const CHANNEL_MAGENTA = 2;
- const CHANNEL_BLUE = 4;
- const CHANNEL_YELLOW = 4;
- const CHANNEL_ALPHA = 8;
- const CHANNEL_OPACITY = 8;
- const CHANNEL_MATTE = 8;
- const CHANNEL_BLACK = 32;
- const CHANNEL_INDEX = 32;
- const CHANNEL_ALL = 134217727;
- const CHANNEL_DEFAULT = 134217719;
- const CHANNEL_RGBA = 15;
- const CHANNEL_TRUEALPHA = 64;
- const CHANNEL_RGBS = 128;
- const CHANNEL_GRAY_CHANNELS = 128;
- const CHANNEL_SYNC = 256;
- const CHANNEL_COMPOSITES = 47;
- const METRIC_UNDEFINED = 0;
- const METRIC_ABSOLUTEERRORMETRIC = 1;
- const METRIC_MEANABSOLUTEERROR = 2;
- const METRIC_MEANERRORPERPIXELMETRIC = 3;
- const METRIC_MEANSQUAREERROR = 4;
- const METRIC_PEAKABSOLUTEERROR = 5;
- const METRIC_PEAKSIGNALTONOISERATIO = 6;
- const METRIC_ROOTMEANSQUAREDERROR = 7;
- const METRIC_NORMALIZEDCROSSCORRELATIONERRORMETRIC = 8;
- const METRIC_FUZZERROR = 9;
- const PIXEL_CHAR = 1;
- const PIXEL_DOUBLE = 2;
- const PIXEL_FLOAT = 3;
- const PIXEL_INTEGER = 4;
- const PIXEL_LONG = 5;
- const PIXEL_QUANTUM = 6;
- const PIXEL_SHORT = 7;
- const EVALUATE_UNDEFINED = 0;
- const EVALUATE_ADD = 1;
- const EVALUATE_AND = 2;
- const EVALUATE_DIVIDE = 3;
- const EVALUATE_LEFTSHIFT = 4;
- const EVALUATE_MAX = 5;
- const EVALUATE_MIN = 6;
- const EVALUATE_MULTIPLY = 7;
- const EVALUATE_OR = 8;
- const EVALUATE_RIGHTSHIFT = 9;
- const EVALUATE_SET = 10;
- const EVALUATE_SUBTRACT = 11;
- const EVALUATE_XOR = 12;
- const EVALUATE_POW = 13;
- const EVALUATE_LOG = 14;
- const EVALUATE_THRESHOLD = 15;
- const EVALUATE_THRESHOLDBLACK = 16;
- const EVALUATE_THRESHOLDWHITE = 17;
- const EVALUATE_GAUSSIANNOISE = 18;
- const EVALUATE_IMPULSENOISE = 19;
- const EVALUATE_LAPLACIANNOISE = 20;
- const EVALUATE_MULTIPLICATIVENOISE = 21;
- const EVALUATE_POISSONNOISE = 22;
- const EVALUATE_UNIFORMNOISE = 23;
- const EVALUATE_COSINE = 24;
- const EVALUATE_SINE = 25;
- const EVALUATE_ADDMODULUS = 26;
- const EVALUATE_MEAN = 27;
- const EVALUATE_ABS = 28;
- const EVALUATE_EXPONENTIAL = 29;
- const EVALUATE_MEDIAN = 30;
- const EVALUATE_SUM = 31;
- const COLORSPACE_UNDEFINED = 0;
- const COLORSPACE_RGB = 1;
- const COLORSPACE_GRAY = 2;
- const COLORSPACE_TRANSPARENT = 3;
- const COLORSPACE_OHTA = 4;
- const COLORSPACE_LAB = 5;
- const COLORSPACE_XYZ = 6;
- const COLORSPACE_YCBCR = 7;
- const COLORSPACE_YCC = 8;
- const COLORSPACE_YIQ = 9;
- const COLORSPACE_YPBPR = 10;
- const COLORSPACE_YUV = 11;
- const COLORSPACE_CMYK = 12;
- const COLORSPACE_SRGB = 13;
- const COLORSPACE_HSB = 14;
- const COLORSPACE_HSL = 15;
- const COLORSPACE_HWB = 16;
- const COLORSPACE_REC601LUMA = 17;
- const COLORSPACE_REC709LUMA = 19;
- const COLORSPACE_LOG = 21;
- const COLORSPACE_CMY = 22;
- const COLORSPACE_LUV = 23;
- const COLORSPACE_HCL = 24;
- const COLORSPACE_LCH = 25;
- const COLORSPACE_LMS = 26;
- const COLORSPACE_LCHAB = 27;
- const COLORSPACE_LCHUV = 28;
- const COLORSPACE_SCRGB = 29;
- const COLORSPACE_HSI = 30;
- const COLORSPACE_HSV = 31;
- const COLORSPACE_HCLP = 32;
- const COLORSPACE_YDBDR = 33;
- const COLORSPACE_REC601YCBCR = 18;
- const COLORSPACE_REC709YCBCR = 20;
- const VIRTUALPIXELMETHOD_UNDEFINED = 0;
- const VIRTUALPIXELMETHOD_BACKGROUND = 1;
- const VIRTUALPIXELMETHOD_CONSTANT = 2;
- const VIRTUALPIXELMETHOD_EDGE = 4;
- const VIRTUALPIXELMETHOD_MIRROR = 5;
- const VIRTUALPIXELMETHOD_TILE = 7;
- const VIRTUALPIXELMETHOD_TRANSPARENT = 8;
- const VIRTUALPIXELMETHOD_MASK = 9;
- const VIRTUALPIXELMETHOD_BLACK = 10;
- const VIRTUALPIXELMETHOD_GRAY = 11;
- const VIRTUALPIXELMETHOD_WHITE = 12;
- const VIRTUALPIXELMETHOD_HORIZONTALTILE = 13;
- const VIRTUALPIXELMETHOD_VERTICALTILE = 14;
- const VIRTUALPIXELMETHOD_HORIZONTALTILEEDGE = 15;
- const VIRTUALPIXELMETHOD_VERTICALTILEEDGE = 16;
- const VIRTUALPIXELMETHOD_CHECKERTILE = 17;
- const PREVIEW_UNDEFINED = 0;
- const PREVIEW_ROTATE = 1;
- const PREVIEW_SHEAR = 2;
- const PREVIEW_ROLL = 3;
- const PREVIEW_HUE = 4;
- const PREVIEW_SATURATION = 5;
- const PREVIEW_BRIGHTNESS = 6;
- const PREVIEW_GAMMA = 7;
- const PREVIEW_SPIFF = 8;
- const PREVIEW_DULL = 9;
- const PREVIEW_GRAYSCALE = 10;
- const PREVIEW_QUANTIZE = 11;
- const PREVIEW_DESPECKLE = 12;
- const PREVIEW_REDUCENOISE = 13;
- const PREVIEW_ADDNOISE = 14;
- const PREVIEW_SHARPEN = 15;
- const PREVIEW_BLUR = 16;
- const PREVIEW_THRESHOLD = 17;
- const PREVIEW_EDGEDETECT = 18;
- const PREVIEW_SPREAD = 19;
- const PREVIEW_SOLARIZE = 20;
- const PREVIEW_SHADE = 21;
- const PREVIEW_RAISE = 22;
- const PREVIEW_SEGMENT = 23;
- const PREVIEW_SWIRL = 24;
- const PREVIEW_IMPLODE = 25;
- const PREVIEW_WAVE = 26;
- const PREVIEW_OILPAINT = 27;
- const PREVIEW_CHARCOALDRAWING = 28;
- const PREVIEW_JPEG = 29;
- const RENDERINGINTENT_UNDEFINED = 0;
- const RENDERINGINTENT_SATURATION = 1;
- const RENDERINGINTENT_PERCEPTUAL = 2;
- const RENDERINGINTENT_ABSOLUTE = 3;
- const RENDERINGINTENT_RELATIVE = 4;
- const INTERLACE_UNDEFINED = 0;
- const INTERLACE_NO = 1;
- const INTERLACE_LINE = 2;
- const INTERLACE_PLANE = 3;
- const INTERLACE_PARTITION = 4;
- const INTERLACE_GIF = 5;
- const INTERLACE_JPEG = 6;
- const INTERLACE_PNG = 7;
- const FILLRULE_UNDEFINED = 0;
- const FILLRULE_EVENODD = 1;
- const FILLRULE_NONZERO = 2;
- const PATHUNITS_UNDEFINED = 0;
- const PATHUNITS_USERSPACE = 1;
- const PATHUNITS_USERSPACEONUSE = 2;
- const PATHUNITS_OBJECTBOUNDINGBOX = 3;
- const LINECAP_UNDEFINED = 0;
- const LINECAP_BUTT = 1;
- const LINECAP_ROUND = 2;
- const LINECAP_SQUARE = 3;
- const LINEJOIN_UNDEFINED = 0;
- const LINEJOIN_MITER = 1;
- const LINEJOIN_ROUND = 2;
- const LINEJOIN_BEVEL = 3;
- const RESOURCETYPE_UNDEFINED = 0;
- const RESOURCETYPE_AREA = 1;
- const RESOURCETYPE_DISK = 2;
- const RESOURCETYPE_FILE = 3;
- const RESOURCETYPE_MAP = 4;
- const RESOURCETYPE_MEMORY = 5;
- const RESOURCETYPE_TIME = 7;
- const RESOURCETYPE_THROTTLE = 8;
- const RESOURCETYPE_THREAD = 6;
- const DISPOSE_UNRECOGNIZED = 0;
- const DISPOSE_UNDEFINED = 0;
- const DISPOSE_NONE = 1;
- const DISPOSE_BACKGROUND = 2;
- const DISPOSE_PREVIOUS = 3;
- const INTERPOLATE_UNDEFINED = 0;
- const INTERPOLATE_AVERAGE = 1;
- const INTERPOLATE_BICUBIC = 2;
- const INTERPOLATE_BILINEAR = 3;
- const INTERPOLATE_FILTER = 4;
- const INTERPOLATE_INTEGER = 5;
- const INTERPOLATE_MESH = 6;
- const INTERPOLATE_NEARESTNEIGHBOR = 7;
- const INTERPOLATE_SPLINE = 8;
- const LAYERMETHOD_UNDEFINED = 0;
- const LAYERMETHOD_COALESCE = 1;
- const LAYERMETHOD_COMPAREANY = 2;
- const LAYERMETHOD_COMPARECLEAR = 3;
- const LAYERMETHOD_COMPAREOVERLAY = 4;
- const LAYERMETHOD_DISPOSE = 5;
- const LAYERMETHOD_OPTIMIZE = 6;
- const LAYERMETHOD_OPTIMIZEPLUS = 8;
- const LAYERMETHOD_OPTIMIZETRANS = 9;
- const LAYERMETHOD_COMPOSITE = 12;
- const LAYERMETHOD_OPTIMIZEIMAGE = 7;
- const LAYERMETHOD_REMOVEDUPS = 10;
- const LAYERMETHOD_REMOVEZERO = 11;
- const LAYERMETHOD_TRIMBOUNDS = 16;
- const ORIENTATION_UNDEFINED = 0;
- const ORIENTATION_TOPLEFT = 1;
- const ORIENTATION_TOPRIGHT = 2;
- const ORIENTATION_BOTTOMRIGHT = 3;
- const ORIENTATION_BOTTOMLEFT = 4;
- const ORIENTATION_LEFTTOP = 5;
- const ORIENTATION_RIGHTTOP = 6;
- const ORIENTATION_RIGHTBOTTOM = 7;
- const ORIENTATION_LEFTBOTTOM = 8;
- const DISTORTION_UNDEFINED = 0;
- const DISTORTION_AFFINE = 1;
- const DISTORTION_AFFINEPROJECTION = 2;
- const DISTORTION_ARC = 9;
- const DISTORTION_BILINEAR = 6;
- const DISTORTION_PERSPECTIVE = 4;
- const DISTORTION_PERSPECTIVEPROJECTION = 5;
- const DISTORTION_SCALEROTATETRANSLATE = 3;
- const DISTORTION_POLYNOMIAL = 8;
- const DISTORTION_POLAR = 10;
- const DISTORTION_DEPOLAR = 11;
- const DISTORTION_BARREL = 14;
- const DISTORTION_SHEPARDS = 16;
- const DISTORTION_SENTINEL = 18;
- const DISTORTION_BARRELINVERSE = 15;
- const DISTORTION_BILINEARFORWARD = 6;
- const DISTORTION_BILINEARREVERSE = 7;
- const DISTORTION_RESIZE = 17;
- const DISTORTION_CYLINDER2PLANE = 12;
- const DISTORTION_PLANE2CYLINDER = 13;
- const LAYERMETHOD_MERGE = 13;
- const LAYERMETHOD_FLATTEN = 14;
- const LAYERMETHOD_MOSAIC = 15;
- const ALPHACHANNEL_ACTIVATE = 1;
- const ALPHACHANNEL_RESET = 7;
- const ALPHACHANNEL_SET = 8;
- const ALPHACHANNEL_UNDEFINED = 0;
- const ALPHACHANNEL_COPY = 3;
- const ALPHACHANNEL_DEACTIVATE = 4;
- const ALPHACHANNEL_EXTRACT = 5;
- const ALPHACHANNEL_OPAQUE = 6;
- const ALPHACHANNEL_SHAPE = 9;
- const ALPHACHANNEL_TRANSPARENT = 10;
- const SPARSECOLORMETHOD_UNDEFINED = 0;
- const SPARSECOLORMETHOD_BARYCENTRIC = 1;
- const SPARSECOLORMETHOD_BILINEAR = 7;
- const SPARSECOLORMETHOD_POLYNOMIAL = 8;
- const SPARSECOLORMETHOD_SPEPARDS = 16;
- const SPARSECOLORMETHOD_VORONOI = 18;
- const SPARSECOLORMETHOD_INVERSE = 19;
- const DITHERMETHOD_UNDEFINED = 0;
- const DITHERMETHOD_NO = 1;
- const DITHERMETHOD_RIEMERSMA = 2;
- const DITHERMETHOD_FLOYDSTEINBERG = 3;
- const FUNCTION_UNDEFINED = 0;
- const FUNCTION_POLYNOMIAL = 1;
- const FUNCTION_SINUSOID = 2;
- const ALPHACHANNEL_BACKGROUND = 2;
- const FUNCTION_ARCSIN = 3;
- const FUNCTION_ARCTAN = 4;
- const ALPHACHANNEL_FLATTEN = 11;
- const ALPHACHANNEL_REMOVE = 12;
- const STATISTIC_GRADIENT = 1;
- const STATISTIC_MAXIMUM = 2;
- const STATISTIC_MEAN = 3;
- const STATISTIC_MEDIAN = 4;
- const STATISTIC_MINIMUM = 5;
- const STATISTIC_MODE = 6;
- const STATISTIC_NONPEAK = 7;
- const STATISTIC_STANDARD_DEVIATION = 8;
- const MORPHOLOGY_CONVOLVE = 1;
- const MORPHOLOGY_CORRELATE = 2;
- const MORPHOLOGY_ERODE = 3;
- const MORPHOLOGY_DILATE = 4;
- const MORPHOLOGY_ERODE_INTENSITY = 5;
- const MORPHOLOGY_DILATE_INTENSITY = 6;
- const MORPHOLOGY_DISTANCE = 7;
- const MORPHOLOGY_OPEN = 8;
- const MORPHOLOGY_CLOSE = 9;
- const MORPHOLOGY_OPEN_INTENSITY = 10;
- const MORPHOLOGY_CLOSE_INTENSITY = 11;
- const MORPHOLOGY_SMOOTH = 12;
- const MORPHOLOGY_EDGE_IN = 13;
- const MORPHOLOGY_EDGE_OUT = 14;
- const MORPHOLOGY_EDGE = 15;
- const MORPHOLOGY_TOP_HAT = 16;
- const MORPHOLOGY_BOTTOM_HAT = 17;
- const MORPHOLOGY_HIT_AND_MISS = 18;
- const MORPHOLOGY_THINNING = 19;
- const MORPHOLOGY_THICKEN = 20;
- const MORPHOLOGY_VORONOI = 21;
- const MORPHOLOGY_ITERATIVE = 22;
- const KERNEL_UNITY = 1;
- const KERNEL_GAUSSIAN = 2;
- const KERNEL_DIFFERENCE_OF_GAUSSIANS = 3;
- const KERNEL_LAPLACIAN_OF_GAUSSIANS = 4;
- const KERNEL_BLUR = 5;
- const KERNEL_COMET = 6;
- const KERNEL_LAPLACIAN = 7;
- const KERNEL_SOBEL = 8;
- const KERNEL_FREI_CHEN = 9;
- const KERNEL_ROBERTS = 10;
- const KERNEL_PREWITT = 11;
- const KERNEL_COMPASS = 12;
- const KERNEL_KIRSCH = 13;
- const KERNEL_DIAMOND = 14;
- const KERNEL_SQUARE = 15;
- const KERNEL_RECTANGLE = 16;
- const KERNEL_OCTAGON = 17;
- const KERNEL_DISK = 18;
- const KERNEL_PLUS = 19;
- const KERNEL_CROSS = 20;
- const KERNEL_RING = 21;
- const KERNEL_PEAKS = 22;
- const KERNEL_EDGES = 23;
- const KERNEL_CORNERS = 24;
- const KERNEL_DIAGONALS = 25;
- const KERNEL_LINE_ENDS = 26;
- const KERNEL_LINE_JUNCTIONS = 27;
- const KERNEL_RIDGES = 28;
- const KERNEL_CONVEX_HULL = 29;
- const KERNEL_THIN_SE = 30;
- const KERNEL_SKELETON = 31;
- const KERNEL_CHEBYSHEV = 32;
- const KERNEL_MANHATTAN = 33;
- const KERNEL_OCTAGONAL = 34;
- const KERNEL_EUCLIDEAN = 35;
- const KERNEL_USER_DEFINED = 36;
- const KERNEL_BINOMIAL = 37;
- const DIRECTION_LEFT_TO_RIGHT = 2;
- const DIRECTION_RIGHT_TO_LEFT = 1;
- const NORMALIZE_KERNEL_NONE = 0;
- const NORMALIZE_KERNEL_VALUE = 8192;
- const NORMALIZE_KERNEL_CORRELATE = 65536;
- const NORMALIZE_KERNEL_PERCENT = 4096;
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Removes repeated portions of images to optimize
- * @link https://php.net/manual/en/imagick.optimizeimagelayers.php
- * @return bool <b>TRUE</b> on success.
- */
- public function optimizeImageLayers () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the maximum bounding region between images
- * @link https://php.net/manual/en/imagick.compareimagelayers.php
- * @param int $method <p>
- * One of the layer method constants.
- * </p>
- * @return Imagick <b>TRUE</b> on success.
- */
- public function compareImageLayers ($method) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Quickly fetch attributes
- * @link https://php.net/manual/en/imagick.pingimageblob.php
- * @param string $image <p>
- * A string containing the image.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function pingImageBlob ($image) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Get basic image attributes in a lightweight manner
- * @link https://php.net/manual/en/imagick.pingimagefile.php
- * @param resource $filehandle <p>
- * An open filehandle to the image.
- * </p>
- * @param string $fileName [optional] <p>
- * Optional filename for this image.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function pingImageFile ($filehandle, $fileName = null) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a vertical mirror image
- * @link https://php.net/manual/en/imagick.transposeimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function transposeImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a horizontal mirror image
- * @link https://php.net/manual/en/imagick.transverseimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function transverseImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Remove edges from the image
- * @link https://php.net/manual/en/imagick.trimimage.php
- * @param float $fuzz <p>
- * By default target must match a particular pixel color exactly.
- * However, in many cases two colors may differ by a small amount.
- * The fuzz member of image defines how much tolerance is acceptable
- * to consider two colors as the same. This parameter represents the variation
- * on the quantum range.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function trimImage ($fuzz) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Applies wave filter to the image
- * @link https://php.net/manual/en/imagick.waveimage.php
- * @param float $amplitude <p>
- * The amplitude of the wave.
- * </p>
- * @param float $length <p>
- * The length of the wave.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function waveImage ($amplitude, $length) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds vignette filter to the image
- * @link https://php.net/manual/en/imagick.vignetteimage.php
- * @param float $blackPoint <p>
- * The black point.
- * </p>
- * @param float $whitePoint <p>
- * The white point
- * </p>
- * @param int $x <p>
- * X offset of the ellipse
- * </p>
- * @param int $y <p>
- * Y offset of the ellipse
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function vignetteImage ($blackPoint, $whitePoint, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Discards all but one of any pixel color
- * @link https://php.net/manual/en/imagick.uniqueimagecolors.php
- * @return bool <b>TRUE</b> on success.
- */
- public function uniqueImageColors () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Return if the image has a matte channel
- * @link https://php.net/manual/en/imagick.getimagematte.php
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
- public function getImageMatte () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image matte channel
- * @link https://php.net/manual/en/imagick.setimagematte.php
- * @param bool $matte <p>
- * True activates the matte channel and false disables it.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageMatte ($matte) {}
-
- /**
- * Adaptively resize image with data dependent triangulation
- *
- * If legacy is true, the calculations are done with the small rounding bug that existed in Imagick before 3.4.0.<br>
- * If false, the calculations should produce the same results as ImageMagick CLI does.<br>
- * <br>
- * <b>Note:</b> The behavior of the parameter bestfit changed in Imagick 3.0.0. Before this version given dimensions 400x400 an image of dimensions 200x150 would be left untouched.
- * In Imagick 3.0.0 and later the image would be scaled up to size 400x300 as this is the "best fit" for the given dimensions. If bestfit parameter is used both width and height must be given.
- * @link https://php.net/manual/en/imagick.adaptiveresizeimage.php
- * @param int $columns The number of columns in the scaled image.
- * @param int $rows The number of rows in the scaled image.
- * @param bool $bestfit [optional] Whether to fit the image inside a bounding box.<br>
- * The behavior of the parameter bestfit changed in Imagick 3.0.0. Before this version given dimensions 400x400 an image of dimensions 200x150 would be left untouched. In Imagick 3.0.0 and later the image would be scaled up to size 400x300 as this is the "best fit" for the given dimensions. If bestfit parameter is used both width and height must be given.
- * @param bool $legacy [optional] Added since 3.4.0. Default value FALSE
- * @return bool TRUE on success
- * @throws ImagickException Throws ImagickException on error
- * @since 2.0.0
- */
- public function adaptiveResizeImage ($columns, $rows, $bestfit = false, $legacy = false) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Simulates a pencil sketch
- * @link https://php.net/manual/en/imagick.sketchimage.php
- * @param float $radius <p>
- * The radius of the Gaussian, in pixels, not counting the center pixel
- * </p>
- * @param float $sigma <p>
- * The standard deviation of the Gaussian, in pixels.
- * </p>
- * @param float $angle <p>
- * Apply the effect along this angle.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function sketchImage ($radius, $sigma, $angle) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a 3D effect
- * @link https://php.net/manual/en/imagick.shadeimage.php
- * @param bool $gray <p>
- * A value other than zero shades the intensity of each pixel.
- * </p>
- * @param float $azimuth <p>
- * Defines the light source direction.
- * </p>
- * @param float $elevation <p>
- * Defines the light source direction.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function shadeImage ($gray, $azimuth, $elevation) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the size offset
- * @link https://php.net/manual/en/imagick.getsizeoffset.php
- * @return int the size offset associated with the Imagick object.
- */
- public function getSizeOffset () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the size and offset of the Imagick object
- * @link https://php.net/manual/en/imagick.setsizeoffset.php
- * @param int $columns <p>
- * The width in pixels.
- * </p>
- * @param int $rows <p>
- * The height in pixels.
- * </p>
- * @param int $offset <p>
- * The image offset.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setSizeOffset ($columns, $rows, $offset) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds adaptive blur filter to image
- * @link https://php.net/manual/en/imagick.adaptiveblurimage.php
- * @param float $radius <p>
- * The radius of the Gaussian, in pixels, not counting the center pixel.
- * Provide a value of 0 and the radius will be chosen automagically.
- * </p>
- * @param float $sigma <p>
- * The standard deviation of the Gaussian, in pixels.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function adaptiveBlurImage ($radius, $sigma, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Enhances the contrast of a color image
- * @link https://php.net/manual/en/imagick.contraststretchimage.php
- * @param float $black_point <p>
- * The black point.
- * </p>
- * @param float $white_point <p>
- * The white point.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. <b>Imagick::CHANNEL_ALL</b>. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function contrastStretchImage ($black_point, $white_point, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adaptively sharpen the image
- * @link https://php.net/manual/en/imagick.adaptivesharpenimage.php
- * @param float $radius <p>
- * The radius of the Gaussian, in pixels, not counting the center pixel. Use 0 for auto-select.
- * </p>
- * @param float $sigma <p>
- * The standard deviation of the Gaussian, in pixels.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function adaptiveSharpenImage ($radius, $sigma, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a high-contrast, two-color image
- * @link https://php.net/manual/en/imagick.randomthresholdimage.php
- * @param float $low <p>
- * The low point
- * </p>
- * @param float $high <p>
- * The high point
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function randomThresholdImage ($low, $high, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * @param $xRounding
- * @param $yRounding
- * @param $strokeWidth [optional]
- * @param $displace [optional]
- * @param $sizeCorrection [optional]
- */
- public function roundCornersImage ($xRounding, $yRounding, $strokeWidth, $displace, $sizeCorrection) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Rounds image corners
- * @link https://php.net/manual/en/imagick.roundcorners.php
- * @param float $x_rounding <p>
- * x rounding
- * </p>
- * @param float $y_rounding <p>
- * y rounding
- * </p>
- * @param float $stroke_width [optional] <p>
- * stroke width
- * </p>
- * @param float $displace [optional] <p>
- * image displace
- * </p>
- * @param float $size_correction [optional] <p>
- * size correction
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function roundCorners ($x_rounding, $y_rounding, $stroke_width = 10.0, $displace = 5.0, $size_correction = -6.0) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Set the iterator position
- * @link https://php.net/manual/en/imagick.setiteratorindex.php
- * @param int $index <p>
- * The position to set the iterator to
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setIteratorIndex ($index) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the index of the current active image
- * @link https://php.net/manual/en/imagick.getiteratorindex.php
- * @return int an integer containing the index of the image in the stack.
- */
- public function getIteratorIndex () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Convenience method for setting crop size and the image geometry
- * @link https://php.net/manual/en/imagick.transformimage.php
- * @param string $crop <p>
- * A crop geometry string. This geometry defines a subregion of the image to crop.
- * </p>
- * @param string $geometry <p>
- * An image geometry string. This geometry defines the final size of the image.
- * </p>
- * @return Imagick <b>TRUE</b> on success.
- */
- public function transformImage ($crop, $geometry) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image opacity level
- * @link https://php.net/manual/en/imagick.setimageopacity.php
- * @param float $opacity <p>
- * The level of transparency: 1.0 is fully opaque and 0.0 is fully
- * transparent.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageOpacity ($opacity) {}
-
- /**
- * (PECL imagick 2.2.2)<br/>
- * Performs an ordered dither
- * @link https://php.net/manual/en/imagick.orderedposterizeimage.php
- * @param string $threshold_map <p>
- * A string containing the name of the threshold dither map to use
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function orderedPosterizeImage ($threshold_map, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Simulates a Polaroid picture
- * @link https://php.net/manual/en/imagick.polaroidimage.php
- * @param ImagickDraw $properties <p>
- * The polaroid properties
- * </p>
- * @param float $angle <p>
- * The polaroid angle
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function polaroidImage (ImagickDraw $properties, $angle) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the named image property
- * @link https://php.net/manual/en/imagick.getimageproperty.php
- * @param string $name <p>
- * name of the property (for example Exif:DateTime)
- * </p>
- * @return string|false a string containing the image property, false if a
- * property with the given name does not exist.
- */
- public function getImageProperty ($name) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets an image property
- * @link https://php.net/manual/en/imagick.setimageproperty.php
- * @param string $name
- * @param string $value
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageProperty ($name, $value) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image interpolate pixel method
- * @link https://php.net/manual/en/imagick.setimageinterpolatemethod.php
- * @param int $method <p>
- * The method is one of the <b>Imagick::INTERPOLATE_*</b> constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageInterpolateMethod ($method) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the interpolation method
- * @link https://php.net/manual/en/imagick.getimageinterpolatemethod.php
- * @return int the interpolate method on success.
- */
- public function getImageInterpolateMethod () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Stretches with saturation the image intensity
- * @link https://php.net/manual/en/imagick.linearstretchimage.php
- * @param float $blackPoint <p>
- * The image black point
- * </p>
- * @param float $whitePoint <p>
- * The image white point
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function linearStretchImage ($blackPoint, $whitePoint) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the image length in bytes
- * @link https://php.net/manual/en/imagick.getimagelength.php
- * @return int an int containing the current image size.
- */
- public function getImageLength () {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Set image size
- * @link https://php.net/manual/en/imagick.extentimage.php
- * @param int $width <p>
- * The new width
- * </p>
- * @param int $height <p>
- * The new height
- * </p>
- * @param int $x <p>
- * X position for the new size
- * </p>
- * @param int $y <p>
- * Y position for the new size
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function extentImage ($width, $height, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image orientation
- * @link https://php.net/manual/en/imagick.getimageorientation.php
- * @return int an int on success.
- */
- public function getImageOrientation () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image orientation
- * @link https://php.net/manual/en/imagick.setimageorientation.php
- * @param int $orientation <p>
- * One of the orientation constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageOrientation ($orientation) {}
-
- /**
- * (PECL imagick 2.1.0)<br/>
- * Changes the color value of any pixel that matches target
- * @link https://php.net/manual/en/imagick.paintfloodfillimage.php
- * @param mixed $fill <p>
- * ImagickPixel object or a string containing the fill color
- * </p>
- * @param float $fuzz <p>
- * The amount of fuzz. For example, set fuzz to 10 and the color red at
- * intensities of 100 and 102 respectively are now interpreted as the
- * same color for the purposes of the floodfill.
- * </p>
- * @param mixed $bordercolor <p>
- * ImagickPixel object or a string containing the border color
- * </p>
- * @param int $x <p>
- * X start position of the floodfill
- * </p>
- * @param int $y <p>
- * Y start position of the floodfill
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function paintFloodfillImage ($fill, $fuzz, $bordercolor, $x, $y, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Replaces colors in the image from a color lookup table. Optional second parameter to replace colors in a specific channel. This method is available if Imagick has been compiled against ImageMagick version 6.3.6 or newer.
- * @link https://php.net/manual/en/imagick.clutimage.php
- * @param Imagick $lookup_table <p>
- * Imagick object containing the color lookup table
- * </p>
- * @param int $channel [optional] <p>
- * The Channeltype
- * constant. When not supplied, default channels are replaced.
- * </p>
- * @return bool <b>TRUE</b> on success.
- * @since 2.0.0
- */
- public function clutImage (Imagick $lookup_table, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the image properties
- * @link https://php.net/manual/en/imagick.getimageproperties.php
- * @param string $pattern [optional] <p>
- * The pattern for property names.
- * </p>
- * @param bool $only_names [optional] <p>
- * Whether to return only property names. If <b>FALSE</b> then also the values are returned
- * </p>
- * @return array an array containing the image properties or property names.
- */
- public function getImageProperties ($pattern = "*", $only_names = true) {}
-
- /**
- * (PECL imagick 2.2.0)<br/>
- * Returns the image profiles
- * @link https://php.net/manual/en/imagick.getimageprofiles.php
- * @param string $pattern [optional] <p>
- * The pattern for profile names.
- * </p>
- * @param bool $include_values [optional] <p>
- * Whether to return only profile names. If <b>FALSE</b> then only profile names will be returned.
- * </p>
- * @return array an array containing the image profiles or profile names.
- */
- public function getImageProfiles ($pattern = "*", $include_values = true) {}
-
- /**
- * (PECL imagick 2.0.1)<br/>
- * Distorts an image using various distortion methods
- * @link https://php.net/manual/en/imagick.distortimage.php
- * @param int $method <p>
- * The method of image distortion. See distortion constants
- * </p>
- * @param array $arguments <p>
- * The arguments for this distortion method
- * </p>
- * @param bool $bestfit <p>
- * Attempt to resize destination to fit distorted source
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function distortImage ($method, array $arguments, $bestfit) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Writes an image to a filehandle
- * @link https://php.net/manual/en/imagick.writeimagefile.php
- * @param resource $filehandle <p>
- * Filehandle where to write the image
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function writeImageFile ($filehandle) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Writes frames to a filehandle
- * @link https://php.net/manual/en/imagick.writeimagesfile.php
- * @param resource $filehandle <p>
- * Filehandle where to write the images
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function writeImagesFile ($filehandle) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Reset image page
- * @link https://php.net/manual/en/imagick.resetimagepage.php
- * @param string $page <p>
- * The page definition. For example 7168x5147+0+0
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function resetImagePage ($page) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Sets image clip mask
- * @link https://php.net/manual/en/imagick.setimageclipmask.php
- * @param Imagick $clip_mask <p>
- * The Imagick object containing the clip mask
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageClipMask (Imagick $clip_mask) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Gets image clip mask
- * @link https://php.net/manual/en/imagick.getimageclipmask.php
- * @return Imagick an Imagick object containing the clip mask.
- */
- public function getImageClipMask () {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Animates an image or images
- * @link https://php.net/manual/en/imagick.animateimages.php
- * @param string $x_server <p>
- * X server address
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function animateImages ($x_server) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Recolors image
- * @link https://php.net/manual/en/imagick.recolorimage.php
- * @param array $matrix <p>
- * The matrix containing the color values
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function recolorImage (array $matrix) {}
-
- /**
- * (PECL imagick 2.1.0)<br/>
- * Sets font
- * @link https://php.net/manual/en/imagick.setfont.php
- * @param string $font <p>
- * Font name or a filename
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setFont ($font) {}
-
- /**
- * (PECL imagick 2.1.0)<br/>
- * Gets font
- * @link https://php.net/manual/en/imagick.getfont.php
- * @return string|false the string containing the font name or <b>FALSE</b> if not font is set.
- */
- public function getFont () {}
-
- /**
- * (PECL imagick 2.1.0)<br/>
- * Sets point size
- * @link https://php.net/manual/en/imagick.setpointsize.php
- * @param float $point_size <p>
- * Point size
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setPointSize ($point_size) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Gets point size
- * @link https://php.net/manual/en/imagick.getpointsize.php
- * @return float a float containing the point size.
- */
- public function getPointSize () {}
-
- /**
- * (PECL imagick 2.1.0)<br/>
- * Merges image layers
- * @link https://php.net/manual/en/imagick.mergeimagelayers.php
- * @param int $layer_method <p>
- * One of the <b>Imagick::LAYERMETHOD_*</b> constants
- * </p>
- * @return Imagick Returns an Imagick object containing the merged image.
- * @throws ImagickException
- */
- public function mergeImageLayers ($layer_method) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Sets image alpha channel
- * @link https://php.net/manual/en/imagick.setimagealphachannel.php
- * @param int $mode <p>
- * One of the <b>Imagick::ALPHACHANNEL_*</b> constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageAlphaChannel ($mode) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Changes the color value of any pixel that matches target
- * @link https://php.net/manual/en/imagick.floodfillpaintimage.php
- * @param mixed $fill <p>
- * ImagickPixel object or a string containing the fill color
- * </p>
- * @param float $fuzz <p>
- * The amount of fuzz. For example, set fuzz to 10 and the color red at intensities of 100 and 102 respectively are now interpreted as the same color.
- * </p>
- * @param mixed $target <p>
- * ImagickPixel object or a string containing the target color to paint
- * </p>
- * @param int $x <p>
- * X start position of the floodfill
- * </p>
- * @param int $y <p>
- * Y start position of the floodfill
- * </p>
- * @param bool $invert <p>
- * If <b>TRUE</b> paints any pixel that does not match the target color.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function floodFillPaintImage ($fill, $fuzz, $target, $x, $y, $invert, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Changes the color value of any pixel that matches target
- * @link https://php.net/manual/en/imagick.opaquepaintimage.php
- * @param mixed $target <p>
- * ImagickPixel object or a string containing the color to change
- * </p>
- * @param mixed $fill <p>
- * The replacement color
- * </p>
- * @param float $fuzz <p>
- * The amount of fuzz. For example, set fuzz to 10 and the color red at intensities of 100 and 102 respectively are now interpreted as the same color.
- * </p>
- * @param bool $invert <p>
- * If <b>TRUE</b> paints any pixel that does not match the target color.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function opaquePaintImage ($target, $fill, $fuzz, $invert, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Paints pixels transparent
- * @link https://php.net/manual/en/imagick.transparentpaintimage.php
- * @param mixed $target <p>
- * The target color to paint
- * </p>
- * @param float $alpha <p>
- * The level of transparency: 1.0 is fully opaque and 0.0 is fully transparent.
- * </p>
- * @param float $fuzz <p>
- * The amount of fuzz. For example, set fuzz to 10 and the color red at intensities of 100 and 102 respectively are now interpreted as the same color.
- * </p>
- * @param bool $invert <p>
- * If <b>TRUE</b> paints any pixel that does not match the target color.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function transparentPaintImage ($target, $alpha, $fuzz, $invert) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Animates an image or images
- * @link https://php.net/manual/en/imagick.liquidrescaleimage.php
- * @param int $width <p>
- * The width of the target size
- * </p>
- * @param int $height <p>
- * The height of the target size
- * </p>
- * @param float $delta_x <p>
- * How much the seam can traverse on x-axis.
- * Passing 0 causes the seams to be straight.
- * </p>
- * @param float $rigidity <p>
- * Introduces a bias for non-straight seams. This parameter is
- * typically 0.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function liquidRescaleImage ($width, $height, $delta_x, $rigidity) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Enciphers an image
- * @link https://php.net/manual/en/imagick.encipherimage.php
- * @param string $passphrase <p>
- * The passphrase
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function encipherImage ($passphrase) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Deciphers an image
- * @link https://php.net/manual/en/imagick.decipherimage.php
- * @param string $passphrase <p>
- * The passphrase
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function decipherImage ($passphrase) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Sets the gravity
- * @link https://php.net/manual/en/imagick.setgravity.php
- * @param int $gravity <p>
- * The gravity property. Refer to the list of
- * gravity constants.
- * </p>
- * @return bool No value is returned.
- */
- public function setGravity ($gravity) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Gets the gravity
- * @link https://php.net/manual/en/imagick.getgravity.php
- * @return int the gravity property. Refer to the list of
- * gravity constants.
- */
- public function getGravity () {}
-
- /**
- * (PECL imagick 2.2.1)<br/>
- * Gets channel range
- * @link https://php.net/manual/en/imagick.getimagechannelrange.php
- * @param int $channel <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return array an array containing minima and maxima values of the channel(s).
- */
- public function getImageChannelRange ($channel) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Gets the image alpha channel
- * @link https://php.net/manual/en/imagick.getimagealphachannel.php
- * @return int a constant defining the current alpha channel value. Refer to this
- * list of alpha channel constants.
- */
- public function getImageAlphaChannel () {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Gets channel distortions
- * @link https://php.net/manual/en/imagick.getimagechanneldistortions.php
- * @param Imagick $reference <p>
- * Imagick object containing the reference image
- * </p>
- * @param int $metric <p>
- * Refer to this list of metric type constants.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return float a double describing the channel distortion.
- */
- public function getImageChannelDistortions (Imagick $reference, $metric, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Sets the image gravity
- * @link https://php.net/manual/en/imagick.setimagegravity.php
- * @param int $gravity <p>
- * The gravity property. Refer to the list of
- * gravity constants.
- * </p>
- * @return bool No value is returned.
- */
- public function setImageGravity ($gravity) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Gets the image gravity
- * @link https://php.net/manual/en/imagick.getimagegravity.php
- * @return int the images gravity property. Refer to the list of
- * gravity constants.
- */
- public function getImageGravity () {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Imports image pixels
- * @link https://php.net/manual/en/imagick.importimagepixels.php
- * @param int $x <p>
- * The image x position
- * </p>
- * @param int $y <p>
- * The image y position
- * </p>
- * @param int $width <p>
- * The image width
- * </p>
- * @param int $height <p>
- * The image height
- * </p>
- * @param string $map <p>
- * Map of pixel ordering as a string. This can be for example RGB.
- * The value can be any combination or order of R = red, G = green, B = blue, A = alpha (0 is transparent),
- * O = opacity (0 is opaque), C = cyan, Y = yellow, M = magenta, K = black, I = intensity (for grayscale), P = pad.
- * </p>
- * @param int $storage <p>
- * The pixel storage method.
- * Refer to this list of pixel constants.
- * </p>
- * @param array $pixels <p>
- * The array of pixels
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function importImagePixels ($x, $y, $width, $height, $map, $storage, array $pixels) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Removes skew from the image
- * @link https://php.net/manual/en/imagick.deskewimage.php
- * @param float $threshold <p>
- * Deskew threshold
- * </p>
- * @return bool
- */
- public function deskewImage ($threshold) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Segments an image
- * @link https://php.net/manual/en/imagick.segmentimage.php
- * @param int $COLORSPACE <p>
- * One of the COLORSPACE constants.
- * </p>
- * @param float $cluster_threshold <p>
- * A percentage describing minimum number of pixels
- * contained in hexedra before it is considered valid.
- * </p>
- * @param float $smooth_threshold <p>
- * Eliminates noise from the histogram.
- * </p>
- * @param bool $verbose [optional] <p>
- * Whether to output detailed information about recognised classes.
- * </p>
- * @return bool
- */
- public function segmentImage ($COLORSPACE, $cluster_threshold, $smooth_threshold, $verbose = false) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Interpolates colors
- * @link https://php.net/manual/en/imagick.sparsecolorimage.php
- * @param int $SPARSE_METHOD <p>
- * Refer to this list of sparse method constants
- * </p>
- * @param array $arguments <p>
- * An array containing the coordinates.
- * The array is in format array(1,1, 2,45)
- * </p>
- * @param int $channel [optional]
- * @return bool <b>TRUE</b> on success.
- */
- public function sparseColorImage ($SPARSE_METHOD, array $arguments, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Remaps image colors
- * @link https://php.net/manual/en/imagick.remapimage.php
- * @param Imagick $replacement <p>
- * An Imagick object containing the replacement colors
- * </p>
- * @param int $DITHER <p>
- * Refer to this list of dither method constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function remapImage (Imagick $replacement, $DITHER) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Exports raw image pixels
- * @link https://php.net/manual/en/imagick.exportimagepixels.php
- * @param int $x <p>
- * X-coordinate of the exported area
- * </p>
- * @param int $y <p>
- * Y-coordinate of the exported area
- * </p>
- * @param int $width <p>
- * Width of the exported aread
- * </p>
- * @param int $height <p>
- * Height of the exported area
- * </p>
- * @param string $map <p>
- * Ordering of the exported pixels. For example "RGB".
- * Valid characters for the map are R, G, B, A, O, C, Y, M, K, I and P.
- * </p>
- * @param int $STORAGE <p>
- * Refer to this list of pixel type constants
- * </p>
- * @return array an array containing the pixels values.
- */
- public function exportImagePixels ($x, $y, $width, $height, $map, $STORAGE) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * The getImageChannelKurtosis purpose
- * @link https://php.net/manual/en/imagick.getimagechannelkurtosis.php
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return array an array with kurtosis and skewness
- * members.
- */
- public function getImageChannelKurtosis ($channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Applies a function on the image
- * @link https://php.net/manual/en/imagick.functionimage.php
- * @param int $function <p>
- * Refer to this list of function constants
- * </p>
- * @param array $arguments <p>
- * Array of arguments to pass to this function.
- * </p>
- * @param int $channel [optional]
- * @return bool <b>TRUE</b> on success.
- */
- public function functionImage ($function, array $arguments, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * @param $COLORSPACE
- */
- public function transformImageColorspace ($COLORSPACE) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Replaces colors in the image
- * @link https://php.net/manual/en/imagick.haldclutimage.php
- * @param Imagick $clut <p>
- * Imagick object containing the Hald lookup image.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function haldClutImage (Imagick $clut, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * @param $CHANNEL [optional]
- */
- public function autoLevelImage ($CHANNEL) {}
-
- /**
- * @param $factor [optional]
- */
- public function blueShiftImage ($factor) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Get image artifact
- * @link https://php.net/manual/en/imagick.getimageartifact.php
- * @param string $artifact <p>
- * The name of the artifact
- * </p>
- * @return string the artifact value on success.
- */
- public function getImageArtifact ($artifact) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Set image artifact
- * @link https://php.net/manual/en/imagick.setimageartifact.php
- * @param string $artifact <p>
- * The name of the artifact
- * </p>
- * @param string $value <p>
- * The value of the artifact
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageArtifact ($artifact, $value) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Delete image artifact
- * @link https://php.net/manual/en/imagick.deleteimageartifact.php
- * @param string $artifact <p>
- * The name of the artifact to delete
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function deleteImageArtifact ($artifact) {}
-
- /**
- * (PECL imagick 0.9.10-0.9.9)<br/>
- * Gets the colorspace
- * @link https://php.net/manual/en/imagick.getcolorspace.php
- * @return int an integer which can be compared against COLORSPACE constants.
- */
- public function getColorspace () {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Set colorspace
- * @link https://php.net/manual/en/imagick.setcolorspace.php
- * @param int $COLORSPACE <p>
- * One of the COLORSPACE constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setColorspace ($COLORSPACE) {}
-
- /**
- * @param $CHANNEL [optional]
- */
- public function clampImage ($CHANNEL) {}
-
- /**
- * @param $stack
- * @param $offset
- */
- public function smushImages ($stack, $offset) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * The Imagick constructor
- * @link https://php.net/manual/en/imagick.construct.php
- * @param mixed $files <p>
- * The path to an image to load or an array of paths. Paths can include
- * wildcards for file names, or can be URLs.
- * </p>
- * @throws ImagickException Throws ImagickException on error.
- */
- public function __construct ($files = null) {}
-
- /**
- * @return string
- */
- public function __toString () {}
-
- public function count () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns a MagickPixelIterator
- * @link https://php.net/manual/en/imagick.getpixeliterator.php
- * @return ImagickPixelIterator an ImagickPixelIterator on success.
- */
- public function getPixelIterator () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Get an ImagickPixelIterator for an image section
- * @link https://php.net/manual/en/imagick.getpixelregioniterator.php
- * @param int $x <p>
- * The x-coordinate of the region.
- * </p>
- * @param int $y <p>
- * The y-coordinate of the region.
- * </p>
- * @param int $columns <p>
- * The width of the region.
- * </p>
- * @param int $rows <p>
- * The height of the region.
- * </p>
- * @return ImagickPixelIterator an ImagickPixelIterator for an image section.
- */
- public function getPixelRegionIterator ($x, $y, $columns, $rows) {}
-
- /**
- * (PECL imagick 0.9.0-0.9.9)<br/>
- * Reads image from filename
- * @link https://php.net/manual/en/imagick.readimage.php
- * @param string $filename
- * @return bool <b>TRUE</b> on success.
- * @throws ImagickException Throws ImagickException on error.
- */
- public function readImage ($filename) {}
-
- /**
- * @param $filenames
- * @throws ImagickException Throws ImagickException on error.
- */
- public function readImages ($filenames) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Reads image from a binary string
- * @link https://php.net/manual/en/imagick.readimageblob.php
- * @param string $image
- * @param string $filename [optional]
- * @return bool <b>TRUE</b> on success.
- * @throws ImagickException Throws ImagickException on error.
- */
- public function readImageBlob ($image, $filename = null) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the format of a particular image
- * @link https://php.net/manual/en/imagick.setimageformat.php
- * @param string $format <p>
- * String presentation of the image format. Format support
- * depends on the ImageMagick installation.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageFormat ($format) {}
-
- /**
- * Scales the size of an image to the given dimensions. Passing zero as either of the arguments will preserve dimension while scaling.<br>
- * If legacy is true, the calculations are done with the small rounding bug that existed in Imagick before 3.4.0.<br>
- * If false, the calculations should produce the same results as ImageMagick CLI does.
- * @link https://php.net/manual/en/imagick.scaleimage.php
- * @param int $cols
- * @param int $rows
- * @param bool $bestfit [optional] The behavior of the parameter bestfit changed in Imagick 3.0.0. Before this version given dimensions 400x400 an image of dimensions 200x150 would be left untouched. In Imagick 3.0.0 and later the image would be scaled up to size 400x300 as this is the "best fit" for the given dimensions. If bestfit parameter is used both width and height must be given.
- * @param bool $legacy [optional] Added since 3.4.0. Default value FALSE
- * @return bool <b>TRUE</b> on success.
- * @throws ImagickException Throws ImagickException on error
- * @since 2.0.0
- */
- public function scaleImage ($cols, $rows, $bestfit = false, $legacy = false) {}
-
- /**
- * (PECL imagick 0.9.0-0.9.9)<br/>
- * Writes an image to the specified filename
- * @link https://php.net/manual/en/imagick.writeimage.php
- * @param string $filename [optional] <p>
- * Filename where to write the image. The extension of the filename
- * defines the type of the file.
- * Format can be forced regardless of file extension using format: prefix,
- * for example "jpg:test.png".
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function writeImage ($filename = null) {}
-
- /**
- * (PECL imagick 0.9.0-0.9.9)<br/>
- * Writes an image or image sequence
- * @link https://php.net/manual/en/imagick.writeimages.php
- * @param string $filename
- * @param bool $adjoin
- * @return bool <b>TRUE</b> on success.
- */
- public function writeImages ($filename, $adjoin) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds blur filter to image
- * @link https://php.net/manual/en/imagick.blurimage.php
- * @param float $radius <p>
- * Blur radius
- * </p>
- * @param float $sigma <p>
- * Standard deviation
- * </p>
- * @param int $channel [optional] <p>
- * The Channeltype
- * constant. When not supplied, all channels are blurred.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function blurImage ($radius, $sigma, $channel = null) {}
-
- /**
- * Changes the size of an image to the given dimensions and removes any associated profiles.<br>
- * If legacy is true, the calculations are done with the small rounding bug that existed in Imagick before 3.4.0.<br>
- * If false, the calculations should produce the same results as ImageMagick CLI does.<br>
- * <br>
- * <b>Note:</b> The behavior of the parameter bestfit changed in Imagick 3.0.0. Before this version given dimensions 400x400 an image of dimensions 200x150 would be left untouched. In Imagick 3.0.0 and later the image would be scaled up to size 400x300 as this is the "best fit" for the given dimensions. If bestfit parameter is used both width and height must be given.
- * @link https://php.net/manual/en/imagick.thumbnailimage.php
- * @param int $columns <p>
- * Image width
- * </p>
- * @param int $rows <p>
- * Image height
- * </p>
- * @param bool $bestfit [optional] <p>
- * Whether to force maximum values
- * </p>
- * The behavior of the parameter bestfit changed in Imagick 3.0.0. Before this version given dimensions 400x400 an image of dimensions 200x150 would be left untouched. In Imagick 3.0.0 and later the image would be scaled up to size 400x300 as this is the "best fit" for the given dimensions. If bestfit parameter is used both width and height must be given.
- * @param bool $fill [optional]
- * @param bool $legacy [optional] Added since 3.4.0. Default value FALSE
- * @return bool <b>TRUE</b> on success.
- * @since 2.0.0
- */
- public function thumbnailImage ($columns, $rows, $bestfit = false, $fill = false, $legacy = false) {}
-
- /**
- * Creates a cropped thumbnail at the requested size.
- * If legacy is true, uses the incorrect behaviour that was present until Imagick 3.4.0.
- * If false it uses the correct behaviour.
- * @link https://php.net/manual/en/imagick.cropthumbnailimage.php
- * @param int $width The width of the thumbnail
- * @param int $height The Height of the thumbnail
- * @param bool $legacy [optional] Added since 3.4.0. Default value FALSE
- * @return bool TRUE on succes
- * @throws ImagickException Throws ImagickException on error
- * @since 2.0.0
- */
- public function cropThumbnailImage ($width, $height, $legacy = false) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the filename of a particular image in a sequence
- * @link https://php.net/manual/en/imagick.getimagefilename.php
- * @return string a string with the filename of the image.
- */
- public function getImageFilename () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the filename of a particular image
- * @link https://php.net/manual/en/imagick.setimagefilename.php
- * @param string $filename
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageFilename ($filename) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the format of a particular image in a sequence
- * @link https://php.net/manual/en/imagick.getimageformat.php
- * @return string a string containing the image format on success.
- */
- public function getImageFormat () {}
-
- /**
- * @link https://www.php.net/manual/en/imagick.getimagemimetype.php
- * @return string Returns the image mime-type.
- */
- public function getImageMimeType () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Removes an image from the image list
- * @link https://php.net/manual/en/imagick.removeimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function removeImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Destroys the Imagick object
- * @link https://php.net/manual/en/imagick.destroy.php
- * @return bool <b>TRUE</b> on success.
- */
- public function destroy () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Clears all resources associated to Imagick object
- * @link https://php.net/manual/en/imagick.clear.php
- * @return bool <b>TRUE</b> on success.
- */
- public function clear () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the image length in bytes
- * @link https://php.net/manual/en/imagick.getimagesize.php
- * @return int an int containing the current image size.
- * @deprecated use {@see Imagick::getImageLength()} instead
- */
- public function getImageSize () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the image sequence as a blob
- * @link https://php.net/manual/en/imagick.getimageblob.php
- * @return string a string containing the image.
- */
- public function getImageBlob () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns all image sequences as a blob
- * @link https://php.net/manual/en/imagick.getimagesblob.php
- * @return string a string containing the images. On failure, throws ImagickException on failure
- * @throws ImagickException on failure
- */
- public function getImagesBlob () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the Imagick iterator to the first image
- * @link https://php.net/manual/en/imagick.setfirstiterator.php
- * @return bool <b>TRUE</b> on success.
- */
- public function setFirstIterator () {}
-
- /**
- * (PECL imagick 2.0.1)<br/>
- * Sets the Imagick iterator to the last image
- * @link https://php.net/manual/en/imagick.setlastiterator.php
- * @return bool <b>TRUE</b> on success.
- */
- public function setLastIterator () {}
-
- public function resetIterator () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Move to the previous image in the object
- * @link https://php.net/manual/en/imagick.previousimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function previousImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Moves to the next image
- * @link https://php.net/manual/en/imagick.nextimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function nextImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Checks if the object has a previous image
- * @link https://php.net/manual/en/imagick.haspreviousimage.php
- * @return bool <b>TRUE</b> if the object has more images when traversing the list in the
- * reverse direction, returns <b>FALSE</b> if there are none.
- */
- public function hasPreviousImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Checks if the object has more images
- * @link https://php.net/manual/en/imagick.hasnextimage.php
- * @return bool <b>TRUE</b> if the object has more images when traversing the list in the
- * forward direction, returns <b>FALSE</b> if there are none.
- */
- public function hasNextImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Set the iterator position
- * @link https://php.net/manual/en/imagick.setimageindex.php
- * @param int $index <p>
- * The position to set the iterator to
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageIndex ($index) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the index of the current active image
- * @link https://php.net/manual/en/imagick.getimageindex.php
- * @return int an integer containing the index of the image in the stack.
- */
- public function getImageIndex () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds a comment to your image
- * @link https://php.net/manual/en/imagick.commentimage.php
- * @param string $comment <p>
- * The comment to add
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function commentImage ($comment) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Extracts a region of the image
- * @link https://php.net/manual/en/imagick.cropimage.php
- * @param int $width <p>
- * The width of the crop
- * </p>
- * @param int $height <p>
- * The height of the crop
- * </p>
- * @param int $x <p>
- * The X coordinate of the cropped region's top left corner
- * </p>
- * @param int $y <p>
- * The Y coordinate of the cropped region's top left corner
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function cropImage ($width, $height, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds a label to an image
- * @link https://php.net/manual/en/imagick.labelimage.php
- * @param string $label <p>
- * The label to add
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function labelImage ($label) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the width and height as an associative array
- * @link https://php.net/manual/en/imagick.getimagegeometry.php
- * @return array an array with the width/height of the image.
- */
- public function getImageGeometry () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Renders the ImagickDraw object on the current image
- * @link https://php.net/manual/en/imagick.drawimage.php
- * @param ImagickDraw $draw <p>
- * The drawing operations to render on the image.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function drawImage (ImagickDraw $draw) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Sets the image compression quality
- * @link https://php.net/manual/en/imagick.setimagecompressionquality.php
- * @param int $quality <p>
- * The image compression quality as an integer
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageCompressionQuality ($quality) {}
-
- /**
- * (PECL imagick 2.2.2)<br/>
- * Gets the current image's compression quality
- * @link https://php.net/manual/en/imagick.getimagecompressionquality.php
- * @return int integer describing the images compression quality
- */
- public function getImageCompressionQuality () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Annotates an image with text
- * @link https://php.net/manual/en/imagick.annotateimage.php
- * @param ImagickDraw $draw_settings <p>
- * The ImagickDraw object that contains settings for drawing the text
- * </p>
- * @param float $x <p>
- * Horizontal offset in pixels to the left of text
- * </p>
- * @param float $y <p>
- * Vertical offset in pixels to the baseline of text
- * </p>
- * @param float $angle <p>
- * The angle at which to write the text
- * </p>
- * @param string $text <p>
- * The string to draw
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function annotateImage (ImagickDraw $draw_settings, $x, $y, $angle, $text) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Composite one image onto another
- * @link https://php.net/manual/en/imagick.compositeimage.php
- * @param Imagick $composite_object <p>
- * Imagick object which holds the composite image
- * </p>
- * @param int $composite Composite operator
- * @param int $x <p>
- * The column offset of the composited image
- * </p>
- * @param int $y <p>
- * The row offset of the composited image
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function compositeImage (Imagick $composite_object, $composite, $x, $y, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Control the brightness, saturation, and hue
- * @link https://php.net/manual/en/imagick.modulateimage.php
- * @param float $brightness
- * @param float $saturation
- * @param float $hue
- * @return bool <b>TRUE</b> on success.
- */
- public function modulateImage ($brightness, $saturation, $hue) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the number of unique colors in the image
- * @link https://php.net/manual/en/imagick.getimagecolors.php
- * @return int <b>TRUE</b> on success.
- */
- public function getImageColors () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a composite image
- * @link https://php.net/manual/en/imagick.montageimage.php
- * @param ImagickDraw $draw <p>
- * The font name, size, and color are obtained from this object.
- * </p>
- * @param string $tile_geometry <p>
- * The number of tiles per row and page (e.g. 6x4+0+0).
- * </p>
- * @param string $thumbnail_geometry <p>
- * Preferred image size and border size of each thumbnail
- * (e.g. 120x120+4+3>).
- * </p>
- * @param int $mode <p>
- * Thumbnail framing mode, see Montage Mode constants.
- * </p>
- * @param string $frame <p>
- * Surround the image with an ornamental border (e.g. 15x15+3+3). The
- * frame color is that of the thumbnail's matte color.
- * </p>
- * @return Imagick <b>TRUE</b> on success.
- */
- public function montageImage (ImagickDraw $draw, $tile_geometry, $thumbnail_geometry, $mode, $frame) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Identifies an image and fetches attributes
- * @link https://php.net/manual/en/imagick.identifyimage.php
- * @param bool $appendRawOutput [optional]
- * @return array Identifies an image and returns the attributes. Attributes include
- * the image width, height, size, and others.
- */
- public function identifyImage ($appendRawOutput = false) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Changes the value of individual pixels based on a threshold
- * @link https://php.net/manual/en/imagick.thresholdimage.php
- * @param float $threshold
- * @param int $channel [optional]
- * @return bool <b>TRUE</b> on success.
- */
- public function thresholdImage ($threshold, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Selects a threshold for each pixel based on a range of intensity
- * @link https://php.net/manual/en/imagick.adaptivethresholdimage.php
- * @param int $width <p>
- * Width of the local neighborhood.
- * </p>
- * @param int $height <p>
- * Height of the local neighborhood.
- * </p>
- * @param int $offset <p>
- * The mean offset
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function adaptiveThresholdImage ($width, $height, $offset) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Forces all pixels below the threshold into black
- * @link https://php.net/manual/en/imagick.blackthresholdimage.php
- * @param mixed $threshold <p>
- * The threshold below which everything turns black
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function blackThresholdImage ($threshold) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Force all pixels above the threshold into white
- * @link https://php.net/manual/en/imagick.whitethresholdimage.php
- * @param mixed $threshold
- * @return bool <b>TRUE</b> on success.
- */
- public function whiteThresholdImage ($threshold) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Append a set of images
- * @link https://php.net/manual/en/imagick.appendimages.php
- * @param bool $stack [optional] <p>
- * Whether to stack the images vertically.
- * By default (or if <b>FALSE</b> is specified) images are stacked left-to-right.
- * If <i>stack</i> is <b>TRUE</b>, images are stacked top-to-bottom.
- * </p>
- * @return Imagick Imagick instance on success.
- */
- public function appendImages ($stack = false) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Simulates a charcoal drawing
- * @link https://php.net/manual/en/imagick.charcoalimage.php
- * @param float $radius <p>
- * The radius of the Gaussian, in pixels, not counting the center pixel
- * </p>
- * @param float $sigma <p>
- * The standard deviation of the Gaussian, in pixels
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function charcoalImage ($radius, $sigma) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Enhances the contrast of a color image
- * @link https://php.net/manual/en/imagick.normalizeimage.php
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function normalizeImage ($channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Simulates an oil painting
- * @link https://php.net/manual/en/imagick.oilpaintimage.php
- * @param float $radius <p>
- * The radius of the circular neighborhood.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function oilPaintImage ($radius) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Reduces the image to a limited number of color level
- * @link https://php.net/manual/en/imagick.posterizeimage.php
- * @param int $levels
- * @param bool $dither
- * @return bool <b>TRUE</b> on success.
- */
- public function posterizeImage ($levels, $dither) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Radial blurs an image
- * @link https://php.net/manual/en/imagick.radialblurimage.php
- * @param float $angle
- * @param int $channel [optional]
- * @return bool <b>TRUE</b> on success.
- */
- public function radialBlurImage ($angle, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a simulated 3d button-like effect
- * @link https://php.net/manual/en/imagick.raiseimage.php
- * @param int $width
- * @param int $height
- * @param int $x
- * @param int $y
- * @param bool $raise
- * @return bool <b>TRUE</b> on success.
- */
- public function raiseImage ($width, $height, $x, $y, $raise) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Resample image to desired resolution
- * @link https://php.net/manual/en/imagick.resampleimage.php
- * @param float $x_resolution
- * @param float $y_resolution
- * @param int $filter
- * @param float $blur
- * @return bool <b>TRUE</b> on success.
- */
- public function resampleImage ($x_resolution, $y_resolution, $filter, $blur) {}
-
- /**
- * Scales an image to the desired dimensions with one of these filters:<br>
- * If legacy is true, the calculations are done with the small rounding bug that existed in Imagick before 3.4.0.<br>
- * If false, the calculations should produce the same results as ImageMagick CLI does.<br>
- * <br>
- * <b>Note:</b> The behavior of the parameter bestfit changed in Imagick 3.0.0. Before this version given dimensions 400x400 an image of dimensions 200x150 would be left untouched.<br>
- * In Imagick 3.0.0 and later the image would be scaled up to size 400x300 as this is the "best fit" for the given dimensions. If bestfit parameter is used both width and height must be given.
- * @link https://php.net/manual/en/imagick.resizeimage.php
- * @param int $columns Width of the image
- * @param int $rows Height of the image
- * @param int $filter Refer to the list of filter constants.
- * @param float $blur The blur factor where > 1 is blurry, < 1 is sharp.
- * @param bool $bestfit [optional] Added since 2.1.0. Added optional fit parameter. This method now supports proportional scaling. Pass zero as either parameter for proportional scaling
- * @param bool $legacy [optional] Added since 3.4.0. Default value FALSE
- * @return bool TRUE on success
- * @since 2.0.0
- */
- public function resizeImage ($columns, $rows, $filter, $blur, $bestfit = false, $legacy = false) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Offsets an image
- * @link https://php.net/manual/en/imagick.rollimage.php
- * @param int $x <p>
- * The X offset.
- * </p>
- * @param int $y <p>
- * The Y offset.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function rollImage ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Rotates an image
- * @link https://php.net/manual/en/imagick.rotateimage.php
- * @param mixed $background <p>
- * The background color
- * </p>
- * @param float $degrees <p>
- * The number of degrees to rotate the image
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function rotateImage ($background, $degrees) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Scales an image with pixel sampling
- * @link https://php.net/manual/en/imagick.sampleimage.php
- * @param int $columns
- * @param int $rows
- * @return bool <b>TRUE</b> on success.
- */
- public function sampleImage ($columns, $rows) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Applies a solarizing effect to the image
- * @link https://php.net/manual/en/imagick.solarizeimage.php
- * @param int $threshold
- * @return bool <b>TRUE</b> on success.
- */
- public function solarizeImage ($threshold) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Simulates an image shadow
- * @link https://php.net/manual/en/imagick.shadowimage.php
- * @param float $opacity
- * @param float $sigma
- * @param int $x
- * @param int $y
- * @return bool <b>TRUE</b> on success.
- */
- public function shadowImage ($opacity, $sigma, $x, $y) {}
-
- /**
- * @param $key
- * @param $value
- */
- public function setImageAttribute ($key, $value) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image background color
- * @link https://php.net/manual/en/imagick.setimagebackgroundcolor.php
- * @param mixed $background
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageBackgroundColor ($background) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image composite operator
- * @link https://php.net/manual/en/imagick.setimagecompose.php
- * @param int $compose
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageCompose ($compose) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image compression
- * @link https://php.net/manual/en/imagick.setimagecompression.php
- * @param int $compression <p>
- * One of the <b>COMPRESSION</b> constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageCompression ($compression) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image delay
- * @link https://php.net/manual/en/imagick.setimagedelay.php
- * @param int $delay <p>
- * The amount of time expressed in 'ticks' that the image should be
- * displayed for. For animated GIFs there are 100 ticks per second, so a
- * value of 20 would be 20/100 of a second aka 1/5th of a second.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageDelay ($delay) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image depth
- * @link https://php.net/manual/en/imagick.setimagedepth.php
- * @param int $depth
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageDepth ($depth) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image gamma
- * @link https://php.net/manual/en/imagick.setimagegamma.php
- * @param float $gamma
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageGamma ($gamma) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image iterations
- * @link https://php.net/manual/en/imagick.setimageiterations.php
- * @param int $iterations <p>
- * The number of iterations the image should loop over. Set to '0' to loop
- * continuously.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageIterations ($iterations) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image matte color
- * @link https://php.net/manual/en/imagick.setimagemattecolor.php
- * @param mixed $matte
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageMatteColor ($matte) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the page geometry of the image
- * @link https://php.net/manual/en/imagick.setimagepage.php
- * @param int $width
- * @param int $height
- * @param int $x
- * @param int $y
- * @return bool <b>TRUE</b> on success.
- */
- public function setImagePage ($width, $height, $x, $y) {}
-
- /**
- * @param $filename
- */
- public function setImageProgressMonitor ($filename) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image resolution
- * @link https://php.net/manual/en/imagick.setimageresolution.php
- * @param float $x_resolution
- * @param float $y_resolution
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageResolution ($x_resolution, $y_resolution) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image scene
- * @link https://php.net/manual/en/imagick.setimagescene.php
- * @param int $scene
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageScene ($scene) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image ticks-per-second
- * @link https://php.net/manual/en/imagick.setimagetickspersecond.php
- * @param int $ticks_per_second <p>
- * The duration for which an image should be displayed expressed in ticks
- * per second.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageTicksPerSecond ($ticks_per_second) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image type
- * @link https://php.net/manual/en/imagick.setimagetype.php
- * @param int $image_type
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageType ($image_type) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image units of resolution
- * @link https://php.net/manual/en/imagick.setimageunits.php
- * @param int $units
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageUnits ($units) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sharpens an image
- * @link https://php.net/manual/en/imagick.sharpenimage.php
- * @param float $radius
- * @param float $sigma
- * @param int $channel [optional]
- * @return bool <b>TRUE</b> on success.
- */
- public function sharpenImage ($radius, $sigma, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Shaves pixels from the image edges
- * @link https://php.net/manual/en/imagick.shaveimage.php
- * @param int $columns
- * @param int $rows
- * @return bool <b>TRUE</b> on success.
- */
- public function shaveImage ($columns, $rows) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creating a parallelogram
- * @link https://php.net/manual/en/imagick.shearimage.php
- * @param mixed $background <p>
- * The background color
- * </p>
- * @param float $x_shear <p>
- * The number of degrees to shear on the x axis
- * </p>
- * @param float $y_shear <p>
- * The number of degrees to shear on the y axis
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function shearImage ($background, $x_shear, $y_shear) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Splices a solid color into the image
- * @link https://php.net/manual/en/imagick.spliceimage.php
- * @param int $width
- * @param int $height
- * @param int $x
- * @param int $y
- * @return bool <b>TRUE</b> on success.
- */
- public function spliceImage ($width, $height, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Fetch basic attributes about the image
- * @link https://php.net/manual/en/imagick.pingimage.php
- * @param string $filename <p>
- * The filename to read the information from.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function pingImage ($filename) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Reads image from open filehandle
- * @link https://php.net/manual/en/imagick.readimagefile.php
- * @param resource $filehandle
- * @param string $fileName [optional]
- * @return bool <b>TRUE</b> on success.
- */
- public function readImageFile ($filehandle, $fileName = null) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Displays an image
- * @link https://php.net/manual/en/imagick.displayimage.php
- * @param string $servername <p>
- * The X server name
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function displayImage ($servername) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Displays an image or image sequence
- * @link https://php.net/manual/en/imagick.displayimages.php
- * @param string $servername <p>
- * The X server name
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function displayImages ($servername) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Randomly displaces each pixel in a block
- * @link https://php.net/manual/en/imagick.spreadimage.php
- * @param float $radius
- * @return bool <b>TRUE</b> on success.
- */
- public function spreadImage ($radius) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Swirls the pixels about the center of the image
- * @link https://php.net/manual/en/imagick.swirlimage.php
- * @param float $degrees
- * @return bool <b>TRUE</b> on success.
- */
- public function swirlImage ($degrees) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Strips an image of all profiles and comments
- * @link https://php.net/manual/en/imagick.stripimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function stripImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns formats supported by Imagick
- * @link https://php.net/manual/en/imagick.queryformats.php
- * @param string $pattern [optional]
- * @return array an array containing the formats supported by Imagick.
- */
- public static function queryFormats ($pattern = "*") {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the configured fonts
- * @link https://php.net/manual/en/imagick.queryfonts.php
- * @param string $pattern [optional] <p>
- * The query pattern
- * </p>
- * @return array an array containing the configured fonts.
- */
- public static function queryFonts ($pattern = "*") {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns an array representing the font metrics
- * @link https://php.net/manual/en/imagick.queryfontmetrics.php
- * @param ImagickDraw $properties <p>
- * ImagickDraw object containing font properties
- * </p>
- * @param string $text <p>
- * The text
- * </p>
- * @param bool $multiline [optional] <p>
- * Multiline parameter. If left empty it is autodetected
- * </p>
- * @return array a multi-dimensional array representing the font metrics.
- */
- public function queryFontMetrics (ImagickDraw $properties, $text, $multiline = null) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Hides a digital watermark within the image
- * @link https://php.net/manual/en/imagick.steganoimage.php
- * @param Imagick $watermark_wand
- * @param int $offset
- * @return Imagick <b>TRUE</b> on success.
- */
- public function steganoImage (Imagick $watermark_wand, $offset) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds random noise to the image
- * @link https://php.net/manual/en/imagick.addnoiseimage.php
- * @param int $noise_type <p>
- * The type of the noise. Refer to this list of
- * noise constants.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function addNoiseImage ($noise_type, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Simulates motion blur
- * @link https://php.net/manual/en/imagick.motionblurimage.php
- * @param float $radius <p>
- * The radius of the Gaussian, in pixels, not counting the center pixel.
- * </p>
- * @param float $sigma <p>
- * The standard deviation of the Gaussian, in pixels.
- * </p>
- * @param float $angle <p>
- * Apply the effect along this angle.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * The channel argument affects only if Imagick is compiled against ImageMagick version
- * 6.4.4 or greater.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function motionBlurImage ($radius, $sigma, $angle, $channel = Imagick::CHANNEL_DEFAULT) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Forms a mosaic from images
- * @link https://php.net/manual/en/imagick.mosaicimages.php
- * @return Imagick <b>TRUE</b> on success.
- */
- public function mosaicImages () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Method morphs a set of images
- * @link https://php.net/manual/en/imagick.morphimages.php
- * @param int $number_frames <p>
- * The number of in-between images to generate.
- * </p>
- * @return Imagick This method returns a new Imagick object on success.
- * Throw an <b>ImagickException</b> on error.
- * @throws ImagickException on error
- */
- public function morphImages ($number_frames) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Scales an image proportionally to half its size
- * @link https://php.net/manual/en/imagick.minifyimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function minifyImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Transforms an image
- * @link https://php.net/manual/en/imagick.affinetransformimage.php
- * @param ImagickDraw $matrix <p>
- * The affine matrix
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function affineTransformImage (ImagickDraw $matrix) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Average a set of images
- * @link https://php.net/manual/en/imagick.averageimages.php
- * @return Imagick a new Imagick object on success.
- */
- public function averageImages () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Surrounds the image with a border
- * @link https://php.net/manual/en/imagick.borderimage.php
- * @param mixed $bordercolor <p>
- * ImagickPixel object or a string containing the border color
- * </p>
- * @param int $width <p>
- * Border width
- * </p>
- * @param int $height <p>
- * Border height
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function borderImage ($bordercolor, $width, $height) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Removes a region of an image and trims
- * @link https://php.net/manual/en/imagick.chopimage.php
- * @param int $width <p>
- * Width of the chopped area
- * </p>
- * @param int $height <p>
- * Height of the chopped area
- * </p>
- * @param int $x <p>
- * X origo of the chopped area
- * </p>
- * @param int $y <p>
- * Y origo of the chopped area
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function chopImage ($width, $height, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Clips along the first path from the 8BIM profile
- * @link https://php.net/manual/en/imagick.clipimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function clipImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Clips along the named paths from the 8BIM profile
- * @link https://php.net/manual/en/imagick.clippathimage.php
- * @param string $pathname <p>
- * The name of the path
- * </p>
- * @param bool $inside <p>
- * If <b>TRUE</b> later operations take effect inside clipping path.
- * Otherwise later operations take effect outside clipping path.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function clipPathImage ($pathname, $inside) {}
-
- /**
- * @param $pathname
- * @param $inside
- */
- public function clipImagePath ($pathname, $inside) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Composites a set of images
- * @link https://php.net/manual/en/imagick.coalesceimages.php
- * @return Imagick a new Imagick object on success.
- */
- public function coalesceImages () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Changes the color value of any pixel that matches target
- * @link https://php.net/manual/en/imagick.colorfloodfillimage.php
- * @param mixed $fill <p>
- * ImagickPixel object containing the fill color
- * </p>
- * @param float $fuzz <p>
- * The amount of fuzz. For example, set fuzz to 10 and the color red at
- * intensities of 100 and 102 respectively are now interpreted as the
- * same color for the purposes of the floodfill.
- * </p>
- * @param mixed $bordercolor <p>
- * ImagickPixel object containing the border color
- * </p>
- * @param int $x <p>
- * X start position of the floodfill
- * </p>
- * @param int $y <p>
- * Y start position of the floodfill
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function colorFloodfillImage ($fill, $fuzz, $bordercolor, $x, $y) {}
-
- /**
- * Blends the fill color with each pixel in the image. The 'opacity' color is a per channel strength factor for how strongly the color should be applied.<br>
- * If legacy is true, the behaviour of this function is incorrect, but consistent with how it behaved before Imagick version 3.4.0
- * @link https://php.net/manual/en/imagick.colorizeimage.php
- * @param mixed $colorize <p>
- * ImagickPixel object or a string containing the colorize color
- * </p>
- * @param mixed $opacity <p>
- * ImagickPixel object or an float containing the opacity value.
- * 1.0 is fully opaque and 0.0 is fully transparent.
- * </p>
- * @param bool $legacy [optional] Added since 3.4.0. Default value FALSE
- * @return bool <b>TRUE</b> on success.
- * @throws ImagickException Throws ImagickException on error
- * @since 2.0.0
- */
- public function colorizeImage ($colorize, $opacity, $legacy = false) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the difference in one or more images
- * @link https://php.net/manual/en/imagick.compareimagechannels.php
- * @param Imagick $image <p>
- * Imagick object containing the image to compare.
- * </p>
- * @param int $channelType <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @param int $metricType <p>
- * One of the metric type constants.
- * </p>
- * @return array Array consisting of new_wand and
- * distortion.
- */
- public function compareImageChannels (Imagick $image, $channelType, $metricType) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Compares an image to a reconstructed image
- * @link https://php.net/manual/en/imagick.compareimages.php
- * @param Imagick $compare <p>
- * An image to compare to.
- * </p>
- * @param int $metric <p>
- * Provide a valid metric type constant. Refer to this
- * list of metric constants.
- * </p>
- * @return array Array consisting of an Imagick object of the
- * reconstructed image and a double representing the difference.
- * @throws ImagickException Throws ImagickException on error.
- */
- public function compareImages (Imagick $compare, $metric) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Change the contrast of the image
- * @link https://php.net/manual/en/imagick.contrastimage.php
- * @param bool $sharpen <p>
- * The sharpen value
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function contrastImage ($sharpen) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Combines one or more images into a single image
- * @link https://php.net/manual/en/imagick.combineimages.php
- * @param int $channelType <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return Imagick <b>TRUE</b> on success.
- */
- public function combineImages ($channelType) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Applies a custom convolution kernel to the image
- * @link https://php.net/manual/en/imagick.convolveimage.php
- * @param array $kernel <p>
- * The convolution kernel
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function convolveImage (array $kernel, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Displaces an image's colormap
- * @link https://php.net/manual/en/imagick.cyclecolormapimage.php
- * @param int $displace <p>
- * The amount to displace the colormap.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function cycleColormapImage ($displace) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns certain pixel differences between images
- * @link https://php.net/manual/en/imagick.deconstructimages.php
- * @return Imagick a new Imagick object on success.
- */
- public function deconstructImages () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Reduces the speckle noise in an image
- * @link https://php.net/manual/en/imagick.despeckleimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function despeckleImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Enhance edges within the image
- * @link https://php.net/manual/en/imagick.edgeimage.php
- * @param float $radius <p>
- * The radius of the operation.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function edgeImage ($radius) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns a grayscale image with a three-dimensional effect
- * @link https://php.net/manual/en/imagick.embossimage.php
- * @param float $radius <p>
- * The radius of the effect
- * </p>
- * @param float $sigma <p>
- * The sigma of the effect
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function embossImage ($radius, $sigma) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Improves the quality of a noisy image
- * @link https://php.net/manual/en/imagick.enhanceimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function enhanceImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Equalizes the image histogram
- * @link https://php.net/manual/en/imagick.equalizeimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function equalizeImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Applies an expression to an image
- * @link https://php.net/manual/en/imagick.evaluateimage.php
- * @param int $op <p>
- * The evaluation operator
- * </p>
- * @param float $constant <p>
- * The value of the operator
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function evaluateImage ($op, $constant, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * Merges a sequence of images. This is useful for combining Photoshop layers into a single image.
- * This is replaced by:
- * <pre>
- * $im = $im->mergeImageLayers(\Imagick::LAYERMETHOD_FLATTEN)
- * </pre>
- * @link https://php.net/manual/en/imagick.flattenimages.php
- * @return Imagick Returns an Imagick object containing the merged image.
- * @throws ImagickException Throws ImagickException on error.
- * @since 2.0.0
- */
- public function flattenImages () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a vertical mirror image
- * @link https://php.net/manual/en/imagick.flipimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function flipImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a horizontal mirror image
- * @link https://php.net/manual/en/imagick.flopimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function flopImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds a simulated three-dimensional border
- * @link https://php.net/manual/en/imagick.frameimage.php
- * @param mixed $matte_color <p>
- * ImagickPixel object or a string representing the matte color
- * </p>
- * @param int $width <p>
- * The width of the border
- * </p>
- * @param int $height <p>
- * The height of the border
- * </p>
- * @param int $inner_bevel <p>
- * The inner bevel width
- * </p>
- * @param int $outer_bevel <p>
- * The outer bevel width
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function frameImage ($matte_color, $width, $height, $inner_bevel, $outer_bevel) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Evaluate expression for each pixel in the image
- * @link https://php.net/manual/en/imagick.fximage.php
- * @param string $expression <p>
- * The expression.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return Imagick <b>TRUE</b> on success.
- */
- public function fxImage ($expression, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gamma-corrects an image
- * @link https://php.net/manual/en/imagick.gammaimage.php
- * @param float $gamma <p>
- * The amount of gamma-correction.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function gammaImage ($gamma, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Blurs an image
- * @link https://php.net/manual/en/imagick.gaussianblurimage.php
- * @param float $radius <p>
- * The radius of the Gaussian, in pixels, not counting the center pixel.
- * </p>
- * @param float $sigma <p>
- * The standard deviation of the Gaussian, in pixels.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function gaussianBlurImage ($radius, $sigma, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * @param $key
- */
- public function getImageAttribute ($key) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the image background color
- * @link https://php.net/manual/en/imagick.getimagebackgroundcolor.php
- * @return ImagickPixel an ImagickPixel set to the background color of the image.
- */
- public function getImageBackgroundColor () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the chromaticy blue primary point
- * @link https://php.net/manual/en/imagick.getimageblueprimary.php
- * @return array Array consisting of "x" and "y" coordinates of point.
- */
- public function getImageBluePrimary () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the image border color
- * @link https://php.net/manual/en/imagick.getimagebordercolor.php
- * @return ImagickPixel <b>TRUE</b> on success.
- */
- public function getImageBorderColor () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the depth for a particular image channel
- * @link https://php.net/manual/en/imagick.getimagechanneldepth.php
- * @param int $channel <p>
- * Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to <b>Imagick::CHANNEL_DEFAULT</b>. Refer to this list of channel constants
- * </p>
- * @return int <b>TRUE</b> on success.
- */
- public function getImageChannelDepth ($channel) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Compares image channels of an image to a reconstructed image
- * @link https://php.net/manual/en/imagick.getimagechanneldistortion.php
- * @param Imagick $reference <p>
- * Imagick object to compare to.
- * </p>
- * @param int $channel <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @param int $metric <p>
- * One of the metric type constants.
- * </p>
- * @return float <b>TRUE</b> on success.
- */
- public function getImageChannelDistortion (Imagick $reference, $channel, $metric) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the extrema for one or more image channels
- * @link https://php.net/manual/en/imagick.getimagechannelextrema.php
- * @param int $channel <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return array <b>TRUE</b> on success.
- */
- public function getImageChannelExtrema ($channel) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the mean and standard deviation
- * @link https://php.net/manual/en/imagick.getimagechannelmean.php
- * @param int $channel <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return array <b>TRUE</b> on success.
- */
- public function getImageChannelMean ($channel) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns statistics for each channel in the image
- * @link https://php.net/manual/en/imagick.getimagechannelstatistics.php
- * @return array <b>TRUE</b> on success.
- */
- public function getImageChannelStatistics () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the color of the specified colormap index
- * @link https://php.net/manual/en/imagick.getimagecolormapcolor.php
- * @param int $index <p>
- * The offset into the image colormap.
- * </p>
- * @return ImagickPixel <b>TRUE</b> on success.
- */
- public function getImageColormapColor ($index) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image colorspace
- * @link https://php.net/manual/en/imagick.getimagecolorspace.php
- * @return int <b>TRUE</b> on success.
- */
- public function getImageColorspace () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the composite operator associated with the image
- * @link https://php.net/manual/en/imagick.getimagecompose.php
- * @return int <b>TRUE</b> on success.
- */
- public function getImageCompose () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image delay
- * @link https://php.net/manual/en/imagick.getimagedelay.php
- * @return int the image delay.
- */
- public function getImageDelay () {}
-
- /**
- * (PECL imagick 0.9.1-0.9.9)<br/>
- * Gets the image depth
- * @link https://php.net/manual/en/imagick.getimagedepth.php
- * @return int The image depth.
- */
- public function getImageDepth () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Compares an image to a reconstructed image
- * @link https://php.net/manual/en/imagick.getimagedistortion.php
- * @param Imagick $reference <p>
- * Imagick object to compare to.
- * </p>
- * @param int $metric <p>
- * One of the metric type constants.
- * </p>
- * @return float the distortion metric used on the image (or the best guess
- * thereof).
- */
- public function getImageDistortion (Imagick $reference, $metric) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the extrema for the image
- * @link https://php.net/manual/en/imagick.getimageextrema.php
- * @return array an associative array with the keys "min" and "max".
- */
- public function getImageExtrema () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image disposal method
- * @link https://php.net/manual/en/imagick.getimagedispose.php
- * @return int the dispose method on success.
- */
- public function getImageDispose () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image gamma
- * @link https://php.net/manual/en/imagick.getimagegamma.php
- * @return float the image gamma on success.
- */
- public function getImageGamma () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the chromaticy green primary point
- * @link https://php.net/manual/en/imagick.getimagegreenprimary.php
- * @return array an array with the keys "x" and "y" on success, throws an ImagickException on failure.
- * @throws ImagickException on failure
- */
- public function getImageGreenPrimary () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the image height
- * @link https://php.net/manual/en/imagick.getimageheight.php
- * @return int the image height in pixels.
- */
- public function getImageHeight () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image histogram
- * @link https://php.net/manual/en/imagick.getimagehistogram.php
- * @return array the image histogram as an array of ImagickPixel objects.
- */
- public function getImageHistogram () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image interlace scheme
- * @link https://php.net/manual/en/imagick.getimageinterlacescheme.php
- * @return int the interlace scheme as an integer on success.
- * Trhow an <b>ImagickException</b> on error.
- * @throws ImagickException on error
- */
- public function getImageInterlaceScheme () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image iterations
- * @link https://php.net/manual/en/imagick.getimageiterations.php
- * @return int the image iterations as an integer.
- */
- public function getImageIterations () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the image matte color
- * @link https://php.net/manual/en/imagick.getimagemattecolor.php
- * @return ImagickPixel ImagickPixel object on success.
- */
- public function getImageMatteColor () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the page geometry
- * @link https://php.net/manual/en/imagick.getimagepage.php
- * @return array the page geometry associated with the image in an array with the
- * keys "width", "height", "x", and "y".
- */
- public function getImagePage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the color of the specified pixel
- * @link https://php.net/manual/en/imagick.getimagepixelcolor.php
- * @param int $x <p>
- * The x-coordinate of the pixel
- * </p>
- * @param int $y <p>
- * The y-coordinate of the pixel
- * </p>
- * @return ImagickPixel an ImagickPixel instance for the color at the coordinates given.
- */
- public function getImagePixelColor ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the named image profile
- * @link https://php.net/manual/en/imagick.getimageprofile.php
- * @param string $name <p>
- * The name of the profile to return.
- * </p>
- * @return string a string containing the image profile.
- */
- public function getImageProfile ($name) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the chromaticity red primary point
- * @link https://php.net/manual/en/imagick.getimageredprimary.php
- * @return array the chromaticity red primary point as an array with the keys "x"
- * and "y".
- * Throw an <b>ImagickException</b> on error.
- * @throws ImagickException on error
- */
- public function getImageRedPrimary () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image rendering intent
- * @link https://php.net/manual/en/imagick.getimagerenderingintent.php
- * @return int the image rendering intent.
- */
- public function getImageRenderingIntent () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image X and Y resolution
- * @link https://php.net/manual/en/imagick.getimageresolution.php
- * @return array the resolution as an array.
- */
- public function getImageResolution () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image scene
- * @link https://php.net/manual/en/imagick.getimagescene.php
- * @return int the image scene.
- */
- public function getImageScene () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Generates an SHA-256 message digest
- * @link https://php.net/manual/en/imagick.getimagesignature.php
- * @return string a string containing the SHA-256 hash of the file.
- */
- public function getImageSignature () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image ticks-per-second
- * @link https://php.net/manual/en/imagick.getimagetickspersecond.php
- * @return int the image ticks-per-second.
- */
- public function getImageTicksPerSecond () {}
-
- /**
- * (PECL imagick 0.9.10-0.9.9)<br/>
- * Gets the potential image type
- * @link https://php.net/manual/en/imagick.getimagetype.php
- * @return int the potential image type.
- * <b>imagick::IMGTYPE_UNDEFINED</b>
- * <b>imagick::IMGTYPE_BILEVEL</b>
- * <b>imagick::IMGTYPE_GRAYSCALE</b>
- * <b>imagick::IMGTYPE_GRAYSCALEMATTE</b>
- * <b>imagick::IMGTYPE_PALETTE</b>
- * <b>imagick::IMGTYPE_PALETTEMATTE</b>
- * <b>imagick::IMGTYPE_TRUECOLOR</b>
- * <b>imagick::IMGTYPE_TRUECOLORMATTE</b>
- * <b>imagick::IMGTYPE_COLORSEPARATION</b>
- * <b>imagick::IMGTYPE_COLORSEPARATIONMATTE</b>
- * <b>imagick::IMGTYPE_OPTIMIZE</b>
- */
- public function getImageType () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image units of resolution
- * @link https://php.net/manual/en/imagick.getimageunits.php
- * @return int the image units of resolution.
- */
- public function getImageUnits () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the virtual pixel method
- * @link https://php.net/manual/en/imagick.getimagevirtualpixelmethod.php
- * @return int the virtual pixel method on success.
- */
- public function getImageVirtualPixelMethod () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the chromaticity white point
- * @link https://php.net/manual/en/imagick.getimagewhitepoint.php
- * @return array the chromaticity white point as an associative array with the keys
- * "x" and "y".
- */
- public function getImageWhitePoint () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the image width
- * @link https://php.net/manual/en/imagick.getimagewidth.php
- * @return int the image width.
- */
- public function getImageWidth () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the number of images in the object
- * @link https://php.net/manual/en/imagick.getnumberimages.php
- * @return int the number of images associated with Imagick object.
- */
- public function getNumberImages () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the image total ink density
- * @link https://php.net/manual/en/imagick.getimagetotalinkdensity.php
- * @return float the image total ink density of the image.
- * Throw an <b>ImagickException</b> on error.
- * @throws ImagickException on error
- */
- public function getImageTotalInkDensity () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Extracts a region of the image
- * @link https://php.net/manual/en/imagick.getimageregion.php
- * @param int $width <p>
- * The width of the extracted region.
- * </p>
- * @param int $height <p>
- * The height of the extracted region.
- * </p>
- * @param int $x <p>
- * X-coordinate of the top-left corner of the extracted region.
- * </p>
- * @param int $y <p>
- * Y-coordinate of the top-left corner of the extracted region.
- * </p>
- * @return Imagick Extracts a region of the image and returns it as a new wand.
- */
- public function getImageRegion ($width, $height, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a new image as a copy
- * @link https://php.net/manual/en/imagick.implodeimage.php
- * @param float $radius <p>
- * The radius of the implode
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function implodeImage ($radius) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adjusts the levels of an image
- * @link https://php.net/manual/en/imagick.levelimage.php
- * @param float $blackPoint <p>
- * The image black point
- * </p>
- * @param float $gamma <p>
- * The gamma value
- * </p>
- * @param float $whitePoint <p>
- * The image white point
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function levelImage ($blackPoint, $gamma, $whitePoint, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Scales an image proportionally 2x
- * @link https://php.net/manual/en/imagick.magnifyimage.php
- * @return bool <b>TRUE</b> on success.
- */
- public function magnifyImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Replaces the colors of an image with the closest color from a reference image.
- * @link https://php.net/manual/en/imagick.mapimage.php
- * @param Imagick $map
- * @param bool $dither
- * @return bool <b>TRUE</b> on success.
- */
- public function mapImage (Imagick $map, $dither) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Changes the transparency value of a color
- * @link https://php.net/manual/en/imagick.mattefloodfillimage.php
- * @param float $alpha <p>
- * The level of transparency: 1.0 is fully opaque and 0.0 is fully
- * transparent.
- * </p>
- * @param float $fuzz <p>
- * The fuzz member of image defines how much tolerance is acceptable to
- * consider two colors as the same.
- * </p>
- * @param mixed $bordercolor <p>
- * An <b>ImagickPixel</b> object or string representing the border color.
- * </p>
- * @param int $x <p>
- * The starting x coordinate of the operation.
- * </p>
- * @param int $y <p>
- * The starting y coordinate of the operation.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function matteFloodfillImage ($alpha, $fuzz, $bordercolor, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Applies a digital filter
- * @link https://php.net/manual/en/imagick.medianfilterimage.php
- * @param float $radius <p>
- * The radius of the pixel neighborhood.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function medianFilterImage ($radius) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Negates the colors in the reference image
- * @link https://php.net/manual/en/imagick.negateimage.php
- * @param bool $gray <p>
- * Whether to only negate grayscale pixels within the image.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function negateImage ($gray, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Change any pixel that matches color
- * @link https://php.net/manual/en/imagick.paintopaqueimage.php
- * @param mixed $target <p>
- * Change this target color to the fill color within the image. An
- * ImagickPixel object or a string representing the target color.
- * </p>
- * @param mixed $fill <p>
- * An ImagickPixel object or a string representing the fill color.
- * </p>
- * @param float $fuzz <p>
- * The fuzz member of image defines how much tolerance is acceptable to
- * consider two colors as the same.
- * </p>
- * @param int $channel [optional] <p>
- * Provide any channel constant that is valid for your channel mode. To
- * apply to more than one channel, combine channeltype constants using
- * bitwise operators. Refer to this
- * list of channel constants.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function paintOpaqueImage ($target, $fill, $fuzz, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Changes any pixel that matches color with the color defined by fill
- * @link https://php.net/manual/en/imagick.painttransparentimage.php
- * @param mixed $target <p>
- * Change this target color to specified opacity value within the image.
- * </p>
- * @param float $alpha <p>
- * The level of transparency: 1.0 is fully opaque and 0.0 is fully
- * transparent.
- * </p>
- * @param float $fuzz <p>
- * The fuzz member of image defines how much tolerance is acceptable to
- * consider two colors as the same.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function paintTransparentImage ($target, $alpha, $fuzz) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Quickly pin-point appropriate parameters for image processing
- * @link https://php.net/manual/en/imagick.previewimages.php
- * @param int $preview <p>
- * Preview type. See Preview type constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function previewImages ($preview) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds or removes a profile from an image
- * @link https://php.net/manual/en/imagick.profileimage.php
- * @param string $name
- * @param string $profile
- * @return bool <b>TRUE</b> on success.
- */
- public function profileImage ($name, $profile) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Analyzes the colors within a reference image
- * @link https://php.net/manual/en/imagick.quantizeimage.php
- * @param int $numberColors
- * @param int $colorspace
- * @param int $treedepth
- * @param bool $dither
- * @param bool $measureError
- * @return bool <b>TRUE</b> on success.
- */
- public function quantizeImage ($numberColors, $colorspace, $treedepth, $dither, $measureError) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Analyzes the colors within a sequence of images
- * @link https://php.net/manual/en/imagick.quantizeimages.php
- * @param int $numberColors
- * @param int $colorspace
- * @param int $treedepth
- * @param bool $dither
- * @param bool $measureError
- * @return bool <b>TRUE</b> on success.
- */
- public function quantizeImages ($numberColors, $colorspace, $treedepth, $dither, $measureError) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Smooths the contours of an image
- * @link https://php.net/manual/en/imagick.reducenoiseimage.php
- * @param float $radius
- * @return bool <b>TRUE</b> on success.
- */
- public function reduceNoiseImage ($radius) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Removes the named image profile and returns it
- * @link https://php.net/manual/en/imagick.removeimageprofile.php
- * @param string $name
- * @return string a string containing the profile of the image.
- */
- public function removeImageProfile ($name) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Separates a channel from the image
- * @link https://php.net/manual/en/imagick.separateimagechannel.php
- * @param int $channel
- * @return bool <b>TRUE</b> on success.
- */
- public function separateImageChannel ($channel) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sepia tones an image
- * @link https://php.net/manual/en/imagick.sepiatoneimage.php
- * @param float $threshold
- * @return bool <b>TRUE</b> on success.
- */
- public function sepiaToneImage ($threshold) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image bias for any method that convolves an image
- * @link https://php.net/manual/en/imagick.setimagebias.php
- * @param float $bias
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageBias ($bias) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image chromaticity blue primary point
- * @link https://php.net/manual/en/imagick.setimageblueprimary.php
- * @param float $x
- * @param float $y
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageBluePrimary ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image border color
- * @link https://php.net/manual/en/imagick.setimagebordercolor.php
- * @param mixed $border <p>
- * The border color
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageBorderColor ($border) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the depth of a particular image channel
- * @link https://php.net/manual/en/imagick.setimagechanneldepth.php
- * @param int $channel
- * @param int $depth
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageChannelDepth ($channel, $depth) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the color of the specified colormap index
- * @link https://php.net/manual/en/imagick.setimagecolormapcolor.php
- * @param int $index
- * @param ImagickPixel $color
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageColormapColor ($index, ImagickPixel $color) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image colorspace
- * @link https://php.net/manual/en/imagick.setimagecolorspace.php
- * @param int $colorspace <p>
- * One of the COLORSPACE constants
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageColorspace ($colorspace) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image disposal method
- * @link https://php.net/manual/en/imagick.setimagedispose.php
- * @param int $dispose
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageDispose ($dispose) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image size
- * @link https://php.net/manual/en/imagick.setimageextent.php
- * @param int $columns
- * @param int $rows
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageExtent ($columns, $rows) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image chromaticity green primary point
- * @link https://php.net/manual/en/imagick.setimagegreenprimary.php
- * @param float $x
- * @param float $y
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageGreenPrimary ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image compression
- * @link https://php.net/manual/en/imagick.setimageinterlacescheme.php
- * @param int $interlace_scheme
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageInterlaceScheme ($interlace_scheme) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds a named profile to the Imagick object
- * @link https://php.net/manual/en/imagick.setimageprofile.php
- * @param string $name
- * @param string $profile
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageProfile ($name, $profile) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image chromaticity red primary point
- * @link https://php.net/manual/en/imagick.setimageredprimary.php
- * @param float $x
- * @param float $y
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageRedPrimary ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image rendering intent
- * @link https://php.net/manual/en/imagick.setimagerenderingintent.php
- * @param int $rendering_intent
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageRenderingIntent ($rendering_intent) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image virtual pixel method
- * @link https://php.net/manual/en/imagick.setimagevirtualpixelmethod.php
- * @param int $method
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageVirtualPixelMethod ($method) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image chromaticity white point
- * @link https://php.net/manual/en/imagick.setimagewhitepoint.php
- * @param float $x
- * @param float $y
- * @return bool <b>TRUE</b> on success.
- */
- public function setImageWhitePoint ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adjusts the contrast of an image
- * @link https://php.net/manual/en/imagick.sigmoidalcontrastimage.php
- * @param bool $sharpen
- * @param float $alpha
- * @param float $beta
- * @param int $channel [optional]
- * @return bool <b>TRUE</b> on success.
- */
- public function sigmoidalContrastImage ($sharpen, $alpha, $beta, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Composites two images
- * @link https://php.net/manual/en/imagick.stereoimage.php
- * @param Imagick $offset_wand
- * @return bool <b>TRUE</b> on success.
- */
- public function stereoImage (Imagick $offset_wand) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Repeatedly tiles the texture image
- * @link https://php.net/manual/en/imagick.textureimage.php
- * @param Imagick $texture_wand
- * @return bool <b>TRUE</b> on success.
- */
- public function textureImage (Imagick $texture_wand) {}
-
- /**
- * pplies a color vector to each pixel in the image. The 'opacity' color is a per channel strength factor for how strongly the color should be applied.
- * If legacy is true, the behaviour of this function is incorrect, but consistent with how it behaved before Imagick version 3.4.0
- * @link https://php.net/manual/en/imagick.tintimage.php
- * @param mixed $tint
- * @param mixed $opacity
- * @param bool $legacy [optional]
- * @return bool <b>TRUE</b> on success.
- * @throws ImagickException Throws ImagickException on error
- * @since 2.0.0
- */
- public function tintImage ($tint, $opacity, $legacy = false) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sharpens an image
- * @link https://php.net/manual/en/imagick.unsharpmaskimage.php
- * @param float $radius
- * @param float $sigma
- * @param float $amount
- * @param float $threshold
- * @param int $channel [optional]
- * @return bool <b>TRUE</b> on success.
- */
- public function unsharpMaskImage ($radius, $sigma, $amount, $threshold, $channel = Imagick::CHANNEL_ALL) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns a new Imagick object
- * @link https://php.net/manual/en/imagick.getimage.php
- * @return Imagick a new Imagick object with the current image sequence.
- */
- public function getImage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds new image to Imagick object image list
- * @link https://php.net/manual/en/imagick.addimage.php
- * @param Imagick $source <p>
- * The source Imagick object
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function addImage (Imagick $source) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Replaces image in the object
- * @link https://php.net/manual/en/imagick.setimage.php
- * @param Imagick $replace <p>
- * The replace Imagick object
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setImage (Imagick $replace) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a new image
- * @link https://php.net/manual/en/imagick.newimage.php
- * @param int $cols <p>
- * Columns in the new image
- * </p>
- * @param int $rows <p>
- * Rows in the new image
- * </p>
- * @param mixed $background <p>
- * The background color used for this image
- * </p>
- * @param string $format [optional] <p>
- * Image format. This parameter was added in Imagick version 2.0.1.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function newImage ($cols, $rows, $background, $format = null) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Creates a new image
- * @link https://php.net/manual/en/imagick.newpseudoimage.php
- * @param int $columns <p>
- * columns in the new image
- * </p>
- * @param int $rows <p>
- * rows in the new image
- * </p>
- * @param string $pseudoString <p>
- * string containing pseudo image definition.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function newPseudoImage ($columns, $rows, $pseudoString) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the object compression type
- * @link https://php.net/manual/en/imagick.getcompression.php
- * @return int the compression constant
- */
- public function getCompression () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the object compression quality
- * @link https://php.net/manual/en/imagick.getcompressionquality.php
- * @return int integer describing the compression quality
- */
- public function getCompressionQuality () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the ImageMagick API copyright as a string
- * @link https://php.net/manual/en/imagick.getcopyright.php
- * @return string a string containing the copyright notice of Imagemagick and
- * Magickwand C API.
- */
- public static function getCopyright () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * The filename associated with an image sequence
- * @link https://php.net/manual/en/imagick.getfilename.php
- * @return string a string on success.
- */
- public function getFilename () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the format of the Imagick object
- * @link https://php.net/manual/en/imagick.getformat.php
- * @return string the format of the image.
- */
- public function getFormat () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the ImageMagick home URL
- * @link https://php.net/manual/en/imagick.gethomeurl.php
- * @return string a link to the imagemagick homepage.
- */
- public static function getHomeURL () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the object interlace scheme
- * @link https://php.net/manual/en/imagick.getinterlacescheme.php
- * @return int Gets the wand interlace
- * scheme.
- */
- public function getInterlaceScheme () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns a value associated with the specified key
- * @link https://php.net/manual/en/imagick.getoption.php
- * @param string $key <p>
- * The name of the option
- * </p>
- * @return string a value associated with a wand and the specified key.
- */
- public function getOption ($key) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the ImageMagick package name
- * @link https://php.net/manual/en/imagick.getpackagename.php
- * @return string the ImageMagick package name as a string.
- */
- public static function getPackageName () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the page geometry
- * @link https://php.net/manual/en/imagick.getpage.php
- * @return array the page geometry associated with the Imagick object in
- * an associative array with the keys "width", "height", "x", and "y",
- * throwing ImagickException on error.
- * @throws ImagickException on error
- */
- public function getPage () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the quantum depth
- * @link https://php.net/manual/en/imagick.getquantumdepth.php
- * @return array the Imagick quantum depth as a string.
- */
- public static function getQuantumDepth () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the Imagick quantum range
- * @link https://php.net/manual/en/imagick.getquantumrange.php
- * @return array the Imagick quantum range as a string.
- */
- public static function getQuantumRange () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the ImageMagick release date
- * @link https://php.net/manual/en/imagick.getreleasedate.php
- * @return string the ImageMagick release date as a string.
- */
- public static function getReleaseDate () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the specified resource's memory usage
- * @link https://php.net/manual/en/imagick.getresource.php
- * @param int $type <p>
- * Refer to the list of resourcetype constants.
- * </p>
- * @return int the specified resource's memory usage in megabytes.
- */
- public static function getResource ($type) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the specified resource limit
- * @link https://php.net/manual/en/imagick.getresourcelimit.php
- * @param int $type <p>
- * Refer to the list of resourcetype constants.
- * </p>
- * @return int the specified resource limit in megabytes.
- */
- public static function getResourceLimit ($type) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the horizontal and vertical sampling factor
- * @link https://php.net/manual/en/imagick.getsamplingfactors.php
- * @return array an associative array with the horizontal and vertical sampling
- * factors of the image.
- */
- public function getSamplingFactors () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the size associated with the Imagick object
- * @link https://php.net/manual/en/imagick.getsize.php
- * @return array the size associated with the Imagick object as an array with the
- * keys "columns" and "rows".
- */
- public function getSize () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the ImageMagick API version
- * @link https://php.net/manual/en/imagick.getversion.php
- * @return array the ImageMagick API version as a string and as a number.
- */
- public static function getVersion () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the object's default background color
- * @link https://php.net/manual/en/imagick.setbackgroundcolor.php
- * @param mixed $background
- * @return bool <b>TRUE</b> on success.
- */
- public function setBackgroundColor ($background) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the object's default compression type
- * @link https://php.net/manual/en/imagick.setcompression.php
- * @param int $compression
- * @return bool <b>TRUE</b> on success.
- */
- public function setCompression ($compression) {}
-
- /**
- * (PECL imagick 0.9.10-0.9.9)<br/>
- * Sets the object's default compression quality
- * @link https://php.net/manual/en/imagick.setcompressionquality.php
- * @param int $quality
- * @return bool <b>TRUE</b> on success.
- */
- public function setCompressionQuality ($quality) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the filename before you read or write the image
- * @link https://php.net/manual/en/imagick.setfilename.php
- * @param string $filename
- * @return bool <b>TRUE</b> on success.
- */
- public function setFilename ($filename) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the format of the Imagick object
- * @link https://php.net/manual/en/imagick.setformat.php
- * @param string $format
- * @return bool <b>TRUE</b> on success.
- */
- public function setFormat ($format) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image compression
- * @link https://php.net/manual/en/imagick.setinterlacescheme.php
- * @param int $interlace_scheme
- * @return bool <b>TRUE</b> on success.
- */
- public function setInterlaceScheme ($interlace_scheme) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Set an option
- * @link https://php.net/manual/en/imagick.setoption.php
- * @param string $key
- * @param string $value
- * @return bool <b>TRUE</b> on success.
- */
- public function setOption ($key, $value) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the page geometry of the Imagick object
- * @link https://php.net/manual/en/imagick.setpage.php
- * @param int $width
- * @param int $height
- * @param int $x
- * @param int $y
- * @return bool <b>TRUE</b> on success.
- */
- public function setPage ($width, $height, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the limit for a particular resource in megabytes
- * @link https://php.net/manual/en/imagick.setresourcelimit.php
- * @param int $type <p>
- * Refer to the list of resourcetype constants.
- * </p>
- * @param int $limit <p>
- * The resource limit. The unit depends on the type of the resource being limited.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public static function setResourceLimit ($type, $limit) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image resolution
- * @link https://php.net/manual/en/imagick.setresolution.php
- * @param float $x_resolution <p>
- * The horizontal resolution.
- * </p>
- * @param float $y_resolution <p>
- * The vertical resolution.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setResolution ($x_resolution, $y_resolution) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image sampling factors
- * @link https://php.net/manual/en/imagick.setsamplingfactors.php
- * @param array $factors
- * @return bool <b>TRUE</b> on success.
- */
- public function setSamplingFactors (array $factors) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the size of the Imagick object
- * @link https://php.net/manual/en/imagick.setsize.php
- * @param int $columns
- * @param int $rows
- * @return bool <b>TRUE</b> on success.
- */
- public function setSize ($columns, $rows) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the image type attribute
- * @link https://php.net/manual/en/imagick.settype.php
- * @param int $image_type
- * @return bool <b>TRUE</b> on success.
- */
- public function setType ($image_type) {}
-
- public function key () {}
-
- public function next () {}
-
- public function rewind () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Checks if the current item is valid
- * @link https://php.net/manual/en/imagick.valid.php
- * @return bool <b>TRUE</b> on success.
- */
- public function valid () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns a reference to the current Imagick object
- * @link https://php.net/manual/en/imagick.current.php
- * @return Imagick self on success.
- */
- public function current () {}
-
- /**
- * Change the brightness and/or contrast of an image. It converts the brightness and contrast parameters into slope and intercept and calls a polynomical function to apply to the image.
- * @link https://php.net/manual/en/imagick.brightnesscontrastimage.php
- * @param string $brightness
- * @param string $contrast
- * @param int $CHANNEL [optional]
- * @return void
- * @since 3.3.0
- */
- public function brightnessContrastImage ($brightness, $contrast, $CHANNEL = Imagick::CHANNEL_DEFAULT) { }
-
- /**
- * Applies a user supplied kernel to the image according to the given morphology method.
- * @link https://php.net/manual/en/imagick.morphology.php
- * @param int $morphologyMethod Which morphology method to use one of the \Imagick::MORPHOLOGY_* constants.
- * @param int $iterations The number of iteration to apply the morphology function. A value of -1 means loop until no change found. How this is applied may depend on the morphology method. Typically this is a value of 1.
- * @param ImagickKernel $ImagickKernel
- * @param int $CHANNEL [optional]
- * @return void
- * @since 3.3.0
- */
- public function morphology ($morphologyMethod, $iterations, ImagickKernel $ImagickKernel, $CHANNEL = Imagick::CHANNEL_DEFAULT) { }
-
- /**
- * Applies a custom convolution kernel to the image.
- * @link https://php.net/manual/en/imagick.filter.php
- * @param ImagickKernel $ImagickKernel An instance of ImagickKernel that represents either a single kernel or a linked series of kernels.
- * @param int $CHANNEL [optional] Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to Imagick::CHANNEL_DEFAULT. Refer to this list of channel constants
- * @return void
- * @since 3.3.0
- */
- public function filter (ImagickKernel $ImagickKernel , $CHANNEL = Imagick::CHANNEL_DEFAULT) { }
-
- /**
- * Apply color transformation to an image. The method permits saturation changes, hue rotation, luminance to alpha, and various other effects. Although variable-sized transformation matrices can be used, typically one uses a 5x5 matrix for an RGBA image and a 6x6 for CMYKA (or RGBA with offsets).
- * The matrix is similar to those used by Adobe Flash except offsets are in column 6 rather than 5 (in support of CMYKA images) and offsets are normalized (divide Flash offset by 255)
- * @link https://php.net/manual/en/imagick.colormatriximage.php
- * @param string $color_matrix
- * @return void
- * @since 3.3.0
- */
- public function colorMatrixImage ($color_matrix = Imagick::CHANNEL_DEFAULT) { }
-
- /**
- * Deletes an image property.
- * @link https://php.net/manual/en/imagick.deleteimageproperty.php
- * @param string $name The name of the property to delete.
- * @return void
- * @since 3.3.0
- */
- public function deleteImageProperty ($name) { }
-
- /**
- * Implements the discrete Fourier transform (DFT) of the image either as a magnitude / phase or real / imaginary image pair.
- * @link https://php.net/manual/en/imagick.forwardfouriertransformimage.php
- * @param bool $magnitude If true, return as magnitude / phase pair otherwise a real / imaginary image pair.
- * @return void
- * @since 3.3.0
- */
- public function forwardFourierTransformimage ($magnitude) { }
-
- /**
- * Gets the current image's compression type.
- * @link https://php.net/manual/en/imagick.getimagecompression.php
- * @return int
- * @since 3.3.0
- */
- public function getImageCompression () { }
-
- /**
- * Get the StringRegistry entry for the named key or false if not set.
- * @link https://php.net/manual/en/imagick.getregistry.php
- * @param string $key
- * @return string|false
- * @throws Exception Since version >=3.4.3. Throws an exception if the key does not exist, rather than terminating the program.
- * @since 3.3.0
- */
- public static function getRegistry ($key) { }
-
- /**
- * Returns the ImageMagick quantum range as an integer.
- * @link https://php.net/manual/en/imagick.getquantum.php
- * @return int
- * @since 3.3.0
- */
- public static function getQuantum () { }
-
- /**
- * Replaces any embedded formatting characters with the appropriate image property and returns the interpreted text. See https://www.imagemagick.org/script/escape.php for escape sequences.
- * @link https://php.net/manual/en/imagick.identifyformat.php
- * @see https://www.imagemagick.org/script/escape.php
- * @param string $embedText A string containing formatting sequences e.g. "Trim box: %@ number of unique colors: %k".
- * @return bool
- * @since 3.3.0
- */
- public function identifyFormat ($embedText) { }
-
- /**
- * Implements the inverse discrete Fourier transform (DFT) of the image either as a magnitude / phase or real / imaginary image pair.
- * @link https://php.net/manual/en/imagick.inversefouriertransformimage.php
- * @param Imagick $complement The second image to combine with this one to form either the magnitude / phase or real / imaginary image pair.
- * @param bool $magnitude If true, combine as magnitude / phase pair otherwise a real / imaginary image pair.
- * @return void
- * @since 3.3.0
- */
- public function inverseFourierTransformImage ($complement, $magnitude) { }
-
- /**
- * List all the registry settings. Returns an array of all the key/value pairs in the registry
- * @link https://php.net/manual/en/imagick.listregistry.php
- * @return array An array containing the key/values from the registry.
- * @since 3.3.0
- */
- public static function listRegistry () { }
-
- /**
- * Rotational blurs an image.
- * @link https://php.net/manual/en/imagick.rotationalblurimage.php
- * @param string $angle
- * @param string $CHANNEL
- * @return void
- * @since 3.3.0
- */
- public function rotationalBlurImage ($angle, $CHANNEL = Imagick::CHANNEL_DEFAULT) { }
-
- /**
- * Selectively blur an image within a contrast threshold. It is similar to the unsharpen mask that sharpens everything with contrast above a certain threshold.
- * @link https://php.net/manual/en/imagick.selectiveblurimage.php
- * @param float $radius
- * @param float $sigma
- * @param float $threshold
- * @param int $CHANNEL Provide any channel constant that is valid for your channel mode. To apply to more than one channel, combine channel constants using bitwise operators. Defaults to Imagick::CHANNEL_DEFAULT. Refer to this list of channel constants
- * @return void
- * @since 3.3.0
- */
- public function selectiveBlurImage ($radius, $sigma, $threshold, $CHANNEL = Imagick::CHANNEL_DEFAULT) { }
-
- /**
- * Set whether antialiasing should be used for operations. On by default.
- * @param bool $antialias
- * @return int
- * @since 3.3.0
- */
- public function setAntiAlias ($antialias) { }
-
- /**
- * @link https://php.net/manual/en/imagick.setimagebiasquantum.php
- * @param string $bias
- * @return void
- * @since 3.3.0
- */
- public function setImageBiasQuantum ($bias) { }
-
- /**
- * Set a callback that will be called during the processing of the Imagick image.
- * @link https://php.net/manual/en/imagick.setprogressmonitor.php
- * @param callable $callback The progress function to call. It should return true if image processing should continue, or false if it should be cancelled.
- * The offset parameter indicates the progress and the span parameter indicates the total amount of work needed to be done.
- * <pre> bool callback ( mixed $offset , mixed $span ) </pre>
- * <b>Caution</b>
- * The values passed to the callback function are not consistent. In particular the span parameter can increase during image processing. Because of this calculating the percentage complete of an image operation is not trivial.
- * @return void
- * @since 3.3.0
- */
- public function setProgressMonitor ($callback) { }
-
- /**
- * Sets the ImageMagick registry entry named key to value. This is most useful for setting "temporary-path" which controls where ImageMagick creates temporary images e.g. while processing PDFs.
- * @link https://php.net/manual/en/imagick.setregistry.php
- * @param string $key
- * @param string $value
- * @return void
- * @since 3.3.0
- */
- public static function setRegistry ($key, $value) { }
-
- /**
- * Replace each pixel with corresponding statistic from the neighborhood of the specified width and height.
- * @link https://php.net/manual/en/imagick.statisticimage.php
- * @param int $type
- * @param int $width
- * @param int $height
- * @param int $channel [optional]
- * @return void
- * @since 3.3.0
- */
- public function statisticImage ($type, $width, $height, $channel = Imagick::CHANNEL_DEFAULT ) { }
-
- /**
- * Searches for a subimage in the current image and returns a similarity image such that an exact match location is
- * completely white and if none of the pixels match, black, otherwise some gray level in-between.
- * You can also pass in the optional parameters bestMatch and similarity. After calling the function similarity will
- * be set to the 'score' of the similarity between the subimage and the matching position in the larger image,
- * bestMatch will contain an associative array with elements x, y, width, height that describe the matching region.
- *
- * @link https://php.net/manual/en/imagick.subimagematch.php
- * @param Imagick $imagick
- * @param array $bestMatch [optional]
- * @param float $similarity [optional] A new image that displays the amount of similarity at each pixel.
- * @param float $similarity_threshold [optional] Only used if compiled with ImageMagick (library) > 7
- * @param int $metric [optional] Only used if compiled with ImageMagick (library) > 7
- * @return Imagick
- * @since 3.3.0
- */
- public function subImageMatch (Imagick $imagick, array &$bestMatch, &$similarity, $similarity_threshold, $metric) { }
-
- /**
- * Is an alias of Imagick::subImageMatch
- *
- * @param Imagick $imagick
- * @param array $bestMatch [optional]
- * @param float $similarity [optional] A new image that displays the amount of similarity at each pixel.
- * @param float $similarity_threshold [optional]
- * @param int $metric [optional]
- * @return Imagick
- * @see Imagick::subImageMatch() This function is an alias of subImageMatch()
- * @since 3.4.0
- */
- public function similarityImage (Imagick $imagick, array &$bestMatch, &$similarity, $similarity_threshold, $metric) { }
-
- /**
- * Returns any ImageMagick configure options that match the specified pattern (e.g. "*" for all). Options include NAME, VERSION, LIB_VERSION, etc.
- * @return string
- * @since 3.4.0
- */
- public function getConfigureOptions () { }
-
- /**
- * GetFeatures() returns the ImageMagick features that have been compiled into the runtime.
- * @return string
- * @since 3.4.0
- */
- public function getFeatures () { }
-
- /**
- * @return int
- * @since 3.4.0
- */
- public function getHDRIEnabled () { }
-
- /**
- * Sets the image channel mask. Returns the previous set channel mask.
- * Only works with Imagick >=7
- * @param int $channel
- * @since 3.4.0
- */
- public function setImageChannelMask ($channel) {}
-
- /**
- * Merge multiple images of the same size together with the selected operator. https://www.imagemagick.org/Usage/layers/#evaluate-sequence
- * @param int $EVALUATE_CONSTANT
- * @return bool
- * @see https://www.imagemagick.org/Usage/layers/#evaluate-sequence
- * @since 3.4.0
- */
- public function evaluateImages ($EVALUATE_CONSTANT) { }
-
- /**
- * Extracts the 'mean' from the image and adjust the image to try make set its gamma appropriately.
- * @param int $channel [optional] Default value Imagick::CHANNEL_ALL
- * @return bool
- * @since 3.4.1
- */
- public function autoGammaImage ($channel = Imagick::CHANNEL_ALL) { }
-
- /**
- * Adjusts an image so that its orientation is suitable $ for viewing (i.e. top-left orientation).
- * @return bool
- * @since 3.4.1
- */
- public function autoOrient () { }
-
- /**
- * Composite one image onto another using the specified gravity.
- *
- * @param Imagick $imagick
- * @param int $COMPOSITE_CONSTANT
- * @param int $GRAVITY_CONSTANT
- * @return bool
- * @since 3.4.1
- */
- public function compositeImageGravity(Imagick $imagick, $COMPOSITE_CONSTANT, $GRAVITY_CONSTANT) { }
-
- /**
- * Attempts to increase the appearance of large-scale light-dark transitions.
- *
- * @param float $radius
- * @param float $strength
- * @return bool
- * @since 3.4.1
- */
- public function localContrastImage($radius, $strength) { }
-
- /**
- * Identifies the potential image type, returns one of the Imagick::IMGTYPE_* constants
- * @return int
- * @since 3.4.3
- */
- public function identifyImageType() { }
-
- /**
- * Sets the image to the specified alpha level. Will replace ImagickDraw::setOpacity()
- *
- * @param float $alpha
- * @return bool
- * @since 3.4.3
- */
- public function setImageAlpha($alpha) { }
-}
+ public function transposeImage(): bool {}
+
+ public function transverseImage(): bool {}
+
+ public function trimImage(float $fuzz): bool {}
+
+ public function waveImage(float $amplitude, float $length): bool {}
+
+ public function vignetteImage(float $black_point, float $white_point, int $x, int $y): bool {}
+
+ public function uniqueImageColors(): bool {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+// PHP_ME(imagick, getimagematte, imagick_zero_args, ZEND_ACC_PUBLIC | ZEND_ACC_DEPRECATED)
+ /** @deprecated */
+ public function getImageMatte(): bool {}
+#endif
+#endif
+
+ // TODO - enabled?
+ public function setImageMatte(bool $matte): bool {}
+
+ public function adaptiveResizeImage(
+ int $columns,
+ int $rows,
+ bool $bestfit = false,
+ bool $legacy = false): bool {}
-/**
- * @method ImagickDraw clone() (PECL imagick 2.0.0)<br/>Makes an exact copy of the specified ImagickDraw object
- * @link https://php.net/manual/en/class.imagickdraw.php
- */
-class ImagickDraw {
-
- public function resetVectorGraphics () {}
-
- public function getTextKerning () {}
-
- /**
- * @param $kerning
- */
- public function setTextKerning ($kerning) {}
-
- public function getTextInterWordSpacing () {}
-
- /**
- * @param $spacing
- */
- public function setTextInterWordSpacing ($spacing) {}
-
- public function getTextInterLineSpacing () {}
-
- /**
- * @param $spacing
- */
- public function setTextInterLineSpacing ($spacing) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * The ImagickDraw constructor
- * @link https://php.net/manual/en/imagickdraw.construct.php
- */
- public function __construct () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the fill color to be used for drawing filled objects
- * @link https://php.net/manual/en/imagickdraw.setfillcolor.php
- * @param ImagickPixel $fill_pixel <p>
- * ImagickPixel to use to set the color
- * </p>
- * @return bool No value is returned.
- */
- public function setFillColor (ImagickPixel $fill_pixel) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the opacity to use when drawing using the fill color or fill texture
- * @link https://php.net/manual/en/imagickdraw.setfillalpha.php
- * @param float $opacity <p>
- * fill alpha
- * </p>
- * @return bool No value is returned.
- */
- public function setFillAlpha ($opacity) {}
-
- /**
- * @param $x_resolution
- * @param $y_resolution
- */
- public function setResolution ($x_resolution, $y_resolution) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the color used for stroking object outlines
- * @link https://php.net/manual/en/imagickdraw.setstrokecolor.php
- * @param ImagickPixel $stroke_pixel <p>
- * the stroke color
- * </p>
- * @return bool No value is returned.
- */
- public function setStrokeColor (ImagickPixel $stroke_pixel) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies the opacity of stroked object outlines
- * @link https://php.net/manual/en/imagickdraw.setstrokealpha.php
- * @param float $opacity <p>
- * opacity
- * </p>
- * @return bool No value is returned.
- */
- public function setStrokeAlpha ($opacity) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the width of the stroke used to draw object outlines
- * @link https://php.net/manual/en/imagickdraw.setstrokewidth.php
- * @param float $stroke_width <p>
- * stroke width
- * </p>
- * @return bool No value is returned.
- */
- public function setStrokeWidth ($stroke_width) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Clears the ImagickDraw
- * @link https://php.net/manual/en/imagickdraw.clear.php
- * @return bool an ImagickDraw object.
- */
- public function clear () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a circle
- * @link https://php.net/manual/en/imagickdraw.circle.php
- * @param float $ox <p>
- * origin x coordinate
- * </p>
- * @param float $oy <p>
- * origin y coordinate
- * </p>
- * @param float $px <p>
- * perimeter x coordinate
- * </p>
- * @param float $py <p>
- * perimeter y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function circle ($ox, $oy, $px, $py) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws text on the image
- * @link https://php.net/manual/en/imagickdraw.annotation.php
- * @param float $x <p>
- * The x coordinate where text is drawn
- * </p>
- * @param float $y <p>
- * The y coordinate where text is drawn
- * </p>
- * @param string $text <p>
- * The text to draw on the image
- * </p>
- * @return bool No value is returned.
- */
- public function annotation ($x, $y, $text) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Controls whether text is antialiased
- * @link https://php.net/manual/en/imagickdraw.settextantialias.php
- * @param bool $antiAlias
- * @return bool No value is returned.
- */
- public function setTextAntialias ($antiAlias) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies specifies the text code set
- * @link https://php.net/manual/en/imagickdraw.settextencoding.php
- * @param string $encoding <p>
- * the encoding name
- * </p>
- * @return bool No value is returned.
- */
- public function setTextEncoding ($encoding) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the fully-specified font to use when annotating with text
- * @link https://php.net/manual/en/imagickdraw.setfont.php
- * @param string $font_name
- * @return bool <b>TRUE</b> on success.
- */
- public function setFont ($font_name) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the font family to use when annotating with text
- * @link https://php.net/manual/en/imagickdraw.setfontfamily.php
- * @param string $font_family <p>
- * the font family
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setFontFamily ($font_family) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the font pointsize to use when annotating with text
- * @link https://php.net/manual/en/imagickdraw.setfontsize.php
- * @param float $pointsize <p>
- * the point size
- * </p>
- * @return bool No value is returned.
- */
- public function setFontSize ($pointsize) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the font style to use when annotating with text
- * @link https://php.net/manual/en/imagickdraw.setfontstyle.php
- * @param int $style <p>
- * STYLETYPE_ constant
- * </p>
- * @return bool No value is returned.
- */
- public function setFontStyle ($style) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the font weight
- * @link https://php.net/manual/en/imagickdraw.setfontweight.php
- * @param int $font_weight
- * @return bool
- */
- public function setFontWeight ($font_weight) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the font
- * @link https://php.net/manual/en/imagickdraw.getfont.php
- * @return string|false a string on success and false if no font is set.
- */
- public function getFont () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the font family
- * @link https://php.net/manual/en/imagickdraw.getfontfamily.php
- * @return string|false the font family currently selected or false if font family is not set.
- */
- public function getFontFamily () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the font pointsize
- * @link https://php.net/manual/en/imagickdraw.getfontsize.php
- * @return float the font size associated with the current ImagickDraw object.
- */
- public function getFontSize () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the font style
- * @link https://php.net/manual/en/imagickdraw.getfontstyle.php
- * @return int the font style constant (STYLE_) associated with the ImagickDraw object
- * or 0 if no style is set.
- */
- public function getFontStyle () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the font weight
- * @link https://php.net/manual/en/imagickdraw.getfontweight.php
- * @return int an int on success and 0 if no weight is set.
- */
- public function getFontWeight () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Frees all associated resources
- * @link https://php.net/manual/en/imagickdraw.destroy.php
- * @return bool No value is returned.
- */
- public function destroy () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a rectangle
- * @link https://php.net/manual/en/imagickdraw.rectangle.php
- * @param float $x1 <p>
- * x coordinate of the top left corner
- * </p>
- * @param float $y1 <p>
- * y coordinate of the top left corner
- * </p>
- * @param float $x2 <p>
- * x coordinate of the bottom right corner
- * </p>
- * @param float $y2 <p>
- * y coordinate of the bottom right corner
- * </p>
- * @return bool No value is returned.
- */
- public function rectangle ($x1, $y1, $x2, $y2) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a rounded rectangle
- * @link https://php.net/manual/en/imagickdraw.roundrectangle.php
- * @param float $x1 <p>
- * x coordinate of the top left corner
- * </p>
- * @param float $y1 <p>
- * y coordinate of the top left corner
- * </p>
- * @param float $x2 <p>
- * x coordinate of the bottom right
- * </p>
- * @param float $y2 <p>
- * y coordinate of the bottom right
- * </p>
- * @param float $rx <p>
- * x rounding
- * </p>
- * @param float $ry <p>
- * y rounding
- * </p>
- * @return bool No value is returned.
- */
- public function roundRectangle ($x1, $y1, $x2, $y2, $rx, $ry) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws an ellipse on the image
- * @link https://php.net/manual/en/imagickdraw.ellipse.php
- * @param float $ox
- * @param float $oy
- * @param float $rx
- * @param float $ry
- * @param float $start
- * @param float $end
- * @return bool No value is returned.
- */
- public function ellipse ($ox, $oy, $rx, $ry, $start, $end) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Skews the current coordinate system in the horizontal direction
- * @link https://php.net/manual/en/imagickdraw.skewx.php
- * @param float $degrees <p>
- * degrees to skew
- * </p>
- * @return bool No value is returned.
- */
- public function skewX ($degrees) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Skews the current coordinate system in the vertical direction
- * @link https://php.net/manual/en/imagickdraw.skewy.php
- * @param float $degrees <p>
- * degrees to skew
- * </p>
- * @return bool No value is returned.
- */
- public function skewY ($degrees) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Applies a translation to the current coordinate system
- * @link https://php.net/manual/en/imagickdraw.translate.php
- * @param float $x <p>
- * horizontal translation
- * </p>
- * @param float $y <p>
- * vertical translation
- * </p>
- * @return bool No value is returned.
- */
- public function translate ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a line
- * @link https://php.net/manual/en/imagickdraw.line.php
- * @param float $sx <p>
- * starting x coordinate
- * </p>
- * @param float $sy <p>
- * starting y coordinate
- * </p>
- * @param float $ex <p>
- * ending x coordinate
- * </p>
- * @param float $ey <p>
- * ending y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function line ($sx, $sy, $ex, $ey) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws an arc
- * @link https://php.net/manual/en/imagickdraw.arc.php
- * @param float $sx <p>
- * Starting x ordinate of bounding rectangle
- * </p>
- * @param float $sy <p>
- * starting y ordinate of bounding rectangle
- * </p>
- * @param float $ex <p>
- * ending x ordinate of bounding rectangle
- * </p>
- * @param float $ey <p>
- * ending y ordinate of bounding rectangle
- * </p>
- * @param float $sd <p>
- * starting degrees of rotation
- * </p>
- * @param float $ed <p>
- * ending degrees of rotation
- * </p>
- * @return bool No value is returned.
- */
- public function arc ($sx, $sy, $ex, $ey, $sd, $ed) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Paints on the image's opacity channel
- * @link https://php.net/manual/en/imagickdraw.matte.php
- * @param float $x <p>
- * x coordinate of the matte
- * </p>
- * @param float $y <p>
- * y coordinate of the matte
- * </p>
- * @param int $paintMethod <p>
- * PAINT_ constant
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
- public function matte ($x, $y, $paintMethod) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a polygon
- * @link https://php.net/manual/en/imagickdraw.polygon.php
- * @param array $coordinates <p>
- * multidimensional array like array( array( 'x' => 3, 'y' => 4 ), array( 'x' => 2, 'y' => 6 ) );
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function polygon (array $coordinates) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a point
- * @link https://php.net/manual/en/imagickdraw.point.php
- * @param float $x <p>
- * point's x coordinate
- * </p>
- * @param float $y <p>
- * point's y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function point ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the text decoration
- * @link https://php.net/manual/en/imagickdraw.gettextdecoration.php
- * @return int one of the DECORATION_ constants
- * and 0 if no decoration is set.
- */
- public function getTextDecoration () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the code set used for text annotations
- * @link https://php.net/manual/en/imagickdraw.gettextencoding.php
- * @return string a string specifying the code set
- * or false if text encoding is not set.
- */
- public function getTextEncoding () {}
-
- public function getFontStretch () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the font stretch to use when annotating with text
- * @link https://php.net/manual/en/imagickdraw.setfontstretch.php
- * @param int $fontStretch <p>
- * STRETCH_ constant
- * </p>
- * @return bool No value is returned.
- */
- public function setFontStretch ($fontStretch) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Controls whether stroked outlines are antialiased
- * @link https://php.net/manual/en/imagickdraw.setstrokeantialias.php
- * @param bool $stroke_antialias <p>
- * the antialias setting
- * </p>
- * @return bool No value is returned.
- */
- public function setStrokeAntialias ($stroke_antialias) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies a text alignment
- * @link https://php.net/manual/en/imagickdraw.settextalignment.php
- * @param int $alignment <p>
- * ALIGN_ constant
- * </p>
- * @return bool No value is returned.
- */
- public function setTextAlignment ($alignment) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies a decoration
- * @link https://php.net/manual/en/imagickdraw.settextdecoration.php
- * @param int $decoration <p>
- * DECORATION_ constant
- * </p>
- * @return bool No value is returned.
- */
- public function setTextDecoration ($decoration) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies the color of a background rectangle
- * @link https://php.net/manual/en/imagickdraw.settextundercolor.php
- * @param ImagickPixel $under_color <p>
- * the under color
- * </p>
- * @return bool No value is returned.
- */
- public function setTextUnderColor (ImagickPixel $under_color) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the overall canvas size
- * @link https://php.net/manual/en/imagickdraw.setviewbox.php
- * @param int $x1 <p>
- * left x coordinate
- * </p>
- * @param int $y1 <p>
- * left y coordinate
- * </p>
- * @param int $x2 <p>
- * right x coordinate
- * </p>
- * @param int $y2 <p>
- * right y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function setViewbox ($x1, $y1, $x2, $y2) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adjusts the current affine transformation matrix
- * @link https://php.net/manual/en/imagickdraw.affine.php
- * @param array $affine <p>
- * Affine matrix parameters
- * </p>
- * @return bool No value is returned.
- */
- public function affine (array $affine) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a bezier curve
- * @link https://php.net/manual/en/imagickdraw.bezier.php
- * @param array $coordinates <p>
- * Multidimensional array like array( array( 'x' => 1, 'y' => 2 ),
- * array( 'x' => 3, 'y' => 4 ) )
- * </p>
- * @return bool No value is returned.
- */
- public function bezier (array $coordinates) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Composites an image onto the current image
- * @link https://php.net/manual/en/imagickdraw.composite.php
- * @param int $compose <p>
- * composition operator. One of COMPOSITE_ constants
- * </p>
- * @param float $x <p>
- * x coordinate of the top left corner
- * </p>
- * @param float $y <p>
- * y coordinate of the top left corner
- * </p>
- * @param float $width <p>
- * width of the composition image
- * </p>
- * @param float $height <p>
- * height of the composition image
- * </p>
- * @param Imagick $compositeWand <p>
- * the Imagick object where composition image is taken from
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function composite ($compose, $x, $y, $width, $height, Imagick $compositeWand) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws color on image
- * @link https://php.net/manual/en/imagickdraw.color.php
- * @param float $x <p>
- * x coordinate of the paint
- * </p>
- * @param float $y <p>
- * y coordinate of the paint
- * </p>
- * @param int $paintMethod <p>
- * one of the PAINT_ constants
- * </p>
- * @return bool No value is returned.
- */
- public function color ($x, $y, $paintMethod) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds a comment
- * @link https://php.net/manual/en/imagickdraw.comment.php
- * @param string $comment <p>
- * The comment string to add to vector output stream
- * </p>
- * @return bool No value is returned.
- */
- public function comment ($comment) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Obtains the current clipping path ID
- * @link https://php.net/manual/en/imagickdraw.getclippath.php
- * @return string|false a string containing the clip path ID or false if no clip path exists.
- */
- public function getClipPath () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the current polygon fill rule
- * @link https://php.net/manual/en/imagickdraw.getcliprule.php
- * @return int one of the FILLRULE_ constants.
- */
- public function getClipRule () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the interpretation of clip path units
- * @link https://php.net/manual/en/imagickdraw.getclipunits.php
- * @return int an int on success.
- */
- public function getClipUnits () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the fill color
- * @link https://php.net/manual/en/imagickdraw.getfillcolor.php
- * @return ImagickPixel an ImagickPixel object.
- */
- public function getFillColor () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the opacity used when drawing
- * @link https://php.net/manual/en/imagickdraw.getfillopacity.php
- * @return float The opacity.
- */
- public function getFillOpacity () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the fill rule
- * @link https://php.net/manual/en/imagickdraw.getfillrule.php
- * @return int a FILLRULE_ constant
- */
- public function getFillRule () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the text placement gravity
- * @link https://php.net/manual/en/imagickdraw.getgravity.php
- * @return int a GRAVITY_ constant on success and 0 if no gravity is set.
- */
- public function getGravity () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the current stroke antialias setting
- * @link https://php.net/manual/en/imagickdraw.getstrokeantialias.php
- * @return bool <b>TRUE</b> if antialiasing is on and false if it is off.
- */
- public function getStrokeAntialias () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the color used for stroking object outlines
- * @link https://php.net/manual/en/imagickdraw.getstrokecolor.php
- * @return ImagickPixel an ImagickPixel object which describes the color.
- */
- public function getStrokeColor () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns an array representing the pattern of dashes and gaps used to stroke paths
- * @link https://php.net/manual/en/imagickdraw.getstrokedasharray.php
- * @return array an array on success and empty array if not set.
- */
- public function getStrokeDashArray () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the offset into the dash pattern to start the dash
- * @link https://php.net/manual/en/imagickdraw.getstrokedashoffset.php
- * @return float a float representing the offset and 0 if it's not set.
- */
- public function getStrokeDashOffset () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the shape to be used at the end of open subpaths when they are stroked
- * @link https://php.net/manual/en/imagickdraw.getstrokelinecap.php
- * @return int one of the LINECAP_ constants or 0 if stroke linecap is not set.
- */
- public function getStrokeLineCap () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the shape to be used at the corners of paths when they are stroked
- * @link https://php.net/manual/en/imagickdraw.getstrokelinejoin.php
- * @return int one of the LINEJOIN_ constants or 0 if stroke line join is not set.
- */
- public function getStrokeLineJoin () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the stroke miter limit
- * @link https://php.net/manual/en/imagickdraw.getstrokemiterlimit.php
- * @return int an int describing the miter limit
- * and 0 if no miter limit is set.
- */
- public function getStrokeMiterLimit () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the opacity of stroked object outlines
- * @link https://php.net/manual/en/imagickdraw.getstrokeopacity.php
- * @return float a double describing the opacity.
- */
- public function getStrokeOpacity () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the width of the stroke used to draw object outlines
- * @link https://php.net/manual/en/imagickdraw.getstrokewidth.php
- * @return float a double describing the stroke width.
- */
- public function getStrokeWidth () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the text alignment
- * @link https://php.net/manual/en/imagickdraw.gettextalignment.php
- * @return int one of the ALIGN_ constants and 0 if no align is set.
- */
- public function getTextAlignment () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the current text antialias setting
- * @link https://php.net/manual/en/imagickdraw.gettextantialias.php
- * @return bool <b>TRUE</b> if text is antialiased and false if not.
- */
- public function getTextAntialias () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns a string containing vector graphics
- * @link https://php.net/manual/en/imagickdraw.getvectorgraphics.php
- * @return string a string containing the vector graphics.
- */
- public function getVectorGraphics () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the text under color
- * @link https://php.net/manual/en/imagickdraw.gettextundercolor.php
- * @return ImagickPixel an ImagickPixel object describing the color.
- */
- public function getTextUnderColor () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adds a path element to the current path
- * @link https://php.net/manual/en/imagickdraw.pathclose.php
- * @return bool No value is returned.
- */
- public function pathClose () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a cubic Bezier curve
- * @link https://php.net/manual/en/imagickdraw.pathcurvetoabsolute.php
- * @param float $x1 <p>
- * x coordinate of the first control point
- * </p>
- * @param float $y1 <p>
- * y coordinate of the first control point
- * </p>
- * @param float $x2 <p>
- * x coordinate of the second control point
- * </p>
- * @param float $y2 <p>
- * y coordinate of the first control point
- * </p>
- * @param float $x <p>
- * x coordinate of the curve end
- * </p>
- * @param float $y <p>
- * y coordinate of the curve end
- * </p>
- * @return bool No value is returned.
- */
- public function pathCurveToAbsolute ($x1, $y1, $x2, $y2, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a cubic Bezier curve
- * @link https://php.net/manual/en/imagickdraw.pathcurvetorelative.php
- * @param float $x1 <p>
- * x coordinate of starting control point
- * </p>
- * @param float $y1 <p>
- * y coordinate of starting control point
- * </p>
- * @param float $x2 <p>
- * x coordinate of ending control point
- * </p>
- * @param float $y2 <p>
- * y coordinate of ending control point
- * </p>
- * @param float $x <p>
- * ending x coordinate
- * </p>
- * @param float $y <p>
- * ending y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathCurveToRelative ($x1, $y1, $x2, $y2, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a quadratic Bezier curve
- * @link https://php.net/manual/en/imagickdraw.pathcurvetoquadraticbezierabsolute.php
- * @param float $x1 <p>
- * x coordinate of the control point
- * </p>
- * @param float $y1 <p>
- * y coordinate of the control point
- * </p>
- * @param float $x <p>
- * x coordinate of the end point
- * </p>
- * @param float $y <p>
- * y coordinate of the end point
- * </p>
- * @return bool No value is returned.
- */
- public function pathCurveToQuadraticBezierAbsolute ($x1, $y1, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a quadratic Bezier curve
- * @link https://php.net/manual/en/imagickdraw.pathcurvetoquadraticbezierrelative.php
- * @param float $x1 <p>
- * starting x coordinate
- * </p>
- * @param float $y1 <p>
- * starting y coordinate
- * </p>
- * @param float $x <p>
- * ending x coordinate
- * </p>
- * @param float $y <p>
- * ending y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathCurveToQuadraticBezierRelative ($x1, $y1, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a quadratic Bezier curve
- * @link https://php.net/manual/en/imagickdraw.pathcurvetoquadraticbeziersmoothabsolute.php
- * @param float $x <p>
- * ending x coordinate
- * </p>
- * @param float $y <p>
- * ending y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathCurveToQuadraticBezierSmoothAbsolute ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a quadratic Bezier curve
- * @link https://php.net/manual/en/imagickdraw.pathcurvetoquadraticbeziersmoothrelative.php
- * @param float $x <p>
- * ending x coordinate
- * </p>
- * @param float $y <p>
- * ending y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathCurveToQuadraticBezierSmoothRelative ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a cubic Bezier curve
- * @link https://php.net/manual/en/imagickdraw.pathcurvetosmoothabsolute.php
- * @param float $x2 <p>
- * x coordinate of the second control point
- * </p>
- * @param float $y2 <p>
- * y coordinate of the second control point
- * </p>
- * @param float $x <p>
- * x coordinate of the ending point
- * </p>
- * @param float $y <p>
- * y coordinate of the ending point
- * </p>
- * @return bool No value is returned.
- */
- public function pathCurveToSmoothAbsolute ($x2, $y2, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a cubic Bezier curve
- * @link https://php.net/manual/en/imagickdraw.pathcurvetosmoothrelative.php
- * @param float $x2 <p>
- * x coordinate of the second control point
- * </p>
- * @param float $y2 <p>
- * y coordinate of the second control point
- * </p>
- * @param float $x <p>
- * x coordinate of the ending point
- * </p>
- * @param float $y <p>
- * y coordinate of the ending point
- * </p>
- * @return bool No value is returned.
- */
- public function pathCurveToSmoothRelative ($x2, $y2, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws an elliptical arc
- * @link https://php.net/manual/en/imagickdraw.pathellipticarcabsolute.php
- * @param float $rx <p>
- * x radius
- * </p>
- * @param float $ry <p>
- * y radius
- * </p>
- * @param float $x_axis_rotation <p>
- * x axis rotation
- * </p>
- * @param bool $large_arc_flag <p>
- * large arc flag
- * </p>
- * @param bool $sweep_flag <p>
- * sweep flag
- * </p>
- * @param float $x <p>
- * x coordinate
- * </p>
- * @param float $y <p>
- * y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathEllipticArcAbsolute ($rx, $ry, $x_axis_rotation, $large_arc_flag, $sweep_flag, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws an elliptical arc
- * @link https://php.net/manual/en/imagickdraw.pathellipticarcrelative.php
- * @param float $rx <p>
- * x radius
- * </p>
- * @param float $ry <p>
- * y radius
- * </p>
- * @param float $x_axis_rotation <p>
- * x axis rotation
- * </p>
- * @param bool $large_arc_flag <p>
- * large arc flag
- * </p>
- * @param bool $sweep_flag <p>
- * sweep flag
- * </p>
- * @param float $x <p>
- * x coordinate
- * </p>
- * @param float $y <p>
- * y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathEllipticArcRelative ($rx, $ry, $x_axis_rotation, $large_arc_flag, $sweep_flag, $x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Terminates the current path
- * @link https://php.net/manual/en/imagickdraw.pathfinish.php
- * @return bool No value is returned.
- */
- public function pathFinish () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a line path
- * @link https://php.net/manual/en/imagickdraw.pathlinetoabsolute.php
- * @param float $x <p>
- * starting x coordinate
- * </p>
- * @param float $y <p>
- * ending x coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathLineToAbsolute ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a line path
- * @link https://php.net/manual/en/imagickdraw.pathlinetorelative.php
- * @param float $x <p>
- * starting x coordinate
- * </p>
- * @param float $y <p>
- * starting y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathLineToRelative ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a horizontal line path
- * @link https://php.net/manual/en/imagickdraw.pathlinetohorizontalabsolute.php
- * @param float $x <p>
- * x coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathLineToHorizontalAbsolute ($x) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a horizontal line
- * @link https://php.net/manual/en/imagickdraw.pathlinetohorizontalrelative.php
- * @param float $x <p>
- * x coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathLineToHorizontalRelative ($x) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a vertical line
- * @link https://php.net/manual/en/imagickdraw.pathlinetoverticalabsolute.php
- * @param float $y <p>
- * y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathLineToVerticalAbsolute ($y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a vertical line path
- * @link https://php.net/manual/en/imagickdraw.pathlinetoverticalrelative.php
- * @param float $y <p>
- * y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathLineToVerticalRelative ($y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Starts a new sub-path
- * @link https://php.net/manual/en/imagickdraw.pathmovetoabsolute.php
- * @param float $x <p>
- * x coordinate of the starting point
- * </p>
- * @param float $y <p>
- * y coordinate of the starting point
- * </p>
- * @return bool No value is returned.
- */
- public function pathMoveToAbsolute ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Starts a new sub-path
- * @link https://php.net/manual/en/imagickdraw.pathmovetorelative.php
- * @param float $x <p>
- * target x coordinate
- * </p>
- * @param float $y <p>
- * target y coordinate
- * </p>
- * @return bool No value is returned.
- */
- public function pathMoveToRelative ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Declares the start of a path drawing list
- * @link https://php.net/manual/en/imagickdraw.pathstart.php
- * @return bool No value is returned.
- */
- public function pathStart () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Draws a polyline
- * @link https://php.net/manual/en/imagickdraw.polyline.php
- * @param array $coordinates <p>
- * array of x and y coordinates: array( array( 'x' => 4, 'y' => 6 ), array( 'x' => 8, 'y' => 10 ) )
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function polyline (array $coordinates) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Terminates a clip path definition
- * @link https://php.net/manual/en/imagickdraw.popclippath.php
- * @return bool No value is returned.
- */
- public function popClipPath () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Terminates a definition list
- * @link https://php.net/manual/en/imagickdraw.popdefs.php
- * @return bool No value is returned.
- */
- public function popDefs () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Terminates a pattern definition
- * @link https://php.net/manual/en/imagickdraw.poppattern.php
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
- public function popPattern () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Starts a clip path definition
- * @link https://php.net/manual/en/imagickdraw.pushclippath.php
- * @param string $clip_mask_id <p>
- * Clip mask Id
- * </p>
- * @return bool No value is returned.
- */
- public function pushClipPath ($clip_mask_id) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Indicates that following commands create named elements for early processing
- * @link https://php.net/manual/en/imagickdraw.pushdefs.php
- * @return bool No value is returned.
- */
- public function pushDefs () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Indicates that subsequent commands up to a ImagickDraw::opPattern() command comprise the definition of a named pattern
- * @link https://php.net/manual/en/imagickdraw.pushpattern.php
- * @param string $pattern_id <p>
- * the pattern Id
- * </p>
- * @param float $x <p>
- * x coordinate of the top-left corner
- * </p>
- * @param float $y <p>
- * y coordinate of the top-left corner
- * </p>
- * @param float $width <p>
- * width of the pattern
- * </p>
- * @param float $height <p>
- * height of the pattern
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
- public function pushPattern ($pattern_id, $x, $y, $width, $height) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Renders all preceding drawing commands onto the image
- * @link https://php.net/manual/en/imagickdraw.render.php
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
- public function render () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Applies the specified rotation to the current coordinate space
- * @link https://php.net/manual/en/imagickdraw.rotate.php
- * @param float $degrees <p>
- * degrees to rotate
- * </p>
- * @return bool No value is returned.
- */
- public function rotate ($degrees) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Adjusts the scaling factor
- * @link https://php.net/manual/en/imagickdraw.scale.php
- * @param float $x <p>
- * horizontal factor
- * </p>
- * @param float $y <p>
- * vertical factor
- * </p>
- * @return bool No value is returned.
- */
- public function scale ($x, $y) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Associates a named clipping path with the image
- * @link https://php.net/manual/en/imagickdraw.setclippath.php
- * @param string $clip_mask <p>
- * the clipping path name
- * </p>
- * @return bool No value is returned.
- */
- public function setClipPath ($clip_mask) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Set the polygon fill rule to be used by the clipping path
- * @link https://php.net/manual/en/imagickdraw.setcliprule.php
- * @param int $fill_rule <p>
- * FILLRULE_ constant
- * </p>
- * @return bool No value is returned.
- */
- public function setClipRule ($fill_rule) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the interpretation of clip path units
- * @link https://php.net/manual/en/imagickdraw.setclipunits.php
- * @param int $clip_units <p>
- * the number of clip units
- * </p>
- * @return bool No value is returned.
- */
- public function setClipUnits ($clip_units) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the opacity to use when drawing using the fill color or fill texture
- * @link https://php.net/manual/en/imagickdraw.setfillopacity.php
- * @param float $fillOpacity <p>
- * the fill opacity
- * </p>
- * @return bool No value is returned.
- */
- public function setFillOpacity ($fillOpacity) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the URL to use as a fill pattern for filling objects
- * @link https://php.net/manual/en/imagickdraw.setfillpatternurl.php
- * @param string $fill_url <p>
- * URL to use to obtain fill pattern.
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
- public function setFillPatternURL ($fill_url) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the fill rule to use while drawing polygons
- * @link https://php.net/manual/en/imagickdraw.setfillrule.php
- * @param int $fill_rule <p>
- * FILLRULE_ constant
- * </p>
- * @return bool No value is returned.
- */
- public function setFillRule ($fill_rule) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the text placement gravity
- * @link https://php.net/manual/en/imagickdraw.setgravity.php
- * @param int $gravity <p>
- * GRAVITY_ constant
- * </p>
- * @return bool No value is returned.
- */
- public function setGravity ($gravity) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the pattern used for stroking object outlines
- * @link https://php.net/manual/en/imagickdraw.setstrokepatternurl.php
- * @param string $stroke_url <p>
- * stroke URL
- * </p>
- * @return bool imagick.imagickdraw.return.success;
- */
- public function setStrokePatternURL ($stroke_url) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies the offset into the dash pattern to start the dash
- * @link https://php.net/manual/en/imagickdraw.setstrokedashoffset.php
- * @param float $dash_offset <p>
- * dash offset
- * </p>
- * @return bool No value is returned.
- */
- public function setStrokeDashOffset ($dash_offset) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies the shape to be used at the end of open subpaths when they are stroked
- * @link https://php.net/manual/en/imagickdraw.setstrokelinecap.php
- * @param int $linecap <p>
- * LINECAP_ constant
- * </p>
- * @return bool No value is returned.
- */
- public function setStrokeLineCap ($linecap) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies the shape to be used at the corners of paths when they are stroked
- * @link https://php.net/manual/en/imagickdraw.setstrokelinejoin.php
- * @param int $linejoin <p>
- * LINEJOIN_ constant
- * </p>
- * @return bool No value is returned.
- */
- public function setStrokeLineJoin ($linejoin) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies the miter limit
- * @link https://php.net/manual/en/imagickdraw.setstrokemiterlimit.php
- * @param int $miterlimit <p>
- * the miter limit
- * </p>
- * @return bool No value is returned.
- */
- public function setStrokeMiterLimit ($miterlimit) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies the opacity of stroked object outlines
- * @link https://php.net/manual/en/imagickdraw.setstrokeopacity.php
- * @param float $stroke_opacity <p>
- * stroke opacity. 1.0 is fully opaque
- * </p>
- * @return bool No value is returned.
- */
- public function setStrokeOpacity ($stroke_opacity) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the vector graphics
- * @link https://php.net/manual/en/imagickdraw.setvectorgraphics.php
- * @param string $xml <p>
- * xml containing the vector graphics
- * </p>
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
- public function setVectorGraphics ($xml) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Destroys the current ImagickDraw in the stack, and returns to the previously pushed ImagickDraw
- * @link https://php.net/manual/en/imagickdraw.pop.php
- * @return bool <b>TRUE</b> on success and false on failure.
- */
- public function pop () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Clones the current ImagickDraw and pushes it to the stack
- * @link https://php.net/manual/en/imagickdraw.push.php
- * @return bool <b>TRUE</b> on success or <b>FALSE</b> on failure.
- */
- public function push () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Specifies the pattern of dashes and gaps used to stroke paths
- * @link https://php.net/manual/en/imagickdraw.setstrokedasharray.php
- * @param array $dashArray <p>
- * array of floats
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setStrokeDashArray (array $dashArray) {}
+ public function sketchImage(float $radius, float $sigma, float $angle): bool {}
+ public function shadeImage(bool $gray, float $azimuth, float $elevation): bool {}
+
+ public function getSizeOffset(): int {}
+
+ public function setSizeOffset(int $columns, int $rows, int $offset): bool {}
+
+
+ public function adaptiveBlurImage(
+ float $radius,
+ float $sigma,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+
+ public function contrastStretchImage(
+ float $black_point,
+ float $white_point,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+
+ public function adaptiveSharpenImage(
+ float $radius,
+ float $sigma,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+
+
+ public function randomThresholdImage(
+ float $low,
+ float $high,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function roundCornersImage(
+ float $x_rounding,
+ float $y_rounding,
+ float $stroke_width = 10,
+ float $displace = 5,
+ float $size_correction = -6): bool {}
+
+ /* This alias is due to BWC */
/**
- * Sets the opacity to use when drawing using the fill or stroke color or texture. Fully opaque is 1.0.
+ * @deprecated
+ * @alias Imagick::roundCornersImage
+ */
+ public function roundCorners(
+ float $x_rounding,
+ float $y_rounding,
+ float $stroke_width = 10,
+ float $displace = 5,
+ float $size_correction = -6): bool {}
+
+#endif
+
+ public function setIteratorIndex(int $index): bool {}
+
+ public function getIteratorIndex(): int {}
+
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function transformImage(string $crop, string $geometry): Imagick {}
+#endif
+#endif
+
+#if MagickLibVersion > 0x630
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function setImageOpacity(float $opacity): bool {}
+#endif
+
+#if MagickLibVersion >= 0x700
+ public function setImageAlpha(float $alpha): bool {}
+#endif
+
+#if MagickLibVersion < 0x700
+
+ /** @deprecated */
+ public function orderedPosterizeImage(
+ string $threshold_map,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+#endif
+#endif
+
+#if MagickLibVersion > 0x631
+ // TODO - ImagickDraw ....
+ public function polaroidImage(ImagickDraw $settings, float $angle): bool {}
+
+ public function getImageProperty(string $name): string {}
+
+ public function setImageProperty(string $name, string $value): bool {}
+
+ public function deleteImageProperty(string $name): bool {}
+
+ // Replaces any embedded formatting characters with the appropriate
+ // image property and returns the interpreted text.
+ // See http://www.imagemagick.org/script/escape.php for escape sequences.
+ // -format "%m:%f %wx%h"
+ public function identifyFormat(string $format): string {}
+
+
+#if IM_HAVE_IMAGICK_SETIMAGEINTERPOLATEMETHOD
+ // INTERPOLATE_*
+ public function setImageInterpolateMethod(int $method): bool {}
+#endif
+
+ // why does this not need to be inside the 'if' for IM_HAVE_IMAGICK_SETIMAGEINTERPOLATEMETHOD ..?
+ public function getImageInterpolateMethod(): int {}
+
+ public function linearStretchImage(float $black_point, float $white_point): bool {}
+
+ public function getImageLength(): int {}
+
+ public function extentImage(int $width, int $height, int $x, int $y): bool {}
+#endif
+#if MagickLibVersion > 0x633
+ public function getImageOrientation(): int {}
+
+ public function setImageOrientation(int $orientation): bool {}
+#endif
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion > 0x634
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function paintFloodfillImage(
+ ImagickPixel|string $fill_color,
+ float $fuzz,
+ ImagickPixel|string $border_color,
+ int $x,
+ int $y,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+#endif
+#endif
+#endif
+
+#if MagickLibVersion > 0x635
+
+ // TODO - Imagick
+ public function clutImage(Imagick $lookup_table, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function getImageProperties(string $pattern = "*", bool $include_values = true): array {}
+
+ public function getImageProfiles(string $pattern = "*", bool $include_values = true): array {}
+
+ // DISTORTION_*
+ public function distortImage(int $distortion, array $arguments, bool $bestfit): bool {}
+
+ public function writeImageFile(resource $filehandle, ?string $format = null): bool {}
+
+ public function writeImagesFile(resource $filehandle, ?string $format = null): bool {}
+
+ public function resetImagePage(string $page): bool {}
+
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function setImageClipMask(imagick $clip_mask): bool {}
+
+ /** @deprecated */
+ public function getImageClipMask(): Imagick {}
+#endif
+
+ // TODO - x server?
+ public function animateImages(string $x_server): bool {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function recolorImage(array $matrix): bool {}
+#endif
+#endif
+#endif
+
+#if MagickLibVersion > 0x636
+ public function setFont(string $font): bool {}
+
+ public function getFont(): string {}
+
+ public function setPointSize(float $point_size): bool {}
+
+ public function getPointSize(): float {}
+
+ // LAYERMETHOD_*
+ public function mergeImageLayers(int $layermethod): Imagick {}
+#endif
+
+#if MagickLibVersion > 0x637
+ // ALPHACHANNEL_*
+ public function setImageAlphaChannel(int $alphachannel): bool {}
+
+ // TODO - ImagickPixel ugh
+// TODO - ugh MagickBooleanType MagickFloodfillPaintImage(MagickWand *wand,
+// const PixelWand *fill,const double fuzz,const PixelWand *bordercolor,
+// const ssize_t x,const ssize_t y,const MagickBooleanType invert)
+
+ public function floodfillPaintImage(
+ ImagickPixel|string $fill_color,
+ float $fuzz,
+ ImagickPixel|string $border_color,
+ int $x,
+ int $y,
+ bool $invert,
+ ?int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool{}
+
+
+
+ public function opaquePaintImage(
+ ImagickPixel|string $target_color,
+ ImagickPixel|string $fill_color,
+ float $fuzz,
+ bool $invert,
+ int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function transparentPaintImage(
+ ImagickPixel|string $target_color,
+ float $alpha,
+ float $fuzz,
+ bool $invert
+ ): bool {}
+#endif
+#if MagickLibVersion > 0x638
+ public function liquidRescaleImage(int $width, int $height, float $delta_x, float $rigidity): bool {}
+
+ public function encipherImage(string $passphrase): bool {}
+
+// PHP_ME(imagick, decipherimage, imagick_decipherimage_args, ZEND_ACC_PUBLIC)
+ public function decipherImage(string $passphrase): bool {}
+#endif
+
+#if MagickLibVersion > 0x639
+
+ // GRAVITY_*
+ public function setGravity(int $gravity): bool {}
+
+ public function getGravity(): int {}
+
+ // CHANNEL_
+ public function getImageChannelRange(int $channel): array {}
+
+ public function getImageAlphaChannel(): int {}
+#endif
+
+#if MagickLibVersion > 0x642
+ public function getImageChannelDistortions(
+ Imagick $reference_image,
+ int $metric,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): float {}
+#endif
+
+#if MagickLibVersion > 0x643
+ // GRAVITY_
+ public function setImageGravity(int $gravity): bool {}
+
+ public function getImageGravity(): int {}
+#endif
+
+#if MagickLibVersion > 0x645
+ /**
+ * @param int $x
+ * @param int $y
+ * @param int $width
+ * @param int $height
+ * @param string $map
+ * @param int $pixelstorage // PIXELSTORAGE
+ * @param array $pixels
+ * @return bool
+ */
+ public function importImagePixels(
+ int $x,
+ int $y,
+ int $width,
+ int $height,
+ string $map,
+ int $pixelstorage,
+ array $pixels): bool {}
+
+ public function deskewImage(float $threshold): bool {}
+
+ /**
+ * @param int $colorspace // COLORSPACE
+ * @param float $cluster_threshold
+ * @param float $smooth_threshold
+ * @param bool $verbose
+ * @return bool
+ */
+ public function segmentImage(
+ int $colorspace,
+ float $cluster_threshold,
+ float $smooth_threshold,
+ bool $verbose = false
+ ): bool {}
+
+ // SPARSECOLORMETHOD_*
+ public function sparseColorImage(
+ int $sparsecolormethod,
+ array $arguments,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+
+ public function remapImage(Imagick $replacement, int $dither_method): bool {}
+#endif
+
+
+#if PHP_IMAGICK_HAVE_HOUGHLINE
+ public function houghLineImage(int $width, int $height, float $threshold): bool {}
+#endif
+
+#if MagickLibVersion > 0x646
+ /**
+ * @param int $x
+ * @param int $y
+ * @param int $width
+ * @param int $height
+ * @param string $map e.g. "RGB"
+ * @param int $pixelstorage // PIXELSTORAGE
+ * @return array
+ */
+ public function exportImagePixels(
+ int $x,
+ int $y,
+ int $width,
+ int $height,
+ string $map,
+ int $pixelstorage
+ ): array {}
+#endif
+
+#if MagickLibVersion > 0x648
+ public function getImageChannelKurtosis(int $channel = Imagick::CHANNEL_DEFAULT): array {}
+
+ public function functionImage(
+ int $function,
+ array $parameters,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+#endif
+
+#if MagickLibVersion > 0x651
+ // COLORSPACE_*
+ public function transformImageColorspace(int $colorspace): bool {}
+#endif
+
+#if MagickLibVersion > 0x652
+ public function haldClutImage(Imagick $clut, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+#endif
+
+#if MagickLibVersion > 0x655
+ public function autoLevelImage(int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function blueShiftImage(float $factor = 1.5): bool {}
+#endif
+
+#if MagickLibVersion > 0x656
+ /**
+ * @param string $artifact example 'compose:args'
+ * @return string
+ */
+ public function getImageArtifact(string $artifact): string {}
+
+ /**
+ * @param string $artifact example 'compose:args'
+ * @param string $value example "1,0,-0.5,0.5"
+ * @return bool
+ */
+ public function setImageArtifact(string $artifact, string $value): bool {}
+
+ public function deleteImageArtifact(string $artifact): bool {}
+
+ // Will return CHANNEL_*
+ public function getColorspace(): int {}
+
+// PHP_ME(imagick, setcolorspace, imagick_setcolorspace_args, ZEND_ACC_PUBLIC)
+ public function setColorspace(int $colorspace): bool {}
+
+ // CHANNEL_*
+ public function clampImage(int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+#endif
+
+#if MagickLibVersion > 0x667
+ // stack By default, images are stacked left-to-right. Set stack to MagickTrue to stack them top-to-bottom.
+ //offset minimum distance in pixels between images.
+ public function smushImages(bool $stack, int $offset): Imagick {}
+#endif
+
+// PHP_ME(imagick, __construct, imagick_construct_args, ZEND_ACC_PUBLIC|ZEND_ACC_CTOR)
+ // TODO int|float? :spocks_eyebrow.gif:
+ public function __construct(string|array|int|float|null $files = null) {}
+
+ public function __toString(): string {}
+
+#if PHP_VERSION_ID >= 50600
+ // This calls MagickGetNumberImages underneath
+ // mode is unused. Remove at next major release
+ // https://github.com/Imagick/imagick/commit/13302500c0ab0ce58e6502e68871187180f7987c
+ public function count(int $mode = 0): int {}
+#else
+ public function count(): int {}
+#endif
+
+ public function getPixelIterator(): ImagickPixelIterator {}
+
+ public function getPixelRegionIterator(int $x, int $y, int $columns, int $rows): ImagickPixelIterator {}
+
+ public function readImage(string $filename): bool {}
+
+ public function readImages(array $filenames): bool {}
+
+ public function readImageBlob(string $image, ?string $filename = null): bool {}
+
+ public function setImageFormat(string $format): bool {}
+
+ public function scaleImage(int $columns, int $rows, bool $bestfit = false, bool $legacy = false): bool {}
+
+ public function writeImage(?string $filename = null): bool {}
+
+ public function writeImages(string $filename, bool $adjoin): bool {}
+
+ // CHANNEL_
+ public function blurImage(float $radius, float $sigma, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function thumbnailImage(
+ ?int $columns,
+ ?int $rows,
+ bool $bestfit = false,
+ bool $fill = false,
+ bool $legacy = false): bool {}
+
+ public function cropThumbnailImage(int $width, int $height, bool $legacy = false): bool {}
+
+ public function getImageFilename(): string {}
+
+ public function setImageFilename(string $filename): bool {}
+
+ public function getImageFormat(): string {}
+
+ public function getImageMimeType(): string {}
+
+ public function removeImage(): bool {}
+
+ /** @alias Imagick::clear */
+ public function destroy(): bool {}
+
+ public function clear(): bool {}
+
+ public function clone(): Imagick {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function getImageSize(): int {}
+#endif
+#endif
+
+ public function getImageBlob(): string {}
+
+ public function getImagesBlob(): string {}
+
+ public function setFirstIterator(): bool {}
+
+ public function setLastIterator(): bool {}
+
+ public function resetIterator(): void {}
+
+ public function previousImage(): bool {}
+
+ public function nextImage(): bool {}
+
+ public function hasPreviousImage(): bool {}
+
+ public function hasNextImage(): bool {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function setImageIndex(int $index): bool {}
+
+ /** @deprecated */
+ public function getImageIndex(): int {}
+#endif
+#endif
+
+ public function commentImage(string $comment): bool {}
+
+ public function cropImage(int $width, int $height, int $x, int $y): bool {}
+
+ public function labelImage(string $label): bool {}
+
+ public function getImageGeometry(): array {}
+
+ public function drawImage(ImagickDraw $drawing): bool {}
+
+ public function setImageCompressionQuality(int $quality): bool {}
+
+ public function getImageCompressionQuality(): int {}
+
+ public function setImageCompression(int $compression): bool {}
+
+ public function getImageCompression(): int {}
+
+ public function annotateImage(
+ ImagickDraw $settings,
+ float $x,
+ float $y,
+ float $angle,
+ string $text
+ ): bool {}
+
+ public function compositeImage(
+ Imagick $composite_image,
+ int $composite,
+ int $x,
+ int $y,
+ int $channel = Imagick::CHANNEL_DEFAULT): bool{}
+
+ public function modulateImage(float $brightness, float $saturation, float $hue): bool {}
+
+ public function getImageColors(): int {}
+
+
+
+ /**
+ * @param ImagickDraw $settings
+ * @param string $tile_geometry e.g. "3x2+0+0"
+ * @param string $thumbnail_geometry e.g. "200x160+3+3>"
+ * @param int $monatgemode // MONTAGEMODE_
+ * @param string $frame // "10x10+2+2"
+ * @return Imagick
+ */
+ public function montageImage(
+ ImagickDraw $settings,
+ string $tile_geometry,
+ string $thumbnail_geometry,
+ int $monatgemode,
+ string $frame
+ ): Imagick {}
+
+ public function identifyImage(bool $append_raw_output = false): array {}
+
+ public function thresholdImage(float $threshold, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function adaptiveThresholdImage(int $width, int $height, int $offset): bool {}
+
+ public function blackThresholdImage(ImagickPixel|string $threshold_color): bool {}
+
+ public function whiteThresholdImage(ImagickPixel|string $threshold_color): bool {}
+
+ public function appendImages(bool $stack): Imagick {}
+
+ public function charcoalImage(float $radius, float $sigma): bool {}
+
+ public function normalizeImage(int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function oilPaintImage(float $radius): bool {}
+
+ public function posterizeImage(int $levels, bool $dither): bool {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function radialBlurImage(float $angle, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+#endif
+#endif
+
+ public function raiseImage(int $width, int $height, int $x, int $y, bool $raise): bool {}
+
+ public function resampleImage(float $x_resolution, float $y_resolution, int $filter, float $blur): bool {}
+
+ public function resizeImage(
+ int $columns,
+ int $rows,
+ int $filter,
+ float $blur,
+ bool $bestfit = false,
+ bool $legacy = false): bool {}
+
+ public function rollImage(int $x, int $y): bool {}
+
+ public function rotateImage(ImagickPixel|string $background_color, float $degrees): bool {}
+
+ public function sampleImage(int $columns, int $rows): bool {}
+
+ public function solarizeImage(int $threshold): bool {}
+
+ public function shadowImage(float $opacity, float $sigma, int $x, int $y): bool {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function setImageAttribute(string $key, string $value): bool {}
+#endif
+#endif
+
+ public function setImageBackgroundColor(ImagickPixel|string $background_color): bool {}
+
+#if MagickLibVersion >= 0x700
+ public function setImageChannelMask(int $channel): int {}
+#endif
+
+ public function setImageCompose(int $compose): bool {}
+
+ public function setImageDelay(int $delay): bool {}
+
+ public function setImageDepth(int $depth): bool {}
+
+ public function setImageGamma(float $gamma): bool {}
+
+ public function setImageIterations(int $iterations): bool {}
+
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function setImageMatteColor(ImagickPixel|string $matte_color): bool {}
+#endif
+
+ public function setImagePage(int $width, int $height, int $x, int $y): bool {}
+
+ // TODO test this.
+ public function setImageProgressMonitor(string $filename): bool {}
+
+#if MagickLibVersion > 0x653
+ public function setProgressMonitor(callable $callback): bool {}
+#endif
+
+ public function setImageResolution(float $x_resolution, float $y_resolution): bool {}
+
+ // I have no idea what scene does.
+ public function setImageScene(int $scene): bool {}
+
+ public function setImageTicksPerSecond(int $ticks_per_second): bool {}
+
+ // IMGTYPE_*
+ public function setImageType(int $image_type): bool {}
+
+ public function setImageUnits(int $units): bool {}
+
+ public function sharpenImage(float $radius, float $sigma, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function shaveImage(int $columns, int $rows): bool {}
+
+ public function shearImage(ImagickPixel|string $background_color, float $x_shear, float $y_shear): bool {}
+
+ public function spliceImage(int $width, int $height, int $x, int $y): bool {}
+
+ public function pingImage(string $filename): bool {}
+
+ public function readImageFile(resource $filehandle, ?string $filename = null): bool {}
+
+ public function displayImage(string $servername): bool {}
+
+ public function displayImages(string $servername): bool {}
+
+ public function spreadImage(float $radius): bool {}
+
+ public function swirlImage(float $degrees): bool {}
+
+ public function stripImage(): bool {}
+
+ public static function queryFormats(string $pattern = "*"): array {}
+
+ public static function queryFonts(string $pattern = "*"): array {}
+
+ /* TODO $multiline == null, means we should autodetect */
+ public function queryFontMetrics(ImagickDraw $settings, string $text, ?bool $multiline = null): array {}
+
+ public function steganoImage(Imagick $watermark, int $offset): Imagick {}
+
+ // NOISE_*
+ public function addNoiseImage(int $noise, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function motionBlurImage(
+ float $radius,
+ float $sigma,
+ float $angle,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ):bool {}
+
+#if MagickLibVersion < 0x700
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+ /** @deprecated */
+ public function mosaicImages(): Imagick {}
+#endif
+#endif
+
+ public function morphImages(int $number_frames): Imagick {}
+
+ public function minifyImage(): bool {}
+
+ public function affineTransformImage(ImagickDraw $settings): bool {}
+
+#if MagickLibVersion < 0x700
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+ /** @deprecated */
+ public function averageImages(): Imagick {}
+#endif
+#endif
+
+ public function borderImage(ImagickPixel|string $border_color, int $width, int $height): bool {}
+
+ public static function calculateCrop(
+ int $original_width,
+ int $original_height,
+ int $desired_width,
+ int $desired_height,
+ bool $legacy = false): array {}
+
+ public function chopImage(int $width, int $height, int $x, int $y): bool {}
+
+ public function clipImage(): bool {}
+
+ public function clipPathImage(string $pathname, bool $inside): bool {}
+
+ /* clippathimage has been deprecated. Create alias here and use the newer API function if present */
+ /** @alias Imagick::clipPathImage */
+ public function clipImagePath(string $pathname, bool $inside): void {}
+
+ public function coalesceImages(): Imagick {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function colorFloodfillImage(
+ ImagickPixel|string $fill_color,
+ float $fuzz,
+ ImagickPixel|string $border_color,
+ int $x,
+ int $y
+ ): bool {}
+#endif
+#endif
+
+ // TODO - opacity is actually float if legacy is true...
+ public function colorizeImage(
+ ImagickPixel|string $colorize_color,
+ ImagickPixel|string|false $opacity_color,
+ ?bool $legacy = false ): bool {}
+
+ public function compareImageChannels(Imagick $reference, int $channel, int $metric): array {}
+
+ public function compareImages(Imagick $reference, int $metric): array {}
+
+ public function contrastImage(bool $sharpen): bool {}
+
+ public function combineImages(int $colorspace): Imagick {}
+
+ // kernel is a 2d array of float values
+ public function convolveImage(array $kernel, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function cycleColormapImage(int $displace): bool {}
+
+ public function deconstructImages(): Imagick {}
+
+ public function despeckleImage(): bool {}
+
+ public function edgeImage(float $radius): bool {}
+
+ public function embossImage(float $radius, float $sigma): bool {}
+
+ public function enhanceImage(): bool {}
+
+ public function equalizeImage(): bool {}
+
+ // EVALUATE_*
+ public function evaluateImage(int $evaluate, float $constant, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+#if MagickLibVersion >= 0x687
+// Merge multiple images of the same size together with the selected operator.
+//http://www.imagemagick.org/Usage/layers/#evaluate-sequence
+
+ // EVALUATE_*
+ public function evaluateImages(int $evaluate): bool {}
+
+#endif
+
+#if MagickLibVersion < 0x700
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+ /** @deprecated */
+ public function flattenImages(): Imagick {}
+#endif
+#endif
+ public function flipImage(): bool {}
+
+ public function flopImage(): bool {}
+
+#if MagickLibVersion >= 0x655
+ public function forwardFourierTransformImage(bool $magnitude): bool {}
+#endif
+
+ public function frameImage(
+ ImagickPixel|string $matte_color,
+ int $width,
+ int $height,
+ int $inner_bevel,
+ int $outer_bevel
+ ): bool {}
+
+
+ public function fxImage(string $expression, int $channel = Imagick::CHANNEL_DEFAULT): Imagick {}
+
+ public function gammaImage(float $gamma, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+ public function gaussianBlurImage(float $radius, float $sigma, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+#if MagickLibVersion < 0x700
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+ /** @deprecated */
+ public function getImageAttribute(string $key): string {}
+#endif
+#endif
+
+ public function getImageBackgroundColor(): ImagickPixel {}
+
+ public function getImageBluePrimary(): array {}
+
+ public function getImageBorderColor(): ImagickPixel {}
+
+ public function getImageChannelDepth(int $channel): int {}
+
+ public function getImageChannelDistortion(Imagick $reference, int $channel, int $metric): float {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function getImageChannelExtrema(int $channel): array {}
+#endif
+#endif
+
+ public function getImageChannelMean(int $channel): array {}
+
+ public function getImageChannelStatistics(): array {}
+
+ // index - the offset into the image colormap. I have no idea.
+ public function getImageColormapColor(int $index): ImagickPixel {}
+
+ public function getImageColorspace(): int {}
+
+ public function getImageCompose(): int {}
+
+ public function getImageDelay(): int {}
+
+ public function getImageDepth(): int {}
+
+ // METRIC_
+ public function getImageDistortion(Imagick $reference, int $metric): float {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function getImageExtrema(): array {}
+#endif
+#endif
+
+ public function getImageDispose(): int {}
+
+ public function getImageGamma(): float {}
+
+ public function getImageGreenPrimary(): array {}
+
+ public function getImageHeight(): int {}
+
+ public function getImageHistogram(): array {}
+
+ public function getImageInterlaceScheme(): int {}
+
+ public function getImageIterations(): int {}
+
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function getImageMatteColor(): ImagickPixel {}
+#endif
+
+ public function getImagePage(): array {}
+
+ public function getImagePixelColor(int $x, int $y): ImagickPixel {}
+
+
+#if IM_HAVE_IMAGICK_SETIMAGEPIXELCOLOR
+ // TODO - needs a test.
+ public function setImagePixelColor(int $x, int $y, ImagickPixel|string $color): ImagickPixel {}
+#endif
+
+ public function getImageProfile(string $name): string {}
+
+ public function getImageRedPrimary(): array {}
+
+ public function getImageRenderingIntent(): int {}
+
+ public function getImageResolution(): array {}
+
+ public function getImageScene(): int {}
+
+ public function getImageSignature(): string {}
+
+ public function getImageTicksPerSecond(): int {}
+
+ public function getImageType(): int {}
+
+ public function getImageUnits(): int {}
+
+ public function getImageVirtualPixelMethod(): int {}
+
+ public function getImageWhitePoint(): array {}
+
+ public function getImageWidth(): int {}
+
+ public function getNumberImages(): int {}
+
+ public function getImageTotalInkDensity(): float {}
+
+ public function getImageRegion(int $width, int $height, int $x, int $y): Imagick {}
+
+ public function implodeImage(float $radius): bool {}
+
+#if MagickLibVersion >= 0x658
+ // TODO MagickWand *magnitude_wand,MagickWand *phase_wand,
+ public function inverseFourierTransformImage(Imagick $complement, bool $magnitude): bool {}
+#endif
+
+ public function levelImage(
+ float $black_point,
+ float $gamma,
+ float $white_point,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+
+ public function magnifyImage(): bool {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function mapImage(imagick $map, bool $dither): bool {}
+
+ /** @deprecated */
+ public function matteFloodfillImage(
+ float $alpha,
+ float $fuzz,
+ ImagickPixel|string $border_color,
+ int $x,
+ int $y
+ ): bool {}
+#endif
+#endif
+
+#if MagickLibVersion < 0x700
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+ /** @deprecated */
+ public function medianFilterImage(float $radius): bool {}
+#endif
+#endif
+
+ public function negateImage(bool $gray, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function paintOpaqueImage(
+ ImagickPixel|string $target_color,
+ ImagickPixel|string $fill_color,
+ float $fuzz,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+
+ /** @deprecated */
+ public function paintTransparentImage(ImagickPixel|string $target_color, float $alpha, float $fuzz): bool {}
+#endif
+#endif
+
+ // PREVIEW_*
+ public function previewImages(int $preview): bool {}
+
+ public function profileImage(string $name, string $profile): bool {}
+
+ public function quantizeImage(
+ int $number_colors,
+ int $colorspace,
+ int $tree_depth,
+ bool $dither,
+ bool $measure_error
+ ): bool {}
+
+
+ public function quantizeImages(
+ int $number_colors,
+ int $colorspace,
+ int $tree_depth,
+ bool $dither,
+ bool $measure_error): bool {}
+
+#if !defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function reduceNoiseImage(float $radius): bool {}
+#endif
+#endif
+
+ public function removeImageProfile(string $name): string {}
+
+ public function separateImageChannel(int $channel): bool {}
+
+ public function sepiaToneImage(float $threshold): bool {}
+
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function setImageBias(float $bias): bool {}
+
+ /** @deprecated */
+ public function setImageBiasQuantum(string $bias): void {}
+#endif
+
+ public function setImageBluePrimary(float $x, float $y): bool {}
+ /* {{{ proto bool Imagick::setImageBluePrimary(float x,float y)
+For IM7 the prototype is
+proto bool Imagick::setImageBluePrimary(float x, float y, float z) */
+
+ public function setImageBorderColor(ImagickPixel|string $border_color): bool {}
+
+ public function setImageChannelDepth(int $channel, int $depth): bool {}
+
+ public function setImageColormapColor(int $index, ImagickPixel|string $color): bool {}
+
+ public function setImageColorspace(int $colorspace): bool {}
+
+ public function setImageDispose(int $dispose): bool {}
+
+ public function setImageExtent(int $columns, int $rows): bool {}
+
+ public function setImageGreenPrimary(float $x, float $y): bool {}
+
+ // INTERLACE_*
+ public function setImageInterlaceScheme(int $interlace): bool {}
+
+ public function setImageProfile(string $name, string $profile): bool {}
+
+ public function setImageRedPrimary(float $x, float $y): bool {}
+
+ // RENDERINGINTENT
+ public function setImageRenderingIntent(int $rendering_intent): bool {}
+
+ public function setImageVirtualPixelMethod(int $method): bool {}
+
+ public function setImageWhitePoint(float $x, float $y): bool {}
+
+ public function sigmoidalContrastImage(
+ bool $sharpen,
+ float $alpha,
+ float $beta,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool{}
+
+ // TODO - MagickStereoImage() composites two images and produces a single
+ // image that is the composite of a left and right image of a stereo pair
+ public function stereoImage(Imagick $offset_image): bool {}
+
+ public function textureImage(Imagick $texture): Imagick {}
+
+ public function tintImage(
+ ImagickPixel|string $tint_color,
+ ImagickPixel|string $opacity_color,
+ bool $legacy = false
+ ): bool {}
+
+ public function unsharpMaskImage(
+ float $radius,
+ float $sigma,
+ float $amount,
+ float $threshold,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+
+ public function getImage(): Imagick {}
+
+ public function addImage(Imagick $image): bool {}
+
+ public function setImage(Imagick $image): bool {}
+
+
+ public function newImage(
+ int $columns,
+ int $rows,
+ ImagickPixel|string $background_color,
+ string $format = null
+ ): bool {}
+
+ // TODO - canvas? description
+ public function newPseudoImage(int $columns, int $rows, string $pseudo_format): bool {}
+
+ public function getCompression(): int {}
+
+ public function getCompressionQuality(): int {}
+
+ public static function getCopyright(): string {}
+
+ public static function getConfigureOptions(string $pattern = "*"): string {}
+
+
+#if MagickLibVersion > 0x660
+ public static function getFeatures(): string {}
+#endif
+
+ public function getFilename(): string {}
+
+ public function getFormat(): string {}
+
+ public static function getHomeURL(): string {}
+
+ public function getInterlaceScheme(): int {}
+
+ public function getOption(string $key): string {}
+
+ public static function getPackageName(): string {}
+
+ public function getPage(): array {}
+
+ public static function getQuantum(): int {}
+
+ public static function getHdriEnabled(): bool {}
+
+ public static function getQuantumDepth(): array {}
+
+ public static function getQuantumRange(): array {}
+
+ public static function getReleaseDate(): string {}
+
+ public static function getResource(int $type): int {}
+
+ public static function getResourceLimit(int $type): int {}
+
+ public function getSamplingFactors(): array {}
+
+ public function getSize(): array {}
+
+ public static function getVersion(): array {}
+
+ public function setBackgroundColor(ImagickPixel|string $background_color): bool {}
+
+ public function setCompression(int $compression): bool {}
+
+ public function setCompressionQuality(int $quality): bool {}
+
+ public function setFilename(string $filename): bool {}
+
+ public function setFormat(string $format): bool {}
+
+ // INTERLACE_*
+ public function setInterlaceScheme(int $interlace): bool {}
+
+ public function setOption(string $key, string $value): bool {}
+
+ public function setPage(int $width, int $height, int $x, int $y): bool {}
+
+ public static function setResourceLimit(int $type, int $limit): bool {}
+
+ public function setResolution(float $x_resolution, float $y_resolution): bool {}
+
+ public function setSamplingFactors(array $factors): bool {}
+
+ public function setSize(int $columns, int $rows): bool {}
+
+ // IMGTYPE_*
+ public function setType(int $imgtype): bool {}
+
+#if MagickLibVersion > 0x628
+ /** @alias Imagick::getIteratorIndex */
+ public function key(): int {}
+
+//#else
+//# if defined(MAGICKCORE_EXCLUDE_DEPRECATED)
+//# error "MAGICKCORE_EXCLUDE_DEPRECATED should not be defined with ImageMagick version below 6.2.8"
+//# else
+//// PHP_MALIAS(imagick, key, getimageindex, imagick_zero_args, ZEND_ACC_PUBLIC)
+// /** @alias Imagick::getImageIndex */
+// public function key(): int {}
+//
+//# endif
+//#endif
+
+ /** @alias Imagick::nextImage
+ * @tentative-return-type
+ */
+ public function next(): void {}
+
+ /** @alias Imagick::setFirstIterator
+ * @tentative-return-type
+ */
+ public function rewind(): void {}
+
+ public function valid(): bool {}
+
+ public function current(): Imagick {}
+
+#if MagickLibVersion >= 0x659
+ public function brightnessContrastImage(
+ float $brightness,
+ float $contrast,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+#endif
+
+#if MagickLibVersion > 0x661
+ public function colorMatrixImage(array $color_matrix): bool {}
+#endif
+
+ public function selectiveBlurImage(
+ float $radius,
+ float $sigma,
+ float $threshold,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+
+#if MagickLibVersion >= 0x689
+ public function rotationalBlurImage(float $angle, int $channel = Imagick::CHANNEL_DEFAULT): bool {}
+#endif
+
+#if MagickLibVersion >= 0x683
+ public function statisticImage(
+ int $type,
+ int $width,
+ int $height,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+#endif
+
+#if MagickLibVersion >= 0x652
+ public function subimageMatch(Imagick $image, ?array &$offset = null, ?float &$similarity = null, float $threshold = 0.0, int $metric = 0): Imagick {}
+
+ /** @alias Imagick::subimageMatch */
+ public function similarityimage(Imagick $image, ?array &$offset = null, ?float &$similarity = null, float $threshold = 0.0, int $metric = 0): Imagick {}
+#endif
+
+ public static function setRegistry(string $key, string $value): bool {}
+
+ public static function getRegistry(string $key): string {}
+
+ public static function listRegistry(): array {}
+
+#if MagickLibVersion >= 0x680
+
+ /**
+ * @param int $morphology MORPHOLOGY_*
+ * @param int $iterations
+ * @param ImagickKernel $kernel
+ * @param int $channel
+ * @return bool
+ */
+ public function morphology(
+ int $morphology,
+ int $iterations,
+ ImagickKernel $kernel,
+ int $channel = Imagick::CHANNEL_DEFAULT
+ ): bool {}
+#endif
+
+#ifdef IMAGICK_WITH_KERNEL
+#if MagickLibVersion < 0x700
+ /** @deprecated */
+ public function filter(ImagickKernel $kernel, int $channel = Imagick::CHANNEL_UNDEFINED): bool {}
+#endif
+#endif
+
+ public function setAntialias(bool $antialias): void {}
+
+ public function getAntialias(): bool {}
+
+#if MagickLibVersion > 0x676
+ /**
+ * @param string $color_correction_collection
+ * <ColorCorrectionCollection xmlns="urn:ASC:CDL:v1.2">
+ * <ColorCorrection id="cc03345">
+ * <SOPNode>
+ * <Slope> 0.9 1.2 0.5 </Slope>
+ * <Offset> 0.4 -0.5 0.6 </Offset>
+ * <Power> 1.0 0.8 1.5 </Power>
+ * </SOPNode>
+ * <SATNode>
+ * <Saturation> 0.85 </Saturation>
+ * </SATNode>
+ * </ColorCorrection>
+ * </ColorCorrectionCollection>
*
- * @param float $opacity
- * @return void
- * @since 3.4.1
+ * @return bool
*/
- public function setOpacity($opacity) { }
-
- /**
- * Returns the opacity used when drawing with the fill or stroke color or texture. Fully opaque is 1.0.
- *
- * @return float
- * @since 3.4.1
- */
- public function getOpacity() { }
-
- /**
- * Sets the image font resolution.
- *
- * @param float $x
- * @param float $y
- * @return bool
- * @since 3.4.1
- */
- public function setFontResolution($x, $y) { }
-
- /**
- * Gets the image X and Y resolution.
- *
- * @return array
- * @since 3.4.1
- */
- public function getFontResolution() { }
-
- /**
- * Returns the direction that will be used when annotating with text.
- * @return bool
- * @since 3.4.1
- */
- public function getTextDirection() { }
-
- /**
- * Sets the font style to use when annotating with text. The AnyStyle enumeration acts as a wild-card "don't care" option.
- *
- * @param int $direction
- * @return bool
- * @since 3.4.1
- */
- public function setTextDirection($direction) { }
-
- /**
- * Returns the border color used for drawing bordered objects.
- *
- * @return ImagickPixel
- * @since 3.4.1
- */
- public function getBorderColor() { }
-
- /**
- * Sets the border color to be used for drawing bordered objects.
- * @param ImagickPixel $color
- * @return bool
- * @since 3.4.1
- */
- public function setBorderColor(ImagickPixel $color) { }
-
- /**
- * Obtains the vertical and horizontal resolution.
- *
- * @return string|null
- * @since 3.4.1
- */
- public function getDensity() { }
-
- /**
- * Sets the vertical and horizontal resolution.
- * @param string $density_string
- * @return bool
- * @since 3.4.1
- */
- public function setDensity($density_string) { }
-}
+ public function colorDecisionListImage(string $color_correction_collection): bool {}
+#endif
-/**
- * @link https://php.net/manual/en/class.imagickpixeliterator.php
- */
-class ImagickPixelIterator implements Iterator {
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * The ImagickPixelIterator constructor
- * @link https://php.net/manual/en/imagickpixeliterator.construct.php
- * @param Imagick $wand
- */
- public function __construct (Imagick $wand) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns a new pixel iterator
- * @link https://php.net/manual/en/imagickpixeliterator.newpixeliterator.php
- * @param Imagick $wand
- * @return bool <b>TRUE</b> on success. Throwing ImagickPixelIteratorException.
- * @throws ImagickPixelIteratorException
- */
- public function newPixelIterator (Imagick $wand) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns a new pixel iterator
- * @link https://php.net/manual/en/imagickpixeliterator.newpixelregioniterator.php
- * @param Imagick $wand
- * @param int $x
- * @param int $y
- * @param int $columns
- * @param int $rows
- * @return bool a new ImagickPixelIterator on success; on failure, throws ImagickPixelIteratorException
- * @throws ImagickPixelIteratorException
- */
- public function newPixelRegionIterator (Imagick $wand, $x, $y, $columns, $rows) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the current pixel iterator row
- * @link https://php.net/manual/en/imagickpixeliterator.getiteratorrow.php
- * @return int the integer offset of the row, throwing ImagickPixelIteratorException on error.
- * @throws ImagickPixelIteratorException on error
- */
- public function getIteratorRow () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Set the pixel iterator row
- * @link https://php.net/manual/en/imagickpixeliterator.setiteratorrow.php
- * @param int $row
- * @return bool <b>TRUE</b> on success.
- */
- public function setIteratorRow ($row) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the pixel iterator to the first pixel row
- * @link https://php.net/manual/en/imagickpixeliterator.setiteratorfirstrow.php
- * @return bool <b>TRUE</b> on success.
- */
- public function setIteratorFirstRow () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the pixel iterator to the last pixel row
- * @link https://php.net/manual/en/imagickpixeliterator.setiteratorlastrow.php
- * @return bool <b>TRUE</b> on success.
- */
- public function setIteratorLastRow () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the previous row
- * @link https://php.net/manual/en/imagickpixeliterator.getpreviousiteratorrow.php
- * @return array the previous row as an array of ImagickPixelWand objects from the
- * ImagickPixelIterator, throwing ImagickPixelIteratorException on error.
- * @throws ImagickPixelIteratorException on error
- */
- public function getPreviousIteratorRow () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the current row of ImagickPixel objects
- * @link https://php.net/manual/en/imagickpixeliterator.getcurrentiteratorrow.php
- * @return array a row as an array of ImagickPixel objects that can themselves be iterated.
- */
- public function getCurrentIteratorRow () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the next row of the pixel iterator
- * @link https://php.net/manual/en/imagickpixeliterator.getnextiteratorrow.php
- * @return array the next row as an array of ImagickPixel objects, throwing
- * ImagickPixelIteratorException on error.
- * @throws ImagickPixelIteratorException on error
- */
- public function getNextIteratorRow () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Resets the pixel iterator
- * @link https://php.net/manual/en/imagickpixeliterator.resetiterator.php
- * @return bool <b>TRUE</b> on success.
- */
- public function resetIterator () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Syncs the pixel iterator
- * @link https://php.net/manual/en/imagickpixeliterator.synciterator.php
- * @return bool <b>TRUE</b> on success.
- */
- public function syncIterator () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Deallocates resources associated with a PixelIterator
- * @link https://php.net/manual/en/imagickpixeliterator.destroy.php
- * @return bool <b>TRUE</b> on success.
- */
- public function destroy () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Clear resources associated with a PixelIterator
- * @link https://php.net/manual/en/imagickpixeliterator.clear.php
- * @return bool <b>TRUE</b> on success.
- */
- public function clear () {}
-
- /**
- * @param Imagick $Imagick
- */
- public static function getpixeliterator (Imagick $Imagick) {}
-
- /**
- * @param Imagick $Imagick
- * @param $x
- * @param $y
- * @param $columns
- * @param $rows
- */
- public static function getpixelregioniterator (Imagick $Imagick, $x, $y, $columns, $rows) {}
-
- public function key () {}
-
- public function next () {}
-
- public function rewind () {}
-
- public function current () {}
-
- public function valid () {}
+#if MagickLibVersion >= 0x687
+ public function optimizeImageTransparency(): void {}
+#endif
-}
+#if MagickLibVersion >= 0x660
+ public function autoGammaImage(?int $channel = Imagick::CHANNEL_ALL): void {}
+#endif
-/**
- * @method clone()
- * @link https://php.net/manual/en/class.imagickpixel.php
- */
-class ImagickPixel {
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the normalized HSL color of the ImagickPixel object
- * @link https://php.net/manual/en/imagickpixel.gethsl.php
- * @return array the HSL value in an array with the keys "hue",
- * "saturation", and "luminosity". Throws ImagickPixelException on failure.
- * @throws ImagickPixelException on failure
- */
- public function getHSL () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the normalized HSL color
- * @link https://php.net/manual/en/imagickpixel.sethsl.php
- * @param float $hue <p>
- * The normalized value for hue, described as a fractional arc
- * (between 0 and 1) of the hue circle, where the zero value is
- * red.
- * </p>
- * @param float $saturation <p>
- * The normalized value for saturation, with 1 as full saturation.
- * </p>
- * @param float $luminosity <p>
- * The normalized value for luminosity, on a scale from black at
- * 0 to white at 1, with the full HS value at 0.5 luminosity.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setHSL ($hue, $saturation, $luminosity) {}
-
- public function getColorValueQuantum () {}
-
- /**
- * @param $color_value
- */
- public function setColorValueQuantum ($color_value) {}
-
- public function getIndex () {}
-
- /**
- * @param $index
- */
- public function setIndex ($index) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * The ImagickPixel constructor
- * @link https://php.net/manual/en/imagickpixel.construct.php
- * @param string $color [optional] <p>
- * The optional color string to use as the initial value of this object.
- * </p>
- */
- public function __construct ($color = null) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the color
- * @link https://php.net/manual/en/imagickpixel.setcolor.php
- * @param string $color <p>
- * The color definition to use in order to initialise the
- * ImagickPixel object.
- * </p>
- * @return bool <b>TRUE</b> if the specified color was set, <b>FALSE</b> otherwise.
- */
- public function setColor ($color) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Sets the normalized value of one of the channels
- * @link https://php.net/manual/en/imagickpixel.setcolorvalue.php
- * @param int $color <p>
- * One of the Imagick color constants e.g. \Imagick::COLOR_GREEN or \Imagick::COLOR_ALPHA.
- * </p>
- * @param float $value <p>
- * The value to set this channel to, ranging from 0 to 1.
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function setColorValue ($color, $value) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Gets the normalized value of the provided color channel
- * @link https://php.net/manual/en/imagickpixel.getcolorvalue.php
- * @param int $color <p>
- * The color to get the value of, specified as one of the Imagick color
- * constants. This can be one of the RGB colors, CMYK colors, alpha and
- * opacity e.g (Imagick::COLOR_BLUE, Imagick::COLOR_MAGENTA).
- * </p>
- * @return float The value of the channel, as a normalized floating-point number, throwing
- * ImagickPixelException on error.
- * @throws ImagickPixelException on error
- */
- public function getColorValue ($color) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Clears resources associated with this object
- * @link https://php.net/manual/en/imagickpixel.clear.php
- * @return bool <b>TRUE</b> on success.
- */
- public function clear () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Deallocates resources associated with this object
- * @link https://php.net/manual/en/imagickpixel.destroy.php
- * @return bool <b>TRUE</b> on success.
- */
- public function destroy () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Check the distance between this color and another
- * @link https://php.net/manual/en/imagickpixel.issimilar.php
- * @param ImagickPixel $color <p>
- * The ImagickPixel object to compare this object against.
- * </p>
- * @param float $fuzz <p>
- * The maximum distance within which to consider these colors as similar.
- * The theoretical maximum for this value is the square root of three
- * (1.732).
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function isSimilar (ImagickPixel $color, $fuzz) {}
-
- /**
- * (No version information available, might only be in SVN)<br/>
- * Check the distance between this color and another
- * @link https://php.net/manual/en/imagickpixel.ispixelsimilar.php
- * @param ImagickPixel $color <p>
- * The ImagickPixel object to compare this object against.
- * </p>
- * @param float $fuzz <p>
- * The maximum distance within which to consider these colors as similar.
- * The theoretical maximum for this value is the square root of three
- * (1.732).
- * </p>
- * @return bool <b>TRUE</b> on success.
- */
- public function isPixelSimilar (ImagickPixel $color, $fuzz) {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the color
- * @link https://php.net/manual/en/imagickpixel.getcolor.php
- * @param bool $normalized [optional] <p>
- * Normalize the color values
- * </p>
- * @return array An array of channel values, each normalized if <b>TRUE</b> is given as param. Throws
- * ImagickPixelException on error.
- * @throws ImagickPixelException on error.
- */
- public function getColor ($normalized = false) {}
-
- /**
- * (PECL imagick 2.1.0)<br/>
- * Returns the color as a string
- * @link https://php.net/manual/en/imagickpixel.getcolorasstring.php
- * @return string the color of the ImagickPixel object as a string.
- */
- public function getColorAsString () {}
-
- /**
- * (PECL imagick 2.0.0)<br/>
- * Returns the color count associated with this color
- * @link https://php.net/manual/en/imagickpixel.getcolorcount.php
- * @return int the color count as an integer on success, throws
- * ImagickPixelException on failure.
- * @throws ImagickPixelException on failure.
- */
- public function getColorCount () {}
-
- /**
- * @param $colorCount
- */
- public function setColorCount ($colorCount) {}
-
-
- /**
- * Returns true if the distance between two colors is less than the specified distance. The fuzz value should be in the range 0-QuantumRange.<br>
- * The maximum value represents the longest possible distance in the colorspace. e.g. from RGB(0, 0, 0) to RGB(255, 255, 255) for the RGB colorspace
- * @link https://php.net/manual/en/imagickpixel.ispixelsimilarquantum.php
- * @param string $pixel
- * @param string $fuzz
- * @return bool
- * @since 3.3.0
- */
- public function isPixelSimilarQuantum($color, $fuzz) { }
-
- /**
- * Returns the color of the pixel in an array as Quantum values. If ImageMagick was compiled as HDRI these will be floats, otherwise they will be integers.
- * @link https://php.net/manual/en/imagickpixel.getcolorquantum.php
- * @return mixed The quantum value of the color element. Float if ImageMagick was compiled with HDRI, otherwise an int.
- * @since 3.3.0
- */
- public function getColorQuantum() { }
-
- /**
- * Sets the color count associated with this color from another ImagickPixel object.
- *
- * @param ImagickPixel $srcPixel
- * @return bool
- * @since 3.4.1
- */
- public function setColorFromPixel(ImagickPixel $srcPixel) { }
-}
-// End of imagick v.3.2.0RC1
-
-// Start of Imagick v3.3.0RC1
-
-/**
- * @link https://php.net/manual/en/class.imagickkernel.php
- */
-class ImagickKernel {
- /**
- * Attach another kernel to this kernel to allow them to both be applied in a single morphology or filter function. Returns the new combined kernel.
- * @link https://php.net/manual/en/imagickkernel.addkernel.php
- * @param ImagickKernel $imagickKernel
- * @return void
- * @since 3.3.0
- */
- public function addKernel(ImagickKernel $imagickKernel) { }
-
- /**
- * Adds a given amount of the 'Unity' Convolution Kernel to the given pre-scaled and normalized Kernel. This in effect adds that amount of the original image into the resulting convolution kernel. The resulting effect is to convert the defined kernels into blended soft-blurs, unsharp kernels or into sharpening kernels.
- * @link https://php.net/manual/en/imagickkernel.addunitykernel.php
- * @return void
- * @since 3.3.0
- */
- public function addUnityKernel() { }
-
- /**
- * Create a kernel from a builtin in kernel. See https://www.imagemagick.org/Usage/morphology/#kernel for examples.<br>
- * Currently the 'rotation' symbols are not supported. Example: $diamondKernel = ImagickKernel::fromBuiltIn(\Imagick::KERNEL_DIAMOND, "2");
- * @link https://php.net/manual/en/imagickkernel.frombuiltin.php
- * @param string $kernelType The type of kernel to build e.g. \Imagick::KERNEL_DIAMOND
- * @param string $kernelString A string that describes the parameters e.g. "4,2.5"
- * @return void
- * @since 3.3.0
- */
- public static function fromBuiltin($kernelType, $kernelString) { }
-
- /**
- * Create a kernel from a builtin in kernel. See https://www.imagemagick.org/Usage/morphology/#kernel for examples.<br>
- * Currently the 'rotation' symbols are not supported. Example: $diamondKernel = ImagickKernel::fromBuiltIn(\Imagick::KERNEL_DIAMOND, "2");
- * @link https://php.net/manual/en/imagickkernel.frombuiltin.php
- * @see https://www.imagemagick.org/Usage/morphology/#kernel
- * @param array $matrix A matrix (i.e. 2d array) of values that define the kernel. Each element should be either a float value, or FALSE if that element shouldn't be used by the kernel.
- * @param array $origin [optional] Which element of the kernel should be used as the origin pixel. e.g. For a 3x3 matrix specifying the origin as [2, 2] would specify that the bottom right element should be the origin pixel.
- * @return ImagickKernel
- * @since 3.3.0
- */
- public static function fromMatrix($matrix, $origin) { }
-
- /**
- * Get the 2d matrix of values used in this kernel. The elements are either float for elements that are used or 'false' if the element should be skipped.
- * @link https://php.net/manual/en/imagickkernel.getmatrix.php
- * @return array A matrix (2d array) of the values that represent the kernel.
- * @since 3.3.0
- */
- public function getMatrix() { }
-
- /**
- * ScaleKernelInfo() scales the given kernel list by the given amount, with or without normalization of the sum of the kernel values (as per given flags).<br>
- * The exact behaviour of this function depends on the normalization type being used please see https://www.imagemagick.org/api/morphology.php#ScaleKernelInfo for details.<br>
- * Flag should be one of Imagick::NORMALIZE_KERNEL_VALUE, Imagick::NORMALIZE_KERNEL_CORRELATE, Imagick::NORMALIZE_KERNEL_PERCENT or not set.
- * @link https://php.net/manual/en/imagickkernel.scale.php
- * @see https://www.imagemagick.org/api/morphology.php#ScaleKernelInfo
- * @return void
- * @since 3.3.0
- */
- public function scale() { }
-
- /**
- * Separates a linked set of kernels and returns an array of ImagickKernels.
- * @link https://php.net/manual/en/imagickkernel.separate.php
- * @return void
- * @since 3.3.0
- */
- public function seperate() { }
+#if MagickLibVersion >= 0x692
+ public function autoOrient(): void {}
+
+ /** @alias Imagick::autoOrient */
+ public function autoOrientate(): void {}
+
+ // COMPOSITE_*
+ public function compositeImageGravity(Imagick $image, int $composite_constant, int $gravity): bool {}
+
+#endif
+
+#if MagickLibVersion >= 0x693
+ public function localContrastImage(float $radius, float $strength): void {}
+#endif
+
+#if MagickLibVersion >= 0x700
+ // Identifies the potential image type, returns one of the Imagick::IMGTYPE_* constants
+ public function identifyImageType(): int {}
+#endif
+
+
+#if IM_HAVE_IMAGICK_GETSETIMAGEMASK
+ // PIXELMASK_*
+ public function getImageMask(int $pixelmask): ?Imagick {}
+
+ // PIXELMASK_*
+ public function setImageMask(Imagick $clip_mask, int $pixelmask): void {}
+#endif
+
+
+ // TODO - needs deleting from docs.
+// public function getImageMagickLicense(): string {}
+
+ // TODO - needs deleting from docs.
+// public function render(): bool {}
+
+// public function floodfillPaintImage(
+// ImagickPixel|string $fill,
+// float $fuzz,
+// ImagickPixel|string $bordercolor,
+// int $x,
+// int $y,
+// bool $invert,
+// int $channel = Imagick::CHANNEL_DEFAULT): null {}
}
diff --git a/build/stubs/ldap.php b/build/stubs/ldap.php
index b635c8e01bc..faa7edda3dc 100644
--- a/build/stubs/ldap.php
+++ b/build/stubs/ldap.php
@@ -1,5 +1,7 @@
<?php
+/** @generate-class-entries */
+
namespace LDAP {
/**
@@ -25,4 +27,200 @@ namespace LDAP {
final class ResultEntry
{
}
+
+}
+
+namespace {
+
+ #ifdef HAVE_ORALDAP
+ function ldap_connect(?string $uri = null, int $port = 389, string $wallet = UNKNOWN, string $password = UNKNOWN, int $auth_mode = GSLC_SSL_NO_AUTH): LDAP\Connection|false {}
+ #else
+ function ldap_connect(?string $uri = null, int $port = 389): LDAP\Connection|false {}
+ #endif
+
+ function ldap_unbind(LDAP\Connection $ldap): bool {}
+
+ /** @alias ldap_unbind */
+ function ldap_close(LDAP\Connection $ldap): bool {}
+
+ function ldap_bind(LDAP\Connection $ldap, ?string $dn = null, ?string $password = null): bool {}
+
+ function ldap_bind_ext(LDAP\Connection $ldap, ?string $dn = null, ?string $password = null, ?array $controls = null): LDAP\Result|false {}
+
+ #ifdef HAVE_LDAP_SASL
+ function ldap_sasl_bind(LDAP\Connection $ldap, ?string $dn = null, ?string $password = null, ?string $mech = null, ?string $realm = null, ?string $authc_id = null, ?string $authz_id = null, ?string $props = null): bool {}
+ #endif
+
+ /** @param LDAP\Connection|array $ldap */
+ function ldap_read($ldap, array|string $base, array|string $filter, array $attributes = [], int $attributes_only = 0, int $sizelimit = -1, int $timelimit = -1, int $deref = LDAP_DEREF_NEVER, ?array $controls = null): LDAP\Result|array|false {}
+
+ /** @param LDAP\Connection|array $ldap */
+ function ldap_list($ldap, array|string $base, array|string $filter, array $attributes = [], int $attributes_only = 0, int $sizelimit = -1, int $timelimit = -1, int $deref = LDAP_DEREF_NEVER, ?array $controls = null): LDAP\Result|array|false {}
+
+ /** @param LDAP\Connection|array $ldap */
+ function ldap_search($ldap, array|string $base, array|string $filter, array $attributes = [], int $attributes_only = 0, int $sizelimit = -1, int $timelimit = -1, int $deref = LDAP_DEREF_NEVER, ?array $controls = null): LDAP\Result|array|false {}
+
+ function ldap_free_result(LDAP\Result $result): bool {}
+
+ function ldap_count_entries(LDAP\Connection $ldap, LDAP\Result $result): int {}
+
+ function ldap_first_entry(LDAP\Connection $ldap, LDAP\Result $result): LDAP\ResultEntry|false {}
+
+ function ldap_next_entry(LDAP\Connection $ldap, LDAP\ResultEntry $entry): LDAP\ResultEntry|false {}
+
+ /**
+ * @return array<int|string, int|array>|false
+ * @refcount 1
+ */
+ function ldap_get_entries(LDAP\Connection $ldap, LDAP\Result $result): array|false {}
+
+ function ldap_first_attribute(LDAP\Connection $ldap, LDAP\ResultEntry $entry): string|false {}
+
+ function ldap_next_attribute(LDAP\Connection $ldap, LDAP\ResultEntry $entry): string|false {}
+
+ /**
+ * @return array<int|string, int|string|array>
+ * @refcount 1
+ */
+ function ldap_get_attributes(LDAP\Connection $ldap, LDAP\ResultEntry $entry): array {}
+
+ /**
+ * @return array<int|string, int|string>|false
+ * @refcount 1
+ */
+ function ldap_get_values_len(LDAP\Connection $ldap, LDAP\ResultEntry $entry, string $attribute): array|false {}
+
+ /**
+ * @return array<int|string, int|string>|false
+ * @refcount 1
+ * @alias ldap_get_values_len
+ */
+ function ldap_get_values(LDAP\Connection $ldap, LDAP\ResultEntry $entry, string $attribute): array|false {}
+
+ function ldap_get_dn(LDAP\Connection $ldap, LDAP\ResultEntry $entry): string|false {}
+
+ /**
+ * @return array<int|string, int|string>|false
+ * @refcount 1
+ */
+ function ldap_explode_dn(string $dn, int $with_attrib): array|false {}
+
+ function ldap_dn2ufn(string $dn): string|false {}
+
+ function ldap_add(LDAP\Connection $ldap, string $dn, array $entry, ?array $controls = null): bool {}
+
+ function ldap_add_ext(LDAP\Connection $ldap, string $dn, array $entry, ?array $controls = null): LDAP\Result|false {}
+
+ function ldap_delete(LDAP\Connection $ldap, string $dn, ?array $controls = null): bool {}
+
+ function ldap_delete_ext(LDAP\Connection $ldap, string $dn, ?array $controls = null): LDAP\Result|false {}
+
+ function ldap_modify_batch(LDAP\Connection $ldap, string $dn, array $modifications_info, ?array $controls = null): bool {}
+
+ function ldap_mod_add(LDAP\Connection $ldap, string $dn, array $entry, ?array $controls = null): bool {}
+
+ function ldap_mod_add_ext(LDAP\Connection $ldap, string $dn, array $entry, ?array $controls = null): LDAP\Result|false {}
+
+ function ldap_mod_replace(LDAP\Connection $ldap, string $dn, array $entry, ?array $controls = null): bool {}
+
+ /** @alias ldap_mod_replace */
+ function ldap_modify(LDAP\Connection $ldap, string $dn, array $entry, ?array $controls = null): bool {}
+
+ function ldap_mod_replace_ext(LDAP\Connection $ldap, string $dn, array $entry, ?array $controls = null): LDAP\Result|false {}
+
+ function ldap_mod_del(LDAP\Connection $ldap, string $dn, array $entry, ?array $controls = null): bool {}
+
+ function ldap_mod_del_ext(LDAP\Connection $ldap, string $dn, array $entry, ?array $controls = null): LDAP\Result|false {}
+
+ function ldap_errno(LDAP\Connection $ldap): int {}
+
+ function ldap_error(LDAP\Connection $ldap): string {}
+
+ function ldap_err2str(int $errno): string {}
+
+ function ldap_compare(LDAP\Connection $ldap, string $dn, string $attribute, string $value, ?array $controls = null): bool|int {}
+
+ #if (LDAP_API_VERSION > 2000) || defined(HAVE_ORALDAP)
+ function ldap_rename(LDAP\Connection $ldap, string $dn, string $new_rdn, string $new_parent, bool $delete_old_rdn, ?array $controls = null): bool {}
+
+ function ldap_rename_ext(LDAP\Connection $ldap, string $dn, string $new_rdn, string $new_parent, bool $delete_old_rdn, ?array $controls = null): LDAP\Result|false {}
+
+ /** @param array|string|int $value */
+ function ldap_get_option(LDAP\Connection $ldap, int $option, &$value = null): bool {}
+
+ /** @param array|string|int|bool $value */
+ function ldap_set_option(?LDAP\Connection $ldap, int $option, $value): bool {}
+
+ function ldap_count_references(LDAP\Connection $ldap, LDAP\Result $result): int {}
+
+ function ldap_first_reference(LDAP\Connection $ldap, LDAP\Result $result): LDAP\ResultEntry|false {}
+
+ function ldap_next_reference(LDAP\Connection $ldap, LDAP\ResultEntry $entry): LDAP\ResultEntry|false {}
+
+ #ifdef HAVE_LDAP_PARSE_REFERENCE
+ /** @param array $referrals */
+ function ldap_parse_reference(LDAP\Connection $ldap, LDAP\ResultEntry $entry, &$referrals): bool {}
+ #endif
+
+ #ifdef HAVE_LDAP_PARSE_RESULT
+ /**
+ * @param int $error_code
+ * @param string $matched_dn
+ * @param string $error_message
+ * @param array $referrals
+ * @param array $controls
+ */
+ function ldap_parse_result(LDAP\Connection $ldap, LDAP\Result $result, &$error_code, &$matched_dn = null, &$error_message = null, &$referrals = null, &$controls = null): bool {}
+ #endif
+ #endif
+
+ #if defined(LDAP_API_FEATURE_X_OPENLDAP) && defined(HAVE_3ARG_SETREBINDPROC)
+ function ldap_set_rebind_proc(LDAP\Connection $ldap, ?callable $callback): bool {}
+ #endif
+
+ #ifdef HAVE_LDAP_START_TLS_S
+ function ldap_start_tls(LDAP\Connection $ldap): bool {}
+ #endif
+
+ function ldap_escape(string $value, string $ignore = "", int $flags = 0): string {}
+
+ #ifdef STR_TRANSLATION
+ function ldap_t61_to_8859(string $value): string|false {}
+
+ function ldap_8859_to_t61(string $value): string|false {}
+ #endif
+
+
+ #ifdef HAVE_LDAP_EXTENDED_OPERATION_S
+ /**
+ * @param string $response_data
+ * @param string $response_oid
+ */
+ function ldap_exop(LDAP\Connection $ldap, string $request_oid, ?string $request_data = null, ?array $controls = NULL, &$response_data = UNKNOWN, &$response_oid = null): LDAP\Result|bool {}
+ #endif
+
+ #ifdef HAVE_LDAP_PASSWD
+ /**
+ * @param array $controls
+ */
+ function ldap_exop_passwd(LDAP\Connection $ldap, string $user = "", string $old_password = "", string $new_password = "", &$controls = null): string|bool {}
+ #endif
+
+
+ #ifdef HAVE_LDAP_WHOAMI_S
+ function ldap_exop_whoami(LDAP\Connection $ldap): string|false {}
+ #endif
+
+ #ifdef HAVE_LDAP_REFRESH_S
+ function ldap_exop_refresh(LDAP\Connection $ldap, string $dn, int $ttl): int|false {}
+ #endif
+
+ #ifdef HAVE_LDAP_PARSE_EXTENDED_RESULT
+ /**
+ * @param string $response_data
+ * @param string $response_oid
+ */
+ function ldap_parse_exop(LDAP\Connection $ldap, LDAP\Result $result, &$response_data = null, &$response_oid = null): bool {}
+ #endif
+
}
diff --git a/build/translation-checker.php b/build/translation-checker.php
index 7bc80d53cdb..ea2fd85ee24 100644
--- a/build/translation-checker.php
+++ b/build/translation-checker.php
@@ -1,22 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2017 Joas Schilling <coding@schilljs.com>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
$directories = [
diff --git a/build/triple-dot-checker.php b/build/triple-dot-checker.php
index 15985a0a95c..d5e67f835f3 100644
--- a/build/triple-dot-checker.php
+++ b/build/triple-dot-checker.php
@@ -1,25 +1,7 @@
<?php
/**
- * @copyright Copyright (c) 2017 Joas Schilling <coding@schilljs.com>
- * @copyright Copyright (c) 2020 Gary Kim <gary@garykim.dev>
- *
- * @author Gary Kim <gary@garykim.dev>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program 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 Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
+ * SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
+ * SPDX-License-Identifier: AGPL-3.0-or-later
*/
$directories = [
diff --git a/build/update-apps.sh b/build/update-apps.sh
index e4611a79aff..444fd84c73e 100755
--- a/build/update-apps.sh
+++ b/build/update-apps.sh
@@ -1,4 +1,8 @@
#!/bin/bash
+#
+# SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
+#
# Update Nextcloud apps from latest git master
# For local development environment
# Use from Nextcloud server folder with `./build/update-apps.sh`
diff --git a/build/update.sh b/build/update.sh
index 3a3d2eac5dc..4f20535d917 100755
--- a/build/update.sh
+++ b/build/update.sh
@@ -1,4 +1,8 @@
#!/bin/bash
+#
+# SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors
+# SPDX-License-Identifier: AGPL-3.0-or-later
+#
# Update Nextcloud server and apps from latest git master
# For local development environment
# Use from Nextcloud server folder with `./build/update.sh`