@haibun/utils 1.13.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/link-packages.d.ts +2 -0
- package/build/link-packages.js +22 -0
- package/build/link-packages.js.map +1 -0
- package/build/postinstall.d.ts +1 -0
- package/build/postinstall.js +32 -0
- package/build/postinstall.js.map +1 -0
- package/build/scaffold/index.d.ts +2 -0
- package/build/scaffold/index.js +9 -0
- package/build/scaffold/index.js.map +1 -0
- package/build/scaffold/scaffold.d.ts +10 -0
- package/build/scaffold/scaffold.js +84 -0
- package/build/scaffold/scaffold.js.map +1 -0
- package/build/scaffold/scaffold.test.d.ts +1 -0
- package/build/scaffold/scaffold.test.js +29 -0
- package/build/scaffold/scaffold.test.js.map +1 -0
- package/build/util/index.d.ts +1 -0
- package/build/util/index.js +18 -0
- package/build/util/index.js.map +1 -0
- package/build/util/util.test.d.ts +1 -0
- package/build/util/util.test.js +10 -0
- package/build/util/util.test.js.map +1 -0
- package/build/version.d.ts +1 -0
- package/build/version.js +92 -0
- package/build/version.js.map +1 -0
- package/index.js +1 -0
- package/package.json +42 -0
- package/scaffold/.eslintrc.in +20 -0
- package/scaffold/.prettierrc.in +6 -0
- package/scaffold/jest.config.ts.in +11 -0
- package/scaffold/src/lib/test.ts.in +10 -0
- package/scaffold/src/lib/ts.in +11 -0
- package/scaffold/src/stepper.test.ts.in +16 -0
- package/scaffold/src/stepper.ts.in +26 -0
- package/scaffold/tsconfig.json.in +14 -0
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { readFileSync } from "fs";
|
|
3
|
+
import { spawn } from "./util/index.js";
|
|
4
|
+
let pkg;
|
|
5
|
+
try {
|
|
6
|
+
pkg = JSON.parse(readFileSync('package.json', 'utf-8'));
|
|
7
|
+
}
|
|
8
|
+
catch (e) {
|
|
9
|
+
console.error(`failed to read package.json ${e}`);
|
|
10
|
+
process.exit(1);
|
|
11
|
+
}
|
|
12
|
+
for (const i in pkg.dependencies) {
|
|
13
|
+
if (i.startsWith('@haibun/')) {
|
|
14
|
+
spawn(['npm', 'link', i], process.cwd());
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
for (const i in pkg.devDependencies) {
|
|
18
|
+
if (i.startsWith('@haibun/')) {
|
|
19
|
+
spawn(['npm', 'link', i], process.cwd());
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=link-packages.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"link-packages.js","sourceRoot":"","sources":["../src/link-packages.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC;AAClC,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAExC,IAAI,GAAG,CAAC;AACR,IAAI;IACA,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC,CAAC;CAC3D;AAAC,OAAO,CAAC,EAAE;IACR,OAAO,CAAC,KAAK,CAAC,+BAA+B,CAAC,EAAE,CAAC,CAAC;IAClD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;CACnB;AAED,KAAK,MAAM,CAAC,IAAI,GAAG,CAAC,YAAY,EAAE;IAC9B,IAAI,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAC1B,KAAK,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;KAC5C;CACJ;AAED,KAAK,MAAM,CAAC,IAAI,GAAG,CAAC,eAAe,EAAE;IACjC,IAAI,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAC1B,KAAK,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;KAC5C;CACJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { readdirSync, readFileSync, statSync } from 'fs';
|
|
2
|
+
import { DepGraph } from 'dependency-graph';
|
|
3
|
+
import { spawn } from './util/index.js';
|
|
4
|
+
console.log('linking packages');
|
|
5
|
+
const graph = new DepGraph();
|
|
6
|
+
const modules = readdirSync('./modules/').map(f => `./modules/${f}`)
|
|
7
|
+
.filter(f => statSync(f).isDirectory()).map(m => m.replace(/\/$/, '').replace(/.*\//, ''));
|
|
8
|
+
modules.forEach(m => graph.addNode(`@haibun/${m}`));
|
|
9
|
+
for (const module of [...modules]) {
|
|
10
|
+
const pkg = JSON.parse(readFileSync(`./modules/${module}/package.json`, 'utf-8'));
|
|
11
|
+
const hd = [...Object.keys(pkg.dependencies || {}), ...Object.keys(pkg.devDependencies || {})].filter(d => d.startsWith('@haibun/'));
|
|
12
|
+
hd.forEach(dep => graph.addDependency(`@haibun/${module}`, dep));
|
|
13
|
+
}
|
|
14
|
+
try {
|
|
15
|
+
doWork();
|
|
16
|
+
}
|
|
17
|
+
catch (e) {
|
|
18
|
+
console.error('caught an exception:', e);
|
|
19
|
+
process.exit(1);
|
|
20
|
+
}
|
|
21
|
+
function doWork() {
|
|
22
|
+
for (const module of graph.overallOrder()) {
|
|
23
|
+
console.info('setting up', module, graph.dependenciesOf(module).length, 'deps');
|
|
24
|
+
const dest = `./modules/${module.replace(/^@haibun\//, '')}`;
|
|
25
|
+
spawn(['tsc', '-b', '.'], dest);
|
|
26
|
+
// if (graph.dependenciesOf(module).length) {
|
|
27
|
+
// spawn(['npm', 'link', ...graph.dependenciesOf(module)], dest);
|
|
28
|
+
// }
|
|
29
|
+
// spawn(['npm', 'link'], dest);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=postinstall.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postinstall.js","sourceRoot":"","sources":["../src/postinstall.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAExC,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;AAEhC,MAAM,KAAK,GAAG,IAAI,QAAQ,EAAE,CAAC;AAE7B,MAAM,OAAO,GAAG,WAAW,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC;KACjE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC;AAC7F,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;AAEpD,KAAK,MAAM,MAAM,IAAI,CAAC,GAAG,OAAO,CAAC,EAAE;IACjC,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,aAAa,MAAM,eAAe,EAAE,OAAO,CAAC,CAAC,CAAC;IAClF,MAAM,EAAE,GAAG,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,IAAI,EAAE,CAAC,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC;IACrI,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,MAAM,EAAE,EAAE,GAAG,CAAC,CAAC,CAAC;CAClE;AAED,IAAI;IACF,MAAM,EAAE,CAAC;CACV;AAAC,OAAO,CAAC,EAAE;IACV,OAAO,CAAC,KAAK,CAAC,sBAAsB,EAAE,CAAC,CAAC,CAAC;IACzC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;CACjB;AAED,SAAS,MAAM;IACb,KAAK,MAAM,MAAM,IAAI,KAAK,CAAC,YAAY,EAAE,EAAE;QACzC,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAChF,MAAM,IAAI,GAAG,aAAa,MAAM,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC,EAAE,CAAC;QAE7D,KAAK,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC;QAChC,6CAA6C;QAC7C,iEAAiE;QACjE,IAAI;QACJ,gCAAgC;KACjC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/scaffold/index.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE/C,IAAI;IACA,cAAc,CAAC,GAAG,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;CACrC;AAAC,OAAO,CAAC,EAAE;IACR,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;CACpB"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'fs';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import { dirname } from 'path';
|
|
5
|
+
import { fileURLToPath } from 'url';
|
|
6
|
+
const refDir = path.join(dirname(fileURLToPath(import.meta.url)), '..', '..');
|
|
7
|
+
export function scaffoldHaibun(dest, out, add) {
|
|
8
|
+
const refHaibunPackage = JSON.parse(readFileSync(path.join(refDir, 'package.json'), 'utf-8'));
|
|
9
|
+
const what = {
|
|
10
|
+
dependencies: {
|
|
11
|
+
'@haibun/core': `${refHaibunPackage.version}`
|
|
12
|
+
},
|
|
13
|
+
devDependencies: ["@types/jest", "@types/node", "@typescript-eslint/eslint-plugin", "@typescript-eslint/parser", "eslint", "eslint-config-airbnb-typescript",
|
|
14
|
+
"eslint-config-prettier", "eslint-plugin-import", "eslint-plugin-prefer-arrow", "eslint-plugin-prettier", "jest",
|
|
15
|
+
"prettier", "ts-jest", "typescript"]
|
|
16
|
+
.reduce((a, i) => ({ ...a, [i]: refHaibunPackage.devDependencies[i] }), {}),
|
|
17
|
+
scripts: {
|
|
18
|
+
test: 'jest --config jest.config.ts',
|
|
19
|
+
lint: 'lint --ext .ts ./src/',
|
|
20
|
+
},
|
|
21
|
+
dirs: [
|
|
22
|
+
'src',
|
|
23
|
+
'src/lib',
|
|
24
|
+
]
|
|
25
|
+
};
|
|
26
|
+
let localDest;
|
|
27
|
+
let pName;
|
|
28
|
+
const localPackageJson = path.join(dest, 'package.json');
|
|
29
|
+
try {
|
|
30
|
+
const localPackage = readFileSync(localPackageJson, 'utf-8');
|
|
31
|
+
localDest = JSON.parse(localPackage);
|
|
32
|
+
pName = localDest.name.replace(/.*\//, '').replace(/[@]/, '_', 'g').replace(/-./g, (x) => x[1].toUpperCase());
|
|
33
|
+
}
|
|
34
|
+
catch (e) {
|
|
35
|
+
throw Error('please run this command from a project folder that has a package.json file with at least a name field. {e}');
|
|
36
|
+
}
|
|
37
|
+
for (const t of ['devDependencies', 'dependencies', 'scripts']) {
|
|
38
|
+
if (!localDest[t]) {
|
|
39
|
+
localDest[t] = {};
|
|
40
|
+
}
|
|
41
|
+
for (const [k, v] of Object.entries(what[t])) {
|
|
42
|
+
if (!localDest[t][k]) {
|
|
43
|
+
if (v === undefined) {
|
|
44
|
+
throw Error(`${t} ${k} is undefined`);
|
|
45
|
+
}
|
|
46
|
+
localDest[t][k] = v;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
writeFileSync(localPackageJson, JSON.stringify(localDest, null, 2));
|
|
51
|
+
for (const f of ['tsconfig.json', 'jest.config.ts', '.eslintrc', '.prettierrc']) {
|
|
52
|
+
writeIfMissing(f);
|
|
53
|
+
}
|
|
54
|
+
for (const d of what.dirs) {
|
|
55
|
+
const ddest = path.join(dest, d);
|
|
56
|
+
if (!existsSync(ddest)) {
|
|
57
|
+
out('mkdir', ddest);
|
|
58
|
+
mkdirSync(ddest);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
for (const f of ['stepper.ts', 'stepper.test.ts']) {
|
|
62
|
+
writeIfMissing(`src/${f}`, `src/${pName}-${f}`, 'WTW', pName);
|
|
63
|
+
}
|
|
64
|
+
for (const f of ['ts', 'test.ts']) {
|
|
65
|
+
writeIfMissing(`src/lib/${f}`, `src/lib/${pName}.${f}`, 'WTW', pName);
|
|
66
|
+
}
|
|
67
|
+
function writeIfMissing(from, to, replace, instead) {
|
|
68
|
+
to = path.join(dest, to || from);
|
|
69
|
+
from = `${from}.in`;
|
|
70
|
+
if (existsSync(to)) {
|
|
71
|
+
out(`not copying ${to} because it already exists`);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
let contents = readFileSync(path.join(refDir, 'scaffold', from), 'utf-8');
|
|
75
|
+
if (replace) {
|
|
76
|
+
contents = contents.replaceAll(replace, `${instead}`);
|
|
77
|
+
}
|
|
78
|
+
writeFileSync(to, contents);
|
|
79
|
+
out(`copied ${to}`);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=scaffold.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scaffold.js","sourceRoot":"","sources":["../../src/scaffold/scaffold.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { mkdirSync, readdirSync, readFileSync, rmSync, writeFileSync } from "fs";
|
|
2
|
+
import path from "path";
|
|
3
|
+
import { scaffoldHaibun } from "./scaffold.js";
|
|
4
|
+
const TMPDIR = '/tmp/haibun-scaffold-test/';
|
|
5
|
+
const out = (...a) => undefined;
|
|
6
|
+
beforeEach(() => {
|
|
7
|
+
rmSync(TMPDIR, { recursive: true, force: true });
|
|
8
|
+
mkdirSync(TMPDIR);
|
|
9
|
+
});
|
|
10
|
+
afterAll(() => {
|
|
11
|
+
rmSync(TMPDIR, { recursive: true, force: true });
|
|
12
|
+
});
|
|
13
|
+
describe('scaffold', () => {
|
|
14
|
+
it('throws for empty directory', async () => {
|
|
15
|
+
expect(() => scaffoldHaibun(TMPDIR, out)).toThrow();
|
|
16
|
+
});
|
|
17
|
+
it('creates from basic', async () => {
|
|
18
|
+
const haibunPackage = JSON.parse(readFileSync((path.join(process.cwd(), '..', '..', 'package.json')), 'utf-8'));
|
|
19
|
+
writeFileSync(`${TMPDIR}/package.json`, JSON.stringify({ name: 'test' }));
|
|
20
|
+
expect(() => scaffoldHaibun(TMPDIR, out)).not.toThrow();
|
|
21
|
+
const pkg = JSON.parse(readFileSync(`${TMPDIR}/package.json`, 'utf-8'));
|
|
22
|
+
expect(readdirSync(TMPDIR).sort()).toEqual(['package.json', 'src', 'tsconfig.json', 'jest.config.ts', '.eslintrc', '.prettierrc'].sort());
|
|
23
|
+
expect(pkg.dependencies['@haibun/core']).toBeDefined();
|
|
24
|
+
expect(pkg.devDependencies.jest).toEqual(haibunPackage.devDependencies.jest);
|
|
25
|
+
expect(readdirSync(path.join(TMPDIR, 'src'))).toEqual(['lib', 'test-stepper.test.ts', 'test-stepper.ts']);
|
|
26
|
+
expect(readdirSync(path.join(TMPDIR, 'src/lib'))).toEqual(['test.test.ts', 'test.ts']);
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
//# sourceMappingURL=scaffold.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scaffold.test.js","sourceRoot":"","sources":["../../src/scaffold/scaffold.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AACjF,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAE9C,MAAM,MAAM,GAAG,4BAA4B,CAAC;AAC5C,MAAM,GAAG,GAAG,CAAC,GAAG,CAAW,EAAE,EAAE,CAAC,SAAS,CAAC;AAE1C,UAAU,CAAC,GAAG,EAAE;IACZ,MAAM,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACjD,SAAS,CAAC,MAAM,CAAC,CAAC;AACtB,CAAC,CAAC,CAAC;AACH,QAAQ,CAAC,GAAG,EAAE;IACV,MAAM,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;AACrD,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,UAAU,EAAE,GAAG,EAAE;IACtB,EAAE,CAAC,4BAA4B,EAAE,KAAK,IAAI,EAAE;QACxC,MAAM,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;IACxD,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,oBAAoB,EAAE,KAAK,IAAI,EAAE;QAChC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC;QAEhH,aAAa,CAAC,GAAG,MAAM,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC;QAC1E,MAAM,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACxD,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,MAAM,eAAe,EAAE,OAAO,CAAC,CAAC,CAAC;QACxE,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,cAAc,EAAE,KAAK,EAAE,eAAe,EAAE,gBAAgB,EAAE,WAAW,EAAE,aAAa,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QAC1I,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QACvD,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAC7E,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,sBAAsB,EAAE,iBAAiB,CAAC,CAAC,CAAC;QAC1G,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC;IAC3F,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function spawn(command: string[], module?: string, show?: boolean): void | Error;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { spawnSync } from 'child_process';
|
|
2
|
+
export function spawn(command, module = '.', show = false) {
|
|
3
|
+
const place = module === '.' ? '<root>' : module;
|
|
4
|
+
console.info(`${place}$ ${command.join(' ')}`);
|
|
5
|
+
const [cmd, ...args] = command;
|
|
6
|
+
const { output, stdout, stderr, status, error } = spawnSync(cmd, args, { cwd: module, env: process.env });
|
|
7
|
+
const errString = (error?.message || '') + (stderr?.toString() || '');
|
|
8
|
+
if (errString.length > 0) {
|
|
9
|
+
console.error(`${place}> "${output}" status: ${status}`);
|
|
10
|
+
if (status !== 0) {
|
|
11
|
+
throw Error(place + ': ' + (errString.substring(0, errString.indexOf('\n'))));
|
|
12
|
+
}
|
|
13
|
+
if (show) {
|
|
14
|
+
console.log(`${place}> ${output}`);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/util/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1C,MAAM,UAAU,KAAK,CAAC,OAAiB,EAAE,SAAiB,GAAG,EAAE,OAAgB,KAAK;IAClF,MAAM,KAAK,GAAG,MAAM,KAAK,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC;IACjD,OAAO,CAAC,IAAI,CAAC,GAAG,KAAK,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAC/C,MAAM,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,OAAO,CAAC;IAC/B,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,SAAS,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;IAC1G,MAAM,SAAS,GAAG,CAAC,KAAK,EAAE,OAAO,IAAI,EAAE,CAAC,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;IACtE,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;QACxB,OAAO,CAAC,KAAK,CAAC,GAAG,KAAK,MAAM,MAAM,aAAa,MAAM,EAAE,CAAC,CAAC;QACzD,IAAI,MAAM,KAAK,CAAC,EAAE;YAChB,MAAM,KAAK,CAAC,KAAK,GAAG,IAAI,GAAG,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;SAC/E;QACD,IAAI,IAAI,EAAE;YACR,OAAO,CAAC,GAAG,CAAC,GAAG,KAAK,KAAK,MAAM,EAAE,CAAC,CAAC;SACpC;KACF;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { spawn } from './index.js';
|
|
2
|
+
describe('spawn', () => {
|
|
3
|
+
it('should spawn', () => {
|
|
4
|
+
expect(() => spawn(['echo', 'hello'])).not.toThrow();
|
|
5
|
+
});
|
|
6
|
+
it('should catch failure', () => {
|
|
7
|
+
expect(() => spawn(['xecho', 'hello'])).toThrow();
|
|
8
|
+
});
|
|
9
|
+
});
|
|
10
|
+
//# sourceMappingURL=util.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"util.test.js","sourceRoot":"","sources":["../../src/util/util.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAC;AAEnC,QAAQ,CAAC,OAAO,EAAE,GAAG,EAAE;IACrB,EAAE,CAAC,cAAc,EAAE,GAAG,EAAE;QACtB,MAAM,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IACvD,CAAC,CAAC,CAAC;IACH,EAAE,CAAC,sBAAsB,EAAE,GAAG,EAAE;QAC9B,MAAM,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;IACpD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/build/version.js
ADDED
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { readFileSync, writeFileSync } from 'fs';
|
|
2
|
+
import { spawn } from './util/index.js';
|
|
3
|
+
const [, me, version, ...extra] = process.argv;
|
|
4
|
+
class Versioner {
|
|
5
|
+
toPublish = [];
|
|
6
|
+
version;
|
|
7
|
+
haibun = {};
|
|
8
|
+
constructor(version) {
|
|
9
|
+
this.version = version;
|
|
10
|
+
}
|
|
11
|
+
doVersion() {
|
|
12
|
+
try {
|
|
13
|
+
const hpkg = JSON.parse(readFileSync('./package.json', 'utf-8'));
|
|
14
|
+
if (hpkg.name !== 'haibun') {
|
|
15
|
+
throw Error('not in haibun root');
|
|
16
|
+
}
|
|
17
|
+
for (const [dep, version] of Object.entries({
|
|
18
|
+
...hpkg.dependencies,
|
|
19
|
+
...hpkg.devDependencies,
|
|
20
|
+
})) {
|
|
21
|
+
this.haibun[dep] = version;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
catch (e) {
|
|
25
|
+
console.error(e);
|
|
26
|
+
process.exit(1);
|
|
27
|
+
}
|
|
28
|
+
if (!this.version) {
|
|
29
|
+
console.error(`usage: ${me}: <version> <extra modules>`);
|
|
30
|
+
process.exit(1);
|
|
31
|
+
}
|
|
32
|
+
const modules = JSON.parse(readFileSync(`./modules/tsconfig.json`, 'utf-8'))
|
|
33
|
+
.references
|
|
34
|
+
.map(f => `./modules/${f.path}`)
|
|
35
|
+
.concat(extra);
|
|
36
|
+
for (const module of modules) {
|
|
37
|
+
const name = module.replace(/\/$/, '').replace(/.*\//, '');
|
|
38
|
+
this.updateVersion(name, module);
|
|
39
|
+
this.toPublish.push(module);
|
|
40
|
+
}
|
|
41
|
+
this.updateVersion('haibun', '.');
|
|
42
|
+
this.publishAll();
|
|
43
|
+
}
|
|
44
|
+
publishAll() {
|
|
45
|
+
for (const module of this.toPublish) {
|
|
46
|
+
console.info('publishing', module);
|
|
47
|
+
spawn(['npm', 'publish'], module);
|
|
48
|
+
spawn(['git', 'push'], module);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
updateVersion(name, location) {
|
|
52
|
+
console.info('updating', name);
|
|
53
|
+
const pkgFile = `${location}/package.json`;
|
|
54
|
+
const pkg = JSON.parse(readFileSync(pkgFile, 'utf-8'));
|
|
55
|
+
pkg.version = this.version;
|
|
56
|
+
for (const d in pkg.dependencies) {
|
|
57
|
+
if (d.startsWith('@haibun/')) {
|
|
58
|
+
pkg.dependencies[d] = this.version;
|
|
59
|
+
}
|
|
60
|
+
if (this.haibun[d]) {
|
|
61
|
+
pkg.dependencies[d] = this.haibun[d];
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
for (const d in pkg.devDependencies) {
|
|
65
|
+
if (d.startsWith('@haibun/')) {
|
|
66
|
+
pkg.devDependencies[d] = this.version;
|
|
67
|
+
}
|
|
68
|
+
if (this.haibun[d]) {
|
|
69
|
+
pkg.devDependencies[d] = this.haibun[d];
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
writeFileSync(pkgFile, JSON.stringify(pkg, null, 2));
|
|
73
|
+
if (location !== '.') {
|
|
74
|
+
try {
|
|
75
|
+
// spawn(['npm', 'run', 'test'], location);
|
|
76
|
+
}
|
|
77
|
+
catch (e) {
|
|
78
|
+
console.error(`npm test failed for ${name}: ${e}`);
|
|
79
|
+
throw e;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
try {
|
|
83
|
+
spawn(['git', 'commit', '-m', `'update ${name} to version ${this.version}'`, 'package.json',], location);
|
|
84
|
+
}
|
|
85
|
+
catch (e) {
|
|
86
|
+
console.error(`git commit failed for ${name}: ${e}`);
|
|
87
|
+
throw e;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
new Versioner(version).doVersion();
|
|
92
|
+
//# sourceMappingURL=version.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"version.js","sourceRoot":"","sources":["../src/version.ts"],"names":[],"mappings":"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"}
|
package/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './build/util/index.js';
|
package/package.json
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@haibun/utils",
|
|
3
|
+
"type": "module",
|
|
4
|
+
"version": "1.13.13",
|
|
5
|
+
"description": "",
|
|
6
|
+
"main": "index.js",
|
|
7
|
+
"files": [
|
|
8
|
+
"build/**",
|
|
9
|
+
"scaffold/**"
|
|
10
|
+
],
|
|
11
|
+
"bin": {
|
|
12
|
+
"scaffold": "build/scaffold/index.js",
|
|
13
|
+
"link-packages": "build/link-packages.js"
|
|
14
|
+
},
|
|
15
|
+
"scripts": {
|
|
16
|
+
"test": "jest",
|
|
17
|
+
"test-watch": "jest --watch",
|
|
18
|
+
"build": "tsc -b tsconfig.json"
|
|
19
|
+
},
|
|
20
|
+
"author": "",
|
|
21
|
+
"license": "ISC",
|
|
22
|
+
"dependencies": {
|
|
23
|
+
"dependency-graph": "^0.11.0"
|
|
24
|
+
},
|
|
25
|
+
"devDependencies": {
|
|
26
|
+
"@types/jest": "^29.2.4",
|
|
27
|
+
"@types/node": "^18.11.14",
|
|
28
|
+
"@typescript-eslint/eslint-plugin": "^5.48.0",
|
|
29
|
+
"@typescript-eslint/parser": "^5.48.0",
|
|
30
|
+
"eslint": "^8.31.0",
|
|
31
|
+
"eslint-config-airbnb-typescript": "^17.0.0",
|
|
32
|
+
"eslint-config-prettier": "^8.6.0",
|
|
33
|
+
"eslint-plugin-import": "^2.22.1",
|
|
34
|
+
"eslint-plugin-prefer-arrow": "^1.2.2",
|
|
35
|
+
"eslint-plugin-prettier": "^4.2.1",
|
|
36
|
+
"jest": "^29.3.1",
|
|
37
|
+
"prettier": "^2.8.1",
|
|
38
|
+
"ts-jest": "^29.0.3",
|
|
39
|
+
"ts-node": "^10.9.1",
|
|
40
|
+
"typescript": "^5.0.0-dev.20230117"
|
|
41
|
+
}
|
|
42
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
{
|
|
2
|
+
"parser": "@typescript-eslint/parser",
|
|
3
|
+
"parserOptions": {
|
|
4
|
+
"ecmaVersion": 12,
|
|
5
|
+
"sourceType": "module",
|
|
6
|
+
},
|
|
7
|
+
"plugins": ["@typescript-eslint"],
|
|
8
|
+
"extends": ["eslint:recommended", "plugin:@typescript-eslint/recommended"],
|
|
9
|
+
|
|
10
|
+
"rules": {
|
|
11
|
+
"@typescript-eslint/no-unused-vars": "warn",
|
|
12
|
+
// to enforce using type for object type definitions, can be type or interface
|
|
13
|
+
"@typescript-eslint/consistent-type-definitions": ["error", "type"],
|
|
14
|
+
},
|
|
15
|
+
|
|
16
|
+
"env": {
|
|
17
|
+
"browser": false,
|
|
18
|
+
"es2021": true
|
|
19
|
+
}
|
|
20
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/** @type {import('ts-jest/dist/types').InitialOptionsTsJest} */
|
|
2
|
+
module.exports = {
|
|
3
|
+
preset: 'ts-jest',
|
|
4
|
+
testEnvironment: 'node',
|
|
5
|
+
testPathIgnorePatterns: ['node_modules', 'build'],
|
|
6
|
+
globals: {
|
|
7
|
+
'testMatch': [
|
|
8
|
+
"<rootDir>/src/**/*.test.ts"
|
|
9
|
+
]
|
|
10
|
+
}
|
|
11
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { testWithDefaults } from '@haibun/core/build/lib/test/lib.js';
|
|
2
|
+
|
|
3
|
+
import WTW from './WTW-stepper';
|
|
4
|
+
|
|
5
|
+
describe('WTW test', () => {
|
|
6
|
+
it('passes', async () => {
|
|
7
|
+
const feature = { path: '/features/test.feature', content: `your test phrase passes` };
|
|
8
|
+
const result = await testWithDefaults([feature], [WTW]);
|
|
9
|
+
expect(result.ok).toBe(true);
|
|
10
|
+
});
|
|
11
|
+
it('fails', async () => {
|
|
12
|
+
const feature = { path: '/features/test.feature', content: `your test phrase fails` };
|
|
13
|
+
const result = await testWithDefaults([feature], [WTW]);
|
|
14
|
+
expect(result.ok).toBe(false);
|
|
15
|
+
});
|
|
16
|
+
});
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { AStepper, OK, TNamed, TWorld } from '@haibun/core/build/lib/defs.js';
|
|
2
|
+
import { actionNotOK } from '@haibun/core/build/lib/util/index.js';
|
|
3
|
+
|
|
4
|
+
import WTW from './lib/WTW';
|
|
5
|
+
|
|
6
|
+
class WTWStepper extends AStepper {
|
|
7
|
+
setWorld(world: TWorld, steppers: AStepper[]) {
|
|
8
|
+
super.setWorld(world, steppers);
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
steps = {
|
|
12
|
+
WTW: {
|
|
13
|
+
gwta: `your test phrase {what}`,
|
|
14
|
+
action: async ({ what }: TNamed) => {
|
|
15
|
+
const value = await WTW(what);
|
|
16
|
+
if (value.ok === true) {
|
|
17
|
+
return OK;
|
|
18
|
+
}
|
|
19
|
+
const { message } = value.error;
|
|
20
|
+
return actionNotOK(message, { topics: { WTW: { summary: message, details: value } } });
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export default WTWStepper;
|