source: git/src/cavern.h @ ed04c553

debug-cidebug-ci-sanitisersfaster-cavernloglog-selectstereo-2025walls-datawalls-data-hanging-as-warningwarn-only-for-hanging-survey
Last change on this file since ed04c553 was 63d4f07, checked in by Olly Betts <olly@…>, 17 months ago

Use stdbool.h

We've required C99 since 1.4.2.

  • Property mode set to 100644
File size: 15.2 KB
RevLine 
[0badc31]1/* cavern.h
[bb90203]2 * SURVEX Cave surveying software - header file
[fdffa7d]3 * Copyright (C) 1991-2024 Olly Betts
[44bb30d]4 * Copyright (C) 2004 Simeon Warner
[846746e]5 *
[89231c4]6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
[846746e]10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
[89231c4]13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 * GNU General Public License for more details.
[846746e]15 *
[89231c4]16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
[d333899]18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
[bb90203]19 */
20
[3875c32]21#ifndef CAVERN_H
22#define CAVERN_H
23
[05c700b]24/* Using covariances increases the memory required somewhat - may be
25 * desirable to disable this for small memory machines */
26
[93ac03a]27/* #define NO_COVARIANCES 1 */
[bb90203]28
[63d4f07]29#include <stdbool.h>
[bb90203]30#include <stdio.h>
31#include <stdlib.h>
32#include <string.h>
33#include <ctype.h>
34#include <math.h>
35#include <float.h>
36
[b39e24a]37#include <proj.h>
[c092d72]38
[a405bc1]39#include "img_hosted.h"
[3d441da]40#include "useful.h"
[bb90203]41
[05c700b]42/* Set EXPLICIT_FIXED_FLAG to 1 to force an explicit fixed flag to be used
43 * in each pos struct, rather than using p[0]==UNFIXED_VAL to indicate
44 * unfixed-ness.  This may be slightly faster, but uses more memory.
[bb90203]45 */
46#ifndef EXPLICIT_FIXED_FLAG
47# define EXPLICIT_FIXED_FLAG 0
48#endif
49
50typedef double real; /* so we can change the precision used easily */
51#define HUGE_REAL HUGE_VAL
[7bdf66d]52#define REAL_EPSILON DBL_EPSILON
[bb90203]53
54#if (!EXPLICIT_FIXED_FLAG)
55# define UNFIXED_VAL HUGE_VAL /* if p[0]==UNFIXED_VAL, station is unfixed */
56#endif
57
[7d40549]58#define SPECIAL_EOL             0x0001
59#define SPECIAL_BLANK           0x0002
60#define SPECIAL_KEYWORD         0x0004
61#define SPECIAL_COMMENT         0x0008
62#define SPECIAL_OMIT            0x0010
[a882316]63#ifndef NO_DEPRECATED
[7d40549]64#define SPECIAL_ROOT            0x0020
[a882316]65#endif
[7d40549]66#define SPECIAL_SEPARATOR       0x0040
67#define SPECIAL_NAMES           0x0080
68#define SPECIAL_DECIMAL         0x0100
69#define SPECIAL_MINUS           0x0200
70#define SPECIAL_PLUS            0x0400
71#define SPECIAL_OPEN            0x0800
72#define SPECIAL_CLOSE           0x1000
[bb90203]73
[3875c32]74extern char *fnm_output_base;
75extern int fnm_output_base_is_dir;
76
[d1878c51]77extern bool fExportUsed;
78
[1ee204e]79extern int current_days_since_1900;
[e0c7cd1]80
[bb90203]81/* Types */
82
[05c700b]83typedef enum {
[009a9e4]84   Q_NULL = -1, Q_DEFAULT, Q_POS, Q_PLUMB, Q_LEVEL,
85   Q_GRADIENT, Q_BACKGRADIENT, Q_BEARING, Q_BACKBEARING,
[4f38f94]86   Q_LENGTH, Q_BACKLENGTH, Q_DEPTH, Q_DX, Q_DY, Q_DZ, Q_COUNT, Q_DECLINATION,
[009a9e4]87   Q_LEFT, Q_RIGHT, Q_UP, Q_DOWN,
88   Q_MAC
[05c700b]89} q_quantity;
[bb90203]90
[27b8b59]91typedef enum {
[4e00b50]92   INFER_NULL = -1,
93   INFER_EQUATES,
94   INFER_EXPORTS,
95   INFER_PLUMBS,
96   INFER_SUBSURVEYS,
97   /* In Compass DAT files a dummy zero-length leg from a station to itself is
98    * used to provide a place to specify LRUD for the start or end of a
99    * traverse (depending if dimensions are measured at the from or to
100    * station), so we shouldn't warn about equating a station to itself.
101    */
102   INFER_EQUATES_SELF_OK
[27b8b59]103} infer_what;
104
[bb90203]105/* unsigned long to cope with 16-bit int-s */
106#define BIT(N) (1UL << (N))
107#define BITA(N) (1UL << ((N) - 'a'))
108
[7f08c83]109#define TSTBIT(W, N) (((W)>>(N))&1)
110
[bb90203]111/* masks for quantities which are length and angles respectively */
[4f38f94]112#define LEN_QMASK (BIT(Q_LENGTH) | BIT(Q_BACKLENGTH) | BIT(Q_DEPTH) |\
[9dc51ae]113   BIT(Q_DX) | BIT(Q_DY) | BIT(Q_DZ) | BIT(Q_POS) | BIT(Q_COUNT) |\
114   BIT(Q_LEFT) | BIT(Q_RIGHT) | BIT(Q_UP) | BIT(Q_DOWN))
[b14f44f]115#define ANG_QMASK (BIT(Q_BEARING) | BIT(Q_BACKBEARING) |\
116   BIT(Q_GRADIENT) | BIT(Q_BACKGRADIENT) | BIT(Q_PLUMB) | BIT(Q_LEVEL) |\
117   BIT(Q_DECLINATION))
[bb90203]118
[5c3c61a]119/* if you add/change the order, check factor_tab in commands.c */
[05c700b]120typedef enum {
121   UNITS_NULL = -1, UNITS_METRES, UNITS_FEET, UNITS_YARDS,
[00b10c1]122   UNITS_DEGS, UNITS_QUADRANTS, UNITS_GRADS, UNITS_PERCENT, UNITS_MINUTES,
123   UNITS_MAC, UNITS_DEPRECATED_ALIAS_FOR_GRADS
[05c700b]124} u_units;
[5c3c61a]125
[95c3272]126/* don't reorder these values!  They need to match with img.h too */
[5c3c61a]127typedef enum {
[95c3272]128   FLAGS_NOT = -2, FLAGS_UNKNOWN = -1, FLAGS_SURFACE, FLAGS_DUPLICATE,
[710ecc1]129   FLAGS_SPLAY,
[3d441da]130#if 0
131   /* underground, but through rock (e.g. radiolocation).  Want to hide from
132    * plots by default (so not cave) but don't want to include in surface
133    * triangulation nets (so not surface) */
[710ecc1]134   FLAGS_SKELETAL, /* FIXME */
[3d441da]135#endif
[dcbcae0]136   /* Don't need to match img.h: */
137   FLAGS_ANON_ONE_END,
[eb5aea0]138   FLAGS_IMPLICIT_SPLAY,
139   FLAGS_STYLE_BIT0, FLAGS_STYLE_BIT1, FLAGS_STYLE_BIT2
[5c3c61a]140} flags;
[bb90203]141
[eb5aea0]142/* flags are currently stored in an unsigned char */
143typedef int compiletimeassert_flags0[FLAGS_STYLE_BIT2 <= 7 ? 1 : -1];
144
145/* Mask to AND with to get bits to pass to img library. */
146#define FLAGS_MASK \
147    (BIT(FLAGS_SURFACE) | BIT(FLAGS_DUPLICATE) | BIT(FLAGS_SPLAY))
148
[ab4de24]149typedef int compiletimeassert_flags1[BIT(FLAGS_SURFACE) == img_FLAG_SURFACE ? 1 : -1];
150typedef int compiletimeassert_flags2[BIT(FLAGS_DUPLICATE) == img_FLAG_DUPLICATE ? 1 : -1];
151typedef int compiletimeassert_flags3[BIT(FLAGS_SPLAY) == img_FLAG_SPLAY ? 1 : -1];
152
[95c3272]153typedef enum {
[ee05463]154   /* Don't reorder these values!  They need to match with img.h too. */
[dfb4240]155   SFLAGS_SURFACE = 0, SFLAGS_UNDERGROUND, SFLAGS_ENTRANCE, SFLAGS_EXPORTED,
[dcbcae0]156   SFLAGS_FIXED, SFLAGS_ANON, SFLAGS_WALL,
[ee05463]157   /* These values don't need to match img.h, but mustn't clash. */
[f15cde77]158   SFLAGS_USED = 11,
[d333899]159   SFLAGS_SOLVED = 12, SFLAGS_SUSPECTTYPO = 13, SFLAGS_SURVEY = 14, SFLAGS_PREFIX_ENTERED = 15
[95c3272]160} sflags;
[ee05463]161
162/* Mask to AND with to get bits to pass to img library. */
163#define SFLAGS_MASK (BIT(SFLAGS_SURFACE) | BIT(SFLAGS_UNDERGROUND) |\
[a2c33ae]164        BIT(SFLAGS_ENTRANCE) | BIT(SFLAGS_EXPORTED) | BIT(SFLAGS_FIXED) |\
[dcbcae0]165        BIT(SFLAGS_ANON) | BIT(SFLAGS_WALL))
[95c3272]166
[ab4de24]167typedef int compiletimeassert_sflags1[BIT(SFLAGS_SURFACE) == img_SFLAG_SURFACE ? 1 : -1];
168typedef int compiletimeassert_sflags2[BIT(SFLAGS_UNDERGROUND) == img_SFLAG_UNDERGROUND ? 1 : -1];
169typedef int compiletimeassert_sflags3[BIT(SFLAGS_ENTRANCE) == img_SFLAG_ENTRANCE ? 1 : -1];
170typedef int compiletimeassert_sflags4[BIT(SFLAGS_EXPORTED) == img_SFLAG_EXPORTED ? 1 : -1];
171typedef int compiletimeassert_sflags5[BIT(SFLAGS_FIXED) == img_SFLAG_FIXED ? 1 : -1];
[a2c33ae]172typedef int compiletimeassert_sflags6[BIT(SFLAGS_ANON) == img_SFLAG_ANON ? 1 : -1];
[dcbcae0]173typedef int compiletimeassert_sflags7[BIT(SFLAGS_WALL) == img_SFLAG_WALL ? 1 : -1];
[ab4de24]174
[bb90203]175/* enumeration of field types */
[05c700b]176typedef enum {
[4f38f94]177   End = 0, Tape, Comp, Clino, BackTape, BackComp, BackClino,
178   Left, Right, Up, Down,
[21c226e]179   FrDepth, ToDepth, Dx, Dy, Dz, FrCount, ToCount,
[44bb30d]180   /* Up to here are readings are allowed multiple values
181    * and have slot in the value[] array in datain.c.
182    * (Depth, DepthChange, and Count can have multiple
183    * readings, but are actually handled using tokens
184    * above rather than as themselves).
185    *
186    * Fr must be the first reading after this comment!
187    */
[21c226e]188   Fr, To, Station, Depth, DepthChange, Count, Dir,
[44bb30d]189   Newline, IgnoreAllAndNewLine, Ignore, IgnoreAll,
190   /* IgnoreAll must be the last reading before this comment!
191    *
192    * Readings after this comment are only used in datain.c
193    * so can have enum values >= 32 because we only use a
194    * bitmask for those readings used in commands.c.
195    */
[07442af]196   CompassDATComp, CompassDATClino, CompassDATBackComp, CompassDATBackClino,
197   CompassDATLeft, CompassDATRight, CompassDATUp, CompassDATDown,
198   CompassDATFlags
[0395657]199} reading;
[05c700b]200
[90bb053f]201/* if IgnoreAll is >= 32, the compiler will choke on this */
202typedef char compiletimeassert_reading[IgnoreAll < 32 ? 1 : -1];
203
[3d441da]204/* position or length vector */
205typedef real delta[3];
206
207/* variance */
208#ifdef NO_COVARIANCES
209typedef real var[3];
210typedef var svar;
211#else
212typedef real var[3][3];
213typedef real svar[6];
214#endif
[bb90203]215
216/* station name */
217typedef struct Prefix {
218   struct Prefix *up, *down, *right;
219   struct Node *stn;
220   struct Pos *pos;
[eb18f4d]221   const char *ident;
[4d9eecd]222   const char *filename;
223   unsigned int line;
[c00c74a9]224   /* If (min_export == 0) then max_export is max # levels above is this
225    * prefix is used (and so needs to be exported) (0 == parent only).
226    * If (min_export > 0) then max_export is max # levels above this
[932f7e9]227    * prefix has been exported, and min_export is how far down the exports
228    * have got (if min_export > 1 after a run, this prefix hasn't been
[c00c74a9]229    * exported from below enough).
[27b8b59]230    * If INFER_EXPORTS is active when a station is encountered, we
[c00c74a9]231    * set min_export = USHRT_MAX and max_export gets set as usual.  Then at
232    * the end of the run, we also mark stations with min_export == USHRT_MAX
233    * and max_export > 0 as exported. */
234   unsigned short max_export, min_export;
[95c3272]235   /* stn flags - e.g. surface, underground, entrance
236    * also suspecttypo and survey */
[421b7d2]237   unsigned short sflags;
[c00c74a9]238   short shape;
[bb90203]239} prefix;
240
[b5a3219]241/* survey metadata */
242typedef struct Meta_data {
243    size_t ref_count;
[0e9e1ee]244    /* Days since 1900 for start and end date of survey, or -1 if undated. */
[1ee204e]245    int days1, days2;
[b5a3219]246} meta_data;
247
[bb90203]248/* stuff stored for both forward & reverse legs */
249typedef struct {
250   struct Node *to;
251   /* bits 0..1 = reverse leg number; bit7 is fFullLeg */
252   /* bit6 = fReplacementLeg (by reduction rules) */
[cb3d1e2]253   /* bit5 = articulation leg (i.e. carries no error) */
[67508f0]254   unsigned char reverse;
[5c3c61a]255   /* flags - e.g. surface, duplicate survey
[693388e]256    * only used if (FLAG_DATAHERE & !(FLAG_REPLACEMENTLEG|FLAG_FAKE))
[b5a3219]257    * This could be only in linkfor, but this is actually more space
258    * efficient.
[5c3c61a]259    */
[67508f0]260   unsigned char flags;
[bb90203]261} linkcommon;
[3d441da]262
[cb3d1e2]263#define FLAG_DATAHERE 0x80
264#define FLAG_REPLACEMENTLEG 0x40
[7f08c83]265#define FLAG_ARTICULATION 0x20
[693388e]266#define FLAG_FAKE 0x10 /* an equate or leg inside an sdfix */
[cb3d1e2]267#define MASK_REVERSEDIRN 0x03
[bb90203]268
269/* reverse leg - deltas & vars stored on other dirn */
270typedef struct LinkRev {
271   linkcommon l;
272} linkrev;
273
274/* forward leg - deltas & vars stored here */
275typedef struct Link {
276   linkcommon l;
[eb18f4d]277   delta d; /* Delta */
[59f2dbb]278   svar v; /* Variances */
[b5a3219]279   meta_data *meta;
[bb90203]280} linkfor;
281
282/* node - like a station, except several nodes are used to represent a
283 * station with more than 3 legs connected to it
284 */
285typedef struct Node {
286   struct Prefix *name;
287   struct Link *leg[3];
[564f471]288   struct Node *prev, *next;
[118eea4]289   long colour;
[bb90203]290} node;
291
292/* station position */
293typedef struct Pos {
[eb18f4d]294   delta p; /* Position */
[bb90203]295#if EXPLICIT_FIXED_FLAG
[67508f0]296   unsigned char fFixed; /* flag indicating if station is a fixed point */
[bb90203]297#endif
298} pos;
299
300/*
301typedef struct Inst {
302   real zero, scale, units;
303} inst;
304*/
305
[107b8bd]306/* Survey data styles */
307#define STYLE_NORMAL     0
308#define STYLE_DIVING     1
309#define STYLE_CARTESIAN  2
310#define STYLE_CYLPOLAR   3
[ac28f4f]311#define STYLE_NOSURVEY   4
312#define STYLE_PASSAGE    5
[ee05463]313#define STYLE_IGNORE     6
[107b8bd]314
[eb5aea0]315typedef int compiletimeassert_style1[STYLE_NORMAL == img_STYLE_NORMAL ? 1 : -1];
316typedef int compiletimeassert_style2[STYLE_DIVING == img_STYLE_DIVING ? 1 : -1];
317typedef int compiletimeassert_style3[STYLE_CARTESIAN == img_STYLE_CARTESIAN ? 1 : -1];
318typedef int compiletimeassert_style4[STYLE_CYLPOLAR == img_STYLE_CYLPOLAR ? 1 : -1];
319typedef int compiletimeassert_style5[STYLE_NOSURVEY == img_STYLE_NOSURVEY ? 1 : -1];
320
[bb90203]321/* various settings preserved by *BEGIN and *END */
322typedef struct Settings {
[b5a3219]323   struct Settings *next;
[eb18f4d]324   unsigned int Truncate;
[fa42426]325   bool f_clino_percent;
326   bool f_backclino_percent;
[00b10c1]327   bool f_bearing_quadrants;
328   bool f_backbearing_quadrants;
[dcbcae0]329   bool dash_for_anon_wall_station;
[27b8b59]330   unsigned char infer;
[bb90203]331   enum {OFF, LOWER, UPPER} Case;
[fdffa7d]332   /* STYLE_xxx value to process data as. */
[107b8bd]333   int style;
[fdffa7d]334   /* STYLE_xxx value to put in 3d file (different for Compass DAT diving
335    * data, as the data in the DAT file is always presented in the format
336    * tape,compass,clino even if that isn't how it was really measured).
337    */
338   int recorded_style;
[bb90203]339   prefix *Prefix;
[613028c]340   prefix *begin_survey; /* used to check BEGIN and END match */
[bb90203]341   short *Translate; /* if short is >= 16 bits, which ANSI requires */
342   real Var[Q_MAC];
343   real z[Q_MAC];
344   real sc[Q_MAC];
[cb3d1e2]345   real units[Q_MAC];
[78ed938]346   const reading *ordering;
[47c7a94]347   int begin_lineno; /* 0 means no block started in this file */
[5c3c61a]348   int flags;
[b39e24a]349   char* proj_str;
[58c7b459]350   /* Location at which we calculate the declination if
[3830dc0]351    * z[Q_DECLINATION] == HUGE_REAL.
352    *
353    * Latitude and longitude are in radians; altitude is in metres above the
354    * ellipsoid.
355    */
356   real dec_lat, dec_lon, dec_alt;
[b5907bb]357   /* Cached auto-declination in radians, or HUGE_REAL for no cached value.
358    * Only meaningful if date1 != -1.
[95b0f1d]359    */
360   real declination;
[37d6b84]361   double min_declination, max_declination;
362   int min_declination_days, max_declination_days;
363   const char* dec_filename;
364   int dec_line;
365   /* Copy of the text of the `*declination auto ...` line (malloced). */
366   char* dec_context;
[b5907bb]367   /* Grid convergence in radians. */
[2c17123e]368   real convergence;
[b5a3219]369   meta_data * meta;
[bb90203]370} settings;
371
372/* global variables */
373extern settings *pcs;
374extern prefix *root;
[a2c33ae]375extern prefix *anon_list;
[bb90203]376extern node *stnlist;
[3875c32]377extern unsigned long optimize;
[c092d72]378extern char * proj_str_out;
[da9163b]379extern PJ * pj_cached;
[bd283cf6]380
[bb90203]381extern char *survey_title;
382extern int survey_title_len;
383
384extern bool fExplicitTitle;
385extern long cLegs, cStns, cComponents;
386extern FILE *fhErrStat;
[693388e]387extern img *pimg;
[bb90203]388extern real totadj, total, totplan, totvert;
[dfac588]389extern real min[6], max[6];
390extern prefix *pfxHi[6], *pfxLo[6];
[647407d]391extern bool fQuiet; /* just show brief summary + errors */
[ed0f5b6]392extern bool fMute; /* just show errors */
[c0b279c]393extern bool fSuppress; /* only output 3d file */
[bb90203]394
395/* macros */
396
397#define POS(S, D) ((S)->name->pos->p[(D)])
398#define POSD(S) ((S)->name->pos->p)
399
400#define data_here(L) ((L)->l.reverse & FLAG_DATAHERE)
[cb3d1e2]401#define reverse_leg_dirn(L) ((L)->l.reverse & MASK_REVERSEDIRN)
402#define reverse_leg(L) ((L)->l.to->leg[reverse_leg_dirn(L)])
[bb90203]403
404#if EXPLICIT_FIXED_FLAG
405# define pfx_fixed(N) ((N)->pos->fFixed)
[3e25a0d]406# define pos_fixed(P) ((P)->fFixed)
[63d4f07]407# define fix(S) (S)->name->pos->fFixed = (char)true
408# define fixpos(P) (P)->fFixed = (char)true
409# define unfix(S) (S)->name->pos->fFixed = (char)false
[bb90203]410#else
411# define pfx_fixed(N) ((N)->pos->p[0] != UNFIXED_VAL)
[3e25a0d]412# define pos_fixed(P) ((P)->p[0] != UNFIXED_VAL)
[bb90203]413# define fix(S) NOP
[084905c]414# define fixpos(P) NOP
[bb90203]415# define unfix(S) POS((S), 0) = UNFIXED_VAL
416#endif
417#define fixed(S) pfx_fixed((S)->name)
418
[0af7076]419/* macros for special chars */
[bb90203]420
421#define isEol(c)    (pcs->Translate[(c)] & SPECIAL_EOL)
422#define isBlank(c)  (pcs->Translate[(c)] & SPECIAL_BLANK)
423#define isKeywd(c)  (pcs->Translate[(c)] & SPECIAL_KEYWORD)
424#define isComm(c)   (pcs->Translate[(c)] & SPECIAL_COMMENT)
425#define isOmit(c)   (pcs->Translate[(c)] & SPECIAL_OMIT)
[a882316]426#ifndef NO_DEPRECATED
[bb90203]427#define isRoot(c)   (pcs->Translate[(c)] & SPECIAL_ROOT)
[a882316]428#endif
[bb90203]429#define isSep(c)    (pcs->Translate[(c)] & SPECIAL_SEPARATOR)
430#define isNames(c)  (pcs->Translate[(c)] & SPECIAL_NAMES)
431#define isDecimal(c) (pcs->Translate[(c)] & SPECIAL_DECIMAL)
432#define isMinus(c)  (pcs->Translate[(c)] & SPECIAL_MINUS)
433#define isPlus(c)   (pcs->Translate[(c)] & SPECIAL_PLUS)
[21c226e]434#define isOpen(c)   (pcs->Translate[(c)] & SPECIAL_OPEN)
435#define isClose(c)  (pcs->Translate[(c)] & SPECIAL_CLOSE)
[bb90203]436
437#define isSign(c)   (pcs->Translate[(c)] & (SPECIAL_PLUS | SPECIAL_MINUS))
438#define isData(c)   (pcs->Translate[(c)] & (SPECIAL_OMIT | SPECIAL_ROOT|\
439   SPECIAL_SEPARATOR | SPECIAL_NAMES | SPECIAL_DECIMAL | SPECIAL_PLUS |\
440   SPECIAL_MINUS))
441
[647407d]442typedef struct nosurveylink {
443   node *fr, *to;
[b3bef47]444   int flags;
[ee05463]445   meta_data *meta;
[647407d]446   struct nosurveylink *next;
447} nosurveylink;
448
449extern nosurveylink *nosurveyhead;
450
[ee05463]451typedef struct lrud {
452    struct lrud * next;
453    prefix *stn;
[a6301a1]454    meta_data *meta;
[ee05463]455    real l, r, u, d;
456} lrud;
457
458typedef struct lrudlist {
459    lrud * tube;
460    struct lrudlist * next;
461} lrudlist;
462
463extern lrudlist * model;
464
465extern lrud ** next_lrud;
466
[3875c32]467#endif /* CAVERN_H */
Note: See TracBrowser for help on using the repository browser.