|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ VFile: () => (/* binding */ VFile)\n/* harmony export */ });\n/* harmony import */ var is_buffer__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! is-buffer */ \"(ssr)/./node_modules/is-buffer/index.js\");\n/* harmony import */ var vfile_message__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! vfile-message */ \"(ssr)/./node_modules/vfile-message/lib/index.js\");\n/* harmony import */ var _minpath_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./minpath.js */ \"path\");\n/* harmony import */ var _minproc_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./minproc.js */ \"process\");\n/* harmony import */ var _minurl_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./minurl.js */ \"(ssr)/./node_modules/vfile/lib/minurl.shared.js\");\n/* harmony import */ var _minurl_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./minurl.js */ \"url\");\n/**\n * @typedef {import('unist').Node} Node\n * @typedef {import('unist').Position} Position\n * @typedef {import('unist').Point} Point\n * @typedef {import('./minurl.shared.js').URL} URL\n * @typedef {import('../index.js').Data} Data\n * @typedef {import('../index.js').Value} Value\n */ /**\n * @typedef {Record<string, unknown> & {type: string, position?: Position | undefined}} NodeLike\n *\n * @typedef {'ascii' | 'utf8' | 'utf-8' | 'utf16le' | 'ucs2' | 'ucs-2' | 'base64' | 'base64url' | 'latin1' | 'binary' | 'hex'} BufferEncoding\n * Encodings supported by the buffer class.\n *\n * This is a copy of the types from Node, copied to prevent Node globals from\n * being needed.\n * Copied from: <https://github.com/DefinitelyTyped/DefinitelyTyped/blob/90a4ec8/types/node/buffer.d.ts#L170>\n *\n * @typedef {Options | URL | Value | VFile} Compatible\n * Things that can be passed to the constructor.\n *\n * @typedef VFileCoreOptions\n * Set multiple values.\n * @property {Value | null | undefined} [value]\n * Set `value`.\n * @property {string | null | undefined} [cwd]\n * Set `cwd`.\n * @property {Array<string> | null | undefined} [history]\n * Set `history`.\n * @property {URL | string | null | undefined} [path]\n * Set `path`.\n * @property {string | null | undefined} [basename]\n * Set `basename`.\n * @property {string | null | undefined} [stem]\n * Set `stem`.\n * @property {string | null | undefined} [extname]\n * Set `extname`.\n * @property {string | null | undefined} [dirname]\n * Set `dirname`.\n * @property {Data | null | undefined} [data]\n * Set `data`.\n *\n * @typedef Map\n * Raw source map.\n *\n * See:\n * <https://github.com/mozilla/source-map/blob/58819f0/source-map.d.ts#L15-L23>.\n * @property {number} version\n * Which version of the source map spec this map is following.\n * @property {Array<string>} sources\n * An array of URLs to the original source files.\n * @property {Array<string>} names\n * An array of identifiers which can be referenced by individual mappings.\n * @property {string | undefined} [sourceRoot]\n * The URL root from which all sources are relative.\n * @property {Array<string> | undefined} [sourcesContent]\n * An array of contents of the original source files.\n * @property {string} mappings\n * A string of base64 VLQs which contain the actual mappings.\n * @property {string} file\n * The generated file this source map is associated with.\n *\n * @typedef {{[key: string]: unknown} & VFileCoreOptions} Options\n * Configuration.\n *\n * A bunch of keys that will be shallow copied over to the new file.\n *\n * @typedef {Record<string, unknown>} ReporterSettings\n * Configuration for reporters.\n */ /**\n * @template {ReporterSettings} Settings\n * Options type.\n * @callback Reporter\n * Type for a reporter.\n * @param {Array<VFile>} files\n * Files to report.\n * @param {Settings} options\n * Configuration.\n * @returns {string}\n * Report.\n */ \n\n\n\n\n/**\n * Order of setting (least specific to most), we need this because otherwise\n * `{stem: 'a', path: '~/b.js'}` would throw, as a path is needed before a\n * stem can be set.\n *\n * @type {Array<'basename' | 'dirname' | 'extname' | 'history' | 'path' | 'stem'>}\n */ const order = [\n \"history\",\n \"path\",\n \"basename\",\n \"stem\",\n \"extname\",\n \"dirname\"\n];\nclass VFile {\n /**\n * Create a new virtual file.\n *\n * `options` is treated as:\n *\n * * `string` or `Buffer` — `{value: options}`\n * * `URL` — `{path: options}`\n * * `VFile` — shallow copies its data over to the new file\n * * `object` — all fields are shallow copied over to the new file\n *\n * Path related fields are set in the following order (least specific to\n * most specific): `history`, `path`, `basename`, `stem`, `extname`,\n * `dirname`.\n *\n * You cannot set `dirname` or `extname` without setting either `history`,\n * `path`, `basename`, or `stem` too.\n *\n * @param {Compatible | null | undefined} [value]\n * File value.\n * @returns\n * New instance.\n */ constructor(value){\n /** @type {Options | VFile} */ let options;\n if (!value) {\n options = {};\n } else if (typeof value === \"string\" || buffer(value)) {\n options = {\n value\n };\n } else if ((0,_minurl_js__WEBPACK_IMPORTED_MODULE_1__.isUrl)(value)) {\n options = {\n path: value\n };\n } else {\n options = value;\n }\n /**\n * Place to store custom information (default: `{}`).\n *\n * It’s OK to store custom data directly on the file but moving it to\n * `data` is recommended.\n *\n * @type {Data}\n */ this.data = {};\n /**\n * List of messages associated with the file.\n *\n * @type {Array<VFileMessage>}\n */ this.messages = [];\n /**\n * List of filepaths the file moved between.\n *\n * The first is the original path and the last is the current path.\n *\n * @type {Array<string>}\n */ this.history = [];\n /**\n * Base of `path` (default: `process.cwd()` or `'/'` in browsers).\n *\n * @type {string}\n */ this.cwd = _minproc_js__WEBPACK_IMPORTED_MODULE_2__.cwd();\n /* eslint-disable no-unused-expressions */ /**\n * Raw value.\n *\n * @type {Value}\n */ this.value;\n // The below are non-standard, they are “well-known”.\n // As in, used in several tools.\n /**\n * Whether a file was saved to disk.\n *\n * This is used by vfile reporters.\n *\n * @type {boolean}\n */ this.stored;\n /**\n * Custom, non-string, compiled, representation.\n *\n * This is used by unified to store non-string results.\n * One example is when turning markdown into React nodes.\n *\n * @type {unknown}\n */ this.result;\n /**\n * Source map.\n *\n * This type is equivalent to the `RawSourceMap` type from the `source-map`\n * module.\n *\n * @type {Map | null | undefined}\n */ this.map;\n /* eslint-enable no-unused-expressions */ // Set path related properties in the correct order.\n let index = -1;\n while(++index < order.length){\n const prop = order[index];\n // Note: we specifically use `in` instead of `hasOwnProperty` to accept\n // `vfile`s too.\n if (prop in options && options[prop] !== undefined && options[prop] !== null) {\n // @ts-expect-error: TS doesn’t understand basic reality.\n this[prop] = prop === \"history\" ? [\n ...options[prop]\n ] : options[prop];\n }\n }\n /** @type {string} */ let prop;\n // Set non-path related properties.\n for(prop in options){\n // @ts-expect-error: fine to set other things.\n if (!order.includes(prop)) {\n // @ts-expect-error: fine to set other things.\n this[prop] = options[prop];\n }\n }\n }\n /**\n * Get the full path (example: `'~/index.min.js'`).\n *\n * @returns {string}\n */ get path() {\n return this.history[this.history.length - 1];\n }\n /**\n * Set the full path (example: `'~/index.min.js'`).\n *\n * Cannot be nullified.\n * You can set a file URL (a `URL` object with a `file:` protocol) which will\n * be turned into a path with `url.fileURLToPath`.\n *\n * @param {string | URL} path\n */ set path(path) {\n if ((0,_minurl_js__WEBPACK_IMPORTED_MODULE_1__.isUrl)(path)) {\n path = (0,_minurl_js__WEBPACK_IMPORTED_MODULE_3__.fileURLToPath)(path);\n }\n assertNonEmpty(path, \"path\");\n if (this.path !== path) {\n this.history.push(path);\n }\n }\n /**\n * Get the parent path (example: `'~'`).\n */ get dirname() {\n return typeof this.path === \"string\" ? _minpath_js__WEBPACK_IMPORTED_MODULE_4__.dirname(this.path) : undefined;\n }\n /**\n * Set the parent path (example: `'~'`).\n *\n * Cannot be set if there’s no `path` yet.\n */ set dirname(dirname) {\n assertPath(this.basename, \"dirname\");\n this.path = _minpath_js__WEBPACK_IMPORTED_MODULE_4__.join(dirname || \"\", this.basename);\n }\n /**\n * Get the basename (including extname) (example: `'index.min.js'`).\n */ get basename() {\n return typeof this.path === \"string\" ? _minpath_js__WEBPACK_IMPORTED_MODULE_4__.basename(this.path) : undefined;\n }\n /**\n * Set basename (including extname) (`'index.min.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n */ set basename(basename) {\n assertNonEmpty(basename, \"basename\");\n assertPart(basename, \"basename\");\n this.path = _minpath_js__WEBPACK_IMPORTED_MODULE_4__.join(this.dirname || \"\", basename);\n }\n /**\n * Get the extname (including dot) (example: `'.js'`).\n */ get extname() {\n return typeof this.path === \"string\" ? _minpath_js__WEBPACK_IMPORTED_MODULE_4__.extname(this.path) : undefined;\n }\n /**\n * Set the extname (including dot) (example: `'.js'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be set if there’s no `path` yet.\n */ set extname(extname) {\n assertPart(extname, \"extname\");\n assertPath(this.dirname, \"extname\");\n if (extname) {\n if (extname.charCodeAt(0) !== 46 /* `.` */ ) {\n throw new Error(\"`extname` must start with `.`\");\n }\n if (extname.includes(\".\", 1)) {\n throw new Error(\"`extname` cannot contain multiple dots\");\n }\n }\n this.path = _minpath_js__WEBPACK_IMPORTED_MODULE_4__.join(this.dirname, this.stem + (extname || \"\"));\n }\n /**\n * Get the stem (basename w/o extname) (example: `'index.min'`).\n */ get stem() {\n return typeof this.path === \"string\" ? _minpath_js__WEBPACK_IMPORTED_MODULE_4__.basename(this.path, this.extname) : undefined;\n }\n /**\n * Set the stem (basename w/o extname) (example: `'index.min'`).\n *\n * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n * on windows).\n * Cannot be nullified (use `file.path = file.dirname` instead).\n */ set stem(stem) {\n assertNonEmpty(stem, \"stem\");\n assertPart(stem, \"stem\");\n this.path = _minpath_js__WEBPACK_IMPORTED_MODULE_4__.join(this.dirname || \"\", stem + (this.extname || \"\"));\n }\n /**\n * Serialize the file.\n *\n * @param {BufferEncoding | null | undefined} [encoding='utf8']\n * Character encoding to understand `value` as when it’s a `Buffer`\n * (default: `'utf8'`).\n * @returns {string}\n * Serialized file.\n */ toString(encoding) {\n return (this.value || \"\").toString(encoding || undefined);\n }\n /**\n * Create a warning message associated with the file.\n *\n * Its `fatal` is set to `false` and `file` is set to the current file path.\n * Its added to `file.messages`.\n *\n * @param {string | Error | VFileMessage} reason\n * Reason for message, uses the stack and message of the error if given.\n * @param {Node | NodeLike | Position | Point | null | undefined} [place]\n * Place in file where the message occurred.\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */ message(reason, place, origin) {\n const message = new vfile_message__WEBPACK_IMPORTED_MODULE_5__.VFileMessage(reason, place, origin);\n if (this.path) {\n message.name = this.path + \":\" + message.name;\n message.file = this.path;\n }\n message.fatal = false;\n this.messages.push(message);\n return message;\n }\n /**\n * Create an info message associated with the file.\n *\n * Its `fatal` is set to `null` and `file` is set to the current file path.\n * Its added to `file.messages`.\n *\n * @param {string | Error | VFileMessage} reason\n * Reason for message, uses the stack and message of the error if given.\n * @param {Node | NodeLike | Position | Point | null | undefined} [place]\n * Place in file where the message occurred.\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {VFileMessage}\n * Message.\n */ info(reason, place, origin) {\n const message = this.message(reason, place, origin);\n message.fatal = null;\n return message;\n }\n /**\n * Create a fatal error associated with the file.\n *\n * Its `fatal` is set to `true` and `file` is set to the current file path.\n * Its added to `file.messages`.\n *\n * > 👉 **Note**: a fatal error means that a file is no longer processable.\n *\n * @param {string | Error | VFileMessage} reason\n * Reason for message, uses the stack and message of the error if given.\n * @param {Node | NodeLike | Position | Point | null | undefined} [place]\n * Place in file where the message occurred.\n * @param {string | null | undefined} [origin]\n * Place in code where the message originates (example:\n * `'my-package:my-rule'` or `'my-rule'`).\n * @returns {never}\n * Message.\n * @throws {VFileMessage}\n * Message.\n */ fail(reason, place, origin) {\n const message = this.message(reason, place, origin);\n message.fatal = true;\n throw message;\n }\n}\n/**\n * Assert that `part` is not a path (as in, does not contain `path.sep`).\n *\n * @param {string | null | undefined} part\n * File path part.\n * @param {string} name\n * Part name.\n * @returns {void}\n * Nothing.\n */ function assertPart(part, name) {\n if (part && part.includes(_minpath_js__WEBPACK_IMPORTED_MODULE_4__.sep)) {\n throw new Error(\"`\" + name + \"` cannot be a path: did not expect `\" + _minpath_js__WEBPACK_IMPORTED_MODULE_4__.sep + \"`\");\n }\n}\n/**\n * Assert that `part` is not empty.\n *\n * @param {string | undefined} part\n * Thing.\n * @param {string} name\n * Part name.\n * @returns {asserts part is string}\n * Nothing.\n */ function assertNonEmpty(part, name) {\n if (!part) {\n throw new Error(\"`\" + name + \"` cannot be empty\");\n }\n}\n/**\n * Assert `path` exists.\n *\n * @param {string | undefined} path\n * Path.\n * @param {string} name\n * Dependency name.\n * @returns {asserts path is string}\n * Nothing.\n */ function assertPath(path, name) {\n if (!path) {\n throw new Error(\"Setting `\" + name + \"` requires `path` to be set too\");\n }\n}\n/**\n * Assert `value` is a buffer.\n *\n * @param {unknown} value\n * thing.\n * @returns {value is Buffer}\n * Whether `value` is a Node.js buffer.\n */ function buffer(value) {\n return is_buffer__WEBPACK_IMPORTED_MODULE_0__(value);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/vfile/lib/index.js","mappings":"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","sources":["webpack://nextchat/./node_modules/vfile/lib/index.js?da36"],"sourcesContent":["/**\n * @typedef {import('unist').Node} Node\n * @typedef {import('unist').Position} Position\n * @typedef {import('unist').Point} Point\n * @typedef {import('./minurl.shared.js').URL} URL\n * @typedef {import('../index.js').Data} Data\n * @typedef {import('../index.js').Value} Value\n */\n\n/**\n * @typedef {Record<string, unknown> & {type: string, position?: Position | undefined}} NodeLike\n *\n * @typedef {'ascii' | 'utf8' | 'utf-8' | 'utf16le' | 'ucs2' | 'ucs-2' | 'base64' | 'base64url' | 'latin1' | 'binary' | 'hex'} BufferEncoding\n *   Encodings supported by the buffer class.\n *\n *   This is a copy of the types from Node, copied to prevent Node globals from\n *   being needed.\n *   Copied from: <https://github.com/DefinitelyTyped/DefinitelyTyped/blob/90a4ec8/types/node/buffer.d.ts#L170>\n *\n * @typedef {Options | URL | Value | VFile} Compatible\n *   Things that can be passed to the constructor.\n *\n * @typedef VFileCoreOptions\n *   Set multiple values.\n * @property {Value | null | undefined} [value]\n *   Set `value`.\n * @property {string | null | undefined} [cwd]\n *   Set `cwd`.\n * @property {Array<string> | null | undefined} [history]\n *   Set `history`.\n * @property {URL | string | null | undefined} [path]\n *   Set `path`.\n * @property {string | null | undefined} [basename]\n *   Set `basename`.\n * @property {string | null | undefined} [stem]\n *   Set `stem`.\n * @property {string | null | undefined} [extname]\n *   Set `extname`.\n * @property {string | null | undefined} [dirname]\n *   Set `dirname`.\n * @property {Data | null | undefined} [data]\n *   Set `data`.\n *\n * @typedef Map\n *   Raw source map.\n *\n *   See:\n *   <https://github.com/mozilla/source-map/blob/58819f0/source-map.d.ts#L15-L23>.\n * @property {number} version\n *   Which version of the source map spec this map is following.\n * @property {Array<string>} sources\n *   An array of URLs to the original source files.\n * @property {Array<string>} names\n *   An array of identifiers which can be referenced by individual mappings.\n * @property {string | undefined} [sourceRoot]\n *   The URL root from which all sources are relative.\n * @property {Array<string> | undefined} [sourcesContent]\n *   An array of contents of the original source files.\n * @property {string} mappings\n *   A string of base64 VLQs which contain the actual mappings.\n * @property {string} file\n *   The generated file this source map is associated with.\n *\n * @typedef {{[key: string]: unknown} & VFileCoreOptions} Options\n *   Configuration.\n *\n *   A bunch of keys that will be shallow copied over to the new file.\n *\n * @typedef {Record<string, unknown>} ReporterSettings\n *   Configuration for reporters.\n */\n\n/**\n * @template {ReporterSettings} Settings\n *   Options type.\n * @callback Reporter\n *   Type for a reporter.\n * @param {Array<VFile>} files\n *   Files to report.\n * @param {Settings} options\n *   Configuration.\n * @returns {string}\n *   Report.\n */\n\nimport bufferLike from 'is-buffer'\nimport {VFileMessage} from 'vfile-message'\nimport {path} from './minpath.js'\nimport {proc} from './minproc.js'\nimport {urlToPath, isUrl} from './minurl.js'\n\n/**\n * Order of setting (least specific to most), we need this because otherwise\n * `{stem: 'a', path: '~/b.js'}` would throw, as a path is needed before a\n * stem can be set.\n *\n * @type {Array<'basename' | 'dirname' | 'extname' | 'history' | 'path' | 'stem'>}\n */\nconst order = ['history', 'path', 'basename', 'stem', 'extname', 'dirname']\n\nexport class VFile {\n  /**\n   * Create a new virtual file.\n   *\n   * `options` is treated as:\n   *\n   * *   `string` or `Buffer` — `{value: options}`\n   * *   `URL` — `{path: options}`\n   * *   `VFile` — shallow copies its data over to the new file\n   * *   `object` — all fields are shallow copied over to the new file\n   *\n   * Path related fields are set in the following order (least specific to\n   * most specific): `history`, `path`, `basename`, `stem`, `extname`,\n   * `dirname`.\n   *\n   * You cannot set `dirname` or `extname` without setting either `history`,\n   * `path`, `basename`, or `stem` too.\n   *\n   * @param {Compatible | null | undefined} [value]\n   *   File value.\n   * @returns\n   *   New instance.\n   */\n  constructor(value) {\n    /** @type {Options | VFile} */\n    let options\n\n    if (!value) {\n      options = {}\n    } else if (typeof value === 'string' || buffer(value)) {\n      options = {value}\n    } else if (isUrl(value)) {\n      options = {path: value}\n    } else {\n      options = value\n    }\n\n    /**\n     * Place to store custom information (default: `{}`).\n     *\n     * It’s OK to store custom data directly on the file but moving it to\n     * `data` is recommended.\n     *\n     * @type {Data}\n     */\n    this.data = {}\n\n    /**\n     * List of messages associated with the file.\n     *\n     * @type {Array<VFileMessage>}\n     */\n    this.messages = []\n\n    /**\n     * List of filepaths the file moved between.\n     *\n     * The first is the original path and the last is the current path.\n     *\n     * @type {Array<string>}\n     */\n    this.history = []\n\n    /**\n     * Base of `path` (default: `process.cwd()` or `'/'` in browsers).\n     *\n     * @type {string}\n     */\n    this.cwd = proc.cwd()\n\n    /* eslint-disable no-unused-expressions */\n    /**\n     * Raw value.\n     *\n     * @type {Value}\n     */\n    this.value\n\n    // The below are non-standard, they are “well-known”.\n    // As in, used in several tools.\n\n    /**\n     * Whether a file was saved to disk.\n     *\n     * This is used by vfile reporters.\n     *\n     * @type {boolean}\n     */\n    this.stored\n\n    /**\n     * Custom, non-string, compiled, representation.\n     *\n     * This is used by unified to store non-string results.\n     * One example is when turning markdown into React nodes.\n     *\n     * @type {unknown}\n     */\n    this.result\n\n    /**\n     * Source map.\n     *\n     * This type is equivalent to the `RawSourceMap` type from the `source-map`\n     * module.\n     *\n     * @type {Map | null | undefined}\n     */\n    this.map\n    /* eslint-enable no-unused-expressions */\n\n    // Set path related properties in the correct order.\n    let index = -1\n\n    while (++index < order.length) {\n      const prop = order[index]\n\n      // Note: we specifically use `in` instead of `hasOwnProperty` to accept\n      // `vfile`s too.\n      if (\n        prop in options &&\n        options[prop] !== undefined &&\n        options[prop] !== null\n      ) {\n        // @ts-expect-error: TS doesn’t understand basic reality.\n        this[prop] = prop === 'history' ? [...options[prop]] : options[prop]\n      }\n    }\n\n    /** @type {string} */\n    let prop\n\n    // Set non-path related properties.\n    for (prop in options) {\n      // @ts-expect-error: fine to set other things.\n      if (!order.includes(prop)) {\n        // @ts-expect-error: fine to set other things.\n        this[prop] = options[prop]\n      }\n    }\n  }\n\n  /**\n   * Get the full path (example: `'~/index.min.js'`).\n   *\n   * @returns {string}\n   */\n  get path() {\n    return this.history[this.history.length - 1]\n  }\n\n  /**\n   * Set the full path (example: `'~/index.min.js'`).\n   *\n   * Cannot be nullified.\n   * You can set a file URL (a `URL` object with a `file:` protocol) which will\n   * be turned into a path with `url.fileURLToPath`.\n   *\n   * @param {string | URL} path\n   */\n  set path(path) {\n    if (isUrl(path)) {\n      path = urlToPath(path)\n    }\n\n    assertNonEmpty(path, 'path')\n\n    if (this.path !== path) {\n      this.history.push(path)\n    }\n  }\n\n  /**\n   * Get the parent path (example: `'~'`).\n   */\n  get dirname() {\n    return typeof this.path === 'string' ? path.dirname(this.path) : undefined\n  }\n\n  /**\n   * Set the parent path (example: `'~'`).\n   *\n   * Cannot be set if there’s no `path` yet.\n   */\n  set dirname(dirname) {\n    assertPath(this.basename, 'dirname')\n    this.path = path.join(dirname || '', this.basename)\n  }\n\n  /**\n   * Get the basename (including extname) (example: `'index.min.js'`).\n   */\n  get basename() {\n    return typeof this.path === 'string' ? path.basename(this.path) : undefined\n  }\n\n  /**\n   * Set basename (including extname) (`'index.min.js'`).\n   *\n   * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n   * on windows).\n   * Cannot be nullified (use `file.path = file.dirname` instead).\n   */\n  set basename(basename) {\n    assertNonEmpty(basename, 'basename')\n    assertPart(basename, 'basename')\n    this.path = path.join(this.dirname || '', basename)\n  }\n\n  /**\n   * Get the extname (including dot) (example: `'.js'`).\n   */\n  get extname() {\n    return typeof this.path === 'string' ? path.extname(this.path) : undefined\n  }\n\n  /**\n   * Set the extname (including dot) (example: `'.js'`).\n   *\n   * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n   * on windows).\n   * Cannot be set if there’s no `path` yet.\n   */\n  set extname(extname) {\n    assertPart(extname, 'extname')\n    assertPath(this.dirname, 'extname')\n\n    if (extname) {\n      if (extname.charCodeAt(0) !== 46 /* `.` */) {\n        throw new Error('`extname` must start with `.`')\n      }\n\n      if (extname.includes('.', 1)) {\n        throw new Error('`extname` cannot contain multiple dots')\n      }\n    }\n\n    this.path = path.join(this.dirname, this.stem + (extname || ''))\n  }\n\n  /**\n   * Get the stem (basename w/o extname) (example: `'index.min'`).\n   */\n  get stem() {\n    return typeof this.path === 'string'\n      ? path.basename(this.path, this.extname)\n      : undefined\n  }\n\n  /**\n   * Set the stem (basename w/o extname) (example: `'index.min'`).\n   *\n   * Cannot contain path separators (`'/'` on unix, macOS, and browsers, `'\\'`\n   * on windows).\n   * Cannot be nullified (use `file.path = file.dirname` instead).\n   */\n  set stem(stem) {\n    assertNonEmpty(stem, 'stem')\n    assertPart(stem, 'stem')\n    this.path = path.join(this.dirname || '', stem + (this.extname || ''))\n  }\n\n  /**\n   * Serialize the file.\n   *\n   * @param {BufferEncoding | null | undefined} [encoding='utf8']\n   *   Character encoding to understand `value` as when it’s a `Buffer`\n   *   (default: `'utf8'`).\n   * @returns {string}\n   *   Serialized file.\n   */\n  toString(encoding) {\n    return (this.value || '').toString(encoding || undefined)\n  }\n\n  /**\n   * Create a warning message associated with the file.\n   *\n   * Its `fatal` is set to `false` and `file` is set to the current file path.\n   * Its added to `file.messages`.\n   *\n   * @param {string | Error | VFileMessage} reason\n   *   Reason for message, uses the stack and message of the error if given.\n   * @param {Node | NodeLike | Position | Point | null | undefined} [place]\n   *   Place in file where the message occurred.\n   * @param {string | null | undefined} [origin]\n   *   Place in code where the message originates (example:\n   *   `'my-package:my-rule'` or `'my-rule'`).\n   * @returns {VFileMessage}\n   *   Message.\n   */\n  message(reason, place, origin) {\n    const message = new VFileMessage(reason, place, origin)\n\n    if (this.path) {\n      message.name = this.path + ':' + message.name\n      message.file = this.path\n    }\n\n    message.fatal = false\n\n    this.messages.push(message)\n\n    return message\n  }\n\n  /**\n   * Create an info message associated with the file.\n   *\n   * Its `fatal` is set to `null` and `file` is set to the current file path.\n   * Its added to `file.messages`.\n   *\n   * @param {string | Error | VFileMessage} reason\n   *   Reason for message, uses the stack and message of the error if given.\n   * @param {Node | NodeLike | Position | Point | null | undefined} [place]\n   *   Place in file where the message occurred.\n   * @param {string | null | undefined} [origin]\n   *   Place in code where the message originates (example:\n   *   `'my-package:my-rule'` or `'my-rule'`).\n   * @returns {VFileMessage}\n   *   Message.\n   */\n  info(reason, place, origin) {\n    const message = this.message(reason, place, origin)\n\n    message.fatal = null\n\n    return message\n  }\n\n  /**\n   * Create a fatal error associated with the file.\n   *\n   * Its `fatal` is set to `true` and `file` is set to the current file path.\n   * Its added to `file.messages`.\n   *\n   * > 👉 **Note**: a fatal error means that a file is no longer processable.\n   *\n   * @param {string | Error | VFileMessage} reason\n   *   Reason for message, uses the stack and message of the error if given.\n   * @param {Node | NodeLike | Position | Point | null | undefined} [place]\n   *   Place in file where the message occurred.\n   * @param {string | null | undefined} [origin]\n   *   Place in code where the message originates (example:\n   *   `'my-package:my-rule'` or `'my-rule'`).\n   * @returns {never}\n   *   Message.\n   * @throws {VFileMessage}\n   *   Message.\n   */\n  fail(reason, place, origin) {\n    const message = this.message(reason, place, origin)\n\n    message.fatal = true\n\n    throw message\n  }\n}\n\n/**\n * Assert that `part` is not a path (as in, does not contain `path.sep`).\n *\n * @param {string | null | undefined} part\n *   File path part.\n * @param {string} name\n *   Part name.\n * @returns {void}\n *   Nothing.\n */\nfunction assertPart(part, name) {\n  if (part && part.includes(path.sep)) {\n    throw new Error(\n      '`' + name + '` cannot be a path: did not expect `' + path.sep + '`'\n    )\n  }\n}\n\n/**\n * Assert that `part` is not empty.\n *\n * @param {string | undefined} part\n *   Thing.\n * @param {string} name\n *   Part name.\n * @returns {asserts part is string}\n *   Nothing.\n */\nfunction assertNonEmpty(part, name) {\n  if (!part) {\n    throw new Error('`' + name + '` cannot be empty')\n  }\n}\n\n/**\n * Assert `path` exists.\n *\n * @param {string | undefined} path\n *   Path.\n * @param {string} name\n *   Dependency name.\n * @returns {asserts path is string}\n *   Nothing.\n */\nfunction assertPath(path, name) {\n  if (!path) {\n    throw new Error('Setting `' + name + '` requires `path` to be set too')\n  }\n}\n\n/**\n * Assert `value` is a buffer.\n *\n * @param {unknown} value\n *   thing.\n * @returns {value is Buffer}\n *   Whether `value` is a Node.js buffer.\n */\nfunction buffer(value) {\n  return bufferLike(value)\n}\n"],"names":["bufferLike","VFileMessage","path","proc","urlToPath","isUrl","order","VFile","constructor","value","options","buffer","data","messages","history","cwd","stored","result","map","index","length","prop","undefined","includes","assertNonEmpty","push","dirname","assertPath","basename","join","assertPart","extname","charCodeAt","Error","stem","toString","encoding","message","reason","place","origin","name","file","fatal","info","fail","part","sep"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/vfile/lib/index.js\n");
|