# 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. """ Collection of assertion functions used for the steps. """ class Almost: """ Compares a float value with a certain jitter. """ def __init__(self, value, offset=0.00001): self.value = value self.offset = offset def __eq__(self, other): return abs(other - self.value) < self.offset class Bbox: """ Comparator for bounding boxes. """ def __init__(self, bbox_string): self.coord = [float(x) for x in bbox_string.split(',')] def __contains__(self, item): if isinstance(item, str): item = item.split(',') item = list(map(float, item)) if len(item) == 2: return self.coord[0] <= item[0] <= self.coord[2] \ and self.coord[1] <= item[1] <= self.coord[3] if len(item) == 4: return item[0] >= self.coord[0] and item[1] <= self.coord[1] \ and item[2] >= self.coord[2] and item[3] <= self.coord[3] raise ValueError("Not a coordinate or bbox.") def __str__(self): return str(self.coord)