2011-07-19 20:48:11 +02:00
|
|
|
/**
|
|
|
|
* Controls the communication with the Abiword application
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2011-08-11 16:26:41 +02:00
|
|
|
* 2011 Peter 'Pita' Martischka (Primary Technology Ltd)
|
2011-07-19 20:48:11 +02:00
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS-IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
var spawn = require('child_process').spawn;
|
2011-08-04 14:35:42 +02:00
|
|
|
var async = require("async");
|
2011-07-27 20:29:44 +02:00
|
|
|
var settings = require("./Settings");
|
2011-08-04 14:35:42 +02:00
|
|
|
var os = require('os');
|
2011-07-19 20:48:11 +02:00
|
|
|
|
2011-08-13 14:02:27 +02:00
|
|
|
var doConvertTask;
|
|
|
|
|
2011-08-04 14:35:42 +02:00
|
|
|
//on windows we have to spawn a process for each convertion, cause the plugin abicommand doesn't exist on this platform
|
|
|
|
if(os.type().indexOf("Windows") > -1)
|
2011-07-19 20:48:11 +02:00
|
|
|
{
|
2011-08-04 14:35:42 +02:00
|
|
|
var stdoutBuffer = "";
|
|
|
|
|
2011-08-13 14:02:27 +02:00
|
|
|
doConvertTask = function(task, callback)
|
2011-08-04 14:35:42 +02:00
|
|
|
{
|
|
|
|
//span an abiword process to perform the conversion
|
|
|
|
var abiword = spawn(settings.abiword, ["--to=" + task.destFile, task.srcFile]);
|
|
|
|
|
|
|
|
//delegate the processing of stdout to another function
|
|
|
|
abiword.stdout.on('data', function (data)
|
|
|
|
{
|
|
|
|
//add data to buffer
|
|
|
|
stdoutBuffer+=data.toString();
|
|
|
|
});
|
|
|
|
|
|
|
|
//append error messages to the buffer
|
|
|
|
abiword.stderr.on('data', function (data)
|
|
|
|
{
|
|
|
|
stdoutBuffer += data.toString();
|
|
|
|
});
|
|
|
|
|
|
|
|
//throw exceptions if abiword is dieing
|
|
|
|
abiword.on('exit', function (code)
|
|
|
|
{
|
|
|
|
if(code != 0) {
|
2018-08-27 01:29:37 +02:00
|
|
|
return callback(`Abiword died with exit code ${code}`);
|
2011-08-04 14:35:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if(stdoutBuffer != "")
|
|
|
|
{
|
|
|
|
console.log(stdoutBuffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
callback();
|
|
|
|
});
|
2013-03-24 01:18:44 +01:00
|
|
|
};
|
2011-07-19 20:48:11 +02:00
|
|
|
|
2011-08-04 14:35:42 +02:00
|
|
|
exports.convertFile = function(srcFile, destFile, type, callback)
|
2011-08-04 00:57:11 +02:00
|
|
|
{
|
2011-08-04 14:35:42 +02:00
|
|
|
doConvertTask({"srcFile": srcFile, "destFile": destFile, "type": type}, callback);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
//on unix operating systems, we can start abiword with abicommand and communicate with it via stdin/stdout
|
|
|
|
//thats much faster, about factor 10
|
|
|
|
else
|
|
|
|
{
|
|
|
|
//spawn the abiword process
|
2012-02-27 00:22:53 +01:00
|
|
|
var abiword;
|
|
|
|
var stdoutCallback = null;
|
|
|
|
var spawnAbiword = function (){
|
|
|
|
abiword = spawn(settings.abiword, ["--plugin", "AbiCommand"]);
|
|
|
|
var stdoutBuffer = "";
|
|
|
|
var firstPrompt = true;
|
2011-08-04 14:35:42 +02:00
|
|
|
|
2012-02-27 00:22:53 +01:00
|
|
|
//append error messages to the buffer
|
|
|
|
abiword.stderr.on('data', function (data)
|
|
|
|
{
|
|
|
|
stdoutBuffer += data.toString();
|
|
|
|
});
|
2011-08-04 00:57:11 +02:00
|
|
|
|
2012-02-27 00:22:53 +01:00
|
|
|
//abiword died, let's restart abiword and return an error with the callback
|
|
|
|
abiword.on('exit', function (code)
|
|
|
|
{
|
|
|
|
spawnAbiword();
|
2018-08-27 01:29:37 +02:00
|
|
|
stdoutCallback(`Abiword died with exit code ${code}`);
|
2012-02-27 00:22:53 +01:00
|
|
|
});
|
2011-08-04 14:35:42 +02:00
|
|
|
|
2012-02-27 00:22:53 +01:00
|
|
|
//delegate the processing of stdout to a other function
|
|
|
|
abiword.stdout.on('data',function (data)
|
2011-07-19 20:48:11 +02:00
|
|
|
{
|
2012-02-27 00:22:53 +01:00
|
|
|
//add data to buffer
|
|
|
|
stdoutBuffer+=data.toString();
|
2013-09-22 00:29:32 +02:00
|
|
|
|
2012-02-27 00:22:53 +01:00
|
|
|
//we're searching for the prompt, cause this means everything we need is in the buffer
|
|
|
|
if(stdoutBuffer.search("AbiWord:>") != -1)
|
2011-08-04 14:35:42 +02:00
|
|
|
{
|
2012-02-27 00:22:53 +01:00
|
|
|
//filter the feedback message
|
|
|
|
var err = stdoutBuffer.search("OK") != -1 ? null : stdoutBuffer;
|
|
|
|
|
|
|
|
//reset the buffer
|
|
|
|
stdoutBuffer = "";
|
|
|
|
|
|
|
|
//call the callback with the error message
|
|
|
|
//skip the first prompt
|
|
|
|
if(stdoutCallback != null && !firstPrompt)
|
|
|
|
{
|
|
|
|
stdoutCallback(err);
|
|
|
|
stdoutCallback = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
firstPrompt = false;
|
2011-08-04 14:35:42 +02:00
|
|
|
}
|
2012-02-27 00:22:53 +01:00
|
|
|
});
|
2013-03-24 01:18:44 +01:00
|
|
|
};
|
2012-02-27 00:22:53 +01:00
|
|
|
spawnAbiword();
|
2011-07-19 20:48:11 +02:00
|
|
|
|
2011-08-13 14:02:27 +02:00
|
|
|
doConvertTask = function(task, callback)
|
2011-08-04 14:35:42 +02:00
|
|
|
{
|
|
|
|
abiword.stdin.write("convert " + task.srcFile + " " + task.destFile + " " + task.type + "\n");
|
|
|
|
//create a callback that calls the task callback and the caller callback
|
|
|
|
stdoutCallback = function (err)
|
|
|
|
{
|
|
|
|
callback();
|
2012-02-27 00:22:53 +01:00
|
|
|
console.log("queue continue");
|
2013-04-16 00:01:08 +02:00
|
|
|
try{
|
|
|
|
task.callback(err);
|
|
|
|
}catch(e){
|
|
|
|
console.error("Abiword File failed to convert", e);
|
|
|
|
}
|
2011-08-04 14:35:42 +02:00
|
|
|
};
|
2013-03-24 01:18:44 +01:00
|
|
|
};
|
2011-08-04 14:35:42 +02:00
|
|
|
|
2011-08-16 14:40:01 +02:00
|
|
|
//Queue with the converts we have to do
|
|
|
|
var queue = async.queue(doConvertTask, 1);
|
2011-08-04 14:35:42 +02:00
|
|
|
exports.convertFile = function(srcFile, destFile, type, callback)
|
2013-12-05 08:41:29 +01:00
|
|
|
{
|
2011-08-04 14:35:42 +02:00
|
|
|
queue.push({"srcFile": srcFile, "destFile": destFile, "type": type, "callback": callback});
|
|
|
|
};
|
2011-07-19 20:48:11 +02:00
|
|
|
}
|