Download the PHP package stubbles/sequence without Composer

On this page you can find all versions of the php package stubbles/sequence. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package sequence

stubbles/sequence

Stream your iterators.

Build status

Tests Coverage Status

Latest Stable Version

Installation

stubbles/sequence is distributed as Composer package. To install it as a dependency of your package use the following command:

composer require "stubbles/sequence": "^10.0"

Requirements

stubbles/sequence requires at least PHP 8.0.

Introduction

Sequence operations are divided into intermediate and terminal operations, and are combined to form pipelines. A pipeline consists of a source (such as a collection, an array, a generator function, or an I/O channel); followed by zero or more intermediate operations such as Sequence::filter() or Sequence::map(); and a terminal operation such as Sequence::each() or Sequence::reduce().

Intermediate operations return a new Sequence. They are always lazy; executing an intermediate operation such as Sequence::filter() does not actually perform any filtering, but instead creates a new Sequence that, when traversed, contains the elements of the initial stream that match the given predicate. Traversal of the pipeline source does not begin until the terminal operation of the pipeline is executed.

Terminal operations, such as Sequence::each() or Sequence::reduce(), may traverse the Sequence to produce a result or a side-effect. After the terminal operation is performed, the pipeline is considered consumed, and can no longer be used; if you need to traverse the same data source again, you must return to the data source to get a new Sequence. In almost all cases, terminal operations are eager, completing their traversal of the data source and processing of the pipeline before returning. Only the terminal operation Sequence::getIterator() is not; this is provided as an "escape hatch" to enable arbitrary client-controlled pipeline traversals in the event that the existing operations are not sufficient to the task.

Create a sequence

Sequence::of($elements)

Creates sequence of given $elements which can be either a \Traversable or an array.

Since release 8.1 it is possible to create a sequence in these ways:

Sequence::infinite($seed, callable $operation)

Creates an infinite sequence. With $seed the initial value can be specified, while $operation must be callable which takes the current value and generates the next value.

Warning: calling terminal operations on an infinite sequence result in endless loops trying to calculate the terminal value. Before calling a terminal operation the sequence should be limited via Sequence::limit(). Alternatively you can iterate over the sequence itself and stop the iteration when required.

Sequence::generate($seed, callable $operation, callable $validator)

Creates a sequence which generates values while being worked on.

The sequence ends when the provided validator returns false for the first time. The validator receives two values: the last generated value, and the amount of values already generated.

The following example generates an array which has $start as first value, where each following value is incremented by 2, and the amount of values in the array is either maximal 100 or PHP_INT_MAX has been reached:

Intermediate operations

limit($n)

Limits sequence to the first n elements, i.e. stops iteration when the nth element is reached.

Result: [1, 2, 3]

skip($n)

Skips the first n elements of the sequence.

Result: [11]

filter(callable $predicate)

Returns a new sequence with elements matching the given predicate. The given predicate reveives a value and must return true to accept the value or false to reject the value.

Result: [2, 4, 6, 8, 10]

map(callable $valueMapper, callable $keyMapper = null)

Returns a new sequence which maps each element using the given mapper.

Result: [2, 4, 6, 8]

mapKeys(callable $keyMapper)

Returns a new sequence which maps each key using the given mapper.

Result: [0 => 1, 2 => 2, 4 => 3, 6 => 4]

append($other)

Appends any value, creating a new combined sequence.

In case given $other is not something iterable it is simply appended as last element to a new sequence.

peek(callable $valueConsumer, callable $keyConsumer = null)

Allows consumer to receive the value before any further operations are applied.

You can use it to inspect the values and keys before any further operations are applied. This is especially useful when you need to debug the contents of a sequence.

Terminal operations

each(callable $consumer)

Invokes consumer for each element and returns the amount of invocations.

The consumer receives the element as first value, and the key as second:

The key is optional and can be left away:

Iteration can be stopped by returning false from the consumer. The following example stops when it reaches element 2:

first()

Returns first element of sequence.

reduce(callable $accumulate = null, $identity = null)

Reduces all elements of the sequence to a single value. The given callable will receive two values: the current reduced value which on first invocation is the value of $identity, and the current element as second. It needs to calculate and return a new value from both which becomes the new value of identity, and will be returned from reduce() after the last element has been processed.

In case no callable is provided an instance of stubbles\sequence\Reducer will be returned which provides convenience methods for some common reduction operations.

reduce()->toSum(callable $summer = null)

Reduces sequence to the sum of all elements. By default assumes the sequence consists of numbers and simply adds them one after another.

In case the sequence consists of other types a callable can be passed that can calculate the sum instead. The callable must expect two values: the sum calculated until now and a single element. The return value must be the new sum with the given element.

reduce()->toMin(callable $min = null)

Reduces sequence to the smallest element. By default assumes the sequence consists of numbers.

In case the sequence consists of other types a callable can be passed that can calculate the smallest value instead. The callable must expect two values: the smalles value found until until now (which null on the first invocation) and a single element. The return value must be the smaller of both arguments.

reduce()->toMax(callable $max = null)

Reduces sequence to the greatest element. By default assumes the sequence consists of numbers.

In case the sequence consists of other types a callable can be passed that can calculate the greatest value instead. The callable must expect two values: the greatest value found until until now (which null on the first invocation) and a single element. The return value must be the greater of both arguments.

collect(Collector $collector = null)

Collects all elements into a structure defined by given collector.

A collector accumulates elements into a structure, optionally transforming the result into a final representation.

In case no collector is provided an instance of stubbles\sequence\Collectors will be returned which provides convenience methods for some common collector operations.

collect()->inList()

Returns the values of the sequence as array.

collect()->inMap(callable $selectKey = null, callable $selectValue = null)

Returns the sequence data with keys and values as associative array. The $selectKey callable will be used to determine the key for a value in the new map, and $selectValue will be used to determine the value. If they are omitted the key and value from the source elements will be used as they are.

collect()->inPartitions(callable $predicate, Collector $base = null)

Groups the elements in two partitions according to given predicate.

The second argument can be used to influence the actual partition value.

collect()->inGroups(callable $classifier, Collector $base = null)

Groups the elements in two partitions according to given predicate.

The second argument can be used to influence the actual group value:

collect()->byJoining($delimiter = ', ', $prefix = '', $suffix = '', $keySeparator = null)

Concatenates all elements into a single string.

When $keySeparator is supplied the key will also be included:

count()

Returns number of elements in sequence.

As Sequence is also an instance of \Countable it can also be used with PHP's native count() function:

values()

Returns the values of the sequence as array, shortcut for collect()->inList().

data()

Returns the sequence data with keys and values as associative array. Shortcut for collect()->inMap().

Sequence validation with bovigo/assert

Available since release 8.0.0

In case you use bovigo/assert for assertions in your unit tests stubbles/sequence provides two predicates which can be used to ensure a sequence contains the expected data:

Both are available with the class stubbles\sequence\assert\Provides. While the first one checks values only and does not consider the keys, the second also checks the keys. Please note that both check exactly those elements - if the sequence contains more values the predicated will fail.


All versions of sequence with dependencies

PHP Build Version
Package Version
Requires php Version ^8.2
ext-json Version *
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package stubbles/sequence contains the following files

Loading the files please wait ....