94 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			94 lines
		
	
	
		
			2.2 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\Text;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Text methods to perform string and Text object comparison
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @author Thomas Gossmann
							 | 
						||
| 
								 | 
							
								 * @author Cristiano Cinotti
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								trait ComparisonPart {
							 | 
						||
| 
								 | 
							
									abstract protected function getString(): string;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									/**
							 | 
						||
| 
								 | 
							
									 * Compares this string to another
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @param mixed $comparison
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @return int
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @see \phootwork\lang\Comparable::compareTo()
							 | 
						||
| 
								 | 
							
									 */
							 | 
						||
| 
								 | 
							
									public function compareTo(mixed $comparison): int {
							 | 
						||
| 
								 | 
							
										if (is_string($comparison) || $comparison instanceof Text) {
							 | 
						||
| 
								 | 
							
											return $this->compare($comparison);
							 | 
						||
| 
								 | 
							
										}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
										throw new \InvalidArgumentException('`compareTo` method can accept only strings or Text objects.');
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									/**
							 | 
						||
| 
								 | 
							
									 * Compares this string to another string, ignoring the case
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @param string|Text $compare
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @return int Return Values:<br>
							 | 
						||
| 
								 | 
							
									 * 		< 0 if the object is less than comparison<br>
							 | 
						||
| 
								 | 
							
									 *  	> 0 if the object is greater than comparison<br>
							 | 
						||
| 
								 | 
							
									 * 		0 if they are equal.
							 | 
						||
| 
								 | 
							
									 */
							 | 
						||
| 
								 | 
							
									public function compareCaseInsensitive(string|Text $compare): int {
							 | 
						||
| 
								 | 
							
										return $this->compare($compare, 'strcasecmp');
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									/**
							 | 
						||
| 
								 | 
							
									 * Compares this string to another
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @param string|Text   $compare string to compare to
							 | 
						||
| 
								 | 
							
									 * @param callable|null $callback
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @return int
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @psalm-suppress MixedInferredReturnType
							 | 
						||
| 
								 | 
							
									 */
							 | 
						||
| 
								 | 
							
									public function compare(string|Text $compare, ?callable $callback = null): int {
							 | 
						||
| 
								 | 
							
										if ($callback === null) {
							 | 
						||
| 
								 | 
							
											$callback = 'strcmp';
							 | 
						||
| 
								 | 
							
										}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
										return $callback($this->getString(), (string) $compare);
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									/**
							 | 
						||
| 
								 | 
							
									 * Checks whether the string and the given object are equal
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @param string|Text $string
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @return bool
							 | 
						||
| 
								 | 
							
									 */
							 | 
						||
| 
								 | 
							
									public function equals(string|Text $string): bool {
							 | 
						||
| 
								 | 
							
										return $this->compareTo($string) === 0;
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									/**
							 | 
						||
| 
								 | 
							
									 * Checks whether the string and the given object are equal ignoring the case
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @param string|Text $string
							 | 
						||
| 
								 | 
							
									 *
							 | 
						||
| 
								 | 
							
									 * @return bool
							 | 
						||
| 
								 | 
							
									 */
							 | 
						||
| 
								 | 
							
									public function equalsIgnoreCase(string|Text $string): bool {
							 | 
						||
| 
								 | 
							
										return $this->compareCaseInsensitive($string) === 0;
							 | 
						||
| 
								 | 
							
									}
							 | 
						||
| 
								 | 
							
								}
							 |