You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
41 lines
1.1 KiB
41 lines
1.1 KiB
"use strict";
|
|
/**
|
|
* Returns true if the string matches the specified shell
|
|
* expression.
|
|
*
|
|
* Actually, currently the patterns are shell expressions,
|
|
* not regular expressions.
|
|
*
|
|
* Examples:
|
|
*
|
|
* ``` js
|
|
* shExpMatch("http://home.netscape.com/people/ari/index.html", "*\/ari/*")
|
|
* // is true.
|
|
*
|
|
* shExpMatch("http://home.netscape.com/people/montulli/index.html", "*\/ari/*")
|
|
* // is false.
|
|
* ```
|
|
*
|
|
* @param {String} str is any string to compare (e.g. the URL, or the hostname).
|
|
* @param {String} shexp is a shell expression to compare against.
|
|
* @return {Boolean} true if the string matches the shell expression.
|
|
*/
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
function shExpMatch(str, shexp) {
|
|
const re = toRegExp(shexp);
|
|
return re.test(str);
|
|
}
|
|
exports.default = shExpMatch;
|
|
/**
|
|
* Converts a "shell expression" to a JavaScript RegExp.
|
|
*
|
|
* @api private
|
|
*/
|
|
function toRegExp(str) {
|
|
str = String(str)
|
|
.replace(/\./g, '\\.')
|
|
.replace(/\?/g, '.')
|
|
.replace(/\*/g, '.*');
|
|
return new RegExp(`^${str}$`);
|
|
}
|
|
//# sourceMappingURL=shExpMatch.js.map
|