-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathverb-atomic.c
99 lines (81 loc) · 3.16 KB
/
verb-atomic.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#include <stdio.h>
#include <stdlib.h>
#include "anicca.h"
#include "util.h"
#include "error.h"
#include "convert.h"
#include "scalar1.h"
#include "scalar2.h"
#include "verb-atomic.h"
static UC vaindx[256]={
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,1,0,0,0,0,2,3,0,4,0,0, /* !"#$%&'()*+,-./*/
0,0,0,0,0,0,0,0,0,0,0,0,5,0,0,0, /*0123456789:;<=>?*/
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /*@ABCDEFGHIJKLMNO*/
0,0,0,0,0,0,0,0,0,0,0,0,0,0,6,0, /*PQRSTUVWXYZ[\]^_*/
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /*`abcdefghijklmno*/
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /*pqrstuvwxyz{|}~ */
0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
};
#define NVA1 2
static VA verbatm1[NVA1]={
{{ {NULL, 0 }, {NULL, 0 }, {NULL, 0 },
{NULL, 0 }, {NULL, 0 }, {NULL, 0 } }},
{{ {bfact, VAB|VRB }, {ifact, VAI|VRI }, {dfact, VAD|VRD },
{jfact, VAZ|VRZ }, {dfact, VAD|VRD }, {dfact, VAZ|VRZ } }}
};
#define NVA2 7
static VA verbatm2[NVA2]={
{{ {NULL, 0 }, {NULL, 0 }, {NULL, 0 },
{NULL, 0 }, {NULL, 0 }, {NULL, 0 } }},
{{ {bdivide, VAB|VRD}, {idivide, VAI|VRD}, {ddivide, VAD|VRD},
{jdivide, VAZ|VRZ}, {ddivide, VAD|VRD}, {ddivide, VAZ|VRZ} }},
{{ {btimes, VAB|VRB}, {itimes, VAI|VRI}, {dtimes, VAD|VRD},
{jtimes, VAZ|VRZ}, {dtimes, VAD|VRD}, {dtimes, VAZ|VRZ} }},
{{ {bplus, VAB|VRI}, {iplus, VAI|VRI}, {dplus, VAD|VRD},
{jplus, VAZ|VRZ}, {dplus, VAD|VRD}, {dplus, VAZ|VRZ} }},
{{ {bminus, VAB|VRI}, {iminus, VAI|VRI}, {dminus, VAD|VRD},
{jminus, VAZ|VRZ}, {dminus, VAD|VRD}, {dminus, VAZ|VRZ} }},
{{ {blthan, VAB|VRB}, {ilthan, VAI|VRB}, {dlthan, VAD|VRB},
{dlthan, VAZ|VRZ}, {dlthan, VAD|VRD}, {dlthan, VAZ|VRZ} }},
{{ {bpower, VAB|VRB}, {ipower, VAI|VRD}, {dpower, VAD|VRD},
{dpower, VAZ|VRZ}, {dlthan, VAD|VRD}, {dlthan, VAZ|VRZ} }}
};
I atype(I cv) { R cv&VAB ? BOOL : cv&VAI ? INT : cv&VAD ? FLT : CMPX; }
I rtype(I cv) { R cv&VRB ? BOOL : cv&VRI ? INT : cv&VRD ? FLT : CMPX; }
A va1(C id, A y) { A z;
I t=AT(y), cv, at, rt;
I i=vaindx[id+96], j=(t&BOOL ? 0 : t&INT ? 1 : t&FLT ? 2 : 3);
VA2 *vd=&(&verbatm1[i])->fcv[j];
SF f1=vd->f;
ASSERT(t&NUMERIC,ERDOM);
cv=vd->cv; at=atype(cv); rt=rtype(cv);
z = sex1(t==at ? y : conv(at,y), rt, f1);
R z;
}
/*
va2: Execute dyadic atomic verb.
input:
id: ID of atomic verb to execute.
x: left argument.
y: right argument.
output:
Result of the dyadic atomic verb.
*/
A va2(C id, A x, A y) { A z;
I xt=AT(x), yt=AT(y), t=MAX(xt,yt), cv, at, rt;
I i=vaindx[id], j=(t&BOOL ? 0 : t&INT ? 1 : t&FLT ? 2 : 3);
VA2 *vd=&(&verbatm2[i])->fcv[j];
SF f2=vd->f;
ASSERT(xt&NUMERIC&&yt&NUMERIC, ERDOM);
cv=vd->cv; at=atype(cv); rt=rtype(cv);
z = sex2(xt==at ? x : conv(at,x), yt==at ? y : conv(at,y), rt, f2);
R z;
}