source: git/src/cavern.h @ c0b279c

RELEASE/1.1RELEASE/1.2debug-cidebug-ci-sanitisersstereowalls-datawalls-data-hanging-as-warning
Last change on this file since c0b279c was c0b279c, checked in by Olly Betts <olly@…>, 18 years ago

Remove lingering traces of .3dx support

git-svn-id: file:///home/survex-svn/survex/branches/survex-1_1@3287 4b37db11-9a0c-4f06-9ece-9ab7cdaee568

  • Property mode set to 100644
File size: 12.7 KB
RevLine 
[0badc31]1/* cavern.h
[bb90203]2 * SURVEX Cave surveying software - header file
[d333899]3 * Copyright (C) 1991-2003,2005,2006 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
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.h"
[3d441da]37#include "useful.h"
[bb90203]38
[05c700b]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.
[bb90203]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
[daf88e1]49/* RISC OS FP emulation is broken, and the reported epsilon value isn't
50 * useful in practice, so we fake it in the makefile */
51#ifndef REAL_EPSILON
52# define REAL_EPSILON DBL_EPSILON
53#endif
[bb90203]54
55#if (!EXPLICIT_FIXED_FLAG)
56# define UNFIXED_VAL HUGE_VAL /* if p[0]==UNFIXED_VAL, station is unfixed */
57#endif
58
[7d40549]59#define SPECIAL_EOL             0x0001
60#define SPECIAL_BLANK           0x0002
61#define SPECIAL_KEYWORD         0x0004
62#define SPECIAL_COMMENT         0x0008
63#define SPECIAL_OMIT            0x0010
[a882316]64#ifndef NO_DEPRECATED
[7d40549]65#define SPECIAL_ROOT            0x0020
[a882316]66#endif
[7d40549]67#define SPECIAL_SEPARATOR       0x0040
68#define SPECIAL_NAMES           0x0080
69#define SPECIAL_DECIMAL         0x0100
70#define SPECIAL_MINUS           0x0200
71#define SPECIAL_PLUS            0x0400
72#define SPECIAL_OPEN            0x0800
73#define SPECIAL_CLOSE           0x1000
[bb90203]74
[3875c32]75extern char *fnm_output_base;
76extern int fnm_output_base_is_dir;
77
[d1878c51]78extern bool fExportUsed;
79
[e0c7cd1]80extern time_t tmUserStart;
81
[bb90203]82/* Types */
83
[05c700b]84typedef enum {
[b14f44f]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,
[07442af]87   Q_PLUMB, Q_LEVEL, Q_LEFT, Q_RIGHT, Q_UP, Q_DOWN, Q_MAC
[05c700b]88} q_quantity;
[bb90203]89
[27b8b59]90typedef enum {
91   INFER_NULL = -1, INFER_EQUATES, INFER_EXPORTS, INFER_PLUMBS, INFER_SUBSURVEYS
92} infer_what;
93
[bb90203]94/* unsigned long to cope with 16-bit int-s */
95#define BIT(N) (1UL << (N))
96#define BITA(N) (1UL << ((N) - 'a'))
97
[7f08c83]98#define TSTBIT(W, N) (((W)>>(N))&1)
99
[bb90203]100/* masks for quantities which are length and angles respectively */
101#define LEN_QMASK (BIT(Q_LENGTH) | BIT(Q_DEPTH) |\
[b14f44f]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))
[bb90203]106
[5c3c61a]107/* if you add/change the order, check factor_tab in commands.c */
[05c700b]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;
[5c3c61a]112
[95c3272]113/* don't reorder these values!  They need to match with img.h too */
[5c3c61a]114typedef enum {
[95c3272]115   FLAGS_NOT = -2, FLAGS_UNKNOWN = -1, FLAGS_SURFACE, FLAGS_DUPLICATE,
116   FLAGS_SPLAY
[3d441da]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) */
[b14f44f]122   FLAGS_SKELETAL /* FIXME */
[3d441da]123#endif
[5c3c61a]124} flags;
[bb90203]125
[ab4de24]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
[95c3272]130typedef enum {
[ee05463]131   /* Don't reorder these values!  They need to match with img.h too. */
[dfb4240]132   SFLAGS_SURFACE = 0, SFLAGS_UNDERGROUND, SFLAGS_ENTRANCE, SFLAGS_EXPORTED,
133   SFLAGS_FIXED,
[ee05463]134   /* These values don't need to match img.h, but mustn't clash. */
[d333899]135   SFLAGS_SOLVED = 12, SFLAGS_SUSPECTTYPO = 13, SFLAGS_SURVEY = 14, SFLAGS_PREFIX_ENTERED = 15
[95c3272]136} sflags;
[ee05463]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))
[95c3272]141
[ab4de24]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
[bb90203]148/* enumeration of field types */
[05c700b]149typedef enum {
[07442af]150   End = 0, Tape, Comp, Clino, BackComp, BackClino, Left, Right, Up, Down,
[21c226e]151   FrDepth, ToDepth, Dx, Dy, Dz, FrCount, ToCount,
[44bb30d]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    */
[21c226e]160   Fr, To, Station, Depth, DepthChange, Count, Dir,
[44bb30d]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    */
[07442af]168   CompassDATComp, CompassDATClino, CompassDATBackComp, CompassDATBackClino,
169   CompassDATLeft, CompassDATRight, CompassDATUp, CompassDATDown,
170   CompassDATFlags
[0395657]171} reading;
[21c226e]172/* Tape Comp Clino BackComp BackClino FrDepth ToDepth Dx Dy Dz FrCount ToCount */
[05c700b]173
[90bb053f]174/* if IgnoreAll is >= 32, the compiler will choke on this */
175typedef char compiletimeassert_reading[IgnoreAll < 32 ? 1 : -1];
176
[3d441da]177/* position or length vector */
178typedef real delta[3];
179
180/* variance */
181#ifdef NO_COVARIANCES
182typedef real var[3];
183typedef var svar;
184#else
185typedef real var[3][3];
186typedef real svar[6];
187#endif
[bb90203]188
189/* station name */
190typedef struct Prefix {
191   struct Prefix *up, *down, *right;
192   struct Node *stn;
193   struct Pos *pos;
[eb18f4d]194   const char *ident;
[4d9eecd]195   const char *filename;
196   unsigned int line;
[c00c74a9]197   /* If (min_export == 0) then max_export is max # levels above is this
198    * prefix is used (and so needs to be exported) (0 == parent only).
199    * If (min_export > 0) then max_export is max # levels above this
[932f7e9]200    * prefix has been exported, and min_export is how far down the exports
201    * have got (if min_export > 1 after a run, this prefix hasn't been
[c00c74a9]202    * exported from below enough).
[27b8b59]203    * If INFER_EXPORTS is active when a station is encountered, we
[c00c74a9]204    * set min_export = USHRT_MAX and max_export gets set as usual.  Then at
205    * the end of the run, we also mark stations with min_export == USHRT_MAX
206    * and max_export > 0 as exported. */
207   unsigned short max_export, min_export;
[95c3272]208   /* stn flags - e.g. surface, underground, entrance
209    * also suspecttypo and survey */
[421b7d2]210   unsigned short sflags;
[c00c74a9]211   short shape;
[bb90203]212} prefix;
213
[b5a3219]214/* survey metadata */
215typedef struct Meta_data {
216    size_t ref_count;
[5981033]217    time_t date1, date2;
[b5a3219]218} meta_data;
219
[bb90203]220/* stuff stored for both forward & reverse legs */
221typedef struct {
222   struct Node *to;
223   /* bits 0..1 = reverse leg number; bit7 is fFullLeg */
224   /* bit6 = fReplacementLeg (by reduction rules) */
[cb3d1e2]225   /* bit5 = articulation leg (i.e. carries no error) */
[67508f0]226   unsigned char reverse;
[5c3c61a]227   /* flags - e.g. surface, duplicate survey
[693388e]228    * only used if (FLAG_DATAHERE & !(FLAG_REPLACEMENTLEG|FLAG_FAKE))
[b5a3219]229    * This could be only in linkfor, but this is actually more space
230    * efficient.
[5c3c61a]231    */
[67508f0]232   unsigned char flags;
[bb90203]233} linkcommon;
[3d441da]234
[cb3d1e2]235#define FLAG_DATAHERE 0x80
236#define FLAG_REPLACEMENTLEG 0x40
[7f08c83]237#define FLAG_ARTICULATION 0x20
[693388e]238#define FLAG_FAKE 0x10 /* an equate or leg inside an sdfix */
[cb3d1e2]239#define MASK_REVERSEDIRN 0x03
[bb90203]240
241/* reverse leg - deltas & vars stored on other dirn */
242typedef struct LinkRev {
243   linkcommon l;
244} linkrev;
245
246/* forward leg - deltas & vars stored here */
247typedef struct Link {
248   linkcommon l;
[eb18f4d]249   delta d; /* Delta */
[59f2dbb]250   svar v; /* Variances */
[b5a3219]251   meta_data *meta;
[bb90203]252} linkfor;
253
254/* node - like a station, except several nodes are used to represent a
255 * station with more than 3 legs connected to it
256 */
257typedef struct Node {
258   struct Prefix *name;
259   struct Link *leg[3];
[564f471]260   struct Node *prev, *next;
[118eea4]261   long colour;
[bb90203]262} node;
263
264/* station position */
265typedef struct Pos {
[eb18f4d]266   delta p; /* Position */
[bb90203]267#if EXPLICIT_FIXED_FLAG
[67508f0]268   unsigned char fFixed; /* flag indicating if station is a fixed point */
[bb90203]269#endif
270} pos;
271
272/*
273typedef struct Inst {
274   real zero, scale, units;
275} inst;
276*/
277
[107b8bd]278/* Survey data styles */
279#define STYLE_NORMAL     0
280#define STYLE_DIVING     1
281#define STYLE_CARTESIAN  2
282#define STYLE_CYLPOLAR   3
[ee05463]283#define STYLE_PASSAGE    4
284#define STYLE_NOSURVEY   5
285#define STYLE_IGNORE     6
[107b8bd]286
[bb90203]287/* various settings preserved by *BEGIN and *END */
288typedef struct Settings {
[b5a3219]289   struct Settings *next;
[eb18f4d]290   unsigned int Truncate;
[fa42426]291   bool f_clino_percent;
292   bool f_backclino_percent;
[27b8b59]293   unsigned char infer;
[bb90203]294   enum {OFF, LOWER, UPPER} Case;
[107b8bd]295   int style;
[bb90203]296   prefix *Prefix;
297   prefix *tag; /* used to check BEGIN/END tags match */
298   short *Translate; /* if short is >= 16 bits, which ANSI requires */
299   real Var[Q_MAC];
300   real z[Q_MAC];
301   real sc[Q_MAC];
[cb3d1e2]302   real units[Q_MAC];
[0395657]303   reading *ordering;
[47c7a94]304   int begin_lineno; /* 0 means no block started in this file */
[5c3c61a]305   int flags;
[b5a3219]306   meta_data * meta;
[bb90203]307} settings;
308
309/* global variables */
310extern settings *pcs;
311extern prefix *root;
312extern node *stnlist;
[3875c32]313extern unsigned long optimize;
[bd283cf6]314
[bb90203]315extern char *survey_title;
316extern int survey_title_len;
317
318extern bool fExplicitTitle;
319extern long cLegs, cStns, cComponents;
320extern FILE *fhErrStat;
[693388e]321extern img *pimg;
[bb90203]322#ifndef NO_PERCENTAGE
323extern bool fPercent;
324#endif
325extern real totadj, total, totplan, totvert;
326extern real min[3], max[3];
327extern prefix *pfxHi[3], *pfxLo[3];
[647407d]328extern bool fQuiet; /* just show brief summary + errors */
[ed0f5b6]329extern bool fMute; /* just show errors */
[c0b279c]330extern bool fSuppress; /* only output 3d file */
[bb90203]331
332/* macros */
333
334#define POS(S, D) ((S)->name->pos->p[(D)])
335#define POSD(S) ((S)->name->pos->p)
336
337#define data_here(L) ((L)->l.reverse & FLAG_DATAHERE)
[cb3d1e2]338#define reverse_leg_dirn(L) ((L)->l.reverse & MASK_REVERSEDIRN)
339#define reverse_leg(L) ((L)->l.to->leg[reverse_leg_dirn(L)])
[bb90203]340
341#if EXPLICIT_FIXED_FLAG
342# define pfx_fixed(N) ((N)->pos->fFixed)
[3e25a0d]343# define pos_fixed(P) ((P)->fFixed)
[bb90203]344# define fix(S) (S)->name->pos->fFixed = (char)fTrue
[084905c]345# define fixpos(P) (P)->fFixed = (char)fTrue
[bb90203]346# define unfix(S) (S)->name->pos->fFixed = (char)fFalse
347#else
348# define pfx_fixed(N) ((N)->pos->p[0] != UNFIXED_VAL)
[3e25a0d]349# define pos_fixed(P) ((P)->p[0] != UNFIXED_VAL)
[bb90203]350# define fix(S) NOP
[084905c]351# define fixpos(P) NOP
[bb90203]352# define unfix(S) POS((S), 0) = UNFIXED_VAL
353#endif
354#define fixed(S) pfx_fixed((S)->name)
355
[0af7076]356/* macros for special chars */
[bb90203]357
358#define isEol(c)    (pcs->Translate[(c)] & SPECIAL_EOL)
359#define isBlank(c)  (pcs->Translate[(c)] & SPECIAL_BLANK)
360#define isKeywd(c)  (pcs->Translate[(c)] & SPECIAL_KEYWORD)
361#define isComm(c)   (pcs->Translate[(c)] & SPECIAL_COMMENT)
362#define isOmit(c)   (pcs->Translate[(c)] & SPECIAL_OMIT)
[a882316]363#ifndef NO_DEPRECATED
[bb90203]364#define isRoot(c)   (pcs->Translate[(c)] & SPECIAL_ROOT)
[a882316]365#endif
[bb90203]366#define isSep(c)    (pcs->Translate[(c)] & SPECIAL_SEPARATOR)
367#define isNames(c)  (pcs->Translate[(c)] & SPECIAL_NAMES)
368#define isDecimal(c) (pcs->Translate[(c)] & SPECIAL_DECIMAL)
369#define isMinus(c)  (pcs->Translate[(c)] & SPECIAL_MINUS)
370#define isPlus(c)   (pcs->Translate[(c)] & SPECIAL_PLUS)
[21c226e]371#define isOpen(c)   (pcs->Translate[(c)] & SPECIAL_OPEN)
372#define isClose(c)  (pcs->Translate[(c)] & SPECIAL_CLOSE)
[bb90203]373
374#define isSign(c)   (pcs->Translate[(c)] & (SPECIAL_PLUS | SPECIAL_MINUS))
375#define isData(c)   (pcs->Translate[(c)] & (SPECIAL_OMIT | SPECIAL_ROOT|\
376   SPECIAL_SEPARATOR | SPECIAL_NAMES | SPECIAL_DECIMAL | SPECIAL_PLUS |\
377   SPECIAL_MINUS))
378
[647407d]379typedef struct nosurveylink {
380   node *fr, *to;
[b3bef47]381   int flags;
[ee05463]382   meta_data *meta;
[647407d]383   struct nosurveylink *next;
384} nosurveylink;
385
386extern nosurveylink *nosurveyhead;
387
[ee05463]388typedef struct lrud {
389    struct lrud * next;
390    prefix *stn;
[a6301a1]391    meta_data *meta;
[ee05463]392    real l, r, u, d;
393} lrud;
394
395typedef struct lrudlist {
396    lrud * tube;
397    struct lrudlist * next;
398} lrudlist;
399
400extern lrudlist * model;
401
402extern lrud ** next_lrud;
403
[3875c32]404#endif /* CAVERN_H */
Note: See TracBrowser for help on using the repository browser.