-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathconditional.js
91 lines (88 loc) · 3.51 KB
/
conditional.js
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
const {
Enum: { CompilerTypeKind: { PARAMETRIZABLE } }
} = require('../../utils')
module.exports = {
Read: {
'switch': [PARAMETRIZABLE, (compiler, struct) => {
let compare = struct.compareTo ? struct.compareTo : struct.compareToValue
let args = []
if (compare.startsWith('$')) args.push(compare)
else if (struct.compareTo) {
compare = compiler.getField(compare)
}
let code = `switch (${compare}) {\n`
for (const key in struct.fields) {
let val = key
if (isNaN(val) && val !== 'true' && val !== 'false') val = `"${val}"`
code += compiler.indent(`case ${val}: return ` + compiler.callType(struct.fields[key])) + '\n'
}
code += compiler.indent('default: return ' + compiler.callType(struct.default ? struct.default : 'void')) + '\n'
code += `}`
return compiler.wrapCode(code, args)
}],
'option': [PARAMETRIZABLE, (compiler, type) => {
let code = 'const {value} = ctx.bool(buffer, offset)\n'
code += 'if (value) {\n'
code += ' const result = ' + compiler.callType(type, 'offset + 1') + '\n'
code += ' return new Result(result.value, result.size + 1)\n'
code += '}\n'
code += 'return new Result(undefined, 1)'
return compiler.wrapCode(code)
}]
},
Write: {
'switch': [PARAMETRIZABLE, (compiler, struct) => {
let compare = struct.compareTo ? struct.compareTo : struct.compareToValue
let args = []
if (compare.startsWith('$')) args.push(compare)
else if (struct.compareTo) {
compare = compiler.getField(compare)
}
let code = `switch (${compare}) {\n`
for (const key in struct.fields) {
let val = key
if (isNaN(val) && val !== 'true' && val !== 'false') val = `"${val}"`
code += compiler.indent(`case ${val}: return ` + compiler.callType('value', struct.fields[key])) + '\n'
}
code += compiler.indent('default: return ' + compiler.callType('value', struct.default ? struct.default : 'void')) + '\n'
code += `}`
return compiler.wrapCode(code, args)
}],
'option': [PARAMETRIZABLE, (compiler, type) => {
let code = 'if (value != null) {\n'
code += ' offset = ctx.bool(1, buffer, offset)\n'
code += ' offset = ' + compiler.callType('value', type) + '\n'
code += '} else {\n'
code += ' offset = ctx.bool(0, buffer, offset)\n'
code += '}\n'
code += 'return offset'
return compiler.wrapCode(code)
}]
},
SizeOf: {
'switch': [PARAMETRIZABLE, (compiler, struct) => {
let compare = struct.compareTo ? struct.compareTo : struct.compareToValue
let args = []
if (compare.startsWith('$')) args.push(compare)
else if (struct.compareTo) {
compare = compiler.getField(compare)
}
let code = `switch (${compare}) {\n`
for (const key in struct.fields) {
let val = key
if (isNaN(val) && val !== 'true' && val !== 'false') val = `"${val}"`
code += compiler.indent(`case ${val}: return ` + compiler.callType('value', struct.fields[key])) + '\n'
}
code += compiler.indent('default: return ' + compiler.callType('value', struct.default ? struct.default : 'void')) + '\n'
code += `}`
return compiler.wrapCode(code, args)
}],
'option': [PARAMETRIZABLE, (compiler, type) => {
let code = 'if (value != null) {\n'
code += ' return 1 + ' + compiler.callType('value', type) + '\n'
code += '}\n'
code += 'return 1'
return compiler.wrapCode(code)
}]
}
}