grunt
Version:
A task-based command line build tool for JavaScript projects.
81 lines (73 loc) • 2.35 kB
JavaScript
/*
* grunt
* https://github.com/cowboy/grunt
*
* Copyright (c) 2012 "Cowboy" Ben Alman
* Licensed under the MIT license.
* http://benalman.com/about/license/
*/
// Error codes
// 1. Generic error.
// 2. Config file not found.
// 3. Generic task failed.
// 10. Uglify-JS error.
// 11. Banner generation error.
// 20. Init error.
// 90-99. Nodeunit/QUnit errors.
// DRY it up!
function writeln(e, mode) {
log.muted = false;
// Pretty colors.
var tags = {
warn: ['<'.red + 'WARN'.yellow + '>'.red, '</'.red + 'WARN'.yellow + '>'.red],
fatal: ['<'.red + 'FATAL'.yellow + '>'.red, '</'.red + 'FATAL'.yellow + '>'.red]
};
var msg = String(e.message || e) + '\x07'; // Beep!
if (mode === 'warn') {
msg += ' ' + (option('force') ? 'Used --force, continuing.'.underline : 'Use --force to continue.');
}
log.writeln([tags[mode][0], msg.yellow, tags[mode][1]].join(' '));
}
// A fatal error occured. Abort immediately.
exports.fatal = function(e, errcode) {
writeln(e, 'fatal');
process.reallyExit(typeof errcode === 'number' ? errcode : 1);
};
// Keep track of error and warning counts.
exports.errorcount = 0;
exports.warncount = 0;
// Something (like the watch task) can override this to perform an alternate
// action to exiting on warn.
exports.warnAlternate = null;
// A warning ocurred. Abort immediately unless -f or --force was used.
exports.warn = function(e, errcode) {
var message = typeof e === 'string' ? e : e.message;
exports.warncount++;
writeln(message, 'warn');
// If -f or --force aren't used, stop script processing.
if (!option('force')) {
if (exports.warnAlternate) {
exports.warnAlternate();
} else {
// If --debug is enabled, log the appropriate error stack (if it exists).
if (option('debug') >= 9) {
if (e.origError && e.origError.stack) {
console.log(e.origError.stack);
} else if (e.stack) {
console.log(e.stack);
}
}
// Log and exit.
log.writeln().fail('Aborted due to warnings.');
process.reallyExit(typeof errcode === 'number' ? errcode : 2);
}
}
};
// This gets called at the very end.
exports.report = function() {
if (exports.warncount > 0) {
log.writeln().fail('Done, but with warnings.');
} else {
log.writeln().success('Done, without errors.');
}
};