X-Git-Url: https://git.openstreetmap.org./nominatim.git/blobdiff_plain/6e89310a9285f1ad15d8002bf68f578eada367a0..2735ea768aa812998a9498cf411563f118bd6ad6:/src/nominatim_db/tokenizer/icu_rule_loader.py diff --git a/src/nominatim_db/tokenizer/icu_rule_loader.py b/src/nominatim_db/tokenizer/icu_rule_loader.py index 9e7f00b4..978739c3 100644 --- a/src/nominatim_db/tokenizer/icu_rule_loader.py +++ b/src/nominatim_db/tokenizer/icu_rule_loader.py @@ -14,10 +14,10 @@ import logging from icu import Transliterator -from nominatim_core.config import flatten_config_list, Configuration -from nominatim_core.db.properties import set_property, get_property -from nominatim_core.db.connection import Connection -from nominatim_core.errors import UsageError +from ..config import flatten_config_list, Configuration +from ..db.properties import set_property, get_property +from ..db.connection import Connection +from ..errors import UsageError from .place_sanitizer import PlaceSanitizer from .icu_token_analysis import ICUTokenAnalysis from .token_analysis.base import AnalysisModule, Analyzer @@ -61,7 +61,6 @@ class ICURuleLoader: # Load optional sanitizer rule set. self.sanitizer_rules = rules.get('sanitizers', []) - def load_config_from_db(self, conn: Connection) -> None: """ Get previously saved parts of the configuration from the database. @@ -81,7 +80,6 @@ class ICURuleLoader: self.analysis_rules = [] self._setup_analysis() - def save_config_to_db(self, conn: Connection) -> None: """ Save the part of the configuration that cannot be changed into the database. @@ -90,20 +88,17 @@ class ICURuleLoader: set_property(conn, DBCFG_IMPORT_TRANS_RULES, self.transliteration_rules) set_property(conn, DBCFG_IMPORT_ANALYSIS_RULES, json.dumps(self.analysis_rules)) - def make_sanitizer(self) -> PlaceSanitizer: """ Create a place sanitizer from the configured rules. """ return PlaceSanitizer(self.sanitizer_rules, self.config) - def make_token_analysis(self) -> ICUTokenAnalysis: """ Create a token analyser from the reviouly loaded rules. """ return ICUTokenAnalysis(self.normalization_rules, self.transliteration_rules, self.analysis) - def get_search_rules(self) -> str: """ Return the ICU rules to be used during search. The rules combine normalization and transliteration. @@ -116,23 +111,20 @@ class ICURuleLoader: rules.write(self.transliteration_rules) return rules.getvalue() - def get_normalization_rules(self) -> str: """ Return rules for normalisation of a term. """ return self.normalization_rules - def get_transliteration_rules(self) -> str: """ Return the rules for converting a string into its asciii representation. """ return self.transliteration_rules - def _setup_analysis(self) -> None: """ Process the rules used for creating the various token analyzers. """ - self.analysis: Dict[Optional[str], TokenAnalyzerRule] = {} + self.analysis: Dict[Optional[str], TokenAnalyzerRule] = {} if not isinstance(self.analysis_rules, list): raise UsageError("Configuration section 'token-analysis' must be a list.") @@ -140,7 +132,7 @@ class ICURuleLoader: norm = Transliterator.createFromRules("rule_loader_normalization", self.normalization_rules) trans = Transliterator.createFromRules("rule_loader_transliteration", - self.transliteration_rules) + self.transliteration_rules) for section in self.analysis_rules: name = section.get('id', None) @@ -154,7 +146,6 @@ class ICURuleLoader: self.analysis[name] = TokenAnalyzerRule(section, norm, trans, self.config) - @staticmethod def _cfg_to_icu_rules(rules: Mapping[str, Any], section: str) -> str: """ Load an ICU ruleset from the given section. If the section is a @@ -184,12 +175,11 @@ class TokenAnalyzerRule: raise UsageError("'analyzer' parameter needs to be simple string") self._analysis_mod: AnalysisModule = \ - config.load_plugin_module(analyzer_name, 'nominatim.tokenizer.token_analysis') + config.load_plugin_module(analyzer_name, 'nominatim_db.tokenizer.token_analysis') self.config = self._analysis_mod.configure(rules, normalizer, transliterator) - def create(self, normalizer: Any, transliterator: Any) -> Analyzer: """ Create a new analyser instance for the given rule. """