MobilityDB 1.1
stbox.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 __STBOX_H__
35#define __STBOX_H__
36
37/* PostgreSQL */
38#include <postgres.h>
39/* PostGIS */
40#include <liblwgeom.h>
41/* MEOS */
42#include "general/set.h"
43
44/*****************************************************************************
45 * fmgr macros
46 *****************************************************************************/
47
48#define DatumGetSTboxP(X) ((STBox *) DatumGetPointer(X))
49#define STboxPGetDatum(X) PointerGetDatum(X)
50#define PG_GETARG_STBOX_P(n) DatumGetSTboxP(PG_GETARG_DATUM(n))
51#define PG_RETURN_STBOX_P(x) return STboxPGetDatum(x)
52
53/*****************************************************************************/
54
55/* Parameter tests */
56
57extern void ensure_has_X_stbox(const STBox *box);
58extern void ensure_has_T_stbox(const STBox *box);
59
60/* Set an STBox from a <Type> */
61
62extern void tstzset_stbox_slice(Datum tsdatum, STBox *box);
63extern void periodset_stbox_slice(Datum psdatum, STBox *box);
64
65/* SRID functions */
66
67extern STBox *stbox_set_srid(const STBox *box, int32 srid);
68
69/*****************************************************************************/
70
71#endif
STBox * stbox_set_srid(const STBox *box, int32 srid)
Set the SRID of a spatiotemporal box.
Definition: stbox.c:906
uintptr_t Datum
Definition: pg_ext_defs.in.h:4
signed int int32
Definition: pg_ext_defs.in.h:8
void ensure_has_T_stbox(const STBox *box)
Ensure that the temporal value has T dimension.
Definition: stbox.c:120
void ensure_has_X_stbox(const STBox *box)
Ensure that the temporal value has XY dimension.
Definition: stbox.c:109
void tstzset_stbox_slice(Datum tsdatum, STBox *box)
void periodset_stbox_slice(Datum psdatum, STBox *box)
Peak into a period set datum to find the bounding box.
Definition: stbox.c:392
Structure to represent spatiotemporal boxes.
Definition: meos.h:107