mirror of
https://github.com/reality/dbot.git
synced 2024-11-27 06:19:24 +01:00
Framework for reloading modules when it's possible... Sigh...
This commit is contained in:
parent
d266f71c0e
commit
df61c97eb2
@ -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
44
run.js
@ -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,21 +11,20 @@ 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');
|
||||||
|
Loading…
Reference in New Issue
Block a user