PHP Classes

File: system/Helpers/array_helper.php

Recommend this page to a friend!
  Classes of Faris AL-Otabi   Task App   system/Helpers/array_helper.php   Download  
File: system/Helpers/array_helper.php
Role: Auxiliary script
Content type: text/plain
Description: Configuration script
Class: Task App
Create and manage tasks to be done
Author: By
Last change:
Date: 17 days ago
Size: 3,413 bytes
 

Contents

Class file image Download
<?php
/**
 * CodeIgniter
 *
 * An open source application development framework for PHP
 *
 * This content is released under the MIT License (MIT)
 *
 * Copyright (c) 2014-2019 British Columbia Institute of Technology
 * Copyright (c) 2019-2020 CodeIgniter Foundation
 *
 * 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.
 *
 * @package CodeIgniter
 * @author CodeIgniter Dev Team
 * @copyright 2019-2020 CodeIgniter Foundation
 * @license https://opensource.org/licenses/MIT MIT License
 * @link https://codeigniter.com
 * @since Version 4.0.0
 * @filesource
 */

/**
 * CodeIgniter Array Helpers
 *
 * @package CodeIgniter
 */

if (! function_exists('dot_array_search'))
{
   
/**
     * Searches an array through dot syntax. Supports
     * wildcard searches, like foo.*.bar
     *
     * @param string $index
     * @param array $array
     *
     * @return mixed|null
     */
   
function dot_array_search(string $index, array $array)
    {
       
$segments = explode('.', rtrim(rtrim($index, '* '), '.'));

        return
_array_search_dot($segments, $array);
    }
}

if (!
function_exists('_array_search_dot'))
{
   
/**
     * Used by dot_array_search to recursively search the
     * array with wildcards.
     *
     * @param array $indexes
     * @param array $array
     *
     * @return mixed|null
     */
   
function _array_search_dot(array $indexes, array $array)
    {
       
// Grab the current index
       
$currentIndex = $indexes
           
? array_shift($indexes)
            :
null;

        if ((empty(
$currentIndex) && intval($currentIndex) !== 0) || (! isset($array[$currentIndex]) && $currentIndex !== '*'))
        {
            return
null;
        }

       
// Handle Wildcard (*)
       
if ($currentIndex === '*')
        {
           
// If $array has more than 1 item, we have to loop over each.
           
if (is_array($array))
            {
                foreach (
$array as $value)
                {
                   
$answer = _array_search_dot($indexes, $value);

                    if (
$answer !== null)
                    {
                        return
$answer;
                    }
                }

               
// Still here after searching all child nodes?
               
return null;
            }
        }

       
// If this is the last index, make sure to return it now,
        // and not try to recurse through things.
       
if (empty($indexes))
        {
            return
$array[$currentIndex];
        }

       
// Do we need to recursively search this value?
       
if (is_array($array[$currentIndex]) && $array[$currentIndex])
        {
            return
_array_search_dot($indexes, $array[$currentIndex]);
        }

       
// Otherwise we've found our match!
       
return $array[$currentIndex];
    }
}