diff options
| author | Unknown <jtsshieh@outlook.com> | 2018-03-07 21:35:39 -0500 |
|---|---|---|
| committer | Unknown <jtsshieh@outlook.com> | 2018-03-07 21:35:39 -0500 |
| commit | 255d07c718f5fab9ec28741abf4cc41fc2b52b13 (patch) | |
| tree | 21562584bcd9e1e309a5c37619f1537379d58586 /test.js | |
| parent | acd851a680e9df85d3d6fffc03e68b870e95f475 (diff) | |
| download | PokeBot-255d07c718f5fab9ec28741abf4cc41fc2b52b13.tar.gz PokeBot-255d07c718f5fab9ec28741abf4cc41fc2b52b13.tar.bz2 PokeBot-255d07c718f5fab9ec28741abf4cc41fc2b52b13.zip | |
getting ready for ci
Diffstat (limited to 'test.js')
| -rw-r--r-- | test.js | 72 |
1 files changed, 72 insertions, 0 deletions
@@ -0,0 +1,72 @@ +const Discord = require('discord.js'); +const bot = new Discord.Client(); +const fs = require('fs'); + +bot.commands = new Discord.Collection(); +bot.aliases = new Discord.Collection(); +bot.categories = new Discord.Collection(); +bot.queue = new Discord.Collection(); +bot.plugins = { music : require('./Plugins/Music.js') }; +cmdLoader(); + +async function cmdLoader() { + const categories = await fs.readdirSync('./commands'); + console.log(`Loading ${categories.length} categories(s) into memory\n`); + categories.forEach(x => { + loadGroup(x); + }); +} +async function loadGroup(name) { + const files = await fs.readdirSync(`./commands/${name}`); + + console.log(`Loading the category '${name}' into memory with a total of ${files.length} command(s)`); + + bot.commands.set(name, new Map()); + bot.aliases.set(name, new Map()); + + const commands = []; + files.forEach(x => { + loadCmd(name, x); + commands.push(x.split('.')[0]); + }); + + bot.categories.set(name, commands); + console.log(`The category ${name} has been loaded.\n`); +} + +async function loadCmd(category, cmd) { + try { + console.log(`Loading the Command ${cmd.split('.')[0]}`); + const command = require(`./commands/${category}/${cmd}`); + bot.commands.get(category).set(command.help.name, command); + command.conf.aliases.forEach(alias => { + console.log(`Loading the alias ${alias} for the command ${command.help.name}`); + bot.aliases.get(category).set(alias, command.help.name); + }); + } + catch (err) { + console.log(`An error has occured trying to load the command '${cmd.split('.')[0]}'`); + console.log(err.stack); + } +} + + +fs.readdir('./events', (err, files) => { + if (err) console.error(err); + console.log(`Attempting to load a total of ${files.length} events into the memory.`); + files.forEach(file => { + try { + const eventName = file.split('.')[0]; + const event = require(`./events/${file}`); + console.log(`Attempting to load the event "${eventName}".`); + bot.on(eventName, event.bind(null, bot)); + delete require.cache[require.resolve(`./events/${file}`)]; + } + catch (err) { + console.log('An error has occured trying to load a event. Here is the error.'); + console.log(err.stack); + } + }); + console.log('Event Loading complete!'); + console.log('\n'); +}); |
