mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-20 21:43:33 +01:00
Implemented queuing
This commit is contained in:
@@ -19,7 +19,7 @@ var WebSocket = require("ws");
|
||||
var fs = require("fs");
|
||||
|
||||
var defaultOptions = {
|
||||
queue: false
|
||||
queue: []
|
||||
};
|
||||
|
||||
var Client = (function () {
|
||||
@@ -35,7 +35,7 @@ var Client = (function () {
|
||||
further efforts will be made to connect.
|
||||
*/
|
||||
this.options = options;
|
||||
this.options.queue = this.options.queue || false;
|
||||
this.options.queue = this.options.queue || [];
|
||||
this.token = token;
|
||||
this.state = 0;
|
||||
this.websocket = null;
|
||||
@@ -605,14 +605,14 @@ var Client = (function () {
|
||||
}
|
||||
|
||||
function send(destination) {
|
||||
|
||||
if (self.options.queue) {
|
||||
if (~self.options.queue.indexOf("sendMessage")) {
|
||||
//we're QUEUEING messages, so sending them sequentially based on servers.
|
||||
if (!self.messageQueue[destination]) {
|
||||
self.messageQueue[destination] = [];
|
||||
}
|
||||
|
||||
self.messageQueue[destination].push({
|
||||
action: "sendMessage",
|
||||
content: message,
|
||||
mentions: mentions,
|
||||
then: [resolve, callback],
|
||||
@@ -1405,7 +1405,10 @@ var Client = (function () {
|
||||
done();
|
||||
return;
|
||||
}
|
||||
var msgToSend = self.messageQueue[channelID][0];
|
||||
var queuedEvent = self.messageQueue[channelID][0];
|
||||
switch (queuedEvent.action) {
|
||||
case "sendMessage":
|
||||
var msgToSend = queuedEvent;
|
||||
self._sendMessage(channelID, msgToSend.content, msgToSend.mentions).then(function (msg) {
|
||||
msgToSend.then[0](msg);
|
||||
msgToSend.then[1](null, msg);
|
||||
@@ -1417,6 +1420,11 @@ var Client = (function () {
|
||||
self.messageQueue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
default:
|
||||
done();
|
||||
break;
|
||||
}
|
||||
};
|
||||
|
||||
var done = function done() {
|
||||
|
||||
@@ -13,7 +13,7 @@ var WebSocket = require("ws");
|
||||
var fs = require("fs");
|
||||
|
||||
var defaultOptions = {
|
||||
queue: false
|
||||
queue: []
|
||||
}
|
||||
|
||||
class Client {
|
||||
@@ -25,7 +25,7 @@ class Client {
|
||||
further efforts will be made to connect.
|
||||
*/
|
||||
this.options = options;
|
||||
this.options.queue = this.options.queue || false;
|
||||
this.options.queue = this.options.queue || [];
|
||||
this.token = token;
|
||||
this.state = 0;
|
||||
this.websocket = null;
|
||||
@@ -623,14 +623,14 @@ class Client {
|
||||
}
|
||||
|
||||
function send(destination) {
|
||||
|
||||
if(self.options.queue){
|
||||
if (~self.options.queue.indexOf("sendMessage")) {
|
||||
//we're QUEUEING messages, so sending them sequentially based on servers.
|
||||
if (!self.messageQueue[destination]) {
|
||||
self.messageQueue[destination] = [];
|
||||
}
|
||||
|
||||
self.messageQueue[destination].push({
|
||||
action: "sendMessage",
|
||||
content: message,
|
||||
mentions: mentions,
|
||||
then: [resolve, callback],
|
||||
@@ -1165,7 +1165,10 @@ class Client {
|
||||
done();
|
||||
return;
|
||||
}
|
||||
var msgToSend = self.messageQueue[channelID][0];
|
||||
var queuedEvent = self.messageQueue[channelID][0];
|
||||
switch (queuedEvent.action) {
|
||||
case "sendMessage":
|
||||
var msgToSend = queuedEvent;
|
||||
self._sendMessage(channelID, msgToSend.content, msgToSend.mentions)
|
||||
.then(function (msg) {
|
||||
msgToSend.then[0](msg);
|
||||
@@ -1179,6 +1182,11 @@ class Client {
|
||||
self.messageQueue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
default:
|
||||
done();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
function done() {
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
var Discord = require("../");
|
||||
var mybot = new Discord.Client({
|
||||
queue : true
|
||||
queue : ["sendMessage"]
|
||||
});
|
||||
|
||||
var server, channel, message, sentMessage = false;
|
||||
@@ -8,14 +8,9 @@ var server, channel, message, sentMessage = false;
|
||||
mybot.on("message", function(message){
|
||||
|
||||
if(message.content === "$$$"){
|
||||
mybot.sendMessage(message.channel, "this is part 1");
|
||||
mybot.sendMessage(message.channel, "this is part 2");
|
||||
mybot.sendMessage(message.channel, "this is part 3");
|
||||
mybot.sendMessage(message.channel, "this is part 4");
|
||||
mybot.sendMessage(message.channel, "this is part 5");
|
||||
mybot.sendMessage(message.channel, "this is part 6");
|
||||
mybot.sendMessage(message.channel, "this is part 7");
|
||||
mybot.sendMessage(message.channel, "this is part 8");
|
||||
for(var x=1;x<=10;x++){
|
||||
mybot.sendMessage(message.channel, "this is message " + x);
|
||||
}
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user