X-Git-Url: https://git.openstreetmap.org./nominatim.git/blobdiff_plain/f727620859cacfa39146642b31ad446762212262..0a3c3827859e504fec64ca44a83ed2686ee318d5:/test/bdd/steps/geometry_factory.py diff --git a/test/bdd/steps/geometry_factory.py b/test/bdd/steps/geometry_factory.py index 7eedfc37..d62ad9c5 100644 --- a/test/bdd/steps/geometry_factory.py +++ b/test/bdd/steps/geometry_factory.py @@ -1,3 +1,9 @@ +# SPDX-License-Identifier: GPL-2.0-only +# +# This file is part of Nominatim. (https://nominatim.org) +# +# Copyright (C) 2022 by the Nominatim developer community. +# For a full list of authors see the git log. from pathlib import Path import os @@ -9,7 +15,7 @@ class GeometryFactory: defpath = Path(__file__) / '..' / '..' / '..' / 'scenes' / 'data' self.scene_path = os.environ.get('SCENE_PATH', defpath.resolve()) self.scene_cache = {} - self.clear_grid() + self.grid = {} def parse_geometry(self, geom, scene): """ Create a WKT SQL term for the given geometry. @@ -103,11 +109,20 @@ class GeometryFactory: return scene - def clear_grid(self): + def set_grid(self, lines, grid_step): + """ Replace the grid with one from the given lines. + """ self.grid = {} - - def add_grid_node(self, nodeid, x, y): - self.grid[nodeid] = (x, y) + y = 0 + for line in lines: + x = 0 + for pt_id in line: + if pt_id.isdigit(): + self.grid[int(pt_id)] = (x, y) + x += grid_step + y += grid_step def grid_node(self, nodeid): + """ Get the coordinates for the given grid node. + """ return self.grid.get(nodeid)