mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-09 16:13:31 +01:00
Merge pull request #90 from qeled/indev-speed
Improve Cache class performance
This commit is contained in:
@@ -1076,11 +1076,6 @@ export default class InternalClient {
|
||||
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));
|
||||
data.guilds.forEach(server => {
|
||||
self.servers.add(new Server(server, client));
|
||||
@@ -1090,11 +1085,6 @@ export default class InternalClient {
|
||||
});
|
||||
self.state = ConnectionState.READY;
|
||||
|
||||
self.users.setNormalPerformance();
|
||||
self.servers.setNormalPerformance();
|
||||
self.channels.setNormalPerformance();
|
||||
self.private_channels.setNormalPerformance();
|
||||
|
||||
client.emit("ready");
|
||||
client.emit("debug", `ready packet took ${Date.now() - startTime}ms to process`);
|
||||
client.emit("debug", `ready with ${self.servers.length} servers, ${self.channels.length} channels and ${self.users.length} users cached.`);
|
||||
|
||||
@@ -33,8 +33,6 @@ export default class Server extends Equality {
|
||||
this.afkChannelID = data.afk_channel_id;
|
||||
this.memberMap = {};
|
||||
|
||||
this.members.setHighPerformance();
|
||||
|
||||
var self = this;
|
||||
|
||||
data.roles.forEach((dataRole) => {
|
||||
@@ -71,8 +69,6 @@ export default class Server extends Equality {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
this.members.setNormalPerformance();
|
||||
}
|
||||
|
||||
detailsOf(user) {
|
||||
|
||||
@@ -4,28 +4,18 @@ export default class Cache extends Array {
|
||||
constructor(discrim, limit) {
|
||||
super();
|
||||
this.discrim = discrim || "id";
|
||||
this.discrimCache = [];
|
||||
this.highPerformance = false;
|
||||
}
|
||||
|
||||
setHighPerformance() {
|
||||
this.highPerformance = true;
|
||||
}
|
||||
|
||||
setNormalPerformance() {
|
||||
this.discrimCache = [];
|
||||
this.highPerformance = false;
|
||||
this.discrimCache = {};
|
||||
}
|
||||
|
||||
get(key, value) {
|
||||
var found = null;
|
||||
this.forEach((val, index, array) => {
|
||||
if (val[key] == value) {
|
||||
found = val;
|
||||
return;
|
||||
}
|
||||
});
|
||||
return found;
|
||||
if (key === this.discrim)
|
||||
return this.discrimCache[value] || null;
|
||||
|
||||
var l = this.length;
|
||||
for (var i = 0; i < l; i++)
|
||||
if (this[i][key] == value)
|
||||
return this[i];
|
||||
return null;
|
||||
}
|
||||
|
||||
has(object) {
|
||||
@@ -44,18 +34,16 @@ export default class Cache extends Array {
|
||||
}
|
||||
|
||||
add(data) {
|
||||
var exit = false;
|
||||
exit = ~this.discrimCache.indexOf(data[this.discrim]);
|
||||
if (exit) {
|
||||
return data;
|
||||
} else {
|
||||
if (this.limit && this.length >= this.limit) {
|
||||
this.splice(0, 1);
|
||||
}
|
||||
this.push(data);
|
||||
this.discrimCache.push(data[this.discrim]);
|
||||
return data;
|
||||
var cacheKey = this.discrim === "id" ? data.id : data[this.discrim];
|
||||
if (this.discrimCache[cacheKey]) {
|
||||
return this.discrimCache[cacheKey];
|
||||
}
|
||||
if (this.limit && this.length >= this.limit) {
|
||||
this.splice(0, 1);
|
||||
}
|
||||
this.push(data);
|
||||
this.discrimCache[cacheKey] = data;
|
||||
return data;
|
||||
}
|
||||
|
||||
update(old, data) {
|
||||
@@ -63,6 +51,7 @@ export default class Cache extends Array {
|
||||
if (item) {
|
||||
var index = this.indexOf(item);
|
||||
this[index] = data;
|
||||
this.discrimCache[data[this.discrim]] = data;
|
||||
return this[index];
|
||||
} else {
|
||||
return false;
|
||||
@@ -74,6 +63,7 @@ export default class Cache extends Array {
|
||||
}
|
||||
|
||||
remove(data) {
|
||||
delete this.discrimCache[data[this.discrim]];
|
||||
var index = this.indexOf(data);
|
||||
if (~index) {
|
||||
this.splice(index, 1);
|
||||
|
||||
Reference in New Issue
Block a user