from typing import Any, Mapping, Optional, Set, Match
import re
-from nominatim_core.errors import UsageError
+from ..errors import UsageError
from . import country_info
+
class CountryPostcodeMatcher:
""" Matches and formats a postcode according to a format definition
of the given country.
self.output = config.get('output', r'\g<0>')
-
def match(self, postcode: str) -> Optional[Match[str]]:
""" Match the given postcode against the postcode pattern for this
matcher. Returns a `re.Match` object if the match was successful
return None
-
def normalize(self, match: Match[str]) -> str:
""" Return the default format of the postcode for the given match.
`match` must be a `re.Match` object previously returned by
else:
raise UsageError(f"Invalid entry 'postcode' for country '{ccode}'")
-
def set_default_pattern(self, pattern: str) -> None:
""" Set the postcode match pattern to use, when a country does not
have a specific pattern.
"""
self.default_matcher = CountryPostcodeMatcher('', {'pattern': pattern})
-
def get_matcher(self, country_code: Optional[str]) -> Optional[CountryPostcodeMatcher]:
""" Return the CountryPostcodeMatcher for the given country.
Returns None if the country doesn't have a postcode and the
return self.country_matcher.get(country_code, self.default_matcher)
-
def match(self, country_code: Optional[str], postcode: str) -> Optional[Match[str]]:
""" Match the given postcode against the postcode pattern for this
matcher. Returns a `re.Match` object if the country has a pattern
return self.country_matcher.get(country_code, self.default_matcher).match(postcode)
-
def normalize(self, country_code: str, match: Match[str]) -> str:
""" Return the default format of the postcode for the given match.
`match` must be a `re.Match` object previously returned by