-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmakeSchema.js
45 lines (38 loc) · 1.1 KB
/
makeSchema.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
/*
Equivalent to the following:
```sh
#!/bin/sh
for i in 1 2 3; do
rm -f __empty.db
sqlite3 __empty.db < db-v$i.sql
npx @rmp135/sql-ts -c sqlite-v$i.json
rm __empty.db
echo "done v$i"
done
```
Except, below, we'll probably only run this for ONE schema version.
*/
var VERSIONS = [3, 4];
var {rm, readFile, writeFile} = require('fs/promises');
var sqlite3 = require('better-sqlite3');
var sqlts = require('@rmp135/sql-ts');
var emptyDb = './__empty.db';
var config = {
"client": "sqlite3",
"connection": {"filename": emptyDb},
"interfaceNameFormat": "${table}Row",
"typeMap": {
"Buffer|string|Uint8Array": ["blob"], // I like having blob be generic like this
"number|bigint": ["integer"] // better-sqlite3 will return bigint to avoid float problems!
}
};
if (require.main === module) {
(async function main() {
for (const i of VERSIONS) {
await rm(emptyDb, {force: true});
sqlite3(emptyDb).exec(await readFile(`db-v${i}.sql`, 'utf8'));
await writeFile(`DbTablesV${i}.ts`, await sqlts.toTypeScript(config));
await rm(emptyDb, {force: true});
}
})();
}