-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathau.c
79 lines (64 loc) · 2.77 KB
/
au.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/* Copyright 1990-2011, Jsoftware Inc. All rights reserved. */
/* License in license.txt. */
/* */
/* Adverbs: Utilities */
#include "j.h"
static I jtfdepger(J jt,A w){A*wv;I d=0,k,wd;
wv=AAV(w); wd=(I)w*ARELATIVE(w);
DO(AN(w), k=fdep(fx(WVR(i))); d=MAX(d,k););
R d;
}
I jtfdep(J jt,A w){A f,g;I d=0,k;V*v;
RZ(w);
v=VAV(w);
if(v->fdep)R v->fdep;
if(f=v->f) d=VERB&AT(f)?fdep(f):NOUN&AT(f)&&VGERL&v->flag?fdepger(f):0;
if(g=v->g){k=VERB&AT(g)?fdep(g):NOUN&AT(g)&&VGERR&v->flag?fdepger(g):0; d=MAX(d,k);}
if(CFORK==v->id){k=fdep(v->h); d=MAX(d,k);}
R v->fdep=1+d;
} /* function depth: 1 + max depth of components */
F1(jtfdepadv){RZ(w); ASSERT(VERB&AT(w),EVDOMAIN); R sc(fdep(w));}
DF1(jtdf1){RZ(self); R CALL1(VAV(self)->f1, w,self);}
DF2(jtdf2){RZ(self); R CALL2(VAV(self)->f2,a,w,self);}
DF1(jtdfs1){A s=jt->sf,z; RZ(self); z=CALL1(VAV(self)->f1, w,jt->sf=self); jt->sf=s; R z;}
DF2(jtdfs2){A s=jt->sf,z; RZ(self); z=CALL2(VAV(self)->f2,a,w,jt->sf=self); jt->sf=s; R z;}
/* for monads and dyads that can possibly involve $: */
F1(jtself1){A z;I d=fdep(jt->sf); FDEPINC(d); z=df1( w,jt->sf); FDEPDEC(d); R z;}
F2(jtself2){A z;I d=fdep(jt->sf); FDEPINC(d); z=df2(a,w,jt->sf); FDEPDEC(d); R z;}
A jtac1(J jt,AF f){R fdef(0,VERB, f,0L, 0L,0L,0L, 0L, RMAX,RMAX,RMAX);}
A jtac2(J jt,AF f){R fdef(0,VERB, 0L,f, 0L,0L,0L, 0L, RMAX,RMAX,RMAX);}
F1(jtdomainerr1){ASSERT(0,EVDOMAIN);}
F2(jtdomainerr2){ASSERT(0,EVDOMAIN);}
A jtfdef(J jt,C id,I t,AF f1,AF f2,A fs,A gs,A hs,I flag,I m,I l,I r){A z;V*v;
RE(0);
GA(z,t,1,0,0); v=VAV(z);
v->f1 =f1?f1:jtdomainerr1; /* monad C function */
v->f2 =f2?f2:jtdomainerr2; /* dyad C function */
v->f =fs; /* monad */
v->g =gs; /* dyad */
v->h =hs; /* fork right tine or other auxiliary stuff */
v->flag =flag;
v->mr =m; /* monadic rank */
v->lr =l; /* left rank */
v->rr =r; /* right rank */
v->fdep =0; /* function depth */
v->id =id; /* spelling */
R z;
}
B nameless(A w){A f,g,h;C id;V*v;
if(!w||NOUN&AT(w))R 1;
v=VAV(w);
id=v->id; f=v->f; g=v->g; h=v->h;
R !(id==CTILDE&&NAME&AT(f)) && nameless(f) && nameless(g) && (id==CFORK?nameless(h):1);
}
B jtprimitive(J jt,A w){A x=w;V*v;
RZ(w);
v=VAV(w);
if(CTILDE==v->id&&NOUN&AT(v->f))RZ(x=fix(w));
R!VAV(x)->f;
} /* 1 iff w is a primitive */
B jtboxatop(J jt,A w){A x;C c;V*v;
RZ(w);
x=VAV(w)->f; v=VAV(x); c=v->id;
R COMPOSE(c)&&CBOX==ID(v->f);
} /* 1 iff "last" function in w is <@f */