a68g-defines.h
1 //! @file a68g-defines.h
2 //! @author J. Marcel van der Veer
3 //!
4 //! @section Copyright
5 //!
6 //! This file is part of Algol68G - an Algol 68 compiler-interpreter.
7 //! Copyright 2001-2023 J. Marcel van der Veer [algol68g@xs4all.nl].
8 //!
9 //! @section License
10 //!
11 //! This program is free software; you can redistribute it and/or modify it
12 //! under the terms of the GNU General Public License as published by the
13 //! Free Software Foundation; either version 3 of the License, or
14 //! (at your option) any later version.
15 //!
16 //! This program is distributed in the hope that it will be useful, but
17 //! WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
18 //! or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
19 //! more details. You should have received a copy of the GNU General Public
20 //! License along with this program. If not, see [http://www.gnu.org/licenses/].
21
22 #if !defined (__A68G_DEFINES_H__)
23 #define __A68G_DEFINES_H__
24
25 // Constants
26
27 #define KILOBYTE ((unt) 1024)
28 #define MEGABYTE (KILOBYTE * KILOBYTE)
29 #define GIGABYTE (KILOBYTE * MEGABYTE)
30
31 #define A68_TRUE ((BOOL_T) 1)
32 #define A68_FALSE ((BOOL_T) 0)
33
34 #define BACKSLASH_CHAR '\\'
35 #define BLANK_CHAR ' '
36 #define CR_CHAR '\r'
37 #define EOF_CHAR (EOF)
38 #define ERROR_CHAR '*'
39 #define ESCAPE_CHAR '\033'
40 #define EXPONENT_CHAR 'e'
41 #define FLIP_CHAR 'T'
42 #define FLOP_CHAR 'F'
43 #define FORMFEED_CHAR '\f'
44 #define NEWLINE_CHAR '\n'
45 #define NULL_CHAR '\0'
46 #define POINT_CHAR '.'
47 #define QUOTE_CHAR '"'
48 #define RADIX_CHAR 'r'
49 #define TAB_CHAR '\t'
50
51 // File extensions
52 #define BINARY_EXTENSION ".o"
53 #define PLUGIN_EXTENSION ".so"
54 #define LISTING_EXTENSION ".l"
55 #define OBJECT_EXTENSION ".c"
56 #define PRETTY_EXTENSION ".f"
57 #define SCRIPT_EXTENSION ""
58
59 // Static options for GCC.
60 //
61 // -fno-stack-protector is needed for Ubuntu etcetera that enforce -fstack-protector-strong
62 // which may give an undefined reference to `__stack_chk_fail_local'.
63 //
64 // -Wno-parentheses-equality is needed for OpenBSD.
65 //
66
67 #define A68_GCC_OPTIONS "-DA68_OPTIMISE -ggdb -fno-stack-protector -Wno-parentheses-equality"
68
69 // Formats
70 #define DIGIT_BLANK ((unt) 0x2)
71 #define DIGIT_NORMAL ((unt) 0x1)
72 #define INSERTION_BLANK ((unt) 0x20)
73 #define INSERTION_NORMAL ((unt) 0x10)
74
75 #define MAX_RESTART 256
76
77 #define A68_DIR ".a68g"
78 #define A68_HISTORY_FILE ".a68g.edit.hist"
79 #define A68_NO_FILENO ((FILE_T) -1)
80 #define A68_PROTECTION (S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH) // -rw-r--r--
81 #define A68_READ_ACCESS (O_RDONLY)
82 #define A68_WRITE_ACCESS (O_WRONLY | O_CREAT | O_TRUNC)
83 #define BUFFER_SIZE (KILOBYTE)
84 #define DEFAULT_WIDTH (-1)
85
86 #define EMBEDDED_FORMAT A68_TRUE
87 #define EVEN(k) ((k) % 2 == 0)
88 #define HIDDEN_TEMP_FILE_NAME ".a68g.tmp"
89 #define ITEM_NOT_USED (-1)
90 #define MAX_ERRORS 5
91 #define MAX_PRIORITY 9
92 #define MAX_TERM_HEIGTH 24
93 #define MAX_TERM_WIDTH (BUFFER_SIZE / 2)
94 #define MIN_MEM_SIZE (128 * KILOBYTE)
95 #define MOID_ERROR_WIDTH 80
96 #define MOID_WIDTH 80
97 #define MONADS "%^&+-~!?"
98 #define NEWLINE_STRING "\n"
99 #define NOMADS "></=*"
100 #define NOT_EMBEDDED_FORMAT A68_FALSE
101 #define NOT_PRINTED 1
102 #define OVER_2G(n) ((REAL_T) (n) > (REAL_T) (2 * GIGABYTE))
103 #define PRIMAL_SCOPE 0
104 #define SKIP_PATTERN A68_FALSE
105 #define SMALL_BUFFER_SIZE 128
106 #define SNPRINTF_SIZE ((size_t) (BUFFER_SIZE - 1))
107 #define TRANSPUT_BUFFER_SIZE BUFFER_SIZE
108 #define WANT_PATTERN A68_TRUE
109
110 #define MANT_DIGS(n) ((int) round ((n) * log10 (2.0)))
111 #define MANT_BITS(n) ((int) round ((n) / log10 (2.0)))
112 #define REAL_DIGITS MANT_DIGS (REAL_MANT_DIG)
113
114 // Macros
115
116 #define _SKIP_ { (void) 0;}
117
118 #define BUFCLR(z) {memset ((z), 0, BUFFER_SIZE + 1);}
119
120 #define ABS(n) ((n) >= 0 ? (n) : -(n))
121
122 #define MAX(u, v) (((u) > (v) ? (u) : (v)))
123 #define MAXIMISE(u, v) ((u) = MAX (u, v))
124
125 #define MIN(u, v) (((u) < (v) ? (u) : (v)))
126 #define MINIMISE(u, v) ((u) = MIN (u, v))
127
128 #define COPY(d, s, n) {\
129 int _m_k = (n); BYTE_T *_m_u = (BYTE_T *) (d), *_m_v = (BYTE_T *) (s);\
130 while (_m_k--) {*_m_u++ = *_m_v++;}}
131
132 #define COPY_ALIGNED(d, s, n) {\
133 int _m_k = (n); A68_ALIGN_T *_m_u = (A68_ALIGN_T *) (d), *_m_v = (A68_ALIGN_T *) (s);\
134 while (_m_k > 0) {*_m_u++ = *_m_v++; _m_k -= A68_ALIGNMENT;}}
135
136 #define MOVE(d, s, n) {\
137 int _m_k = (int) (n); BYTE_T *_m_d = (BYTE_T *) (d), *_m_s = (BYTE_T *) (s);\
138 if (_m_s < _m_d) {\
139 _m_d += _m_k; _m_s += _m_k;\
140 while (_m_k--) {*(--_m_d) = *(--_m_s);}\
141 } else {\
142 while (_m_k--) {*(_m_d++) = *(_m_s++);}\
143 }}
144
145 #define FILL(d, s, n) {\
146 int _m_k = (n); BYTE_T *_m_u = (BYTE_T *) (d), _m_v = (BYTE_T) (s);\
147 while (_m_k--) {*_m_u++ = _m_v;}}
148
149 #define FILL_ALIGNED(d, s, n) {\
150 int _m_k = (n); A68_ALIGN_T *_m_u = (A68_ALIGN_T *) (d), _m_v = (A68_ALIGN_T) (s);\
151 while (_m_k > 0) {*_m_u++ = _m_v; _m_k -= A68_ALIGNMENT;}}
152
153 #define ABEND(p, reason, info) {\
154 if (p) {\
155 abend ((char *) reason, (char *) info, __FILE__, __LINE__);\
156 }}
157
158 #if defined (HAVE_CURSES)
159 #define ASSERT(f) {\
160 if (!(f)) {\
161 if (A68 (curses_mode) == A68_TRUE) {\
162 (void) attrset (A_NORMAL);\
163 (void) endwin ();\
164 A68 (curses_mode) = A68_FALSE;\
165 }\
166 ABEND (A68_TRUE, ERROR_ASSERTION, __func__)\
167 }}
168 #else
169 #define ASSERT(f) {\
170 ABEND((!(f)), ERROR_ASSERTION, __func__)\
171 }
172 #endif
173
174 // Some macros to overcome the ambiguity in having signed or unt char
175 // on various systems. PDP-11s and IBM 370s are still haunting us with this.
176
177 #define IS_ALNUM(c) isalnum ((unt char) (c))
178 #define IS_ALPHA(c) isalpha ((unt char) (c))
179 #define IS_CNTRL(c) iscntrl ((unt char) (c))
180 #define IS_DIGIT(c) isdigit ((unt char) (c))
181 #define IS_GRAPH(c) isgraph ((unt char) (c))
182 #define IS_LOWER(c) islower ((unt char) (c))
183 #define IS_PRINT(c) isprint ((unt char) (c))
184 #define IS_PUNCT(c) ispunct ((unt char) (c))
185 #define IS_SPACE(c) isspace ((unt char) (c))
186 #define IS_UPPER(c) isupper ((unt char) (c))
187 #define IS_XDIGIT(c) isxdigit ((unt char) (c))
188 #define TO_LOWER(c) (char) tolower ((unt char) (c))
189 #define TO_UCHAR(c) ((c) >= 0 ? (int) (c) : (int) (UCHAR_MAX + (int) (c) + 1))
190 #define TO_UPPER(c) (char) toupper ((unt char) (c))
191
192 // Macro's for fat A68 pointers
193
194 #define ADDRESS(z) (&(((IS_IN_HEAP (z) || IS_IN_COMMON (z)) ? REF_POINTER (z) : A68_STACK)[REF_OFFSET (z)]))
195 #define ARRAY_ADDRESS(z) (&(REF_POINTER (z)[REF_OFFSET (z)]))
196 #define DEREF(mode, expr) ((mode *) ADDRESS (expr))
197 #define FILE_DEREF(p) DEREF (A68_FILE, (p))
198 #define HEAP_ADDRESS(n) ((BYTE_T *) & (A68_HEAP[n]))
199 #define IS_IN_FRAME(z) (STATUS (z) & IN_FRAME_MASK)
200 #define IS_IN_HEAP(z) (STATUS (z) & IN_HEAP_MASK)
201 #define IS_IN_COMMON(z) (STATUS (z) & IN_COMMON_MASK)
202 #define IS_IN_STACK(z) (STATUS (z) & IN_STACK_MASK)
203 #define IS_NIL(p) ((BOOL_T) ((STATUS (&(p)) & NIL_MASK) != 0))
204 #define LOCAL_ADDRESS(z) (& A68_STACK[REF_OFFSET (z)])
205 #define REF_HANDLE(z) (HANDLE (z))
206 #define REF_OFFSET(z) (OFFSET (z))
207 #define REF_POINTER(z) (POINTER (REF_HANDLE (z)))
208 #define REF_SCOPE(z) (SCOPE (z))
209 #define STACK_ADDRESS(n) ((BYTE_T *) &(A68_STACK[(n)]))
210 #define STACK_OFFSET(n) (STACK_ADDRESS (A68_SP + (int) (n)))
211 #define STACK_TOP (STACK_ADDRESS (A68_SP))
212
213 // Miscellaneous macros
214
215 #define IN_PRELUDE(p) (LINE_NUMBER (p) <= 0)
216 #define EOL(c) ((c) == NEWLINE_CHAR || (c) == NULL_CHAR)
217
218 #define SIZE_ALIGNED(p) ((int) A68_ALIGN (sizeof (p)))
219 #define A68_REF_SIZE (SIZE_ALIGNED (A68_REF))
220 #define A68_UNION_SIZE (SIZE_ALIGNED (A68_UNION))
221
222 #define A68_SOUND_BYTES(s) ((int) (BITS_PER_SAMPLE (s)) / 8 + (int) (BITS_PER_SAMPLE (s) % 8 == 0 ? 0 : 1))
223 #define A68_SOUND_DATA_SIZE(s) ((int) (NUM_SAMPLES (s)) * (int) (NUM_CHANNELS (s)) * (int) (A68_SOUND_BYTES (s)))
224 #define BACKWARD(p) (p = PREVIOUS (p))
225 #define BITS_WIDTH ((int) (1 + ceil (log ((REAL_T) A68_MAX_INT) / log ((REAL_T) 2))))
226 #define DEFLEX(p) (DEFLEXED (p) != NO_MOID ? DEFLEXED(p) : (p))
227 #define FORWARD(p) ((p) = NEXT (p))
228 #define INT_WIDTH ((int) (1 + floor (log ((REAL_T) A68_MAX_INT) / log ((REAL_T) 10))))
229 #define LONG_INT_WIDTH (1 + LONG_WIDTH)
230 #define PM(m) (moid_to_string (m, 132, NO_NODE))
231 #define SIGN(n) ((n) == 0 ? 0 : ((n) > 0 ? 1 : -1))
232 #define STATUS_CLEAR(p, q) {STATUS (p) &= (~(q));}
233 #define STATUS_SET(p, q) {STATUS (p) |= (q);}
234 #define STATUS_TEST(p, q) ((STATUS (p) & (q)) != (unt) 0)
235 #define WIS(p) where_in_source (STDOUT_FILENO, (p))
236 #define WRITE(f, s) io_write_string ((f), (s));
237 #define WRITELN(f, s) {WRITE ((f), "\n"); WRITE ((f), (s));}
238
239 // Access macros
240
241 #define A(p) ((p)->a)
242 #define A68_STANDENV_PROC(p) ((p)->a68_standenv_proc)
243 #define ACTION(p) ((p)->action)
244 #define ACTIVE(p) ((p)->active)
245 #define ADDR(p) ((p)->addr)
246 #define ANNOTATION(p) ((p)->annotation)
247 #define ANONYMOUS(p) ((p)->anonymous)
248 #define APPLICATIONS(p) ((p)->applications)
249 #define AP_INCREMENT(p) ((p)->ap_increment)
250 #define ARGSIZE(p) ((p)->argsize)
251 #define ARRAY(p) ((p)->array)
252 #define ATTRIBUTE(p) ((p)->attribute)
253 #define B(p) ((p)->b)
254 #define BEGIN(p) ((p)->begin)
255 #define BIN(p) ((p)->bin)
256 #define BITS_PER_SAMPLE(p) ((p)->bits_per_sample)
257 #define BLUE(p) ((p)->blue)
258 #define BODY(p) ((p)->body)
259 #define BSTATE(p) ((p)->bstate)
260 #define BYTES(p) ((p)->bytes)
261 #define CAST(p) ((p)->cast)
262 #define CAT(p) ((p)->cat)
263 #define CHANNEL(p) ((p)->channel)
264 #define CHAR_IN_LINE(p) ((p)->char_in_line)
265 #define CHAR_MOOD(p) ((p)->char_mood)
266 #define CMD(p) ((p)->cmd)
267 #define CMD_ROW(p) ((p)->cmd_row)
268 #define CODE(p) ((p)->code)
269 #define CODEX(p) ((p)->codex)
270 #define COLLECT(p) ((p)->collect)
271 #define COMPILED(p) ((p)->compiled)
272 #define COMPILE_NAME(p) ((p)->compile_name)
273 #define COMPILE_NODE(p) ((p)->compile_node)
274 #define COMPRESS(p) ((p)->compress)
275 #define CONNECTION(p) ((p)->connection)
276 #define CONSTANT(p) ((p)->constant)
277 #define COUNT(p) ((p)->count)
278 #define CROSS_REFERENCE_SAFE(p) ((p)->cross_reference_safe)
279 #define CUR_PTR(p) ((p)->cur_ptr)
280 #define DATA(p) ((p)->data)
281 #define DATA_SIZE(p) ((p)->data_size)
282 #define DATE(p) ((p)->date)
283 #define DEF(p) ((p)->def)
284 #define DEFLEXED(p) ((p)->deflexed_mode)
285 #define DERIVATE(p) ((p)->derivate)
286 #define DEVICE(p) ((p)->device)
287 #define DEVICE_HANDLE(p) ((p)->device_handle)
288 #define DEVICE_MADE(p) ((p)->device_made)
289 #define DEVICE_OPENED(p) ((p)->device_opened)
290 #define DIAGNOSTICS(p) ((p)->diagnostics)
291 #define DIGITS(p) ((p)->digits)
292 #define DIGITSC(p) ((p)->digitsc)
293 #define DIM(p) ((p)->dim)
294 #define DISPLAY(p) ((p)->display)
295 #define DRAW(p) ((p)->draw)
296 #define DRAW_MOOD(p) ((p)->draw_mood)
297 #define DUMP(p) ((p)->dump)
298 #define DYNAMIC_LINK(p) ((p)->dynamic_link)
299 #define DYNAMIC_SCOPE(p) ((p)->dynamic_scope)
300 #define D_NAME(p) ((p)->d_name)
301 #define ELEM_SIZE(p) ((p)->elem_size)
302 #define END(p) ((p)->end)
303 #define END_OF_FILE(p) ((p)->end_of_file)
304 #define ENVIRON(p) ((p)->fp_environ)
305 #define EQUIVALENT(p) ((p)->equivalent_mode)
306 #define EQUIVALENT_MODE(p) ((p)->equivalent_mode)
307 #define ERROR_COUNT(p) ((p)->error_count)
308 #define RENDEZ_VOUS(p) ((p)->rendez_vous)
309 #define EXPR(p) ((p)->expr)
310 #define F(p) ((p)->f)
311 #define FACTOR(p) ((p)->factor)
312 #define FD(p) ((p)->fd)
313 #define FIELD_OFFSET(p) ((p)->field_offset)
314 #define FILENAME(p) ((p)->filename)
315 #define FILES(p) ((p)->files)
316 #define FILE_BINARY_NAME(p) (FILES (p).binary.name)
317 #define FILE_BINARY_OPENED(p) (FILES (p).binary.opened)
318 #define FILE_BINARY_WRITEMOOD(p) (FILES (p).binary.writemood)
319 #define FILE_DIAGS_FD(p) (FILES (p).diags.fd)
320 #define FILE_DIAGS_NAME(p) (FILES (p).diags.name)
321 #define FILE_DIAGS_OPENED(p) (FILES (p).diags.opened)
322 #define FILE_DIAGS_WRITEMOOD(p) (FILES (p).diags.writemood)
323 #define FILE_END_MENDED(p) ((p)->file_end_mended)
324 #define FILE_ENTRY(p) ((p)->file_entry)
325 #define FILE_GENERIC_NAME(p) (FILES (p).generic_name)
326 #define FILE_INITIAL_NAME(p) (FILES (p).initial_name)
327 #define FILE_PLUGIN_NAME(p) (FILES (p).plugin.name)
328 #define FILE_PLUGIN_OPENED(p) (FILES (p).plugin.opened)
329 #define FILE_PLUGIN_WRITEMOOD(p) (FILES (p).plugin.writemood)
330 #define FILE_LISTING_FD(p) (FILES (p).listing.fd)
331 #define FILE_LISTING_NAME(p) (FILES (p).listing.name)
332 #define FILE_LISTING_OPENED(p) (FILES (p).listing.opened)
333 #define FILE_LISTING_WRITEMOOD(p) (FILES (p).listing.writemood)
334 #define FILE_OBJECT_FD(p) (FILES (p).object.fd)
335 #define FILE_OBJECT_NAME(p) (FILES (p).object.name)
336 #define FILE_OBJECT_OPENED(p) (FILES (p).object.opened)
337 #define FILE_OBJECT_WRITEMOOD(p) (FILES (p).object.writemood)
338 #define FILE_PATH(p) (FILES (p).path)
339 #define FILE_PRETTY_FD(p) (FILES (p).pretty.fd)
340 #define FILE_PRETTY_NAME(p) (FILES (p).pretty.name)
341 #define FILE_PRETTY_OPENED(p) (FILES (p).pretty.opened)
342 #define FILE_PRETTY_WRITEMOOD(p) (FILES (p).pretty.writemood)
343 #define FILE_SCRIPT_NAME(p) (FILES (p).script.name)
344 #define FILE_SCRIPT_OPENED(p) (FILES (p).script.opened)
345 #define FILE_SCRIPT_WRITEMOOD(p) (FILES (p).script.writemood)
346 #define FILE_SOURCE_FD(p) (FILES (p).source.fd)
347 #define FILE_SOURCE_NAME(p) (FILES (p).source.name)
348 #define FILE_SOURCE_OPENED(p) (FILES (p).source.opened)
349 #define FILE_SOURCE_WRITEMOOD(p) (FILES (p).source.writemood)
350 #define FIND(p) ((p)->find)
351 #define FORMAT(p) ((p)->format)
352 #define FORMAT_END_MENDED(p) ((p)->format_end_mended)
353 #define FORMAT_ERROR_MENDED(p) ((p)->format_error_mended)
354 #define FRAME(p) ((p)->frame)
355 #define FRAME_LEVEL(p) ((p)->frame_level)
356 #define FRAME_NO(p) ((p)->frame_no)
357 #define FRAME_POINTER(p) ((p)->frame_pointer)
358 #define FUNCTION(p) ((p)->function)
359 #define G(p) ((p)->g)
360 #define GINFO(p) ((p)->genie)
361 #define GET(p) ((p)->get)
362 #define GLOBAL_PROP(p) ((p)->global_prop)
363 #define GPARENT(p) (PARENT (GINFO (p)))
364 #define GREEN(p) ((p)->green)
365 #define H(p) ((p)->h)
366 #define HANDLE(p) ((p)->handle)
367 #define HAS_ROWS(p) ((p)->has_rows)
368 #define HEAP(p) ((p)->heap)
369 #define HEAP_POINTER(p) ((p)->heap_pointer)
370 #define H_ADDR(p) ((p)->h_addr)
371 #define H_LENGTH(p) ((p)->h_length)
372 #define ID(p) ((p)->id)
373 #define IDENTIFICATION(p) ((p)->identification)
374 #define IDENTIFIERS(p) ((p)->identifiers)
375 #define IDF(p) ((p)->idf)
376 #define IM(z) (VALUE (&(z)[1]))
377 #define IN(p) ((p)->in)
378 #define INDEX(p) ((p)->index)
379 #define INDICANTS(p) ((p)->indicants)
380 #define INFO(p) ((p)->info)
381 #define INITIALISE_ANON(p) ((p)->initialise_anon)
382 #define INITIALISE_FRAME(p) ((p)->initialise_frame)
383 #define INI_PTR(p) ((p)->ini_ptr)
384 #define INS_MODE(p) ((p)->ins_mode)
385 #define IN_CMD(p) ((p)->in_cmd)
386 #define IN_FORBIDDEN(p) ((p)->in_forbidden)
387 #define IN_PREFIX(p) ((p)->in_prefix)
388 #define IN_PROC(p) ((p)->in_proc)
389 #define IN_TEXT(p) ((p)->in_text)
390 #define IS_COMPILED(p) ((p)->is_compiled)
391 #define IS_OPEN(p) ((p)->is_open)
392 #define IS_TMP(p) ((p)->is_tmp)
393 #define JUMP_STAT(p) ((p)->jump_stat)
394 #define JUMP_TO(p) ((p)->jump_to)
395 #define K(q) ((q)->k)
396 #define LABELS(p) ((p)->labels)
397 #define LAST(p) ((p)->last)
398 #define LAST_LINE(p) ((p)->last_line)
399 #define LESS(p) ((p)->less)
400 #define LEVEL(p) ((p)->level)
401 #define LEX_LEVEL(p) (LEVEL (TABLE (p)))
402 #define LINBUF(p) ((p)->linbuf)
403 #define LINE(p) ((p)->line)
404 #define LINE_APPLIED(p) ((p)->line_applied)
405 #define LINE_DEFINED(p) ((p)->line_defined)
406 #define LINE_END_MENDED(p) ((p)->line_end_mended)
407 #define LINE_NUMBER(p) (NUMBER (LINE (INFO (p))))
408 #define LINSIZ(p) ((p)->linsiz)
409 #define LIST(p) ((p)->list)
410 #define ln(x) (log (x))
411 #define LOCALE(p) ((p)->locale)
412 #define LOC_ASSIGNED(p) ((p)->loc_assigned)
413 #define LOWER_BOUND(p) ((p)->lower_bound)
414 #define LWB(p) ((p)->lower_bound)
415 #define MARKER(p) ((p)->marker)
416 #define MATCH(p) ((p)->match)
417 #define MODIFIED(p) ((p)->modified)
418 #define MOID(p) ((p)->type)
419 #define MORE(p) ((p)->more)
420 #define MSGS(p) ((p)->msgs)
421 #define MULTIPLE(p) ((p)->multiple_mode)
422 #define MULTIPLE_MODE(p) ((p)->multiple_mode)
423 #define M_EO(p) ((p)->m_eo)
424 #define M_MATCH(p) ((p)->match)
425 #define M_SO(p) ((p)->m_so)
426 #define NAME(p) ((p)->name)
427 #define NEED_DNS(p) ((p)->need_dns)
428 #define NEGATE(p) ((p)->negate)
429 #define NEST(p) ((p)->nest)
430 #define NEW_FILE(p) ((p)->new_file)
431 #define NEXT(p) ((p)->next)
432 #define NEXT_NEXT(p) (NEXT (NEXT (p)))
433 #define NEXT_NEXT_NEXT(p) (NEXT (NEXT_NEXT (p)))
434 #define NEXT_SUB(p) (NEXT (SUB (p)))
435 #define NF(p) ((p)->nf)
436 #define NODE(p) ((p)->node)
437 #define NODE_DEFINED(p) ((p)->node_defined)
438 #define NODE_PACK(p) ((p)->pack)
439 #define NON_LOCAL(p) ((p)->non_local)
440 #define NCHAR_IN_LINE(p) (CHAR_IN_LINE (INFO (p)))
441 #define NPRAGMENT(p) (PRAGMENT (INFO (p)))
442 #define NPRAGMENT_TYPE(p) (PRAGMENT_TYPE (INFO (p)))
443 #define NSYMBOL(p) (SYMBOL (INFO (p)))
444 #define NUM(p) ((p)->num)
445 #define NUMBER(p) ((p)->number)
446 #define NUM_CHANNELS(p) ((p)->num_channels)
447 #define NUM_MATCH(p) ((p)->num_match)
448 #define NUM_SAMPLES(p) ((p)->num_samples)
449 #define OFFSET(p) ((p)->offset)
450 #define OPENED(p) ((p)->opened)
451 #define OPEN_ERROR_MENDED(p) ((p)->open_error_mended)
452 #define OPEN_EXCLUSIVE(p) ((p)->open_exclusive)
453 #define OPER(p) ((p)->oper)
454 #define OPERATORS(p) ((p)->operators)
455 #define OPTIONS(p) ((p)->options)
456 #define OPTION_BACKTRACE(p) (OPTIONS (p).backtrace)
457 #define OPTION_BRACKETS(p) (OPTIONS (p).brackets)
458 #define OPTION_CHECK_ONLY(p) (OPTIONS (p).check_only)
459 #define OPTION_CLOCK(p) (OPTIONS (p).clock)
460 #define OPTION_COMPILE(p) (OPTIONS (p).compile)
461 #define OPTION_COMPILE_CHECK(p) (OPTIONS (p).compile_check)
462 #define OPTION_CROSS_REFERENCE(p) (OPTIONS (p).cross_reference)
463 #define OPTION_DEBUG(p) (OPTIONS (p).debug)
464 #define OPTION_FOLD(p) (OPTIONS (p).fold)
465 #define OPTION_INDENT(p) (OPTIONS (p).indent)
466 #define OPTION_KEEP(p) (OPTIONS (p).keep)
467 #define OPTION_LICENSE(p) (OPTIONS (p).license)
468 #define OPTION_LIST(p) (OPTIONS (p).list)
469 #define OPTION_LOCAL(p) (OPTIONS (p).local)
470 #define OPTION_MOID_LISTING(p) (OPTIONS (p).moid_listing)
471 #define OPTION_NODEMASK(p) (OPTIONS (p).nodemask)
472 #define OPTION_NO_WARNINGS(p) (OPTIONS (p).no_warnings)
473 #define OPTION_OBJECT_LISTING(p) (OPTIONS (p).object_listing)
474 #define OPTION_OPT_LEVEL(p) (OPTIONS (p).opt_level)
475 #define OPTION_PORTCHECK(p) (OPTIONS (p).portcheck)
476 #define OPTION_PRAGMAT_SEMA(p) (OPTIONS (p).pragmat_sema)
477 #define OPTION_PRETTY(p) (OPTIONS (p).pretty)
478 #define OPTION_QUIET(p) (OPTIONS (p).quiet)
479 #define OPTION_REDUCTIONS(p) (OPTIONS (p).reductions)
480 #define OPTION_REGRESSION_TEST(p) (OPTIONS (p).regression_test)
481 #define OPTION_RERUN(p) (OPTIONS (p).rerun)
482 #define OPTION_RUN(p) (OPTIONS (p).run)
483 #define OPTION_RUN_SCRIPT(p) (OPTIONS (p).run_script)
484 #define OPTION_SOURCE_LISTING(p) (OPTIONS (p).source_listing)
485 #define OPTION_STANDARD_PRELUDE_LISTING(p) (OPTIONS (p).standard_prelude_listing)
486 #define OPTION_STATISTICS_LISTING(p) (OPTIONS (p).statistics_listing)
487 #define OPTION_STRICT(p) (OPTIONS (p).strict)
488 #define OPTION_STROPPING(p) (OPTIONS (p).stropping)
489 #define OPTION_TIME_LIMIT(p) (OPTIONS (p).time_limit)
490 #define OPTION_TRACE(p) (OPTIONS (p).trace)
491 #define OPTION_TREE_LISTING(p) (OPTIONS (p).tree_listing)
492 #define OPTION_UNUSED(p) (OPTIONS (p).unused)
493 #define OPTION_VERBOSE(p) (OPTIONS (p).verbose)
494 #define OPTION_VERSION(p) (OPTIONS (p).version)
495 #define OUT(p) ((p)->out)
496 #define OUTER(p) ((p)->outer)
497 #define P(q) ((q)->p)
498 #define PACK(p) ((p)->pack)
499 #define PAGE_END_MENDED(p) ((p)->page_end_mended)
500 #define A68_PAGE_SIZE(p) ((p)->page_size)
501 #define PARAMETERS(p) ((p)->parameters)
502 #define PARAMETER_LEVEL(p) ((p)->parameter_level)
503 #define GSL_PARAMS(p) ((p)->params)
504 #define PARENT(p) ((p)->parent)
505 #define PARTIAL_LOCALE(p) ((p)->partial_locale)
506 #define PARTIAL_PROC(p) ((p)->partial_proc)
507 #define PATTERN(p) ((p)->pattern)
508 #define PERM(p) ((p)->perm)
509 #define PERMS(p) ((p)->perms)
510 #define IDF_ROW(p) ((p)->idf_row)
511 #define PHASE(p) ((p)->phase)
512 #define PLOTTER(p) ((p)->plotter)
513 #define PLOTTER_PARAMS(p) ((p)->plotter_params)
514 #define POINTER(p) ((p)->pointer)
515 #define PORTABLE(p) ((p)->portable)
516 #define POS(p) ((p)->pos)
517 #define PRAGMENT(p) ((p)->pragment)
518 #define PRAGMENT_TYPE(p) ((p)->pragment_type)
519 #define PRECMD(p) ((p)->precmd)
520 #define PREVIOUS(p) ((p)->previous)
521 #define PRINT_STATUS(p) ((p)->print_status)
522 #define PRIO(p) ((p)->priority)
523 #define PROCEDURE(p) ((p)->procedure)
524 #define PROCEDURE_LEVEL(p) ((p)->procedure_level)
525 #define PROCESSED(p) ((p)->processed)
526 #define PROC_FRAME(p) ((p)->proc_frame)
527 #define PROC_OPS(p) ((p)->proc_ops)
528 #define GPROP(p) (GINFO (p)->propagator)
529 #define PROP(p) ((p)->propagator)
530 #define PS(p) ((p)->ps)
531 #define PUT(p) ((p)->put)
532 #define P_PROTO(p) ((p)->p_proto)
533 #define R(p) ((p)->r)
534 #define RE(z) (VALUE (&(z)[0]))
535 #define READ_MOOD(p) ((p)->read_mood)
536 #define RED(p) ((p)->red)
537 #define REPL(p) ((p)->repl)
538 #define RESERVED(p) ((p)->reserved)
539 #define RESET(p) ((p)->reset)
540 #define RESULT(p) ((p)->result)
541 #define RE_NSUB(p) ((p)->re_nsub)
542 #define RLIM_CUR(p) ((p)->rlim_cur)
543 #define RLIM_MAX(p) ((p)->rlim_max)
544 #define RM_EO(p) ((p)->rm_eo)
545 #define RM_SO(p) ((p)->rm_so)
546 #define ROWED(p) ((p)->rowed)
547 #define S(p) ((p)->s)
548 #define SAMPLE_RATE(p) ((p)->sample_rate)
549 #define SCAN_STATE_C(p) ((p)->scan_state.save_c)
550 #define SCAN_STATE_L(p) ((p)->scan_state.save_l)
551 #define SCAN_STATE_S(p) ((p)->scan_state.save_s)
552 #define SCALE_ROW(p) ((p)->scale_row)
553 #define SCAN(p) ((p)->scan)
554 #define SCAN_ERROR(c, u, v, txt) if (c) {scan_error (u, v, txt);}
555 #define SCAN_WARNING(c, u, v, txt) if (c) {scan_warning (u, v, txt);}
556 #define SCOPE(p) ((p)->scope)
557 #define SCOPE_ASSIGNED(p) ((p)->scope_assigned)
558 #define SEARCH(p) ((p)->search)
559 #define SELECT(p) ((p)->select)
560 #define SEQUENCE(p) ((p)->sequence)
561 #define SET(p) ((p)->set)
562 #define SHIFT(p) ((p)->shift)
563 #define SHORT_ID(p) ((p)->short_id)
564 #define SIN_ADDR(p) ((p)->sin_addr)
565 #define SIN_FAMILY(p) ((p)->sin_family)
566 #define SIN_PORT(p) ((p)->sin_port)
567 #define SIZE(p) ((p)->size)
568 #define SIZE1(p) ((p)->size1)
569 #define SIZE2(p) ((p)->size2)
570 #define SIZEC(p) ((p)->sizec)
571 #define SLICE(p) ((p)->slice)
572 #define SLICE_OFFSET(p) ((p)->slice_offset)
573 #define SO(p) ((p)->so)
574 #define SORT(p) ((p)->sort)
575 #define SOURCE(p) ((p)->source)
576 #define SOURCE_SCAN(p) ((p)->source_scan)
577 #define SPAN(p) ((p)->span)
578 #define STACK(p) ((p)->stack)
579 #define STACK_POINTER(p) ((p)->stack_pointer)
580 #define STACK_USED(p) ((p)->stack_used)
581 #define STANDENV_MOID(p) ((p)->standenv_moid)
582 #define START(p) ((p)->start)
583 #define STATIC_LINK(p) ((p)->static_link)
584 #define STATUS(p) ((p)->status)
585 #define STATUS_IM(z) (STATUS (&(z)[1]))
586 #define STATUS_RE(z) (STATUS (&(z)[0]))
587 #define STR(p) ((p)->str)
588 #define STREAM(p) ((p)->stream)
589 #define STRING(p) ((p)->string)
590 #define STRPOS(p) ((p)->strpos)
591 #define ST_MODE(p) ((p)->st_mode)
592 #define ST_MTIME(p) ((p)->st_mtime)
593 #define SUB(p) ((p)->sub)
594 #define SUBSET(p) ((p)->subset)
595 #define SUB_MOID(p) (SUB (MOID (p)))
596 #define SUB_NEXT(p) (SUB (NEXT (p)))
597 #define SUB_SUB(p) (SUB (SUB (p)))
598 #define SWAP(p) ((p)->swap)
599 #define SYMBOL(p) ((p)->symbol)
600 #define SYNC(p) ((p)->sync)
601 #define SYNC_INDEX(p) ((p)->sync_index)
602 #define SYNC_LINE(p) ((p)->sync_line)
603 #define S_PORT(p) ((p)->s_port)
604 #define TABLE(p) ((p)->symbol_table)
605 #define TABS(p) ((p)->tabs)
606 #define TAG_LEX_LEVEL(p) (LEVEL (TAG_TABLE (p)))
607 #define TAG_TABLE(p) ((p)->symbol_table)
608 #define TAX(p) ((p)->tag)
609 #define TERM(p) ((p)->term)
610 #define TERMINATOR(p) ((p)->terminator)
611 #define TEXT(p) ((p)->text)
612 #define THREAD_ID(p) ((p)->thread_id)
613 #define THREAD_STACK_OFFSET(p) ((p)->thread_stack_offset)
614 #define TMP_FILE(p) ((p)->tmp_file)
615 #define TMP_TEXT(p) ((p)->tmp_text)
616 #define TM_HOUR(p) ((p)->tm_hour)
617 #define TM_ISDST(p) ((p)->tm_isdst)
618 #define TM_MDAY(p) ((p)->tm_mday)
619 #define TM_MIN(p) ((p)->tm_min)
620 #define TM_MON(p) ((p)->tm_mon)
621 #define TM_SEC(p) ((p)->tm_sec)
622 #define TM_WDAY(p) ((p)->tm_wday)
623 #define TM_YEAR(p) ((p)->tm_year)
624 #define TOF(p) ((p)->tof)
625 #define TOP_LINE(p) ((p)->top_line)
626 #define TOP_MOID(p) ((p)->top_moid)
627 #define TOP_NODE(p) ((p)->top_node)
628 #define TOP_REFINEMENT(p) ((p)->top_refinement)
629 #define TRANS(p) ((p)->trans)
630 #define TRANSIENT(p) ((p)->transient)
631 #define TRANSPUT_BUFFER(p) ((p)->transput_buffer)
632 #define TRANSPUT_ERROR_MENDED(p) ((p)->transput_error_mended)
633 #define TREE_LISTING_SAFE(p) ((p)->tree_listing_safe)
634 #define TRIM(p) ((p)->trim)
635 #define TUPLE(p) ((p)->tuple)
636 #define TV_SEC(p) ((p)->tv_sec)
637 #define TV_USEC(p) ((p)->tv_usec)
638 #define UNDO(p) ((p)->undo)
639 #define UNDO_LINE(p) ((p)->undo_line)
640 #define UNION_OFFSET (SIZE_ALIGNED (A68_UNION))
641 #define UNIT(p) ((p)->unit)
642 #define UPB(p) ((p)->upper_bound)
643 #define UPPER_BOUND(p) ((p)->upper_bound)
644 #define USE(p) ((p)->use)
645 #define VAL(p) ((p)->val)
646 #define VALUE(p) ((p)->value)
647 #define VALUE_ERROR_MENDED(p) ((p)->value_error_mended)
648 #define WARNING_COUNT(p) ((p)->warning_count)
649 #define WHERE(p) ((p)->where)
650 #define IF_ROW(m) (IS_FLEX (m) || IS_ROW (m) || m == M_STRING)
651 #define IS_COERCION(p) ((p)->is_coercion)
652 #define IS_FLEX(m) IS ((m), FLEX_SYMBOL)
653 #define IS_LITERALLY(p, s) (strcmp (NSYMBOL (p), s) == 0)
654 #define IS_NEW_LEXICAL_LEVEL(p) ((p)->is_new_lexical_level)
655 #define ISNT(p, s) (! IS (p, s))
656 #define IS(p, s) (ATTRIBUTE (p) == (s))
657 #define IS_REF_FLEX(m) (IS (m, REF_SYMBOL) && IS (SUB (m), FLEX_SYMBOL))
658 #define IS_REF(m) IS ((m), REF_SYMBOL)
659 #define IS_ROW(m) IS ((m), ROW_SYMBOL)
660 #define IS_STRUCT(m) IS ((m), STRUCT_SYMBOL)
661 #define IS_UNION(m) IS ((m), UNION_SYMBOL)
662 #define WINDOW_X_SIZE(p) ((p)->window_x_size)
663 #define WINDOW_Y_SIZE(p) ((p)->window_y_size)
664 #define WRITE_MOOD(p) ((p)->write_mood)
665 #define X(p) ((p)->x)
666 #define X_COORD(p) ((p)->x_coord)
667 #define Y(p) ((p)->y)
668 #define YOUNGEST_ENVIRON(p) ((p)->youngest_environ)
669 #define Y_COORD(p) ((p)->y_coord)
670
671 #endif