X-Git-Url: https://git.openstreetmap.org/nominatim.git/blobdiff_plain/991bd0004a400c84c2a63053eb6671a6442204f8..22b7aed769fed5e0bcc31479a65869437cb2d5dd:/lib/template/address-xml.php?ds=inline

diff --git a/lib/template/address-xml.php b/lib/template/address-xml.php
index 109e66a1..a17da738 100644
--- a/lib/template/address-xml.php
+++ b/lib/template/address-xml.php
@@ -1,110 +1,87 @@
 <?php
-	header("content-type: text/xml; charset=UTF-8");
+header('content-type: text/xml; charset=UTF-8');
 
-	echo "<";
-	echo "?xml version=\"1.0\" encoding=\"UTF-8\" ?";
-	echo ">\n";
+echo '<';
+echo '?xml version="1.0" encoding="UTF-8" ?';
+echo ">\n";
 
-	echo "<reversegeocode";
-	echo " timestamp='".date(DATE_RFC822)."'";
-	echo " attribution='Data © OpenStreetMap contributors, ODbL 1.0. http://www.openstreetmap.org/copyright'";
-	echo " querystring='".htmlspecialchars($_SERVER['QUERY_STRING'], ENT_QUOTES)."'";
-	echo ">\n";
+echo '<reversegeocode';
+echo " timestamp='".date(DATE_RFC822)."'";
+echo " attribution='Data © OpenStreetMap contributors, ODbL 1.0. http://www.openstreetmap.org/copyright'";
+echo " querystring='".htmlspecialchars($_SERVER['QUERY_STRING'], ENT_QUOTES)."'";
+echo ">\n";
 
