3
0
mirror of https://github.com/reality/dbot.git synced 2025-01-23 10:34:31 +01:00

file existence checking for module property files and config.json [#163]

This commit is contained in:
reality 2013-01-24 21:35:00 +00:00
parent 2e620fea6f
commit 6f73fde865
2 changed files with 24 additions and 12 deletions

@ -1 +1 @@
Subproject commit 42ce44222f4ef4311cae5648438b872227c9b3bf
Subproject commit 33886df41d84c160270b581f072e710e4c9d00e8

34
run.js
View File

@ -5,7 +5,9 @@ var fs = require('fs'),
require('./snippets');
var DBot = function(timers) {
// Load DB
/*** Load the DB ***/
if(fs.existsSync('db.json')) {
try {
this.db = JSON.parse(fs.readFileSync('db.json', 'utf-8'));
@ -21,12 +23,18 @@ var DBot = function(timers) {
this.db.config = {};
}
// Load config
/*** Load the Config ***/
if(!fs.existsSync('config.json')) {
console.log('Error: config.json file does not exist. Stopping');
process.exit();
}
this.config = _.clone(this.db.config);
try {
_.defaults(this.config, JSON.parse(fs.readFileSync('config.json', 'utf-8')));
} catch(err) {
console.log('Config file is invalid. Stopping');
console.log('Config file is invalid. Stopping: ' + err);
process.exit();
}
@ -40,7 +48,8 @@ var DBot = function(timers) {
// Load missing config directives from sample file
_.defaults(this.config, defaultConfig);
// Load Strings file
/*** Load main strings ***/
try {
this.strings = JSON.parse(fs.readFileSync('strings.json', 'utf-8'));
} catch(err) {
@ -216,13 +225,16 @@ DBot.prototype.reloadModules = function() {
// Load the module data
_.each([ 'commands', 'pages', 'api' ], function(property) {
var propertyObj = {};
try {
var propertyKey = require.resolve(moduleDir + property);
if(propertyKey) delete require.cache[propertyKey];
propertyObj = require(moduleDir + property).fetch(this);
} catch(err) {
console.log('Module error (' + module.name + ') in ' + property + ': ' + err);
}
if(fs.existsSync(moduleDir + property + '.js')) {
try {
var propertyKey = require.resolve(moduleDir + property);
if(propertyKey) delete require.cache[propertyKey];
propertyObj = require(moduleDir + property).fetch(this);
} catch(err) {
console.log('Module error (' + module.name + ') in ' + property + ': ' + err);
}
}
if(!_.has(module, property)) module[property] = {};
_.extend(module[property], propertyObj);