| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 | /** * @fileoverview Common helpers for naming of plugins, formatters and configs */"use strict";//------------------------------------------------------------------------------// Requirements//------------------------------------------------------------------------------const pathUtil = require("../util/path-util");//------------------------------------------------------------------------------// Private//------------------------------------------------------------------------------const NAMESPACE_REGEX = /^@.*\//i;/** * 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.indexOf("\\") > -1) {        normalizedName = pathUtil.convertPathToPosix(normalizedName);    }    if (normalizedName.charAt(0) === "@") {        /**         * it's a scoped package         * package name is the prefix, or just a username         */        const scopedPackageShortcutRegex = new RegExp(`^(@[^/]+)(?:/(?:${prefix})?)?$`),            scopedPackageNameRegex = new RegExp(`^${prefix}(-|$)`);        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(/^@([^/]+)\/(.*)$/, `@$1/${prefix}-$2`);        }    } else if (normalizedName.indexOf(`${prefix}-`) !== 0) {        normalizedName = `${prefix}-${normalizedName}`;    }    return normalizedName;}/** * Removes the prefix from a term. * @param {string} prefix The prefix to remove. * @param {string} term The term which may have the prefix. * @returns {string} The term without prefix. */function removePrefixFromTerm(prefix, term) {    return term.startsWith(prefix) ? term.slice(prefix.length) : term;}/** * Adds a prefix to a term. * @param {string} prefix The prefix to add. * @param {string} term The term which may not have the prefix. * @returns {string} The term with prefix. */function addPrefixToTerm(prefix, term) {    return term.startsWith(prefix) ? term : `${prefix}${term}`;}/** * Gets the scope (namespace) of a term. * @param {string} term The term which may have the namespace. * @returns {string} The namepace of the term if it has one. */function getNamespaceFromTerm(term) {    const match = term.match(NAMESPACE_REGEX);    return match ? match[0] : "";}/** * Removes the namespace from a term. * @param {string} term The term which may have the namespace. * @returns {string} The name of the plugin without the namespace. */function removeNamespaceFromTerm(term) {    return term.replace(NAMESPACE_REGEX, "");}//------------------------------------------------------------------------------// Public Interface//------------------------------------------------------------------------------module.exports = {    normalizePackageName,    removePrefixFromTerm,    addPrefixToTerm,    getNamespaceFromTerm,    removeNamespaceFromTerm};
 |