2022-03-14 22:04:11 +01:00
|
|
|
import * as plugins from './tswatch.plugins.js';
|
|
|
|
import { logger } from './tswatch.logging.js';
|
2020-05-22 07:25:34 +00:00
|
|
|
/**
|
|
|
|
* A watcher keeps track of one child execution
|
|
|
|
*/
|
2022-03-14 22:04:11 +01:00
|
|
|
export class Watcher {
|
2020-05-22 07:25:34 +00:00
|
|
|
constructor(optionsArg) {
|
|
|
|
/**
|
|
|
|
* used to execute shell commands
|
|
|
|
*/
|
|
|
|
this.smartshellInstance = new plugins.smartshell.Smartshell({
|
2021-03-08 00:26:44 +00:00
|
|
|
executor: 'bash',
|
2020-05-22 07:25:34 +00:00
|
|
|
});
|
2024-01-28 18:23:32 +01:00
|
|
|
this.smartchokWatcher = new plugins.smartchok.Smartchok([]);
|
2020-05-22 07:25:34 +00:00
|
|
|
this.options = optionsArg;
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* start the file
|
|
|
|
*/
|
|
|
|
async start() {
|
|
|
|
await this.setupCleanup();
|
|
|
|
console.log(`Looking at ${this.options.filePathToWatch} for changes`);
|
|
|
|
this.smartchokWatcher.add([this.options.filePathToWatch]); // __dirname refers to the directory of this very file
|
|
|
|
await this.smartchokWatcher.start();
|
|
|
|
const changeObservable = await this.smartchokWatcher.getObservableFor('change');
|
|
|
|
changeObservable.subscribe(() => {
|
|
|
|
this.updateCurrentExecution();
|
|
|
|
});
|
|
|
|
await this.updateCurrentExecution();
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* updates the current execution
|
|
|
|
*/
|
|
|
|
async updateCurrentExecution() {
|
2022-03-18 16:36:13 +01:00
|
|
|
if (this.options.commandToExecute) {
|
2020-05-22 07:25:34 +00:00
|
|
|
if (this.currentExecution) {
|
2022-03-14 22:04:11 +01:00
|
|
|
logger.log('ok', `reexecuting ${this.options.commandToExecute}`);
|
2020-05-22 07:25:34 +00:00
|
|
|
this.currentExecution.kill();
|
|
|
|
}
|
|
|
|
else {
|
2022-03-14 22:04:11 +01:00
|
|
|
logger.log('ok', `executing ${this.options.commandToExecute} for the first time`);
|
2020-05-22 07:25:34 +00:00
|
|
|
}
|
|
|
|
this.currentExecution = await this.smartshellInstance.execStreaming(this.options.commandToExecute);
|
|
|
|
}
|
|
|
|
else {
|
2022-03-18 16:36:13 +01:00
|
|
|
console.log('no executionCommand set');
|
|
|
|
}
|
|
|
|
if (this.options.functionToCall) {
|
|
|
|
this.options.functionToCall();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
console.log('no functionToCall set.');
|
2020-05-22 07:25:34 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* this method sets up a clean exit strategy
|
|
|
|
*/
|
|
|
|
async setupCleanup() {
|
|
|
|
process.on('exit', () => {
|
|
|
|
console.log('');
|
|
|
|
console.log('now exiting!');
|
2021-07-26 21:42:51 +02:00
|
|
|
this.stop();
|
2020-05-22 07:25:34 +00:00
|
|
|
process.exit(0);
|
|
|
|
});
|
|
|
|
process.on('SIGINT', () => {
|
|
|
|
console.log('');
|
|
|
|
console.log('ok! got SIGINT We are exiting! Just cleaning up to exit neatly :)');
|
2021-07-26 21:42:51 +02:00
|
|
|
this.stop();
|
2020-05-22 07:25:34 +00:00
|
|
|
process.exit(0);
|
|
|
|
});
|
|
|
|
// handle timeout
|
|
|
|
if (this.options.timeout) {
|
|
|
|
plugins.smartdelay.delayFor(this.options.timeout).then(() => {
|
|
|
|
console.log(`timed out afer ${this.options.timeout} milliseconds! exiting!`);
|
2021-07-26 21:42:51 +02:00
|
|
|
this.stop();
|
2020-05-22 07:25:34 +00:00
|
|
|
process.exit(0);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* stops the watcher
|
|
|
|
*/
|
|
|
|
async stop() {
|
|
|
|
await this.smartchokWatcher.stop();
|
|
|
|
if (this.currentExecution && !this.currentExecution.childProcess.killed) {
|
2021-07-26 21:42:51 +02:00
|
|
|
this.currentExecution.kill();
|
2020-05-22 07:25:34 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-01-28 18:23:32 +01:00
|
|
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHN3YXRjaC5jbGFzc2VzLndhdGNoZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy90c3dhdGNoLmNsYXNzZXMud2F0Y2hlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssT0FBTyxNQUFNLHNCQUFzQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQVM5Qzs7R0FFRztBQUNILE1BQU0sT0FBTyxPQUFPO0lBWWxCLFlBQVksVUFBc0M7UUFYbEQ7O1dBRUc7UUFDSyx1QkFBa0IsR0FBRyxJQUFJLE9BQU8sQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDO1lBQzdELFFBQVEsRUFBRSxNQUFNO1NBQ2pCLENBQUMsQ0FBQztRQUdLLHFCQUFnQixHQUFHLElBQUksT0FBTyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUM7UUFJN0QsSUFBSSxDQUFDLE9BQU8sR0FBRyxVQUFVLENBQUM7SUFDNUIsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLEtBQUs7UUFDaEIsTUFBTSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDMUIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLElBQUksQ0FBQyxPQUFPLENBQUMsZUFBZSxjQUFjLENBQUMsQ0FBQztRQUN0RSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUMsc0RBQXNEO1FBQ2pILE1BQU0sSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3BDLE1BQU0sZ0JBQWdCLEdBQUcsTUFBTSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDaEYsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUM5QixJQUFJLENBQUMsc0JBQXNCLEVB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
|