]> git.openstreetmap.org Git - nominatim.git/blobdiff - utils/warm.php
fix postcode search
[nominatim.git] / utils / warm.php
index 72eac27adf254d0597596a66813bff6539e9a71c..68fa751ca6d1d10a01a6ce646eaa30ea2692b3d8 100755 (executable)
@@ -1,64 +1,69 @@
 #!/usr/bin/php -Cq
 <?php
 
-       require_once(dirname(dirname(__FILE__)).'/settings/settings.php');
-       require_once(CONST_BasePath.'/lib/init-cmd.php');
-       ini_set('memory_limit', '800M');
+require_once(dirname(dirname(__FILE__)).'/settings/settings.php');
+require_once(CONST_BasePath.'/lib/init-cmd.php');
+ini_set('memory_limit', '800M');
 
-       $aCMDOptions = array(
-               "Tools to warm nominatim db",
-               array('help', 'h', 0, 1, 0, 0, false, 'Show Help'),
-               array('quiet', 'q', 0, 1, 0, 0, 'bool', 'Quiet output'),
-               array('verbose', 'v', 0, 1, 0, 0, 'bool', 'Verbose output'),
-               array('reverse-only', '', 0, 1, 0, 0, 'bool', 'Warm reverse only'),
-               array('search-only', '', 0, 1, 0, 0, 'bool', 'Warm reverse only'),
-       );
-       getCmdOpt($_SERVER['argv'], $aCMDOptions, $aResult, true, true);
+$aCMDOptions = array(
+                "Tools to warm nominatim db",
+                array('help', 'h', 0, 1, 0, 0, false, 'Show Help'),
+                array('quiet', 'q', 0, 1, 0, 0, 'bool', 'Quiet output'),
+                array('verbose', 'v', 0, 1, 0, 0, 'bool', 'Verbose output'),
+                array('reverse-only', '', 0, 1, 0, 0, 'bool', 'Warm reverse only'),
+                array('search-only', '', 0, 1, 0, 0, 'bool', 'Warm search only'),
+               );
+getCmdOpt($_SERVER['argv'], $aCMDOptions, $aResult, true, true);
 
-       require_once(CONST_BasePath.'/lib/log.php');
-       require_once(CONST_BasePath.'/lib/Geocode.php');
-       require_once(CONST_BasePath.'/lib/PlaceLookup.php');
-       require_once(CONST_BasePath.'/lib/ReverseGeocode.php');
+require_once(CONST_BasePath.'/lib/log.php');
+require_once(CONST_BasePath.'/lib/Geocode.php');
+require_once(CONST_BasePath.'/lib/PlaceLookup.php');
+require_once(CONST_BasePath.'/lib/ReverseGeocode.php');
 
-       $oDB =& getDB();
+$oDB =& getDB();
 
-       $bVerbose = $aResult['verbose'];
+$bVerbose = $aResult['verbose'];
 
-       if (!$aResult['search-only']) {
+if (!$aResult['search-only']) {
+    $oReverseGeocode = new Nominatim\ReverseGeocode($oDB);
+    $oReverseGeocode->setZoom(20);
+    $oPlaceLookup = new Nominatim\PlaceLookup($oDB);
+    $oPlaceLookup->setIncludeAddressDetails(true);
+    $oPlaceLookup->setLanguagePreference(array('en'));
 
-               $oReverseGeocode = new ReverseGeocode($oDB);
-               $oReverseGeocode->setIncludeAddressDetails(true);
+    echo "Warm reverse: ";
+    if ($bVerbose) echo "\n";
+    for ($i = 0; $i < 1000; $i++) {
+        $fLat = rand(-9000, 9000) / 100;
+        $fLon = rand(-18000, 18000) / 100;
+        if ($bVerbose) echo "$fLat, $fLon = ";
+        $aLookup = $oReverseGeocode->lookup($fLat, $fLon);
+        if ($aLookup && $aLookup['place_id']) {
+            $aDetails = $oPlaceLookup->lookup(
+                (int)$aLookup['place_id'],
+                $aLookup['type'],
+                $aLookup['fraction']
+            );
+            if ($bVerbose) echo $aDetails['langaddress']."\n";
+        } else {
+            echo ".";
+        }
+    }
+    echo "\n";
+}
 
-               echo "Warm reverse: ";
-               if ($bVerbose) echo "\n";
-               for($i = 0; $i < 1000; $i++) {
-                       $fLat = rand(-9000, 9000) / 100;
-                       $fLon = rand(-18000, 18000) / 100;
-                       if ($bVerbose) echo "$fLat, $fLon = ";
-                       $oReverseGeocode->setLanguagePreference(array('en'));
-                       $oReverseGeocode->setLatLon($fLat, $fLon);
-                       $oReverseGeocode->setZoom(20);
-                       $aDetails = $oReverseGeocode->lookup();
-                       if ($bVerbose) echo $aDetails['langaddress']."\n";
-                       else echo ".";
-               }
-               echo "\n";
-       }
-
-       if (!$aResult['reverse-only']) {
-
-               $oGeocode =& new Geocode($oDB);
-
-               echo "Warm search: ";
-               if ($bVerbose) echo "\n";
-               $sSQL = 'select word from word where word is not null order by search_name_count desc limit 1000';
-               foreach($oDB->getCol($sSQL) as $sWord) {
-                       if ($bVerbose) echo "$sWord = ";
-                       $oGeocode->setLanguagePreference(array('en'));
-                       $oGeocode->setQuery($sWord);
-                       $aSearchResults = $oGeocode->lookup();
-                       if ($bVerbose) echo $aSearchResults[0]['langaddress']."\n";
-                       else echo ".";
-               }
-       }
+if (!$aResult['reverse-only']) {
+    $oGeocode = new Nominatim\Geocode($oDB);
 
+    echo "Warm search: ";
+    if ($bVerbose) echo "\n";
+    $sSQL = 'select word from word where word is not null order by search_name_count desc limit 1000';
+    foreach ($oDB->getCol($sSQL) as $sWord) {
+        if ($bVerbose) echo "$sWord = ";
+        $oGeocode->setLanguagePreference(array('en'));
+        $oGeocode->setQuery($sWord);
+        $aSearchResults = $oGeocode->lookup();
+        if ($bVerbose) echo $aSearchResults[0]['langaddress']."\n";
+        else echo ".";
+    }
+}