X-Git-Url: https://git.openstreetmap.org./nominatim.git/blobdiff_plain/a48ebd9b477318bc5fdb44d7dc6bbf695911a4b9..b79d5494f915b1b1e1dc4ce12b80680f0b7c53b3:/lib-php/TokenSpecialTerm.php?ds=sidebyside diff --git a/lib-php/TokenSpecialTerm.php b/lib-php/TokenSpecialTerm.php index 89dfa026..475ae71b 100644 --- a/lib-php/TokenSpecialTerm.php +++ b/lib-php/TokenSpecialTerm.php @@ -1,4 +1,12 @@ iId; } + /** + * 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 !$oSearch->hasOperator() + && $oPosition->isPhrase('') + && ($this->iOperator != \Nominatim\Operator::NONE + || (!$oSearch->hasAddress() && !$oSearch->hasHousenumber() && !$oSearch->hasCountry())); + } + /** * Derive new searches by adding this token to an existing search. * @@ -42,23 +69,31 @@ class SpecialTerm */ public function extendSearch($oSearch, $oPosition) { - if ($oSearch->hasOperator() || !$oPosition->isPhrase('')) { - return array(); - } - - $iSearchCost = 2; + $iSearchCost = 0; $iOp = $this->iOperator; if ($iOp == \Nominatim\Operator::NONE) { - if ($oSearch->hasName() || $oSearch->getContext()->isBoundedSearch()) { + if ($oPosition->isFirstToken() + || $oSearch->hasName() + || $oSearch->getContext()->isBoundedSearch() + ) { $iOp = \Nominatim\Operator::NAME; + $iSearchCost += 3; } else { $iOp = \Nominatim\Operator::NEAR; + $iSearchCost += 4; + if (!$oPosition->isFirstToken()) { + $iSearchCost += 3; + } } + } elseif ($oPosition->isFirstToken()) { $iSearchCost += 2; - } elseif (!$oPosition->isFirstToken() && !$oPosition->isLastToken()) { - $iSearchCost += 2; + } elseif ($oPosition->isLastToken()) { + $iSearchCost += 4; + } else { + $iSearchCost += 6; } + if ($oSearch->hasHousenumber()) { $iSearchCost ++; }