%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
Server IP : 49.231.201.246 / Your IP : 216.73.216.149 Web Server : Apache/2.4.18 (Ubuntu) System : Linux 246 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64 User : root ( 0) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : exec,passthru,shell_exec,system,proc_open,popen,pcntl_exec MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /var/www/html/water/vendor/codeception/codeception/src/Codeception/Util/ |
Upload File : |
<?php namespace Codeception\Util; class ArrayContainsComparator { /** * @var array */ protected $haystack = []; public function __construct($haystack) { $this->haystack = $haystack; } /** * @return array */ public function getHaystack() { return $this->haystack; } public function containsArray(array $needle) { return $needle == $this->arrayIntersectRecursive($needle, $this->haystack); } /** * @author nleippe@integr8ted.com * @author tiger.seo@gmail.com * @link http://www.php.net/manual/en/function.array-intersect-assoc.php#39822 * * @param mixed $arr1 * @param mixed $arr2 * * @return array|bool */ private function arrayIntersectRecursive($arr1, $arr2) { if (!is_array($arr1) || !is_array($arr2)) { return false; } // if it is not an associative array we do not compare keys if ($this->arrayIsSequential($arr1) && $this->arrayIsSequential($arr2)) { return $this->sequentialArrayIntersect($arr1, $arr2); } return $this->associativeArrayIntersect($arr1, $arr2); } /** * This array has sequential keys? * * @param array $array * * @return bool */ private function arrayIsSequential(array $array) { return array_keys($array) === range(0, count($array) - 1); } /** * @param array $arr1 * @param array $arr2 * @return array */ private function sequentialArrayIntersect(array $arr1, array $arr2) { $ret = []; // Do not match the same item of $arr2 against multiple items of $arr1 $matchedKeys = []; foreach ($arr1 as $key1 => $value1) { foreach ($arr2 as $key2 => $value2) { if (isset($matchedKeys[$key2])) { continue; } $return = $this->arrayIntersectRecursive($value1, $value2); if ($return !== false && $return == $value1) { $ret[$key1] = $return; $matchedKeys[$key2] = true; break; } if ($this->isEqualValue($value1, $value2)) { $ret[$key1] = $value1; $matchedKeys[$key2] = true; break; } } } return $ret; } /** * @param array $arr1 * @param array $arr2 * * @return array|bool|null */ private function associativeArrayIntersect(array $arr1, array $arr2) { $commonKeys = array_intersect(array_keys($arr1), array_keys($arr2)); $ret = []; foreach ($commonKeys as $key) { $return = $this->arrayIntersectRecursive($arr1[$key], $arr2[$key]); if ($return !== false) { $ret[$key] = $return; continue; } if ($this->isEqualValue($arr1[$key], $arr2[$key])) { $ret[$key] = $arr1[$key]; } } if (empty($commonKeys)) { foreach ($arr2 as $arr) { $return = $this->arrayIntersectRecursive($arr1, $arr); if ($return && $return == $arr1) { return $return; } } } if (count($ret) < min(count($arr1), count($arr2))) { return null; } return $ret; } private function isEqualValue($val1, $val2) { if (is_numeric($val1)) { $val1 = (string) $val1; } if (is_numeric($val2)) { $val2 = (string) $val2; } return $val1 === $val2; } }