Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
tipuloidea
/
back
/
vendor
/
staabm
/
side-effects-detector
:
README.md
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
Analyzes php-code for side-effects. When code has no side-effects it can e.g. be used with `eval($code)` in the same process without interfering. [Side-effects are classified](https://github.com/staabm/side-effects-detector/blob/main/lib/SideEffect.php) into categories to filter them more easily depending on your use-case. ## Install `composer require staabm/side-effects-detector` ## Usage Example: ```php use staabm\SideEffectsDetector\SideEffectsDetector; $code = '<?php version_compare(PHP_VERSION, "8.0", ">=") or echo("skip because attributes are only available since PHP 8.0");'; $detector = new SideEffectsDetector(); // [SideEffect::STANDARD_OUTPUT] var_dump($detector->getSideEffects($code)); ``` In case functions are called which are not known to have side-effects - e.g. userland functions - `null` is returned. ```php use staabm\SideEffectsDetector\SideEffectsDetector; $code = '<?php userlandFunction();'; $detector = new SideEffectsDetector(); // [SideEffect::MAYBE] var_dump($detector->getSideEffects($code)); ``` Code might have multiple side-effects: ```php use staabm\SideEffectsDetector\SideEffectsDetector; $code = '<?php include "some-file.php"; echo "hello world"; exit(1);'; $detector = new SideEffectsDetector(); // [SideEffect::SCOPE_POLLUTION, SideEffect::STANDARD_OUTPUT, SideEffect::PROCESS_EXIT] var_dump($detector->getSideEffects($code)); ``` ## Disclaimer Non goals are: - find the best possible answer for all cases - add runtime dependencies If you are in need of a fully fledged side-effect analysis, use more advanced tools like PHPStan. Look at the test-suite to get an idea of [supported use-cases](https://github.com/staabm/side-effects-detector/blob/main/tests/SideEffectsDetectorTest.php).