forked from a64f7bb4-7358-4778-9fbe-3b882c34cc1d/v1
134 lines
3.1 KiB
PHP
134 lines
3.1 KiB
PHP
<?php declare(strict_types=1);
|
|
/**
|
|
* This file is part of the Phootwork package.
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*
|
|
* @license MIT License
|
|
* @copyright Thomas Gossmann
|
|
*/
|
|
namespace phootwork\lang\parts;
|
|
|
|
use phootwork\lang\inflector\Inflector;
|
|
use phootwork\lang\inflector\InflectorInterface;
|
|
|
|
trait CheckerPart {
|
|
abstract protected function getString(): string;
|
|
|
|
/**
|
|
* Checks if the string is empty
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isEmpty(): bool {
|
|
return empty($this->getString());
|
|
}
|
|
|
|
/**
|
|
* Check if the string contains only alphanumeric characters.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isAlphanumeric(): bool {
|
|
return ctype_alnum($this->getString());
|
|
}
|
|
|
|
/**
|
|
* Check if the string contains only alphanumeric characters.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isAlphabetic(): bool {
|
|
return ctype_alpha($this->getString());
|
|
}
|
|
|
|
/**
|
|
* Check if the string contains only numeric characters.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isNumeric(): bool {
|
|
return ctype_digit($this->getString());
|
|
}
|
|
|
|
/**
|
|
* Check if the string contains only characters which are not whitespace or an alphanumeric.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isPunctuation(): bool {
|
|
return ctype_punct($this->getString());
|
|
}
|
|
|
|
/**
|
|
* Check if the string contains only space characters.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isSpace(): bool {
|
|
return ctype_space($this->getString());
|
|
}
|
|
|
|
/**
|
|
* Check if the string contains only lower case characters.
|
|
*
|
|
* Spaces are considered non-lowercase characters, so lowercase strings with multiple words, separated by spaces,
|
|
* return false. E.g.:
|
|
*
|
|
* <code>
|
|
* $text = new Text('lowercase multi words string');<br>
|
|
* var_dump($text->isLowercase()); // false
|
|
* </code>
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isLowerCase(): bool {
|
|
return ctype_lower($this->getString());
|
|
}
|
|
|
|
/**
|
|
* Check if the string contains only upper case characters.
|
|
*
|
|
* Spaces are considered non-uppercase characters, so uppercase strings with multiple words, separated by spaces,
|
|
* return false. E.g.:
|
|
*
|
|
* <code>
|
|
* $text = new Text('UPPERCASE MULTI WORDS STRING'); <br>
|
|
* var_dump($text->isUppercase()); // false
|
|
* </code>
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isUpperCase(): bool {
|
|
return ctype_upper($this->getString());
|
|
}
|
|
|
|
/**
|
|
* Check if a string is singular form.
|
|
*
|
|
* @param InflectorInterface|null $pluralizer
|
|
* A custom pluralizer. Default is the Inflector
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isSingular(?InflectorInterface $pluralizer = null): bool {
|
|
$pluralizer = $pluralizer ?? new Inflector();
|
|
|
|
return $pluralizer->isSingular($this->getString());
|
|
}
|
|
|
|
/**
|
|
* Check if a string is plural form.
|
|
*
|
|
* @param InflectorInterface|null $pluralizer
|
|
* A custom pluralizer. Default is the Inflector
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isPlural(?InflectorInterface $pluralizer = null): bool {
|
|
$pluralizer = $pluralizer ?? new Inflector();
|
|
|
|
return $pluralizer->isPlural($this->getString());
|
|
}
|
|
}
|