X-Git-Url: https://git.openstreetmap.org./nominatim.git/blobdiff_plain/35b52c46562c3dd3427da7bca898d18edfd60047..ce1f4cbbdce29460e0984345996d0d6276e0b0f0:/nominatim/api/v1/classtypes.py diff --git a/nominatim/api/v1/classtypes.py b/nominatim/api/v1/classtypes.py index b8ed8a9c..273fe2f5 100644 --- a/nominatim/api/v1/classtypes.py +++ b/nominatim/api/v1/classtypes.py @@ -10,14 +10,18 @@ Hard-coded information about tag catagories. These tables have been copied verbatim from the old PHP code. For future version a more flexible formatting is required. """ -from typing import Tuple, Optional, Mapping +from typing import Tuple, Optional, Mapping, Union + +import nominatim.api as napi def get_label_tag(category: Tuple[str, str], extratags: Optional[Mapping[str, str]], rank: int, country: Optional[str]) -> str: """ Create a label tag for the given place that can be used as an XML name. """ - if rank < 26 and extratags and 'place'in extratags: + if rank < 26 and extratags and 'place' in extratags: label = extratags['place'] + elif rank < 26 and extratags and 'linked_place' in extratags: + label = extratags['linked_place'] elif category == ('boundary', 'administrative'): label = ADMIN_LABELS.get((country or '', int(rank/2)))\ or ADMIN_LABELS.get(('', int(rank/2)))\ @@ -37,6 +41,30 @@ def get_label_tag(category: Tuple[str, str], extratags: Optional[Mapping[str, st return label.lower().replace(' ', '_') +def bbox_from_result(result: Union[napi.ReverseResult, napi.SearchResult]) -> napi.Bbox: + """ Compute a bounding box for the result. For ways and relations + a given boundingbox is used. For all other object, a box is computed + around the centroid according to dimensions dereived from the + search rank. + """ + if (result.osm_object and result.osm_object[0] == 'N') or result.bbox is None: + extent = NODE_EXTENT.get(result.category, 0.00005) + return napi.Bbox.from_point(result.centroid, extent) + + return result.bbox + + +# pylint: disable=line-too-long +OSM_ATTRIBUTION = 'Data © OpenStreetMap contributors, ODbL 1.0. http://osm.org/copyright' + + +OSM_TYPE_NAME = { + 'N': 'node', + 'W': 'way', + 'R': 'relation' +} + + ADMIN_LABELS = { ('', 1): 'Continent', ('', 2): 'Country', @@ -142,3 +170,31 @@ ICONS = { ('amenity', 'prison'): 'amenity_prison', ('highway', 'bus_stop'): 'transport_bus_stop2' } + +NODE_EXTENT = { + ('place', 'continent'): 25, + ('place', 'country'): 7, + ('place', 'state'): 2.6, + ('place', 'province'): 2.6, + ('place', 'region'): 1.0, + ('place', 'county'): 0.7, + ('place', 'city'): 0.16, + ('place', 'municipality'): 0.16, + ('place', 'island'): 0.32, + ('place', 'postcode'): 0.16, + ('place', 'town'): 0.04, + ('place', 'village'): 0.02, + ('place', 'hamlet'): 0.02, + ('place', 'district'): 0.02, + ('place', 'borough'): 0.02, + ('place', 'suburb'): 0.02, + ('place', 'locality'): 0.01, + ('place', 'neighbourhood'): 0.01, + ('place', 'quarter'): 0.01, + ('place', 'city_block'): 0.01, + ('landuse', 'farm'): 0.01, + ('place', 'farm'): 0.01, + ('place', 'airport'): 0.015, + ('aeroway', 'aerodrome'): 0.015, + ('railway', 'station'): 0.005 +}