mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-17 03:53:29 +01:00
types(Options): add types for cacheWithLimits (#6095)
This commit is contained in:
@@ -22,7 +22,7 @@
|
|||||||
* @typedef {Function} CacheFactory
|
* @typedef {Function} CacheFactory
|
||||||
* @param {Function} manager The manager class the cache is being requested from.
|
* @param {Function} manager The manager class the cache is being requested from.
|
||||||
* @param {Function} holds The class that the cache will hold.
|
* @param {Function} holds The class that the cache will hold.
|
||||||
* @returns {Collection} Cache instance that follows collection interface.
|
* @returns {Collection} A Collection used to store the cache of the manager.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -34,8 +34,7 @@
|
|||||||
* @property {number} [shardCount=1] The total amount of shards used by all processes of this bot
|
* @property {number} [shardCount=1] The total amount of shards used by all processes of this bot
|
||||||
* (e.g. recommended shard count, shard count of the ShardingManager)
|
* (e.g. recommended shard count, shard count of the ShardingManager)
|
||||||
* @property {CacheFactory} [makeCache] Function to create a cache.
|
* @property {CacheFactory} [makeCache] Function to create a cache.
|
||||||
* (-1 or Infinity for unlimited - don't do this without message sweeping, otherwise memory usage will climb
|
* You can use your own function, or the {@link Options} class to customize the Collection used for the cache.
|
||||||
* indefinitely)
|
|
||||||
* @property {number} [messageCacheLifetime=0] How long a message should stay in the cache until it is considered
|
* @property {number} [messageCacheLifetime=0] How long a message should stay in the cache until it is considered
|
||||||
* sweepable (in seconds, 0 for forever)
|
* sweepable (in seconds, 0 for forever)
|
||||||
* @property {number} [messageSweepInterval=0] How frequently to remove messages from the cache that are older than
|
* @property {number} [messageSweepInterval=0] How frequently to remove messages from the cache that are older than
|
||||||
|
|||||||
33
typings/index.d.ts
vendored
33
typings/index.d.ts
vendored
@@ -366,7 +366,7 @@ export class ClientUser extends User {
|
|||||||
export class Options extends null {
|
export class Options extends null {
|
||||||
private constructor();
|
private constructor();
|
||||||
public static createDefaultOptions(): ClientOptions;
|
public static createDefaultOptions(): ClientOptions;
|
||||||
public static cacheWithLimits(limits?: Record<string, number>): CacheFactory;
|
public static cacheWithLimits(limits?: CacheWithLimitOptions): CacheFactory;
|
||||||
public static cacheEverything(): CacheFactory;
|
public static cacheEverything(): CacheFactory;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2739,7 +2739,36 @@ export type BitFieldResolvable<T extends string, N extends number | bigint> =
|
|||||||
|
|
||||||
export type BufferResolvable = Buffer | string;
|
export type BufferResolvable = Buffer | string;
|
||||||
|
|
||||||
export type CacheFactory = <T>(manager: { name: string }, holds: { name: string }) => Collection<Snowflake, T>;
|
export type CachedManagerTypes = keyof CacheFactoryArgs;
|
||||||
|
|
||||||
|
export type CacheFactory = <T extends CachedManagerTypes>(
|
||||||
|
...args: CacheFactoryArgs[T]
|
||||||
|
) => Collection<Snowflake, CacheFactoryArgs[T][1]>;
|
||||||
|
|
||||||
|
export interface CacheFactoryArgs {
|
||||||
|
ApplicationCommandManager: [manager: typeof ApplicationCommandManager, holds: typeof ApplicationCommand];
|
||||||
|
BaseGuildEmojiManager: [manager: typeof BaseGuildEmojiManager, holds: typeof GuildEmoji];
|
||||||
|
ChannelManager: [manager: typeof ChannelManager, holds: typeof Channel];
|
||||||
|
GuildChannelManager: [manager: typeof GuildChannelManager, holds: typeof GuildChannel];
|
||||||
|
GuildManager: [manager: typeof GuildManager, holds: typeof Guild];
|
||||||
|
GuildMemberManager: [manager: typeof GuildMemberManager, holds: typeof GuildMember];
|
||||||
|
GuildBanManager: [manager: typeof GuildBanManager, holds: typeof GuildBan];
|
||||||
|
MessageManager: [manager: typeof MessageManager, holds: typeof Message];
|
||||||
|
PermissionOverwriteManager: [manager: typeof PermissionOverwriteManager, holds: typeof PermissionOverwrites];
|
||||||
|
PresenceManager: [manager: typeof PresenceManager, holds: typeof Presence];
|
||||||
|
ReactionManager: [manager: typeof ReactionManager, holds: typeof MessageReaction];
|
||||||
|
ReactionUserManager: [manager: typeof ReactionUserManager, holds: typeof User];
|
||||||
|
RoleManager: [manager: typeof RoleManager, holds: typeof Role];
|
||||||
|
StageInstanceManager: [manager: typeof StageInstanceManager, holds: typeof StageInstance];
|
||||||
|
ThreadManager: [manager: typeof ThreadManager, holds: typeof ThreadChannel];
|
||||||
|
ThreadMemberManager: [manager: typeof ThreadMemberManager, holds: typeof ThreadMember];
|
||||||
|
UserManager: [manager: typeof UserManager, holds: typeof User];
|
||||||
|
VoiceStateManager: [manager: typeof VoiceStateManager, holds: typeof VoiceState];
|
||||||
|
}
|
||||||
|
|
||||||
|
export type CacheWithLimitOptions = {
|
||||||
|
[K in CachedManagerTypes]?: number;
|
||||||
|
};
|
||||||
|
|
||||||
export interface ChannelCreationOverwrites {
|
export interface ChannelCreationOverwrites {
|
||||||
allow?: PermissionResolvable;
|
allow?: PermissionResolvable;
|
||||||
|
|||||||
@@ -53,6 +53,8 @@ const client: Client = new Client({
|
|||||||
intents: Intents.FLAGS.GUILDS,
|
intents: Intents.FLAGS.GUILDS,
|
||||||
makeCache: Options.cacheWithLimits({
|
makeCache: Options.cacheWithLimits({
|
||||||
MessageManager: 200,
|
MessageManager: 200,
|
||||||
|
// @ts-expect-error
|
||||||
|
Message: 100,
|
||||||
}),
|
}),
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user