Files
faveo/vendor/giggsey/libphonenumber-for-php/src/PhoneNumberMatch.php
RafficMohammed da241bacb6 updated-packages
2023-01-08 00:13:22 +05:30

88 lines
1.9 KiB
PHP

<?php
namespace libphonenumber;
class PhoneNumberMatch
{
/**
* The start index into the text.
* @var int
*/
private $start;
/**
* The raw substring matched.
* @var string
*/
private $rawString;
/**
* The matched phone number.
* @var PhoneNumber
*/
private $number;
/**
* Creates a new match
*
* @param int $start The start index into the target text
* @param string $rawString The matched substring of the target text
* @param PhoneNumber $number The matched phone number
*/
public function __construct($start, $rawString, PhoneNumber $number)
{
if ($start < 0) {
throw new \InvalidArgumentException('Start index must be >= 0.');
}
if ($rawString === null) {
throw new \InvalidArgumentException('$rawString must be a string');
}
$this->start = $start;
$this->rawString = $rawString;
$this->number = $number;
}
/**
* Returns the phone number matched by the receiver.
* @return PhoneNumber
*/
public function number()
{
return $this->number;
}
/**
* Returns the start index of the matched phone number within the searched text.
* @return int
*/
public function start()
{
return $this->start;
}
/**
* Returns the exclusive end index of the matched phone number within the searched text.
* @return int
*/
public function end()
{
return $this->start + \mb_strlen($this->rawString);
}
/**
* Returns the raw string matched as a phone number in the searched text.
* @return string
*/
public function rawString()
{
return $this->rawString;
}
public function __toString()
{
return "PhoneNumberMatch [{$this->start()},{$this->end()}) {$this->rawString}";
}
}