]> git.openstreetmap.org Git - nominatim.git/blobdiff - lib-php/TokenCountry.php
Merge remote-tracking branch 'upstream/master'
[nominatim.git] / lib-php / TokenCountry.php
index 917ed9d25867d55834003aaf3e53720155ec0ed7..ab84c388edf00e9269de3dce040505b08eb6b51a 100644 (file)
@@ -23,6 +23,24 @@ class Country
         return $this->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->hasCountry()
+               && $oPosition->maybePhrase('country')
+               && $oSearch->getContext()->isCountryApplicable($this->sCountryCode);
+    }
+
     /**
      * Derive new searches by adding this token to an existing search.
      *
@@ -34,10 +52,6 @@ class Country
      */
     public function extendSearch($oSearch, $oPosition)
     {
-        if ($oSearch->hasCountry() || !$oPosition->maybePhrase('country')) {
-            return array();
-        }
-
         $oNewSearch = $oSearch->clone($oPosition->isLastToken() ? 1 : 6);
         $oNewSearch->setCountry($this->sCountryCode);