Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../httpdocs/clone/wp-conte.../plugins/flow-flo.../libs/cakephp/utility
File: MergeVariablesTrait.php
<?php
[0] Fix | Delete
/**
[1] Fix | Delete
* CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
[2] Fix | Delete
* Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
[3] Fix | Delete
*
[4] Fix | Delete
* Licensed under The MIT License
[5] Fix | Delete
* Redistributions of files must retain the above copyright notice.
[6] Fix | Delete
*
[7] Fix | Delete
* @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
[8] Fix | Delete
* @link https://cakephp.org CakePHP(tm) Project
[9] Fix | Delete
* @since 3.0.0
[10] Fix | Delete
* @license https://opensource.org/licenses/mit-license.php MIT License
[11] Fix | Delete
*/
[12] Fix | Delete
namespace Cake\Utility;
[13] Fix | Delete
[14] Fix | Delete
/**
[15] Fix | Delete
* Provides features for merging object properties recursively with
[16] Fix | Delete
* parent classes.
[17] Fix | Delete
*/
[18] Fix | Delete
trait MergeVariablesTrait
[19] Fix | Delete
{
[20] Fix | Delete
/**
[21] Fix | Delete
* Merge the list of $properties with all parent classes of the current class.
[22] Fix | Delete
*
[23] Fix | Delete
* ### Options:
[24] Fix | Delete
*
[25] Fix | Delete
* - `associative` - A list of properties that should be treated as associative arrays.
[26] Fix | Delete
* Properties in this list will be passed through Hash::normalize() before merging.
[27] Fix | Delete
*
[28] Fix | Delete
* @param string[] $properties An array of properties and the merge strategy for them.
[29] Fix | Delete
* @param array $options The options to use when merging properties.
[30] Fix | Delete
* @return void
[31] Fix | Delete
*/
[32] Fix | Delete
protected function _mergeVars($properties, $options = [])
[33] Fix | Delete
{
[34] Fix | Delete
$class = get_class($this);
[35] Fix | Delete
$parents = [];
[36] Fix | Delete
while (true) {
[37] Fix | Delete
$parent = get_parent_class($class);
[38] Fix | Delete
if (!$parent) {
[39] Fix | Delete
break;
[40] Fix | Delete
}
[41] Fix | Delete
$parents[] = $parent;
[42] Fix | Delete
$class = $parent;
[43] Fix | Delete
}
[44] Fix | Delete
foreach ($properties as $property) {
[45] Fix | Delete
if (!property_exists($this, $property)) {
[46] Fix | Delete
continue;
[47] Fix | Delete
}
[48] Fix | Delete
$thisValue = $this->{$property};
[49] Fix | Delete
if ($thisValue === null || $thisValue === false) {
[50] Fix | Delete
continue;
[51] Fix | Delete
}
[52] Fix | Delete
$this->_mergeProperty($property, $parents, $options);
[53] Fix | Delete
}
[54] Fix | Delete
}
[55] Fix | Delete
[56] Fix | Delete
/**
[57] Fix | Delete
* Merge a single property with the values declared in all parent classes.
[58] Fix | Delete
*
[59] Fix | Delete
* @param string $property The name of the property being merged.
[60] Fix | Delete
* @param array $parentClasses An array of classes you want to merge with.
[61] Fix | Delete
* @param array $options Options for merging the property, see _mergeVars()
[62] Fix | Delete
* @return void
[63] Fix | Delete
*/
[64] Fix | Delete
protected function _mergeProperty($property, $parentClasses, $options)
[65] Fix | Delete
{
[66] Fix | Delete
$thisValue = $this->{$property};
[67] Fix | Delete
$isAssoc = false;
[68] Fix | Delete
if (
[69] Fix | Delete
isset($options['associative']) &&
[70] Fix | Delete
in_array($property, (array)$options['associative'])
[71] Fix | Delete
) {
[72] Fix | Delete
$isAssoc = true;
[73] Fix | Delete
}
[74] Fix | Delete
[75] Fix | Delete
if ($isAssoc) {
[76] Fix | Delete
$thisValue = Hash::normalize($thisValue);
[77] Fix | Delete
}
[78] Fix | Delete
foreach ($parentClasses as $class) {
[79] Fix | Delete
$parentProperties = get_class_vars($class);
[80] Fix | Delete
if (empty($parentProperties[$property])) {
[81] Fix | Delete
continue;
[82] Fix | Delete
}
[83] Fix | Delete
$parentProperty = $parentProperties[$property];
[84] Fix | Delete
if (!is_array($parentProperty)) {
[85] Fix | Delete
continue;
[86] Fix | Delete
}
[87] Fix | Delete
$thisValue = $this->_mergePropertyData($thisValue, $parentProperty, $isAssoc);
[88] Fix | Delete
}
[89] Fix | Delete
$this->{$property} = $thisValue;
[90] Fix | Delete
}
[91] Fix | Delete
[92] Fix | Delete
/**
[93] Fix | Delete
* Merge each of the keys in a property together.
[94] Fix | Delete
*
[95] Fix | Delete
* @param array $current The current merged value.
[96] Fix | Delete
* @param array $parent The parent class' value.
[97] Fix | Delete
* @param bool $isAssoc Whether or not the merging should be done in associative mode.
[98] Fix | Delete
* @return mixed The updated value.
[99] Fix | Delete
*/
[100] Fix | Delete
protected function _mergePropertyData($current, $parent, $isAssoc)
[101] Fix | Delete
{
[102] Fix | Delete
if (!$isAssoc) {
[103] Fix | Delete
return array_merge($parent, $current);
[104] Fix | Delete
}
[105] Fix | Delete
$parent = Hash::normalize($parent);
[106] Fix | Delete
foreach ($parent as $key => $value) {
[107] Fix | Delete
if (!isset($current[$key])) {
[108] Fix | Delete
$current[$key] = $value;
[109] Fix | Delete
}
[110] Fix | Delete
}
[111] Fix | Delete
[112] Fix | Delete
return $current;
[113] Fix | Delete
}
[114] Fix | Delete
}
[115] Fix | Delete
[116] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function