source: git/src/cavern.h @ 53496ab3

RELEASE/1.2debug-cidebug-ci-sanitisersstereowalls-data
Last change on this file since 53496ab3 was a405bc1, checked in by Olly Betts <olly@…>, 11 years ago

src/: IMG_HOSTED no longer affects the img API at all.

  • Property mode set to 100644
File size: 13.7 KB
Line 
1/* cavern.h
2 * SURVEX Cave surveying software - header file
3 * Copyright (C) 1991-2003,2005,2006,2010,2013 Olly Betts
4 * Copyright (C) 2004 Simeon Warner
5 *
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.
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
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 * GNU General Public License for more details.
15 *
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
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
19 */
20
21#ifndef CAVERN_H
22#define CAVERN_H
23
24/* Using covariances increases the memory required somewhat - may be
25 * desirable to disable this for small memory machines */
26
27/* #define NO_COVARIANCES 1 */
28
29#include <stdio.h>
30#include <stdlib.h>
31#include <string.h>
32#include <ctype.h>
33#include <math.h>
34#include <float.h>
35
36#include "img_hosted.h"
37#include "useful.h"
38
39/* Set EXPLICIT_FIXED_FLAG to 1 to force an explicit fixed flag to be used
40 * in each pos struct, rather than using p[0]==UNFIXED_VAL to indicate
41 * unfixed-ness.  This may be slightly faster, but uses more memory.
42 */
43#ifndef EXPLICIT_FIXED_FLAG
44# define EXPLICIT_FIXED_FLAG 0
45#endif
46
47typedef double real; /* so we can change the precision used easily */
48#define HUGE_REAL HUGE_VAL
49#define REAL_EPSILON DBL_EPSILON
50
51#if (!EXPLICIT_FIXED_FLAG)
52# define UNFIXED_VAL HUGE_VAL /* if p[0]==UNFIXED_VAL, station is unfixed */
53#endif
54
55#define SPECIAL_EOL             0x0001
56#define SPECIAL_BLANK           0x0002
57#define SPECIAL_KEYWORD         0x0004
58#define SPECIAL_COMMENT         0x0008
59#define SPECIAL_OMIT            0x0010
60#ifndef NO_DEPRECATED
61#define SPECIAL_ROOT            0x0020
62#endif
63#define SPECIAL_SEPARATOR       0x0040
64#define SPECIAL_NAMES           0x0080
65#define SPECIAL_DECIMAL         0x0100
66#define SPECIAL_MINUS           0x0200
67#define SPECIAL_PLUS            0x0400
68#define SPECIAL_OPEN            0x0800
69#define SPECIAL_CLOSE           0x1000
70
71extern char *fnm_output_base;
72extern int fnm_output_base_is_dir;
73
74extern bool fExportUsed;
75
76extern int current_days_since_1900;
77
78/* Types */
79
80typedef enum {
81   Q_NULL = -1, Q_DEFAULT, Q_LENGTH, Q_DEPTH, Q_DX, Q_DY, Q_DZ, Q_COUNT, Q_POS,
82   Q_BEARING, Q_BACKBEARING, Q_GRADIENT, Q_BACKGRADIENT, Q_DECLINATION,
83   Q_PLUMB, Q_LEVEL, Q_LEFT, Q_RIGHT, Q_UP, Q_DOWN, Q_MAC
84} q_quantity;
85
86typedef enum {
87   INFER_NULL = -1, INFER_EQUATES, INFER_EXPORTS, INFER_PLUMBS, INFER_SUBSURVEYS
88} infer_what;
89
90/* unsigned long to cope with 16-bit int-s */
91#define BIT(N) (1UL << (N))
92#define BITA(N) (1UL << ((N) - 'a'))
93
94#define TSTBIT(W, N) (((W)>>(N))&1)
95
96/* masks for quantities which are length and angles respectively */
97#define LEN_QMASK (BIT(Q_LENGTH) | BIT(Q_DEPTH) |\
98   BIT(Q_DX) | BIT(Q_DY) | BIT(Q_DZ) | BIT(Q_POS) | BIT(Q_COUNT))
99#define ANG_QMASK (BIT(Q_BEARING) | BIT(Q_BACKBEARING) |\
100   BIT(Q_GRADIENT) | BIT(Q_BACKGRADIENT) | BIT(Q_PLUMB) | BIT(Q_LEVEL) |\
101   BIT(Q_DECLINATION))
102
103/* if you add/change the order, check factor_tab in commands.c */
104typedef enum {
105   UNITS_NULL = -1, UNITS_METRES, UNITS_FEET, UNITS_YARDS,
106   UNITS_DEGS, UNITS_GRADS, UNITS_PERCENT, UNITS_MINUTES, UNITS_MAC
107} u_units;
108
109/* don't reorder these values!  They need to match with img.h too */
110typedef enum {
111   FLAGS_NOT = -2, FLAGS_UNKNOWN = -1, FLAGS_SURFACE, FLAGS_DUPLICATE,
112   FLAGS_SPLAY,
113#if 0
114   /* underground, but through rock (e.g. radiolocation).  Want to hide from
115    * plots by default (so not cave) but don't want to include in surface
116    * triangulation nets (so not surface) */
117   FLAGS_SKELETAL, /* FIXME */
118#endif
119   /* Don't need to match img.h: */
120   FLAGS_ANON_ONE_END,
121   FLAGS_IMPLICIT_SPLAY,
122   FLAGS_STYLE_BIT0, FLAGS_STYLE_BIT1, FLAGS_STYLE_BIT2
123} flags;
124
125/* flags are currently stored in an unsigned char */
126typedef int compiletimeassert_flags0[FLAGS_STYLE_BIT2 <= 7 ? 1 : -1];
127
128/* Mask to AND with to get bits to pass to img library. */
129#define FLAGS_MASK \
130    (BIT(FLAGS_SURFACE) | BIT(FLAGS_DUPLICATE) | BIT(FLAGS_SPLAY))
131
132typedef int compiletimeassert_flags1[BIT(FLAGS_SURFACE) == img_FLAG_SURFACE ? 1 : -1];
133typedef int compiletimeassert_flags2[BIT(FLAGS_DUPLICATE) == img_FLAG_DUPLICATE ? 1 : -1];
134typedef int compiletimeassert_flags3[BIT(FLAGS_SPLAY) == img_FLAG_SPLAY ? 1 : -1];
135
136typedef enum {
137   /* Don't reorder these values!  They need to match with img.h too. */
138   SFLAGS_SURFACE = 0, SFLAGS_UNDERGROUND, SFLAGS_ENTRANCE, SFLAGS_EXPORTED,
139   SFLAGS_FIXED, SFLAGS_ANON, SFLAGS_WALL,
140   /* These values don't need to match img.h, but mustn't clash. */
141   SFLAGS_USED = 11,
142   SFLAGS_SOLVED = 12, SFLAGS_SUSPECTTYPO = 13, SFLAGS_SURVEY = 14, SFLAGS_PREFIX_ENTERED = 15
143} sflags;
144
145/* Mask to AND with to get bits to pass to img library. */
146#define SFLAGS_MASK (BIT(SFLAGS_SURFACE) | BIT(SFLAGS_UNDERGROUND) |\
147        BIT(SFLAGS_ENTRANCE) | BIT(SFLAGS_EXPORTED) | BIT(SFLAGS_FIXED) |\
148        BIT(SFLAGS_ANON) | BIT(SFLAGS_WALL))
149
150typedef int compiletimeassert_sflags1[BIT(SFLAGS_SURFACE) == img_SFLAG_SURFACE ? 1 : -1];
151typedef int compiletimeassert_sflags2[BIT(SFLAGS_UNDERGROUND) == img_SFLAG_UNDERGROUND ? 1 : -1];
152typedef int compiletimeassert_sflags3[BIT(SFLAGS_ENTRANCE) == img_SFLAG_ENTRANCE ? 1 : -1];
153typedef int compiletimeassert_sflags4[BIT(SFLAGS_EXPORTED) == img_SFLAG_EXPORTED ? 1 : -1];
154typedef int compiletimeassert_sflags5[BIT(SFLAGS_FIXED) == img_SFLAG_FIXED ? 1 : -1];
155typedef int compiletimeassert_sflags6[BIT(SFLAGS_ANON) == img_SFLAG_ANON ? 1 : -1];
156typedef int compiletimeassert_sflags7[BIT(SFLAGS_WALL) == img_SFLAG_WALL ? 1 : -1];
157
158/* enumeration of field types */
159typedef enum {
160   End = 0, Tape, Comp, Clino, BackComp, BackClino, Left, Right, Up, Down,
161   FrDepth, ToDepth, Dx, Dy, Dz, FrCount, ToCount,
162   /* Up to here are readings are allowed multiple values
163    * and have slot in the value[] array in datain.c.
164    * (Depth, DepthChange, and Count can have multiple
165    * readings, but are actually handled using tokens
166    * above rather than as themselves).
167    *
168    * Fr must be the first reading after this comment!
169    */
170   Fr, To, Station, Depth, DepthChange, Count, Dir,
171   Newline, IgnoreAllAndNewLine, Ignore, IgnoreAll,
172   /* IgnoreAll must be the last reading before this comment!
173    *
174    * Readings after this comment are only used in datain.c
175    * so can have enum values >= 32 because we only use a
176    * bitmask for those readings used in commands.c.
177    */
178   CompassDATComp, CompassDATClino, CompassDATBackComp, CompassDATBackClino,
179   CompassDATLeft, CompassDATRight, CompassDATUp, CompassDATDown,
180   CompassDATFlags
181} reading;
182/* Tape Comp Clino BackComp BackClino FrDepth ToDepth Dx Dy Dz FrCount ToCount */
183
184/* if IgnoreAll is >= 32, the compiler will choke on this */
185typedef char compiletimeassert_reading[IgnoreAll < 32 ? 1 : -1];
186
187/* position or length vector */
188typedef real delta[3];
189
190/* variance */
191#ifdef NO_COVARIANCES
192typedef real var[3];
193typedef var svar;
194#else
195typedef real var[3][3];
196typedef real svar[6];
197#endif
198
199/* station name */
200typedef struct Prefix {
201   struct Prefix *up, *down, *right;
202   struct Node *stn;
203   struct Pos *pos;
204   const char *ident;
205   const char *filename;
206   unsigned int line;
207   /* If (min_export == 0) then max_export is max # levels above is this
208    * prefix is used (and so needs to be exported) (0 == parent only).
209    * If (min_export > 0) then max_export is max # levels above this
210    * prefix has been exported, and min_export is how far down the exports
211    * have got (if min_export > 1 after a run, this prefix hasn't been
212    * exported from below enough).
213    * If INFER_EXPORTS is active when a station is encountered, we
214    * set min_export = USHRT_MAX and max_export gets set as usual.  Then at
215    * the end of the run, we also mark stations with min_export == USHRT_MAX
216    * and max_export > 0 as exported. */
217   unsigned short max_export, min_export;
218   /* stn flags - e.g. surface, underground, entrance
219    * also suspecttypo and survey */
220   unsigned short sflags;
221   short shape;
222} prefix;
223
224/* survey metadata */
225typedef struct Meta_data {
226    size_t ref_count;
227    int days1, days2;
228} meta_data;
229
230/* stuff stored for both forward & reverse legs */
231typedef struct {
232   struct Node *to;
233   /* bits 0..1 = reverse leg number; bit7 is fFullLeg */
234   /* bit6 = fReplacementLeg (by reduction rules) */
235   /* bit5 = articulation leg (i.e. carries no error) */
236   unsigned char reverse;
237   /* flags - e.g. surface, duplicate survey
238    * only used if (FLAG_DATAHERE & !(FLAG_REPLACEMENTLEG|FLAG_FAKE))
239    * This could be only in linkfor, but this is actually more space
240    * efficient.
241    */
242   unsigned char flags;
243} linkcommon;
244
245#define FLAG_DATAHERE 0x80
246#define FLAG_REPLACEMENTLEG 0x40
247#define FLAG_ARTICULATION 0x20
248#define FLAG_FAKE 0x10 /* an equate or leg inside an sdfix */
249#define MASK_REVERSEDIRN 0x03
250
251/* reverse leg - deltas & vars stored on other dirn */
252typedef struct LinkRev {
253   linkcommon l;
254} linkrev;
255
256/* forward leg - deltas & vars stored here */
257typedef struct Link {
258   linkcommon l;
259   delta d; /* Delta */
260   svar v; /* Variances */
261   meta_data *meta;
262} linkfor;
263
264/* node - like a station, except several nodes are used to represent a
265 * station with more than 3 legs connected to it
266 */
267typedef struct Node {
268   struct Prefix *name;
269   struct Link *leg[3];
270   struct Node *prev, *next;
271   long colour;
272} node;
273
274/* station position */
275typedef struct Pos {
276   delta p; /* Position */
277#if EXPLICIT_FIXED_FLAG
278   unsigned char fFixed; /* flag indicating if station is a fixed point */
279#endif
280} pos;
281
282/*
283typedef struct Inst {
284   real zero, scale, units;
285} inst;
286*/
287
288/* Survey data styles */
289#define STYLE_NORMAL     0
290#define STYLE_DIVING     1
291#define STYLE_CARTESIAN  2
292#define STYLE_CYLPOLAR   3
293#define STYLE_NOSURVEY   4
294#define STYLE_PASSAGE    5
295#define STYLE_IGNORE     6
296
297typedef int compiletimeassert_style1[STYLE_NORMAL == img_STYLE_NORMAL ? 1 : -1];
298typedef int compiletimeassert_style2[STYLE_DIVING == img_STYLE_DIVING ? 1 : -1];
299typedef int compiletimeassert_style3[STYLE_CARTESIAN == img_STYLE_CARTESIAN ? 1 : -1];
300typedef int compiletimeassert_style4[STYLE_CYLPOLAR == img_STYLE_CYLPOLAR ? 1 : -1];
301typedef int compiletimeassert_style5[STYLE_NOSURVEY == img_STYLE_NOSURVEY ? 1 : -1];
302
303/* various settings preserved by *BEGIN and *END */
304typedef struct Settings {
305   struct Settings *next;
306   unsigned int Truncate;
307   bool f_clino_percent;
308   bool f_backclino_percent;
309   bool dash_for_anon_wall_station;
310   unsigned char infer;
311   enum {OFF, LOWER, UPPER} Case;
312   int style;
313   prefix *Prefix;
314   prefix *tag; /* used to check BEGIN/END tags match */
315   short *Translate; /* if short is >= 16 bits, which ANSI requires */
316   real Var[Q_MAC];
317   real z[Q_MAC];
318   real sc[Q_MAC];
319   real units[Q_MAC];
320   reading *ordering;
321   int begin_lineno; /* 0 means no block started in this file */
322   int flags;
323   meta_data * meta;
324} settings;
325
326/* global variables */
327extern settings *pcs;
328extern prefix *root;
329extern prefix *anon_list;
330extern node *stnlist;
331extern unsigned long optimize;
332
333extern char *survey_title;
334extern int survey_title_len;
335
336extern bool fExplicitTitle;
337extern long cLegs, cStns, cComponents;
338extern FILE *fhErrStat;
339extern img *pimg;
340#ifndef NO_PERCENTAGE
341extern bool fPercent;
342#endif
343extern real totadj, total, totplan, totvert;
344extern real min[3], max[3];
345extern prefix *pfxHi[3], *pfxLo[3];
346extern bool fQuiet; /* just show brief summary + errors */
347extern bool fMute; /* just show errors */
348extern bool fSuppress; /* only output 3d file */
349
350/* macros */
351
352#define POS(S, D) ((S)->name->pos->p[(D)])
353#define POSD(S) ((S)->name->pos->p)
354
355#define data_here(L) ((L)->l.reverse & FLAG_DATAHERE)
356#define reverse_leg_dirn(L) ((L)->l.reverse & MASK_REVERSEDIRN)
357#define reverse_leg(L) ((L)->l.to->leg[reverse_leg_dirn(L)])
358
359#if EXPLICIT_FIXED_FLAG
360# define pfx_fixed(N) ((N)->pos->fFixed)
361# define pos_fixed(P) ((P)->fFixed)
362# define fix(S) (S)->name->pos->fFixed = (char)fTrue
363# define fixpos(P) (P)->fFixed = (char)fTrue
364# define unfix(S) (S)->name->pos->fFixed = (char)fFalse
365#else
366# define pfx_fixed(N) ((N)->pos->p[0] != UNFIXED_VAL)
367# define pos_fixed(P) ((P)->p[0] != UNFIXED_VAL)
368# define fix(S) NOP
369# define fixpos(P) NOP
370# define unfix(S) POS((S), 0) = UNFIXED_VAL
371#endif
372#define fixed(S) pfx_fixed((S)->name)
373
374/* macros for special chars */
375
376#define isEol(c)    (pcs->Translate[(c)] & SPECIAL_EOL)
377#define isBlank(c)  (pcs->Translate[(c)] & SPECIAL_BLANK)
378#define isKeywd(c)  (pcs->Translate[(c)] & SPECIAL_KEYWORD)
379#define isComm(c)   (pcs->Translate[(c)] & SPECIAL_COMMENT)
380#define isOmit(c)   (pcs->Translate[(c)] & SPECIAL_OMIT)
381#ifndef NO_DEPRECATED
382#define isRoot(c)   (pcs->Translate[(c)] & SPECIAL_ROOT)
383#endif
384#define isSep(c)    (pcs->Translate[(c)] & SPECIAL_SEPARATOR)
385#define isNames(c)  (pcs->Translate[(c)] & SPECIAL_NAMES)
386#define isDecimal(c) (pcs->Translate[(c)] & SPECIAL_DECIMAL)
387#define isMinus(c)  (pcs->Translate[(c)] & SPECIAL_MINUS)
388#define isPlus(c)   (pcs->Translate[(c)] & SPECIAL_PLUS)
389#define isOpen(c)   (pcs->Translate[(c)] & SPECIAL_OPEN)
390#define isClose(c)  (pcs->Translate[(c)] & SPECIAL_CLOSE)
391
392#define isSign(c)   (pcs->Translate[(c)] & (SPECIAL_PLUS | SPECIAL_MINUS))
393#define isData(c)   (pcs->Translate[(c)] & (SPECIAL_OMIT | SPECIAL_ROOT|\
394   SPECIAL_SEPARATOR | SPECIAL_NAMES | SPECIAL_DECIMAL | SPECIAL_PLUS |\
395   SPECIAL_MINUS))
396
397typedef struct nosurveylink {
398   node *fr, *to;
399   int flags;
400   meta_data *meta;
401   struct nosurveylink *next;
402} nosurveylink;
403
404extern nosurveylink *nosurveyhead;
405
406typedef struct lrud {
407    struct lrud * next;
408    prefix *stn;
409    meta_data *meta;
410    real l, r, u, d;
411} lrud;
412
413typedef struct lrudlist {
414    lrud * tube;
415    struct lrudlist * next;
416} lrudlist;
417
418extern lrudlist * model;
419
420extern lrud ** next_lrud;
421
422#endif /* CAVERN_H */
Note: See TracBrowser for help on using the repository browser.