2017 © Pedro Peláez
 

library iterable-functions

Functions to transform iterables into more specific types

image

wmde/iterable-functions

Functions to transform iterables into more specific types

  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 1 Open issues
  • 3 Versions
  • 0 % Grown

The README.md

Iterable Functions

Build Status Scrutinizer Code Quality Code Coverage Latest Stable Version Download count, (*1)

Provides basic functions to work with variables for type iterable (added in PHP 7.1). Primarily to transform variables of type iteratble into more specific types such as array., (*2)

If you have an iterable somewhere and you need to pass it to a function that only takes an array or an Iterator, you have a problem. You will need to add conditional logic to find out the type of the value and transform it if needed, which gets quite involved in the case of needing an Iterator., (*3)

This problem is quite common, as PHP's standard library, as of version 7.1, tends to either require arrays, iterators or traversables., (*4)

Example:, (*5)

function doStuff(iterable $iterable) {
    $iterableMinusFooBar = array_diff( $iterable, [ 'foo', 'bar' ] );
}
// Output: array_diff(): Argument #1 is not an array

Installation

To add this package as a local, per-project dependency to your project, simply add a dependency on wmde/iterable-functions to your project's composer.json file. Here is a minimal example of a composer.json file that just defines a dependency on Iterable Functions 1.x:, (*6)

{
    "require": {
        "wmde/iterable-functions": "~1.0"
    }
}

Usage

When you need an array, (*7)

function doStuff(iterable $iterable) {
    $iterableMinusFooBar = array_diff( iterable_to_array( $iterable ), [ 'foo', 'bar' ] );
}

When you need an Iterator, (*8)

function doStuff(iterable $iterable) {
    $firstFewThings = new LimitIterator( iterable_to_iterator( $iterable ), 42 );
}

Running the tests

For a full CI run, (*9)

composer ci

For tests only, (*10)

composer test

For style checks only, (*11)

composer cs

Release notes

0.2.0 (2018-09-13)

  • Added iterable_merge

0.1.0 (2017-06-17)

Initial release with, (*12)

  • iterable_to_array
  • iterable_to_iterator

The Versions

03/02 2018

dev-master

9999999-dev https://github.com/wmde/iterable-functions

Functions to transform iterables into more specific types

  Sources   Download

GPL-2.0+ GPL-2.0-or-later

The Requires

 

The Development Requires

22/06 2017

dev-no-traversable-iterator

dev-no-traversable-iterator https://github.com/wmde/iterable-functions

Functions to transform iterables into more specific types

  Sources   Download

GPL-2.0+

The Requires

  • php >=7.1

 

The Development Requires

17/06 2017