refactor(Util): make class extend null (#6000)

This commit is contained in:
Antonio Román
2021-07-03 14:25:35 +02:00
committed by GitHub
parent e7ad2fe207
commit 2446ff5251
5 changed files with 12 additions and 24 deletions

View File

@@ -11,11 +11,7 @@ const Invite = require('../structures/Invite');
* The DataResolver identifies different objects and tries to resolve a specific piece of information from them.
* @private
*/
class DataResolver {
constructor() {
throw new Error(`The ${this.constructor.name} class may not be instantiated.`);
}
class DataResolver extends null {
/**
* Data that can be resolved to give an invite code. This can be:
* * An invite code

View File

@@ -9,11 +9,7 @@ let INCREMENT = 0;
/**
* A container for useful snowflake-related methods.
*/
class SnowflakeUtil {
constructor() {
throw new Error(`The ${this.constructor.name} class may not be instantiated.`);
}
class SnowflakeUtil extends null {
/**
* A Twitter snowflake, except the epoch is 2015-01-01T00:00:00.000Z
* ```

View File

@@ -31,11 +31,7 @@
/**
* Allows for the extension of built-in Discord.js structures that are instantiated by {@link BaseManager Managers}.
*/
class Structures {
constructor() {
throw new Error(`The ${this.constructor.name} class may not be instantiated.`);
}
class Structures extends null {
/**
* Retrieves a structure class.
* @param {string} structure Name of the structure to retrieve

View File

@@ -10,11 +10,7 @@ const isObject = d => typeof d === 'object' && d !== null;
/**
* Contains various general-purpose utility methods.
*/
class Util {
constructor() {
throw new Error(`The ${this.constructor.name} class may not be instantiated.`);
}
class Util extends null {
/**
* Flatten an object. Any properties that are collections will get converted to an array of keys.
* @param {Object} obj The object to flatten.

12
typings/index.d.ts vendored
View File

@@ -812,7 +812,8 @@ declare module 'discord.js' {
PremiumTiers: typeof PremiumTiers;
};
export class DataResolver {
export class DataResolver extends null {
private constructor();
public static resolveBase64(data: Base64Resolvable): string;
public static resolveCode(data: string, regx: RegExp): string;
public static resolveFile(resource: BufferResolvable | Stream): Promise<Buffer | Stream>;
@@ -1855,7 +1856,8 @@ declare module 'discord.js' {
public once(event: 'shardCreate', listener: (shard: Shard) => Awaited<void>): this;
}
export class SnowflakeUtil {
export class SnowflakeUtil extends null {
private constructor();
public static deconstruct(snowflake: Snowflake): DeconstructedSnowflake;
public static generate(timestamp?: number | Date): Snowflake;
public static readonly EPOCH: number;
@@ -1892,7 +1894,8 @@ declare module 'discord.js' {
public type: 'store';
}
export class Structures {
export class Structures extends null {
private constructor();
public static get<K extends keyof Extendable>(structure: K): Extendable[K];
public static get(structure: string): (...args: any[]) => void;
public static extend<K extends keyof Extendable, T extends Extendable[K]>(
@@ -2052,7 +2055,8 @@ declare module 'discord.js' {
public static resolve(bit?: BitFieldResolvable<UserFlagsString, number>): number;
}
export class Util {
export class Util extends null {
private constructor();
public static basename(path: string, ext?: string): string;
public static binaryToID(num: string): Snowflake;
public static cleanContent(str: string, channel: Channel): string;