-
-
Notifications
You must be signed in to change notification settings - Fork 17
/
fb-util.ts
65 lines (52 loc) · 1.74 KB
/
fb-util.ts
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
import { sqlTypes, Descriptor } from 'node-firebird-driver/dist/lib/impl';
export * from 'node-firebird-driver/dist/lib/impl';
import * as fb from 'node-firebird-native-api';
/** Fix metadata descriptors to types we want to read. */
export function fixMetadata(status: fb.Status, metadata?: fb.MessageMetadata): fb.MessageMetadata | undefined {
if (!metadata)
return undefined;
let ret: fb.MessageMetadata;
const outBuilder = metadata.getBuilderSync(status)!;
try {
for (let i = metadata.getCountSync(status) - 1; i >= 0; --i) {
switch (metadata.getTypeSync(status, i)) {
// Transforms CHAR descriptors to VARCHAR.
case sqlTypes.SQL_TEXT:
outBuilder.setTypeSync(status, i, sqlTypes.SQL_VARYING);
break;
// Transforms numeric descriptors to DOUBLE PRECISION.
case sqlTypes.SQL_SHORT:
case sqlTypes.SQL_LONG:
case sqlTypes.SQL_INT64:
case sqlTypes.SQL_FLOAT:
outBuilder.setTypeSync(status, i, sqlTypes.SQL_DOUBLE);
outBuilder.setLengthSync(status, i, 8);
outBuilder.setScaleSync(status, i, 0);
break;
}
}
ret = outBuilder.getMetadataSync(status)!;
}
finally {
outBuilder.releaseSync();
}
metadata.releaseSync();
return ret;
}
export function createDescriptors(status: fb.Status, metadata?: fb.MessageMetadata): Descriptor[] {
if (!metadata)
return [];
const count = metadata.getCountSync(status);
const ret: Descriptor[] = [];
for (let i = 0; i < count; ++i) {
ret.push({
type: metadata.getTypeSync(status, i),
subType: metadata.getSubTypeSync(status, i),
nullOffset: metadata.getNullOffsetSync(status, i),
offset: metadata.getOffsetSync(status, i),
length: metadata.getLengthSync(status, i),
scale: metadata.getScaleSync(status, i)
});
}
return ret;
}