|
|
|
"use strict";
|
|
|
|
|
|
|
|
const spawn = require('child_process').spawn;
|
|
|
|
const settings = require("../../settings");
|
|
|
|
|
|
|
|
module.exports = (params, processor) => ({
|
|
|
|
process: () => {
|
|
|
|
let result = "";
|
|
|
|
let error = "";
|
|
|
|
const builder = spawn(settings.builderExecutable, [params.command]);
|
|
|
|
|
|
|
|
processor.onInfo("DotNetBuilderWrapper processing (at " + (new Date().toISOString()) + "): " + JSON.stringify(params, null, 4));
|
|
|
|
|
|
|
|
builder.stdout.on('data', (data) => result += data);
|
|
|
|
builder.stderr.on('data', (data) => error += data);
|
|
|
|
builder.on('exit', (code) => {
|
|
|
|
if (code !== 0) {
|
|
|
|
error = "Return code is " + code + "\r\n" + error;
|
|
|
|
processor.onError(error);
|
|
|
|
return processor.done();
|
|
|
|
}
|
|
|
|
|
|
|
|
const report = JSON.parse(result);
|
|
|
|
const messages = report.Messages;
|
|
|
|
messages.forEach((message) => {
|
|
|
|
if (!message) {
|
|
|
|
return processor.onError("Message is null");
|
|
|
|
}
|
|
|
|
|
|
|
|
switch(message.Type) {
|
|
|
|
case "info":
|
|
|
|
return processor.onInfo(message.Body);
|
|
|
|
case "warn":
|
|
|
|
return processor.onWarn(message.Body);
|
|
|
|
default:
|
|
|
|
return processor.onError(message.Body);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
processor.onInfo("Done DotNetBuilderWrapper processing (at " + (new Date().toISOString()) + ")");
|
|
|
|
return processor.done();
|
|
|
|
});
|
|
|
|
|
|
|
|
builder.stdin.write(JSON.stringify(params));
|
|
|
|
builder.stdin.end();
|
|
|
|
}
|
|
|
|
});
|