@git.zone/tswatch 2.0.9
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/cli.js +4 -0
- package/dist_ts/00_commitinfo_data.d.ts +8 -0
- package/dist_ts/00_commitinfo_data.js +9 -0
- package/dist_ts/index.d.ts +2 -0
- package/dist_ts/index.js +6 -0
- package/dist_ts/interfaces/index.d.ts +1 -0
- package/dist_ts/interfaces/index.js +2 -0
- package/dist_ts/interfaces/interfaces.watchmodes.d.ts +1 -0
- package/dist_ts/interfaces/interfaces.watchmodes.js +2 -0
- package/dist_ts/tswatch.classes.parcel.d.ts +3 -0
- package/dist_ts/tswatch.classes.parcel.js +44 -0
- package/dist_ts/tswatch.classes.tswatch.d.ts +17 -0
- package/dist_ts/tswatch.classes.tswatch.js +134 -0
- package/dist_ts/tswatch.classes.watcher.d.ts +35 -0
- package/dist_ts/tswatch.classes.watcher.js +90 -0
- package/dist_ts/tswatch.cli.d.ts +1 -0
- package/dist_ts/tswatch.cli.js +38 -0
- package/dist_ts/tswatch.logging.d.ts +2 -0
- package/dist_ts/tswatch.logging.js +14 -0
- package/dist_ts/tswatch.paths.d.ts +1 -0
- package/dist_ts/tswatch.paths.js +3 -0
- package/dist_ts/tswatch.plugins.d.ts +15 -0
- package/dist_ts/tswatch.plugins.js +20 -0
- package/license +19 -0
- package/npmextra.json +17 -0
- package/package.json +53 -0
- package/readme.md +39 -0
- package/ts/00_commitinfo_data.ts +8 -0
- package/ts/index.ts +5 -0
- package/ts/interfaces/index.ts +1 -0
- package/ts/interfaces/interfaces.watchmodes.ts +7 -0
- package/ts/tswatch.classes.tswatch.ts +159 -0
- package/ts/tswatch.classes.watcher.ts +105 -0
- package/ts/tswatch.cli.ts +46 -0
- package/ts/tswatch.logging.ts +15 -0
- package/ts/tswatch.paths.ts +3 -0
- package/ts/tswatch.plugins.ts +37 -0
package/cli.js
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* autocreated commitinfo by @pushrocks/commitinfo
|
|
3
|
+
*/
|
|
4
|
+
export const commitinfo = {
|
|
5
|
+
name: '@git.zone/tswatch',
|
|
6
|
+
version: '2.0.8',
|
|
7
|
+
description: 'watch typescript projects during development'
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMDBfY29tbWl0aW5mb19kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvMDBfY29tbWl0aW5mb19kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLElBQUksRUFBRSxtQkFBbUI7SUFDekIsT0FBTyxFQUFFLE9BQU87SUFDaEIsV0FBVyxFQUFFLDhDQUE4QztDQUM1RCxDQUFBIn0=
|
package/dist_ts/index.js
ADDED
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import * as early from '@push.rocks/early';
|
|
2
|
+
early.start('tswatch');
|
|
3
|
+
export * from './tswatch.classes.tswatch.js';
|
|
4
|
+
export * from './tswatch.cli.js';
|
|
5
|
+
early.stop();
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssS0FBSyxNQUFNLG1CQUFtQixDQUFDO0FBQzNDLEtBQUssQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7QUFDdkIsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQyJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './interfaces.watchmodes.js';
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './interfaces.watchmodes.js';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90cy9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUMifQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type TWatchModes = 'test' | 'gitzone_npm' | 'gitzone_service' | 'gitzone_element' | 'gitzone_website' | 'echoSomething';
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
3
|
+
if (mod && mod.__esModule) return mod;
|
|
4
|
+
var result = {};
|
|
5
|
+
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
|
6
|
+
result["default"] = mod;
|
|
7
|
+
return result;
|
|
8
|
+
};
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
const plugins = __importStar(require("./tswatch.plugins"));
|
|
11
|
+
const paths = __importStar(require("./tswatch.paths"));
|
|
12
|
+
class Parcel {
|
|
13
|
+
async start() {
|
|
14
|
+
const entryFiles = plugins.path.join(paths.cwd, './html/index.html');
|
|
15
|
+
// Bundler options
|
|
16
|
+
const options = {
|
|
17
|
+
outDir: './dist_watch',
|
|
18
|
+
outFile: 'index.html',
|
|
19
|
+
publicUrl: '/',
|
|
20
|
+
watch: true,
|
|
21
|
+
cache: true,
|
|
22
|
+
cacheDir: '.nogit/.parcelcache',
|
|
23
|
+
contentHash: false,
|
|
24
|
+
global: 'moduleName',
|
|
25
|
+
minify: false,
|
|
26
|
+
scopeHoist: false,
|
|
27
|
+
target: 'browser',
|
|
28
|
+
bundleNodeModules: true,
|
|
29
|
+
https: null,
|
|
30
|
+
logLevel: 3,
|
|
31
|
+
hmr: true,
|
|
32
|
+
hmrPort: 3003,
|
|
33
|
+
sourceMaps: true,
|
|
34
|
+
hmrHostname: '',
|
|
35
|
+
detailedReport: false // Prints a detailed report of the bundles, assets, filesizes and times, defaults to false, reports are only printed if watch is disabled
|
|
36
|
+
};
|
|
37
|
+
const bundler = new plugins.parcel(entryFiles, options);
|
|
38
|
+
// Run the bundler, this returns the main bundle
|
|
39
|
+
// Use the events if you're using watch mode as this promise will only trigger once and not for every rebuild
|
|
40
|
+
const bundle = await bundler.serve(3002);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
exports.Parcel = Parcel;
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHN3YXRjaC5jbGFzc2VzLnBhcmNlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3Rzd2F0Y2guY2xhc3Nlcy5wYXJjZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsMkRBQTZDO0FBQzdDLHVEQUF5QztBQUV6QyxNQUFhLE1BQU07SUFDVixLQUFLLENBQUMsS0FBSztRQUNoQixNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLG1CQUFtQixDQUFDLENBQUM7UUFFckUsa0JBQWtCO1FBQ2xCLE1BQU0sT0FBTyxHQUFpQztZQUM1QyxNQUFNLEVBQUUsY0FBYztZQUN0QixPQUFPLEVBQUUsWUFBWTtZQUNyQixTQUFTLEVBQUUsR0FBRztZQUNkLEtBQUssRUFBRSxJQUFJO1lBQ1gsS0FBSyxFQUFFLElBQUk7WUFDWCxRQUFRLEVBQUUscUJBQXFCO1lBQy9CLFdBQVcsRUFBRSxLQUFLO1lBQ2xCLE1BQU0sRUFBRSxZQUFZO1lBQ3BCLE1BQU0sRUFBRSxLQUFLO1lBQ2IsVUFBVSxFQUFFLEtBQUs7WUFDakIsTUFBTSxFQUFFLFNBQVM7WUFDakIsaUJBQWlCLEVBQUUsSUFBSTtZQUN2QixLQUFLLEVBQUUsSUFBSTtZQUNYLFFBQVEsRUFBRSxDQUFDO1lBQ1gsR0FBRyxFQUFFLElBQUk7WUFDVCxPQUFPLEVBQUUsSUFBSTtZQUNiLFVBQVUsRUFBRSxJQUFJO1lBQ2hCLFdBQVcsRUFBRSxFQUFFO1lBQ2YsY0FBYyxFQUFFLEtBQUssQ0FBQyx5SUFBeUk7U0FDaEssQ0FBQztRQUVGLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxVQUFVLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFFeEQsZ0RBQWdEO1FBQ2hELDZHQUE2RztRQUM3RyxNQUFNLE1BQU0sR0FBRyxNQUFNLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDM0MsQ0FBQztDQUNGO0FBakNELHdCQWlDQyJ9
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
import * as interfaces from './interfaces/index.js';
|
|
3
|
+
import { Watcher } from './tswatch.classes.watcher.js';
|
|
4
|
+
export declare class TsWatch {
|
|
5
|
+
watchmode: interfaces.TWatchModes;
|
|
6
|
+
watcherMap: plugins.lik.ObjectMap<Watcher>;
|
|
7
|
+
typedserver: plugins.typedserver.TypedServer;
|
|
8
|
+
constructor(watchmodeArg: interfaces.TWatchModes);
|
|
9
|
+
/**
|
|
10
|
+
* starts the TsWatch instance
|
|
11
|
+
*/
|
|
12
|
+
start(): Promise<void>;
|
|
13
|
+
/**
|
|
14
|
+
* stops the execution of any active Watchers
|
|
15
|
+
*/
|
|
16
|
+
stop(): Promise<void>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
import * as paths from './tswatch.paths.js';
|
|
3
|
+
import * as interfaces from './interfaces/index.js';
|
|
4
|
+
import { Watcher } from './tswatch.classes.watcher.js';
|
|
5
|
+
export class TsWatch {
|
|
6
|
+
constructor(watchmodeArg) {
|
|
7
|
+
this.watcherMap = new plugins.lik.ObjectMap();
|
|
8
|
+
this.watchmode = watchmodeArg;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* starts the TsWatch instance
|
|
12
|
+
*/
|
|
13
|
+
async start() {
|
|
14
|
+
const tsbundle = new plugins.tsbundle.TsBundle();
|
|
15
|
+
const htmlHandler = new plugins.tsbundle.HtmlHandler();
|
|
16
|
+
switch (this.watchmode) {
|
|
17
|
+
case 'test':
|
|
18
|
+
this.watcherMap.add(new Watcher({
|
|
19
|
+
filePathToWatch: paths.cwd,
|
|
20
|
+
commandToExecute: 'npm run test2',
|
|
21
|
+
timeout: null,
|
|
22
|
+
}));
|
|
23
|
+
break;
|
|
24
|
+
case 'gitzone_npm':
|
|
25
|
+
this.watcherMap.add(new Watcher({
|
|
26
|
+
filePathToWatch: paths.cwd,
|
|
27
|
+
commandToExecute: 'npm run test',
|
|
28
|
+
timeout: null,
|
|
29
|
+
}));
|
|
30
|
+
break;
|
|
31
|
+
case 'gitzone_element':
|
|
32
|
+
// lets create a standard server
|
|
33
|
+
console.log('bundling TypeScript files to "dist_watch" Note: This is for development only!');
|
|
34
|
+
this.typedserver = new plugins.typedserver.TypedServer({
|
|
35
|
+
cors: true,
|
|
36
|
+
injectReload: true,
|
|
37
|
+
serveDir: plugins.path.join(paths.cwd, './dist_watch/'),
|
|
38
|
+
port: 3002,
|
|
39
|
+
});
|
|
40
|
+
const bundleAndReloadElement = async () => {
|
|
41
|
+
await tsbundle.build(paths.cwd, './html/index.ts', './dist_watch/bundle.js', {
|
|
42
|
+
bundler: 'esbuild',
|
|
43
|
+
});
|
|
44
|
+
await this.typedserver.reload();
|
|
45
|
+
};
|
|
46
|
+
this.watcherMap.add(new Watcher({
|
|
47
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts_web/'),
|
|
48
|
+
functionToCall: async () => {
|
|
49
|
+
await bundleAndReloadElement();
|
|
50
|
+
},
|
|
51
|
+
timeout: null,
|
|
52
|
+
}));
|
|
53
|
+
this.watcherMap.add(new Watcher({
|
|
54
|
+
filePathToWatch: plugins.path.join(paths.cwd, './html/'),
|
|
55
|
+
functionToCall: async () => {
|
|
56
|
+
await htmlHandler.processHtml({
|
|
57
|
+
from: plugins.path.join(paths.cwd, './html/index.html'),
|
|
58
|
+
to: plugins.path.join(paths.cwd, './dist_watch/index.html'),
|
|
59
|
+
minify: false,
|
|
60
|
+
});
|
|
61
|
+
await bundleAndReloadElement();
|
|
62
|
+
},
|
|
63
|
+
timeout: null,
|
|
64
|
+
}));
|
|
65
|
+
break;
|
|
66
|
+
case 'gitzone_website':
|
|
67
|
+
this.watcherMap.add(new Watcher({
|
|
68
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts/'),
|
|
69
|
+
commandToExecute: 'npm run startTs',
|
|
70
|
+
timeout: null,
|
|
71
|
+
}));
|
|
72
|
+
const bundleAndReloadWebsite = async () => {
|
|
73
|
+
await tsbundle.build(paths.cwd, './ts_web/index.ts', './dist_serve/bundle.js', {
|
|
74
|
+
bundler: 'esbuild',
|
|
75
|
+
});
|
|
76
|
+
};
|
|
77
|
+
this.watcherMap.add(new Watcher({
|
|
78
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts_web/'),
|
|
79
|
+
functionToCall: async () => {
|
|
80
|
+
await bundleAndReloadWebsite();
|
|
81
|
+
},
|
|
82
|
+
timeout: null,
|
|
83
|
+
}));
|
|
84
|
+
this.watcherMap.add(new Watcher({
|
|
85
|
+
filePathToWatch: plugins.path.join(paths.cwd, './html/'),
|
|
86
|
+
functionToCall: async () => {
|
|
87
|
+
await htmlHandler.processHtml({
|
|
88
|
+
from: plugins.path.join(paths.cwd, './html/index.html'),
|
|
89
|
+
to: plugins.path.join(paths.cwd, './dist_serve/index.html'),
|
|
90
|
+
minify: false,
|
|
91
|
+
});
|
|
92
|
+
await bundleAndReloadWebsite();
|
|
93
|
+
},
|
|
94
|
+
timeout: null,
|
|
95
|
+
}));
|
|
96
|
+
break;
|
|
97
|
+
case 'gitzone_service':
|
|
98
|
+
this.watcherMap.add(new Watcher({
|
|
99
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts/'),
|
|
100
|
+
commandToExecute: 'npm run startTs',
|
|
101
|
+
timeout: null,
|
|
102
|
+
}));
|
|
103
|
+
break;
|
|
104
|
+
case 'echoSomething':
|
|
105
|
+
const tsWatchInstanceEchoSomething = new Watcher({
|
|
106
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts'),
|
|
107
|
+
commandToExecute: 'npm -v',
|
|
108
|
+
timeout: null,
|
|
109
|
+
});
|
|
110
|
+
this.watcherMap.add(tsWatchInstanceEchoSomething);
|
|
111
|
+
break;
|
|
112
|
+
default:
|
|
113
|
+
break;
|
|
114
|
+
}
|
|
115
|
+
this.watcherMap.forEach(async (watcher) => {
|
|
116
|
+
await watcher.start();
|
|
117
|
+
});
|
|
118
|
+
if (this.typedserver) {
|
|
119
|
+
await this.typedserver.start();
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* stops the execution of any active Watchers
|
|
124
|
+
*/
|
|
125
|
+
async stop() {
|
|
126
|
+
if (this.typedserver) {
|
|
127
|
+
await this.typedserver.stop();
|
|
128
|
+
}
|
|
129
|
+
this.watcherMap.forEach(async (watcher) => {
|
|
130
|
+
await watcher.stop();
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHN3YXRjaC5jbGFzc2VzLnRzd2F0Y2guanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy90c3dhdGNoLmNsYXNzZXMudHN3YXRjaC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHNCQUFzQixDQUFDO0FBQ2hELE9BQU8sS0FBSyxLQUFLLE1BQU0sb0JBQW9CLENBQUM7QUFDNUMsT0FBTyxLQUFLLFVBQVUsTUFBTSx1QkFBdUIsQ0FBQztBQUVwRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFFdkQsTUFBTSxPQUFPLE9BQU87SUFLbEIsWUFBWSxZQUFvQztRQUh6QyxlQUFVLEdBQUcsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBVyxDQUFDO1FBSXZELElBQUksQ0FBQyxTQUFTLEdBQUcsWUFBWSxDQUFDO0lBQ2hDLENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxLQUFLO1FBQ2hCLE1BQU0sUUFBUSxHQUFHLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqRCxNQUFNLFdBQVcsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDdkQsUUFBUSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ3RCLEtBQUssTUFBTTtnQkFDVCxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FDakIsSUFBSSxPQUFPLENBQUM7b0JBQ1YsZUFBZSxFQUFFLEtBQUssQ0FBQyxHQUFHO29CQUMxQixnQkFBZ0IsRUFBRSxlQUFlO29CQUNqQyxPQUFPLEVBQUUsSUFBSTtpQkFDZCxDQUFDLENBQ0gsQ0FBQztnQkFDRixNQUFNO1lBQ1IsS0FBSyxhQUFhO2dCQUNoQixJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FDakIsSUFBSSxPQUFPLENBQUM7b0JBQ1YsZUFBZSxFQUFFLEtBQUssQ0FBQyxHQUFHO29CQUMxQixn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
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export interface IWatcherConstructorOptions {
|
|
2
|
+
filePathToWatch: string;
|
|
3
|
+
commandToExecute?: string;
|
|
4
|
+
functionToCall?: () => Promise<any>;
|
|
5
|
+
timeout?: number;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* A watcher keeps track of one child execution
|
|
9
|
+
*/
|
|
10
|
+
export declare class Watcher {
|
|
11
|
+
/**
|
|
12
|
+
* used to execute shell commands
|
|
13
|
+
*/
|
|
14
|
+
private smartshellInstance;
|
|
15
|
+
private currentExecution;
|
|
16
|
+
private smartchokWatcher;
|
|
17
|
+
private options;
|
|
18
|
+
constructor(optionsArg: IWatcherConstructorOptions);
|
|
19
|
+
/**
|
|
20
|
+
* start the file
|
|
21
|
+
*/
|
|
22
|
+
start(): Promise<void>;
|
|
23
|
+
/**
|
|
24
|
+
* updates the current execution
|
|
25
|
+
*/
|
|
26
|
+
private updateCurrentExecution;
|
|
27
|
+
/**
|
|
28
|
+
* this method sets up a clean exit strategy
|
|
29
|
+
*/
|
|
30
|
+
private setupCleanup;
|
|
31
|
+
/**
|
|
32
|
+
* stops the watcher
|
|
33
|
+
*/
|
|
34
|
+
stop(): Promise<void>;
|
|
35
|
+
}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
import { logger } from './tswatch.logging.js';
|
|
3
|
+
/**
|
|
4
|
+
* A watcher keeps track of one child execution
|
|
5
|
+
*/
|
|
6
|
+
export class Watcher {
|
|
7
|
+
constructor(optionsArg) {
|
|
8
|
+
/**
|
|
9
|
+
* used to execute shell commands
|
|
10
|
+
*/
|
|
11
|
+
this.smartshellInstance = new plugins.smartshell.Smartshell({
|
|
12
|
+
executor: 'bash',
|
|
13
|
+
});
|
|
14
|
+
this.smartchokWatcher = new plugins.smartchok.Smartchok([], {});
|
|
15
|
+
this.options = optionsArg;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* start the file
|
|
19
|
+
*/
|
|
20
|
+
async start() {
|
|
21
|
+
await this.setupCleanup();
|
|
22
|
+
console.log(`Looking at ${this.options.filePathToWatch} for changes`);
|
|
23
|
+
this.smartchokWatcher.add([this.options.filePathToWatch]); // __dirname refers to the directory of this very file
|
|
24
|
+
await this.smartchokWatcher.start();
|
|
25
|
+
const changeObservable = await this.smartchokWatcher.getObservableFor('change');
|
|
26
|
+
changeObservable.subscribe(() => {
|
|
27
|
+
this.updateCurrentExecution();
|
|
28
|
+
});
|
|
29
|
+
await this.updateCurrentExecution();
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* updates the current execution
|
|
33
|
+
*/
|
|
34
|
+
async updateCurrentExecution() {
|
|
35
|
+
if (this.options.commandToExecute) {
|
|
36
|
+
if (this.currentExecution) {
|
|
37
|
+
logger.log('ok', `reexecuting ${this.options.commandToExecute}`);
|
|
38
|
+
this.currentExecution.kill();
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
logger.log('ok', `executing ${this.options.commandToExecute} for the first time`);
|
|
42
|
+
}
|
|
43
|
+
this.currentExecution = await this.smartshellInstance.execStreaming(this.options.commandToExecute);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
console.log('no executionCommand set');
|
|
47
|
+
}
|
|
48
|
+
if (this.options.functionToCall) {
|
|
49
|
+
this.options.functionToCall();
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
console.log('no functionToCall set.');
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* this method sets up a clean exit strategy
|
|
57
|
+
*/
|
|
58
|
+
async setupCleanup() {
|
|
59
|
+
process.on('exit', () => {
|
|
60
|
+
console.log('');
|
|
61
|
+
console.log('now exiting!');
|
|
62
|
+
this.stop();
|
|
63
|
+
process.exit(0);
|
|
64
|
+
});
|
|
65
|
+
process.on('SIGINT', () => {
|
|
66
|
+
console.log('');
|
|
67
|
+
console.log('ok! got SIGINT We are exiting! Just cleaning up to exit neatly :)');
|
|
68
|
+
this.stop();
|
|
69
|
+
process.exit(0);
|
|
70
|
+
});
|
|
71
|
+
// handle timeout
|
|
72
|
+
if (this.options.timeout) {
|
|
73
|
+
plugins.smartdelay.delayFor(this.options.timeout).then(() => {
|
|
74
|
+
console.log(`timed out afer ${this.options.timeout} milliseconds! exiting!`);
|
|
75
|
+
this.stop();
|
|
76
|
+
process.exit(0);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* stops the watcher
|
|
82
|
+
*/
|
|
83
|
+
async stop() {
|
|
84
|
+
await this.smartchokWatcher.stop();
|
|
85
|
+
if (this.currentExecution && !this.currentExecution.childProcess.killed) {
|
|
86
|
+
this.currentExecution.kill();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHN3YXRjaC5jbGFzc2VzLndhdGNoZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy90c3dhdGNoLmNsYXNzZXMud2F0Y2hlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHNCQUFzQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQVM5Qzs7R0FFRztBQUNILE1BQU0sT0FBTyxPQUFPO0lBWWxCLFlBQVksVUFBc0M7UUFYbEQ7O1dBRUc7UUFDSyx1QkFBa0IsR0FBRyxJQUFJLE9BQU8sQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDO1lBQzdELFFBQVEsRUFBRSxNQUFNO1NBQ2pCLENBQUMsQ0FBQztRQUdLLHFCQUFnQixHQUFHLElBQUksT0FBTyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBSWpFLElBQUksQ0FBQyxPQUFPLEdBQUcsVUFBVSxDQUFDO0lBQzVCLENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxLQUFLO1FBQ2hCLE1BQU0sSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQzFCLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxJQUFJLENBQUMsT0FBTyxDQUFDLGVBQWUsY0FBYyxDQUFDLENBQUM7UUFDdEUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxDQUFDLHNEQUFzRDtRQUNqSCxNQUFNLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNwQyxNQUFNLGdCQUFnQixHQUFHLE1BQU0sSUFBSSxDQUFDLGdCQUFnQixDQUFDLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ2hGLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDOUIsSUFBSSxDQUFD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
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const runCli: () => Promise<void>;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
import * as paths from './tswatch.paths.js';
|
|
3
|
+
import { logger } from './tswatch.logging.js';
|
|
4
|
+
import { TsWatch } from './tswatch.classes.tswatch.js';
|
|
5
|
+
const tswatchCli = new plugins.smartcli.Smartcli();
|
|
6
|
+
// standard behaviour will assume gitzone setup
|
|
7
|
+
tswatchCli.standardCommand().subscribe((argvArg => {
|
|
8
|
+
tswatchCli.triggerCommand('npm', {});
|
|
9
|
+
}));
|
|
10
|
+
tswatchCli.addCommand('element').subscribe(async (argvArg) => {
|
|
11
|
+
logger.log('info', `running watch task for a gitzone element project`);
|
|
12
|
+
const tsWatch = new TsWatch('gitzone_element');
|
|
13
|
+
await tsWatch.start();
|
|
14
|
+
});
|
|
15
|
+
tswatchCli.addCommand('npm').subscribe(async (argvArg) => {
|
|
16
|
+
logger.log('info', `running watch task for a gitzone element project`);
|
|
17
|
+
const tsWatch = new TsWatch('gitzone_npm');
|
|
18
|
+
await tsWatch.start();
|
|
19
|
+
});
|
|
20
|
+
tswatchCli.addCommand('service').subscribe(async (argvArg) => {
|
|
21
|
+
logger.log('info', `running test task`);
|
|
22
|
+
const tsWatch = new TsWatch('gitzone_service');
|
|
23
|
+
await tsWatch.start();
|
|
24
|
+
});
|
|
25
|
+
tswatchCli.addCommand('test').subscribe(async (argvArg) => {
|
|
26
|
+
logger.log('info', `running test task`);
|
|
27
|
+
const tsWatch = new TsWatch('test');
|
|
28
|
+
await tsWatch.start();
|
|
29
|
+
});
|
|
30
|
+
tswatchCli.addCommand('website').subscribe(async (argvArg) => {
|
|
31
|
+
logger.log('info', `running watch task for a gitzone website project`);
|
|
32
|
+
const tsWatch = new TsWatch('gitzone_website');
|
|
33
|
+
await tsWatch.start();
|
|
34
|
+
});
|
|
35
|
+
export const runCli = async () => {
|
|
36
|
+
tswatchCli.startParse();
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHN3YXRjaC5jbGkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy90c3dhdGNoLmNsaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHNCQUFzQixDQUFDO0FBQ2hELE9BQU8sS0FBSyxLQUFLLE1BQU0sb0JBQW9CLENBQUM7QUFDNUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRTlDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUV2RCxNQUFNLFVBQVUsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7QUFFbkQsK0NBQStDO0FBQy9DLFVBQVUsQ0FBQyxlQUFlLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUFPLENBQUMsRUFBRTtJQUNoRCxVQUFVLENBQUMsY0FBYyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztBQUN2QyxDQUFDLENBQUMsQ0FBQyxDQUFBO0FBRUgsVUFBVSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFO0lBQzNELE1BQU0sQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLGtEQUFrRCxDQUFDLENBQUM7SUFDdkUsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUMvQyxNQUFNLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUN4QixDQUFDLENBQUMsQ0FBQztBQUVILFVBQVUsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRTtJQUN2RCxNQUFNLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxrREFBa0QsQ0FBQyxDQUFDO0lBQ3ZFLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQzNDLE1BQU0sT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDO0FBQ3hCLENBQUMsQ0FBQyxDQUFDO0FBRUgsVUFBVSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFO0lBQzNELE1BQU0sQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLG1CQUFtQixDQUFDLENBQUM7SUFDeEMsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUMvQyxNQUFNLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUN4QixDQUFDLENBQUMsQ0FBQztBQUVILFVBQVUsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRTtJQUN4RCxNQUFNLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO0lBQ3hDLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3BDLE1BQU0sT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDO0FBQ3hCLENBQUMsQ0FBQyxDQUFDO0FBRUgsVUFBVSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxFQUFFO0lBQzNELE1BQU0sQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLGtEQUFrRCxDQUFDLENBQUM7SUFDdkUsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUMvQyxNQUFNLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUN4QixDQUFDLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxLQUFLLElBQUksRUFBRTtJQUMvQixVQUFVLENBQUMsVUFBVSxFQUFFLENBQUM7QUFDMUIsQ0FBQyxDQUFDIn0=
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
export const logger = new plugins.smartlog.Smartlog({
|
|
3
|
+
logContext: {
|
|
4
|
+
company: 'Some Company',
|
|
5
|
+
companyunit: 'Some CompanyUnit',
|
|
6
|
+
containerName: 'Some Containername',
|
|
7
|
+
environment: 'local',
|
|
8
|
+
runtime: 'node',
|
|
9
|
+
zone: 'gitzone',
|
|
10
|
+
},
|
|
11
|
+
minimumLogLevel: 'silly',
|
|
12
|
+
});
|
|
13
|
+
logger.addLogDestination(new plugins.smartlogDestinationLocal.DestinationLocal());
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHN3YXRjaC5sb2dnaW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvdHN3YXRjaC5sb2dnaW5nLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sc0JBQXNCLENBQUM7QUFFaEQsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUM7SUFDbEQsVUFBVSxFQUFFO1FBQ1YsT0FBTyxFQUFFLGNBQWM7UUFDdkIsV0FBVyxFQUFFLGtCQUFrQjtRQUMvQixhQUFhLEVBQUUsb0JBQW9CO1FBQ25DLFdBQVcsRUFBRSxPQUFPO1FBQ3BCLE9BQU8sRUFBRSxNQUFNO1FBQ2YsSUFBSSxFQUFFLFNBQVM7S0FDaEI7SUFDRCxlQUFlLEVBQUUsT0FBTztDQUN6QixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsaUJBQWlCLENBQUMsSUFBSSxPQUFPLENBQUMsd0JBQXdCLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDIn0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const cwd: string;
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
export const cwd = process.cwd();
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHN3YXRjaC5wYXRocy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3Rzd2F0Y2gucGF0aHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSxzQkFBc0IsQ0FBQztBQUVoRCxNQUFNLENBQUMsTUFBTSxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDIn0=
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import * as path from 'path';
|
|
2
|
+
export { path };
|
|
3
|
+
import * as tsbundle from '@gitzone/tsbundle';
|
|
4
|
+
export { tsbundle };
|
|
5
|
+
import * as typedserver from '@apiglobal/typedserver';
|
|
6
|
+
export { typedserver, };
|
|
7
|
+
import * as lik from '@push.rocks/lik';
|
|
8
|
+
import * as smartchok from '@push.rocks/smartchok';
|
|
9
|
+
import * as smartcli from '@push.rocks/smartcli';
|
|
10
|
+
import * as smartdelay from '@push.rocks/smartdelay';
|
|
11
|
+
import * as smartlog from '@push.rocks/smartlog';
|
|
12
|
+
import * as smartlogDestinationLocal from '@push.rocks/smartlog-destination-local';
|
|
13
|
+
import * as smartshell from '@push.rocks/smartshell';
|
|
14
|
+
import * as taskbuffer from '@push.rocks/taskbuffer';
|
|
15
|
+
export { lik, smartchok, smartcli, smartdelay, smartlog, smartlogDestinationLocal, smartshell, taskbuffer, };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
// node native scope
|
|
2
|
+
import * as path from 'path';
|
|
3
|
+
export { path };
|
|
4
|
+
// @gitzone scope
|
|
5
|
+
import * as tsbundle from '@gitzone/tsbundle';
|
|
6
|
+
export { tsbundle };
|
|
7
|
+
// @apiglobal scope
|
|
8
|
+
import * as typedserver from '@apiglobal/typedserver';
|
|
9
|
+
export { typedserver, };
|
|
10
|
+
// @pushrocks scope
|
|
11
|
+
import * as lik from '@push.rocks/lik';
|
|
12
|
+
import * as smartchok from '@push.rocks/smartchok';
|
|
13
|
+
import * as smartcli from '@push.rocks/smartcli';
|
|
14
|
+
import * as smartdelay from '@push.rocks/smartdelay';
|
|
15
|
+
import * as smartlog from '@push.rocks/smartlog';
|
|
16
|
+
import * as smartlogDestinationLocal from '@push.rocks/smartlog-destination-local';
|
|
17
|
+
import * as smartshell from '@push.rocks/smartshell';
|
|
18
|
+
import * as taskbuffer from '@push.rocks/taskbuffer';
|
|
19
|
+
export { lik, smartchok, smartcli, smartdelay, smartlog, smartlogDestinationLocal, smartshell, taskbuffer, };
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHN3YXRjaC5wbHVnaW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvdHN3YXRjaC5wbHVnaW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG9CQUFvQjtBQUNwQixPQUFPLEtBQUssSUFBSSxNQUFNLE1BQU0sQ0FBQztBQUM3QixPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUM7QUFFaEIsaUJBQWlCO0FBQ2pCLE9BQU8sS0FBSyxRQUFRLE1BQU0sbUJBQW1CLENBQUM7QUFDOUMsT0FBTyxFQUNMLFFBQVEsRUFDVCxDQUFBO0FBRUQsbUJBQW1CO0FBQ25CLE9BQU8sS0FBSyxXQUFXLE1BQU0sd0JBQXdCLENBQUM7QUFFdEQsT0FBTyxFQUNMLFdBQVcsR0FDWixDQUFBO0FBRUQsbUJBQW1CO0FBQ25CLE9BQU8sS0FBSyxHQUFHLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxLQUFLLFNBQVMsTUFBTSx1QkFBdUIsQ0FBQztBQUNuRCxPQUFPLEtBQUssUUFBUSxNQUFNLHNCQUFzQixDQUFDO0FBQ2pELE9BQU8sS0FBSyxVQUFVLE1BQU0sd0JBQXdCLENBQUM7QUFDckQsT0FBTyxLQUFLLFFBQVEsTUFBTSxzQkFBc0IsQ0FBQztBQUNqRCxPQUFPLEtBQUssd0JBQXdCLE1BQU0sd0NBQXdDLENBQUM7QUFDbkYsT0FBTyxLQUFLLFVBQVUsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEtBQUssVUFBVSxNQUFNLHdCQUF3QixDQUFDO0FBRXJELE9BQU8sRUFDTCxHQUFHLEVBQ0gsU0FBUyxFQUNULFFBQVEsRUFDUixVQUFVLEVBQ1YsUUFBUSxFQUNSLHdCQUF3QixFQUN4QixVQUFVLEVBQ1YsVUFBVSxHQUNYLENBQUMifQ==
|
package/license
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
Copyright (c) 2018 Lossless GmbH (hello@lossless.com)
|
|
2
|
+
|
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
4
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
5
|
+
in the Software without restriction, including without limitation the rights
|
|
6
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
7
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
8
|
+
furnished to do so, subject to the following conditions:
|
|
9
|
+
|
|
10
|
+
The above copyright notice and this permission notice shall be included in all
|
|
11
|
+
copies or substantial portions of the Software.
|
|
12
|
+
|
|
13
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
14
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
15
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
16
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
17
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
18
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
19
|
+
SOFTWARE.
|
package/npmextra.json
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
{
|
|
2
|
+
"npmci": {
|
|
3
|
+
"npmGlobalTools": [],
|
|
4
|
+
"npmAccessLevel": "public"
|
|
5
|
+
},
|
|
6
|
+
"gitzone": {
|
|
7
|
+
"projectType": "npm",
|
|
8
|
+
"module": {
|
|
9
|
+
"githost": "gitlab.com",
|
|
10
|
+
"gitscope": "gitzone",
|
|
11
|
+
"gitrepo": "tswatch",
|
|
12
|
+
"shortDescription": "watch typescript projects during development",
|
|
13
|
+
"npmPackagename": "@git.zone/tswatch",
|
|
14
|
+
"license": "MIT"
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@git.zone/tswatch",
|
|
3
|
+
"version": "2.0.9",
|
|
4
|
+
"private": false,
|
|
5
|
+
"description": "watch typescript projects during development",
|
|
6
|
+
"main": "dist_ts/index.js",
|
|
7
|
+
"typings": "dist_ts/index.d.ts",
|
|
8
|
+
"type": "module",
|
|
9
|
+
"author": "Lossless GmbH",
|
|
10
|
+
"license": "MIT",
|
|
11
|
+
"bin": {
|
|
12
|
+
"tswatch": "cli.js"
|
|
13
|
+
},
|
|
14
|
+
"scripts": {
|
|
15
|
+
"test": "(tstest test/ --web)",
|
|
16
|
+
"build": "(tsbuild --web --allowimplicitany)"
|
|
17
|
+
},
|
|
18
|
+
"devDependencies": {
|
|
19
|
+
"@git.zone/tsbuild": "^2.1.69",
|
|
20
|
+
"@git.zone/tstest": "^1.0.77",
|
|
21
|
+
"@push.rocks/tapbundle": "^5.0.15",
|
|
22
|
+
"@types/node": "^20.5.6"
|
|
23
|
+
},
|
|
24
|
+
"dependencies": {
|
|
25
|
+
"@apiglobal/typedserver": "^2.0.65",
|
|
26
|
+
"@git.zone/tsrun": "^1.2.46",
|
|
27
|
+
"@gitzone/tsbundle": "^2.0.8",
|
|
28
|
+
"@push.rocks/early": "^4.0.4",
|
|
29
|
+
"@push.rocks/lik": "^6.0.5",
|
|
30
|
+
"@push.rocks/smartchok": "^1.0.23",
|
|
31
|
+
"@push.rocks/smartcli": "^4.0.8",
|
|
32
|
+
"@push.rocks/smartdelay": "^3.0.5",
|
|
33
|
+
"@push.rocks/smartlog": "^3.0.3",
|
|
34
|
+
"@push.rocks/smartlog-destination-local": "^9.0.0",
|
|
35
|
+
"@push.rocks/smartshell": "^3.0.3",
|
|
36
|
+
"@push.rocks/taskbuffer": "^3.1.6"
|
|
37
|
+
},
|
|
38
|
+
"files": [
|
|
39
|
+
"ts/**/*",
|
|
40
|
+
"ts_web/**/*",
|
|
41
|
+
"dist/**/*",
|
|
42
|
+
"dist_*/**/*",
|
|
43
|
+
"dist_ts/**/*",
|
|
44
|
+
"dist_ts_web/**/*",
|
|
45
|
+
"assets/**/*",
|
|
46
|
+
"cli.js",
|
|
47
|
+
"npmextra.json",
|
|
48
|
+
"readme.md"
|
|
49
|
+
],
|
|
50
|
+
"browserslist": [
|
|
51
|
+
"last 1 chrome versions"
|
|
52
|
+
]
|
|
53
|
+
}
|
package/readme.md
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
# @git.zone/tswatch
|
|
2
|
+
watch typescript projects during development
|
|
3
|
+
|
|
4
|
+
## Availabililty and Links
|
|
5
|
+
* [npmjs.org (npm package)](https://www.npmjs.com/package/@git.zone/tswatch)
|
|
6
|
+
* [gitlab.com (source)](https://gitlab.com/gitzone/tswatch)
|
|
7
|
+
* [github.com (source mirror)](https://github.com/gitzone/tswatch)
|
|
8
|
+
* [docs (typedoc)](https://gitzone.gitlab.io/tswatch/)
|
|
9
|
+
|
|
10
|
+
## Status for master
|
|
11
|
+
|
|
12
|
+
Status Category | Status Badge
|
|
13
|
+
-- | --
|
|
14
|
+
GitLab Pipelines | [](https://lossless.cloud)
|
|
15
|
+
GitLab Pipline Test Coverage | [](https://lossless.cloud)
|
|
16
|
+
npm | [](https://lossless.cloud)
|
|
17
|
+
Snyk | [](https://lossless.cloud)
|
|
18
|
+
TypeScript Support | [](https://lossless.cloud)
|
|
19
|
+
node Support | [](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
|
20
|
+
Code Style | [](https://lossless.cloud)
|
|
21
|
+
PackagePhobia (total standalone install weight) | [](https://lossless.cloud)
|
|
22
|
+
PackagePhobia (package size on registry) | [](https://lossless.cloud)
|
|
23
|
+
BundlePhobia (total size when bundled) | [](https://lossless.cloud)
|
|
24
|
+
Platform support | [](https://lossless.cloud) [](https://lossless.cloud)
|
|
25
|
+
|
|
26
|
+
## Usage
|
|
27
|
+
|
|
28
|
+
Use TypeScript for best in class intellisense
|
|
29
|
+
|
|
30
|
+
## Contribution
|
|
31
|
+
|
|
32
|
+
We are always happy for code contributions. If you are not the code contributing type that is ok. Still, maintaining Open Source repositories takes considerable time and thought. If you like the quality of what we do and our modules are useful to you we would appreciate a little monthly contribution: You can [contribute one time](https://lossless.link/contribute-onetime) or [contribute monthly](https://lossless.link/contribute). :)
|
|
33
|
+
|
|
34
|
+
For further information read the linked docs at the top of this readme.
|
|
35
|
+
|
|
36
|
+
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
|
37
|
+
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
|
|
38
|
+
|
|
39
|
+
[](https://maintainedby.lossless.com)
|
package/ts/index.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './interfaces.watchmodes.js';
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
import * as paths from './tswatch.paths.js';
|
|
3
|
+
import * as interfaces from './interfaces/index.js';
|
|
4
|
+
|
|
5
|
+
import { Watcher } from './tswatch.classes.watcher.js';
|
|
6
|
+
|
|
7
|
+
export class TsWatch {
|
|
8
|
+
public watchmode: interfaces.TWatchModes;
|
|
9
|
+
public watcherMap = new plugins.lik.ObjectMap<Watcher>();
|
|
10
|
+
public typedserver: plugins.typedserver.TypedServer;
|
|
11
|
+
|
|
12
|
+
constructor(watchmodeArg: interfaces.TWatchModes) {
|
|
13
|
+
this.watchmode = watchmodeArg;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* starts the TsWatch instance
|
|
18
|
+
*/
|
|
19
|
+
public async start() {
|
|
20
|
+
const tsbundle = new plugins.tsbundle.TsBundle();
|
|
21
|
+
const htmlHandler = new plugins.tsbundle.HtmlHandler();
|
|
22
|
+
switch (this.watchmode) {
|
|
23
|
+
case 'test':
|
|
24
|
+
this.watcherMap.add(
|
|
25
|
+
new Watcher({
|
|
26
|
+
filePathToWatch: paths.cwd,
|
|
27
|
+
commandToExecute: 'npm run test2',
|
|
28
|
+
timeout: null,
|
|
29
|
+
})
|
|
30
|
+
);
|
|
31
|
+
break;
|
|
32
|
+
case 'gitzone_npm':
|
|
33
|
+
this.watcherMap.add(
|
|
34
|
+
new Watcher({
|
|
35
|
+
filePathToWatch: paths.cwd,
|
|
36
|
+
commandToExecute: 'npm run test',
|
|
37
|
+
timeout: null,
|
|
38
|
+
})
|
|
39
|
+
);
|
|
40
|
+
break;
|
|
41
|
+
case 'gitzone_element':
|
|
42
|
+
// lets create a standard server
|
|
43
|
+
console.log(
|
|
44
|
+
'bundling TypeScript files to "dist_watch" Note: This is for development only!'
|
|
45
|
+
);
|
|
46
|
+
this.typedserver = new plugins.typedserver.TypedServer({
|
|
47
|
+
cors: true,
|
|
48
|
+
injectReload: true,
|
|
49
|
+
serveDir: plugins.path.join(paths.cwd, './dist_watch/'),
|
|
50
|
+
port: 3002,
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
const bundleAndReloadElement = async () => {
|
|
54
|
+
await tsbundle.build(paths.cwd, './html/index.ts', './dist_watch/bundle.js', {
|
|
55
|
+
bundler: 'esbuild',
|
|
56
|
+
});
|
|
57
|
+
await this.typedserver.reload();
|
|
58
|
+
};
|
|
59
|
+
this.watcherMap.add(
|
|
60
|
+
new Watcher({
|
|
61
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts_web/'),
|
|
62
|
+
functionToCall: async () => {
|
|
63
|
+
await bundleAndReloadElement();
|
|
64
|
+
},
|
|
65
|
+
timeout: null,
|
|
66
|
+
})
|
|
67
|
+
);
|
|
68
|
+
this.watcherMap.add(
|
|
69
|
+
new Watcher({
|
|
70
|
+
filePathToWatch: plugins.path.join(paths.cwd, './html/'),
|
|
71
|
+
functionToCall: async () => {
|
|
72
|
+
await htmlHandler.processHtml({
|
|
73
|
+
from: plugins.path.join(paths.cwd, './html/index.html'),
|
|
74
|
+
to: plugins.path.join(paths.cwd, './dist_watch/index.html'),
|
|
75
|
+
minify: false,
|
|
76
|
+
});
|
|
77
|
+
await bundleAndReloadElement();
|
|
78
|
+
},
|
|
79
|
+
timeout: null,
|
|
80
|
+
})
|
|
81
|
+
);
|
|
82
|
+
break;
|
|
83
|
+
case 'gitzone_website':
|
|
84
|
+
this.watcherMap.add(
|
|
85
|
+
new Watcher({
|
|
86
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts/'),
|
|
87
|
+
commandToExecute: 'npm run startTs',
|
|
88
|
+
timeout: null,
|
|
89
|
+
})
|
|
90
|
+
);
|
|
91
|
+
const bundleAndReloadWebsite = async () => {
|
|
92
|
+
await tsbundle.build(paths.cwd, './ts_web/index.ts', './dist_serve/bundle.js', {
|
|
93
|
+
bundler: 'esbuild',
|
|
94
|
+
});
|
|
95
|
+
};
|
|
96
|
+
this.watcherMap.add(
|
|
97
|
+
new Watcher({
|
|
98
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts_web/'),
|
|
99
|
+
functionToCall: async () => {
|
|
100
|
+
await bundleAndReloadWebsite();
|
|
101
|
+
},
|
|
102
|
+
timeout: null,
|
|
103
|
+
})
|
|
104
|
+
);
|
|
105
|
+
this.watcherMap.add(
|
|
106
|
+
new Watcher({
|
|
107
|
+
filePathToWatch: plugins.path.join(paths.cwd, './html/'),
|
|
108
|
+
functionToCall: async () => {
|
|
109
|
+
await htmlHandler.processHtml({
|
|
110
|
+
from: plugins.path.join(paths.cwd, './html/index.html'),
|
|
111
|
+
to: plugins.path.join(paths.cwd, './dist_serve/index.html'),
|
|
112
|
+
minify: false,
|
|
113
|
+
});
|
|
114
|
+
await bundleAndReloadWebsite();
|
|
115
|
+
},
|
|
116
|
+
timeout: null,
|
|
117
|
+
})
|
|
118
|
+
);
|
|
119
|
+
break;
|
|
120
|
+
case 'gitzone_service':
|
|
121
|
+
this.watcherMap.add(
|
|
122
|
+
new Watcher({
|
|
123
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts/'),
|
|
124
|
+
commandToExecute: 'npm run startTs',
|
|
125
|
+
timeout: null,
|
|
126
|
+
})
|
|
127
|
+
);
|
|
128
|
+
break;
|
|
129
|
+
case 'echoSomething':
|
|
130
|
+
const tsWatchInstanceEchoSomething = new Watcher({
|
|
131
|
+
filePathToWatch: plugins.path.join(paths.cwd, './ts'),
|
|
132
|
+
commandToExecute: 'npm -v',
|
|
133
|
+
timeout: null,
|
|
134
|
+
});
|
|
135
|
+
this.watcherMap.add(tsWatchInstanceEchoSomething);
|
|
136
|
+
break;
|
|
137
|
+
default:
|
|
138
|
+
break;
|
|
139
|
+
}
|
|
140
|
+
this.watcherMap.forEach(async (watcher) => {
|
|
141
|
+
await watcher.start();
|
|
142
|
+
});
|
|
143
|
+
if (this.typedserver) {
|
|
144
|
+
await this.typedserver.start();
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
/**
|
|
149
|
+
* stops the execution of any active Watchers
|
|
150
|
+
*/
|
|
151
|
+
public async stop() {
|
|
152
|
+
if (this.typedserver) {
|
|
153
|
+
await this.typedserver.stop();
|
|
154
|
+
}
|
|
155
|
+
this.watcherMap.forEach(async (watcher) => {
|
|
156
|
+
await watcher.stop();
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
import { logger } from './tswatch.logging.js';
|
|
3
|
+
|
|
4
|
+
export interface IWatcherConstructorOptions {
|
|
5
|
+
filePathToWatch: string;
|
|
6
|
+
commandToExecute?: string;
|
|
7
|
+
functionToCall?: () => Promise<any>;
|
|
8
|
+
timeout?: number;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* A watcher keeps track of one child execution
|
|
13
|
+
*/
|
|
14
|
+
export class Watcher {
|
|
15
|
+
/**
|
|
16
|
+
* used to execute shell commands
|
|
17
|
+
*/
|
|
18
|
+
private smartshellInstance = new plugins.smartshell.Smartshell({
|
|
19
|
+
executor: 'bash',
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
private currentExecution: plugins.smartshell.IExecResultStreaming;
|
|
23
|
+
private smartchokWatcher = new plugins.smartchok.Smartchok([], {});
|
|
24
|
+
private options: IWatcherConstructorOptions;
|
|
25
|
+
|
|
26
|
+
constructor(optionsArg: IWatcherConstructorOptions) {
|
|
27
|
+
this.options = optionsArg;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* start the file
|
|
32
|
+
*/
|
|
33
|
+
public async start() {
|
|
34
|
+
await this.setupCleanup();
|
|
35
|
+
console.log(`Looking at ${this.options.filePathToWatch} for changes`);
|
|
36
|
+
this.smartchokWatcher.add([this.options.filePathToWatch]); // __dirname refers to the directory of this very file
|
|
37
|
+
await this.smartchokWatcher.start();
|
|
38
|
+
const changeObservable = await this.smartchokWatcher.getObservableFor('change');
|
|
39
|
+
changeObservable.subscribe(() => {
|
|
40
|
+
this.updateCurrentExecution();
|
|
41
|
+
});
|
|
42
|
+
await this.updateCurrentExecution();
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* updates the current execution
|
|
47
|
+
*/
|
|
48
|
+
private async updateCurrentExecution() {
|
|
49
|
+
if (this.options.commandToExecute) {
|
|
50
|
+
if (this.currentExecution) {
|
|
51
|
+
logger.log('ok', `reexecuting ${this.options.commandToExecute}`);
|
|
52
|
+
this.currentExecution.kill();
|
|
53
|
+
} else {
|
|
54
|
+
logger.log('ok', `executing ${this.options.commandToExecute} for the first time`);
|
|
55
|
+
}
|
|
56
|
+
this.currentExecution = await this.smartshellInstance.execStreaming(
|
|
57
|
+
this.options.commandToExecute
|
|
58
|
+
);
|
|
59
|
+
} else {
|
|
60
|
+
console.log('no executionCommand set');
|
|
61
|
+
}
|
|
62
|
+
if (this.options.functionToCall) {
|
|
63
|
+
this.options.functionToCall();
|
|
64
|
+
} else {
|
|
65
|
+
console.log('no functionToCall set.')
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* this method sets up a clean exit strategy
|
|
71
|
+
*/
|
|
72
|
+
private async setupCleanup() {
|
|
73
|
+
process.on('exit', () => {
|
|
74
|
+
console.log('');
|
|
75
|
+
console.log('now exiting!');
|
|
76
|
+
this.stop();
|
|
77
|
+
process.exit(0);
|
|
78
|
+
});
|
|
79
|
+
process.on('SIGINT', () => {
|
|
80
|
+
console.log('');
|
|
81
|
+
console.log('ok! got SIGINT We are exiting! Just cleaning up to exit neatly :)');
|
|
82
|
+
this.stop();
|
|
83
|
+
process.exit(0);
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
// handle timeout
|
|
87
|
+
if (this.options.timeout) {
|
|
88
|
+
plugins.smartdelay.delayFor(this.options.timeout).then(() => {
|
|
89
|
+
console.log(`timed out afer ${this.options.timeout} milliseconds! exiting!`);
|
|
90
|
+
this.stop();
|
|
91
|
+
process.exit(0);
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* stops the watcher
|
|
98
|
+
*/
|
|
99
|
+
public async stop() {
|
|
100
|
+
await this.smartchokWatcher.stop();
|
|
101
|
+
if (this.currentExecution && !this.currentExecution.childProcess.killed) {
|
|
102
|
+
this.currentExecution.kill();
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
import * as paths from './tswatch.paths.js';
|
|
3
|
+
import { logger } from './tswatch.logging.js';
|
|
4
|
+
|
|
5
|
+
import { TsWatch } from './tswatch.classes.tswatch.js';
|
|
6
|
+
|
|
7
|
+
const tswatchCli = new plugins.smartcli.Smartcli();
|
|
8
|
+
|
|
9
|
+
// standard behaviour will assume gitzone setup
|
|
10
|
+
tswatchCli.standardCommand().subscribe((argvArg => {
|
|
11
|
+
tswatchCli.triggerCommand('npm', {});
|
|
12
|
+
}))
|
|
13
|
+
|
|
14
|
+
tswatchCli.addCommand('element').subscribe(async (argvArg) => {
|
|
15
|
+
logger.log('info', `running watch task for a gitzone element project`);
|
|
16
|
+
const tsWatch = new TsWatch('gitzone_element');
|
|
17
|
+
await tsWatch.start();
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
tswatchCli.addCommand('npm').subscribe(async (argvArg) => {
|
|
21
|
+
logger.log('info', `running watch task for a gitzone element project`);
|
|
22
|
+
const tsWatch = new TsWatch('gitzone_npm');
|
|
23
|
+
await tsWatch.start();
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
tswatchCli.addCommand('service').subscribe(async (argvArg) => {
|
|
27
|
+
logger.log('info', `running test task`);
|
|
28
|
+
const tsWatch = new TsWatch('gitzone_service');
|
|
29
|
+
await tsWatch.start();
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
tswatchCli.addCommand('test').subscribe(async (argvArg) => {
|
|
33
|
+
logger.log('info', `running test task`);
|
|
34
|
+
const tsWatch = new TsWatch('test');
|
|
35
|
+
await tsWatch.start();
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
tswatchCli.addCommand('website').subscribe(async (argvArg) => {
|
|
39
|
+
logger.log('info', `running watch task for a gitzone website project`);
|
|
40
|
+
const tsWatch = new TsWatch('gitzone_website');
|
|
41
|
+
await tsWatch.start();
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
export const runCli = async () => {
|
|
45
|
+
tswatchCli.startParse();
|
|
46
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import * as plugins from './tswatch.plugins.js';
|
|
2
|
+
|
|
3
|
+
export const logger = new plugins.smartlog.Smartlog({
|
|
4
|
+
logContext: {
|
|
5
|
+
company: 'Some Company',
|
|
6
|
+
companyunit: 'Some CompanyUnit',
|
|
7
|
+
containerName: 'Some Containername',
|
|
8
|
+
environment: 'local',
|
|
9
|
+
runtime: 'node',
|
|
10
|
+
zone: 'gitzone',
|
|
11
|
+
},
|
|
12
|
+
minimumLogLevel: 'silly',
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
logger.addLogDestination(new plugins.smartlogDestinationLocal.DestinationLocal());
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
// node native scope
|
|
2
|
+
import * as path from 'path';
|
|
3
|
+
export { path };
|
|
4
|
+
|
|
5
|
+
// @gitzone scope
|
|
6
|
+
import * as tsbundle from '@gitzone/tsbundle';
|
|
7
|
+
export {
|
|
8
|
+
tsbundle
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
// @apiglobal scope
|
|
12
|
+
import * as typedserver from '@apiglobal/typedserver';
|
|
13
|
+
|
|
14
|
+
export {
|
|
15
|
+
typedserver,
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
// @pushrocks scope
|
|
19
|
+
import * as lik from '@push.rocks/lik';
|
|
20
|
+
import * as smartchok from '@push.rocks/smartchok';
|
|
21
|
+
import * as smartcli from '@push.rocks/smartcli';
|
|
22
|
+
import * as smartdelay from '@push.rocks/smartdelay';
|
|
23
|
+
import * as smartlog from '@push.rocks/smartlog';
|
|
24
|
+
import * as smartlogDestinationLocal from '@push.rocks/smartlog-destination-local';
|
|
25
|
+
import * as smartshell from '@push.rocks/smartshell';
|
|
26
|
+
import * as taskbuffer from '@push.rocks/taskbuffer';
|
|
27
|
+
|
|
28
|
+
export {
|
|
29
|
+
lik,
|
|
30
|
+
smartchok,
|
|
31
|
+
smartcli,
|
|
32
|
+
smartdelay,
|
|
33
|
+
smartlog,
|
|
34
|
+
smartlogDestinationLocal,
|
|
35
|
+
smartshell,
|
|
36
|
+
taskbuffer,
|
|
37
|
+
};
|