xuxiaobo-bobo e6520392ec '...'
2024-03-18 11:14:05 +08:00

80 lines
2.0 KiB
JavaScript

var exec = require("child_process").exec;
var fs = require("fs");
var cliCommand = require('../cliCommand.js');
var halt = false;
function error(repoType, task, errorMsg, cb) {
if (halt) return false;
console.error("[Repo-Parser] An error occured while " + task + " in a " + repoType + " repository: " + errorMsg);
halt = true;
return cb("[Repo-Parser] An error occured while " + task + " in a " + repoType + " repository: " + errorMsg);
}
function checkReturn(dataArray, cb) {
if (halt) {
return false;
}
if (Object.keys(dataArray).length > 6) {
Object.keys(dataArray).forEach(function(key) {
if (typeof(dataArray[key]) === 'string') {
dataArray[key] = dataArray[key].replace(/\n/g, '');
}
});
cb(null, dataArray);
}
};
module.exports.parse = function parseHg(folder, cb) {
var data = {};
data.type = 'mercurial';
data.commit_history = []; // temporary
exec(cliCommand(folder, "hg paths default"), function(err, stdout, stderr) {
if(err !== null) {
error("mercurial", "fetching path", stderr, cb);
}
else {
data.url = stdout;
checkReturn(data, cb);
}
});
exec(cliCommand(folder, "hg log --limit 1 --template 'changeset: {rev}:{node|short}\nsummary: {desc}'"), function(err, stdout, stderr) {
if(err !== null) {
error("mercurial", "fetching log", stderr, cb);
}
else {
var changeset = stdout.match(/^changeset:\s+([^\n]+)$/m);
//date = stdout.match(/^date:\s+:([^\n]+)$/m);
var summary = stdout.match(/^summary:\s+([^\n]+)$/m);
data.revision = changeset[1];
data.comment = summary[1];
//data.update_time = date;
checkReturn(data, cb);
}
});
exec(cliCommand(folder, "hg branch"), function(err, stdout, stderr) {
if(err !== null) {
error("mercurial", "fetching branch", stderr, cb);
}
else {
data.branch = stdout;
checkReturn(data, cb);
}
});
fs.stat(folder+".hg", function(err, stats) {
if(err !== null) {
error("mercurial", "fetching stats", "no error available", cb);
}
else {
data.update_time = stats.mtime;
checkReturn(data, cb);
}
});
}