mirror of
https://github.com/nuintun/command-manager.git
synced 2025-06-09 04:34:04 +08:00
update files
This commit is contained in:
parent
53891db655
commit
b82707608e
@ -69,4 +69,40 @@ function normalizeExecArgs(command, options){
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = Emulator;
|
// thread
|
||||||
|
process.on('message', function (project){
|
||||||
|
var stream;
|
||||||
|
|
||||||
|
var emulator = new Emulator({
|
||||||
|
cwd: project.path,
|
||||||
|
command: project.command.value
|
||||||
|
});
|
||||||
|
|
||||||
|
stream = emulator.start();
|
||||||
|
|
||||||
|
stream.stdout.on('data', function (data){
|
||||||
|
process.send({
|
||||||
|
event: 'data',
|
||||||
|
project: project,
|
||||||
|
data: data.toString()
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
stream.stderr.on('data', function (error){
|
||||||
|
emulator.stop();
|
||||||
|
process.send({
|
||||||
|
event: 'error',
|
||||||
|
project: project,
|
||||||
|
data: error.toString()
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
stream.on('close', function (signal){
|
||||||
|
emulator.stop();
|
||||||
|
process.send({
|
||||||
|
event: 'close',
|
||||||
|
project: project,
|
||||||
|
data: signal.toString()
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
@ -4,24 +4,24 @@
|
|||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
var cluster = require('cluster');
|
var path = require('path');
|
||||||
|
|
||||||
var ipc = require('ipc-main');
|
var ipc = require('ipc-main');
|
||||||
|
var fork = require('child_process').fork;
|
||||||
|
|
||||||
// cache
|
// cache
|
||||||
var workers = {};
|
var threads = {};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* killWorker
|
* killThread
|
||||||
* @param name
|
* @param name
|
||||||
*/
|
*/
|
||||||
function killWorker(name){
|
function killThread(name){
|
||||||
var worker = workers[name];
|
var thread = threads[name];
|
||||||
|
|
||||||
if (worker && !worker.isDead()) {
|
if (thread && thread.connected) {
|
||||||
worker.kill('SIGTERM');
|
thread.kill('SIGTERM');
|
||||||
|
|
||||||
delete workers[name];
|
delete threads[name];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -29,11 +29,11 @@ module.exports = {
|
|||||||
start: function (){
|
start: function (){
|
||||||
ipc.on('emulator', function (event, project, action){
|
ipc.on('emulator', function (event, project, action){
|
||||||
var key = project.name + '-' + project.command.name;
|
var key = project.name + '-' + project.command.name;
|
||||||
var worker = workers[key];
|
var thread = threads[key];
|
||||||
|
|
||||||
switch (action) {
|
switch (action) {
|
||||||
case 'start':
|
case 'start':
|
||||||
if (!worker || worker.isDead()) {
|
if (!thread || !thread.connected) {
|
||||||
var env = {};
|
var env = {};
|
||||||
|
|
||||||
Object.keys(process.env).forEach(function (key){
|
Object.keys(process.env).forEach(function (key){
|
||||||
@ -44,29 +44,31 @@ module.exports = {
|
|||||||
env[item.name] = item.value;
|
env[item.name] = item.value;
|
||||||
});
|
});
|
||||||
|
|
||||||
worker = cluster.fork(env);
|
thread = fork(path.join(__dirname, 'emulator'), {
|
||||||
|
env: env
|
||||||
|
});
|
||||||
|
|
||||||
worker.on('message', function (message){
|
thread.on('message', function (message){
|
||||||
event.sender.send('emulator', message.event, message.project, message.data);
|
event.sender.send('emulator', message.event, message.project, message.data);
|
||||||
});
|
});
|
||||||
|
|
||||||
worker.on('error', function (){
|
thread.on('error', function (){
|
||||||
killWorker(project.name);
|
killThread(project.name);
|
||||||
});
|
});
|
||||||
|
|
||||||
delete project.env;
|
delete project.env;
|
||||||
|
|
||||||
worker.send(project);
|
thread.send(project);
|
||||||
|
|
||||||
workers[project.name] = worker;
|
threads[project.name] = thread;
|
||||||
} else {
|
} else {
|
||||||
delete project.env;
|
delete project.env;
|
||||||
|
|
||||||
worker.send(project);
|
thread.send(project);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'stop':
|
case 'stop':
|
||||||
killWorker(project.name);
|
killThread(project.name);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
43
main.js
43
main.js
@ -4,9 +4,6 @@
|
|||||||
|
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
var cluster = require('cluster');
|
|
||||||
|
|
||||||
if (cluster.isMaster) {
|
|
||||||
// node module
|
// node module
|
||||||
var path = require('path');
|
var path = require('path');
|
||||||
// module to control application life
|
// module to control application life
|
||||||
@ -95,43 +92,3 @@ if (cluster.isMaster) {
|
|||||||
// emulator start
|
// emulator start
|
||||||
thread.start();
|
thread.start();
|
||||||
});
|
});
|
||||||
} else {
|
|
||||||
var Emulator = require('./bin/emulator');
|
|
||||||
|
|
||||||
process.on('message', function (project){
|
|
||||||
var stream;
|
|
||||||
|
|
||||||
var emulator = new Emulator({
|
|
||||||
cwd: project.path,
|
|
||||||
command: project.command.value
|
|
||||||
});
|
|
||||||
|
|
||||||
stream = emulator.start();
|
|
||||||
|
|
||||||
stream.stdout.on('data', function (data){
|
|
||||||
process.send({
|
|
||||||
event: 'data',
|
|
||||||
project: project,
|
|
||||||
data: data.toString()
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
stream.stderr.on('data', function (error){
|
|
||||||
emulator.stop();
|
|
||||||
process.send({
|
|
||||||
event: 'error',
|
|
||||||
project: project,
|
|
||||||
data: error.toString()
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
stream.on('close', function (signal){
|
|
||||||
emulator.stop();
|
|
||||||
process.send({
|
|
||||||
event: 'close',
|
|
||||||
project: project,
|
|
||||||
data: signal.toString()
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
@ -494,7 +494,3 @@ header [class*=" icon-"] {
|
|||||||
height: calc(100% - 32px);
|
height: calc(100% - 32px);
|
||||||
background: url(../images/no-data.png) center no-repeat;
|
background: url(../images/no-data.png) center no-repeat;
|
||||||
}
|
}
|
||||||
.ui-terminal-cursor {
|
|
||||||
background: #fff;
|
|
||||||
color: #181818;
|
|
||||||
}
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user