mirror of
https://github.com/azure/login.git
synced 2026-03-15 09:20:56 -04:00
* Bump lodash from 4.17.15 to 4.17.19 (#52) Bumps [lodash](https://github.com/lodash/lodash) from 4.17.15 to 4.17.19. - [Release notes](https://github.com/lodash/lodash/releases) - [Commits](https://github.com/lodash/lodash/compare/4.17.15...4.17.19) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Amruta Kawade <65217380+AmrutaKawade@users.noreply.github.com> * Bump @actions/core from 1.1.3 to 1.2.6 (#60) Bumps [@actions/core](https://github.com/actions/toolkit/tree/HEAD/packages/core) from 1.1.3 to 1.2.6. - [Release notes](https://github.com/actions/toolkit/releases) - [Changelog](https://github.com/actions/toolkit/blob/main/packages/core/RELEASES.md) - [Commits](https://github.com/actions/toolkit/commits/HEAD/packages/core) Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Amruta Kawade <65217380+AmrutaKawade@users.noreply.github.com> * updating node_nodules * updated package-lock Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
73 lines
1.6 KiB
JavaScript
73 lines
1.6 KiB
JavaScript
'use strict';
|
|
|
|
var extend = require('extend-shallow');
|
|
var safe = require('safe-regex');
|
|
|
|
/**
|
|
* The main export is a function that takes a `pattern` string and an `options` object.
|
|
*
|
|
* ```js
|
|
& var not = require('regex-not');
|
|
& console.log(not('foo'));
|
|
& //=> /^(?:(?!^(?:foo)$).)*$/
|
|
* ```
|
|
*
|
|
* @param {String} `pattern`
|
|
* @param {Object} `options`
|
|
* @return {RegExp} Converts the given `pattern` to a regex using the specified `options`.
|
|
* @api public
|
|
*/
|
|
|
|
function toRegex(pattern, options) {
|
|
return new RegExp(toRegex.create(pattern, options));
|
|
}
|
|
|
|
/**
|
|
* Create a regex-compatible string from the given `pattern` and `options`.
|
|
*
|
|
* ```js
|
|
& var not = require('regex-not');
|
|
& console.log(not.create('foo'));
|
|
& //=> '^(?:(?!^(?:foo)$).)*$'
|
|
* ```
|
|
* @param {String} `pattern`
|
|
* @param {Object} `options`
|
|
* @return {String}
|
|
* @api public
|
|
*/
|
|
|
|
toRegex.create = function(pattern, options) {
|
|
if (typeof pattern !== 'string') {
|
|
throw new TypeError('expected a string');
|
|
}
|
|
|
|
var opts = extend({}, options);
|
|
if (opts.contains === true) {
|
|
opts.strictNegate = false;
|
|
}
|
|
|
|
var open = opts.strictOpen !== false ? '^' : '';
|
|
var close = opts.strictClose !== false ? '$' : '';
|
|
var endChar = opts.endChar ? opts.endChar : '+';
|
|
var str = pattern;
|
|
|
|
if (opts.strictNegate === false) {
|
|
str = '(?:(?!(?:' + pattern + ')).)' + endChar;
|
|
} else {
|
|
str = '(?:(?!^(?:' + pattern + ')$).)' + endChar;
|
|
}
|
|
|
|
var res = open + str + close;
|
|
if (opts.safe === true && safe(res) === false) {
|
|
throw new Error('potentially unsafe regular expression: ' + res);
|
|
}
|
|
|
|
return res;
|
|
};
|
|
|
|
/**
|
|
* Expose `toRegex`
|
|
*/
|
|
|
|
module.exports = toRegex;
|