2017 © Pedro Peláez
 

library traversal

Service for for hash map (assoc array) traversal (fork of igorw/get-in).

image

gnugat/traversal

Service for for hash map (assoc array) traversal (fork of igorw/get-in).

  • Sunday, December 7, 2014
  • by gnupat
  • Repository
  • 1 Watchers
  • 0 Stars
  • 434 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 20 Forks
  • 0 Open issues
  • 4 Versions
  • 3 % Grown

The README.md

Traversal

A service for hash map (assoc array) traversal., (*1)

When dealing with nested associative structures, traversing them can become quite a pain. Mostly because of the amount of isset checking that is necessary., (*2)

For example, to access a nested key ['foo']['bar']['baz'], you must do something like this:, (*3)

$baz = (isset($data['foo']['bar']['baz'])) ? $data['foo']['bar']['baz'] : null;

Enough already! Traversal provides a better way:, (*4)

$baz = Gnugat\Traversal\get_in($data, array('foo', 'bar', 'baz'));

Note: Traversal is a fork of Igor's get-in. which provides support for PHP 5.3., (*5)

SensioLabsInsight Travis CI, (*6)

Installation

Use Composer to install Traversal in your projects:, (*7)

composer require gnugat/traversal:~2.0

Usage

Make the functions available by requiring Composer's autoloader:, (*8)

<?php

require __DIR__.'/vendor/autoload.php';

Get in

Retrieve value from a nested structure using a list of keys:, (*9)

$users = array(
    array('name' => 'Igor Wiedler'),
    array('name' => 'Jane Doe'),
    array('name' => 'Acme Inc'),
);

$name = Gnugat\Traversal\get_in($users, array(1, 'name'));
//= 'Jane Doe'

Non existent keys return null:, (*10)

$data = array('foo' => 'bar'];

$baz = Gnugat\Traversal\get_in($data, array('baz'));
//= null

You can provide a default value that will be used instead of null:, (*11)

$data = array('foo' => 'bar');

$baz = Gnugat\Traversal\get_in($data, array('baz'), 'qux');
//= 'qux'

Update in

Apply a function to the value at a particular location in a nested structure:, (*12)

$data = array('foo' => array('answer' => 42));
$inc = function ($x) {
    return $x + 1;
};

$new = Gnugat\Traversal\update_in($data, array('foo', 'answer'), $inc);
//= array('foo' => array('answer' => 43))

You can variadically provide additional arguments for the function:, (*13)

$data = array('foo' => 'bar');
$concat = function (/* $args... */) {
    return implode('', func_get_args());
};

$new = Gnugat\Traversal\update_in($data, array('foo'), $concat, ' is the ', 'best');
//= array('foo' => 'bar is the best')

Assoc in

Set a value at a particular location:, (*14)

$data = array('foo' => 'bar');

$new = Gnugat\Traversal\assoc_in($data, array('foo'), 'baz');
//= array('foo' => 'baz')

It will also set the value if it does not exist yet:, (*15)

$data = [];

$new = Gnugat\Traversal\assoc_in($data, array('foo', 'bar'), 'baz');
//= array('foo' => array('bar' => 'baz'))

Inspiration

The naming and implementation is inspired by the get-in, update-in and assoc-in functions from clojure., (*16)

The Versions

07/12 2014

dev-master

9999999-dev

Service for for hash map (assoc array) traversal (fork of igorw/get-in).

  Sources   Download

MIT

The Requires

  • php >=5.3

 

The Development Requires

fork traversal hash-map assoc-array igorw get-in

07/12 2014

v2.0.0

2.0.0.0

Service for for hash map (assoc array) traversal (fork of igorw/get-in).

  Sources   Download

MIT

The Requires

  • php >=5.3

 

The Development Requires

fork traversal hash-map assoc-array igorw get-in

17/11 2014

v1.0.1

1.0.1.0

Service for for hash map (assoc array) traversal (fork of igorw/get-in).

  Sources   Download

MIT

The Requires

  • php >=5.3

 

The Development Requires

fork traversal hash-map assoc-array igorw get-in

16/11 2014

v1.0.0

1.0.0.0

Service for for hash map (assoc array) traversal (fork of igorw/get-in).

  Sources   Download

MIT

The Requires

  • php >=5.3

 

The Development Requires

fork traversal hash-map assoc-array igorw get-in