/* * Copyright 2020-2022 Bytes & Brains * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include // Datum, etc. #include // PG_FUNCTION_ARGS, etc. #include // Main H3 include #include "extension.h" /* b-tree */ PG_FUNCTION_INFO_V1(h3index_eq); PG_FUNCTION_INFO_V1(h3index_ne); PG_FUNCTION_INFO_V1(h3index_lt); PG_FUNCTION_INFO_V1(h3index_le); PG_FUNCTION_INFO_V1(h3index_gt); PG_FUNCTION_INFO_V1(h3index_ge); /* r-tree */ PG_FUNCTION_INFO_V1(h3index_overlaps); PG_FUNCTION_INFO_V1(h3index_contains); PG_FUNCTION_INFO_V1(h3index_contained_by); /* static helpers */ static int containment(H3Index a, H3Index b) { H3Error error = 0; H3Index aParent = a; H3Index bParent = b; int aRes = getResolution(a); int bRes = getResolution(b); if (aRes > bRes) error = cellToParent(a, bRes, &aParent); else if (aRes < bRes) error = cellToParent(b, aRes, &bParent); H3_ERROR(error, "cellToParent"); /* a contains b */ if (a == bParent) return 1; /* a contained by b */ if (b == aParent) return -1; /* no overlap */ return 0; } /* b-tree operators */ Datum h3index_eq(PG_FUNCTION_ARGS) { H3Index a = PG_GETARG_H3INDEX(0); H3Index b = PG_GETARG_H3INDEX(1); bool ret = a == b; PG_RETURN_BOOL(ret); } Datum h3index_ne(PG_FUNCTION_ARGS) { H3Index a = PG_GETARG_H3INDEX(0); H3Index b = PG_GETARG_H3INDEX(1); bool ret = a != b; PG_RETURN_BOOL(ret); } Datum h3index_lt(PG_FUNCTION_ARGS) { H3Index a = PG_GETARG_H3INDEX(0); H3Index b = PG_GETARG_H3INDEX(1); bool ret = a < b; PG_RETURN_BOOL(ret); } Datum h3index_le(PG_FUNCTION_ARGS) { H3Index a = PG_GETARG_H3INDEX(0); H3Index b = PG_GETARG_H3INDEX(1); bool ret = a <= b; PG_RETURN_BOOL(ret); } Datum h3index_gt(PG_FUNCTION_ARGS) { H3Index a = PG_GETARG_H3INDEX(0); H3Index b = PG_GETARG_H3INDEX(1); bool ret = a > b; PG_RETURN_BOOL(ret); } Datum h3index_ge(PG_FUNCTION_ARGS) { H3Index a = PG_GETARG_H3INDEX(0); H3Index b = PG_GETARG_H3INDEX(1); bool ret = a >= b; PG_RETURN_BOOL(ret); } /* r-tree operators */ Datum h3index_overlaps(PG_FUNCTION_ARGS) { H3Index a = PG_GETARG_H3INDEX(0); H3Index b = PG_GETARG_H3INDEX(1); bool ret = containment(a, b) != 0; PG_RETURN_BOOL(ret); } Datum h3index_contains(PG_FUNCTION_ARGS) { H3Index a = PG_GETARG_H3INDEX(0); H3Index b = PG_GETARG_H3INDEX(1); bool ret = containment(a, b) > 0; PG_RETURN_BOOL(ret); } Datum h3index_contained_by(PG_FUNCTION_ARGS) { H3Index a = PG_GETARG_H3INDEX(0); H3Index b = PG_GETARG_H3INDEX(1); bool ret = containment(a, b) < 0; PG_RETURN_BOOL(ret); }