/**
							 | 
						|
								 * @fileoverview Common helpers for naming of plugins, formatters and configs
							 | 
						|
								 */
							 | 
						|
								
							 | 
						|
								const NAMESPACE_REGEX = /^@.*\//iu;
							 | 
						|
								
							 | 
						|
								/**
							 | 
						|
								 * Brings package name to correct format based on prefix
							 | 
						|
								 * @param {string} name The name of the package.
							 | 
						|
								 * @param {string} prefix Can be either "eslint-plugin", "eslint-config" or "eslint-formatter"
							 | 
						|
								 * @returns {string} Normalized name of the package
							 | 
						|
								 * @private
							 | 
						|
								 */
							 | 
						|
								function normalizePackageName(name, prefix) {
							 | 
						|
								    let normalizedName = name;
							 | 
						|
								
							 | 
						|
								    /**
							 | 
						|
								     * On Windows, name can come in with Windows slashes instead of Unix slashes.
							 | 
						|
								     * Normalize to Unix first to avoid errors later on.
							 | 
						|
								     * https://github.com/eslint/eslint/issues/5644
							 | 
						|
								     */
							 | 
						|
								    if (normalizedName.includes("\\")) {
							 | 
						|
								        normalizedName = normalizedName.replace(/\\/gu, "/");
							 | 
						|
								    }
							 | 
						|
								
							 | 
						|
								    if (normalizedName.charAt(0) === "@") {
							 | 
						|
								
							 | 
						|
								        /**
							 | 
						|
								         * it's a scoped package
							 | 
						|
								         * package name is the prefix, or just a username
							 | 
						|
								         */
							 | 
						|
								        const scopedPackageShortcutRegex = new RegExp(`^(@[^/]+)(?:/(?:${prefix})?)?$`, "u"),
							 | 
						|
								            scopedPackageNameRegex = new RegExp(`^${prefix}(-|$)`, "u");
							 | 
						|
								
							 | 
						|
								        if (scopedPackageShortcutRegex.test(normalizedName)) {
							 | 
						|
								            normalizedName = normalizedName.replace(scopedPackageShortcutRegex, `$1/${prefix}`);
							 | 
						|
								        } else if (!scopedPackageNameRegex.test(normalizedName.split("/")[1])) {
							 | 
						|
								
							 | 
						|
								            /**
							 | 
						|
								             * for scoped packages, insert the prefix after the first / unless
							 | 
						|
								             * the path is already @scope/eslint or @scope/eslint-xxx-yyy
							 | 
						|
								             */
							 | 
						|
								            normalizedName = normalizedName.replace(/^@([^/]+)\/(.*)$/u, `@$1/${prefix}-$2`);
							 | 
						|
								        }
							 | 
						|
								    } else if (!normalizedName.startsWith(`${prefix}-`)) {
							 | 
						|
								        normalizedName = `${prefix}-${normalizedName}`;
							 | 
						|
								    }
							 | 
						|
								
							 | 
						|
								    return normalizedName;
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								/**
							 | 
						|
								 * Removes the prefix from a fullname.
							 | 
						|
								 * @param {string} fullname The term which may have the prefix.
							 | 
						|
								 * @param {string} prefix The prefix to remove.
							 | 
						|
								 * @returns {string} The term without prefix.
							 | 
						|
								 */
							 | 
						|
								function getShorthandName(fullname, prefix) {
							 | 
						|
								    if (fullname[0] === "@") {
							 | 
						|
								        let matchResult = new RegExp(`^(@[^/]+)/${prefix}$`, "u").exec(fullname);
							 | 
						|
								
							 | 
						|
								        if (matchResult) {
							 | 
						|
								            return matchResult[1];
							 | 
						|
								        }
							 | 
						|
								
							 | 
						|
								        matchResult = new RegExp(`^(@[^/]+)/${prefix}-(.+)$`, "u").exec(fullname);
							 | 
						|
								        if (matchResult) {
							 | 
						|
								            return `${matchResult[1]}/${matchResult[2]}`;
							 | 
						|
								        }
							 | 
						|
								    } else if (fullname.startsWith(`${prefix}-`)) {
							 | 
						|
								        return fullname.slice(prefix.length + 1);
							 | 
						|
								    }
							 | 
						|
								
							 | 
						|
								    return fullname;
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								/**
							 | 
						|
								 * Gets the scope (namespace) of a term.
							 | 
						|
								 * @param {string} term The term which may have the namespace.
							 | 
						|
								 * @returns {string} The namespace of the term if it has one.
							 | 
						|
								 */
							 | 
						|
								function getNamespaceFromTerm(term) {
							 | 
						|
								    const match = term.match(NAMESPACE_REGEX);
							 | 
						|
								
							 | 
						|
								    return match ? match[0] : "";
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								//------------------------------------------------------------------------------
							 | 
						|
								// Public Interface
							 | 
						|
								//------------------------------------------------------------------------------
							 | 
						|
								
							 | 
						|
								export {
							 | 
						|
								    normalizePackageName,
							 | 
						|
								    getShorthandName,
							 | 
						|
								    getNamespaceFromTerm
							 | 
						|
								};
							 |