-	if (!sizeof($aPlace))
-	{
-		if (isset($sError))
-			echo "<error>$sError</error>";
-		else
-			echo "<error>Unable to geocode</error>";
-	}
-	else
-	{
-		echo "<result";
-		if ($aPlace['place_id']) echo ' place_id="'.$aPlace['place_id'].'"';
-		$sOSMType = ($aPlace['osm_type'] == 'N'?'node':($aPlace['osm_type'] == 'W'?'way':($aPlace['osm_type'] == 'R'?'relation':'')));
-		if ($sOSMType) echo ' osm_type="'.$sOSMType.'"'.' osm_id="'.$aPlace['osm_id'].'"';
-		if ($aPlace['ref']) echo ' ref="'.htmlspecialchars($aPlace['ref']).'"';
-		if (isset($aPlace['lat'])) echo ' lat="'.htmlspecialchars($aPlace['lat']).'"';
-		if (isset($aPlace['lon'])) echo ' lon="'.htmlspecialchars($aPlace['lon']).'"';
-		if (isset($aPlace['aBoundingBox']))
-		{
-			echo ' boundingbox="';
-			echo join(',', $aPlace['aBoundingBox']);
-			echo '"';
+if (empty($aPlace)) {
+    if (isset($sError))
+        echo "<error>$sError</error>";
+    else echo '<error>Unable to geocode</error>';
+} else {
+    echo '<result';
+    if ($aPlace['place_id']) echo ' place_id="'.$aPlace['place_id'].'"';
+    $sOSMType = formatOSMType($aPlace['osm_type']);
+    if ($sOSMType) echo ' osm_type="'.$sOSMType.'"'.' osm_id="'.$aPlace['osm_id'].'"';
+    if ($aPlace['ref']) echo ' ref="'.htmlspecialchars($aPlace['ref']).'"';
+    if (isset($aPlace['lat'])) echo ' lat="'.htmlspecialchars($aPlace['lat']).'"';
+    if (isset($aPlace['lon'])) echo ' lon="'.htmlspecialchars($aPlace['lon']).'"';
+    if (isset($aPlace['aBoundingBox'])) {
+        echo ' boundingbox="';
+        echo join(',', $aPlace['aBoundingBox']);
+        echo '"';
+    }
 
-			if ($bAsPoints && isset($aPlace['aPolyPoints']))
-			{
-				echo ' polygonpoints=\'';
-				echo json_encode($aPlace['aPolyPoints']);
-				echo '\'';
-			}
-		}
+    if (isset($aPlace['asgeojson'])) {
+        echo ' geojson=\'';
+        echo $aPlace['asgeojson'];
+        echo '\'';
+    }
 
-		if (isset($aPlace['asgeojson']))
-		{
-			echo ' geojson=\'';
-			echo $aPlace['asgeojson'];
-			echo '\'';
-		}
+    if (isset($aPlace['assvg'])) {
+        echo ' geosvg=\'';
+        echo $aPlace['assvg'];
+        echo '\'';
+    }
 
-		if (isset($aPlace['assvg']))
-		{
-			echo ' geosvg=\'';
-			echo $aPlace['assvg'];
-			echo '\'';
-		}
+    if (isset($aPlace['astext'])) {
+        echo ' geotext=\'';
+        echo $aPlace['astext'];
+        echo '\'';
+    }
+    echo '>'.htmlspecialchars($aPlace['langaddress']).'</result>';
 
-		if (isset($aPlace['astext']))
-		{
-			echo ' geotext=\'';
-			echo $aPlace['astext'];
-			echo '\'';
-		}
-		echo ">".htmlspecialchars($aPlace['langaddress'])."</result>";
+    if (isset($aPlace['address'])) {
+        echo '<addressparts>';
+        foreach ($aPlace['address']->getAddressNames() as $sKey => $sValue) {
+            $sKey = str_replace(' ', '_', $sKey);
+            echo "<$sKey>";
+            echo htmlspecialchars($sValue);
+            echo "</$sKey>";
+        }
+        echo '</addressparts>';
+    }
 
-		if (isset($aPlace['aAddress']))
-		{
-			echo "<addressparts>";
-			foreach($aPlace['aAddress'] as $sKey => $sValue)
-			{
-				$sKey = str_replace(' ','_',$sKey);
-				echo "<$sKey>";
-				echo htmlspecialchars($sValue);
-				echo "</$sKey>";
-			}
-			echo "</addressparts>";
-		}
+    if (isset($aPlace['sExtraTags'])) {
+        echo '<extratags>';
+        foreach ($aPlace['sExtraTags'] as $sKey => $sValue) {
+            echo '<tag key="'.htmlspecialchars($sKey).'" value="'.htmlspecialchars($sValue).'"/>';
+        }
+        echo '</extratags>';
+    }
 
-		if (isset($aPlace['sExtraTags']))
-		{
-			echo "<extratags>";
-			foreach ($aPlace['sExtraTags'] as $sKey => $sValue)
-			{
-				echo '<tag key="'.htmlspecialchars($sKey).'" value="'.htmlspecialchars($sValue).'"/>';
-			}
-			echo "</extratags>";
-		}
+    if (isset($aPlace['sNameDetails'])) {
+        echo '<namedetails>';
+        foreach ($aPlace['sNameDetails'] as $sKey => $sValue) {
+            echo '<name desc="'.htmlspecialchars($sKey).'">';
+            echo htmlspecialchars($sValue);
+            echo '</name>';
+        }
+        echo '</namedetails>';
+    }
 
-		if (isset($aPlace['sNameDetails']))
-		{
-			echo "<namedetails>";
-			foreach ($aPlace['sNameDetails'] as $sKey => $sValue)
-			{
-				echo '<name desc="'.htmlspecialchars($sKey).'">';
-				echo htmlspecialchars($sValue);
-				echo "</name>";
-			}
-			echo "</namedetails>";
-		}
+    if (isset($aPlace['askml'])) {
+        echo "\n<geokml>";
+        echo $aPlace['askml'];
+        echo '</geokml>';
+    }
+}
 
-		if (isset($aPlace['askml']))
-		{
-			echo "\n<geokml>";
-			echo $aPlace['askml'];
-			echo "</geokml>";
-		}
-
-	}
-
-	echo "</reversegeocode>";
+echo '</reversegeocode>';