|
|
|
|
@@ -54,21 +54,6 @@
|
|
|
|
|
<pre
|
|
|
|
|
class="sunlight-highlight-javascript linenums">'use strict';
|
|
|
|
|
|
|
|
|
|
var wildstring = (function (name, definition) {
|
|
|
|
|
if (typeof(module) !== 'undefined') {
|
|
|
|
|
module.exports = definition();
|
|
|
|
|
}
|
|
|
|
|
else if (typeof(define) === 'function' && typeof(define.amd) === 'object') {
|
|
|
|
|
define(definition);
|
|
|
|
|
}
|
|
|
|
|
else if (typeof(this) !== 'undefined') {
|
|
|
|
|
this[name] = definition();
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
return definition();
|
|
|
|
|
}
|
|
|
|
|
}('wildstring', function () {
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @namespace wildstring
|
|
|
|
|
* @property {string} wildcard the wildcard to use in your strings, defaults to '*'
|
|
|
|
|
@@ -76,17 +61,16 @@ var wildstring = (function (name, definition) {
|
|
|
|
|
*/
|
|
|
|
|
var wildstring = {
|
|
|
|
|
wildcard: '*',
|
|
|
|
|
caseSensitive: true
|
|
|
|
|
};
|
|
|
|
|
caseSensitive: true,
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* When a match doesn't continue to the end of the string, this function rolls back to try again with the rest of the string
|
|
|
|
|
* @memberof wildstring
|
|
|
|
|
* @access private
|
|
|
|
|
* @param {string[]} rollbackStrings The list of substrings that appeared prior to the current match
|
|
|
|
|
* @param {string[]} patternSubstrings The matching list of pattens that need to be matched before the current pattern
|
|
|
|
|
*/
|
|
|
|
|
function checkRollbackStrings (rollbackStrings, patternSubstrings) {
|
|
|
|
|
/**
|
|
|
|
|
* When a match doesn't continue to the end of the string, this function rolls back to try again with the rest of the string
|
|
|
|
|
* @memberof wildstring
|
|
|
|
|
* @access private
|
|
|
|
|
* @param {string[]} rollbackStrings The list of substrings that appeared prior to the current match
|
|
|
|
|
* @param {string[]} patternSubstrings The matching list of pattens that need to be matched before the current pattern
|
|
|
|
|
*/
|
|
|
|
|
checkRollbackStrings: function (rollbackStrings, patternSubstrings) {
|
|
|
|
|
for (var s = 0; s < rollbackStrings.length; ++s) {
|
|
|
|
|
var currentString = rollbackStrings[s].string; // starting with the rolled back string
|
|
|
|
|
var patternIndex = rollbackStrings[s].index;
|
|
|
|
|
@@ -126,15 +110,15 @@ function checkRollbackStrings (rollbackStrings, patternSubstrings) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Check if a string matches a pattern
|
|
|
|
|
* @memberof wildstring
|
|
|
|
|
* @param {string} pattern The pattern to match using the configured wildcard
|
|
|
|
|
* @param {string} string The string to test for a match
|
|
|
|
|
*/
|
|
|
|
|
wildstring.match = function (pattern, string) {
|
|
|
|
|
/**
|
|
|
|
|
* Check if a string matches a pattern
|
|
|
|
|
* @memberof wildstring
|
|
|
|
|
* @param {string} pattern The pattern to match using the configured wildcard
|
|
|
|
|
* @param {string} string The string to test for a match
|
|
|
|
|
*/
|
|
|
|
|
match: function (pattern, string) {
|
|
|
|
|
// if there are no wildcards, must be exact
|
|
|
|
|
if (pattern.indexOf(wildstring.wildcard) === -1) {
|
|
|
|
|
return pattern === string;
|
|
|
|
|
@@ -166,7 +150,7 @@ wildstring.match = function (pattern, string) {
|
|
|
|
|
|
|
|
|
|
while (patternIndex < patternSubstrings.length) {
|
|
|
|
|
if (currentString.indexOf(patternSubstrings[patternIndex]) === -1) {
|
|
|
|
|
return checkRollbackStrings(rollbackStrings, patternSubstrings);
|
|
|
|
|
return wildstring.checkRollbackStrings(rollbackStrings, patternSubstrings);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// create a queue of strings to roll back and try again if we fail later
|
|
|
|
|
@@ -194,24 +178,24 @@ wildstring.match = function (pattern, string) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return checkRollbackStrings(rollbackStrings, patternSubstrings);
|
|
|
|
|
return wildstring.checkRollbackStrings(rollbackStrings, patternSubstrings);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Replace wildcards in a pattern with strings (string interpolation)
|
|
|
|
|
* @memberof wildstring
|
|
|
|
|
* @param {string} pattern The start string, using wildcards as placeholders
|
|
|
|
|
* @param {string|string[]} strings The string or strings to replace the wildcards in the pattern.
|
|
|
|
|
* If you pass a single string, it will replace all the wildcards with the string.
|
|
|
|
|
* If you pass an array of strings, they will replace the wildcards in order from left to right.
|
|
|
|
|
* @throws The number of items in the strings array (if you pass an array) must match the number of wildcards in the pattern string.
|
|
|
|
|
* @throws You need to pass both parameters
|
|
|
|
|
* @throws You need to pass the right types
|
|
|
|
|
*/
|
|
|
|
|
wildstring.replace = function (pattern, strings) {
|
|
|
|
|
/**
|
|
|
|
|
* Replace wildcards in a pattern with strings (string interpolation)
|
|
|
|
|
* @memberof wildstring
|
|
|
|
|
* @param {string} pattern The start string, using wildcards as placeholders
|
|
|
|
|
* @param {string|string[]} strings The string or strings to replace the wildcards in the pattern.
|
|
|
|
|
* If you pass a single string, it will replace all the wildcards with the string.
|
|
|
|
|
* If you pass an array of strings, they will replace the wildcards in order from left to right.
|
|
|
|
|
* @throws The number of items in the strings array (if you pass an array) must match the number of wildcards in the pattern string.
|
|
|
|
|
* @throws You need to pass both parameters
|
|
|
|
|
* @throws You need to pass the right types
|
|
|
|
|
*/
|
|
|
|
|
replace: function (pattern, strings) {
|
|
|
|
|
if (pattern === undefined || strings === undefined) {
|
|
|
|
|
throw new Error('wildstring.replace takes the pattern as one parameter and either a string or an array of strings as the second. You didn\'t pass enough parameters.');
|
|
|
|
|
}
|
|
|
|
|
@@ -239,10 +223,12 @@ wildstring.replace = function (pattern, strings) {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return wildstring;
|
|
|
|
|
}));
|
|
|
|
|
if (typeof(module) !== 'undefined') { module.exports = wildstring; }
|
|
|
|
|
if (typeof(angular) !== 'undefined') { angular.module('wildstring').factory = wildstring; }
|
|
|
|
|
if (typeof(define) !== 'undefined') { define([], wildstring); }
|
|
|
|
|
</pre>
|
|
|
|
|
</article>
|
|
|
|
|
</section>
|
|
|
|
|
@@ -272,7 +258,7 @@ return wildstring;
|
|
|
|
|
|
|
|
|
|
<span class="jsdoc-message">
|
|
|
|
|
Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.3.2</a>
|
|
|
|
|
on Sun Aug 9th 2015 using the <a
|
|
|
|
|
on Wed Aug 12th 2015 using the <a
|
|
|
|
|
href="https://github.com/terryweiss/docstrap">DocStrap template</a>.
|
|
|
|
|
</span>
|
|
|
|
|
</footer>
|
|
|
|
|
|