aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorFatih Kızmaz <barka_21@hotmail.com>2022-05-16 18:12:36 +0300
committerGitHub <noreply@github.com>2022-05-16 18:12:36 +0300
commit2874b1134189634853c3afaaf46c045f66d51ab9 (patch)
tree552c8bdce9ae3a78427c7abc49e9ed18aaf3002c /src
parente21d59c9def9f25bc6a7c3fbd41e2e126d68b1df (diff)
Small support for arrays => min, max and avg funcs accept array argument. (handwritten arrays not supported yet, can be used for array variables or functions returning an array) (#107)
invalid expression -> "max([1,2,3])" valid expression -> "max($ages_arr)" valid expression -> "max(ages_arr())"
Diffstat (limited to 'src')
-rw-r--r--src/NXP/MathExecutor.php34
1 files changed, 29 insertions, 5 deletions
diff --git a/src/NXP/MathExecutor.php b/src/NXP/MathExecutor.php
index b3e539b..e7e8259 100644
--- a/src/NXP/MathExecutor.php
+++ b/src/NXP/MathExecutor.php
@@ -16,6 +16,7 @@ use NXP\Classes\Operator;
use NXP\Classes\Token;
use NXP\Classes\Tokenizer;
use NXP\Exception\DivisionByZeroException;
+use NXP\Exception\IncorrectNumberOfFunctionParametersException;
use NXP\Exception\MathExecutorException;
use NXP\Exception\UnknownVariableException;
use ReflectionException;
@@ -390,7 +391,18 @@ class MathExecutor
'atan2' => static fn($arg1, $arg2) => \atan2($arg1, $arg2),
'atanh' => static fn($arg) => \atanh($arg),
'atn' => static fn($arg) => \atan($arg),
- 'avg' => static fn($arg1, $arg2) => ($arg1 + $arg2) / 2,
+ 'avg' => static function($arg1, $args) {
+ if (\is_array($arg1)){
+ return \array_sum($arg1) / \count($arg1);
+ }
+
+ if (0 === \count($args)){
+ throw new IncorrectNumberOfFunctionParametersException();
+ }
+ $args = [$arg1, ...$args];
+
+ return \array_sum($args) / \count($args);
+ },
'bindec' => static fn($arg) => \bindec($arg),
'ceil' => static fn($arg) => \ceil($arg),
'cos' => static fn($arg) => \cos($arg),
@@ -431,8 +443,20 @@ class MathExecutor
'log' => static fn($arg) => \log($arg),
'log10' => static fn($arg) => \log10($arg),
'log1p' => static fn($arg) => \log1p($arg),
- 'max' => static fn($arg1, $arg2, ...$args) => \max($arg1, $arg2, ...$args),
- 'min' => static fn($arg1, $arg2, ...$args) => \min($arg1, $arg2, ...$args),
+ 'max' => static function($arg1, ...$args) {
+ if (! \is_array($arg1) && 0 === \count($args)){
+ throw new IncorrectNumberOfFunctionParametersException();
+ }
+
+ return \max($arg1, ...$args);
+ },
+ 'min' => static function($arg1, ...$args) {
+ if (! \is_array($arg1) && 0 === \count($args)){
+ throw new IncorrectNumberOfFunctionParametersException();
+ }
+
+ return \min($arg1, ...$args);
+ },
'octdec' => static fn($arg) => \octdec($arg),
'pi' => static fn() => M_PI,
'pow' => static fn($arg1, $arg2) => $arg1 ** $arg2,
@@ -468,10 +492,10 @@ class MathExecutor
*/
protected function defaultVarValidation(string $variable, $value) : void
{
- if (! \is_scalar($value) && null !== $value) {
+ if (! \is_scalar($value) && ! \is_array($value) && null !== $value) {
$type = \gettype($value);
- throw new MathExecutorException("Variable ({$variable}) type ({$type}) is not scalar");
+ throw new MathExecutorException("Variable ({$variable}) type ({$type}) is not scalar or array!");
}
}
}