Spaces:
Runtime error
Runtime error
| /** | |
| * lodash (Custom Build) <https://lodash.com/> | |
| * Build: `lodash modularize exports="npm" -o ./` | |
| * Copyright jQuery Foundation and other contributors <https://jquery.org/> | |
| * Released under MIT license <https://lodash.com/license> | |
| * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
| * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
| */ | |
| /** Used as references for various `Number` constants. */ | |
| var INFINITY = 1 / 0; | |
| /** `Object#toString` result references. */ | |
| var symbolTag = '[object Symbol]'; | |
| /** Used to match words composed of alphanumeric characters. */ | |
| var reAsciiWord = /[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g; | |
| /** Used to match Latin Unicode letters (excluding mathematical operators). */ | |
| var reLatin = /[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g; | |
| /** Used to compose unicode character classes. */ | |
| var rsAstralRange = '\\ud800-\\udfff', | |
| rsComboMarksRange = '\\u0300-\\u036f\\ufe20-\\ufe23', | |
| rsComboSymbolsRange = '\\u20d0-\\u20f0', | |
| rsDingbatRange = '\\u2700-\\u27bf', | |
| rsLowerRange = 'a-z\\xdf-\\xf6\\xf8-\\xff', | |
| rsMathOpRange = '\\xac\\xb1\\xd7\\xf7', | |
| rsNonCharRange = '\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf', | |
| rsPunctuationRange = '\\u2000-\\u206f', | |
| rsSpaceRange = ' \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000', | |
| rsUpperRange = 'A-Z\\xc0-\\xd6\\xd8-\\xde', | |
| rsVarRange = '\\ufe0e\\ufe0f', | |
| rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange; | |
| /** Used to compose unicode capture groups. */ | |
| var rsApos = "['\u2019]", | |
| rsBreak = '[' + rsBreakRange + ']', | |
| rsCombo = '[' + rsComboMarksRange + rsComboSymbolsRange + ']', | |
| rsDigits = '\\d+', | |
| rsDingbat = '[' + rsDingbatRange + ']', | |
| rsLower = '[' + rsLowerRange + ']', | |
| rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']', | |
| rsFitz = '\\ud83c[\\udffb-\\udfff]', | |
| rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')', | |
| rsNonAstral = '[^' + rsAstralRange + ']', | |
| rsRegional = '(?:\\ud83c[\\udde6-\\uddff]){2}', | |
| rsSurrPair = '[\\ud800-\\udbff][\\udc00-\\udfff]', | |
| rsUpper = '[' + rsUpperRange + ']', | |
| rsZWJ = '\\u200d'; | |
| /** Used to compose unicode regexes. */ | |
| var rsLowerMisc = '(?:' + rsLower + '|' + rsMisc + ')', | |
| rsUpperMisc = '(?:' + rsUpper + '|' + rsMisc + ')', | |
| rsOptLowerContr = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?', | |
| rsOptUpperContr = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?', | |
| reOptMod = rsModifier + '?', | |
| rsOptVar = '[' + rsVarRange + ']?', | |
| rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*', | |
| rsSeq = rsOptVar + reOptMod + rsOptJoin, | |
| rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq; | |
| /** Used to match apostrophes. */ | |
| var reApos = RegExp(rsApos, 'g'); | |
| /** | |
| * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and | |
| * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols). | |
| */ | |
| var reComboMark = RegExp(rsCombo, 'g'); | |
| /** Used to match complex or compound words. */ | |
| var reUnicodeWord = RegExp([ | |
| rsUpper + '?' + rsLower + '+' + rsOptLowerContr + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')', | |
| rsUpperMisc + '+' + rsOptUpperContr + '(?=' + [rsBreak, rsUpper + rsLowerMisc, '$'].join('|') + ')', | |
| rsUpper + '?' + rsLowerMisc + '+' + rsOptLowerContr, | |
| rsUpper + '+' + rsOptUpperContr, | |
| rsDigits, | |
| rsEmoji | |
| ].join('|'), 'g'); | |
| /** Used to detect strings that need a more robust regexp to match words. */ | |
| var reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2,}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/; | |
| /** Used to map Latin Unicode letters to basic Latin letters. */ | |
| var deburredLetters = { | |
| // Latin-1 Supplement block. | |
| '\xc0': 'A', '\xc1': 'A', '\xc2': 'A', '\xc3': 'A', '\xc4': 'A', '\xc5': 'A', | |
| '\xe0': 'a', '\xe1': 'a', '\xe2': 'a', '\xe3': 'a', '\xe4': 'a', '\xe5': 'a', | |
| '\xc7': 'C', '\xe7': 'c', | |
| '\xd0': 'D', '\xf0': 'd', | |
| '\xc8': 'E', '\xc9': 'E', '\xca': 'E', '\xcb': 'E', | |
| '\xe8': 'e', '\xe9': 'e', '\xea': 'e', '\xeb': 'e', | |
| '\xcc': 'I', '\xcd': 'I', '\xce': 'I', '\xcf': 'I', | |
| '\xec': 'i', '\xed': 'i', '\xee': 'i', '\xef': 'i', | |
| '\xd1': 'N', '\xf1': 'n', | |
| '\xd2': 'O', '\xd3': 'O', '\xd4': 'O', '\xd5': 'O', '\xd6': 'O', '\xd8': 'O', | |
| '\xf2': 'o', '\xf3': 'o', '\xf4': 'o', '\xf5': 'o', '\xf6': 'o', '\xf8': 'o', | |
| '\xd9': 'U', '\xda': 'U', '\xdb': 'U', '\xdc': 'U', | |
| '\xf9': 'u', '\xfa': 'u', '\xfb': 'u', '\xfc': 'u', | |
| '\xdd': 'Y', '\xfd': 'y', '\xff': 'y', | |
| '\xc6': 'Ae', '\xe6': 'ae', | |
| '\xde': 'Th', '\xfe': 'th', | |
| '\xdf': 'ss', | |
| // Latin Extended-A block. | |
| '\u0100': 'A', '\u0102': 'A', '\u0104': 'A', | |
| '\u0101': 'a', '\u0103': 'a', '\u0105': 'a', | |
| '\u0106': 'C', '\u0108': 'C', '\u010a': 'C', '\u010c': 'C', | |
| '\u0107': 'c', '\u0109': 'c', '\u010b': 'c', '\u010d': 'c', | |
| '\u010e': 'D', '\u0110': 'D', '\u010f': 'd', '\u0111': 'd', | |
| '\u0112': 'E', '\u0114': 'E', '\u0116': 'E', '\u0118': 'E', '\u011a': 'E', | |
| '\u0113': 'e', '\u0115': 'e', '\u0117': 'e', '\u0119': 'e', '\u011b': 'e', | |
| '\u011c': 'G', '\u011e': 'G', '\u0120': 'G', '\u0122': 'G', | |
| '\u011d': 'g', '\u011f': 'g', '\u0121': 'g', '\u0123': 'g', | |
| '\u0124': 'H', '\u0126': 'H', '\u0125': 'h', '\u0127': 'h', | |
| '\u0128': 'I', '\u012a': 'I', '\u012c': 'I', '\u012e': 'I', '\u0130': 'I', | |
| '\u0129': 'i', '\u012b': 'i', '\u012d': 'i', '\u012f': 'i', '\u0131': 'i', | |
| '\u0134': 'J', '\u0135': 'j', | |
| '\u0136': 'K', '\u0137': 'k', '\u0138': 'k', | |
| '\u0139': 'L', '\u013b': 'L', '\u013d': 'L', '\u013f': 'L', '\u0141': 'L', | |
| '\u013a': 'l', '\u013c': 'l', '\u013e': 'l', '\u0140': 'l', '\u0142': 'l', | |
| '\u0143': 'N', '\u0145': 'N', '\u0147': 'N', '\u014a': 'N', | |
| '\u0144': 'n', '\u0146': 'n', '\u0148': 'n', '\u014b': 'n', | |
| '\u014c': 'O', '\u014e': 'O', '\u0150': 'O', | |
| '\u014d': 'o', '\u014f': 'o', '\u0151': 'o', | |
| '\u0154': 'R', '\u0156': 'R', '\u0158': 'R', | |
| '\u0155': 'r', '\u0157': 'r', '\u0159': 'r', | |
| '\u015a': 'S', '\u015c': 'S', '\u015e': 'S', '\u0160': 'S', | |
| '\u015b': 's', '\u015d': 's', '\u015f': 's', '\u0161': 's', | |
| '\u0162': 'T', '\u0164': 'T', '\u0166': 'T', | |
| '\u0163': 't', '\u0165': 't', '\u0167': 't', | |
| '\u0168': 'U', '\u016a': 'U', '\u016c': 'U', '\u016e': 'U', '\u0170': 'U', '\u0172': 'U', | |
| '\u0169': 'u', '\u016b': 'u', '\u016d': 'u', '\u016f': 'u', '\u0171': 'u', '\u0173': 'u', | |
| '\u0174': 'W', '\u0175': 'w', | |
| '\u0176': 'Y', '\u0177': 'y', '\u0178': 'Y', | |
| '\u0179': 'Z', '\u017b': 'Z', '\u017d': 'Z', | |
| '\u017a': 'z', '\u017c': 'z', '\u017e': 'z', | |
| '\u0132': 'IJ', '\u0133': 'ij', | |
| '\u0152': 'Oe', '\u0153': 'oe', | |
| '\u0149': "'n", '\u017f': 'ss' | |
| }; | |
| /** Detect free variable `global` from Node.js. */ | |
| var freeGlobal = typeof global == 'object' && global && global.Object === Object && global; | |
| /** Detect free variable `self`. */ | |
| var freeSelf = typeof self == 'object' && self && self.Object === Object && self; | |
| /** Used as a reference to the global object. */ | |
| var root = freeGlobal || freeSelf || Function('return this')(); | |
| /** | |
| * A specialized version of `_.reduce` for arrays without support for | |
| * iteratee shorthands. | |
| * | |
| * @private | |
| * @param {Array} [array] The array to iterate over. | |
| * @param {Function} iteratee The function invoked per iteration. | |
| * @param {*} [accumulator] The initial value. | |
| * @param {boolean} [initAccum] Specify using the first element of `array` as | |
| * the initial value. | |
| * @returns {*} Returns the accumulated value. | |
| */ | |
| function arrayReduce(array, iteratee, accumulator, initAccum) { | |
| var index = -1, | |
| length = array ? array.length : 0; | |
| if (initAccum && length) { | |
| accumulator = array[++index]; | |
| } | |
| while (++index < length) { | |
| accumulator = iteratee(accumulator, array[index], index, array); | |
| } | |
| return accumulator; | |
| } | |
| /** | |
| * Splits an ASCII `string` into an array of its words. | |
| * | |
| * @private | |
| * @param {string} The string to inspect. | |
| * @returns {Array} Returns the words of `string`. | |
| */ | |
| function asciiWords(string) { | |
| return string.match(reAsciiWord) || []; | |
| } | |
| /** | |
| * The base implementation of `_.propertyOf` without support for deep paths. | |
| * | |
| * @private | |
| * @param {Object} object The object to query. | |
| * @returns {Function} Returns the new accessor function. | |
| */ | |
| function basePropertyOf(object) { | |
| return function(key) { | |
| return object == null ? undefined : object[key]; | |
| }; | |
| } | |
| /** | |
| * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A | |
| * letters to basic Latin letters. | |
| * | |
| * @private | |
| * @param {string} letter The matched letter to deburr. | |
| * @returns {string} Returns the deburred letter. | |
| */ | |
| var deburrLetter = basePropertyOf(deburredLetters); | |
| /** | |
| * Checks if `string` contains a word composed of Unicode symbols. | |
| * | |
| * @private | |
| * @param {string} string The string to inspect. | |
| * @returns {boolean} Returns `true` if a word is found, else `false`. | |
| */ | |
| function hasUnicodeWord(string) { | |
| return reHasUnicodeWord.test(string); | |
| } | |
| /** | |
| * Splits a Unicode `string` into an array of its words. | |
| * | |
| * @private | |
| * @param {string} The string to inspect. | |
| * @returns {Array} Returns the words of `string`. | |
| */ | |
| function unicodeWords(string) { | |
| return string.match(reUnicodeWord) || []; | |
| } | |
| /** Used for built-in method references. */ | |
| var objectProto = Object.prototype; | |
| /** | |
| * Used to resolve the | |
| * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) | |
| * of values. | |
| */ | |
| var objectToString = objectProto.toString; | |
| /** Built-in value references. */ | |
| var Symbol = root.Symbol; | |
| /** Used to convert symbols to primitives and strings. */ | |
| var symbolProto = Symbol ? Symbol.prototype : undefined, | |
| symbolToString = symbolProto ? symbolProto.toString : undefined; | |
| /** | |
| * The base implementation of `_.toString` which doesn't convert nullish | |
| * values to empty strings. | |
| * | |
| * @private | |
| * @param {*} value The value to process. | |
| * @returns {string} Returns the string. | |
| */ | |
| function baseToString(value) { | |
| // Exit early for strings to avoid a performance hit in some environments. | |
| if (typeof value == 'string') { | |
| return value; | |
| } | |
| if (isSymbol(value)) { | |
| return symbolToString ? symbolToString.call(value) : ''; | |
| } | |
| var result = (value + ''); | |
| return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; | |
| } | |
| /** | |
| * Creates a function like `_.camelCase`. | |
| * | |
| * @private | |
| * @param {Function} callback The function to combine each word. | |
| * @returns {Function} Returns the new compounder function. | |
| */ | |
| function createCompounder(callback) { | |
| return function(string) { | |
| return arrayReduce(words(deburr(string).replace(reApos, '')), callback, ''); | |
| }; | |
| } | |
| /** | |
| * Checks if `value` is object-like. A value is object-like if it's not `null` | |
| * and has a `typeof` result of "object". | |
| * | |
| * @static | |
| * @memberOf _ | |
| * @since 4.0.0 | |
| * @category Lang | |
| * @param {*} value The value to check. | |
| * @returns {boolean} Returns `true` if `value` is object-like, else `false`. | |
| * @example | |
| * | |
| * _.isObjectLike({}); | |
| * // => true | |
| * | |
| * _.isObjectLike([1, 2, 3]); | |
| * // => true | |
| * | |
| * _.isObjectLike(_.noop); | |
| * // => false | |
| * | |
| * _.isObjectLike(null); | |
| * // => false | |
| */ | |
| function isObjectLike(value) { | |
| return !!value && typeof value == 'object'; | |
| } | |
| /** | |
| * Checks if `value` is classified as a `Symbol` primitive or object. | |
| * | |
| * @static | |
| * @memberOf _ | |
| * @since 4.0.0 | |
| * @category Lang | |
| * @param {*} value The value to check. | |
| * @returns {boolean} Returns `true` if `value` is a symbol, else `false`. | |
| * @example | |
| * | |
| * _.isSymbol(Symbol.iterator); | |
| * // => true | |
| * | |
| * _.isSymbol('abc'); | |
| * // => false | |
| */ | |
| function isSymbol(value) { | |
| return typeof value == 'symbol' || | |
| (isObjectLike(value) && objectToString.call(value) == symbolTag); | |
| } | |
| /** | |
| * Converts `value` to a string. An empty string is returned for `null` | |
| * and `undefined` values. The sign of `-0` is preserved. | |
| * | |
| * @static | |
| * @memberOf _ | |
| * @since 4.0.0 | |
| * @category Lang | |
| * @param {*} value The value to process. | |
| * @returns {string} Returns the string. | |
| * @example | |
| * | |
| * _.toString(null); | |
| * // => '' | |
| * | |
| * _.toString(-0); | |
| * // => '-0' | |
| * | |
| * _.toString([1, 2, 3]); | |
| * // => '1,2,3' | |
| */ | |
| function toString(value) { | |
| return value == null ? '' : baseToString(value); | |
| } | |
| /** | |
| * Deburrs `string` by converting | |
| * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table) | |
| * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A) | |
| * letters to basic Latin letters and removing | |
| * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks). | |
| * | |
| * @static | |
| * @memberOf _ | |
| * @since 3.0.0 | |
| * @category String | |
| * @param {string} [string=''] The string to deburr. | |
| * @returns {string} Returns the deburred string. | |
| * @example | |
| * | |
| * _.deburr('déjà vu'); | |
| * // => 'deja vu' | |
| */ | |
| function deburr(string) { | |
| string = toString(string); | |
| return string && string.replace(reLatin, deburrLetter).replace(reComboMark, ''); | |
| } | |
| /** | |
| * Converts `string` to | |
| * [snake case](https://en.wikipedia.org/wiki/Snake_case). | |
| * | |
| * @static | |
| * @memberOf _ | |
| * @since 3.0.0 | |
| * @category String | |
| * @param {string} [string=''] The string to convert. | |
| * @returns {string} Returns the snake cased string. | |
| * @example | |
| * | |
| * _.snakeCase('Foo Bar'); | |
| * // => 'foo_bar' | |
| * | |
| * _.snakeCase('fooBar'); | |
| * // => 'foo_bar' | |
| * | |
| * _.snakeCase('--FOO-BAR--'); | |
| * // => 'foo_bar' | |
| */ | |
| var snakeCase = createCompounder(function(result, word, index) { | |
| return result + (index ? '_' : '') + word.toLowerCase(); | |
| }); | |
| /** | |
| * Splits `string` into an array of its words. | |
| * | |
| * @static | |
| * @memberOf _ | |
| * @since 3.0.0 | |
| * @category String | |
| * @param {string} [string=''] The string to inspect. | |
| * @param {RegExp|string} [pattern] The pattern to match words. | |
| * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. | |
| * @returns {Array} Returns the words of `string`. | |
| * @example | |
| * | |
| * _.words('fred, barney, & pebbles'); | |
| * // => ['fred', 'barney', 'pebbles'] | |
| * | |
| * _.words('fred, barney, & pebbles', /[^, ]+/g); | |
| * // => ['fred', 'barney', '&', 'pebbles'] | |
| */ | |
| function words(string, pattern, guard) { | |
| string = toString(string); | |
| pattern = guard ? undefined : pattern; | |
| if (pattern === undefined) { | |
| return hasUnicodeWord(string) ? unicodeWords(string) : asciiWords(string); | |
| } | |
| return string.match(pattern) || []; | |
| } | |
| module.exports = snakeCase; | |