Framework for reloading modules when it's possible... Sigh...

This commit is contained in:
Luke Slater 2011-08-23 00:04:40 +01:00
parent d266f71c0e
commit df61c97eb2
2 changed files with 32 additions and 15 deletions

View File

@ -1,3 +1,5 @@
var fs = require('fs');
var adminCommands = function(dbot) { var adminCommands = function(dbot) {
var dbot = dbot; var dbot = dbot;
@ -15,6 +17,7 @@ var adminCommands = function(dbot) {
dbot.say(dbot.admin, 'Reloading DB.'); dbot.say(dbot.admin, 'Reloading DB.');
try { try {
dbot.db = JSON.parse(fs.readFileSync('db.json', 'utf-8')); dbot.db = JSON.parse(fs.readFileSync('db.json', 'utf-8'));
dbot.reloadModules();
} catch(err) { } catch(err) {
dbot.say(dbot.admin, 'DB reload failed.'); dbot.say(dbot.admin, 'DB reload failed.');
} finally { } finally {

44
run.js
View File

@ -1,13 +1,9 @@
require('./snippets'); require('./snippets');
var fs = require('fs'); var fs = require('fs');
var jsbot = require('./jsbot'); var jsbot = require('./jsbot');
var quote = require('./modules/quotes'); //var quote = require('./modules/quotes');
var userCommands = require('./modules/user');
var adminCommands = require('./modules/admin'); var modules = ['user', 'admin', 'puns', 'kick', 'reality', 'karma'];
var puns = require('./modules/puns');
var kick = require('./modules/kick');
var reality = require('./modules/reality');
var karma = require('./modules/karma');
var dbot = Class.create({ var dbot = Class.create({
initialize: function(dModules, quotes) { initialize: function(dModules, quotes) {
@ -15,20 +11,19 @@ var dbot = Class.create({
this.waitingForKarma = false; this.waitingForKarma = false;
this.name = 'depressionbot'; this.name = 'depressionbot';
this.db = JSON.parse(fs.readFileSync('db.json', 'utf-8')); this.db = JSON.parse(fs.readFileSync('db.json', 'utf-8'));
this.quotes = quotes.fetch(this); this.quotes = require(quotes).fetch(this);
this.instance = jsbot.createJSBot(this.name, 'elara.ivixor.net', 6667, this, function() { this.instance = jsbot.createJSBot(this.name, 'elara.ivixor.net', 6667, this, function() {
this.instance.join('#realitest'); this.instance.join('#realitest');
this.instance.join('#42'); this.instance.join('#42');
this.instance.join('#fail');
this.instance.join('#itonlygetsworse'); this.instance.join('#itonlygetsworse');
}.bind(this)); }.bind(this));
this.modules = dModules.collect(function(n) { this.moduleNames = dModules;
var module = n.fetch(this); this.rawModules = [];
this.instance.addListener(module.on, module.listener); this.modules = [];
return n.fetch(this);
}.bind(this)); this.reloadModules();
this.instance.connect(); this.instance.connect();
}, },
@ -39,7 +34,26 @@ var dbot = Class.create({
save: function() { save: function() {
fs.writeFile('db.json', JSON.stringify(this.db, null, ' ')); fs.writeFile('db.json', JSON.stringify(this.db, null, ' '));
},
reloadModules: function() {
require.cache = {}; // Stupid bloody prototype.js
this.rawModules = [];
this.modules = [];
this.moduleNames.each(function(name) {
this.rawModules.push(require('./modules/' + name));
}.bind(this));
this.instance.removeListeners();
this.modules = this.rawModules.collect(function(rawModule) {
var module = rawModule.fetch(this);
this.instance.addListener(module.on, module.listener);
return module;
}.bind(this));
} }
}); });
new dbot([userCommands, adminCommands, puns, kick, reality, karma], quote); new dbot(modules, './modules/quotes');