source: git/src/cavern.h @ 1b71c05

RELEASE/1.0
Last change on this file since 1b71c05 was 1b71c05, checked in by Olly Betts <olly@…>, 14 years ago

src/: Update FSF address in (C) notices in source files.

git-svn-id: file:///home/survex-svn/survex/branches/1.0@3463 4b37db11-9a0c-4f06-9ece-9ab7cdaee568

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