20 lines
847 B
JavaScript
20 lines
847 B
JavaScript
/**
|
|
* Un-escape a string that has been escaped with {@link escape}.
|
|
*
|
|
* If the {@link windowsPathsNoEscape} option is used, then square-brace
|
|
* escapes are removed, but not backslash escapes. For example, it will turn
|
|
* the string `'[*]'` into `*`, but it will not turn `'\\*'` into `'*'`,
|
|
* becuase `\` is a path separator in `windowsPathsNoEscape` mode.
|
|
*
|
|
* When `windowsPathsNoEscape` is not set, then both brace escapes and
|
|
* backslash escapes are removed.
|
|
*
|
|
* Slashes (and backslashes in `windowsPathsNoEscape` mode) cannot be escaped
|
|
* or unescaped.
|
|
*/
|
|
export const unescape = (s, { windowsPathsNoEscape = false, } = {}) => {
|
|
return windowsPathsNoEscape
|
|
? s.replace(/\[([^\/\\])\]/g, '$1')
|
|
: s.replace(/((?!\\).|^)\[([^\/\\])\]/g, '$1$2').replace(/\\([^\/])/g, '$1');
|
|
};
|
|
//# sourceMappingURL=unescape.js.map
|