22 lines
968 B
JavaScript
22 lines
968 B
JavaScript
|
"use strict";
|
||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||
|
exports.escape = void 0;
|
||
|
/**
|
||
|
* Escape all magic characters in a glob pattern.
|
||
|
*
|
||
|
* If the {@link windowsPathsNoEscape | GlobOptions.windowsPathsNoEscape}
|
||
|
* option is used, then characters are escaped by wrapping in `[]`, because
|
||
|
* a magic character wrapped in a character class can only be satisfied by
|
||
|
* that exact character. In this mode, `\` is _not_ escaped, because it is
|
||
|
* not interpreted as a magic character, but instead as a path separator.
|
||
|
*/
|
||
|
const escape = (s, { windowsPathsNoEscape = false, } = {}) => {
|
||
|
// don't need to escape +@! because we escape the parens
|
||
|
// that make those magic, and escaping ! as [!] isn't valid,
|
||
|
// because [!]] is a valid glob class meaning not ']'.
|
||
|
return windowsPathsNoEscape
|
||
|
? s.replace(/[?*()[\]]/g, '[$&]')
|
||
|
: s.replace(/[?*()[\]\\]/g, '\\$&');
|
||
|
};
|
||
|
exports.escape = escape;
|
||
|
//# sourceMappingURL=escape.js.map
|