1465 lines
		
	
	
		
			51 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			1465 lines
		
	
	
		
			51 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| export class VFile {
 | ||
|     /**
 | ||
|      * Create a new virtual file.
 | ||
|      *
 | ||
|      * `options` is treated as:
 | ||
|      *
 | ||
|      * *   `string` or `Uint8Array` — `{value: options}`
 | ||
|      * *   `URL` — `{path: options}`
 | ||
|      * *   `VFile` — shallow copies its data over to the new file
 | ||
|      * *   `object` — all fields are shallow copied over to the new file
 | ||
|      *
 | ||
|      * Path related fields are set in the following order (least specific to
 | ||
|      * most specific): `history`, `path`, `basename`, `stem`, `extname`,
 | ||
|      * `dirname`.
 | ||
|      *
 | ||
|      * You cannot set `dirname` or `extname` without setting either `history`,
 | ||
|      * `path`, `basename`, or `stem` too.
 | ||
|      *
 | ||
|      * @param {Compatible | null | undefined} [value]
 | ||
|      *   File value.
 | ||
|      * @returns
 | ||
|      *   New instance.
 | ||
|      */
 | ||
|     constructor(value?: Compatible | null | undefined);
 | ||
|     /**
 | ||
|      * Base of `path` (default: `process.cwd()` or `'/'` in browsers).
 | ||
|      *
 | ||
|      * @type {string}
 | ||
|      */
 | ||
|     cwd: string;
 | ||
|     /**
 | ||
|      * Place to store custom info (default: `{}`).
 | ||
|      *
 | ||
|      * It’s OK to store custom data directly on the file but moving it to
 | ||
|      * `data` is recommended.
 | ||
|      *
 | ||
|      * @type {Data}
 | ||
|      */
 | ||
|     data: Data;
 | ||
|     /**
 | ||
|      * List of file paths the file moved between.
 | ||
|      *
 | ||
|      * The first is the original path and the last is the current path.
 | ||
|      *
 | ||
|      * @type {Array<string>}
 | ||
|      */
 | ||
|     history: Array<string>;
 | ||
|     /**
 | ||
|      * List of messages associated with the file.
 | ||
|      *
 | ||
|      * @type {Array<VFileMessage>}
 | ||
|      */
 | ||
|     messages: Array<VFileMessage>;
 | ||
|     /**
 | ||
|      * Raw value.
 | ||
|      *
 | ||
|      * @type {Value}
 | ||
|      */
 | ||
|     value: Value;
 | ||
|     /**
 | ||
|      * Source map.
 | ||
|      *
 | ||
|      * This type is equivalent to the `RawSourceMap` type from the `source-map`
 | ||
|      * module.
 | ||
|      *
 | ||
|      * @type {Map | null | undefined}
 | ||
|      */
 | ||
|     map: Map | null | undefined;
 | ||
|     /**
 | ||
|      * Custom, non-string, compiled, representation.
 | ||
|      *
 | ||
|      * This is used by unified to store non-string results.
 | ||
|      * One example is when turning markdown into React nodes.
 | ||
|      *
 | ||
|      * @type {unknown}
 | ||
|      */
 | ||
|     result: unknown;
 | ||
|     /**
 | ||
|      * Whether a file was saved to disk.
 | ||
|      *
 | ||
|      * This is used by vfile reporters.
 | ||
|      *
 | ||
|      * @type {boolean}
 | ||
|      */
 | ||
|     stored: boolean;
 | ||
|     /**
 | ||
|      * Set basename (including extname) (`'index.min.js'`).
 | ||
|      *
 | ||
|      * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\'`
 | ||
|      * on windows).
 | ||
|      * Cannot be nullified (use `file.path = file.dirname` instead).
 | ||
|      *
 | ||
|      * @param {string} basename
 | ||
|      *   Basename.
 | ||
|      * @returns {undefined}
 | ||
|      *   Nothing.
 | ||
|      */
 | ||
|     set basename(basename: string);
 | ||
|     /**
 | ||
|      * Get the basename (including extname) (example: `'index.min.js'`).
 | ||
|      *
 | ||
|      * @returns {string | undefined}
 | ||
|      *   Basename.
 | ||
|      */
 | ||
|     get basename(): string | undefined;
 | ||
|     /**
 | ||
|      * Set the full path (example: `'~/index.min.js'`).
 | ||
|      *
 | ||
|      * Cannot be nullified.
 | ||
|      * You can set a file URL (a `URL` object with a `file:` protocol) which will
 | ||
|      * be turned into a path with `url.fileURLToPath`.
 | ||
|      *
 | ||
|      * @param {URL | string} path
 | ||
|      *   Path.
 | ||
|      * @returns {undefined}
 | ||
|      *   Nothing.
 | ||
|      */
 | ||
|     set path(path: string | URL);
 | ||
|     /**
 | ||
|      * Get the full path (example: `'~/index.min.js'`).
 | ||
|      *
 | ||
|      * @returns {string}
 | ||
|      *   Path.
 | ||
|      */
 | ||
|     get path(): string;
 | ||
|     /**
 | ||
|      * Set the parent path (example: `'~'`).
 | ||
|      *
 | ||
|      * Cannot be set if there’s no `path` yet.
 | ||
|      *
 | ||
|      * @param {string | undefined} dirname
 | ||
|      *   Dirname.
 | ||
|      * @returns {undefined}
 | ||
|      *   Nothing.
 | ||
|      */
 | ||
|     set dirname(dirname: string | undefined);
 | ||
|     /**
 | ||
|      * Get the parent path (example: `'~'`).
 | ||
|      *
 | ||
|      * @returns {string | undefined}
 | ||
|      *   Dirname.
 | ||
|      */
 | ||
|     get dirname(): string | undefined;
 | ||
|     /**
 | ||
|      * Set the extname (including dot) (example: `'.js'`).
 | ||
|      *
 | ||
|      * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\'`
 | ||
|      * on windows).
 | ||
|      * Cannot be set if there’s no `path` yet.
 | ||
|      *
 | ||
|      * @param {string | undefined} extname
 | ||
|      *   Extname.
 | ||
|      * @returns {undefined}
 | ||
|      *   Nothing.
 | ||
|      */
 | ||
|     set extname(extname: string | undefined);
 | ||
|     /**
 | ||
|      * Get the extname (including dot) (example: `'.js'`).
 | ||
|      *
 | ||
|      * @returns {string | undefined}
 | ||
|      *   Extname.
 | ||
|      */
 | ||
|     get extname(): string | undefined;
 | ||
|     /**
 | ||
|      * Set the stem (basename w/o extname) (example: `'index.min'`).
 | ||
|      *
 | ||
|      * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\'`
 | ||
|      * on windows).
 | ||
|      * Cannot be nullified (use `file.path = file.dirname` instead).
 | ||
|      *
 | ||
|      * @param {string} stem
 | ||
|      *   Stem.
 | ||
|      * @returns {undefined}
 | ||
|      *   Nothing.
 | ||
|      */
 | ||
|     set stem(stem: string);
 | ||
|     /**
 | ||
|      * Get the stem (basename w/o extname) (example: `'index.min'`).
 | ||
|      *
 | ||
|      * @returns {string | undefined}
 | ||
|      *   Stem.
 | ||
|      */
 | ||
|     get stem(): string | undefined;
 | ||
|     /**
 | ||
|      * Create a fatal message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `true` (error; file not usable)
 | ||
|      * and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {never}
 | ||
|      *   Never.
 | ||
|      * @throws {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     fail(reason: string, options?: MessageOptions | null | undefined): never;
 | ||
|     /**
 | ||
|      * Create a fatal message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `true` (error; file not usable)
 | ||
|      * and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {never}
 | ||
|      *   Never.
 | ||
|      * @throws {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     fail(reason: string, parent: Node | NodeLike | null | undefined, origin?: string | null | undefined): never;
 | ||
|     /**
 | ||
|      * Create a fatal message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `true` (error; file not usable)
 | ||
|      * and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {never}
 | ||
|      *   Never.
 | ||
|      * @throws {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     fail(reason: string, place: Point | Position | null | undefined, origin?: string | null | undefined): never;
 | ||
|     /**
 | ||
|      * Create a fatal message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `true` (error; file not usable)
 | ||
|      * and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {never}
 | ||
|      *   Never.
 | ||
|      * @throws {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     fail(reason: string, origin?: string | null | undefined): never;
 | ||
|     /**
 | ||
|      * Create a fatal message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `true` (error; file not usable)
 | ||
|      * and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {never}
 | ||
|      *   Never.
 | ||
|      * @throws {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     fail(cause: Error | VFileMessage, parent: Node | NodeLike | null | undefined, origin?: string | null | undefined): never;
 | ||
|     /**
 | ||
|      * Create a fatal message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `true` (error; file not usable)
 | ||
|      * and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {never}
 | ||
|      *   Never.
 | ||
|      * @throws {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     fail(cause: Error | VFileMessage, place: Point | Position | null | undefined, origin?: string | null | undefined): never;
 | ||
|     /**
 | ||
|      * Create a fatal message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `true` (error; file not usable)
 | ||
|      * and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {never}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {never}
 | ||
|      *   Never.
 | ||
|      * @throws {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     fail(cause: Error | VFileMessage, origin?: string | null | undefined): never;
 | ||
|     /**
 | ||
|      * Create an info message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `undefined` (info; change
 | ||
|      * likely not needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     info(reason: string, options?: MessageOptions | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create an info message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `undefined` (info; change
 | ||
|      * likely not needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     info(reason: string, parent: Node | NodeLike | null | undefined, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create an info message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `undefined` (info; change
 | ||
|      * likely not needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     info(reason: string, place: Point | Position | null | undefined, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create an info message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `undefined` (info; change
 | ||
|      * likely not needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     info(reason: string, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create an info message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `undefined` (info; change
 | ||
|      * likely not needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     info(cause: Error | VFileMessage, parent: Node | NodeLike | null | undefined, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create an info message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `undefined` (info; change
 | ||
|      * likely not needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     info(cause: Error | VFileMessage, place: Point | Position | null | undefined, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create an info message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `undefined` (info; change
 | ||
|      * likely not needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     info(cause: Error | VFileMessage, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create a message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `false` (warning; change may be
 | ||
|      * needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     message(reason: string, options?: MessageOptions | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create a message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `false` (warning; change may be
 | ||
|      * needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     message(reason: string, parent: Node | NodeLike | null | undefined, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create a message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `false` (warning; change may be
 | ||
|      * needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     message(reason: string, place: Point | Position | null | undefined, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create a message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `false` (warning; change may be
 | ||
|      * needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     message(reason: string, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create a message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `false` (warning; change may be
 | ||
|      * needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     message(cause: Error | VFileMessage, parent: Node | NodeLike | null | undefined, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create a message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `false` (warning; change may be
 | ||
|      * needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     message(cause: Error | VFileMessage, place: Point | Position | null | undefined, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Create a message for `reason` associated with the file.
 | ||
|      *
 | ||
|      * The `fatal` field of the message is set to `false` (warning; change may be
 | ||
|      * needed) and the `file` field is set to the current file path.
 | ||
|      * The message is added to the `messages` field on `file`.
 | ||
|      *
 | ||
|      * > 🪦 **Note**: also has obsolete signatures.
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {MessageOptions | null | undefined} [options]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {string} reason
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Node | NodeLike | null | undefined} parent
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {Point | Position | null | undefined} place
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @overload
 | ||
|      * @param {Error | VFileMessage} cause
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      * @returns {VFileMessage}
 | ||
|      *
 | ||
|      * @param {Error | VFileMessage | string} causeOrReason
 | ||
|      *   Reason for message, should use markdown.
 | ||
|      * @param {Node | NodeLike | MessageOptions | Point | Position | string | null | undefined} [optionsOrParentOrPlace]
 | ||
|      *   Configuration (optional).
 | ||
|      * @param {string | null | undefined} [origin]
 | ||
|      *   Place in code where the message originates (example:
 | ||
|      *   `'my-package:my-rule'` or `'my-rule'`).
 | ||
|      * @returns {VFileMessage}
 | ||
|      *   Message.
 | ||
|      */
 | ||
|     message(cause: Error | VFileMessage, origin?: string | null | undefined): VFileMessage;
 | ||
|     /**
 | ||
|      * Serialize the file.
 | ||
|      *
 | ||
|      * > **Note**: which encodings are supported depends on the engine.
 | ||
|      * > For info on Node.js, see:
 | ||
|      * > <https://nodejs.org/api/util.html#whatwg-supported-encodings>.
 | ||
|      *
 | ||
|      * @param {string | null | undefined} [encoding='utf8']
 | ||
|      *   Character encoding to understand `value` as when it’s a `Uint8Array`
 | ||
|      *   (default: `'utf-8'`).
 | ||
|      * @returns {string}
 | ||
|      *   Serialized file.
 | ||
|      */
 | ||
|     toString(encoding?: string | null | undefined): string;
 | ||
| }
 | ||
| export type NodeLike = object & {
 | ||
|     type: string;
 | ||
|     position?: Position | undefined;
 | ||
| };
 | ||
| import type { Data } from 'vfile';
 | ||
| import { VFileMessage } from 'vfile-message';
 | ||
| import type { Value } from 'vfile';
 | ||
| import type { Map } from 'vfile';
 | ||
| import type { Options as MessageOptions } from 'vfile-message';
 | ||
| import type { Node } from 'unist';
 | ||
| import type { Point } from 'unist';
 | ||
| import type { Position } from 'unist';
 | ||
| import type { Compatible } from 'vfile';
 | ||
| //# sourceMappingURL=index.d.ts.map
 |