endtoend-test-psl/README.md

80 lines
3.7 KiB
Markdown
Raw Normal View History

2019-12-24 01:52:07 +01:00
# Psl - PHP Standard Library
2020-07-12 18:33:29 +01:00
[![TravisCI Build Status](https://travis-ci.org/azjezz/psl.svg?branch=develop)](https://travis-ci.org/azjezz/psl)
[![Appveyor Build status](https://ci.appveyor.com/api/projects/status/cy8bsj35vgqqm2yt/branch/develop?svg=true)](https://ci.appveyor.com/project/azjezz/psl/branch/develop)
2020-07-06 19:35:34 +01:00
[![Scrutinizer Build Status](https://scrutinizer-ci.com/g/azjezz/psl/badges/build.png?b=develop)](https://scrutinizer-ci.com/g/azjezz/psl/build-status/develop)
[![Coverage Status](https://coveralls.io/repos/github/azjezz/psl/badge.svg?branch=develop)](https://coveralls.io/github/azjezz/psl?branch=develop)
2020-03-01 12:01:57 +01:00
[![Type Coverage](https://shepherd.dev/github/azjezz/psl/coverage.svg)](https://shepherd.dev/github/azjezz/psl)
2020-07-06 19:35:34 +01:00
[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/azjezz/psl/badges/quality-score.png?b=develop)](https://scrutinizer-ci.com/g/azjezz/psl/?branch=develop)
[![Code Intelligence Status](https://scrutinizer-ci.com/g/azjezz/psl/badges/code-intelligence.svg?b=develop)](https://scrutinizer-ci.com/code-intelligence)
2019-12-25 20:17:14 +01:00
[![Total Downloads](https://poser.pugx.org/azjezz/psl/d/total.svg)](https://packagist.org/packages/azjezz/psl)
[![Latest Stable Version](https://poser.pugx.org/azjezz/psl/v/stable.svg)](https://packagist.org/packages/azjezz/psl)
[![License](https://poser.pugx.org/azjezz/psl/license.svg)](https://packagist.org/packages/azjezz/psl)
2019-12-25 19:39:01 +01:00
Psl is a standard library for PHP, inspired by [hhvm/hsl](https://github.com/hhvm/hsl).
The goal of Psl is to provide a consistent, centralized, well-typed set of APIs for PHP programmers.
2019-12-24 01:52:07 +01:00
## Example
```php
<?php
declare(strict_types=1);
use Psl\Str;
use Psl\Iter;
/**
* @psalm-param iterable<?int> $codes
*/
function foo(iterable $codes): string
{
2020-07-06 22:45:13 +02:00
/** @var Iter\Iterator<int> $codes */
$codes = Iter\filter_nulls($codes);
/** @var Iter\Iterator<string> $chars */
$chars = Iter\map($codes, fn(int $code): string => Str\chr($code));
return Str\join($chars, ', ');
2019-12-24 01:52:07 +01:00
}
foo([95, 96, null, 98]);
// 'a, b, d'
```
## Installation
2020-07-07 15:17:36 +02:00
This package doesn't have a stable release yet, but you can still install it using composer :
2019-12-24 01:52:07 +01:00
```console
2020-07-06 19:35:34 +01:00
$ composer require azjezz/psl:dev-develop
2019-12-24 01:52:07 +01:00
```
## Documentation
Documentation is not available yet.
## Principles
- All functions should be typed as strictly as possible
- The library should be internally consistent
- References may not be used
- Arguments should be as general as possible. For example, for `array` functions, prefer `iterable` inputs where practical, falling back to `array` when needed.
- Return types should be as specific as possible
- All files should contain `declare(strict_types=1);`
## Consistency Rules
This is not exhaustive list.
- Functions argument order should be consistent within the library
- All iterable-related functions take the iterable as the first argument ( e.g. `Iter\map` and `Iter\filter` )
- `$haystack`, `$needle`, and `$pattern` are in the same order for all functions that take them
- Functions should be consistently named.
- If an operation can conceivably operate on either keys or values, the default is to operate on the values - the version that operates on keys should have `_key` suffix (e.g. `Iter\last`, `Iter\last_key`, `Iter\contains`, `Iter\contains_key` )
- Find-like operations that can fail should return `?T`; a second function should be added with an `x` suffix that uses an invariant to return `T` (e.g. `Arr\last`, `Arr\lastx`)
- Iterable functions that do an operation based on a user-supplied keying function for each element should be suffixed with `_by` (e.g. `Arr\sort_by`, `Iter\group_by`, `Math\max_by`)
## License
The MIT License (MIT). Please see [`LICENSE`](./LICENSE) for more information.