3
0
mirror of https://github.com/reality/dbot.git synced 2025-01-25 19:44:22 +01:00

loaded strings and usage from the modules themselves in reloadModules. some other smaller changes. fixed the syntax of the usage json. careful though this dbot init may delete your database.

This commit is contained in:
Luke Slater 2012-12-11 20:06:29 +00:00
parent cd56a8a197
commit cae8a1fc7d
5 changed files with 73 additions and 25 deletions

View File

@ -1,4 +1,4 @@
{ {
'~js': '~js [command]', "~js": "~js [command]",
'~ajs': '~ajs [command]' "~ajs": '~ajs [command]"
} }

View File

@ -1,7 +1,7 @@
{ {
'~newpoll': '~newpoll [pollname] options=[each,poll,option] [Poll Description]', "~newpoll": "~newpoll [pollname] options=[each,poll,option] [Poll Description]",
'~addoption': '~addoption [pollname] [newoption]', "~addoption": "~addoption [pollname] [newoption]",
'~rmoption': '~rmoption [pollname] [optiontoremove]', "~rmoption": "~rmoption [pollname] [optiontoremove]",
'~vote': '~vote [pollname] [option]', "~vote": "~vote [pollname] [option]",
'~pdesc': '~pdesc [pollname]' "~pdesc": "~pdesc [pollname]"
} }

View File

@ -1,7 +1,7 @@
{ {
'~q': '~q [category]', "~q": "~q [category]",
'~qsearch': '~qsearch [category]=[search]', "~qsearch": "~qsearch [category]=[search]",
'~rm': '~rm [category]=[quote to delete]', "~rm": "~rm [category]=[quote to delete]",
'~rmlast': '~rmlast [category], "~rmlast": "~rmlast [category]",
'~qadd': '~qadd [category]=[content]' "~qadd": "~qadd [category]=[content]"
} }

View File

@ -1,3 +1,3 @@
{ {
'~report': '~report [#channel] [username] [reason for reporting]' "~report": "~report [#channel] [username] [reason for reporting]"
} }

72
run.js
View File

@ -10,11 +10,17 @@ var DBot = function(timers) {
var rawDB; var rawDB;
try { try {
var rawDB = fs.readFileSync('db.json', 'utf-8'); var rawDB = fs.readFileSync('db.json', 'utf-8');
} catch (e) { } catch(err) {
this.db = {}; // If no db file, make empty one this.db = {}; // If no db file, make empty one
} }
if(!this.db) { // If it wasn't empty
this.db = JSON.parse(rawDB); try {
if(!this.db) { // If it wasn't empty
this.db = JSON.parse(rawDB);
}
} catch(err) {
console.log('Probably a syntax error in db.json: ' + err);
this.db = {};
} }
// Repair any deficiencies in the DB; if this is a new DB, that's everything // Repair any deficiencies in the DB; if this is a new DB, that's everything
@ -47,9 +53,15 @@ var DBot = function(timers) {
} }
// Load Strings file // Load Strings file
this.strings = JSON.parse(fs.readFileSync('strings.json', 'utf-8')); try {
this.strings = JSON.parse(fs.readFileSync('strings.json', 'utf-8'));
} catch(err) {
console.log('Probably a syntax error: ' + err);
this.strings = {};
}
// Initialise run-time resources // Initialise run-time resources
this.usage = {};
this.sessionData = {}; this.sessionData = {};
this.timers = timers.create(); this.timers = timers.create();
@ -101,12 +113,19 @@ DBot.prototype.say = function(server, channel, message) {
// Format given stored string in config language // Format given stored string in config language
DBot.prototype.t = function(string, formatData) { DBot.prototype.t = function(string, formatData) {
var lang = this.language; var formattedString;
if(!this.strings[string].hasOwnProperty(lang)) { if(this.strings.hasOwnProperty(string)) {
lang = "english"; var lang = this.language;
} if(!this.strings[string].hasOwnProperty(lang)) {
lang = "english";
}
return this.strings[string][lang].format(formatData); formattedString = this.strings[string][lang].format(formatData);
} else {
formattedString = 'String not found. Something has gone screwy. Maybe.';
}
return formattedString;
}; };
/*DBot.prototype.act = function(channel, data) { /*DBot.prototype.act = function(channel, data) {
@ -132,6 +151,8 @@ DBot.prototype.reloadModules = function() {
this.modules = []; this.modules = [];
this.commands = {}; this.commands = {};
this.commandMap = {}; // Map of which commands belong to which modules this.commandMap = {}; // Map of which commands belong to which modules
this.strings = {};
this.usage = {};
this.timers.clearTimers(); this.timers.clearTimers();
this.save(); this.save();
@ -149,11 +170,13 @@ DBot.prototype.reloadModules = function() {
this.instance.removeListeners(); this.instance.removeListeners();
this.moduleNames.each(function(name) { this.moduleNames.each(function(name) {
var cacheKey = require.resolve('./modules/' + name); var moduleDir = './modules/' + name + '/';
var cacheKey = require.resolve(moduleDir + name);
delete require.cache[cacheKey]; delete require.cache[cacheKey];
try { try {
var rawModule = require('./modules/' + name); // Load the module itself
var rawModule = require(moduleDir + name);
var module = rawModule.fetch(this); var module = rawModule.fetch(this);
this.rawModules.push(rawModule); this.rawModules.push(rawModule);
@ -165,6 +188,7 @@ DBot.prototype.reloadModules = function() {
module.onLoad(); module.onLoad();
} }
// Load module commands
if(module.commands) { if(module.commands) {
var newCommands = module.commands; var newCommands = module.commands;
for(key in newCommands) { for(key in newCommands) {
@ -175,10 +199,34 @@ DBot.prototype.reloadModules = function() {
} }
} }
// Load the module usage data
var usage = JSON.parse(fs.readFileSync(moduleDir + 'usage.json', 'utf-8'));
for(key in usage) {
if(usage.hasOwnProperty(key)) {
if(this.usage.hasOwnProperty(key)) {
console.log('Usage key clash for ' + key + ' in ' + name);
} else {
this.usage[key] = usage[key];
}
}
}
// Load the module string data
var strings = JSON.parse(fs.readFileSync(moduleDir + 'strings.json', 'utf-8'));
for(key in strings) {
if(strings.hasOwnProperty(key)) {
if(this.strings.hasOwnProperty(key)) {
console.log('Strings key clash for ' + key + ' in ' + name);
} else {
this.strings[key] = strings[key];
}
}
}
this.modules.push(module); this.modules.push(module);
} catch(err) { } catch(err) {
console.log(this.t('module_load_error', {'moduleName': name})); console.log(this.t('module_load_error', {'moduleName': name}));
console.log(err); console.log('MODULE ERROR: ' + name + ' ' + err);
} }
}.bind(this)); }.bind(this));
}; };