Go to the documentation of this file.
5 #define WFProve(A) { char *c=(A);if(!WFInput(c)) \
6 fprintf(stderr,"%s failed (%s, line %d)\n",c,__FILE__,__LINE__); }
10 #define NOTQUIET (!quietflag || verbose)
15 #define HEAP_ALLOC(A) (A *)heap_alloc(sizeof(A))
16 #define STACK_ALLOC(A) (A *)stack_alloc(sizeof(A))
18 #define UN_CODED (CODE)0L
26 #define FUNC_ARG(t) ((t)<match_date || (GENERIC)(t)>=heap_pointer)
37 #define DIGIT(C) (C>='0' && C<='9')
39 #define UPPER(C) ((C>='A' && C<='Z') || C=='_')
41 #define LOWER(C) (C>='a' && C<='z')
43 #define ISALPHA(C) (DIGIT(C) || UPPER(C) || LOWER(C))
47 #define SINGLE(C) (C=='(' || C==')' || C=='[' || C==']' || C=='{' || C=='`' || \
48 C=='}' || C==',' || C=='.' || C==';' || C=='@' || \
52 #define SYMBOL(C) (C=='#' || C=='$' || C=='%' || C=='&' || \
53 C=='*' || C=='+' || C=='-' || C=='>' || C=='/' || \
54 C==':' || C=='<' || C=='=' || \
55 C=='~' || C=='^' || C=='|' || C=='\\' || \
62 #define equ_tok(A,B) (!strcmp(A.type->keyword->symbol,B))
63 #define equ_tok3(A,B,Q) (Q?FALSE:equ_tok(A,B))
66 #define equ_tokch(A,B) (A.type->keyword->symbol[0]==B && A.type->keyword->symbol[1]==0)
67 #define equ_tokch3(A,B,Q) (Q?FALSE:equ_tokch(A,B))
71 #define equ_tokc(A,B) (B?equ_tokch(A,B):A.type->keyword->symbol[0]==0)
72 #define equ_tokc3(A,B,Q) (Q?FALSE:equ_tokc(A,B))
80 #define cut_to(C) { ptr_choice_point cp=choice_stack; \
81 while ((GENERIC)cp>(GENERIC)(C)) cp=cp->next; \
95 #define deref_ptr(P) while(P->coref) P=P->coref
98 #define noneval(T) (T->type==quote || T->type==listingsym || T->type==loadsym)
102 #define wl_const_1(S) ((S).value_1 ==NULL && (S).type!=variable)
103 #define wl_const_2(S) ((S).value_2 ==NULL && (S).type!=variable)
104 #define wl_const_3(S) ((S).value_3 ==NULL && (S).type!=variable)
106 #define equal_types(A,B) ((A)==(B))
108 #define is_top(T) ((T)!=NULL && (T)->type==top && (T)->attr_list==NULL)
122 #define VALID_RANGE(A) ((GENERIC)A>=mem_base && (GENERIC)A<mem_limit)
126 #define VALID_ADDRESS(A) ( VALID_RANGE(A) \
127 || (GENERIC)A==(GENERIC)&xevent_list \
128 || (GENERIC)A==(GENERIC)&xevent_existing \
129 || (GENERIC)A==(GENERIC)&var_tree \
132 #define VALID_ADDRESS(A) ( VALID_RANGE(A) \
133 || (GENERIC)A==(GENERIC)&var_tree \
137 #define stack_empty_list() stack_nil()
142 #define deref(P) {deref_ptr(P);if (deref_eval(P)) return TRUE;}
143 #define deref_void(P) {deref_ptr(P);deref_eval(P);}
144 #define deref_rec(P) {deref_ptr(P);if (deref_rec_eval(P)) return TRUE;}
145 #define deref_args(P,S) {deref_ptr(P);if (deref_args_eval(P,S)) return TRUE;}
146 #define deref_args_void(P) {deref_ptr(P);deref_args_eval(P);}
154 #define List_First(header) ((header)->First)
155 #define List_Last(header) ((header)->Last)
156 #define List_Next(header,RefAtom) ((*(header)->GetLinks)(RefAtom)->Next)
157 #define List_Prev(header,RefAtom) ((*(header)->GetLinks)(RefAtom)->Prev)
158 #define List_IsEmpty(header) (List_First(header)==NULL)
163 #define SETARG(args,i,the_feature,the_type,the_options) \
165 args[j].feature = the_feature; \
166 args[j].type = the_type; \
167 args[j].options = the_options; }
169 #define NARGS(args) (sizeof(args)/sizeof(psi_arg))
175 #define XPART(argi,vali,numi) \
176 if (argi->type == xwindow || argi->type == xpixmap) {\
177 vali = GetIntAttr (argi, "id"); \
183 #define XPART(argi,vali,numi) if (FALSE) ;
191 #define include_var_builtin(NBARGS) \
192 ptr_psi_term g, args[NBARGS]; \
195 long ii, success=TRUE, resi=FALSE
198 #define begin_builtin(FUNCNAME, NBARGS, NBARGSIN, TYPES) \
199 if (NBARGS > MAXNBARGS) \
200 Errorline ("in template: you have to increase MAXNBARGS at least to %d !\n", NBARGS); \
205 for (ii = 0; success && ii < NBARGS; ii++) \
206 success = get_arg (g, &args[ii], numbers[ii]); \
210 for (ii = 0; ii < NBARGS; ii++) \
213 deref_args (g, set_extra_args [NBARGS+1]); \
215 for (ii = 0; success && ii < NBARGS; ii++) \
217 success = matches (args[ii]->type, types[ii], &num[ii]); \
218 if (args[ii]->value_3 != NULL && num[ii]) \
219 if (types[ii] == integer) \
220 val[ii] = *(long *) args[ii]->value_3; \
222 if (types[ii] == real) \
223 val[ii] = *(REAL *) args[ii]->value_3; \
225 if (types[ii] == quoted_string) \
226 val[ii] = (long) args[ii]->value_3; \
228 Errorline ("in template: type %T not expected (built-in FUNCNAME).\n", types[ii]); \
230 if (args[ii]->type == lf_true) \
233 if (args[ii]->type == lf_false) \
236 XPART(args[ii],val[ii],num[ii]) \
243 for (ii = 0; ii < NBARGSIN; ii++) \
244 if (args[ii]->resid != NULL || !num[ii]) \
246 residuate (args[ii]); \
250 if (success && !resi) \
254 #define end_builtin() \
258 Errorline ("bad arguments in %P.\n", g); \
261 Errorline ("missing arguments in %P.\n", g); \
265 #define ARGS(args) args
268 #define PERUNIF(X) X,100.0*((double)X/(double)Aunif)
269 #define PERMERGE(X) X,100.0*((double)X/(double)Amerge)
273 #define HASH(A) (((long) A + ((long) A >> 3)) & (HASHSIZE-1))
276 #define ONHEAP(R) ((GENERIC)R>=heap_pointer)
279 #define NEW(A,TYPE) (heap_flag==HEAP \
287 : STACK_ALLOC(TYPE) \
291 #define HEAPDONE(R) (to_heap && ONHEAP(R))
294 #define ALIGNUP(X) { (X) = (GENERIC)( ((long) (X) + (ALIGN-1)) & ~(ALIGN-1) ); }