-
Notifications
You must be signed in to change notification settings - Fork 375
/
Copy pathgmt_types.h
500 lines (457 loc) · 28.6 KB
/
gmt_types.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
/*--------------------------------------------------------------------
*
* Copyright (c) 1991-2025 by the GMT Team (https://www.generic-mapping-tools.org/team.html)
* See LICENSE.TXT file for copying and redistribution conditions.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation; version 3 or any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* Contact info: www.generic-mapping-tools.org
*--------------------------------------------------------------------*/
/*
* gmt_types.h contains definitions of special types used by GMT.
*
* Author: Paul Wessel
* Date: 01-OCT-2009
* Version: 6 API
*/
/*!
* \file gmt_types.h
* \brief Definitions of special types used by GMT.
*/
#ifndef GMT_TYPES_H
#define GMT_TYPES_H
#include <stdbool.h>
#include <stdint.h>
/*--------------------------------------------------------------------
* GMT TYPE DEFINITIONS
*--------------------------------------------------------------------*/
/*! Definition of GMT_SCALED_RECT_DIM used to handle embellishments dimensions given by default or percentages of map width */
struct GMT_SCALED_RECT_DIM {
bool fraction[2]; /* True if dimensions in dim are given as fraction of map width and rectangle height */
double dim[2]; /* Dimensions in inches, if set; */
double scl[2]; /* Scales set to give dim once map width is known (scl[GMT_Y] is relative to rectangle width, not map width) */
};
/*! Definition of CONTOUR_ARGS used by grdcontour and pscontour */
struct CONTOUR_ARGS {
bool cpt; /* true of we were given a CPT file */
bool check; /* true if in modern mode and no CPT was given */
unsigned int mode; /* Module specific action, usually to indicate no annotations desired */
char *file; /* File with cpt or contours, or list of contours */
double interval; /* Constant interval */
double single_cont; /* Single specified contour */
};
/*! Definition of CONTOUR_CLOSED used by grdcontour and pscontour */
struct CONTOUR_CLOSED {
bool label;
bool all;
bool low, high; /* true to tick low and high locals */
double dim[2]; /* spacing, length */
char *txt[2]; /* Low and high label [-+] */
};
/*! Definition of GMT_MATH_MACRO used by grdmath and gmtmath */
struct GMT_MATH_MACRO {
unsigned int n_arg; /* How many commands this macro represents */
char *name; /* The macro name */
char **arg; /* List of those commands */
};
/*! Definition of GMT_KEYWORD_DICTIONARY used to expand keyword-value pairs to GMT options */
struct GMT_KEYWORD_DICTIONARY { /* Used for keyword-value lookup */
char separator; /* Single character separating 2 or more identical specifications [0 for no repeat] */
char short_option; /* Single character GMT option code */
char long_option[GMT_LEN256-1]; /* Name of corresponding long option */
char short_directives[GMT_LEN128]; /* Single character directives, comma-separated */
char long_directives[GMT_LEN512]; /* Long name directives, comma-separated */
char short_modifiers[GMT_LEN64]; /* Single character modifiers, comma-separated */
char long_modifiers[GMT_LEN256]; /* Long name modifiers, comma-separated */
unsigned int transproc_mask; /* Translation processing mask indicating special
behavior, e.g., multi-directive, etc., support */
};
/*! Definition of structure use for finding optimal n_columns/n_rows for surface */
struct GMT_SURFACE_SUGGESTION { /* Used to find top ten list of faster grid dimensions */
unsigned int n_columns;
unsigned int n_rows;
double factor; /* Speed up by a factor of factor */
};
/*! Definition of structure used for holding information of integer items to be selected */
struct GMT_INT_SELECTION { /* Used to hold array with items (0-n) that have been selected */
uint64_t *item; /* Array with item numbers given (0 is first), sorted into ascending order */
uint64_t n; /* Number of items */
uint64_t current; /* Current item in item array */
bool invert; /* Instead select the items NOT listed in item[] */
};
/*! Definition of structure used for holding information of text items to be selected */
struct GMT_TEXT_SELECTION { /* Used to hold array with items (0-n) that have been selected */
char **pattern; /* Array with text items given, sorted into lexical order */
int ogr_item; /* Used if ogr_match is true */
uint64_t n; /* Number of items */
bool invert; /* Instead select the items NOT listed in item[] */
bool *regexp; /* Item is a regex expression */
bool *caseless; /* Treat as caseless */
bool ogr_match; /* Compare pattern to an OGR item */
};
/*! For weighted mean/mode */
struct GMT_OBSERVATION {
gmt_grdfloat value;
gmt_grdfloat weight;
};
/*! For finding tightest west/east range of multiple items */
struct GMT_RANGE {
double west;
double east;
double center; /* Forced to be 0-360 */
};
/*! For accessing singular values in sorted order */
struct GMT_SINGULAR_VALUE {
double value;
unsigned int order;
};
/*! For information on 1-D array */
struct GMT_ARRAY { /* Used by modules that needs to set up 1-D output/bin arrays */
bool temporal; /* true if array will be in absolute time */
bool vartime; /* true if <unit> implies a variable calendar unit */
bool count; /* true if we got number of items rather than increment */
bool add; /* true if we are asked to add a computed spatial distance column to output */
bool reverse; /* true if we want to reverse the array to give high to low on output */
bool reciprocal; /* true if we gave the reciprocal increment */
bool round; /* true if we want to adjust increment to ensure min/max range is a multiple of inc */
bool exact_inc; /* true if we want the increment to be exact and to adjust min/max instead */
bool has_inc; /* true if parsing detected an increment */
bool var_inc; /* true if the resulting array has variable spacing */
bool logarithmic; /* true if inc = 1,2,3 and we want logarithmic scale */
bool logarithmic2; /* true if inc = integer and we want log2 scale */
bool unique; /* true if any list shall be reduced to a monotonic, sorted array */
bool delay[2]; /* true if min and/or max shall be set from data set extremes after read [false] */
unsigned int spatial; /* 1 if <unit> implies a Cartesian and 2 if a geospatial distance */
unsigned int set; /* 1 if inc set, 3 if min/max/in set, 0 otherwise */
unsigned int col; /* The column that this array goes with */
int distmode; /* Type of geospatial calculation mode for distances */
uint64_t n; /* Number of elements in the array when complete */
double min, max, inc; /* Equidistant items */
double *array; /* This will eventually hold the array */
char *file; /* In case a file is given with the values */
char *list; /* In case a comma-separated list of values */
char unit; /* To remind us what units the inc is in, if given */
};
/*! For keeping table,segment IDs in a 1-D array */
struct GMT_TBLSEG {
uint64_t tbl, seg;
};
/*! For keeping track of GMT figures under modern mode */
struct GMT_FIGURE {
int ID; /* Figure number [0] */
char prefix[GMT_LEN256]; /* File prefix (no extension) */
char formats[GMT_LEN64]; /* List of comma-separated extensions(formats) */
char options[GMT_LEN256]; /* Optional arguments to psconvert (e.g., -A, -E, ...) */
};
struct GMT_INSET {
bool active; /* true the first time we set up scaling for a map inset */
bool first; /* true the first time we plot into the map inset */
double w, h; /* Width and height of current inset */
double dx, dy; /* offsets */
};
/*! For keeping track of GMT subplots under modern mode */
struct GMT_SUBPLOT {
unsigned int active; /* 1 if subplot is in effect */
unsigned int first; /* 1 the first time we reach panel, 0 later */
unsigned int no_scaling; /* 1 when we are plotting a scale, bar, etc and not map and don't want to auto-scale plot */
unsigned int parallel; /* 1 for axis-parallel annotations [0 for standard] */
unsigned int inside; /* 1 if all annots/ticks are inside panels [0 for outside] */
int row, col; /* Current panel position e.g., 0,0 */
int nrows, ncolumns; /* Panel arrangement for subplot window */
int dir[2]; /* Cartesian axis direction: +1 or -1 [1/1] */
double x, y; /* LB corner of current panel */
double dx, dy; /* Offset from LB when projection rescaling is required to center */
double w, h; /* Width and height of current panel */
double dim[2]; /* Dimension of entire subplot */
double origin[2]; /* Location of lower left figure origin set via -X -Y */
double off[2]; /* Offset from justification point of panel tag */
double soff[2]; /* Shade offset from justification point of panel tag */
double clearance[4]; /* Space around text for surrounding textbox */
double gap[4]; /* Shrink plottable region to make space for enhancements */
char refpoint[3]; /* Reference point for panel tag */
char justify[3]; /* Justification relative to refpoint */
char tag[GMT_LEN128]; /* Panel tag, e.g., a) */
char fill[GMT_LEN64]; /* Panel fill color */
char shade[GMT_LEN64]; /* Panel tag shade color */
char pen[GMT_LEN64]; /* Panel tag pen outline */
char Baxes[GMT_LEN128]; /* The -B setting for selected axes, including +color, tec */
char Btitle[GMT_LEN128]; /* The -B setting for any title */
char Bxlabel[GMT_LEN128]; /* The -Bx setting for x labels */
char Bylabel[GMT_LEN128]; /* The -By setting for x labels */
char Bxannot[GMT_LEN32]; /* The -Bx setting for annotations */
char Byannot[GMT_LEN32]; /* The -By setting for annotations */
};
/*! For trend-fitting models */
struct GMT_MODEL_TERM { /* A single model term */
unsigned int kind; /* GMT_POLYNOMIAL | GMT_COSINE | GMT_SINE | GMT_FOURIER */
unsigned int order[2]; /* Polygon or Fourier order */
unsigned int type; /* 0-7 for which kind of sin/cos combination */
};
struct GMT_MODEL { /* A model consists of n_terms */
bool robust; /* True for L1 fitting [L2] */
bool chebyshev; /* True if given polynomial of order n */
bool intercept; /* True if given model has intercept */
bool got_origin[2]; /* True if we got origin(s) */
bool got_period[2]; /* True if we got periods(s) */
unsigned int dim; /* 1 or 2 */
unsigned int type; /* 1 = poly, 2 = Fourier, 3 = both */
unsigned int n_terms; /* Terms in model */
unsigned int n_poly; /* The first n_poly terms contain the Polynomial/Chebyshev portion (if any) */
double origin[2]; /* x (or t) and y origins */
double period[2]; /* x (or t) and y periods */
struct GMT_MODEL_TERM term[GMT_N_MAX_MODEL];
};
struct GMT_ORDER { /* Used to sort some item (e.g., structure) based on a value */
double value; /* The value to sort on */
uint64_t order; /* Original position of item in the array */
};
/*! For segments */
struct GMT_SEGMENTIZE { /* Information about segmentation */
unsigned int method; /* Type of segmentation [0] */
unsigned int level; /* Organized by segments (0), per table (1) or per dataset (2) [0] */
double origin[2]; /* Reference point for segmentation */
};
struct GMT_DIST { /* Holds info for a particular distance calculation */
bool init; /* true if we have initialized settings for this type via gmt_init_distaz */
bool arc; /* true if distances are in deg/min/sec or arc; otherwise they are e|f|k|M|n or Cartesian */
double (*func) (struct GMT_CTRL *, double, double, double, double); /* pointer to function returning distance between two points points */
double scale; /* Scale to convert function output to desired unit */
};
struct GMT_MAP { /* Holds all map-related parameters */
struct GMT_PLOT_FRAME frame; /* Everything about the frame parameters */
int this_x_status; /* Tells us what quadrant old and new points are in (-4/4) */
int this_y_status;
int prev_x_status;
int prev_y_status;
int corner; /* Tells us which corner 1-4 or -1 if not a corner */
bool coastline; /* true if we are currently plotting the coastline data in pscoast */
bool on_border_is_outside; /* true if a point exactly on the map border should be considered outside the map */
bool is_world; /* true if map has 360 degrees of longitude range */
bool is_world_tm; /* true if GMT_TM map is global? */
bool lon_wrap; /* true when longitude wrapping over 360 degrees is allowed */
bool lat_wrap; /* true when "latitude" wrapping over 180 degrees is allowed (may be periodic time in y-axis instead) */
bool z_periodic; /* true if grid values are 0-360 degrees (phases etc) */
bool loxodrome; /* true if we are computing loxodrome distances */
unsigned int meridian_straight; /* 1 if meridians plot as straight lines, 2 for special case */
unsigned int parallel_straight; /* 1 if parallels plot as straight lines, 2 for special case */
unsigned int n_lon_nodes; /* Somewhat arbitrary # of nodes for lines in longitude (may be reset in gmt_map.c) */
unsigned int n_lat_nodes; /* Somewhat arbitrary # of nodes for lines in latitude (may be reset in gmt_map.c) */
unsigned int path_mode; /* 0 if we should call gmt_fix_up_path to resample across gaps > path_step, 1 to leave alone */
unsigned int last_dim; /* 2 for 2-D or 3 for 3-D as previous plot */
double last_width; /* Full width in inches of previous plot */
double last_height; /* Full height in inches of previous plot */
double width; /* Full width in inches of this world map */
double height; /* Full height in inches of this world map */
double half_width; /* Half width in inches of this world map */
double half_height; /* Half height of this world map */
double dlon; /* Steps taken in longitude along gridlines (gets reset in gmt_init.c) */
double dlat; /* Steps taken in latitude along gridlines (gets reset in gmt_init.c) */
double path_step; /* Sampling interval if resampling of paths should be done */
double lon_wrap_range; /* 360 for longitudes, but others values for periodic time */
double lat_wrap_range; /* Usually means for for periodic time */
bool (*outside) (struct GMT_CTRL *, double, double); /* Pointer to function checking if a lon/lat point is outside map */
bool (*overlap) (struct GMT_CTRL *, double, double, double, double); /* Pointer to function checking for overlap between 2 regions */
bool (*will_it_wrap) (struct GMT_CTRL *, double *, double *, uint64_t, uint64_t *); /* true if consecutive points indicate wrap */
int (*jump) (struct GMT_CTRL *, double, double, double, double); /* true if we jump in x or y */
unsigned int (*crossing) (struct GMT_CTRL *, double, double, double, double, double *, double *, double *, double *, unsigned int *); /* Pointer to functions returning crossover point at boundary */
uint64_t (*clip) (struct GMT_CTRL *, double *, double *, uint64_t, double **, double **, uint64_t *); /* Pointer to functions that clip a polygon to fit inside map */
double (*left_edge) (struct GMT_CTRL *, double); /* Pointers to functions that return left edge of map */
double (*right_edge) (struct GMT_CTRL *, double); /* Pointers to functions that return right edge of map */
struct GMT_DIST dist[3]; /* struct with pointers to functions/scales returning distance between two points points */
bool (*near_lines_func) (struct GMT_CTRL *, double, double, struct GMT_DATATABLE *, unsigned int, double *, double *, double *); /* Pointer to function returning distance to nearest line among a set of lines */
bool (*near_a_line_func) (struct GMT_CTRL *, double, double, uint64_t, struct GMT_DATASEGMENT *, unsigned int, double *, double *, double *); /* Pointer to function returning distance to line */
bool (*near_point_func) (struct GMT_CTRL *, double, double, struct GMT_DATATABLE *, double); /* Pointer to function returning distance to nearest point */
unsigned int (*wrap_around_check) (struct GMT_CTRL *, double *, double, double, double, double, double *, double *, unsigned int *); /* Does x or y wrap checks */
double (*azimuth_func) (struct GMT_CTRL *, double, double, double, double, bool); /* Pointer to function returning azimuth between two points points */
void (*get_crossings) (struct GMT_CTRL *, double *, double *, double, double, double, double); /* Returns map crossings in x or y */
double (*geodesic_meter) (struct GMT_CTRL *, double, double, double, double); /* pointer to geodesic function returning distance between two points points in meter */
double (*geodesic_az_backaz) (struct GMT_CTRL *, double, double, double, double, bool); /* pointer to geodesic function returning azimuth or backazimuth between two points points */
void (*second_point) (struct GMT_CTRL *, double, double, double, double, double *, double *, double *); /* pointer to function returning second point (and bakaz) given first point, az, and dist */
};
struct GMT_GCAL { /* (proleptic) Gregorian calendar */
int year; /* signed; negative and 0 allowed */
unsigned int month; /* Always between 1 and 12 */
unsigned int day_m; /* Day of month; always in 1 - 31 */
unsigned int day_y; /* Day of year; 1 through 366 */
unsigned int day_w; /* Day of week; 0 (Sun) through 6 (Sat) */
int iso_y; /* ISO year; not necessarily == year */
unsigned int iso_w; /* ISO week of iso_y; must be in 1 -- 53 */
unsigned int iso_d; /* ISO day of iso_w; uses 1 (Mon) through 7 (Sun) */
unsigned int hour; /* 00 through 23 */
unsigned int min; /* 00 through 59 */
double sec; /* 00 through 59.xxxx; leap not yet handled */
};
struct GMT_Y2K_FIX { /* The issue that refuses to go away... */
unsigned int y2_cutoff; /* The 2-digit offset year. If y2 >= y2_cuttoff, add y100 else add y200 */
int y100; /* The multiple of 100 to add to the 2-digit year if we are above the time_Y2K_offset_year */
int y200; /* The multiple of 100 to add to the 2-digit year if we are below the time_Y2K_offset_year */
};
struct GMT_MOMENT_INTERVAL {
struct GMT_GCAL cc[2];
double dt[2];
double sd[2]; /* Seconds since the start of the day. */
int64_t rd[2];
unsigned int step;
char unit;
};
struct GMT_TRUNCATE_TIME { /* Used when TIME_IS_INTERVAL is not OFF */
struct GMT_MOMENT_INTERVAL T;
unsigned int direction; /* 0 [+] to center on next interval, 1 [-] for previous interval */
};
struct GMT_TIME_CONV { /* Holds all time-related parameters */
struct GMT_TRUNCATE_TIME truncate;
struct GMT_Y2K_FIX Y2K_fix; /* Used to convert 2-digit years to 4-digit years */
time_t tic; /* Last system time marker */
int64_t today_rata_die; /* The rata die of current day at start of program */
};
struct GMT_LANGUAGE { /* Language-specific text strings for calendars, map annotations, etc. */
char month_name[4][12][GMT_LEN16]; /* Full, short, 1-char, and short (upper case) month names */
char day_name[3][7][GMT_LEN16]; /* Full, short, and 1-char weekday names */
char week_name[3][GMT_LEN16]; /* Full, short, and 1-char versions of the word Week */
char cardinal_name[3][4][GMT_LEN16]; /* Full, and abbreviated (map annot., direction) versions of compass directions */
};
struct GMT_INIT { /* Holds misc run-time parameters */
unsigned int n_custom_symbols;
const char *module_name; /* Name of current module or NULL if not set */
const char *module_lib; /* Name of current shared library or NULL if not set */
/* The rest of the struct contains pointers that may point to memory not included by this struct */
char *runtime_bindir; /* Directory that contains the main exe at run-time */
char *runtime_libdir; /* Directory that contains the main shared lib at run-time */
char *runtime_library; /* Name of the main shared library at run-time */
char *runtime_plugindir; /* Directory that contains the main supplemental plugins at run-time */
char *history[GMT_N_UNIQUE]; /* The internal gmt.history information */
struct GMT_CUSTOM_SYMBOL **custom_symbol; /* For custom symbol plotting in psxy[z]. */
};
struct GMT_PLOT { /* Holds all plotting-related parameters */
uint64_t n; /* Number of such points */
size_t n_alloc; /* Size of allocated plot arrays */
bool r_theta_annot; /* true for special r-theta map annotation (see gmtlib_get_annot_label) */
bool substitute_pi; /* true when -R or -B was given with pi and we want to use pi in annotations if possible */
unsigned int mode_3D; /* Determines if we draw fore and/or back 3-D box lines [Default is both] */
unsigned int *pen; /* Pen (PSL_MOVE = up, PSL_DRAW = down) for these points */
unsigned int color_seq_id[2]; /* Next sequential color entries (table,segment) in the auto-CPT list of colors from COLOR_SET */
struct GMT_PLOT_CALCLOCK calclock;
/* The rest of the struct contains pointers that may point to memory not included by this struct */
double *x; /* Holds the x/y (inches) of a line to be plotted */
double *y;
double gridline_spacing[2]; /* Holds last gridline spacing used for this plot, via gmt.history */
char format[3][2][GMT_LEN256]; /* Keeps the 6 formats for dd:mm:ss plot output */
struct GMT_SUBPLOT panel; /* Current subplot panel settings */
struct GMT_INSET inset; /* Current inset settings */
};
struct GMT_CURRENT {
/* These are internal parameters that need to be passed around between
* many GMT functions. These values may change by user interaction. */
struct GMT_DEFAULTS setting; /* Holds all GMT defaults parameters */
struct GMT_IO io; /* Holds all i/o-related parameters */
struct GMT_PROJ proj; /* Holds all projection-related parameters */
struct GMT_MAP map; /* Holds all projection-related parameters */
struct GMT_PLOT plot; /* Holds all plotting-related parameters */
struct GMT_TIME_CONV time; /* Holds all time-related parameters */
struct GMT_LANGUAGE language; /* Holds all language-related parameters */
struct GMT_PSL ps; /* Hold parameters related to PSL setup */
struct GMT_OPTION *options; /* Pointer to current program's options */
struct GMT_FFT_HIDDEN fft; /* Structure with info that must survive between FFT calls */
struct GMT_GDALREAD_IN_CTRL gdal_read_in; /* Hold parameters related to options transmitted to gdalread */
struct GMT_GDALREAD_OUT_CTRL gdal_read_out; /* Hold parameters related to options transmitted from gdalread */
struct GMT_GDALWRITE_CTRL gdal_write; /* Hold parameters related to options transmitted to gdalwrite */
};
struct GMT_INTERNAL {
/* These are internal parameters that need to be passed around between
* many GMT functions. These may change during execution but are not
* modified directly by user interaction. */
unsigned int func_level; /* Keeps track of what level in a nested GMT_func calling GMT_func etc we are. GMT_CONTROLLER (0) is initiating process (e.g. gmt.c) */
bool mem_set; /* true when we have initialized the tmp memory already */
bool sample_along_arc; /* true when sample1d need exact sampling along the arc */
size_t mem_cols; /* Current number of allocated columns for temp memory */
size_t mem_rows; /* Current number of allocated rows for temp memory */
size_t mem_txt_alloc;
size_t mem_txt_dup;
double **mem_coord; /* Columns of temp memory */
char **mem_txt; /* For temp text */
struct MEMORY_TRACKER *mem_keeper; /* Only filled when #ifdef MEMDEBUG */
#ifdef DEBUG
bool gridline_debug;
char gridline_kind;
double gridline_val;
#endif
};
struct GMT_SHORTHAND { /* Holds information for each grid extension shorthand read from the user's .gmtio file */
char *suffix; /* suffix of file */
char *format; /* format: ff/scale/offset/invalid */
};
struct GMT_SESSION {
/* These are parameters that is set once at the start of a GMT session and
* are essentially read-only constants for the duration of the session */
FILE *std[3]; /* Pointers for standard input, output, and error */
void * (*input_ascii) (struct GMT_CTRL *, FILE *, uint64_t *, int *); /* Pointer to function reading ASCII tables only */
int (*output_ascii) (struct GMT_CTRL *, FILE *, uint64_t, double *, char *); /* Pointer to function writing ASCII tables only */
unsigned int n_fonts; /* Total number of fonts returned by gmtinit_init_fonts */
unsigned int n_user_media; /* Total number of user media returned by gmtinit_load_user_media */
size_t min_meminc; /* with -DMEMDEBUG, sets min/max memory increments */
size_t max_meminc;
float f_NaN; /* Holds the IEEE NaN for floats */
double d_NaN; /* Holds the IEEE NaN for doubles */
double no_rgb[4]; /* To hold {-1, -1, -1, 0} when needed */
double u2u[4][4]; /* u2u is the 4x4 conversion matrix for cm, inch, m, pt */
char unit_name[4][GMT_LEN8]; /* Full name of the 4 units cm, inch, m, pt */
struct GMT_HASH rgb_hashnode[GMT_N_COLOR_NAMES];/* Used to translate colornames to r/g/b */
bool rgb_hashnode_init; /* true once the rgb_hashnode array has been loaded; false otherwise */
unsigned int n_shorthands; /* Length of array with shorthand information */
char *grdformat[GMT_N_GRD_FORMATS]; /* Type and description of grid format */
int (*readinfo[GMT_N_GRD_FORMATS]) (struct GMT_CTRL *, struct GMT_GRID_HEADER *); /* Pointers to grid read header functions */
int (*updateinfo[GMT_N_GRD_FORMATS]) (struct GMT_CTRL *, struct GMT_GRID_HEADER *); /* Pointers to grid update header functions */
int (*writeinfo[GMT_N_GRD_FORMATS]) (struct GMT_CTRL *, struct GMT_GRID_HEADER *); /* Pointers to grid write header functions */
int (*readgrd[GMT_N_GRD_FORMATS]) (struct GMT_CTRL *, struct GMT_GRID_HEADER *, gmt_grdfloat *, double *, unsigned int *, unsigned int); /* Pointers to grid read functions */
int (*writegrd[GMT_N_GRD_FORMATS]) (struct GMT_CTRL *, struct GMT_GRID_HEADER *, gmt_grdfloat *, double *, unsigned int *, unsigned int); /* Pointers to grid read functions */
int (*fft1d[k_n_fft_algorithms]) (struct GMT_CTRL *, gmt_grdfloat *, unsigned int, int, unsigned int); /* Pointers to available 1-D FFT functions (or NULL if not configured) */
int (*fft2d[k_n_fft_algorithms]) (struct GMT_CTRL *, gmt_grdfloat *, unsigned int, unsigned int, int, unsigned int); /* Pointers to available 2-D FFT functions (or NULL if not configured) */
/* This part contains pointers that may point to additional memory outside this struct */
char *DCWDIR; /* Path to the DCW directory */
char *GSHHGDIR; /* Path to the GSHHG directory */
char *SHAREDIR; /* Path to the GMT share directory */
char *HOMEDIR; /* Path to the user's home directory */
char *USERDIR; /* Path to the user's GMT data directory */
char *CACHEDIR; /* Path to the user's GMT cache directory for downloaded files */
char *DATADIR; /* Path to one or more directories with data sets */
char *TMPDIR; /* Path to the directory directory for isolation mode */
char *CUSTOM_LIBS; /* Names of one or more comma-separated GMT-compatible shared libraries */
char *DATASERVER; /* URL where to get remote @files */
char **user_media_name; /* Length of array with custom media dimensions */
struct GMT_FONTSPEC *font; /* Array with font names and height specification */
struct GMT_MEDIA *user_media; /* Array with custom media dimensions */
struct GMT_SHORTHAND *shorthand; /* Array with info about shorthand file extension magic */
};
struct GMT_CTRL {
/* Master structure for a GMT invocation. All internal settings for GMT is accessed here */
struct PSL_CTRL *PSL; /* Pointer to the PSL structure [or NULL] */
struct GMTAPI_CTRL *parent; /* Owner of this structure [or NULL]; gives access to the API from functions being passed *GMT only */
struct GMT_SESSION session; /* Structure with all values that do not change throughout a session */
struct GMT_INIT init; /* Structure with all values that do not change in a GMT_func call */
struct GMT_COMMON common; /* Structure with all the common GMT command settings (-R -J ..) */
struct GMT_CURRENT current; /* Structure with all the GMT items that can change during execution, such as defaults settings (pens, colors, fonts.. ) */
struct GMT_INTERNAL hidden; /* Internal global variables that are not to be changed directly by users */
};
/* p_to_io_func is used as a pointer to functions such as GMT_read_d in assignments
* and is used to declare gmtlib_get_io_ptr in gmt_io.c and gmt_prototypes.h */
typedef int (*p_to_io_func) (struct GMT_CTRL *, FILE *, uint64_t, double *);
/* Exit or return: For some environments (e.g., Matlab) we do not
wish to call the system "Exit" as it brings down Matlab as well. In those cases
we instead call return and let Matlab client deal with any follow-up. This
decision is set in GMT_Create_Session via its flags. While exit always returns
an integer code, the return functions may have to return other types, hence we
let GMT_exit possibly call exit, else it does nothing. Thus, calls to GMT_exit
must be followed by return <type> so that we return where we said we would. */
/* If GMT is not set or do_not_exit is false then we call system exit, else we move along */
static inline void GMT_exit (struct GMT_CTRL *GMT, int code) {
if (GMT == NULL || GMT->parent == NULL || GMT->parent->do_not_exit == false)
exit (code);
}
#endif /* GMT_TYPES_H */