binary-collections 2.0.13 → 2.0.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.opencode/plugins/opencode-request-logger/README.md +44 -0
- package/.venv/Lib/site-packages/pyarrow/tests/data/orc/README.md +22 -0
- package/binaries/binary-executor.cjs +307 -238
- package/binaries/clean-nodemodule.cjs +307 -238
- package/binaries/clean-nodemodules.cjs +307 -238
- package/binaries/composer.cjs +323 -0
- package/binaries/composer.cmd +2 -0
- package/binaries/composer.phar +0 -0
- package/binaries/dev.cjs +307 -238
- package/binaries/empty.cjs +307 -238
- package/binaries/git-reduce-size.cjs +307 -238
- package/binaries/javakill.cjs +307 -238
- package/binaries/kill-process.cjs +307 -238
- package/binaries/nodekill.cjs +307 -238
- package/binaries/prod.cjs +307 -238
- package/binaries/py.cjs +307 -238
- package/binaries/rmfind.cjs +307 -238
- package/binaries/rmx.cjs +307 -238
- package/binaries/submodule-token.cjs +307 -238
- package/binaries/test-cjs.cjs +307 -238
- package/binaries/test-esm.cjs +307 -238
- package/binaries/yarn-clean.cjs +307 -238
- package/binaries/yc.cjs +307 -238
- package/binaries/ycw.cjs +307 -238
- package/docs-src/binary-collections.md +1 -1
- package/docs-src/clean-github-actions-caches.md +1 -1
- package/docs-src/copy-move-file.md +1 -4
- package/docs-src/del-ps.md +1 -1
- package/docs-src/find-node-modules.md +1 -1
- package/docs-src/generate-test-ci.md +56 -0
- package/docs-src/get-latest-workflow-status.md +100 -0
- package/docs-src/git-diff.md +1 -1
- package/docs-src/git-fix.md +1 -1
- package/docs-src/git-purge.md +1 -1
- package/docs-src/install-opencode-plugins.md +86 -0
- package/docs-src/kill-night-crows.md +1 -1
- package/docs-src/node-cache-cleaner.md +2 -2
- package/docs-src/node-package-packer.md +1 -1
- package/docs-src/opencode-cli.md +155 -0
- package/docs-src/package-resolutions-updater.md +1 -1
- package/docs-src/rmpath.md +1 -1
- package/docs-src/run-by-checksum.md +1 -1
- package/docs-src/submodule-remove.md +1 -1
- package/docs-src/upload-backend.md +29 -0
- package/docs-src/vscode-cli.md +84 -0
- package/docs-src/workflow-badge.md +120 -0
- package/lib/binary-collections/config-types.cjs +17 -0
- package/lib/binary-collections/config-types.d.ts +12 -0
- package/lib/binary-collections/config-types.js +2 -0
- package/lib/binary-collections/config-types.mjs +7 -0
- package/lib/binary-collections/config.cjs +28 -8
- package/lib/binary-collections/config.d.cts +26 -8
- package/lib/binary-collections/config.mjs +2 -2
- package/lib/binary-collections/findScript.cjs +49 -25
- package/lib/binary-collections/findScript.mjs +2 -2
- package/lib/binary-collections/listScript.cjs +49 -25
- package/lib/binary-collections/listScript.mjs +2 -2
- package/lib/binary-collections.cjs +49 -25
- package/lib/binary-collections.mjs +6 -6
- package/lib/changelog.cjs +142 -4
- package/lib/changelog.mjs +9 -5
- package/lib/chunk-3T6AMFI3.mjs +52 -0
- package/lib/{chunk-2MN4VPV2.mjs → chunk-3ZF2QMDK.mjs} +4 -4
- package/lib/chunk-56BVU63B.mjs +86 -0
- package/lib/chunk-7N52Z4IJ.mjs +39 -0
- package/lib/chunk-B77D3SR4.mjs +28 -0
- package/lib/chunk-BPED62FN.mjs +115 -0
- package/lib/{chunk-RDN6HF5Z.mjs → chunk-DHFRWM2W.mjs} +1 -1
- package/lib/chunk-DPEE3FBB.mjs +146 -0
- package/lib/{chunk-MGPYPKIE.mjs → chunk-H7AE4IO3.mjs} +5 -1
- package/lib/{chunk-H44UWUFY.mjs → chunk-J4M5EL5P.mjs} +3 -0
- package/lib/chunk-KCJYREA2.mjs +67 -0
- package/lib/chunk-LACQTD5V.mjs +225 -0
- package/lib/{chunk-TBWXE7ST.mjs → chunk-NHD4HLSU.mjs} +24 -31
- package/lib/{chunk-RDGDLSPD.mjs → chunk-OWNVMKAA.mjs} +6 -5
- package/lib/chunk-SKVF4TMD.mjs +59 -0
- package/lib/{chunk-BZWVHODJ.mjs → chunk-TDUUOAQD.mjs} +5 -5
- package/lib/chunk-TP3O2JGW.mjs +88 -0
- package/lib/{chunk-FLYSZFLW.mjs → chunk-UAEKSLAX.mjs} +1 -1
- package/lib/chunk-UDZBVKXH.mjs +94 -0
- package/lib/chunk-UEOWRYAN.mjs +32 -0
- package/lib/chunk-V6PTSDW5.mjs +82 -0
- package/lib/{chunk-NQXUYO67.mjs → chunk-WNUEY6VJ.mjs} +49 -25
- package/lib/chunk-X7UVQ6ZC.mjs +183 -0
- package/lib/chunk-XW5NZAKI.mjs +82 -0
- package/lib/{chunk-LVSPEFU2.mjs → chunk-Z53IUBUN.mjs} +6 -5
- package/lib/{chunk-CD3HF3LK.mjs → chunk-Z7RM46Q4.mjs} +5 -11
- package/lib/chunk-ZB4IQ6VJ.mjs +46 -0
- package/lib/del-gradle.cjs +1 -1
- package/lib/del-gradle.mjs +22 -16
- package/lib/del-node-modules.cjs +1 -1
- package/lib/del-node-modules.mjs +148 -142
- package/lib/find-node-modules-cli.cjs +1 -1
- package/lib/find-node-modules-cli.mjs +10 -4
- package/lib/{git-diff-cli.cjs → git/git-diff-cli.cjs} +32 -12
- package/lib/{git-diff-cli.mjs → git/git-diff-cli.mjs} +7 -7
- package/lib/{git-diff.cjs → git/git-diff.cjs} +30 -10
- package/lib/{git-diff.js → git/git-diff.js} +3 -3
- package/lib/{git-diff.mjs → git/git-diff.mjs} +6 -6
- package/lib/{git-fix.cjs → git/git-fix.cjs} +142 -3
- package/lib/{git-fix.mjs → git/git-fix.mjs} +19 -14
- package/lib/{git-purge.cjs → git/git-purge.cjs} +1 -1
- package/lib/{git-purge.mjs → git/git-purge.mjs} +4 -4
- package/lib/git/user-config.cjs +139 -1
- package/lib/git/user-config.mjs +3 -1
- package/lib/{clean-github-actions-caches-cli.cjs → github-workflows/clean-github-actions-caches-cli.cjs} +46 -10
- package/lib/{clean-github-actions-caches-cli.mjs → github-workflows/clean-github-actions-caches-cli.mjs} +7 -6
- package/lib/{clean-github-actions-caches.cjs → github-workflows/clean-github-actions-caches.cjs} +46 -10
- package/lib/{clean-github-actions-caches.mjs → github-workflows/clean-github-actions-caches.mjs} +5 -4
- package/lib/github-workflows/generate-test-ci-step-cli.cjs +240 -0
- package/lib/github-workflows/generate-test-ci-step-cli.d.mts +2 -0
- package/lib/github-workflows/generate-test-ci-step-cli.mjs +132 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.cjs +549 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.d.mts +2 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.mjs +61 -0
- package/lib/github-workflows/get-latest-workflow-status.cjs +56 -0
- package/lib/github-workflows/get-latest-workflow-status.d.mts +1 -0
- package/lib/github-workflows/get-latest-workflow-status.mjs +8 -0
- package/lib/github-workflows/utils.cjs +279 -0
- package/lib/github-workflows/utils.d.cts +76 -0
- package/lib/github-workflows/utils.mjs +8 -0
- package/lib/github-workflows/workflow-badge-cli.cjs +730 -0
- package/lib/github-workflows/workflow-badge-cli.d.mts +2 -0
- package/lib/github-workflows/workflow-badge-cli.mjs +98 -0
- package/lib/github-workflows/workflow-badge-generator.cjs +200 -0
- package/lib/github-workflows/workflow-badge-generator.d.mts +14 -0
- package/lib/github-workflows/workflow-badge-generator.mjs +8 -0
- package/lib/github-workflows/workflow-test-data.cjs +73 -0
- package/lib/github-workflows/workflow-test-data.d.cts +63 -0
- package/lib/github-workflows/workflow-test-data.mjs +6 -0
- package/lib/node-cache-cleaner-cli.mjs +3 -3
- package/lib/opencode/cli/auth-rotate.cjs +458 -0
- package/lib/opencode/cli/auth-rotate.d.ts +3 -0
- package/lib/opencode/cli/auth-rotate.js +65 -0
- package/lib/opencode/cli/auth-rotate.mjs +14 -0
- package/lib/opencode/cli/auth-rotate.runner.cjs +454 -0
- package/lib/opencode/cli/auth-rotate.runner.d.ts +1 -0
- package/lib/opencode/cli/auth-rotate.runner.js +8 -0
- package/lib/opencode/cli/auth-rotate.runner.mjs +21 -0
- package/lib/opencode/cli/list-projects.cjs +184 -0
- package/lib/opencode/cli/list-projects.d.ts +1 -0
- package/lib/opencode/cli/list-projects.js +32 -0
- package/lib/opencode/cli/list-projects.mjs +11 -0
- package/lib/opencode/cli/list-sessions.cjs +215 -0
- package/lib/opencode/cli/list-sessions.d.ts +1 -0
- package/lib/opencode/cli/list-sessions.js +45 -0
- package/lib/opencode/cli/list-sessions.mjs +11 -0
- package/lib/opencode/database.cjs +349 -0
- package/lib/opencode/database.d.ts +91 -0
- package/lib/opencode/database.js +252 -0
- package/lib/opencode/database.mjs +28 -0
- package/lib/opencode/database.runner.cjs +145 -0
- package/lib/opencode/database.runner.d.ts +1 -0
- package/lib/opencode/database.runner.js +56 -0
- package/lib/opencode/database.runner.mjs +37 -0
- package/lib/opencode/install-opencode-plugins-cli.cjs +82 -0
- package/lib/opencode/install-opencode-plugins-cli.d.ts +1 -0
- package/lib/opencode/install-opencode-plugins-cli.js +78 -0
- package/lib/opencode/install-opencode-plugins-cli.mjs +65 -0
- package/lib/opencode/opencode-zen.runner.cjs +48 -0
- package/lib/opencode/opencode-zen.runner.d.mts +1 -0
- package/lib/opencode/opencode-zen.runner.mjs +31 -0
- package/lib/opencode/sqlite.cjs +114 -0
- package/lib/opencode/sqlite.d.ts +18 -0
- package/lib/opencode/sqlite.js +82 -0
- package/lib/opencode/sqlite.mjs +10 -0
- package/lib/opencode/storage.cjs +124 -0
- package/lib/opencode/storage.d.ts +27 -0
- package/lib/opencode/storage.js +101 -0
- package/lib/opencode/storage.mjs +38 -0
- package/lib/opencode/storage.runner.cjs +50 -0
- package/lib/opencode/storage.runner.d.ts +1 -0
- package/lib/opencode/storage.runner.js +13 -0
- package/lib/opencode/storage.runner.mjs +29 -0
- package/lib/opencode/types.cjs +17 -0
- package/lib/opencode/types.d.ts +31 -0
- package/lib/opencode/types.js +2 -0
- package/lib/opencode/types.mjs +7 -0
- package/lib/opencode/utils/check-api.cjs +373 -0
- package/lib/opencode/utils/check-api.d.ts +16 -0
- package/lib/opencode/utils/check-api.js +132 -0
- package/lib/opencode/utils/check-api.mjs +12 -0
- package/lib/opencode/utils/check-api.runner.cjs +0 -0
- package/lib/opencode/utils/check-api.runner.d.ts +0 -0
- package/lib/opencode/utils/check-api.runner.js +1 -0
- package/lib/opencode/utils/check-api.runner.mjs +7 -0
- package/lib/opencode-cli.cjs +796 -0
- package/lib/opencode-cli.d.ts +2 -0
- package/lib/opencode-cli.js +116 -0
- package/lib/opencode-cli.mjs +116 -0
- package/lib/package-resolutions-updater-cli.cjs +189 -154
- package/lib/package-resolutions-updater-cli.mjs +3 -2
- package/lib/package-resolutions-updater.cjs +189 -154
- package/lib/package-resolutions-updater.d.mts +12 -3
- package/lib/package-resolutions-updater.mjs +3 -2
- package/lib/print-directory-tree.cjs +139 -3
- package/lib/print-directory-tree.mjs +6 -3
- package/lib/print-tarball-tree-cli.cjs +305 -0
- package/lib/print-tarball-tree-cli.d.mts +2 -0
- package/lib/print-tarball-tree-cli.mjs +54 -0
- package/lib/print-tarball-tree.cjs +43 -216
- package/lib/print-tarball-tree.d.mts +4 -1
- package/lib/print-tarball-tree.mjs +12 -66
- package/lib/rmpath-cli.cjs +139 -5
- package/lib/rmpath-cli.mjs +3 -1
- package/lib/rmpath.cjs +155 -11
- package/lib/rmpath.mjs +3 -1
- package/lib/run-by-checksum/hash.cjs +50 -56
- package/lib/run-by-checksum/hash.d.cts +24 -0
- package/lib/run-by-checksum/hash.mjs +3 -7
- package/lib/run-by-checksum/run.cjs +95 -42
- package/lib/run-by-checksum/run.js +3 -3
- package/lib/run-by-checksum/run.mjs +2 -2
- package/lib/run-by-checksum-cli.cjs +96 -58
- package/lib/run-by-checksum-cli.mjs +2 -2
- package/lib/submodule-install.cjs +138 -4
- package/lib/submodule-install.mjs +5 -4
- package/lib/submodule-remove-cli.cjs +139 -5
- package/lib/submodule-remove-cli.mjs +3 -1
- package/lib/submodule-remove.cjs +154 -5
- package/lib/submodule-remove.mjs +3 -1
- package/lib/utils/findEnvFiles.cjs +3 -0
- package/lib/utils/findEnvFiles.d.cts +2 -2
- package/lib/utils/findEnvFiles.mjs +1 -1
- package/lib/utils/isDebug.cjs +13 -0
- package/lib/utils/isDebug.d.cts +9 -0
- package/lib/utils/isDebug.mjs +6 -0
- package/lib/vscode/project.cjs +0 -0
- package/lib/vscode/project.d.ts +0 -0
- package/lib/vscode/project.js +1 -0
- package/lib/vscode/project.mjs +7 -0
- package/lib/vscode/storage.cjs +138 -0
- package/lib/vscode/storage.d.ts +51 -0
- package/lib/vscode/storage.js +169 -0
- package/lib/vscode/storage.mjs +42 -0
- package/lib/vscode/storage.runner.cjs +125 -0
- package/lib/vscode/storage.runner.d.ts +1 -0
- package/lib/vscode/storage.runner.js +47 -0
- package/lib/vscode/storage.runner.mjs +60 -0
- package/lib/vscode-cli.cjs +155 -0
- package/lib/vscode-cli.d.ts +2 -0
- package/lib/vscode-cli.js +80 -0
- package/lib/vscode-cli.mjs +71 -0
- package/package.json +50 -26
- package/readme.md +104 -8
- package/releases/readme.md +1 -1
- package/src/github-workflows/generate-test-ci-step-cli.mjs +126 -0
- package/vendor/clue/ndjson-react/README.md +365 -0
- package/vendor/composer/pcre/README.md +189 -0
- package/vendor/composer/semver/README.md +99 -0
- package/vendor/composer/xdebug-handler/README.md +305 -0
- package/vendor/ergebnis/agent-detector/README.md +107 -0
- package/vendor/evenement/evenement/README.md +64 -0
- package/vendor/fidry/cpu-core-counter/README.md +138 -0
- package/vendor/friendsofphp/php-cs-fixer/README.md +97 -0
- package/vendor/psr/container/README.md +13 -0
- package/vendor/psr/event-dispatcher/README.md +6 -0
- package/vendor/psr/log/README.md +58 -0
- package/vendor/react/cache/README.md +367 -0
- package/vendor/react/child-process/README.md +619 -0
- package/vendor/react/dns/README.md +453 -0
- package/vendor/react/event-loop/README.md +930 -0
- package/vendor/react/promise/README.md +722 -0
- package/vendor/react/socket/README.md +1564 -0
- package/vendor/react/stream/README.md +1249 -0
- package/vendor/sebastian/diff/README.md +151 -0
- package/vendor/symfony/console/README.md +30 -0
- package/vendor/symfony/deprecation-contracts/README.md +26 -0
- package/vendor/symfony/event-dispatcher/README.md +25 -0
- package/vendor/symfony/event-dispatcher-contracts/README.md +9 -0
- package/vendor/symfony/filesystem/README.md +23 -0
- package/vendor/symfony/finder/README.md +24 -0
- package/vendor/symfony/options-resolver/README.md +25 -0
- package/vendor/symfony/polyfill-ctype/README.md +12 -0
- package/vendor/symfony/polyfill-intl-grapheme/README.md +32 -0
- package/vendor/symfony/polyfill-intl-normalizer/README.md +14 -0
- package/vendor/symfony/polyfill-mbstring/README.md +13 -0
- package/vendor/symfony/polyfill-php80/README.md +25 -0
- package/vendor/symfony/polyfill-php81/README.md +18 -0
- package/vendor/symfony/polyfill-php84/README.md +23 -0
- package/vendor/symfony/polyfill-php85/README.md +20 -0
- package/vendor/symfony/process/README.md +23 -0
- package/vendor/symfony/service-contracts/README.md +9 -0
- package/vendor/symfony/stopwatch/README.md +52 -0
- package/vendor/symfony/string/README.md +24 -0
- package/lib/chunk-WSHVPGNM.mjs +0 -44
- package/lib/chunk-X2B3X7D4.mjs +0 -35
- package/lib/del-gradle.js +0 -16
- package/lib/del-node-modules.js +0 -211
- package/lib/find-node-modules-cli.js +0 -4
- package/lib/run-by-checksum/hash.d.ts +0 -14
- package/lib/run-by-checksum/hash.js +0 -85
- package/readme.html +0 -784
- /package/lib/{clean-github-actions-caches-cli.d.cts → del-gradle.d.cts} +0 -0
- /package/lib/{del-gradle.d.ts → del-node-modules.d.cts} +0 -0
- /package/lib/{find-node-modules-cli.d.ts → find-node-modules-cli.d.cts} +0 -0
- /package/lib/{git-diff-cli.d.ts → git/git-diff-cli.d.ts} +0 -0
- /package/lib/{git-diff-cli.js → git/git-diff-cli.js} +0 -0
- /package/lib/{git-diff.d.ts → git/git-diff.d.ts} +0 -0
- /package/lib/{git-fix.d.cts → git/git-fix.d.cts} +0 -0
- /package/lib/{git-purge.d.cts → git/git-purge.d.cts} +0 -0
- /package/lib/{del-node-modules.d.ts → github-workflows/clean-github-actions-caches-cli.d.cts} +0 -0
- /package/lib/{clean-github-actions-caches.d.cts → github-workflows/clean-github-actions-caches.d.cts} +0 -0
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
<p align="center">
|
|
2
|
+
<a href="https://cs.symfony.com">
|
|
3
|
+
<img src="./logo.png" title="PHP CS Fixer" alt="PHP CS Fixer logo">
|
|
4
|
+
</a>
|
|
5
|
+
</p>
|
|
6
|
+
|
|
7
|
+
# PHP Coding Standards Fixer
|
|
8
|
+
|
|
9
|
+
The PHP Coding Standards Fixer (PHP CS Fixer) fixes your code to follow the standards.
|
|
10
|
+
|
|
11
|
+
If you are already using a linter to identify coding standards problems in your
|
|
12
|
+
code, you know that fixing them by hand is tedious, especially on large
|
|
13
|
+
projects. This tool not only detects them, but also fixes them for you.
|
|
14
|
+
|
|
15
|
+
PHP CS Fixer has built-in rule sets, whether you want to follow PHP coding standards as defined by [PHP-FIG's PER Coding Style](https://www.php-fig.org/per/coding-style/) - [`@PER-CS`](./doc/ruleSets/PER-CS.rst),
|
|
16
|
+
a wide community like the [Symfony](https://symfony.com/doc/current/contributing/code/standards.html) - [`@Symfony`](./doc/ruleSets/Symfony.rst),
|
|
17
|
+
or our opinionated one - [@PhpCsFixer](./doc/ruleSets/PhpCsFixer.rst).
|
|
18
|
+
You can also define your (team's) style through the [configuration file](./doc/config.rst).
|
|
19
|
+
|
|
20
|
+
PHP CS Fixer can not only unify the style of your code, but also help to modernise your codebase towards
|
|
21
|
+
newer PHP (e.g. [`@autoPHPMigration`](./doc/ruleSets/AutoPHPMigration.rst) and [`@autoPHPMigration:risky`](./doc/ruleSets/AutoPHPMigrationRisky.rst)) and newer PHPUnit (e.g. [`@autoPHPUnitMigration:risky`](./doc/ruleSets/AutoPHPUnitMigrationRisky.rst)).
|
|
22
|
+
|
|
23
|
+
There are also [`@auto`](./doc/ruleSets/Auto.rst) and [`@auto:risky`](./doc/ruleSets/AutoRisky.rst) that aim to provide good base rules.
|
|
24
|
+
|
|
25
|
+
## Supported PHP Versions
|
|
26
|
+
|
|
27
|
+
* PHP 7.4 - PHP 8.5
|
|
28
|
+
|
|
29
|
+
> [!NOTE]
|
|
30
|
+
> Each new PHP version requires a huge effort to support the new syntax.
|
|
31
|
+
> That's why the latest PHP version might not be supported yet. If you need it,
|
|
32
|
+
> please consider supporting the project in any convenient way, for example,
|
|
33
|
+
> with code contributions or reviewing existing PRs. To run PHP CS Fixer on yet
|
|
34
|
+
> unsupported versions "at your own risk" - use `--allow-unsupported-php-version=yes` option.
|
|
35
|
+
|
|
36
|
+
## Documentation
|
|
37
|
+
|
|
38
|
+
### Installation
|
|
39
|
+
|
|
40
|
+
The recommended way to install PHP CS Fixer is to use [Composer](https://getcomposer.org/download/):
|
|
41
|
+
|
|
42
|
+
```sh
|
|
43
|
+
composer require --dev friendsofphp/php-cs-fixer
|
|
44
|
+
## or when facing conflicts in dependencies:
|
|
45
|
+
composer require --dev php-cs-fixer/shim
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
For more details and other installation methods (also with Docker or behind CI), see
|
|
49
|
+
[installation instructions](./doc/installation.rst).
|
|
50
|
+
|
|
51
|
+
### Usage
|
|
52
|
+
|
|
53
|
+
Assuming you installed PHP CS Fixer as instructed above, you can
|
|
54
|
+
initialise base config for your project by using following command:
|
|
55
|
+
|
|
56
|
+
```sh
|
|
57
|
+
./vendor/bin/php-cs-fixer init
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
To automatically fix your project, or only check against the need of changes, run:
|
|
61
|
+
|
|
62
|
+
```sh
|
|
63
|
+
./vendor/bin/php-cs-fixer fix
|
|
64
|
+
./vendor/bin/php-cs-fixer check
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
See [usage](./doc/usage.rst), list of [built-in rules](./doc/rules/index.rst), list of [rule sets](./doc/ruleSets/index.rst)
|
|
68
|
+
and [configuration file](./doc/config.rst) documentation for more details.
|
|
69
|
+
|
|
70
|
+
If you need to apply code styles that are not built-in into the tool, you can
|
|
71
|
+
[create custom rules](./doc/custom_rules.rst).
|
|
72
|
+
|
|
73
|
+
## Editor Integration
|
|
74
|
+
|
|
75
|
+
Native support exists for:
|
|
76
|
+
|
|
77
|
+
* [PhpStorm](https://www.jetbrains.com/help/phpstorm/using-php-cs-fixer.html)
|
|
78
|
+
|
|
79
|
+
Community plugins exist for:
|
|
80
|
+
|
|
81
|
+
* [NetBeans](https://plugins.netbeans.apache.org/catalogue/?id=36)
|
|
82
|
+
* [Sublime Text](https://github.com/benmatselby/sublime-phpcs)
|
|
83
|
+
* [Vim](https://github.com/stephpy/vim-php-cs-fixer)
|
|
84
|
+
* [VS Code](https://github.com/junstyle/vscode-php-cs-fixer)
|
|
85
|
+
|
|
86
|
+
## Community
|
|
87
|
+
|
|
88
|
+
The PHP CS Fixer is maintained on GitHub at <https://github.com/PHP-CS-Fixer/PHP-CS-Fixer>.
|
|
89
|
+
Contributions, bug reports and ideas about new features are welcome there.
|
|
90
|
+
|
|
91
|
+
You can reach us in the [GitHub Discussions](https://github.com/PHP-CS-Fixer/PHP-CS-Fixer/discussions/) regarding the
|
|
92
|
+
project, configuration, possible improvements, ideas and questions.
|
|
93
|
+
|
|
94
|
+
## Contribute
|
|
95
|
+
|
|
96
|
+
The tool comes with quite a few built-in fixers, but everyone is more than
|
|
97
|
+
welcome to [contribute](./CONTRIBUTING.md) more of them.
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
Container interface
|
|
2
|
+
==============
|
|
3
|
+
|
|
4
|
+
This repository holds all interfaces related to [PSR-11 (Container Interface)][psr-url].
|
|
5
|
+
|
|
6
|
+
Note that this is not a Container implementation of its own. It is merely abstractions that describe the components of a Dependency Injection Container.
|
|
7
|
+
|
|
8
|
+
The installable [package][package-url] and [implementations][implementation-url] are listed on Packagist.
|
|
9
|
+
|
|
10
|
+
[psr-url]: https://www.php-fig.org/psr/psr-11/
|
|
11
|
+
[package-url]: https://packagist.org/packages/psr/container
|
|
12
|
+
[implementation-url]: https://packagist.org/providers/psr/container-implementation
|
|
13
|
+
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
PSR Event Dispatcher
|
|
2
|
+
====================
|
|
3
|
+
|
|
4
|
+
This repository holds the interfaces related to [PSR-14](http://www.php-fig.org/psr/psr-14/).
|
|
5
|
+
|
|
6
|
+
Note that this is not an Event Dispatcher implementation of its own. It is merely interfaces that describe the components of an Event Dispatcher. See the specification for more details.
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
PSR Log
|
|
2
|
+
=======
|
|
3
|
+
|
|
4
|
+
This repository holds all interfaces/classes/traits related to
|
|
5
|
+
[PSR-3](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md).
|
|
6
|
+
|
|
7
|
+
Note that this is not a logger of its own. It is merely an interface that
|
|
8
|
+
describes a logger. See the specification for more details.
|
|
9
|
+
|
|
10
|
+
Installation
|
|
11
|
+
------------
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
composer require psr/log
|
|
15
|
+
```
|
|
16
|
+
|
|
17
|
+
Usage
|
|
18
|
+
-----
|
|
19
|
+
|
|
20
|
+
If you need a logger, you can use the interface like this:
|
|
21
|
+
|
|
22
|
+
```php
|
|
23
|
+
<?php
|
|
24
|
+
|
|
25
|
+
use Psr\Log\LoggerInterface;
|
|
26
|
+
|
|
27
|
+
class Foo
|
|
28
|
+
{
|
|
29
|
+
private $logger;
|
|
30
|
+
|
|
31
|
+
public function __construct(LoggerInterface $logger = null)
|
|
32
|
+
{
|
|
33
|
+
$this->logger = $logger;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public function doSomething()
|
|
37
|
+
{
|
|
38
|
+
if ($this->logger) {
|
|
39
|
+
$this->logger->info('Doing work');
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
try {
|
|
43
|
+
$this->doSomethingElse();
|
|
44
|
+
} catch (Exception $exception) {
|
|
45
|
+
$this->logger->error('Oh no!', array('exception' => $exception));
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// do something useful
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
You can then pick one of the implementations of the interface to get a logger.
|
|
54
|
+
|
|
55
|
+
If you want to implement the interface, you can require this package and
|
|
56
|
+
implement `Psr\Log\LoggerInterface` in your code. Please read the
|
|
57
|
+
[specification text](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md)
|
|
58
|
+
for details.
|
|
@@ -0,0 +1,367 @@
|
|
|
1
|
+
# Cache
|
|
2
|
+
|
|
3
|
+
[](https://github.com/reactphp/cache/actions)
|
|
4
|
+
[](https://packagist.org/packages/react/cache)
|
|
5
|
+
|
|
6
|
+
Async, [Promise](https://github.com/reactphp/promise)-based cache interface
|
|
7
|
+
for [ReactPHP](https://reactphp.org/).
|
|
8
|
+
|
|
9
|
+
The cache component provides a
|
|
10
|
+
[Promise](https://github.com/reactphp/promise)-based
|
|
11
|
+
[`CacheInterface`](#cacheinterface) and an in-memory [`ArrayCache`](#arraycache)
|
|
12
|
+
implementation of that.
|
|
13
|
+
This allows consumers to type hint against the interface and third parties to
|
|
14
|
+
provide alternate implementations.
|
|
15
|
+
This project is heavily inspired by
|
|
16
|
+
[PSR-16: Common Interface for Caching Libraries](https://www.php-fig.org/psr/psr-16/),
|
|
17
|
+
but uses an interface more suited for async, non-blocking applications.
|
|
18
|
+
|
|
19
|
+
**Table of Contents**
|
|
20
|
+
|
|
21
|
+
* [Usage](#usage)
|
|
22
|
+
* [CacheInterface](#cacheinterface)
|
|
23
|
+
* [get()](#get)
|
|
24
|
+
* [set()](#set)
|
|
25
|
+
* [delete()](#delete)
|
|
26
|
+
* [getMultiple()](#getmultiple)
|
|
27
|
+
* [setMultiple()](#setmultiple)
|
|
28
|
+
* [deleteMultiple()](#deletemultiple)
|
|
29
|
+
* [clear()](#clear)
|
|
30
|
+
* [has()](#has)
|
|
31
|
+
* [ArrayCache](#arraycache)
|
|
32
|
+
* [Common usage](#common-usage)
|
|
33
|
+
* [Fallback get](#fallback-get)
|
|
34
|
+
* [Fallback-get-and-set](#fallback-get-and-set)
|
|
35
|
+
* [Install](#install)
|
|
36
|
+
* [Tests](#tests)
|
|
37
|
+
* [License](#license)
|
|
38
|
+
|
|
39
|
+
## Usage
|
|
40
|
+
|
|
41
|
+
### CacheInterface
|
|
42
|
+
|
|
43
|
+
The `CacheInterface` describes the main interface of this component.
|
|
44
|
+
This allows consumers to type hint against the interface and third parties to
|
|
45
|
+
provide alternate implementations.
|
|
46
|
+
|
|
47
|
+
#### get()
|
|
48
|
+
|
|
49
|
+
The `get(string $key, mixed $default = null): PromiseInterface<mixed>` method can be used to
|
|
50
|
+
retrieve an item from the cache.
|
|
51
|
+
|
|
52
|
+
This method will resolve with the cached value on success or with the
|
|
53
|
+
given `$default` value when no item can be found or when an error occurs.
|
|
54
|
+
Similarly, an expired cache item (once the time-to-live is expired) is
|
|
55
|
+
considered a cache miss.
|
|
56
|
+
|
|
57
|
+
```php
|
|
58
|
+
$cache
|
|
59
|
+
->get('foo')
|
|
60
|
+
->then('var_dump');
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
This example fetches the value of the key `foo` and passes it to the
|
|
64
|
+
`var_dump` function. You can use any of the composition provided by
|
|
65
|
+
[promises](https://github.com/reactphp/promise).
|
|
66
|
+
|
|
67
|
+
#### set()
|
|
68
|
+
|
|
69
|
+
The `set(string $key, mixed $value, ?float $ttl = null): PromiseInterface<bool>` method can be used to
|
|
70
|
+
store an item in the cache.
|
|
71
|
+
|
|
72
|
+
This method will resolve with `true` on success or `false` when an error
|
|
73
|
+
occurs. If the cache implementation has to go over the network to store
|
|
74
|
+
it, it may take a while.
|
|
75
|
+
|
|
76
|
+
The optional `$ttl` parameter sets the maximum time-to-live in seconds
|
|
77
|
+
for this cache item. If this parameter is omitted (or `null`), the item
|
|
78
|
+
will stay in the cache for as long as the underlying implementation
|
|
79
|
+
supports. Trying to access an expired cache item results in a cache miss,
|
|
80
|
+
see also [`get()`](#get).
|
|
81
|
+
|
|
82
|
+
```php
|
|
83
|
+
$cache->set('foo', 'bar', 60);
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
This example eventually sets the value of the key `foo` to `bar`. If it
|
|
87
|
+
already exists, it is overridden.
|
|
88
|
+
|
|
89
|
+
This interface does not enforce any particular TTL resolution, so special
|
|
90
|
+
care may have to be taken if you rely on very high precision with
|
|
91
|
+
millisecond accuracy or below. Cache implementations SHOULD work on a
|
|
92
|
+
best effort basis and SHOULD provide at least second accuracy unless
|
|
93
|
+
otherwise noted. Many existing cache implementations are known to provide
|
|
94
|
+
microsecond or millisecond accuracy, but it's generally not recommended
|
|
95
|
+
to rely on this high precision.
|
|
96
|
+
|
|
97
|
+
This interface suggests that cache implementations SHOULD use a monotonic
|
|
98
|
+
time source if available. Given that a monotonic time source is only
|
|
99
|
+
available as of PHP 7.3 by default, cache implementations MAY fall back
|
|
100
|
+
to using wall-clock time.
|
|
101
|
+
While this does not affect many common use cases, this is an important
|
|
102
|
+
distinction for programs that rely on a high time precision or on systems
|
|
103
|
+
that are subject to discontinuous time adjustments (time jumps).
|
|
104
|
+
This means that if you store a cache item with a TTL of 30s and then
|
|
105
|
+
adjust your system time forward by 20s, the cache item SHOULD still
|
|
106
|
+
expire in 30s.
|
|
107
|
+
|
|
108
|
+
#### delete()
|
|
109
|
+
|
|
110
|
+
The `delete(string $key): PromiseInterface<bool>` method can be used to
|
|
111
|
+
delete an item from the cache.
|
|
112
|
+
|
|
113
|
+
This method will resolve with `true` on success or `false` when an error
|
|
114
|
+
occurs. When no item for `$key` is found in the cache, it also resolves
|
|
115
|
+
to `true`. If the cache implementation has to go over the network to
|
|
116
|
+
delete it, it may take a while.
|
|
117
|
+
|
|
118
|
+
```php
|
|
119
|
+
$cache->delete('foo');
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
This example eventually deletes the key `foo` from the cache. As with
|
|
123
|
+
`set()`, this may not happen instantly and a promise is returned to
|
|
124
|
+
provide guarantees whether or not the item has been removed from cache.
|
|
125
|
+
|
|
126
|
+
#### getMultiple()
|
|
127
|
+
|
|
128
|
+
The `getMultiple(string[] $keys, mixed $default = null): PromiseInterface<array>` method can be used to
|
|
129
|
+
retrieve multiple cache items by their unique keys.
|
|
130
|
+
|
|
131
|
+
This method will resolve with an array of cached values on success or with the
|
|
132
|
+
given `$default` value when an item can not be found or when an error occurs.
|
|
133
|
+
Similarly, an expired cache item (once the time-to-live is expired) is
|
|
134
|
+
considered a cache miss.
|
|
135
|
+
|
|
136
|
+
```php
|
|
137
|
+
$cache->getMultiple(array('name', 'age'))->then(function (array $values) {
|
|
138
|
+
$name = $values['name'] ?? 'User';
|
|
139
|
+
$age = $values['age'] ?? 'n/a';
|
|
140
|
+
|
|
141
|
+
echo $name . ' is ' . $age . PHP_EOL;
|
|
142
|
+
});
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
This example fetches the cache items for the `name` and `age` keys and
|
|
146
|
+
prints some example output. You can use any of the composition provided
|
|
147
|
+
by [promises](https://github.com/reactphp/promise).
|
|
148
|
+
|
|
149
|
+
#### setMultiple()
|
|
150
|
+
|
|
151
|
+
The `setMultiple(array $values, ?float $ttl = null): PromiseInterface<bool>` method can be used to
|
|
152
|
+
persist a set of key => value pairs in the cache, with an optional TTL.
|
|
153
|
+
|
|
154
|
+
This method will resolve with `true` on success or `false` when an error
|
|
155
|
+
occurs. If the cache implementation has to go over the network to store
|
|
156
|
+
it, it may take a while.
|
|
157
|
+
|
|
158
|
+
The optional `$ttl` parameter sets the maximum time-to-live in seconds
|
|
159
|
+
for these cache items. If this parameter is omitted (or `null`), these items
|
|
160
|
+
will stay in the cache for as long as the underlying implementation
|
|
161
|
+
supports. Trying to access an expired cache items results in a cache miss,
|
|
162
|
+
see also [`getMultiple()`](#getmultiple).
|
|
163
|
+
|
|
164
|
+
```php
|
|
165
|
+
$cache->setMultiple(array('foo' => 1, 'bar' => 2), 60);
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
This example eventually sets the list of values - the key `foo` to `1` value
|
|
169
|
+
and the key `bar` to `2`. If some of the keys already exist, they are overridden.
|
|
170
|
+
|
|
171
|
+
#### deleteMultiple()
|
|
172
|
+
|
|
173
|
+
The `setMultiple(string[] $keys): PromiseInterface<bool>` method can be used to
|
|
174
|
+
delete multiple cache items in a single operation.
|
|
175
|
+
|
|
176
|
+
This method will resolve with `true` on success or `false` when an error
|
|
177
|
+
occurs. When no items for `$keys` are found in the cache, it also resolves
|
|
178
|
+
to `true`. If the cache implementation has to go over the network to
|
|
179
|
+
delete it, it may take a while.
|
|
180
|
+
|
|
181
|
+
```php
|
|
182
|
+
$cache->deleteMultiple(array('foo', 'bar, 'baz'));
|
|
183
|
+
```
|
|
184
|
+
|
|
185
|
+
This example eventually deletes keys `foo`, `bar` and `baz` from the cache.
|
|
186
|
+
As with `setMultiple()`, this may not happen instantly and a promise is returned to
|
|
187
|
+
provide guarantees whether or not the item has been removed from cache.
|
|
188
|
+
|
|
189
|
+
#### clear()
|
|
190
|
+
|
|
191
|
+
The `clear(): PromiseInterface<bool>` method can be used to
|
|
192
|
+
wipe clean the entire cache.
|
|
193
|
+
|
|
194
|
+
This method will resolve with `true` on success or `false` when an error
|
|
195
|
+
occurs. If the cache implementation has to go over the network to
|
|
196
|
+
delete it, it may take a while.
|
|
197
|
+
|
|
198
|
+
```php
|
|
199
|
+
$cache->clear();
|
|
200
|
+
```
|
|
201
|
+
|
|
202
|
+
This example eventually deletes all keys from the cache. As with `deleteMultiple()`,
|
|
203
|
+
this may not happen instantly and a promise is returned to provide guarantees
|
|
204
|
+
whether or not all the items have been removed from cache.
|
|
205
|
+
|
|
206
|
+
#### has()
|
|
207
|
+
|
|
208
|
+
The `has(string $key): PromiseInterface<bool>` method can be used to
|
|
209
|
+
determine whether an item is present in the cache.
|
|
210
|
+
|
|
211
|
+
This method will resolve with `true` on success or `false` when no item can be found
|
|
212
|
+
or when an error occurs. Similarly, an expired cache item (once the time-to-live
|
|
213
|
+
is expired) is considered a cache miss.
|
|
214
|
+
|
|
215
|
+
```php
|
|
216
|
+
$cache
|
|
217
|
+
->has('foo')
|
|
218
|
+
->then('var_dump');
|
|
219
|
+
```
|
|
220
|
+
|
|
221
|
+
This example checks if the value of the key `foo` is set in the cache and passes
|
|
222
|
+
the result to the `var_dump` function. You can use any of the composition provided by
|
|
223
|
+
[promises](https://github.com/reactphp/promise).
|
|
224
|
+
|
|
225
|
+
NOTE: It is recommended that has() is only to be used for cache warming type purposes
|
|
226
|
+
and not to be used within your live applications operations for get/set, as this method
|
|
227
|
+
is subject to a race condition where your has() will return true and immediately after,
|
|
228
|
+
another script can remove it making the state of your app out of date.
|
|
229
|
+
|
|
230
|
+
### ArrayCache
|
|
231
|
+
|
|
232
|
+
The `ArrayCache` provides an in-memory implementation of the [`CacheInterface`](#cacheinterface).
|
|
233
|
+
|
|
234
|
+
```php
|
|
235
|
+
$cache = new ArrayCache();
|
|
236
|
+
|
|
237
|
+
$cache->set('foo', 'bar');
|
|
238
|
+
```
|
|
239
|
+
|
|
240
|
+
Its constructor accepts an optional `?int $limit` parameter to limit the
|
|
241
|
+
maximum number of entries to store in the LRU cache. If you add more
|
|
242
|
+
entries to this instance, it will automatically take care of removing
|
|
243
|
+
the one that was least recently used (LRU).
|
|
244
|
+
|
|
245
|
+
For example, this snippet will overwrite the first value and only store
|
|
246
|
+
the last two entries:
|
|
247
|
+
|
|
248
|
+
```php
|
|
249
|
+
$cache = new ArrayCache(2);
|
|
250
|
+
|
|
251
|
+
$cache->set('foo', '1');
|
|
252
|
+
$cache->set('bar', '2');
|
|
253
|
+
$cache->set('baz', '3');
|
|
254
|
+
```
|
|
255
|
+
|
|
256
|
+
This cache implementation is known to rely on wall-clock time to schedule
|
|
257
|
+
future cache expiration times when using any version before PHP 7.3,
|
|
258
|
+
because a monotonic time source is only available as of PHP 7.3 (`hrtime()`).
|
|
259
|
+
While this does not affect many common use cases, this is an important
|
|
260
|
+
distinction for programs that rely on a high time precision or on systems
|
|
261
|
+
that are subject to discontinuous time adjustments (time jumps).
|
|
262
|
+
This means that if you store a cache item with a TTL of 30s on PHP < 7.3
|
|
263
|
+
and then adjust your system time forward by 20s, the cache item may
|
|
264
|
+
expire in 10s. See also [`set()`](#set) for more details.
|
|
265
|
+
|
|
266
|
+
## Common usage
|
|
267
|
+
|
|
268
|
+
### Fallback get
|
|
269
|
+
|
|
270
|
+
A common use case of caches is to attempt fetching a cached value and as a
|
|
271
|
+
fallback retrieve it from the original data source if not found. Here is an
|
|
272
|
+
example of that:
|
|
273
|
+
|
|
274
|
+
```php
|
|
275
|
+
$cache
|
|
276
|
+
->get('foo')
|
|
277
|
+
->then(function ($result) {
|
|
278
|
+
if ($result === null) {
|
|
279
|
+
return getFooFromDb();
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
return $result;
|
|
283
|
+
})
|
|
284
|
+
->then('var_dump');
|
|
285
|
+
```
|
|
286
|
+
|
|
287
|
+
First an attempt is made to retrieve the value of `foo`. A callback function is
|
|
288
|
+
registered that will call `getFooFromDb` when the resulting value is null.
|
|
289
|
+
`getFooFromDb` is a function (can be any PHP callable) that will be called if the
|
|
290
|
+
key does not exist in the cache.
|
|
291
|
+
|
|
292
|
+
`getFooFromDb` can handle the missing key by returning a promise for the
|
|
293
|
+
actual value from the database (or any other data source). As a result, this
|
|
294
|
+
chain will correctly fall back, and provide the value in both cases.
|
|
295
|
+
|
|
296
|
+
### Fallback get and set
|
|
297
|
+
|
|
298
|
+
To expand on the fallback get example, often you want to set the value on the
|
|
299
|
+
cache after fetching it from the data source.
|
|
300
|
+
|
|
301
|
+
```php
|
|
302
|
+
$cache
|
|
303
|
+
->get('foo')
|
|
304
|
+
->then(function ($result) {
|
|
305
|
+
if ($result === null) {
|
|
306
|
+
return $this->getAndCacheFooFromDb();
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
return $result;
|
|
310
|
+
})
|
|
311
|
+
->then('var_dump');
|
|
312
|
+
|
|
313
|
+
public function getAndCacheFooFromDb()
|
|
314
|
+
{
|
|
315
|
+
return $this->db
|
|
316
|
+
->get('foo')
|
|
317
|
+
->then(array($this, 'cacheFooFromDb'));
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
public function cacheFooFromDb($foo)
|
|
321
|
+
{
|
|
322
|
+
$this->cache->set('foo', $foo);
|
|
323
|
+
|
|
324
|
+
return $foo;
|
|
325
|
+
}
|
|
326
|
+
```
|
|
327
|
+
|
|
328
|
+
By using chaining you can easily conditionally cache the value if it is
|
|
329
|
+
fetched from the database.
|
|
330
|
+
|
|
331
|
+
## Install
|
|
332
|
+
|
|
333
|
+
The recommended way to install this library is [through Composer](https://getcomposer.org).
|
|
334
|
+
[New to Composer?](https://getcomposer.org/doc/00-intro.md)
|
|
335
|
+
|
|
336
|
+
This project follows [SemVer](https://semver.org/).
|
|
337
|
+
This will install the latest supported version:
|
|
338
|
+
|
|
339
|
+
```bash
|
|
340
|
+
composer require react/cache:^1.2
|
|
341
|
+
```
|
|
342
|
+
|
|
343
|
+
See also the [CHANGELOG](CHANGELOG.md) for details about version upgrades.
|
|
344
|
+
|
|
345
|
+
This project aims to run on any platform and thus does not require any PHP
|
|
346
|
+
extensions and supports running on legacy PHP 5.3 through current PHP 8+ and
|
|
347
|
+
HHVM.
|
|
348
|
+
It's *highly recommended to use PHP 7+* for this project.
|
|
349
|
+
|
|
350
|
+
## Tests
|
|
351
|
+
|
|
352
|
+
To run the test suite, you first need to clone this repo and then install all
|
|
353
|
+
dependencies [through Composer](https://getcomposer.org):
|
|
354
|
+
|
|
355
|
+
```bash
|
|
356
|
+
composer install
|
|
357
|
+
```
|
|
358
|
+
|
|
359
|
+
To run the test suite, go to the project root and run:
|
|
360
|
+
|
|
361
|
+
```bash
|
|
362
|
+
vendor/bin/phpunit
|
|
363
|
+
```
|
|
364
|
+
|
|
365
|
+
## License
|
|
366
|
+
|
|
367
|
+
MIT, see [LICENSE file](LICENSE).
|