mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-15 19:13:31 +01:00
basic speed improvement - eats more memory
This commit is contained in:
@@ -1184,6 +1184,15 @@ var InternalClient = (function () {
|
|||||||
|
|
||||||
case _Constants.PacketType.READY:
|
case _Constants.PacketType.READY:
|
||||||
var startTime = Date.now();
|
var startTime = Date.now();
|
||||||
|
self.intervals.kai = setInterval(function () {
|
||||||
|
return self.sendWS({ op: 1, d: Date.now() });
|
||||||
|
}, data.heartbeat_interval);
|
||||||
|
|
||||||
|
self.users.setHighPerformance();
|
||||||
|
self.servers.setHighPerformance();
|
||||||
|
self.channels.setHighPerformance();
|
||||||
|
self.private_channels.setHighPerformance();
|
||||||
|
|
||||||
self.user = self.users.add(new _StructuresUser2["default"](data.user, client));
|
self.user = self.users.add(new _StructuresUser2["default"](data.user, client));
|
||||||
data.guilds.forEach(function (server) {
|
data.guilds.forEach(function (server) {
|
||||||
self.servers.add(new _StructuresServer2["default"](server, client));
|
self.servers.add(new _StructuresServer2["default"](server, client));
|
||||||
@@ -1193,9 +1202,10 @@ var InternalClient = (function () {
|
|||||||
});
|
});
|
||||||
self.state = _ConnectionState2["default"].READY;
|
self.state = _ConnectionState2["default"].READY;
|
||||||
|
|
||||||
self.intervals.kai = setInterval(function () {
|
self.users.setNormalPerformance();
|
||||||
return self.sendWS({ op: 1, d: Date.now() });
|
self.servers.setNormalPerformance();
|
||||||
}, data.heartbeat_interval);
|
self.channels.setNormalPerformance();
|
||||||
|
self.private_channels.setNormalPerformance();
|
||||||
|
|
||||||
client.emit("ready");
|
client.emit("ready");
|
||||||
client.emit("debug", "ready packet took " + (Date.now() - startTime) + "ms to process");
|
client.emit("debug", "ready packet took " + (Date.now() - startTime) + "ms to process");
|
||||||
|
|||||||
@@ -65,6 +65,8 @@ var Server = (function (_Equality) {
|
|||||||
this.afkChannelID = data.afk_channel_id;
|
this.afkChannelID = data.afk_channel_id;
|
||||||
this.memberMap = {};
|
this.memberMap = {};
|
||||||
|
|
||||||
|
this.members.setHighPerformance();
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
data.roles.forEach(function (dataRole) {
|
data.roles.forEach(function (dataRole) {
|
||||||
@@ -116,6 +118,8 @@ var Server = (function (_Equality) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.members.setNormalPerformance();
|
||||||
}
|
}
|
||||||
|
|
||||||
Server.prototype.detailsOf = function detailsOf(user) {
|
Server.prototype.detailsOf = function detailsOf(user) {
|
||||||
|
|||||||
@@ -14,12 +14,23 @@ var Cache = (function (_Array) {
|
|||||||
|
|
||||||
_Array.call(this);
|
_Array.call(this);
|
||||||
this.discrim = discrim || "id";
|
this.discrim = discrim || "id";
|
||||||
|
this.discrimCache = [];
|
||||||
|
this.highPerformance = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Cache.prototype.setHighPerformance = function setHighPerformance() {
|
||||||
|
this.highPerformance = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
Cache.prototype.setNormalPerformance = function setNormalPerformance() {
|
||||||
|
this.discrimCache = [];
|
||||||
|
this.highPerformance = false;
|
||||||
|
};
|
||||||
|
|
||||||
Cache.prototype.get = function get(key, value) {
|
Cache.prototype.get = function get(key, value) {
|
||||||
var found = null;
|
var found = null;
|
||||||
this.forEach(function (val, index, array) {
|
this.forEach(function (val, index, array) {
|
||||||
if (val.hasOwnProperty(key) && val[key] == value) {
|
if (val[key] == value) {
|
||||||
found = val;
|
found = val;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -44,32 +55,15 @@ var Cache = (function (_Array) {
|
|||||||
|
|
||||||
Cache.prototype.add = function add(data) {
|
Cache.prototype.add = function add(data) {
|
||||||
var exit = false;
|
var exit = false;
|
||||||
for (var _iterator = this, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
|
exit = ~this.discrimCache.indexOf(data[this.discrim]);
|
||||||
var _ref;
|
|
||||||
|
|
||||||
if (_isArray) {
|
|
||||||
if (_i >= _iterator.length) break;
|
|
||||||
_ref = _iterator[_i++];
|
|
||||||
} else {
|
|
||||||
_i = _iterator.next();
|
|
||||||
if (_i.done) break;
|
|
||||||
_ref = _i.value;
|
|
||||||
}
|
|
||||||
|
|
||||||
var item = _ref;
|
|
||||||
|
|
||||||
if (item[this.discrim] === data[this.discrim]) {
|
|
||||||
exit = item;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (exit) {
|
if (exit) {
|
||||||
return exit;
|
return data;
|
||||||
} else {
|
} else {
|
||||||
if (this.limit && this.length >= this.limit) {
|
if (this.limit && this.length >= this.limit) {
|
||||||
this.splice(0, 1);
|
this.splice(0, 1);
|
||||||
}
|
}
|
||||||
this.push(data);
|
this.push(data);
|
||||||
|
this.discrimCache.push(data[this.discrim]);
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1074,6 +1074,13 @@ export default class InternalClient {
|
|||||||
|
|
||||||
case PacketType.READY:
|
case PacketType.READY:
|
||||||
var startTime = Date.now();
|
var startTime = Date.now();
|
||||||
|
self.intervals.kai = setInterval(() => self.sendWS({ op: 1, d: Date.now() }), data.heartbeat_interval);
|
||||||
|
|
||||||
|
self.users.setHighPerformance();
|
||||||
|
self.servers.setHighPerformance();
|
||||||
|
self.channels.setHighPerformance();
|
||||||
|
self.private_channels.setHighPerformance();
|
||||||
|
|
||||||
self.user = self.users.add(new User(data.user, client));
|
self.user = self.users.add(new User(data.user, client));
|
||||||
data.guilds.forEach(server => {
|
data.guilds.forEach(server => {
|
||||||
self.servers.add(new Server(server, client));
|
self.servers.add(new Server(server, client));
|
||||||
@@ -1083,7 +1090,10 @@ export default class InternalClient {
|
|||||||
});
|
});
|
||||||
self.state = ConnectionState.READY;
|
self.state = ConnectionState.READY;
|
||||||
|
|
||||||
self.intervals.kai = setInterval(() => self.sendWS({ op: 1, d: Date.now() }), data.heartbeat_interval);
|
self.users.setNormalPerformance();
|
||||||
|
self.servers.setNormalPerformance();
|
||||||
|
self.channels.setNormalPerformance();
|
||||||
|
self.private_channels.setNormalPerformance();
|
||||||
|
|
||||||
client.emit("ready");
|
client.emit("ready");
|
||||||
client.emit("debug", `ready packet took ${Date.now() - startTime}ms to process`);
|
client.emit("debug", `ready packet took ${Date.now() - startTime}ms to process`);
|
||||||
|
|||||||
@@ -33,6 +33,8 @@ export default class Server extends Equality {
|
|||||||
this.afkChannelID = data.afk_channel_id;
|
this.afkChannelID = data.afk_channel_id;
|
||||||
this.memberMap = {};
|
this.memberMap = {};
|
||||||
|
|
||||||
|
this.members.setHighPerformance();
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
data.roles.forEach((dataRole) => {
|
data.roles.forEach((dataRole) => {
|
||||||
@@ -69,6 +71,8 @@ export default class Server extends Equality {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.members.setNormalPerformance();
|
||||||
}
|
}
|
||||||
|
|
||||||
detailsOf(user) {
|
detailsOf(user) {
|
||||||
|
|||||||
@@ -4,12 +4,23 @@ export default class Cache extends Array {
|
|||||||
constructor(discrim, limit) {
|
constructor(discrim, limit) {
|
||||||
super();
|
super();
|
||||||
this.discrim = discrim || "id";
|
this.discrim = discrim || "id";
|
||||||
|
this.discrimCache = [];
|
||||||
|
this.highPerformance = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
setHighPerformance() {
|
||||||
|
this.highPerformance = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
setNormalPerformance() {
|
||||||
|
this.discrimCache = [];
|
||||||
|
this.highPerformance = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
get(key, value) {
|
get(key, value) {
|
||||||
var found = null;
|
var found = null;
|
||||||
this.forEach((val, index, array) => {
|
this.forEach((val, index, array) => {
|
||||||
if (val.hasOwnProperty(key) && val[key] == value) {
|
if (val[key] == value) {
|
||||||
found = val;
|
found = val;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -34,19 +45,15 @@ export default class Cache extends Array {
|
|||||||
|
|
||||||
add(data) {
|
add(data) {
|
||||||
var exit = false;
|
var exit = false;
|
||||||
for (var item of this) {
|
exit = ~this.discrimCache.indexOf(data[this.discrim]);
|
||||||
if (item[this.discrim] === data[this.discrim]) {
|
|
||||||
exit = item;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (exit) {
|
if (exit) {
|
||||||
return exit;
|
return data;
|
||||||
} else {
|
} else {
|
||||||
if (this.limit && this.length >= this.limit) {
|
if (this.limit && this.length >= this.limit) {
|
||||||
this.splice(0, 1);
|
this.splice(0, 1);
|
||||||
}
|
}
|
||||||
this.push(data);
|
this.push(data);
|
||||||
|
this.discrimCache.push(data[this.discrim]);
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user