MobilityDB 1.1
temporal_supportfn.h
Go to the documentation of this file.
1/*****************************************************************************
2 *
3 * This MobilityDB code is provided under The PostgreSQL License.
4 * Copyright (c) 2016-2023, Université libre de Bruxelles and MobilityDB
5 * contributors
6 *
7 * MobilityDB includes portions of PostGIS version 3 source code released
8 * under the GNU General Public License (GPLv2 or later).
9 * Copyright (c) 2001-2023, PostGIS contributors
10 *
11 * Permission to use, copy, modify, and distribute this software and its
12 * documentation for any purpose, without fee, and without a written
13 * agreement is hereby granted, provided that the above copyright notice and
14 * this paragraph and the following two paragraphs appear in all copies.
15 *
16 * IN NO EVENT SHALL UNIVERSITE LIBRE DE BRUXELLES BE LIABLE TO ANY PARTY FOR
17 * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING
18 * LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION,
19 * EVEN IF UNIVERSITE LIBRE DE BRUXELLES HAS BEEN ADVISED OF THE POSSIBILITY
20 * OF SUCH DAMAGE.
21 *
22 * UNIVERSITE LIBRE DE BRUXELLES SPECIFICALLY DISCLAIMS ANY WARRANTIES,
23 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
24 * AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS ON
25 * AN "AS IS" BASIS, AND UNIVERSITE LIBRE DE BRUXELLES HAS NO OBLIGATIONS TO
26 * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. 
27 *
28 *****************************************************************************/
29
34#ifndef __TEMPORAL_SUPPORTFN_H__
35#define __TEMPORAL_SUPPORTFN_H__
36
37/* PostgreSQL */
38#include <postgres.h>
39
40/*****************************************************************************/
41
42/*
43* Depending on the function, we will deploy different index enhancement
44* strategies. Containment functions can use a more strict index strategy
45* than overlapping functions. We store the metadata to drive these choices
46* in the IndexableFunctions array.
47*/
48typedef struct
49{
50 const char *fn_name; /* Name of the function */
51 uint16_t index; /* Position of the strategy in the arrays */
52 uint8_t nargs; /* Expected number of function arguments */
53 uint8_t expand_arg; /* Radius argument for "within distance" search */
55
56/*****************************************************************************/
57
58extern Oid opFamilyAmOid(Oid opfamilyoid);
59extern bool func_needs_index(Oid funcid, const IndexableFunction *idxfn,
60 IndexableFunction *result);
61
62/*****************************************************************************/
63
64#endif
unsigned int Oid
Definition: postgres_ext.h:31
uint8_t expand_arg
Definition: temporal_supportfn.h:53
const char * fn_name
Definition: temporal_supportfn.h:50
uint16_t index
Definition: temporal_supportfn.h:51
uint8_t nargs
Definition: temporal_supportfn.h:52
Support functions for temporal types.
Definition: temporal_supportfn.h:49
Oid opFamilyAmOid(Oid opfamilyoid)
We only add index enhancements for indexes that support range-based searches like the && operator),...
Definition: temporal_supportfn.c:206
bool func_needs_index(Oid funcid, const IndexableFunction *idxfn, IndexableFunction *result)
Is the function calling the support function one of those we will enhance with index ops?...
Definition: temporal_supportfn.c:182