@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.
Files changed (37) hide show
  1. package/cli.js +4 -0
  2. package/dist_ts/00_commitinfo_data.d.ts +8 -0
  3. package/dist_ts/00_commitinfo_data.js +9 -0
  4. package/dist_ts/index.d.ts +2 -0
  5. package/dist_ts/index.js +6 -0
  6. package/dist_ts/interfaces/index.d.ts +1 -0
  7. package/dist_ts/interfaces/index.js +2 -0
  8. package/dist_ts/interfaces/interfaces.watchmodes.d.ts +1 -0
  9. package/dist_ts/interfaces/interfaces.watchmodes.js +2 -0
  10. package/dist_ts/tswatch.classes.parcel.d.ts +3 -0
  11. package/dist_ts/tswatch.classes.parcel.js +44 -0
  12. package/dist_ts/tswatch.classes.tswatch.d.ts +17 -0
  13. package/dist_ts/tswatch.classes.tswatch.js +134 -0
  14. package/dist_ts/tswatch.classes.watcher.d.ts +35 -0
  15. package/dist_ts/tswatch.classes.watcher.js +90 -0
  16. package/dist_ts/tswatch.cli.d.ts +1 -0
  17. package/dist_ts/tswatch.cli.js +38 -0
  18. package/dist_ts/tswatch.logging.d.ts +2 -0
  19. package/dist_ts/tswatch.logging.js +14 -0
  20. package/dist_ts/tswatch.paths.d.ts +1 -0
  21. package/dist_ts/tswatch.paths.js +3 -0
  22. package/dist_ts/tswatch.plugins.d.ts +15 -0
  23. package/dist_ts/tswatch.plugins.js +20 -0
  24. package/license +19 -0
  25. package/npmextra.json +17 -0
  26. package/package.json +53 -0
  27. package/readme.md +39 -0
  28. package/ts/00_commitinfo_data.ts +8 -0
  29. package/ts/index.ts +5 -0
  30. package/ts/interfaces/index.ts +1 -0
  31. package/ts/interfaces/interfaces.watchmodes.ts +7 -0
  32. package/ts/tswatch.classes.tswatch.ts +159 -0
  33. package/ts/tswatch.classes.watcher.ts +105 -0
  34. package/ts/tswatch.cli.ts +46 -0
  35. package/ts/tswatch.logging.ts +15 -0
  36. package/ts/tswatch.paths.ts +3 -0
  37. package/ts/tswatch.plugins.ts +37 -0
package/cli.js ADDED
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env node
2
+ process.env.CLI_CALL = 'true';
3
+ const cliTool = await import('./dist_ts/index.js');
4
+ cliTool.runCli();
@@ -0,0 +1,8 @@
1
+ /**
2
+ * autocreated commitinfo by @pushrocks/commitinfo
3
+ */
4
+ export declare const commitinfo: {
5
+ name: string;
6
+ version: string;
7
+ description: string;
8
+ };
@@ -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=
@@ -0,0 +1,2 @@
1
+ export * from './tswatch.classes.tswatch.js';
2
+ export * from './tswatch.cli.js';
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy53YXRjaG1vZGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vdHMvaW50ZXJmYWNlcy9pbnRlcmZhY2VzLndhdGNobW9kZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiJ9
@@ -0,0 +1,3 @@
1
+ export declare class Parcel {
2
+ start(): Promise<void>;
3
+ }
@@ -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,2 @@
1
+ import * as plugins from './tswatch.plugins.js';
2
+ export declare const logger: plugins.smartlog.Smartlog;
@@ -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 | [![pipeline status](https://gitlab.com/gitzone/tswatch/badges/master/pipeline.svg)](https://lossless.cloud)
15
+ GitLab Pipline Test Coverage | [![coverage report](https://gitlab.com/gitzone/tswatch/badges/master/coverage.svg)](https://lossless.cloud)
16
+ npm | [![npm downloads per month](https://badgen.net/npm/dy/@git.zone/tswatch)](https://lossless.cloud)
17
+ Snyk | [![Known Vulnerabilities](https://badgen.net/snyk/gitzone/tswatch)](https://lossless.cloud)
18
+ TypeScript Support | [![TypeScript](https://badgen.net/badge/TypeScript/>=%203.x/blue?icon=typescript)](https://lossless.cloud)
19
+ node Support | [![node](https://img.shields.io/badge/node->=%2010.x.x-blue.svg)](https://nodejs.org/dist/latest-v10.x/docs/api/)
20
+ Code Style | [![Code Style](https://badgen.net/badge/style/prettier/purple)](https://lossless.cloud)
21
+ PackagePhobia (total standalone install weight) | [![PackagePhobia](https://badgen.net/packagephobia/install/@git.zone/tswatch)](https://lossless.cloud)
22
+ PackagePhobia (package size on registry) | [![PackagePhobia](https://badgen.net/packagephobia/publish/@git.zone/tswatch)](https://lossless.cloud)
23
+ BundlePhobia (total size when bundled) | [![BundlePhobia](https://badgen.net/bundlephobia/minzip/@git.zone/tswatch)](https://lossless.cloud)
24
+ Platform support | [![Supports Windows 10](https://badgen.net/badge/supports%20Windows%2010/yes/green?icon=windows)](https://lossless.cloud) [![Supports Mac OS X](https://badgen.net/badge/supports%20Mac%20OS%20X/yes/green?icon=apple)](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 | **&copy;** [Lossless GmbH](https://lossless.gmbh)
37
+ | By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
38
+
39
+ [![repo-footer](https://lossless.gitlab.io/publicrelations/repofooter.svg)](https://maintainedby.lossless.com)
@@ -0,0 +1,8 @@
1
+ /**
2
+ * autocreated commitinfo by @pushrocks/commitinfo
3
+ */
4
+ export const commitinfo = {
5
+ name: '@git.zone/tswatch',
6
+ version: '2.0.9',
7
+ description: 'watch typescript projects during development'
8
+ }
package/ts/index.ts ADDED
@@ -0,0 +1,5 @@
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();
@@ -0,0 +1 @@
1
+ export * from './interfaces.watchmodes.js';
@@ -0,0 +1,7 @@
1
+ export type TWatchModes =
2
+ | 'test'
3
+ | 'gitzone_npm'
4
+ | 'gitzone_service'
5
+ | 'gitzone_element'
6
+ | 'gitzone_website'
7
+ | 'echoSomething';
@@ -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,3 @@
1
+ import * as plugins from './tswatch.plugins.js';
2
+
3
+ export const cwd = process.cwd();
@@ -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
+ };