2018-05-15 00:04:15 +03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Nominatim\Token;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A standard word token.
|
|
|
|
*/
|
|
|
|
class Word
|
|
|
|
{
|
2018-05-15 00:23:38 +03:00
|
|
|
/// Database word id, if applicable.
|
2021-07-17 21:24:33 +03:00
|
|
|
private $iId;
|
2018-05-15 00:23:38 +03:00
|
|
|
/// Number of appearances in the database.
|
2021-07-17 21:24:33 +03:00
|
|
|
private $iSearchNameCount;
|
2020-11-25 13:44:25 +03:00
|
|
|
/// Number of terms in the word.
|
2021-07-17 21:24:33 +03:00
|
|
|
private $iTermCount;
|
2018-05-15 00:04:15 +03:00
|
|
|
|
2021-07-13 17:54:51 +03:00
|
|
|
public function __construct($iId, $iSearchNameCount, $iTermCount)
|
2018-05-15 00:04:15 +03:00
|
|
|
{
|
|
|
|
$this->iId = $iId;
|
|
|
|
$this->iSearchNameCount = $iSearchNameCount;
|
2020-11-25 13:44:25 +03:00
|
|
|
$this->iTermCount = $iTermCount;
|
2018-05-15 00:04:15 +03:00
|
|
|
}
|
|
|
|
|
2021-07-17 21:24:33 +03:00
|
|
|
public function getId()
|
|
|
|
{
|
|
|
|
return $this->iId;
|
|
|
|
}
|
|
|
|
|
2021-07-17 23:01:35 +03:00
|
|
|
/**
|
|
|
|
* Check if the token can be added to the given search.
|
|
|
|
* Derive new searches by adding this token to an existing search.
|
|
|
|
*
|
|
|
|
* @param object $oSearch Partial search description derived so far.
|
|
|
|
* @param object $oPosition Description of the token position within
|
|
|
|
the query.
|
|
|
|
*
|
|
|
|
* @return True if the token is compatible with the search configuration
|
|
|
|
* given the position.
|
|
|
|
*/
|
|
|
|
public function isExtendable($oSearch, $oPosition)
|
|
|
|
{
|
|
|
|
return !$oPosition->isPhrase('country');
|
|
|
|
}
|
|
|
|
|
2021-07-17 21:24:33 +03:00
|
|
|
/**
|
|
|
|
* Derive new searches by adding this token to an existing search.
|
|
|
|
*
|
|
|
|
* @param object $oSearch Partial search description derived so far.
|
|
|
|
* @param object $oPosition Description of the token position within
|
|
|
|
the query.
|
|
|
|
*
|
|
|
|
* @return SearchDescription[] List of derived search descriptions.
|
|
|
|
*/
|
|
|
|
public function extendSearch($oSearch, $oPosition)
|
|
|
|
{
|
|
|
|
// Full words can only be a name if they appear at the beginning
|
|
|
|
// of the phrase. In structured search the name must forcably in
|
|
|
|
// the first phrase. In unstructured search it may be in a later
|
|
|
|
// phrase when the first phrase is a house number.
|
|
|
|
if ($oSearch->hasName()
|
|
|
|
|| !($oPosition->isFirstPhrase() || $oPosition->isPhrase(''))
|
|
|
|
) {
|
|
|
|
if ($this->iTermCount > 1
|
|
|
|
&& ($oPosition->isPhrase('') || !$oPosition->isFirstPhrase())
|
|
|
|
) {
|
|
|
|
$oNewSearch = $oSearch->clone(1);
|
|
|
|
$oNewSearch->addAddressToken($this->iId);
|
|
|
|
|
|
|
|
return array($oNewSearch);
|
|
|
|
}
|
|
|
|
} elseif (!$oSearch->hasName(true)) {
|
|
|
|
$oNewSearch = $oSearch->clone(1);
|
2021-07-18 17:52:37 +03:00
|
|
|
$oNewSearch->addNameToken(
|
|
|
|
$this->iId,
|
|
|
|
CONST_Search_NameOnlySearchFrequencyThreshold
|
2021-07-17 21:24:33 +03:00
|
|
|
&& $this->iSearchNameCount
|
|
|
|
< CONST_Search_NameOnlySearchFrequencyThreshold
|
2021-07-18 17:52:37 +03:00
|
|
|
);
|
2021-07-17 21:24:33 +03:00
|
|
|
|
|
|
|
return array($oNewSearch);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
|
2018-05-15 00:04:15 +03:00
|
|
|
public function debugInfo()
|
|
|
|
{
|
|
|
|
return array(
|
|
|
|
'ID' => $this->iId,
|
|
|
|
'Type' => 'word',
|
|
|
|
'Info' => array(
|
2021-07-13 17:54:51 +03:00
|
|
|
'count' => $this->iSearchNameCount,
|
|
|
|
'terms' => $this->iTermCount
|
2018-05-15 00:04:15 +03:00
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2021-07-17 21:24:33 +03:00
|
|
|
|
|
|
|
public function debugCode()
|
|
|
|
{
|
|
|
|
return 'W';
|
|
|
|
}
|
2018-05-15 00:04:15 +03:00
|
|
|
}
|