2017-09-26 16:45:41 -04:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace JKingWeb\Arsse\Misc;
|
|
|
|
|
|
|
|
class ValueInfo {
|
|
|
|
// universal
|
|
|
|
const VALID = 1 << 0;
|
|
|
|
const NULL = 1 << 1;
|
|
|
|
// integers
|
|
|
|
const ZERO = 1 << 2;
|
|
|
|
const NEG = 1 << 3;
|
|
|
|
// strings
|
|
|
|
const EMPTY = 1 << 2;
|
|
|
|
const WHITE = 1 << 3;
|
|
|
|
|
2017-09-28 09:01:43 -04:00
|
|
|
public static function int($value): int {
|
2017-09-26 16:45:41 -04:00
|
|
|
$out = 0;
|
|
|
|
if (is_null($value)) {
|
2017-09-27 22:25:45 -04:00
|
|
|
// check if the input is null
|
|
|
|
return self::NULL;
|
2017-09-28 08:55:47 -04:00
|
|
|
} elseif (is_string($value) || (is_object($value) && method_exists($value, "__toString"))) {
|
|
|
|
$value = (string) $value;
|
2017-09-27 22:25:45 -04:00
|
|
|
// normalize a string an integer or float if possible
|
2017-09-28 08:55:47 -04:00
|
|
|
if (!strlen($value)) {
|
2017-09-27 22:25:45 -04:00
|
|
|
// the empty string is equivalent to null when evaluating an integer
|
|
|
|
return self::NULL;
|
|
|
|
} elseif (filter_var($value, \FILTER_VALIDATE_FLOAT) !== false && !fmod((float) $value, 1)) {
|
|
|
|
// an integral float is acceptable
|
|
|
|
$value = (int) $value;
|
|
|
|
} else {
|
|
|
|
return $out;
|
2017-09-26 16:45:41 -04:00
|
|
|
}
|
2017-09-27 22:25:45 -04:00
|
|
|
} elseif (is_float($value) && !fmod($value, 1)) {
|
|
|
|
// an integral float is acceptable
|
|
|
|
$value = (int) $value;
|
|
|
|
} elseif (!is_int($value)) {
|
|
|
|
// if the value is not an integer or integral float, stop
|
2017-09-26 16:45:41 -04:00
|
|
|
return $out;
|
|
|
|
}
|
|
|
|
// mark validity
|
|
|
|
$out += self::VALID;
|
|
|
|
// mark zeroness
|
2017-09-28 09:01:43 -04:00
|
|
|
if ($value==0) {
|
2017-09-26 16:45:41 -04:00
|
|
|
$out += self::ZERO;
|
|
|
|
}
|
|
|
|
// mark negativeness
|
|
|
|
if ($value < 0) {
|
|
|
|
$out += self::NEG;
|
|
|
|
}
|
|
|
|
return $out;
|
|
|
|
}
|
|
|
|
|
2017-09-28 09:01:43 -04:00
|
|
|
public static function str($value): int {
|
2017-09-26 16:45:41 -04:00
|
|
|
$out = 0;
|
|
|
|
// check if the input is null
|
|
|
|
if (is_null($value)) {
|
|
|
|
$out += self::NULL;
|
|
|
|
}
|
2017-09-28 08:55:47 -04:00
|
|
|
if (is_object($value) && method_exists($value, "__toString")) {
|
|
|
|
// if the value is an object which has a __toString method, this is acceptable
|
|
|
|
$value = (string) $value;
|
|
|
|
} elseif (!is_scalar($value) || is_bool($value) || (is_float($value) && !is_finite($value))) {
|
|
|
|
// otherwise if the value is not scalar, is a boolean, or is infinity or NaN, it cannot be valid
|
2017-09-26 16:45:41 -04:00
|
|
|
return $out;
|
|
|
|
}
|
|
|
|
// mark validity
|
|
|
|
$out += self::VALID;
|
|
|
|
if (!strlen((string) $value)) {
|
|
|
|
// mark emptiness
|
|
|
|
$out += self::EMPTY;
|
|
|
|
} elseif (!strlen(trim((string) $value))) {
|
|
|
|
// mark whitespacedness
|
|
|
|
$out += self::WHITE;
|
|
|
|
}
|
|
|
|
return $out;
|
|
|
|
}
|
2017-09-27 22:25:45 -04:00
|
|
|
|
2017-09-28 09:01:43 -04:00
|
|
|
public static function id($value, bool $allowNull = false): bool {
|
2017-09-27 22:25:45 -04:00
|
|
|
$info = self::int($value);
|
|
|
|
if ($allowNull && ($info & self::NULL)) { // null (and allowed)
|
|
|
|
return true;
|
|
|
|
} elseif (!($info & self::VALID)) { // not an integer
|
|
|
|
return false;
|
|
|
|
} elseif ($info & self::NEG) { // negative integer
|
|
|
|
return false;
|
|
|
|
} elseif (!$allowNull && ($info & self::ZERO)) { // zero (and not allowed)
|
|
|
|
return false;
|
|
|
|
} else { // non-negative integer
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
2017-09-28 09:01:43 -04:00
|
|
|
}
|