mirror of
https://github.com/arduino/arduino-ide.git
synced 2025-05-01 02:37:18 +00:00

From now on, we spawn a detached process that will periodically check whether the parent Theia the process is alive, if no, terminates the daemon. Signed-off-by: Akos Kitta <kittaakos@typefox.io>
88 lines
3.7 KiB
TypeScript
88 lines
3.7 KiB
TypeScript
import * as which from 'which';
|
|
import * as os from 'os';
|
|
import { join, delimiter } from 'path';
|
|
import { exec, spawn, SpawnOptions } from 'child_process';
|
|
import { inject, injectable, named } from 'inversify';
|
|
import { ILogger } from '@theia/core/lib/common/logger';
|
|
import { BackendApplicationContribution } from '@theia/core/lib/node';
|
|
import { Deferred } from '@theia/core/lib/common/promise-util';
|
|
import { environment } from '@theia/application-package/lib/environment';
|
|
import { DaemonLog } from './daemon-log';
|
|
import { ToolOutputServiceServer } from '../common/protocol/tool-output-service';
|
|
|
|
@injectable()
|
|
export class ArduinoDaemon implements BackendApplicationContribution {
|
|
|
|
// Set this to `true` if you want to connect to a CLI running in debug mode.
|
|
static DEBUG_CLI = false;
|
|
|
|
@inject(ILogger)
|
|
@named('daemon')
|
|
protected readonly logger: ILogger
|
|
|
|
@inject(ToolOutputServiceServer)
|
|
protected readonly toolOutputService: ToolOutputServiceServer;
|
|
|
|
protected isReady = new Deferred<boolean>();
|
|
|
|
async onStart() {
|
|
try {
|
|
if (!ArduinoDaemon.DEBUG_CLI) {
|
|
const build = join(__dirname, '..', '..', 'build');
|
|
const executable = await new Promise<string>((resolve, reject) => {
|
|
which(`arduino-cli${os.platform() === 'win32' ? '.exe' : ''}`, { path: `${process.env.PATH}${delimiter}${build}` }, (err, path) => {
|
|
if (err) {
|
|
reject(err);
|
|
return;
|
|
}
|
|
resolve(path);
|
|
});
|
|
});
|
|
this.logger.info(`>>> Starting 'arduino-cli' daemon... [${executable}]`);
|
|
const daemon = exec(`${executable} --debug daemon`, (err, stdout, stderr) => {
|
|
if (err || stderr) {
|
|
console.log(err || new Error(stderr));
|
|
return;
|
|
}
|
|
console.log(stdout);
|
|
});
|
|
const options: SpawnOptions = {
|
|
env: environment.electron.runAsNodeEnv(),
|
|
detached: true,
|
|
stdio: 'ignore'
|
|
}
|
|
const command = process.execPath;
|
|
const cp = spawn(command, [join(__dirname, 'daemon-watcher.js'), String(process.pid), String(daemon.pid)], options);
|
|
cp.unref();
|
|
|
|
if (daemon.stdout) {
|
|
daemon.stdout.on('data', data => {
|
|
this.toolOutputService.publishNewOutput('daemon', data.toString());
|
|
DaemonLog.log(this.logger, data.toString());
|
|
});
|
|
}
|
|
if (daemon.stderr) {
|
|
daemon.stderr.on('data', data => {
|
|
this.toolOutputService.publishNewOutput('daemon error', data.toString());
|
|
DaemonLog.log(this.logger, data.toString());
|
|
});
|
|
}
|
|
if (daemon.stderr) {
|
|
daemon.on('exit', (code, signal) => DaemonLog.log(this.logger, `Daemon exited with code: ${code}. Signal was: ${signal}.`));
|
|
}
|
|
}
|
|
|
|
await new Promise(resolve => setTimeout(resolve, 2000));
|
|
this.isReady.resolve();
|
|
if (!ArduinoDaemon.DEBUG_CLI) {
|
|
this.logger.info(`<<< The 'arduino-cli' daemon is up an running.`);
|
|
} else {
|
|
this.logger.info(`Assuming the 'arduino-cli' already runs in debug mode.`);
|
|
}
|
|
} catch (error) {
|
|
this.isReady.reject(error || new Error('failed to start arduino-cli'));
|
|
}
|
|
}
|
|
|
|
}
|