1
|
{"version":3,"sources":["node_modules/base64-js/index.js","node_modules/ieee754/index.js","node_modules/isarray/index.js","node_modules/buffer/index.js","../style-spec.js","../../../node_modules/json-stringify-pretty-compact/index.js","../format.js","../../../node_modules/url/node_modules/punycode/punycode.js","../../../node_modules/url/util.js","../../../node_modules/querystring/decode.js","../../../node_modules/querystring/encode.js","../../../node_modules/querystring/index.js","../../../node_modules/url/url.js","../visit.js","../migrate/v8.js","../util/extend.js","../expression/parsing_error.js","../expression/scope.js","../expression/types.js","../../../node_modules/csscolorparser/csscolorparser.js","../util/color.js","../expression/types/collator.js","../expression/types/formatted.js","../expression/values.js","../expression/definitions/literal.js","../expression/runtime_error.js","../expression/definitions/assertion.js","../expression/definitions/format.js","../expression/definitions/coercion.js","../expression/evaluation_context.js","../expression/compound_expression.js","../expression/definitions/collator.js","../expression/is_constant.js","../expression/definitions/var.js","../expression/parsing_context.js","../expression/stops.js","../expression/definitions/step.js","../../../node_modules/@mapbox/unitbezier/index.js","../util/interpolate.js","../util/color_spaces.js","../expression/definitions/interpolate.js","../expression/definitions/coalesce.js","../expression/definitions/let.js","../expression/definitions/at.js","../expression/definitions/match.js","../expression/definitions/case.js","../expression/definitions/comparison.js","../expression/definitions/length.js","../expression/definitions/index.js","../util/result.js","../util/properties.js","../util/get_type.js","../function/index.js","../expression/index.js","../function/convert.js","../feature_filter/index.js","../feature_filter/convert.js","../util/deep_equal.js","../diff.js","../error/validation_error.js","../error/parsing_error.js","../validate/validate_constants.js","../util/unbundle_jsonlint.js","../validate/validate_object.js","../validate/validate_array.js","../validate/validate_number.js","../validate/validate_function.js","../validate/validate_expression.js","../validate/validate_enum.js","../validate/validate_filter.js","../validate/validate_property.js","../validate/validate_paint_property.js","../validate/validate_layout_property.js","../validate/validate_layer.js","../validate/validate_source.js","../validate/validate_light.js","../validate/validate_string.js","../validate/validate.js","../validate/validate_boolean.js","../validate/validate_color.js","../validate/validate_formatted.js","../validate/validate_glyphs_url.js","../validate_style.min.js","../../../node_modules/@mapbox/jsonlint-lines-primitives/lib/jsonlint.js","../validate_style.js","../migrate.js","../migrate/expressions.js","../composite.js","node_modules/@mapbox/mapbox-gl-style-spec/util/ref_properties.js","node_modules/@mapbox/mapbox-gl-style-spec/deref.js","node_modules/@mapbox/mapbox-gl-style-spec/migrate/v9.js","node_modules/codemirror/lib/codemirror.js","node_modules/codemirror/mode/elm/elm.js","node_modules/codemirror/mode/javascript/javascript.js","index.js"],"names":["sortKeysBy","obj","reference","const","result","key","undefined","global","this","require$$0","require$$1","getPropertyReference","propertyName","let","i","Reference","layout","length","paint","eachSource","style","callback","k","sources","eachLayer","layers","eachProperty","options","inner","layer","propertyType","properties","Object","keys","forEach","path","id","value","set","x","eachLayout","indexOf","eachPaint","resolveConstant","constants","renameProperty","from","to","Array","isArray","stops","ParsingError","message","super","Error","Scope","parent","bindings","ref","name","expression","concat","get","has","NullType","kind","NumberType","StringType","BooleanType","ColorType","ObjectType","ValueType","CollatorType","FormattedType","array","itemType","N","toString","type","valueMemberTypes","checkSubtype","expected","t","Color","r","g","b","a","parse","input","rgba","parseCSSColor","toArray","Math","round","black","white","transparent","red","Collator","caseSensitive","diacriticSensitive","locale","sensitivity","collator","Intl","usage","compare","lhs","rhs","resolvedLocale","resolvedOptions","FormattedSection","text","scale","fontStack","Formatted","sections","validateRGBA","join","typeOf","String","JSON","stringify","fromString","unformatted","map","section","serialize","serialized","push","split","Literal","args","context","error","isValue","mixed","expectedType","evaluate","eachChild","possibleOutputs","RuntimeError","toJSON","types","string","number","boolean","object","Assertion","floor","parsed","ctx","fn","arg","FormatExpression","font","Coercion","Boolean","c","parseColor","num","Number","isNaN","valueToString","child","geometryTypes","EvaluationContext","globals","feature","featureState","_parseColorCache","geometryType","cached","CompoundExpression","_evaluate","op","definition","definitions","availableOverloads","overloads","filter","signature","signatureContext","params","ParsingContext","registry","scope","parsedArgs","argParseFailed","errors","ref$1","signatures","stringifySignature","actualTypes","register","CollatorExpression","isFeatureConstant","e","test","isStateConstant","isGlobalPropertyConstant","Var","boundExpression","part","findStopLessThanOrEqualTo","currentValue","upperValue","lowerIndex","upperIndex","currentIndex","max","expr","index","_parse","annotate","typeAnnotation","Expr","actual","isConstant","isTypeAnnotation","childrenConstant","ec","Step","labels","outputs","label","rest","outputType","unshift","Infinity","labelKey","valueKey","stopCount","output","d","Xn","Yn","Zn","t0","t1","t2","t3","deg2rad","PI","rad2deg","xyz2lab","pow","lab2xyz","xyz2rgb","rgb2xyz","rgbToLab","rgbColor","l","y","alpha","labToRgb","labColor","z","interpolateHue","lab","forward","reverse","interpolate","interpolateNumber","hcl","h","atan2","sqrt","hclColor","cos","sin","Interpolate","operator","interpolation","exponentialInterpolation","base","lowerValue","difference","progress","interpolationFactor","lower","upper","controlPoints","UnitBezier","solve","slice","some","outputLower","outputUpper","toLowerCase","Coalesce","needsAnnotation","Let","At","Match","inputType","cases","otherwise","labelContext","abs","MAX_SAFE_INTEGER","out","groupedByOutput","outputLookup","sortedLabels","sort","outputIndex","coerceLabel","Case","branches","isComparableType","eqCollate","makeComparison","compareBasic","compareWithCollator","isOrderComparison","hasUntypedArgument","Comparison","lt","rt","Equals","NotEquals","LessThan","GreaterThan","LessThanOrEqual","GreaterThanOrEqual","Length","expressions","v","varargs","success","supportsPropertyExpression","spec","supportsZoomExpression","parameters","supportsInterpolation","interpolated","getType","val","isFunction","identityFunction","createFunction","propertySpec","innerFun","hashedStops","categoricalKeyType","isColor","zoomAndFeatureDependent","featureDependent","property","zoomDependent","extend","stop","default","colorSpace","colorSpaces","evaluateExponentialFunction","evaluateIntervalFunction","evaluateCategoricalFunction","create","evaluateIdentityFunction","featureFunctions","zoomStops","s","zoom","featureFunctionStops","bind","_","coalesce","keyType","n","interp","colorspace","evaluatedLower","apply","evaluatedUpper","values","typeToString","heatmapDensity","lineProgress","LN2","E","log","LN10","tan","asin","acos","atan","min","ceil","binarySearch","j","m","isSupportedScript","toUpperCase","StyleExpression","_warningHistory","_evaluator","_defaultValue","_enumValues","isExpression","createExpression","parser","color","enum","formatted","getExpectedType","evaluateWithoutErrorHandling","console","warn","ZoomConstantExpression","_styleExpression","isStateDependent","ZoomDependentExpression","zoomCurve","_interpolationType","createPropertyExpression","isZoomConstant","findZoomCurve","childResult","StylePropertyFunction","specification","_parameters","_specification","convertLiteral","convertFunction","splice","convertIdentityFunction","tokens","convertTokenString","featureFunctionParameters","getFunctionType","getInterpolateOperator","convertPropertyFunction","appendStopPair","fixupDegenerateStepCurve","convertZoomAndPropertyFunction","isStep","convertZoomFunction","curve","re","pos","match","exec","literal","lastIndex","isExpressionFilter","f","deserialize","filterSpec","convertFilter","filters","convertComparisonOp","convertNegation","convertInOp","convertHasOp","_convertFilter","expectedTypes","converted","children","typechecks","conditions","runtimeTypeChecks","negate","uniformTypes","deepEqual","operations","setStyle","addLayer","removeLayer","setPaintProperty","setLayoutProperty","setFilter","addSource","removeSource","setGeoJSONSourceData","setLayerZoomRange","setLayerProperty","setCenter","setZoom","setBearing","setPitch","setSprite","setGlyphs","setTransition","setLight","sourceId","after","commands","command","sourcesRemoved","updateSource","canUpdateGeoJSON","before","prop","hasOwnProperty","isEqual","diffLayerPropertyChanges","layerId","klass","pluckId","indexById","group","ValidationError","identifier","__line__","line","parseInt","validateConstants","unbundle","valueOf","deepUnbundle","validateObject","elementSpecs","valueSpec","elementValidators","objectElementValidators","styleSpec","objectKey","elementSpecKey","elementSpec","validateElement","validateSpec","required","validateArray","arraySpec","validateArrayElement","arrayElementValidator","validate","arrayElementSpec","$version","function","arrayIndex","validateNumber","minimum","maximum","validateFunction","stopKeyType","previousStopDomainValue","previousStopDomainZoom","functionValueSpec","functionType","stopDomainValues","isZoomFunction","isPropertyFunction","isZoomAndPropertyFunction","validateFunctionStop","validateStopDomainValue","reportValue","isFinite","validateExpression","expressionContext","propertyKey","validateEnum","validateFilter","validateNonExpressionFilter","filter_operator","geometry_type","validateProperty","layerSpec","layerType","transitionMatch","transition","tokenMatch","glyphs","validatePaintProperty","validateLayoutProperty","validateLayer","otherLayer","p","source","sourceType","lineMetrics","validateSource","replace","source_geojson","source_video","source_image","validateLight","light","lightSpec","rootType","validateString","VALIDATORS","validateStyleMin","latestStyleSpec","$root","validateGlyphsURL","sortErrors","wrapCleanErrors","paintProperty","layoutProperty","validateStyle","Buffer","jsonlint","v8","normalizePropertyExpression","err","constant","styleFunction","visit","latest","space","stringifyPretty","indent","version","center","bearing","pitch","sprite","removeOrAddSourceCommands","data","diffSources","beforeLayers","beforeLayer","afterLayer","insertBeforeLayerId","beforeOrder","afterOrder","beforeIndex","reduce","afterIndex","tracker","clean","lastIndexOf","minzoom","maxzoom","diffLayers","compiled","globalProperties","deref","derefLayers","app","Elm","Main","init","customElements","define","_editorValue","HTMLElement","_editor","identUnit","mode","_mode","lineNumbers","readOnly","_readonly","lineWrapping","on","getValue","dispatchEvent","CustomEvent","detail","getBoundingClientRect","width","height","setSize","setValue","setOption","ports","requestStyleUpgrade","subscribe","migrated","styleUpgradeComplete","send"],"mappings":"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GAAK,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,EAAI,CAAC,EAAE,IAAI,EAAE,EAAI,CAAC,EAAE,IAAI,EAAE,EAAI,CAAC,EAAE,IAAI,EAAE,EAAI,CAAC,EAAE,KAAK,EAAE,EAAI,CAAC,EAAE,KAAK,EAAE,EAAI,CAAC,EAAE,KAAK,EAAE,EAAI,CAAC,EAAE,IAAI,EAAE,EAAI,CAAC,EAAE,IAAI,EAAE,EAAI,CAAC,EAAE,IAAI,EAAE,CAAC,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,EAAE,EAAI,CAAC,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,EAAI,GAAG,CAAC,EAAE,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,EAAE,EAAE,EAAI,EAAE,EAAE,EAAE,EAAI,EAAE,EAAE,EAAE,EAAI,EAAE,EAAE,GAAG,EAAI,GAAG,EAAI,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAI,GAAG,EAAI,GAAG,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,EAAI,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,GAAG,CAAC,EAAE,KAAK,EAAE,EAAI,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,EAAI,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,IAAI,GAAG,CAAC,EAAE,KAAK,EAAE,EAAI,CAAC,EAAE,KAAK,EAAE,EAAI,CAAC,EAAE,KAAK,CAAC,EAAE,GAAG,EAAE,EAAI,GAAG,IAAI,CAAC,EAAE,EAAE,EAAE,EAAI,EAAE,EAAE,EAAE,EAAI,EAAE,EAAE,EAAE,EAAI,EAAE,EAAE,GAAG,EAAI,GAAG,EAAI,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAI,GAAG,GAAK,EAAE,EAAI,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,EAAE,EAAI,EAAE,EAAE,EAAE,EAAI,EAAE,EAAE,EAAE,EAAI,EAAE,EAAE,GAAG,EAAI,GAAG,EAAI,GAAG,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAI,GAAG,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","file":"style-generator.3de3c5f3.map","sourceRoot":"../../style-generator","sourcesContent":["'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n for (var i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('isarray')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n * incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n ? global.TYPED_ARRAY_SUPPORT\n : typedArraySupport()\n\n/*\n * Export kMaxLength after typed array support is determined.\n */\nexports.kMaxLength = kMaxLength()\n\nfunction typedArraySupport () {\n try {\n var arr = new Uint8Array(1)\n arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n return arr.foo() === 42 && // typed array instances can be augmented\n typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n } catch (e) {\n return false\n }\n}\n\nfunction kMaxLength () {\n return Buffer.TYPED_ARRAY_SUPPORT\n ? 0x7fffffff\n : 0x3fffffff\n}\n\nfunction createBuffer (that, length) {\n if (kMaxLength() < length) {\n throw new RangeError('Invalid typed array length')\n }\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = new Uint8Array(length)\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n if (that === null) {\n that = new Buffer(length)\n }\n that.length = length\n }\n\n return that\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n return new Buffer(arg, encodingOrOffset, length)\n }\n\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new Error(\n 'If encoding is specified then the first argument must be a string'\n )\n }\n return allocUnsafe(this, arg)\n }\n return from(this, arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n arr.__proto__ = Buffer.prototype\n return arr\n}\n\nfunction from (that, value, encodingOrOffset, length) {\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number')\n }\n\n if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n return fromArrayBuffer(that, value, encodingOrOffset, length)\n }\n\n if (typeof value === 'string') {\n return fromString(that, value, encodingOrOffset)\n }\n\n return fromObject(that, value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(null, value, encodingOrOffset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n Buffer.prototype.__proto__ = Uint8Array.prototype\n Buffer.__proto__ = Uint8Array\n if (typeof Symbol !== 'undefined' && Symbol.species &&\n Buffer[Symbol.species] === Buffer) {\n // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n Object.defineProperty(Buffer, Symbol.species, {\n value: null,\n configurable: true\n })\n }\n}\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be a number')\n } else if (size < 0) {\n throw new RangeError('\"size\" argument must not be negative')\n }\n}\n\nfunction alloc (that, size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(that, size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpretted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(that, size).fill(fill, encoding)\n : createBuffer(that, size).fill(fill)\n }\n return createBuffer(that, size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(null, size, fill, encoding)\n}\n\nfunction allocUnsafe (that, size) {\n assertSize(size)\n that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) {\n for (var i = 0; i < size; ++i) {\n that[i] = 0\n }\n }\n return that\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(null, size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(null, size)\n}\n\nfunction fromString (that, string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('\"encoding\" must be a valid string encoding')\n }\n\n var length = byteLength(string, encoding) | 0\n that = createBuffer(that, length)\n\n var actual = that.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n that = that.slice(0, actual)\n }\n\n return that\n}\n\nfunction fromArrayLike (that, array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n that = createBuffer(that, length)\n for (var i = 0; i < length; i += 1) {\n that[i] = array[i] & 255\n }\n return that\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\\'offset\\' is out of bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\\'length\\' is out of bounds')\n }\n\n if (byteOffset === undefined && length === undefined) {\n array = new Uint8Array(array)\n } else if (length === undefined) {\n array = new Uint8Array(array, byteOffset)\n } else {\n array = new Uint8Array(array, byteOffset, length)\n }\n\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = array\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n that = fromArrayLike(that, array)\n }\n return that\n}\n\nfunction fromObject (that, obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n that = createBuffer(that, len)\n\n if (that.length === 0) {\n return that\n }\n\n obj.copy(that, 0, 0, len)\n return that\n }\n\n if (obj) {\n if ((typeof ArrayBuffer !== 'undefined' &&\n obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n if (typeof obj.length !== 'number' || isnan(obj.length)) {\n return createBuffer(that, 0)\n }\n return fromArrayLike(that, obj)\n }\n\n if (obj.type === 'Buffer' && isArray(obj.data)) {\n return fromArrayLike(that, obj.data)\n }\n }\n\n throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n // Note: cannot use `length < kMaxLength()` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= kMaxLength()) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + kMaxLength().toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('Arguments must be Buffers')\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n buf.copy(buffer, pos)\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n string = '' + string\n }\n\n var len = string.length\n if (len === 0) return 0\n\n // Use a for loop to avoid recursion\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n case undefined:\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) return utf8ToBytes(string).length // assume utf8\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n var length = this.length | 0\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n var str = ''\n var max = exports.INSPECT_MAX_BYTES\n if (this.length > 0) {\n str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n if (this.length > max) str += ' ... '\n }\n return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('Argument must be a Buffer')\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (isNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (Buffer.TYPED_ARRAY_SUPPORT &&\n typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n var indexSize = 1\n var arrLength = arr.length\n var valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n var i\n if (dir) {\n var foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n var found = true\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n var remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n // must be an even number of digits\n var strLen = string.length\n if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (isNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset | 0\n if (isFinite(length)) {\n length = length | 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n // legacy write(string, encoding, offset, length) - remove in v0.13\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n return asciiWrite(this, string, offset, length)\n\n case 'latin1':\n case 'binary':\n return latin1Write(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF) ? 4\n : (firstByte > 0xDF) ? 3\n : (firstByte > 0xBF) ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = ''\n var i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += toHex(buf[i])\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n for (var i = 0; i < bytes.length; i += 2) {\n res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n newBuf = this.subarray(start, end)\n newBuf.__proto__ = Buffer.prototype\n } else {\n var sliceLen = end - start\n newBuf = new Buffer(sliceLen, undefined)\n for (var i = 0; i < sliceLen; ++i) {\n newBuf[i] = this[i + start]\n }\n }\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var i = byteLength\n var mul = 1\n var val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {\n buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n (littleEndian ? i : 1 - i) * 8\n }\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffffffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {\n buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n }\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n var i\n\n if (this === target && start < targetStart && targetStart < end) {\n // descending copy from end\n for (i = len - 1; i >= 0; --i) {\n target[i + targetStart] = this[i + start]\n }\n } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n // ascending copy from start\n for (i = 0; i < len; ++i) {\n target[i + targetStart] = this[i + start]\n }\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, start + len),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if (code < 256) {\n val = code\n }\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n } else if (typeof val === 'number') {\n val = val & 255\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : utf8ToBytes(new Buffer(val, encoding).toString())\n var len = bytes.length\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction stringtrim (str) {\n if (str.trim) return str.trim()\n return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n if (n < 16) return '0' + n.toString(16)\n return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n var c, hi, lo\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\nfunction isnan (val) {\n return val !== val // eslint-disable-line no-self-compare\n}\n","// @flow\n\ntype ExpressionType = 'data-driven' | 'cross-faded' | 'cross-faded-data-driven' | 'color-ramp' | 'data-constant' | 'constant';\ntype ExpressionParameters = Array<'zoom' | 'feature' | 'feature-state' | 'heatmap-density' | 'line-progress'>;\n\ntype ExpressionSpecification = {\n interpolated: boolean,\n parameters: ExpressionParameters\n}\n\nexport type StylePropertySpecification = {\n type: 'number',\n 'property-type': ExpressionType,\n expression?: ExpressionSpecification,\n transition: boolean,\n default?: number\n} | {\n type: 'string',\n 'property-type': ExpressionType,\n expression?: ExpressionSpecification,\n transition: boolean,\n default?: string,\n tokens?: boolean\n} | {\n type: 'boolean',\n 'property-type': ExpressionType,\n expression?: ExpressionSpecification,\n transition: boolean,\n default?: boolean\n} | {\n type: 'enum',\n 'property-type': ExpressionType,\n expression?: ExpressionSpecification,\n values: {[string]: {}},\n transition: boolean,\n default?: string\n} | {\n type: 'color',\n 'property-type': ExpressionType,\n expression?: ExpressionSpecification,\n transition: boolean,\n default?: string\n} | {\n type: 'array',\n value: 'number',\n 'property-type': ExpressionType,\n expression?: ExpressionSpecification,\n length?: number,\n transition: boolean,\n default?: Array<number>\n} | {\n type: 'array',\n value: 'string',\n 'property-type': ExpressionType,\n expression?: ExpressionSpecification,\n length?: number,\n transition: boolean,\n default?: Array<string>\n};\n\nimport v8 from './reference/v8.json';\nimport latest from './reference/latest';\nimport format from './format';\nimport migrate from './migrate';\nimport composite from './composite';\nimport diff from './diff';\nimport ValidationError from './error/validation_error';\nimport ParsingError from './error/parsing_error';\nimport { StyleExpression, isExpression, createExpression, createPropertyExpression, normalizePropertyExpression, ZoomConstantExpression, ZoomDependentExpression, StylePropertyFunction } from './expression';\nimport featureFilter from './feature_filter';\nimport Color from './util/color';\nimport { createFunction, isFunction } from './function';\nimport convertFunction from './function/convert';\nimport { eachSource, eachLayer, eachProperty } from './visit';\n\nimport validate from './validate_style';\n\nconst expression = {\n StyleExpression,\n isExpression,\n createExpression,\n createPropertyExpression,\n normalizePropertyExpression,\n ZoomConstantExpression,\n ZoomDependentExpression,\n StylePropertyFunction\n};\n\nconst styleFunction = {\n convertFunction,\n createFunction,\n isFunction\n};\n\nconst visit = { eachSource, eachLayer, eachProperty };\n\nexport {\n v8,\n latest,\n format,\n migrate,\n composite,\n diff,\n ValidationError,\n ParsingError,\n expression,\n featureFilter,\n Color,\n styleFunction as function,\n validate,\n visit\n};\n\nvalidate.parsed = validate;\nvalidate.latest = validate;\n","function stringify (obj, options) {\n options = options || {}\n var indent = JSON.stringify([1], null, get(options, 'indent', 2)).slice(2, -3)\n var addMargin = get(options, 'margins', false)\n var maxLength = (indent === '' ? Infinity : get(options, 'maxLength', 80))\n\n return (function _stringify (obj, currentIndent, reserved) {\n if (obj && typeof obj.toJSON === 'function') {\n obj = obj.toJSON()\n }\n\n var string = JSON.stringify(obj)\n\n if (string === undefined) {\n return string\n }\n\n var length = maxLength - currentIndent.length - reserved\n\n if (string.length <= length) {\n var prettified = prettify(string, addMargin)\n if (prettified.length <= length) {\n return prettified\n }\n }\n\n if (typeof obj === 'object' && obj !== null) {\n var nextIndent = currentIndent + indent\n var items = []\n var delimiters\n var comma = function (array, index) {\n return (index === array.length - 1 ? 0 : 1)\n }\n\n if (Array.isArray(obj)) {\n for (var index = 0; index < obj.length; index++) {\n items.push(\n _stringify(obj[index], nextIndent, comma(obj, index)) || 'null'\n )\n }\n delimiters = '[]'\n } else {\n Object.keys(obj).forEach(function (key, index, array) {\n var keyPart = JSON.stringify(key) + ': '\n var value = _stringify(obj[key], nextIndent,\n keyPart.length + comma(array, index))\n if (value !== undefined) {\n items.push(keyPart + value)\n }\n })\n delimiters = '{}'\n }\n\n if (items.length > 0) {\n return [\n delimiters[0],\n indent + items.join(',\\n' + nextIndent),\n delimiters[1]\n ].join('\\n' + currentIndent)\n }\n }\n\n return string\n }(obj, '', 0))\n}\n\n// Note: This regex matches even invalid JSON strings, but since we’re\n// working on the output of `JSON.stringify` we know that only valid strings\n// are present (unless the user supplied a weird `options.indent` but in\n// that case we don’t care since the output would be invalid anyway).\nvar stringOrChar = /(\"(?:[^\\\\\"]|\\\\.)*\")|[:,\\][}{]/g\n\nfunction prettify (string, addMargin) {\n var m = addMargin ? ' ' : ''\n var tokens = {\n '{': '{' + m,\n '[': '[' + m,\n '}': m + '}',\n ']': m + ']',\n ',': ', ',\n ':': ': '\n }\n return string.replace(stringOrChar, function (match, string) {\n return string ? match : tokens[match]\n })\n}\n\nfunction get (options, name, defaultValue) {\n return (name in options ? options[name] : defaultValue)\n}\n\nmodule.exports = stringify\n","\nimport reference from './reference/latest.js';\nimport stringifyPretty from 'json-stringify-pretty-compact';\n\nfunction sortKeysBy(obj, reference) {\n const result = {};\n for (const key in reference) {\n if (obj[key] !== undefined) {\n result[key] = obj[key];\n }\n }\n for (const key in obj) {\n if (result[key] === undefined) {\n result[key] = obj[key];\n }\n }\n return result;\n}\n\n/**\n * Format a Mapbox GL Style. Returns a stringified style with its keys\n * sorted in the same order as the reference style.\n *\n * The optional `space` argument is passed to\n * [`JSON.stringify`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify)\n * to generate formatted output.\n *\n * If `space` is unspecified, a default of `2` spaces will be used.\n *\n * @private\n * @param {Object} style a Mapbox GL Style\n * @param {number} [space] space argument to pass to `JSON.stringify`\n * @returns {string} stringified formatted JSON\n * @example\n * var fs = require('fs');\n * var format = require('mapbox-gl-style-spec').format;\n * var style = fs.readFileSync('./source.json', 'utf8');\n * fs.writeFileSync('./dest.json', format(style));\n * fs.writeFileSync('./dest.min.json', format(style, 0));\n */\nfunction format(style, space = 2) {\n style = sortKeysBy(style, reference.$root);\n\n if (style.layers) {\n style.layers = style.layers.map((layer) => sortKeysBy(layer, reference.layer));\n }\n\n return stringifyPretty(style, {indent: space});\n}\n\nexport default format;\n","/*! https://mths.be/punycode v1.3.2 by @mathias */\n;(function(root) {\n\n\t/** Detect free variables */\n\tvar freeExports = typeof exports == 'object' && exports &&\n\t\t!exports.nodeType && exports;\n\tvar freeModule = typeof module == 'object' && module &&\n\t\t!module.nodeType && module;\n\tvar freeGlobal = typeof global == 'object' && global;\n\tif (\n\t\tfreeGlobal.global === freeGlobal ||\n\t\tfreeGlobal.window === freeGlobal ||\n\t\tfreeGlobal.self === freeGlobal\n\t) {\n\t\troot = freeGlobal;\n\t}\n\n\t/**\n\t * The `punycode` object.\n\t * @name punycode\n\t * @type Object\n\t */\n\tvar punycode,\n\n\t/** Highest positive signed 32-bit float value */\n\tmaxInt = 2147483647, // aka. 0x7FFFFFFF or 2^31-1\n\n\t/** Bootstring parameters */\n\tbase = 36,\n\ttMin = 1,\n\ttMax = 26,\n\tskew = 38,\n\tdamp = 700,\n\tinitialBias = 72,\n\tinitialN = 128, // 0x80\n\tdelimiter = '-', // '\\x2D'\n\n\t/** Regular expressions */\n\tregexPunycode = /^xn--/,\n\tregexNonASCII = /[^\\x20-\\x7E]/, // unprintable ASCII chars + non-ASCII chars\n\tregexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g, // RFC 3490 separators\n\n\t/** Error messages */\n\terrors = {\n\t\t'overflow': 'Overflow: input needs wider integers to process',\n\t\t'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n\t\t'invalid-input': 'Invalid input'\n\t},\n\n\t/** Convenience shortcuts */\n\tbaseMinusTMin = base - tMin,\n\tfloor = Math.floor,\n\tstringFromCharCode = String.fromCharCode,\n\n\t/** Temporary variable */\n\tkey;\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/**\n\t * A generic error utility function.\n\t * @private\n\t * @param {String} type The error type.\n\t * @returns {Error} Throws a `RangeError` with the applicable error message.\n\t */\n\tfunction error(type) {\n\t\tthrow RangeError(errors[type]);\n\t}\n\n\t/**\n\t * A generic `Array#map` utility function.\n\t * @private\n\t * @param {Array} array The array to iterate over.\n\t * @param {Function} callback The function that gets called for every array\n\t * item.\n\t * @returns {Array} A new array of values returned by the callback function.\n\t */\n\tfunction map(array, fn) {\n\t\tvar length = array.length;\n\t\tvar result = [];\n\t\twhile (length--) {\n\t\t\tresult[length] = fn(array[length]);\n\t\t}\n\t\treturn result;\n\t}\n\n\t/**\n\t * A simple `Array#map`-like wrapper to work with domain name strings or email\n\t * addresses.\n\t * @private\n\t * @param {String} domain The domain name or email address.\n\t * @param {Function} callback The function that gets called for every\n\t * character.\n\t * @returns {Array} A new string of characters returned by the callback\n\t * function.\n\t */\n\tfunction mapDomain(string, fn) {\n\t\tvar parts = string.split('@');\n\t\tvar result = '';\n\t\tif (parts.length > 1) {\n\t\t\t// In email addresses, only the domain name should be punycoded. Leave\n\t\t\t// the local part (i.e. everything up to `@`) intact.\n\t\t\tresult = parts[0] + '@';\n\t\t\tstring = parts[1];\n\t\t}\n\t\t// Avoid `split(regex)` for IE8 compatibility. See #17.\n\t\tstring = string.replace(regexSeparators, '\\x2E');\n\t\tvar labels = string.split('.');\n\t\tvar encoded = map(labels, fn).join('.');\n\t\treturn result + encoded;\n\t}\n\n\t/**\n\t * Creates an array containing the numeric code points of each Unicode\n\t * character in the string. While JavaScript uses UCS-2 internally,\n\t * this function will convert a pair of surrogate halves (each of which\n\t * UCS-2 exposes as separate characters) into a single code point,\n\t * matching UTF-16.\n\t * @see `punycode.ucs2.encode`\n\t * @see <https://mathiasbynens.be/notes/javascript-encoding>\n\t * @memberOf punycode.ucs2\n\t * @name decode\n\t * @param {String} string The Unicode input string (UCS-2).\n\t * @returns {Array} The new array of code points.\n\t */\n\tfunction ucs2decode(string) {\n\t\tvar output = [],\n\t\t counter = 0,\n\t\t length = string.length,\n\t\t value,\n\t\t extra;\n\t\twhile (counter < length) {\n\t\t\tvalue = string.charCodeAt(counter++);\n\t\t\tif (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n\t\t\t\t// high surrogate, and there is a next character\n\t\t\t\textra = string.charCodeAt(counter++);\n\t\t\t\tif ((extra & 0xFC00) == 0xDC00) { // low surrogate\n\t\t\t\t\toutput.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n\t\t\t\t} else {\n\t\t\t\t\t// unmatched surrogate; only append this code unit, in case the next\n\t\t\t\t\t// code unit is the high surrogate of a surrogate pair\n\t\t\t\t\toutput.push(value);\n\t\t\t\t\tcounter--;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\toutput.push(value);\n\t\t\t}\n\t\t}\n\t\treturn output;\n\t}\n\n\t/**\n\t * Creates a string based on an array of numeric code points.\n\t * @see `punycode.ucs2.decode`\n\t * @memberOf punycode.ucs2\n\t * @name encode\n\t * @param {Array} codePoints The array of numeric code points.\n\t * @returns {String} The new Unicode string (UCS-2).\n\t */\n\tfunction ucs2encode(array) {\n\t\treturn map(array, function(value) {\n\t\t\tvar output = '';\n\t\t\tif (value > 0xFFFF) {\n\t\t\t\tvalue -= 0x10000;\n\t\t\t\toutput += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800);\n\t\t\t\tvalue = 0xDC00 | value & 0x3FF;\n\t\t\t}\n\t\t\toutput += stringFromCharCode(value);\n\t\t\treturn output;\n\t\t}).join('');\n\t}\n\n\t/**\n\t * Converts a basic code point into a digit/integer.\n\t * @see `digitToBasic()`\n\t * @private\n\t * @param {Number} codePoint The basic numeric code point value.\n\t * @returns {Number} The numeric value of a basic code point (for use in\n\t * representing integers) in the range `0` to `base - 1`, or `base` if\n\t * the code point does not represent a value.\n\t */\n\tfunction basicToDigit(codePoint) {\n\t\tif (codePoint - 48 < 10) {\n\t\t\treturn codePoint - 22;\n\t\t}\n\t\tif (codePoint - 65 < 26) {\n\t\t\treturn codePoint - 65;\n\t\t}\n\t\tif (codePoint - 97 < 26) {\n\t\t\treturn codePoint - 97;\n\t\t}\n\t\treturn base;\n\t}\n\n\t/**\n\t * Converts a digit/integer into a basic code point.\n\t * @see `basicToDigit()`\n\t * @private\n\t * @param {Number} digit The numeric value of a basic code point.\n\t * @returns {Number} The basic code point whose value (when used for\n\t * representing integers) is `digit`, which needs to be in the range\n\t * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n\t * used; else, the lowercase form is used. The behavior is undefined\n\t * if `flag` is non-zero and `digit` has no uppercase form.\n\t */\n\tfunction digitToBasic(digit, flag) {\n\t\t// 0..25 map to ASCII a..z or A..Z\n\t\t// 26..35 map to ASCII 0..9\n\t\treturn digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n\t}\n\n\t/**\n\t * Bias adaptation function as per section 3.4 of RFC 3492.\n\t * http://tools.ietf.org/html/rfc3492#section-3.4\n\t * @private\n\t */\n\tfunction adapt(delta, numPoints, firstTime) {\n\t\tvar k = 0;\n\t\tdelta = firstTime ? floor(delta / damp) : delta >> 1;\n\t\tdelta += floor(delta / numPoints);\n\t\tfor (/* no initialization */; delta > baseMinusTMin * tMax >> 1; k += base) {\n\t\t\tdelta = floor(delta / baseMinusTMin);\n\t\t}\n\t\treturn floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n\t}\n\n\t/**\n\t * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n\t * symbols.\n\t * @memberOf punycode\n\t * @param {String} input The Punycode string of ASCII-only symbols.\n\t * @returns {String} The resulting string of Unicode symbols.\n\t */\n\tfunction decode(input) {\n\t\t// Don't use UCS-2\n\t\tvar output = [],\n\t\t inputLength = input.length,\n\t\t out,\n\t\t i = 0,\n\t\t n = initialN,\n\t\t bias = initialBias,\n\t\t basic,\n\t\t j,\n\t\t index,\n\t\t oldi,\n\t\t w,\n\t\t k,\n\t\t digit,\n\t\t t,\n\t\t /** Cached calculation results */\n\t\t baseMinusT;\n\n\t\t// Handle the basic code points: let `basic` be the number of input code\n\t\t// points before the last delimiter, or `0` if there is none, then copy\n\t\t// the first basic code points to the output.\n\n\t\tbasic = input.lastIndexOf(delimiter);\n\t\tif (basic < 0) {\n\t\t\tbasic = 0;\n\t\t}\n\n\t\tfor (j = 0; j < basic; ++j) {\n\t\t\t// if it's not a basic code point\n\t\t\tif (input.charCodeAt(j) >= 0x80) {\n\t\t\t\terror('not-basic');\n\t\t\t}\n\t\t\toutput.push(input.charCodeAt(j));\n\t\t}\n\n\t\t// Main decoding loop: start just after the last delimiter if any basic code\n\t\t// points were copied; start at the beginning otherwise.\n\n\t\tfor (index = basic > 0 ? basic + 1 : 0; index < inputLength; /* no final expression */) {\n\n\t\t\t// `index` is the index of the next character to be consumed.\n\t\t\t// Decode a generalized variable-length integer into `delta`,\n\t\t\t// which gets added to `i`. The overflow checking is easier\n\t\t\t// if we increase `i` as we go, then subtract off its starting\n\t\t\t// value at the end to obtain `delta`.\n\t\t\tfor (oldi = i, w = 1, k = base; /* no condition */; k += base) {\n\n\t\t\t\tif (index >= inputLength) {\n\t\t\t\t\terror('invalid-input');\n\t\t\t\t}\n\n\t\t\t\tdigit = basicToDigit(input.charCodeAt(index++));\n\n\t\t\t\tif (digit >= base || digit > floor((maxInt - i) / w)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\ti += digit * w;\n\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\n\t\t\t\tif (digit < t) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tbaseMinusT = base - t;\n\t\t\t\tif (w > floor(maxInt / baseMinusT)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tw *= baseMinusT;\n\n\t\t\t}\n\n\t\t\tout = output.length + 1;\n\t\t\tbias = adapt(i - oldi, out, oldi == 0);\n\n\t\t\t// `i` was supposed to wrap around from `out` to `0`,\n\t\t\t// incrementing `n` each time, so we'll fix that now:\n\t\t\tif (floor(i / out) > maxInt - n) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tn += floor(i / out);\n\t\t\ti %= out;\n\n\t\t\t// Insert `n` at position `i` of the output\n\t\t\toutput.splice(i++, 0, n);\n\n\t\t}\n\n\t\treturn ucs2encode(output);\n\t}\n\n\t/**\n\t * Converts a string of Unicode symbols (e.g. a domain name label) to a\n\t * Punycode string of ASCII-only symbols.\n\t * @memberOf punycode\n\t * @param {String} input The string of Unicode symbols.\n\t * @returns {String} The resulting Punycode string of ASCII-only symbols.\n\t */\n\tfunction encode(input) {\n\t\tvar n,\n\t\t delta,\n\t\t handledCPCount,\n\t\t basicLength,\n\t\t bias,\n\t\t j,\n\t\t m,\n\t\t q,\n\t\t k,\n\t\t t,\n\t\t currentValue,\n\t\t output = [],\n\t\t /** `inputLength` will hold the number of code points in `input`. */\n\t\t inputLength,\n\t\t /** Cached calculation results */\n\t\t handledCPCountPlusOne,\n\t\t baseMinusT,\n\t\t qMinusT;\n\n\t\t// Convert the input in UCS-2 to Unicode\n\t\tinput = ucs2decode(input);\n\n\t\t// Cache the length\n\t\tinputLength = input.length;\n\n\t\t// Initialize the state\n\t\tn = initialN;\n\t\tdelta = 0;\n\t\tbias = initialBias;\n\n\t\t// Handle the basic code points\n\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\tcurrentValue = input[j];\n\t\t\tif (currentValue < 0x80) {\n\t\t\t\toutput.push(stringFromCharCode(currentValue));\n\t\t\t}\n\t\t}\n\n\t\thandledCPCount = basicLength = output.length;\n\n\t\t// `handledCPCount` is the number of code points that have been handled;\n\t\t// `basicLength` is the number of basic code points.\n\n\t\t// Finish the basic string - if it is not empty - with a delimiter\n\t\tif (basicLength) {\n\t\t\toutput.push(delimiter);\n\t\t}\n\n\t\t// Main encoding loop:\n\t\twhile (handledCPCount < inputLength) {\n\n\t\t\t// All non-basic code points < n have been handled already. Find the next\n\t\t\t// larger one:\n\t\t\tfor (m = maxInt, j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\t\t\t\tif (currentValue >= n && currentValue < m) {\n\t\t\t\t\tm = currentValue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Increase `delta` enough to advance the decoder's <n,i> state to <m,0>,\n\t\t\t// but guard against overflow\n\t\t\thandledCPCountPlusOne = handledCPCount + 1;\n\t\t\tif (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tdelta += (m - n) * handledCPCountPlusOne;\n\t\t\tn = m;\n\n\t\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\n\t\t\t\tif (currentValue < n && ++delta > maxInt) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tif (currentValue == n) {\n\t\t\t\t\t// Represent delta as a generalized variable-length integer\n\t\t\t\t\tfor (q = delta, k = base; /* no condition */; k += base) {\n\t\t\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\t\t\t\t\t\tif (q < t) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tqMinusT = q - t;\n\t\t\t\t\t\tbaseMinusT = base - t;\n\t\t\t\t\t\toutput.push(\n\t\t\t\t\t\t\tstringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0))\n\t\t\t\t\t\t);\n\t\t\t\t\t\tq = floor(qMinusT / baseMinusT);\n\t\t\t\t\t}\n\n\t\t\t\t\toutput.push(stringFromCharCode(digitToBasic(q, 0)));\n\t\t\t\t\tbias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength);\n\t\t\t\t\tdelta = 0;\n\t\t\t\t\t++handledCPCount;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t++delta;\n\t\t\t++n;\n\n\t\t}\n\t\treturn output.join('');\n\t}\n\n\t/**\n\t * Converts a Punycode string representing a domain name or an email address\n\t * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n\t * it doesn't matter if you call it on a string that has already been\n\t * converted to Unicode.\n\t * @memberOf punycode\n\t * @param {String} input The Punycoded domain name or email address to\n\t * convert to Unicode.\n\t * @returns {String} The Unicode representation of the given Punycode\n\t * string.\n\t */\n\tfunction toUnicode(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexPunycode.test(string)\n\t\t\t\t? decode(string.slice(4).toLowerCase())\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/**\n\t * Converts a Unicode string representing a domain name or an email address to\n\t * Punycode. Only the non-ASCII parts of the domain name will be converted,\n\t * i.e. it doesn't matter if you call it with a domain that's already in\n\t * ASCII.\n\t * @memberOf punycode\n\t * @param {String} input The domain name or email address to convert, as a\n\t * Unicode string.\n\t * @returns {String} The Punycode representation of the given domain name or\n\t * email address.\n\t */\n\tfunction toASCII(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexNonASCII.test(string)\n\t\t\t\t? 'xn--' + encode(string)\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/** Define the public API */\n\tpunycode = {\n\t\t/**\n\t\t * A string representing the current Punycode.js version number.\n\t\t * @memberOf punycode\n\t\t * @type String\n\t\t */\n\t\t'version': '1.3.2',\n\t\t/**\n\t\t * An object of methods to convert from JavaScript's internal character\n\t\t * representation (UCS-2) to Unicode code points, and back.\n\t\t * @see <https://mathiasbynens.be/notes/javascript-encoding>\n\t\t * @memberOf punycode\n\t\t * @type Object\n\t\t */\n\t\t'ucs2': {\n\t\t\t'decode': ucs2decode,\n\t\t\t'encode': ucs2encode\n\t\t},\n\t\t'decode': decode,\n\t\t'encode': encode,\n\t\t'toASCII': toASCII,\n\t\t'toUnicode': toUnicode\n\t};\n\n\t/** Expose `punycode` */\n\t// Some AMD build optimizers, like r.js, check for specific condition patterns\n\t// like the following:\n\tif (\n\t\ttypeof define == 'function' &&\n\t\ttypeof define.amd == 'object' &&\n\t\tdefine.amd\n\t) {\n\t\tdefine('punycode', function() {\n\t\t\treturn punycode;\n\t\t});\n\t} else if (freeExports && freeModule) {\n\t\tif (module.exports == freeExports) { // in Node.js or RingoJS v0.8.0+\n\t\t\tfreeModule.exports = punycode;\n\t\t} else { // in Narwhal or RingoJS v0.7.0-\n\t\t\tfor (key in punycode) {\n\t\t\t\tpunycode.hasOwnProperty(key) && (freeExports[key] = punycode[key]);\n\t\t\t}\n\t\t}\n\t} else { // in Rhino or a web browser\n\t\troot.punycode = punycode;\n\t}\n\n}(this));\n","'use strict';\n\nmodule.exports = {\n isString: function(arg) {\n return typeof(arg) === 'string';\n },\n isObject: function(arg) {\n return typeof(arg) === 'object' && arg !== null;\n },\n isNull: function(arg) {\n return arg === null;\n },\n isNullOrUndefined: function(arg) {\n return arg == null;\n }\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n// If obj.hasOwnProperty has been overridden, then calling\n// obj.hasOwnProperty(prop) will break.\n// See: https://github.com/joyent/node/issues/1707\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nmodule.exports = function(qs, sep, eq, options) {\n sep = sep || '&';\n eq = eq || '=';\n var obj = {};\n\n if (typeof qs !== 'string' || qs.length === 0) {\n return obj;\n }\n\n var regexp = /\\+/g;\n qs = qs.split(sep);\n\n var maxKeys = 1000;\n if (options && typeof options.maxKeys === 'number') {\n maxKeys = options.maxKeys;\n }\n\n var len = qs.length;\n // maxKeys <= 0 means that we should not limit keys count\n if (maxKeys > 0 && len > maxKeys) {\n len = maxKeys;\n }\n\n for (var i = 0; i < len; ++i) {\n var x = qs[i].replace(regexp, '%20'),\n idx = x.indexOf(eq),\n kstr, vstr, k, v;\n\n if (idx >= 0) {\n kstr = x.substr(0, idx);\n vstr = x.substr(idx + 1);\n } else {\n kstr = x;\n vstr = '';\n }\n\n k = decodeURIComponent(kstr);\n v = decodeURIComponent(vstr);\n\n if (!hasOwnProperty(obj, k)) {\n obj[k] = v;\n } else if (Array.isArray(obj[k])) {\n obj[k].push(v);\n } else {\n obj[k] = [obj[k], v];\n }\n }\n\n return obj;\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar stringifyPrimitive = function(v) {\n switch (typeof v) {\n case 'string':\n return v;\n\n case 'boolean':\n return v ? 'true' : 'false';\n\n case 'number':\n return isFinite(v) ? v : '';\n\n default:\n return '';\n }\n};\n\nmodule.exports = function(obj, sep, eq, name) {\n sep = sep || '&';\n eq = eq || '=';\n if (obj === null) {\n obj = undefined;\n }\n\n if (typeof obj === 'object') {\n return Object.keys(obj).map(function(k) {\n var ks = encodeURIComponent(stringifyPrimitive(k)) + eq;\n if (Array.isArray(obj[k])) {\n return obj[k].map(function(v) {\n return ks + encodeURIComponent(stringifyPrimitive(v));\n }).join(sep);\n } else {\n return ks + encodeURIComponent(stringifyPrimitive(obj[k]));\n }\n }).join(sep);\n\n }\n\n if (!name) return '';\n return encodeURIComponent(stringifyPrimitive(name)) + eq +\n encodeURIComponent(stringifyPrimitive(obj));\n};\n","'use strict';\n\nexports.decode = exports.parse = require('./decode');\nexports.encode = exports.stringify = require('./encode');\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar punycode = require('punycode');\nvar util = require('./util');\n\nexports.parse = urlParse;\nexports.resolve = urlResolve;\nexports.resolveObject = urlResolveObject;\nexports.format = urlFormat;\n\nexports.Url = Url;\n\nfunction Url() {\n this.protocol = null;\n this.slashes = null;\n this.auth = null;\n this.host = null;\n this.port = null;\n this.hostname = null;\n this.hash = null;\n this.search = null;\n this.query = null;\n this.pathname = null;\n this.path = null;\n this.href = null;\n}\n\n// Reference: RFC 3986, RFC 1808, RFC 2396\n\n// define these here so at least they only have to be\n// compiled once on the first module load.\nvar protocolPattern = /^([a-z0-9.+-]+:)/i,\n portPattern = /:[0-9]*$/,\n\n // Special case for a simple path URL\n simplePathPattern = /^(\\/\\/?(?!\\/)[^\\?\\s]*)(\\?[^\\s]*)?$/,\n\n // RFC 2396: characters reserved for delimiting URLs.\n // We actually just auto-escape these.\n delims = ['<', '>', '\"', '`', ' ', '\\r', '\\n', '\\t'],\n\n // RFC 2396: characters not allowed for various reasons.\n unwise = ['{', '}', '|', '\\\\', '^', '`'].concat(delims),\n\n // Allowed by RFCs, but cause of XSS attacks. Always escape these.\n autoEscape = ['\\''].concat(unwise),\n // Characters that are never ever allowed in a hostname.\n // Note that any invalid chars are also handled, but these\n // are the ones that are *expected* to be seen, so we fast-path\n // them.\n nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape),\n hostEndingChars = ['/', '?', '#'],\n hostnameMaxLen = 255,\n hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/,\n hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/,\n // protocols that can allow \"unsafe\" and \"unwise\" chars.\n unsafeProtocol = {\n 'javascript': true,\n 'javascript:': true\n },\n // protocols that never have a hostname.\n hostlessProtocol = {\n 'javascript': true,\n 'javascript:': true\n },\n // protocols that always contain a // bit.\n slashedProtocol = {\n 'http': true,\n 'https': true,\n 'ftp': true,\n 'gopher': true,\n 'file': true,\n 'http:': true,\n 'https:': true,\n 'ftp:': true,\n 'gopher:': true,\n 'file:': true\n },\n querystring = require('querystring');\n\nfunction urlParse(url, parseQueryString, slashesDenoteHost) {\n if (url && util.isObject(url) && url instanceof Url) return url;\n\n var u = new Url;\n u.parse(url, parseQueryString, slashesDenoteHost);\n return u;\n}\n\nUrl.prototype.parse = function(url, parseQueryString, slashesDenoteHost) {\n if (!util.isString(url)) {\n throw new TypeError(\"Parameter 'url' must be a string, not \" + typeof url);\n }\n\n // Copy chrome, IE, opera backslash-handling behavior.\n // Back slashes before the query string get converted to forward slashes\n // See: https://code.google.com/p/chromium/issues/detail?id=25916\n var queryIndex = url.indexOf('?'),\n splitter =\n (queryIndex !== -1 && queryIndex < url.indexOf('#')) ? '?' : '#',\n uSplit = url.split(splitter),\n slashRegex = /\\\\/g;\n uSplit[0] = uSplit[0].replace(slashRegex, '/');\n url = uSplit.join(splitter);\n\n var rest = url;\n\n // trim before proceeding.\n // This is to support parse stuff like \" http://foo.com \\n\"\n rest = rest.trim();\n\n if (!slashesDenoteHost && url.split('#').length === 1) {\n // Try fast path regexp\n var simplePath = simplePathPattern.exec(rest);\n if (simplePath) {\n this.path = rest;\n this.href = rest;\n this.pathname = simplePath[1];\n if (simplePath[2]) {\n this.search = simplePath[2];\n if (parseQueryString) {\n this.query = querystring.parse(this.search.substr(1));\n } else {\n this.query = this.search.substr(1);\n }\n } else if (parseQueryString) {\n this.search = '';\n this.query = {};\n }\n return this;\n }\n }\n\n var proto = protocolPattern.exec(rest);\n if (proto) {\n proto = proto[0];\n var lowerProto = proto.toLowerCase();\n this.protocol = lowerProto;\n rest = rest.substr(proto.length);\n }\n\n // figure out if it's got a host\n // user@server is *always* interpreted as a hostname, and url\n // resolution will treat //foo/bar as host=foo,path=bar because that's\n // how the browser resolves relative URLs.\n if (slashesDenoteHost || proto || rest.match(/^\\/\\/[^@\\/]+@[^@\\/]+/)) {\n var slashes = rest.substr(0, 2) === '//';\n if (slashes && !(proto && hostlessProtocol[proto])) {\n rest = rest.substr(2);\n this.slashes = true;\n }\n }\n\n if (!hostlessProtocol[proto] &&\n (slashes || (proto && !slashedProtocol[proto]))) {\n\n // there's a hostname.\n // the first instance of /, ?, ;, or # ends the host.\n //\n // If there is an @ in the hostname, then non-host chars *are* allowed\n // to the left of the last @ sign, unless some host-ending character\n // comes *before* the @-sign.\n // URLs are obnoxious.\n //\n // ex:\n // http://a@b@c/ => user:a@b host:c\n // http://a@b?@c => user:a host:c path:/?@c\n\n // v0.12 TODO(isaacs): This is not quite how Chrome does things.\n // Review our test case against browsers more comprehensively.\n\n // find the first instance of any hostEndingChars\n var hostEnd = -1;\n for (var i = 0; i < hostEndingChars.length; i++) {\n var hec = rest.indexOf(hostEndingChars[i]);\n if (hec !== -1 && (hostEnd === -1 || hec < hostEnd))\n hostEnd = hec;\n }\n\n // at this point, either we have an explicit point where the\n // auth portion cannot go past, or the last @ char is the decider.\n var auth, atSign;\n if (hostEnd === -1) {\n // atSign can be anywhere.\n atSign = rest.lastIndexOf('@');\n } else {\n // atSign must be in auth portion.\n // http://a@b/c@d => host:b auth:a path:/c@d\n atSign = rest.lastIndexOf('@', hostEnd);\n }\n\n // Now we have a portion which is definitely the auth.\n // Pull that off.\n if (atSign !== -1) {\n auth = rest.slice(0, atSign);\n rest = rest.slice(atSign + 1);\n this.auth = decodeURIComponent(auth);\n }\n\n // the host is the remaining to the left of the first non-host char\n hostEnd = -1;\n for (var i = 0; i < nonHostChars.length; i++) {\n var hec = rest.indexOf(nonHostChars[i]);\n if (hec !== -1 && (hostEnd === -1 || hec < hostEnd))\n hostEnd = hec;\n }\n // if we still have not hit it, then the entire thing is a host.\n if (hostEnd === -1)\n hostEnd = rest.length;\n\n this.host = rest.slice(0, hostEnd);\n rest = rest.slice(hostEnd);\n\n // pull out port.\n this.parseHost();\n\n // we've indicated that there is a hostname,\n // so even if it's empty, it has to be present.\n this.hostname = this.hostname || '';\n\n // if hostname begins with [ and ends with ]\n // assume that it's an IPv6 address.\n var ipv6Hostname = this.hostname[0] === '[' &&\n this.hostname[this.hostname.length - 1] === ']';\n\n // validate a little.\n if (!ipv6Hostname) {\n var hostparts = this.hostname.split(/\\./);\n for (var i = 0, l = hostparts.length; i < l; i++) {\n var part = hostparts[i];\n if (!part) continue;\n if (!part.match(hostnamePartPattern)) {\n var newpart = '';\n for (var j = 0, k = part.length; j < k; j++) {\n if (part.charCodeAt(j) > 127) {\n // we replace non-ASCII char with a temporary placeholder\n // we need this to make sure size of hostname is not\n // broken by replacing non-ASCII by nothing\n newpart += 'x';\n } else {\n newpart += part[j];\n }\n }\n // we test again with ASCII char only\n if (!newpart.match(hostnamePartPattern)) {\n var validParts = hostparts.slice(0, i);\n var notHost = hostparts.slice(i + 1);\n var bit = part.match(hostnamePartStart);\n if (bit) {\n validParts.push(bit[1]);\n notHost.unshift(bit[2]);\n }\n if (notHost.length) {\n rest = '/' + notHost.join('.') + rest;\n }\n this.hostname = validParts.join('.');\n break;\n }\n }\n }\n }\n\n if (this.hostname.length > hostnameMaxLen) {\n this.hostname = '';\n } else {\n // hostnames are always lower case.\n this.hostname = this.hostname.toLowerCase();\n }\n\n if (!ipv6Hostname) {\n // IDNA Support: Returns a punycoded representation of \"domain\".\n // It only converts parts of the domain name that\n // have non-ASCII characters, i.e. it doesn't matter if\n // you call it with a domain that already is ASCII-only.\n this.hostname = punycode.toASCII(this.hostname);\n }\n\n var p = this.port ? ':' + this.port : '';\n var h = this.hostname || '';\n this.host = h + p;\n this.href += this.host;\n\n // strip [ and ] from the hostname\n // the host field still retains them, though\n if (ipv6Hostname) {\n this.hostname = this.hostname.substr(1, this.hostname.length - 2);\n if (rest[0] !== '/') {\n rest = '/' + rest;\n }\n }\n }\n\n // now rest is set to the post-host stuff.\n // chop off any delim chars.\n if (!unsafeProtocol[lowerProto]) {\n\n // First, make 100% sure that any \"autoEscape\" chars get\n // escaped, even if encodeURIComponent doesn't think they\n // need to be.\n for (var i = 0, l = autoEscape.length; i < l; i++) {\n var ae = autoEscape[i];\n if (rest.indexOf(ae) === -1)\n continue;\n var esc = encodeURIComponent(ae);\n if (esc === ae) {\n esc = escape(ae);\n }\n rest = rest.split(ae).join(esc);\n }\n }\n\n\n // chop off from the tail first.\n var hash = rest.indexOf('#');\n if (hash !== -1) {\n // got a fragment string.\n this.hash = rest.substr(hash);\n rest = rest.slice(0, hash);\n }\n var qm = rest.indexOf('?');\n if (qm !== -1) {\n this.search = rest.substr(qm);\n this.query = rest.substr(qm + 1);\n if (parseQueryString) {\n this.query = querystring.parse(this.query);\n }\n rest = rest.slice(0, qm);\n } else if (parseQueryString) {\n // no query string, but parseQueryString still requested\n this.search = '';\n this.query = {};\n }\n if (rest) this.pathname = rest;\n if (slashedProtocol[lowerProto] &&\n this.hostname && !this.pathname) {\n this.pathname = '/';\n }\n\n //to support http.request\n if (this.pathname || this.search) {\n var p = this.pathname || '';\n var s = this.search || '';\n this.path = p + s;\n }\n\n // finally, reconstruct the href based on what has been validated.\n this.href = this.format();\n return this;\n};\n\n// format a parsed object into a url string\nfunction urlFormat(obj) {\n // ensure it's an object, and not a string url.\n // If it's an obj, this is a no-op.\n // this way, you can call url_format() on strings\n // to clean up potentially wonky urls.\n if (util.isString(obj)) obj = urlParse(obj);\n if (!(obj instanceof Url)) return Url.prototype.format.call(obj);\n return obj.format();\n}\n\nUrl.prototype.format = function() {\n var auth = this.auth || '';\n if (auth) {\n auth = encodeURIComponent(auth);\n auth = auth.replace(/%3A/i, ':');\n auth += '@';\n }\n\n var protocol = this.protocol || '',\n pathname = this.pathname || '',\n hash = this.hash || '',\n host = false,\n query = '';\n\n if (this.host) {\n host = auth + this.host;\n } else if (this.hostname) {\n host = auth + (this.hostname.indexOf(':') === -1 ?\n this.hostname :\n '[' + this.hostname + ']');\n if (this.port) {\n host += ':' + this.port;\n }\n }\n\n if (this.query &&\n util.isObject(this.query) &&\n Object.keys(this.query).length) {\n query = querystring.stringify(this.query);\n }\n\n var search = this.search || (query && ('?' + query)) || '';\n\n if (protocol && protocol.substr(-1) !== ':') protocol += ':';\n\n // only the slashedProtocols get the //. Not mailto:, xmpp:, etc.\n // unless they had them to begin with.\n if (this.slashes ||\n (!protocol || slashedProtocol[protocol]) && host !== false) {\n host = '//' + (host || '');\n if (pathname && pathname.charAt(0) !== '/') pathname = '/' + pathname;\n } else if (!host) {\n host = '';\n }\n\n if (hash && hash.charAt(0) !== '#') hash = '#' + hash;\n if (search && search.charAt(0) !== '?') search = '?' + search;\n\n pathname = pathname.replace(/[?#]/g, function(match) {\n return encodeURIComponent(match);\n });\n search = search.replace('#', '%23');\n\n return protocol + host + pathname + search + hash;\n};\n\nfunction urlResolve(source, relative) {\n return urlParse(source, false, true).resolve(relative);\n}\n\nUrl.prototype.resolve = function(relative) {\n return this.resolveObject(urlParse(relative, false, true)).format();\n};\n\nfunction urlResolveObject(source, relative) {\n if (!source) return relative;\n return urlParse(source, false, true).resolveObject(relative);\n}\n\nUrl.prototype.resolveObject = function(relative) {\n if (util.isString(relative)) {\n var rel = new Url();\n rel.parse(relative, false, true);\n relative = rel;\n }\n\n var result = new Url();\n var tkeys = Object.keys(this);\n for (var tk = 0; tk < tkeys.length; tk++) {\n var tkey = tkeys[tk];\n result[tkey] = this[tkey];\n }\n\n // hash is always overridden, no matter what.\n // even href=\"\" will remove it.\n result.hash = relative.hash;\n\n // if the relative url is empty, then there's nothing left to do here.\n if (relative.href === '') {\n result.href = result.format();\n return result;\n }\n\n // hrefs like //foo/bar always cut to the protocol.\n if (relative.slashes && !relative.protocol) {\n // take everything except the protocol from relative\n var rkeys = Object.keys(relative);\n for (var rk = 0; rk < rkeys.length; rk++) {\n var rkey = rkeys[rk];\n if (rkey !== 'protocol')\n result[rkey] = relative[rkey];\n }\n\n //urlParse appends trailing / to urls like http://www.example.com\n if (slashedProtocol[result.protocol] &&\n result.hostname && !result.pathname) {\n result.path = result.pathname = '/';\n }\n\n result.href = result.format();\n return result;\n }\n\n if (relative.protocol && relative.protocol !== result.protocol) {\n // if it's a known url protocol, then changing\n // the protocol does weird things\n // first, if it's not file:, then we MUST have a host,\n // and if there was a path\n // to begin with, then we MUST have a path.\n // if it is file:, then the host is dropped,\n // because that's known to be hostless.\n // anything else is assumed to be absolute.\n if (!slashedProtocol[relative.protocol]) {\n var keys = Object.keys(relative);\n for (var v = 0; v < keys.length; v++) {\n var k = keys[v];\n result[k] = relative[k];\n }\n result.href = result.format();\n return result;\n }\n\n result.protocol = relative.protocol;\n if (!relative.host && !hostlessProtocol[relative.protocol]) {\n var relPath = (relative.pathname || '').split('/');\n while (relPath.length && !(relative.host = relPath.shift()));\n if (!relative.host) relative.host = '';\n if (!relative.hostname) relative.hostname = '';\n if (relPath[0] !== '') relPath.unshift('');\n if (relPath.length < 2) relPath.unshift('');\n result.pathname = relPath.join('/');\n } else {\n result.pathname = relative.pathname;\n }\n result.search = relative.search;\n result.query = relative.query;\n result.host = relative.host || '';\n result.auth = relative.auth;\n result.hostname = relative.hostname || relative.host;\n result.port = relative.port;\n // to support http.request\n if (result.pathname || result.search) {\n var p = result.pathname || '';\n var s = result.search || '';\n result.path = p + s;\n }\n result.slashes = result.slashes || relative.slashes;\n result.href = result.format();\n return result;\n }\n\n var isSourceAbs = (result.pathname && result.pathname.charAt(0) === '/'),\n isRelAbs = (\n relative.host ||\n relative.pathname && relative.pathname.charAt(0) === '/'\n ),\n mustEndAbs = (isRelAbs || isSourceAbs ||\n (result.host && relative.pathname)),\n removeAllDots = mustEndAbs,\n srcPath = result.pathname && result.pathname.split('/') || [],\n relPath = relative.pathname && relative.pathname.split('/') || [],\n psychotic = result.protocol && !slashedProtocol[result.protocol];\n\n // if the url is a non-slashed url, then relative\n // links like ../.. should be able\n // to crawl up to the hostname, as well. This is strange.\n // result.protocol has already been set by now.\n // Later on, put the first path part into the host field.\n if (psychotic) {\n result.hostname = '';\n result.port = null;\n if (result.host) {\n if (srcPath[0] === '') srcPath[0] = result.host;\n else srcPath.unshift(result.host);\n }\n result.host = '';\n if (relative.protocol) {\n relative.hostname = null;\n relative.port = null;\n if (relative.host) {\n if (relPath[0] === '') relPath[0] = relative.host;\n else relPath.unshift(relative.host);\n }\n relative.host = null;\n }\n mustEndAbs = mustEndAbs && (relPath[0] === '' || srcPath[0] === '');\n }\n\n if (isRelAbs) {\n // it's absolute.\n result.host = (relative.host || relative.host === '') ?\n relative.host : result.host;\n result.hostname = (relative.hostname || relative.hostname === '') ?\n relative.hostname : result.hostname;\n result.search = relative.search;\n result.query = relative.query;\n srcPath = relPath;\n // fall through to the dot-handling below.\n } else if (relPath.length) {\n // it's relative\n // throw away the existing file, and take the new path instead.\n if (!srcPath) srcPath = [];\n srcPath.pop();\n srcPath = srcPath.concat(relPath);\n result.search = relative.search;\n result.query = relative.query;\n } else if (!util.isNullOrUndefined(relative.search)) {\n // just pull out the search.\n // like href='?foo'.\n // Put this after the other two cases because it simplifies the booleans\n if (psychotic) {\n result.hostname = result.host = srcPath.shift();\n //occationaly the auth can get stuck only in host\n //this especially happens in cases like\n //url.resolveObject('mailto:local1@domain1', 'local2@domain2')\n var authInHost = result.host && result.host.indexOf('@') > 0 ?\n result.host.split('@') : false;\n if (authInHost) {\n result.auth = authInHost.shift();\n result.host = result.hostname = authInHost.shift();\n }\n }\n result.search = relative.search;\n result.query = relative.query;\n //to support http.request\n if (!util.isNull(result.pathname) || !util.isNull(result.search)) {\n result.path = (result.pathname ? result.pathname : '') +\n (result.search ? result.search : '');\n }\n result.href = result.format();\n return result;\n }\n\n if (!srcPath.length) {\n // no path at all. easy.\n // we've already handled the other stuff above.\n result.pathname = null;\n //to support http.request\n if (result.search) {\n result.path = '/' + result.search;\n } else {\n result.path = null;\n }\n result.href = result.format();\n return result;\n }\n\n // if a url ENDs in . or .., then it must get a trailing slash.\n // however, if it ends in anything else non-slashy,\n // then it must NOT get a trailing slash.\n var last = srcPath.slice(-1)[0];\n var hasTrailingSlash = (\n (result.host || relative.host || srcPath.length > 1) &&\n (last === '.' || last === '..') || last === '');\n\n // strip single dots, resolve double dots to parent dir\n // if the path tries to go above the root, `up` ends up > 0\n var up = 0;\n for (var i = srcPath.length; i >= 0; i--) {\n last = srcPath[i];\n if (last === '.') {\n srcPath.splice(i, 1);\n } else if (last === '..') {\n srcPath.splice(i, 1);\n up++;\n } else if (up) {\n srcPath.splice(i, 1);\n up--;\n }\n }\n\n // if the path is allowed to go above the root, restore leading ..s\n if (!mustEndAbs && !removeAllDots) {\n for (; up--; up) {\n srcPath.unshift('..');\n }\n }\n\n if (mustEndAbs && srcPath[0] !== '' &&\n (!srcPath[0] || srcPath[0].charAt(0) !== '/')) {\n srcPath.unshift('');\n }\n\n if (hasTrailingSlash && (srcPath.join('/').substr(-1) !== '/')) {\n srcPath.push('');\n }\n\n var isAbsolute = srcPath[0] === '' ||\n (srcPath[0] && srcPath[0].charAt(0) === '/');\n\n // put the host back\n if (psychotic) {\n result.hostname = result.host = isAbsolute ? '' :\n srcPath.length ? srcPath.shift() : '';\n //occationaly the auth can get stuck only in host\n //this especially happens in cases like\n //url.resolveObject('mailto:local1@domain1', 'local2@domain2')\n var authInHost = result.host && result.host.indexOf('@') > 0 ?\n result.host.split('@') : false;\n if (authInHost) {\n result.auth = authInHost.shift();\n result.host = result.hostname = authInHost.shift();\n }\n }\n\n mustEndAbs = mustEndAbs || (result.host && srcPath.length);\n\n if (mustEndAbs && !isAbsolute) {\n srcPath.unshift('');\n }\n\n if (!srcPath.length) {\n result.pathname = null;\n result.path = null;\n } else {\n result.pathname = srcPath.join('/');\n }\n\n //to support request.http\n if (!util.isNull(result.pathname) || !util.isNull(result.search)) {\n result.path = (result.pathname ? result.pathname : '') +\n (result.search ? result.search : '');\n }\n result.auth = relative.auth || result.auth;\n result.slashes = result.slashes || relative.slashes;\n result.href = result.format();\n return result;\n};\n\nUrl.prototype.parseHost = function() {\n var host = this.host;\n var port = portPattern.exec(host);\n if (port) {\n port = port[0];\n if (port !== ':') {\n this.port = port.substr(1);\n }\n host = host.substr(0, host.length - port.length);\n }\n if (host) this.hostname = host;\n};\n","// @flow\n\nimport Reference from './reference/v8.json';\nimport type {StylePropertySpecification} from './style-spec';\nimport type {\n StyleSpecification,\n SourceSpecification,\n LayerSpecification,\n PropertyValueSpecification,\n DataDrivenPropertyValueSpecification\n} from './types';\n\nfunction getPropertyReference(propertyName): StylePropertySpecification {\n for (let i = 0; i < Reference.layout.length; i++) {\n for (const key in Reference[Reference.layout[i]]) {\n if (key === propertyName) return (Reference[Reference.layout[i]][key]: any);\n }\n }\n for (let i = 0; i < Reference.paint.length; i++) {\n for (const key in Reference[Reference.paint[i]]) {\n if (key === propertyName) return (Reference[Reference.paint[i]][key]: any);\n }\n }\n\n return (null: any);\n}\n\nexport function eachSource(style: StyleSpecification, callback: (SourceSpecification) => void) {\n for (const k in style.sources) {\n callback(style.sources[k]);\n }\n}\n\nexport function eachLayer(style: StyleSpecification, callback: (LayerSpecification) => void) {\n for (const layer of style.layers) {\n callback(layer);\n }\n}\n\ntype PropertyCallback = ({\n path: [string, 'paint' | 'layout', string], // [layerid, paint/layout, property key]\n key: string,\n value: PropertyValueSpecification<mixed> | DataDrivenPropertyValueSpecification<mixed>,\n reference: StylePropertySpecification,\n set: (PropertyValueSpecification<mixed> | DataDrivenPropertyValueSpecification<mixed>) => void\n}) => void;\n\nexport function eachProperty(\n style: StyleSpecification,\n options: {paint?: boolean, layout?: boolean},\n callback: PropertyCallback\n) {\n function inner(layer, propertyType: 'paint' | 'layout') {\n const properties = (layer[propertyType]: any);\n if (!properties) return;\n Object.keys(properties).forEach((key) => {\n callback({\n path: [layer.id, propertyType, key],\n key,\n value: properties[key],\n reference: getPropertyReference(key),\n set(x) {\n properties[key] = x;\n }\n });\n });\n }\n\n eachLayer(style, (layer) => {\n if (options.paint) {\n inner(layer, 'paint');\n }\n if (options.layout) {\n inner(layer, 'layout');\n }\n });\n}\n","\nimport URL from 'url';\nimport {eachSource, eachLayer, eachProperty} from '../visit';\n\nfunction eachLayout(layer, callback) {\n for (const k in layer) {\n if (k.indexOf('layout') === 0) {\n callback(layer[k], k);\n }\n }\n}\n\nfunction eachPaint(layer, callback) {\n for (const k in layer) {\n if (k.indexOf('paint') === 0) {\n callback(layer[k], k);\n }\n }\n}\n\nfunction resolveConstant(style, value) {\n if (typeof value === 'string' && value[0] === '@') {\n return resolveConstant(style, style.constants[value]);\n } else {\n return value;\n }\n}\n\nfunction isFunction(value) {\n return Array.isArray(value.stops);\n}\n\nfunction renameProperty(obj, from, to) {\n obj[to] = obj[from]; delete obj[from];\n}\n\nexport default function(style) {\n style.version = 8;\n\n // Rename properties, reverse coordinates in source and layers\n eachSource(style, (source) => {\n if (source.type === 'video' && source.url !== undefined) {\n renameProperty(source, 'url', 'urls');\n }\n if (source.type === 'video') {\n source.coordinates.forEach((coord) => {\n return coord.reverse();\n });\n }\n });\n\n eachLayer(style, (layer) => {\n eachLayout(layer, (layout) => {\n if (layout['symbol-min-distance'] !== undefined) {\n renameProperty(layout, 'symbol-min-distance', 'symbol-spacing');\n }\n });\n\n eachPaint(layer, (paint) => {\n if (paint['background-image'] !== undefined) {\n renameProperty(paint, 'background-image', 'background-pattern');\n }\n if (paint['line-image'] !== undefined) {\n renameProperty(paint, 'line-image', 'line-pattern');\n }\n if (paint['fill-image'] !== undefined) {\n renameProperty(paint, 'fill-image', 'fill-pattern');\n }\n });\n });\n\n // Inline Constants\n eachProperty(style, {paint: true, layout: true}, (property) => {\n const value = resolveConstant(style, property.value);\n\n if (isFunction(value)) {\n value.stops.forEach((stop) => {\n stop[1] = resolveConstant(style, stop[1]);\n });\n }\n\n property.set(value);\n });\n delete style.constants;\n\n eachLayer(style, (layer) => {\n // get rid of text-max-size, icon-max-size\n // turn text-size, icon-size into layout properties\n // https://github.com/mapbox/mapbox-gl-style-spec/issues/255\n\n eachLayout(layer, (layout) => {\n delete layout['text-max-size'];\n delete layout['icon-max-size'];\n });\n\n eachPaint(layer, (paint) => {\n if (paint['text-size']) {\n if (!layer.layout) layer.layout = {};\n layer.layout['text-size'] = paint['text-size'];\n delete paint['text-size'];\n }\n\n if (paint['icon-size']) {\n if (!layer.layout) layer.layout = {};\n layer.layout['icon-size'] = paint['icon-size'];\n delete paint['icon-size'];\n }\n });\n });\n\n function migrateFontstackURL(input) {\n const inputParsed = URL.parse(input);\n const inputPathnameParts = inputParsed.pathname.split('/');\n\n if (inputParsed.protocol !== 'mapbox:') {\n return input;\n\n } else if (inputParsed.hostname === 'fontstack') {\n assert(decodeURI(inputParsed.pathname) === '/{fontstack}/{range}.pbf');\n return 'mapbox://fonts/mapbox/{fontstack}/{range}.pbf';\n\n } else if (inputParsed.hostname === 'fonts') {\n assert(inputPathnameParts[1] === 'v1');\n assert(decodeURI(inputPathnameParts[3]) === '{fontstack}');\n assert(decodeURI(inputPathnameParts[4]) === '{range}.pbf');\n return `mapbox://fonts/${inputPathnameParts[2]}/{fontstack}/{range}.pbf`;\n\n } else {\n assert(false);\n }\n\n function assert(predicate) {\n if (!predicate) {\n throw new Error(`Invalid font url: \"${input}\"`);\n }\n }\n }\n\n if (style.glyphs) {\n style.glyphs = migrateFontstackURL(style.glyphs);\n }\n\n function migrateFontStack(font) {\n function splitAndTrim(string) {\n return string.split(',').map((s) => {\n return s.trim();\n });\n }\n\n if (Array.isArray(font)) {\n // Assume it's a previously migrated font-array.\n return font;\n\n } else if (typeof font === 'string') {\n return splitAndTrim(font);\n\n } else if (typeof font === 'object') {\n font.stops.forEach((stop) => {\n stop[1] = splitAndTrim(stop[1]);\n });\n return font;\n\n } else {\n throw new Error(\"unexpected font value\");\n }\n }\n\n eachLayer(style, (layer) => {\n eachLayout(layer, (layout) => {\n if (layout['text-font']) {\n layout['text-font'] = migrateFontStack(layout['text-font']);\n }\n });\n });\n\n // Reverse order of symbol layers. This is an imperfect migration.\n //\n // The order of a symbol layer in the layers list affects two things:\n // - how it is drawn relative to other layers (like oneway arrows below bridges)\n // - the placement priority compared to other layers\n //\n // It's impossible to reverse the placement priority without breaking the draw order\n // in some cases. This migration only reverses the order of symbol layers that\n // are above all other types of layers.\n //\n // Symbol layers that are at the top of the map preserve their priority.\n // Symbol layers that are below another type (line, fill) of layer preserve their draw order.\n\n let firstSymbolLayer = 0;\n for (let i = style.layers.length - 1; i >= 0; i--) {\n const layer = style.layers[i];\n if (layer.type !== 'symbol') {\n firstSymbolLayer = i + 1;\n break;\n }\n }\n\n const symbolLayers = style.layers.splice(firstSymbolLayer);\n symbolLayers.reverse();\n style.layers = style.layers.concat(symbolLayers);\n\n return style;\n}\n","\nexport default function (output, ...inputs) {\n for (const input of inputs) {\n for (const k in input) {\n output[k] = input[k];\n }\n }\n return output;\n}\n","// @flow\n\nclass ParsingError extends Error {\n key: string;\n message: string;\n constructor(key: string, message: string) {\n super(message);\n this.message = message;\n this.key = key;\n }\n}\n\nexport default ParsingError;\n","// @flow\n\nimport type {Expression} from './expression';\n\n/**\n * Tracks `let` bindings during expression parsing.\n * @private\n */\nclass Scope {\n parent: ?Scope;\n bindings: {[string]: Expression};\n constructor(parent?: Scope, bindings: Array<[string, Expression]> = []) {\n this.parent = parent;\n this.bindings = {};\n for (const [name, expression] of bindings) {\n this.bindings[name] = expression;\n }\n }\n\n concat(bindings: Array<[string, Expression]>) {\n return new Scope(this, bindings);\n }\n\n get(name: string): Expression {\n if (this.bindings[name]) { return this.bindings[name]; }\n if (this.parent) { return this.parent.get(name); }\n throw new Error(`${name} not found in scope.`);\n }\n\n has(name: string): boolean {\n if (this.bindings[name]) return true;\n return this.parent ? this.parent.has(name) : false;\n }\n}\n\nexport default Scope;\n","// @flow\n\nexport type NullTypeT = { kind: 'null' };\nexport type NumberTypeT = { kind: 'number' };\nexport type StringTypeT = { kind: 'string' };\nexport type BooleanTypeT = { kind: 'boolean' };\nexport type ColorTypeT = { kind: 'color' };\nexport type ObjectTypeT = { kind: 'object' };\nexport type ValueTypeT = { kind: 'value' };\nexport type ErrorTypeT = { kind: 'error' };\nexport type CollatorTypeT = { kind: 'collator' };\nexport type FormattedTypeT = { kind: 'formatted' };\n\nexport type EvaluationKind = 'constant' | 'source' | 'camera' | 'composite';\n\nexport type Type =\n NullTypeT |\n NumberTypeT |\n StringTypeT |\n BooleanTypeT |\n ColorTypeT |\n ObjectTypeT |\n ValueTypeT |\n ArrayType | // eslint-disable-line no-use-before-define\n ErrorTypeT |\n CollatorTypeT |\n FormattedTypeT\n\nexport type ArrayType = {\n kind: 'array',\n itemType: Type,\n N: ?number\n}\n\nexport const NullType = { kind: 'null' };\nexport const NumberType = { kind: 'number' };\nexport const StringType = { kind: 'string' };\nexport const BooleanType = { kind: 'boolean' };\nexport const ColorType = { kind: 'color' };\nexport const ObjectType = { kind: 'object' };\nexport const ValueType = { kind: 'value' };\nexport const ErrorType = { kind: 'error' };\nexport const CollatorType = { kind: 'collator' };\nexport const FormattedType = { kind: 'formatted' };\n\nexport function array(itemType: Type, N: ?number): ArrayType {\n return {\n kind: 'array',\n itemType,\n N\n };\n}\n\nexport function toString(type: Type): string {\n if (type.kind === 'array') {\n const itemType = toString(type.itemType);\n return typeof type.N === 'number' ?\n `array<${itemType}, ${type.N}>` :\n type.itemType.kind === 'value' ? 'array' : `array<${itemType}>`;\n } else {\n return type.kind;\n }\n}\n\nconst valueMemberTypes = [\n NullType,\n NumberType,\n StringType,\n BooleanType,\n ColorType,\n FormattedType,\n ObjectType,\n array(ValueType)\n];\n\n/**\n * Returns null if `t` is a subtype of `expected`; otherwise returns an\n * error message.\n * @private\n */\nexport function checkSubtype(expected: Type, t: Type): ?string {\n if (t.kind === 'error') {\n // Error is a subtype of every type\n return null;\n } else if (expected.kind === 'array') {\n if (t.kind === 'array' &&\n ((t.N === 0 && t.itemType.kind === 'value') || !checkSubtype(expected.itemType, t.itemType)) &&\n (typeof expected.N !== 'number' || expected.N === t.N)) {\n return null;\n }\n } else if (expected.kind === t.kind) {\n return null;\n } else if (expected.kind === 'value') {\n for (const memberType of valueMemberTypes) {\n if (!checkSubtype(memberType, t)) {\n return null;\n }\n }\n }\n\n return `Expected ${toString(expected)} but found ${toString(t)} instead.`;\n}\n","// (c) Dean McNamee <dean@gmail.com>, 2012.\n//\n// https://github.com/deanm/css-color-parser-js\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n// http://www.w3.org/TR/css3-color/\nvar kCSSColorTable = {\n \"transparent\": [0,0,0,0], \"aliceblue\": [240,248,255,1],\n \"antiquewhite\": [250,235,215,1], \"aqua\": [0,255,255,1],\n \"aquamarine\": [127,255,212,1], \"azure\": [240,255,255,1],\n \"beige\": [245,245,220,1], \"bisque\": [255,228,196,1],\n \"black\": [0,0,0,1], \"blanchedalmond\": [255,235,205,1],\n \"blue\": [0,0,255,1], \"blueviolet\": [138,43,226,1],\n \"brown\": [165,42,42,1], \"burlywood\": [222,184,135,1],\n \"cadetblue\": [95,158,160,1], \"chartreuse\": [127,255,0,1],\n \"chocolate\": [210,105,30,1], \"coral\": [255,127,80,1],\n \"cornflowerblue\": [100,149,237,1], \"cornsilk\": [255,248,220,1],\n \"crimson\": [220,20,60,1], \"cyan\": [0,255,255,1],\n \"darkblue\": [0,0,139,1], \"darkcyan\": [0,139,139,1],\n \"darkgoldenrod\": [184,134,11,1], \"darkgray\": [169,169,169,1],\n \"darkgreen\": [0,100,0,1], \"darkgrey\": [169,169,169,1],\n \"darkkhaki\": [189,183,107,1], \"darkmagenta\": [139,0,139,1],\n \"darkolivegreen\": [85,107,47,1], \"darkorange\": [255,140,0,1],\n \"darkorchid\": [153,50,204,1], \"darkred\": [139,0,0,1],\n \"darksalmon\": [233,150,122,1], \"darkseagreen\": [143,188,143,1],\n \"darkslateblue\": [72,61,139,1], \"darkslategray\": [47,79,79,1],\n \"darkslategrey\": [47,79,79,1], \"darkturquoise\": [0,206,209,1],\n \"darkviolet\": [148,0,211,1], \"deeppink\": [255,20,147,1],\n \"deepskyblue\": [0,191,255,1], \"dimgray\": [105,105,105,1],\n \"dimgrey\": [105,105,105,1], \"dodgerblue\": [30,144,255,1],\n \"firebrick\": [178,34,34,1], \"floralwhite\": [255,250,240,1],\n \"forestgreen\": [34,139,34,1], \"fuchsia\": [255,0,255,1],\n \"gainsboro\": [220,220,220,1], \"ghostwhite\": [248,248,255,1],\n \"gold\": [255,215,0,1], \"goldenrod\": [218,165,32,1],\n \"gray\": [128,128,128,1], \"green\": [0,128,0,1],\n \"greenyellow\": [173,255,47,1], \"grey\": [128,128,128,1],\n \"honeydew\": [240,255,240,1], \"hotpink\": [255,105,180,1],\n \"indianred\": [205,92,92,1], \"indigo\": [75,0,130,1],\n \"ivory\": [255,255,240,1], \"khaki\": [240,230,140,1],\n \"lavender\": [230,230,250,1], \"lavenderblush\": [255,240,245,1],\n \"lawngreen\": [124,252,0,1], \"lemonchiffon\": [255,250,205,1],\n \"lightblue\": [173,216,230,1], \"lightcoral\": [240,128,128,1],\n \"lightcyan\": [224,255,255,1], \"lightgoldenrodyellow\": [250,250,210,1],\n \"lightgray\": [211,211,211,1], \"lightgreen\": [144,238,144,1],\n \"lightgrey\": [211,211,211,1], \"lightpink\": [255,182,193,1],\n \"lightsalmon\": [255,160,122,1], \"lightseagreen\": [32,178,170,1],\n \"lightskyblue\": [135,206,250,1], \"lightslategray\": [119,136,153,1],\n \"lightslategrey\": [119,136,153,1], \"lightsteelblue\": [176,196,222,1],\n \"lightyellow\": [255,255,224,1], \"lime\": [0,255,0,1],\n \"limegreen\": [50,205,50,1], \"linen\": [250,240,230,1],\n \"magenta\": [255,0,255,1], \"maroon\": [128,0,0,1],\n \"mediumaquamarine\": [102,205,170,1], \"mediumblue\": [0,0,205,1],\n \"mediumorchid\": [186,85,211,1], \"mediumpurple\": [147,112,219,1],\n \"mediumseagreen\": [60,179,113,1], \"mediumslateblue\": [123,104,238,1],\n \"mediumspringgreen\": [0,250,154,1], \"mediumturquoise\": [72,209,204,1],\n \"mediumvioletred\": [199,21,133,1], \"midnightblue\": [25,25,112,1],\n \"mintcream\": [245,255,250,1], \"mistyrose\": [255,228,225,1],\n \"moccasin\": [255,228,181,1], \"navajowhite\": [255,222,173,1],\n \"navy\": [0,0,128,1], \"oldlace\": [253,245,230,1],\n \"olive\": [128,128,0,1], \"olivedrab\": [107,142,35,1],\n \"orange\": [255,165,0,1], \"orangered\": [255,69,0,1],\n \"orchid\": [218,112,214,1], \"palegoldenrod\": [238,232,170,1],\n \"palegreen\": [152,251,152,1], \"paleturquoise\": [175,238,238,1],\n \"palevioletred\": [219,112,147,1], \"papayawhip\": [255,239,213,1],\n \"peachpuff\": [255,218,185,1], \"peru\": [205,133,63,1],\n \"pink\": [255,192,203,1], \"plum\": [221,160,221,1],\n \"powderblue\": [176,224,230,1], \"purple\": [128,0,128,1],\n \"rebeccapurple\": [102,51,153,1],\n \"red\": [255,0,0,1], \"rosybrown\": [188,143,143,1],\n \"royalblue\": [65,105,225,1], \"saddlebrown\": [139,69,19,1],\n \"salmon\": [250,128,114,1], \"sandybrown\": [244,164,96,1],\n \"seagreen\": [46,139,87,1], \"seashell\": [255,245,238,1],\n \"sienna\": [160,82,45,1], \"silver\": [192,192,192,1],\n \"skyblue\": [135,206,235,1], \"slateblue\": [106,90,205,1],\n \"slategray\": [112,128,144,1], \"slategrey\": [112,128,144,1],\n \"snow\": [255,250,250,1], \"springgreen\": [0,255,127,1],\n \"steelblue\": [70,130,180,1], \"tan\": [210,180,140,1],\n \"teal\": [0,128,128,1], \"thistle\": [216,191,216,1],\n \"tomato\": [255,99,71,1], \"turquoise\": [64,224,208,1],\n \"violet\": [238,130,238,1], \"wheat\": [245,222,179,1],\n \"white\": [255,255,255,1], \"whitesmoke\": [245,245,245,1],\n \"yellow\": [255,255,0,1], \"yellowgreen\": [154,205,50,1]}\n\nfunction clamp_css_byte(i) { // Clamp to integer 0 .. 255.\n i = Math.round(i); // Seems to be what Chrome does (vs truncation).\n return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clamp_css_float(f) { // Clamp to float 0.0 .. 1.0.\n return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parse_css_int(str) { // int or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_byte(parseFloat(str) / 100 * 255);\n return clamp_css_byte(parseInt(str));\n}\n\nfunction parse_css_float(str) { // float or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_float(parseFloat(str) / 100);\n return clamp_css_float(parseFloat(str));\n}\n\nfunction css_hue_to_rgb(m1, m2, h) {\n if (h < 0) h += 1;\n else if (h > 1) h -= 1;\n\n if (h * 6 < 1) return m1 + (m2 - m1) * h * 6;\n if (h * 2 < 1) return m2;\n if (h * 3 < 2) return m1 + (m2 - m1) * (2/3 - h) * 6;\n return m1;\n}\n\nfunction parseCSSColor(css_str) {\n // Remove all whitespace, not compliant, but should just be more accepting.\n var str = css_str.replace(/ /g, '').toLowerCase();\n\n // Color keywords (and transparent) lookup.\n if (str in kCSSColorTable) return kCSSColorTable[str].slice(); // dup.\n\n // #abc and #abc123 syntax.\n if (str[0] === '#') {\n if (str.length === 4) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xfff)) return null; // Covers NaN.\n return [((iv & 0xf00) >> 4) | ((iv & 0xf00) >> 8),\n (iv & 0xf0) | ((iv & 0xf0) >> 4),\n (iv & 0xf) | ((iv & 0xf) << 4),\n 1];\n } else if (str.length === 7) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xffffff)) return null; // Covers NaN.\n return [(iv & 0xff0000) >> 16,\n (iv & 0xff00) >> 8,\n iv & 0xff,\n 1];\n }\n\n return null;\n }\n\n var op = str.indexOf('('), ep = str.indexOf(')');\n if (op !== -1 && ep + 1 === str.length) {\n var fname = str.substr(0, op);\n var params = str.substr(op+1, ep-(op+1)).split(',');\n var alpha = 1; // To allow case fallthrough.\n switch (fname) {\n case 'rgba':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'rgb':\n if (params.length !== 3) return null;\n return [parse_css_int(params[0]),\n parse_css_int(params[1]),\n parse_css_int(params[2]),\n alpha];\n case 'hsla':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'hsl':\n if (params.length !== 3) return null;\n var h = (((parseFloat(params[0]) % 360) + 360) % 360) / 360; // 0 .. 1\n // NOTE(deanm): According to the CSS spec s/l should only be\n // percentages, but we don't bother and let float or percentage.\n var s = parse_css_float(params[1]);\n var l = parse_css_float(params[2]);\n var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n var m1 = l * 2 - m2;\n return [clamp_css_byte(css_hue_to_rgb(m1, m2, h+1/3) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h-1/3) * 255),\n alpha];\n default:\n return null;\n }\n }\n\n return null;\n}\n\ntry { exports.parseCSSColor = parseCSSColor } catch(e) { }\n","// @flow\n\nimport { parseCSSColor } from 'csscolorparser';\n\n/**\n * An RGBA color value. Create instances from color strings using the static\n * method `Color.parse`. The constructor accepts RGB channel values in the range\n * `[0, 1]`, premultiplied by A.\n *\n * @param {number} r The red channel.\n * @param {number} g The green channel.\n * @param {number} b The blue channel.\n * @param {number} a The alpha channel.\n * @private\n */\nclass Color {\n r: number;\n g: number;\n b: number;\n a: number;\n\n constructor(r: number, g: number, b: number, a: number = 1) {\n this.r = r;\n this.g = g;\n this.b = b;\n this.a = a;\n }\n\n static black: Color;\n static white: Color;\n static transparent: Color;\n static red: Color;\n\n /**\n * Parses valid CSS color strings and returns a `Color` instance.\n * @returns A `Color` instance, or `undefined` if the input is not a valid color string.\n */\n static parse(input: ?string): Color | void {\n if (!input) {\n return undefined;\n }\n\n if (input instanceof Color) {\n return input;\n }\n\n if (typeof input !== 'string') {\n return undefined;\n }\n\n const rgba = parseCSSColor(input);\n if (!rgba) {\n return undefined;\n }\n\n return new Color(\n rgba[0] / 255 * rgba[3],\n rgba[1] / 255 * rgba[3],\n rgba[2] / 255 * rgba[3],\n rgba[3]\n );\n }\n\n /**\n * Returns an RGBA string representing the color value.\n *\n * @returns An RGBA string.\n * @example\n * var purple = new Color.parse('purple');\n * purple.toString; // = \"rgba(128,0,128,1)\"\n * var translucentGreen = new Color.parse('rgba(26, 207, 26, .73)');\n * translucentGreen.toString(); // = \"rgba(26,207,26,0.73)\"\n */\n toString(): string {\n const [r, g, b, a] = this.toArray();\n return `rgba(${Math.round(r)},${Math.round(g)},${Math.round(b)},${a})`;\n }\n\n toArray(): [number, number, number, number] {\n const {r, g, b, a} = this;\n return a === 0 ? [0, 0, 0, 0] : [\n r * 255 / a,\n g * 255 / a,\n b * 255 / a,\n a\n ];\n }\n}\n\nColor.black = new Color(0, 0, 0, 1);\nColor.white = new Color(1, 1, 1, 1);\nColor.transparent = new Color(0, 0, 0, 0);\nColor.red = new Color(1, 0, 0, 1);\n\nexport default Color;\n","// @flow\n\n// Flow type declarations for Intl cribbed from\n// https://github.com/facebook/flow/issues/1270\n\ndeclare var Intl: {\n Collator: Class<Intl$Collator>\n};\n\ndeclare class Intl$Collator {\n constructor (\n locales?: string | string[],\n options?: CollatorOptions\n ): Intl$Collator;\n\n static (\n locales?: string | string[],\n options?: CollatorOptions\n ): Intl$Collator;\n\n compare (a: string, b: string): number;\n\n resolvedOptions(): any;\n}\n\ntype CollatorOptions = {\n localeMatcher?: 'lookup' | 'best fit',\n usage?: 'sort' | 'search',\n sensitivity?: 'base' | 'accent' | 'case' | 'variant',\n ignorePunctuation?: boolean,\n numeric?: boolean,\n caseFirst?: 'upper' | 'lower' | 'false'\n}\n\nexport default class Collator {\n locale: string | null;\n sensitivity: 'base' | 'accent' | 'case' | 'variant';\n collator: Intl$Collator;\n\n constructor(caseSensitive: boolean, diacriticSensitive: boolean, locale: string | null) {\n if (caseSensitive)\n this.sensitivity = diacriticSensitive ? 'variant' : 'case';\n else\n this.sensitivity = diacriticSensitive ? 'accent' : 'base';\n\n this.locale = locale;\n this.collator = new Intl.Collator(this.locale ? this.locale : [],\n { sensitivity: this.sensitivity, usage: 'search' });\n }\n\n compare(lhs: string, rhs: string): number {\n return this.collator.compare(lhs, rhs);\n }\n\n resolvedLocale(): string {\n // We create a Collator without \"usage: search\" because we don't want\n // the search options encoded in our result (e.g. \"en-u-co-search\")\n return new Intl.Collator(this.locale ? this.locale : [])\n .resolvedOptions().locale;\n }\n}\n","// @flow\n\nexport class FormattedSection {\n text: string;\n scale: number | null;\n fontStack: string | null;\n\n constructor(text: string, scale: number | null, fontStack: string | null) {\n this.text = text;\n this.scale = scale;\n this.fontStack = fontStack;\n }\n}\n\nexport default class Formatted {\n sections: Array<FormattedSection>;\n\n constructor(sections: Array<FormattedSection>) {\n this.sections = sections;\n }\n\n static fromString(unformatted: string): Formatted {\n return new Formatted([new FormattedSection(unformatted, null, null)]);\n }\n\n toString(): string {\n return this.sections.map(section => section.text).join('');\n }\n\n serialize() {\n const serialized = [\"format\"];\n for (const section of this.sections) {\n serialized.push(section.text);\n const options = {};\n if (section.fontStack) {\n options[\"text-font\"] = [\"literal\", section.fontStack.split(',')];\n }\n if (section.scale) {\n options[\"font-scale\"] = section.scale;\n }\n serialized.push(options);\n }\n return serialized;\n }\n}\n","// @flow\n\nimport assert from 'assert';\n\nimport Color from '../util/color';\nimport Collator from './types/collator';\nimport Formatted from './types/formatted';\nimport { NullType, NumberType, StringType, BooleanType, ColorType, ObjectType, ValueType, CollatorType, FormattedType, array } from './types';\n\nimport type { Type } from './types';\n\nexport function validateRGBA(r: mixed, g: mixed, b: mixed, a?: mixed): ?string {\n if (!(\n typeof r === 'number' && r >= 0 && r <= 255 &&\n typeof g === 'number' && g >= 0 && g <= 255 &&\n typeof b === 'number' && b >= 0 && b <= 255\n )) {\n const value = typeof a === 'number' ? [r, g, b, a] : [r, g, b];\n return `Invalid rgba value [${value.join(', ')}]: 'r', 'g', and 'b' must be between 0 and 255.`;\n }\n\n if (!(\n typeof a === 'undefined' || (typeof a === 'number' && a >= 0 && a <= 1)\n )) {\n return `Invalid rgba value [${[r, g, b, a].join(', ')}]: 'a' must be between 0 and 1.`;\n }\n\n return null;\n}\n\nexport type Value = null | string | boolean | number | Color | Collator | Formatted | $ReadOnlyArray<Value> | { +[string]: Value }\n\nexport function isValue(mixed: mixed): boolean {\n if (mixed === null) {\n return true;\n } else if (typeof mixed === 'string') {\n return true;\n } else if (typeof mixed === 'boolean') {\n return true;\n } else if (typeof mixed === 'number') {\n return true;\n } else if (mixed instanceof Color) {\n return true;\n } else if (mixed instanceof Collator) {\n return true;\n } else if (mixed instanceof Formatted) {\n return true;\n } else if (Array.isArray(mixed)) {\n for (const item of mixed) {\n if (!isValue(item)) {\n return false;\n }\n }\n return true;\n } else if (typeof mixed === 'object') {\n for (const key in mixed) {\n if (!isValue(mixed[key])) {\n return false;\n }\n }\n return true;\n } else {\n return false;\n }\n}\n\nexport function typeOf(value: Value): Type {\n if (value === null) {\n return NullType;\n } else if (typeof value === 'string') {\n return StringType;\n } else if (typeof value === 'boolean') {\n return BooleanType;\n } else if (typeof value === 'number') {\n return NumberType;\n } else if (value instanceof Color) {\n return ColorType;\n } else if (value instanceof Collator) {\n return CollatorType;\n } else if (value instanceof Formatted) {\n return FormattedType;\n } else if (Array.isArray(value)) {\n const length = value.length;\n let itemType: ?Type;\n\n for (const item of value) {\n const t = typeOf(item);\n if (!itemType) {\n itemType = t;\n } else if (itemType === t) {\n continue;\n } else {\n itemType = ValueType;\n break;\n }\n }\n\n return array(itemType || ValueType, length);\n } else {\n assert(typeof value === 'object');\n return ObjectType;\n }\n}\n\nexport function toString(value: Value) {\n const type = typeof value;\n if (value === null) {\n return '';\n } else if (type === 'string' || type === 'number' || type === 'boolean') {\n return String(value);\n } else if (value instanceof Color || value instanceof Formatted) {\n return value.toString();\n } else {\n return JSON.stringify(value);\n }\n}\n\nexport { Color, Collator };\n","// @flow\n\nimport assert from 'assert';\nimport { isValue, typeOf, Color } from '../values';\nimport Formatted from '../types/formatted';\n\nimport type { Type } from '../types';\nimport type { Value } from '../values';\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\n\nclass Literal implements Expression {\n type: Type;\n value: Value;\n\n constructor(type: Type, value: Value) {\n this.type = type;\n this.value = value;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n if (args.length !== 2)\n return context.error(`'literal' expression requires exactly one argument, but found ${args.length - 1} instead.`);\n\n if (!isValue(args[1]))\n return context.error(`invalid value`);\n\n const value = (args[1]: any);\n let type = typeOf(value);\n\n // special case: infer the item type if possible for zero-length arrays\n const expected = context.expectedType;\n if (\n type.kind === 'array' &&\n type.N === 0 &&\n expected &&\n expected.kind === 'array' &&\n (typeof expected.N !== 'number' || expected.N === 0)\n ) {\n type = expected;\n }\n\n return new Literal(type, value);\n }\n\n evaluate() {\n return this.value;\n }\n\n eachChild() {}\n\n possibleOutputs() {\n return [this.value];\n }\n\n serialize(): Array<mixed> {\n if (this.type.kind === 'array' || this.type.kind === 'object') {\n return [\"literal\", this.value];\n } else if (this.value instanceof Color) {\n // Constant-folding can generate Literal expressions that you\n // couldn't actually generate with a \"literal\" expression,\n // so we have to implement an equivalent serialization here\n return [\"rgba\"].concat(this.value.toArray());\n } else if (this.value instanceof Formatted) {\n // Same as Color\n return this.value.serialize();\n } else {\n assert(this.value === null ||\n typeof this.value === 'string' ||\n typeof this.value === 'number' ||\n typeof this.value === 'boolean');\n return (this.value: any);\n }\n }\n}\n\nexport default Literal;\n","// @flow\n\nclass RuntimeError {\n name: string;\n message: string;\n\n constructor(message: string) {\n this.name = 'ExpressionEvaluationError';\n this.message = message;\n }\n\n toJSON() {\n return this.message;\n }\n}\n\nexport default RuntimeError;\n","// @flow\n\nimport assert from 'assert';\n\nimport {\n ObjectType,\n ValueType,\n StringType,\n NumberType,\n BooleanType,\n checkSubtype,\n toString,\n array\n} from '../types';\nimport RuntimeError from '../runtime_error';\nimport { typeOf } from '../values';\n\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\nimport type { Value } from '../values';\nimport type { Type } from '../types';\n\nconst types = {\n string: StringType,\n number: NumberType,\n boolean: BooleanType,\n object: ObjectType\n};\n\nclass Assertion implements Expression {\n type: Type;\n args: Array<Expression>;\n\n constructor(type: Type, args: Array<Expression>) {\n this.type = type;\n this.args = args;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext): ?Expression {\n if (args.length < 2)\n return context.error(`Expected at least one argument.`);\n\n let i = 1;\n let type;\n\n const name: string = (args[0]: any);\n if (name === 'array') {\n let itemType;\n if (args.length > 2) {\n const type = args[1];\n if (typeof type !== 'string' || !(type in types) || type === 'object')\n return context.error('The item type argument of \"array\" must be one of string, number, boolean', 1);\n itemType = types[type];\n i++;\n } else {\n itemType = ValueType;\n }\n\n let N;\n if (args.length > 3) {\n if (args[2] !== null &&\n (typeof args[2] !== 'number' ||\n args[2] < 0 ||\n args[2] !== Math.floor(args[2]))\n ) {\n return context.error('The length argument to \"array\" must be a positive integer literal', 2);\n }\n N = args[2];\n i++;\n }\n\n type = array(itemType, N);\n } else {\n assert(types[name], name);\n type = types[name];\n }\n\n const parsed = [];\n for (; i < args.length; i++) {\n const input = context.parse(args[i], i, ValueType);\n if (!input) return null;\n parsed.push(input);\n }\n\n return new Assertion(type, parsed);\n }\n\n evaluate(ctx: EvaluationContext) {\n for (let i = 0; i < this.args.length; i++) {\n const value = this.args[i].evaluate(ctx);\n const error = checkSubtype(this.type, typeOf(value));\n if (!error) {\n return value;\n } else if (i === this.args.length - 1) {\n throw new RuntimeError(`Expected value to be of type ${toString(this.type)}, but found ${toString(typeOf(value))} instead.`);\n }\n }\n\n assert(false);\n return null;\n }\n\n eachChild(fn: (Expression) => void) {\n this.args.forEach(fn);\n }\n\n possibleOutputs(): Array<Value | void> {\n return [].concat(...this.args.map((arg) => arg.possibleOutputs()));\n }\n\n serialize(): Array<mixed> {\n const type = this.type;\n const serialized = [type.kind];\n if (type.kind === 'array') {\n const itemType = type.itemType;\n if (itemType.kind === 'string' ||\n itemType.kind === 'number' ||\n itemType.kind === 'boolean') {\n serialized.push(itemType.kind);\n const N = type.N;\n if (typeof N === 'number' || this.args.length > 1) {\n serialized.push(N);\n }\n }\n }\n return serialized.concat(this.args.map(arg => arg.serialize()));\n }\n}\n\nexport default Assertion;\n","// @flow\n\nimport { NumberType, ValueType, FormattedType, array, StringType } from '../types';\nimport Formatted, { FormattedSection } from '../types/formatted';\nimport { toString } from '../values';\n\nimport type { Expression } from '../expression';\nimport type EvaluationContext from '../evaluation_context';\nimport type ParsingContext from '../parsing_context';\nimport type { Type } from '../types';\n\ntype FormattedSectionExpression = {\n text: Expression,\n scale: Expression | null;\n font: Expression | null;\n}\n\nexport default class FormatExpression implements Expression {\n type: Type;\n sections: Array<FormattedSectionExpression>;\n\n constructor(sections: Array<FormattedSectionExpression>) {\n this.type = FormattedType;\n this.sections = sections;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext): ?Expression {\n if (args.length < 3) {\n return context.error(`Expected at least two arguments.`);\n }\n\n if ((args.length - 1) % 2 !== 0) {\n return context.error(`Expected an even number of arguments.`);\n }\n\n const sections: Array<FormattedSectionExpression> = [];\n for (let i = 1; i < args.length - 1; i += 2) {\n const text = context.parse(args[i], 1, ValueType);\n if (!text) return null;\n const kind = text.type.kind;\n if (kind !== 'string' && kind !== 'value' && kind !== 'null')\n return context.error(`Formatted text type must be 'string', 'value', or 'null'.`);\n\n const options = (args[i + 1]: any);\n if (typeof options !== \"object\" || Array.isArray(options))\n return context.error(`Format options argument must be an object.`);\n\n let scale = null;\n if (options['font-scale']) {\n scale = context.parse(options['font-scale'], 1, NumberType);\n if (!scale) return null;\n }\n\n let font = null;\n if (options['text-font']) {\n font = context.parse(options['text-font'], 1, array(StringType));\n if (!font) return null;\n }\n sections.push({text, scale, font});\n }\n\n return new FormatExpression(sections);\n }\n\n evaluate(ctx: EvaluationContext) {\n return new Formatted(\n this.sections.map(section =>\n new FormattedSection(\n toString(section.text.evaluate(ctx)),\n section.scale ? section.scale.evaluate(ctx) : null,\n section.font ? section.font.evaluate(ctx).join(',') : null\n )\n )\n );\n }\n\n eachChild(fn: (Expression) => void) {\n for (const section of this.sections) {\n fn(section.text);\n if (section.scale) {\n fn(section.scale);\n }\n if (section.font) {\n fn(section.font);\n }\n }\n }\n\n possibleOutputs() {\n // Technically the combinatoric set of all children\n // Usually, this.text will be undefined anyway\n return [undefined];\n }\n\n serialize() {\n const serialized = [\"format\"];\n for (const section of this.sections) {\n serialized.push(section.text.serialize());\n const options = {};\n if (section.scale) {\n options['font-scale'] = section.scale.serialize();\n }\n if (section.font) {\n options['text-font'] = section.font.serialize();\n }\n serialized.push(options);\n }\n return serialized;\n }\n}\n","// @flow\n\nimport assert from 'assert';\n\nimport {BooleanType, ColorType, NumberType, StringType, ValueType} from '../types';\nimport {Color, toString as valueToString, validateRGBA} from '../values';\nimport RuntimeError from '../runtime_error';\nimport Formatted from '../types/formatted';\nimport FormatExpression from '../definitions/format';\n\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\nimport type { Value } from '../values';\nimport type { Type } from '../types';\n\nconst types = {\n 'to-boolean': BooleanType,\n 'to-color': ColorType,\n 'to-number': NumberType,\n 'to-string': StringType\n};\n\n/**\n * Special form for error-coalescing coercion expressions \"to-number\",\n * \"to-color\". Since these coercions can fail at runtime, they accept multiple\n * arguments, only evaluating one at a time until one succeeds.\n *\n * @private\n */\nclass Coercion implements Expression {\n type: Type;\n args: Array<Expression>;\n\n constructor(type: Type, args: Array<Expression>) {\n this.type = type;\n this.args = args;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext): ?Expression {\n if (args.length < 2)\n return context.error(`Expected at least one argument.`);\n\n const name: string = (args[0]: any);\n assert(types[name], name);\n\n if ((name === 'to-boolean' || name === 'to-string') && args.length !== 2)\n return context.error(`Expected one argument.`);\n\n const type = types[name];\n\n const parsed = [];\n for (let i = 1; i < args.length; i++) {\n const input = context.parse(args[i], i, ValueType);\n if (!input) return null;\n parsed.push(input);\n }\n\n return new Coercion(type, parsed);\n }\n\n evaluate(ctx: EvaluationContext) {\n if (this.type.kind === 'boolean') {\n return Boolean(this.args[0].evaluate(ctx));\n } else if (this.type.kind === 'color') {\n let input;\n let error;\n for (const arg of this.args) {\n input = arg.evaluate(ctx);\n error = null;\n if (input instanceof Color) {\n return input;\n } else if (typeof input === 'string') {\n const c = ctx.parseColor(input);\n if (c) return c;\n } else if (Array.isArray(input)) {\n if (input.length < 3 || input.length > 4) {\n error = `Invalid rbga value ${JSON.stringify(input)}: expected an array containing either three or four numeric values.`;\n } else {\n error = validateRGBA(input[0], input[1], input[2], input[3]);\n }\n if (!error) {\n return new Color((input[0]: any) / 255, (input[1]: any) / 255, (input[2]: any) / 255, (input[3]: any));\n }\n }\n }\n throw new RuntimeError(error || `Could not parse color from value '${typeof input === 'string' ? input : JSON.stringify(input)}'`);\n } else if (this.type.kind === 'number') {\n let value = null;\n for (const arg of this.args) {\n value = arg.evaluate(ctx);\n if (value === null) return 0;\n const num = Number(value);\n if (isNaN(num)) continue;\n return num;\n }\n throw new RuntimeError(`Could not convert ${JSON.stringify(value)} to number.`);\n } else if (this.type.kind === 'formatted') {\n // There is no explicit 'to-formatted' but this coercion can be implicitly\n // created by properties that expect the 'formatted' type.\n return Formatted.fromString(valueToString(this.args[0].evaluate(ctx)));\n } else {\n return valueToString(this.args[0].evaluate(ctx));\n }\n }\n\n eachChild(fn: (Expression) => void) {\n this.args.forEach(fn);\n }\n\n possibleOutputs(): Array<Value | void> {\n return [].concat(...this.args.map((arg) => arg.possibleOutputs()));\n }\n\n serialize() {\n if (this.type.kind === 'formatted') {\n return new FormatExpression([{text: this.args[0], scale: null, font: null}]).serialize();\n }\n const serialized = [`to-${this.type.kind}`];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Coercion;\n","// @flow\n\nimport { Color } from './values';\n\nimport type { GlobalProperties, Feature, FeatureState } from './index';\n\nconst geometryTypes = ['Unknown', 'Point', 'LineString', 'Polygon'];\n\nclass EvaluationContext {\n globals: GlobalProperties;\n feature: ?Feature;\n featureState: ?FeatureState;\n\n _parseColorCache: {[string]: ?Color};\n\n constructor() {\n this.globals = (null: any);\n this.feature = null;\n this.featureState = null;\n this._parseColorCache = {};\n }\n\n id() {\n return this.feature && 'id' in this.feature ? this.feature.id : null;\n }\n\n geometryType() {\n return this.feature ? typeof this.feature.type === 'number' ? geometryTypes[this.feature.type] : this.feature.type : null;\n }\n\n properties() {\n return this.feature && this.feature.properties || {};\n }\n\n parseColor(input: string): ?Color {\n let cached = this._parseColorCache[input];\n if (!cached) {\n cached = this._parseColorCache[input] = Color.parse(input);\n }\n return cached;\n }\n}\n\nexport default EvaluationContext;\n","// @flow\n\nimport { toString } from './types';\n\nimport ParsingContext from './parsing_context';\nimport EvaluationContext from './evaluation_context';\nimport assert from 'assert';\n\nimport type { Expression, ExpressionRegistry } from './expression';\nimport type { Type } from './types';\nimport type { Value } from './values';\n\nexport type Varargs = {| type: Type |};\ntype Signature = Array<Type> | Varargs;\ntype Evaluate = (EvaluationContext, Array<Expression>) => Value;\ntype Definition = [Type, Signature, Evaluate] |\n {|type: Type, overloads: Array<[Signature, Evaluate]>|};\n\nclass CompoundExpression implements Expression {\n name: string;\n type: Type;\n _evaluate: Evaluate;\n args: Array<Expression>;\n\n static definitions: { [string]: Definition };\n\n constructor(name: string, type: Type, evaluate: Evaluate, args: Array<Expression>) {\n this.name = name;\n this.type = type;\n this._evaluate = evaluate;\n this.args = args;\n }\n\n evaluate(ctx: EvaluationContext) {\n return this._evaluate(ctx, this.args);\n }\n\n eachChild(fn: (Expression) => void) {\n this.args.forEach(fn);\n }\n\n possibleOutputs() {\n return [undefined];\n }\n\n serialize(): Array<mixed> {\n return [this.name].concat(this.args.map(arg => arg.serialize()));\n }\n\n static parse(args: Array<mixed>, context: ParsingContext): ?Expression {\n const op: string = (args[0]: any);\n const definition = CompoundExpression.definitions[op];\n if (!definition) {\n return context.error(`Unknown expression \"${op}\". If you wanted a literal array, use [\"literal\", [...]].`, 0);\n }\n\n // Now check argument types against each signature\n const type = Array.isArray(definition) ?\n definition[0] : definition.type;\n\n const availableOverloads = Array.isArray(definition) ?\n [[definition[1], definition[2]]] :\n definition.overloads;\n\n const overloads = availableOverloads.filter(([signature]) => (\n !Array.isArray(signature) || // varags\n signature.length === args.length - 1 // correct param count\n ));\n\n let signatureContext: ParsingContext = (null: any);\n\n for (const [params, evaluate] of overloads) {\n // Use a fresh context for each attempted signature so that, if\n // we eventually succeed, we haven't polluted `context.errors`.\n signatureContext = new ParsingContext(context.registry, context.path, null, context.scope);\n\n // First parse all the args, potentially coercing to the\n // types expected by this overload.\n const parsedArgs: Array<Expression> = [];\n let argParseFailed = false;\n for (let i = 1; i < args.length; i++) {\n const arg = args[i];\n const expectedType = Array.isArray(params) ?\n params[i - 1] :\n params.type;\n\n const parsed = signatureContext.parse(arg, 1 + parsedArgs.length, expectedType);\n if (!parsed) {\n argParseFailed = true;\n break;\n }\n parsedArgs.push(parsed);\n }\n if (argParseFailed) {\n // Couldn't coerce args of this overload to expected type, move\n // on to next one.\n continue;\n }\n\n if (Array.isArray(params)) {\n if (params.length !== parsedArgs.length) {\n signatureContext.error(`Expected ${params.length} arguments, but found ${parsedArgs.length} instead.`);\n continue;\n }\n }\n\n for (let i = 0; i < parsedArgs.length; i++) {\n const expected = Array.isArray(params) ? params[i] : params.type;\n const arg = parsedArgs[i];\n signatureContext.concat(i + 1).checkSubtype(expected, arg.type);\n }\n\n if (signatureContext.errors.length === 0) {\n return new CompoundExpression(op, type, evaluate, parsedArgs);\n }\n }\n\n assert(!signatureContext || signatureContext.errors.length > 0);\n\n if (overloads.length === 1) {\n context.errors.push(...signatureContext.errors);\n } else {\n const expected = overloads.length ? overloads : availableOverloads;\n const signatures = expected\n .map(([params]) => stringifySignature(params))\n .join(' | ');\n\n const actualTypes = [];\n // For error message, re-parse arguments without trying to\n // apply any coercions\n for (let i = 1; i < args.length; i++) {\n const parsed = context.parse(args[i], 1 + actualTypes.length);\n if (!parsed) return null;\n actualTypes.push(toString(parsed.type));\n }\n context.error(`Expected arguments of type ${signatures}, but found (${actualTypes.join(', ')}) instead.`);\n }\n\n return null;\n }\n\n static register(\n registry: ExpressionRegistry,\n definitions: { [string]: Definition }\n ) {\n assert(!CompoundExpression.definitions);\n CompoundExpression.definitions = definitions;\n for (const name in definitions) {\n registry[name] = CompoundExpression;\n }\n }\n}\n\nfunction stringifySignature(signature: Signature): string {\n if (Array.isArray(signature)) {\n return `(${signature.map(toString).join(', ')})`;\n } else {\n return `(${toString(signature.type)}...)`;\n }\n}\n\nexport default CompoundExpression;\n","// @flow\n\nimport { StringType, BooleanType, CollatorType } from '../types';\nimport Collator from '../types/collator';\n\nimport type { Expression } from '../expression';\nimport type EvaluationContext from '../evaluation_context';\nimport type ParsingContext from '../parsing_context';\nimport type { Type } from '../types';\n\nexport default class CollatorExpression implements Expression {\n type: Type;\n caseSensitive: Expression;\n diacriticSensitive: Expression;\n locale: Expression | null;\n\n constructor(caseSensitive: Expression, diacriticSensitive: Expression, locale: Expression | null) {\n this.type = CollatorType;\n this.locale = locale;\n this.caseSensitive = caseSensitive;\n this.diacriticSensitive = diacriticSensitive;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext): ?Expression {\n if (args.length !== 2)\n return context.error(`Expected one argument.`);\n\n const options = (args[1]: any);\n if (typeof options !== \"object\" || Array.isArray(options))\n return context.error(`Collator options argument must be an object.`);\n\n const caseSensitive = context.parse(\n options['case-sensitive'] === undefined ? false : options['case-sensitive'], 1, BooleanType);\n if (!caseSensitive) return null;\n\n const diacriticSensitive = context.parse(\n options['diacritic-sensitive'] === undefined ? false : options['diacritic-sensitive'], 1, BooleanType);\n if (!diacriticSensitive) return null;\n\n let locale = null;\n if (options['locale']) {\n locale = context.parse(options['locale'], 1, StringType);\n if (!locale) return null;\n }\n\n return new CollatorExpression(caseSensitive, diacriticSensitive, locale);\n }\n\n evaluate(ctx: EvaluationContext) {\n return new Collator(this.caseSensitive.evaluate(ctx), this.diacriticSensitive.evaluate(ctx), this.locale ? this.locale.evaluate(ctx) : null);\n }\n\n eachChild(fn: (Expression) => void) {\n fn(this.caseSensitive);\n fn(this.diacriticSensitive);\n if (this.locale) {\n fn(this.locale);\n }\n }\n\n possibleOutputs() {\n // Technically the set of possible outputs is the combinatoric set of Collators produced\n // by all possibleOutputs of locale/caseSensitive/diacriticSensitive\n // But for the primary use of Collators in comparison operators, we ignore the Collator's\n // possibleOutputs anyway, so we can get away with leaving this undefined for now.\n return [undefined];\n }\n\n serialize() {\n const options = {};\n options['case-sensitive'] = this.caseSensitive.serialize();\n options['diacritic-sensitive'] = this.diacriticSensitive.serialize();\n if (this.locale) {\n options['locale'] = this.locale.serialize();\n }\n return [\"collator\", options];\n }\n}\n","// @flow\n\nimport CompoundExpression from './compound_expression';\n\nimport type { Expression } from './expression.js';\n\nfunction isFeatureConstant(e: Expression) {\n if (e instanceof CompoundExpression) {\n if (e.name === 'get' && e.args.length === 1) {\n return false;\n } else if (e.name === 'feature-state') {\n return false;\n } else if (e.name === 'has' && e.args.length === 1) {\n return false;\n } else if (\n e.name === 'properties' ||\n e.name === 'geometry-type' ||\n e.name === 'id'\n ) {\n return false;\n } else if (/^filter-/.test(e.name)) {\n return false;\n }\n }\n\n let result = true;\n e.eachChild(arg => {\n if (result && !isFeatureConstant(arg)) { result = false; }\n });\n return result;\n}\n\nfunction isStateConstant(e: Expression) {\n if (e instanceof CompoundExpression) {\n if (e.name === 'feature-state') {\n return false;\n }\n }\n let result = true;\n e.eachChild(arg => {\n if (result && !isStateConstant(arg)) { result = false; }\n });\n return result;\n}\n\nfunction isGlobalPropertyConstant(e: Expression, properties: Array<string>) {\n if (e instanceof CompoundExpression && properties.indexOf(e.name) >= 0) { return false; }\n let result = true;\n e.eachChild((arg) => {\n if (result && !isGlobalPropertyConstant(arg, properties)) { result = false; }\n });\n return result;\n}\n\nexport { isFeatureConstant, isGlobalPropertyConstant, isStateConstant };\n","// @flow\n\nimport type { Type } from '../types';\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\n\nclass Var implements Expression {\n type: Type;\n name: string;\n boundExpression: Expression;\n\n constructor(name: string, boundExpression: Expression) {\n this.type = boundExpression.type;\n this.name = name;\n this.boundExpression = boundExpression;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n if (args.length !== 2 || typeof args[1] !== 'string')\n return context.error(`'var' expression requires exactly one string literal argument.`);\n\n const name = args[1];\n if (!context.scope.has(name)) {\n return context.error(`Unknown variable \"${name}\". Make sure \"${name}\" has been bound in an enclosing \"let\" expression before using it.`, 1);\n }\n\n return new Var(name, context.scope.get(name));\n }\n\n evaluate(ctx: EvaluationContext) {\n return this.boundExpression.evaluate(ctx);\n }\n\n eachChild() {}\n\n possibleOutputs() {\n return [undefined];\n }\n\n serialize() {\n return [\"var\", this.name];\n }\n}\n\nexport default Var;\n","// @flow\n\nimport Scope from './scope';\nimport { checkSubtype } from './types';\nimport ParsingError from './parsing_error';\nimport Literal from './definitions/literal';\nimport Assertion from './definitions/assertion';\nimport Coercion from './definitions/coercion';\nimport EvaluationContext from './evaluation_context';\nimport CompoundExpression from './compound_expression';\nimport CollatorExpression from './definitions/collator';\nimport {isGlobalPropertyConstant, isFeatureConstant} from './is_constant';\nimport Var from './definitions/var';\n\n\nimport type {Expression, ExpressionRegistry} from './expression';\nimport type {Type} from './types';\n\n/**\n * State associated parsing at a given point in an expression tree.\n * @private\n */\nclass ParsingContext {\n registry: ExpressionRegistry;\n path: Array<number>;\n key: string;\n scope: Scope;\n errors: Array<ParsingError>;\n\n // The expected type of this expression. Provided only to allow Expression\n // implementations to infer argument types: Expression#parse() need not\n // check that the output type of the parsed expression matches\n // `expectedType`.\n expectedType: ?Type;\n\n constructor(\n registry: ExpressionRegistry,\n path: Array<number> = [],\n expectedType: ?Type,\n scope: Scope = new Scope(),\n errors: Array<ParsingError> = []\n ) {\n this.registry = registry;\n this.path = path;\n this.key = path.map(part => `[${part}]`).join('');\n this.scope = scope;\n this.errors = errors;\n this.expectedType = expectedType;\n }\n\n /**\n * @param expr the JSON expression to parse\n * @param index the optional argument index if this expression is an argument of a parent expression that's being parsed\n * @param options\n * @param options.omitTypeAnnotations set true to omit inferred type annotations. Caller beware: with this option set, the parsed expression's type will NOT satisfy `expectedType` if it would normally be wrapped in an inferred annotation.\n * @private\n */\n parse(\n expr: mixed,\n index?: number,\n expectedType?: ?Type,\n bindings?: Array<[string, Expression]>,\n options: {typeAnnotation?: 'assert' | 'coerce' | 'omit'} = {}\n ): ?Expression {\n if (index) {\n return this.concat(index, expectedType, bindings)._parse(expr, options);\n }\n return this._parse(expr, options);\n }\n\n _parse(expr: mixed, options: {typeAnnotation?: 'assert' | 'coerce' | 'omit'}): ?Expression {\n if (expr === null || typeof expr === 'string' || typeof expr === 'boolean' || typeof expr === 'number') {\n expr = ['literal', expr];\n }\n\n function annotate(parsed, type, typeAnnotation: 'assert' | 'coerce' | 'omit') {\n if (typeAnnotation === 'assert') {\n return new Assertion(type, [parsed]);\n } else if (typeAnnotation === 'coerce') {\n return new Coercion(type, [parsed]);\n } else {\n return parsed;\n }\n }\n\n if (Array.isArray(expr)) {\n if (expr.length === 0) {\n return this.error(`Expected an array with at least one element. If you wanted a literal array, use [\"literal\", []].`);\n }\n\n const op = expr[0];\n if (typeof op !== 'string') {\n this.error(`Expression name must be a string, but found ${typeof op} instead. If you wanted a literal array, use [\"literal\", [...]].`, 0);\n return null;\n }\n\n const Expr = this.registry[op];\n if (Expr) {\n let parsed = Expr.parse(expr, this);\n if (!parsed) return null;\n\n if (this.expectedType) {\n const expected = this.expectedType;\n const actual = parsed.type;\n\n // When we expect a number, string, boolean, or array but have a value, wrap it in an assertion.\n // When we expect a color or formatted string, but have a string or value, wrap it in a coercion.\n // Otherwise, we do static type-checking.\n //\n // These behaviors are overridable for:\n // * The \"coalesce\" operator, which needs to omit type annotations.\n // * String-valued properties (e.g. `text-field`), where coercion is more convenient than assertion.\n //\n if ((expected.kind === 'string' || expected.kind === 'number' || expected.kind === 'boolean' || expected.kind === 'object' || expected.kind === 'array') && actual.kind === 'value') {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'assert');\n } else if ((expected.kind === 'color' || expected.kind === 'formatted') && (actual.kind === 'value' || actual.kind === 'string')) {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'coerce');\n } else if (this.checkSubtype(expected, actual)) {\n return null;\n }\n }\n\n // If an expression's arguments are all literals, we can evaluate\n // it immediately and replace it with a literal value in the\n // parsed/compiled result.\n if (!(parsed instanceof Literal) && isConstant(parsed)) {\n const ec = new EvaluationContext();\n try {\n parsed = new Literal(parsed.type, parsed.evaluate(ec));\n } catch (e) {\n this.error(e.message);\n return null;\n }\n }\n\n return parsed;\n }\n\n return this.error(`Unknown expression \"${op}\". If you wanted a literal array, use [\"literal\", [...]].`, 0);\n } else if (typeof expr === 'undefined') {\n return this.error(`'undefined' value invalid. Use null instead.`);\n } else if (typeof expr === 'object') {\n return this.error(`Bare objects invalid. Use [\"literal\", {...}] instead.`);\n } else {\n return this.error(`Expected an array, but found ${typeof expr} instead.`);\n }\n }\n\n /**\n * Returns a copy of this context suitable for parsing the subexpression at\n * index `index`, optionally appending to 'let' binding map.\n *\n * Note that `errors` property, intended for collecting errors while\n * parsing, is copied by reference rather than cloned.\n * @private\n */\n concat(index: number, expectedType?: ?Type, bindings?: Array<[string, Expression]>) {\n const path = typeof index === 'number' ? this.path.concat(index) : this.path;\n const scope = bindings ? this.scope.concat(bindings) : this.scope;\n return new ParsingContext(\n this.registry,\n path,\n expectedType || null,\n scope,\n this.errors\n );\n }\n\n /**\n * Push a parsing (or type checking) error into the `this.errors`\n * @param error The message\n * @param keys Optionally specify the source of the error at a child\n * of the current expression at `this.key`.\n * @private\n */\n error(error: string, ...keys: Array<number>) {\n const key = `${this.key}${keys.map(k => `[${k}]`).join('')}`;\n this.errors.push(new ParsingError(key, error));\n }\n\n /**\n * Returns null if `t` is a subtype of `expected`; otherwise returns an\n * error message and also pushes it to `this.errors`.\n */\n checkSubtype(expected: Type, t: Type): ?string {\n const error = checkSubtype(expected, t);\n if (error) this.error(error);\n return error;\n }\n}\n\nexport default ParsingContext;\n\nfunction isConstant(expression: Expression) {\n if (expression instanceof Var) {\n return isConstant(expression.boundExpression);\n } else if (expression instanceof CompoundExpression && expression.name === 'error') {\n return false;\n } else if (expression instanceof CollatorExpression) {\n // Although the results of a Collator expression with fixed arguments\n // generally shouldn't change between executions, we can't serialize them\n // as constant expressions because results change based on environment.\n return false;\n }\n\n const isTypeAnnotation = expression instanceof Coercion ||\n expression instanceof Assertion;\n\n let childrenConstant = true;\n expression.eachChild(child => {\n // We can _almost_ assume that if `expressions` children are constant,\n // they would already have been evaluated to Literal values when they\n // were parsed. Type annotations are the exception, because they might\n // have been inferred and added after a child was parsed.\n\n // So we recurse into isConstant() for the children of type annotations,\n // but otherwise simply check whether they are Literals.\n if (isTypeAnnotation) {\n childrenConstant = childrenConstant && isConstant(child);\n } else {\n childrenConstant = childrenConstant && child instanceof Literal;\n }\n });\n if (!childrenConstant) {\n return false;\n }\n\n return isFeatureConstant(expression) &&\n isGlobalPropertyConstant(expression, ['zoom', 'heatmap-density', 'line-progress', 'is-supported-script']);\n}\n","// @flow\n\nimport RuntimeError from './runtime_error';\n\nimport type { Expression } from './expression';\n\nexport type Stops = Array<[number, Expression]>;\n\n/**\n * Returns the index of the last stop <= input, or 0 if it doesn't exist.\n * @private\n */\nexport function findStopLessThanOrEqualTo(stops: Array<number>, input: number) {\n const n = stops.length;\n let lowerIndex = 0;\n let upperIndex = n - 1;\n let currentIndex = 0;\n let currentValue, upperValue;\n\n while (lowerIndex <= upperIndex) {\n currentIndex = Math.floor((lowerIndex + upperIndex) / 2);\n currentValue = stops[currentIndex];\n upperValue = stops[currentIndex + 1];\n if (input === currentValue || input > currentValue && input < upperValue) { // Search complete\n return currentIndex;\n } else if (currentValue < input) {\n lowerIndex = currentIndex + 1;\n } else if (currentValue > input) {\n upperIndex = currentIndex - 1;\n } else {\n throw new RuntimeError('Input is not a number.');\n }\n }\n\n return Math.max(currentIndex - 1, 0);\n}\n","// @flow\n\nimport { NumberType } from '../types';\n\nimport { findStopLessThanOrEqualTo } from '../stops';\n\nimport type { Stops } from '../stops';\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\nimport type { Value } from '../values';\nimport type { Type } from '../types';\n\nclass Step implements Expression {\n type: Type;\n\n input: Expression;\n labels: Array<number>;\n outputs: Array<Expression>;\n\n constructor(type: Type, input: Expression, stops: Stops) {\n this.type = type;\n this.input = input;\n\n this.labels = [];\n this.outputs = [];\n for (const [label, expression] of stops) {\n this.labels.push(label);\n this.outputs.push(expression);\n }\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n let [ , input, ...rest] = args;\n\n if (args.length - 1 < 4) {\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n }\n\n if ((args.length - 1) % 2 !== 0) {\n return context.error(`Expected an even number of arguments.`);\n }\n\n input = context.parse(input, 1, NumberType);\n if (!input) return null;\n\n const stops: Stops = [];\n\n let outputType: Type = (null: any);\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n\n rest.unshift(-Infinity);\n\n for (let i = 0; i < rest.length; i += 2) {\n const label = rest[i];\n const value = rest[i + 1];\n\n const labelKey = i + 1;\n const valueKey = i + 2;\n\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"step\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"step\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n\n const parsed = context.parse(value, valueKey, outputType);\n if (!parsed) return null;\n outputType = outputType || parsed.type;\n stops.push([label, parsed]);\n }\n\n return new Step(outputType, input, stops);\n }\n\n evaluate(ctx: EvaluationContext) {\n const labels = this.labels;\n const outputs = this.outputs;\n\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n\n const value = ((this.input.evaluate(ctx): any): number);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n\n const stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n\n const index = findStopLessThanOrEqualTo(labels, value);\n return outputs[index].evaluate(ctx);\n }\n\n eachChild(fn: (Expression) => void) {\n fn(this.input);\n for (const expression of this.outputs) {\n fn(expression);\n }\n }\n\n possibleOutputs(): Array<Value | void> {\n return [].concat(...this.outputs.map((output) => output.possibleOutputs()));\n }\n\n serialize() {\n const serialized = [\"step\", this.input.serialize()];\n for (let i = 0; i < this.labels.length; i++) {\n if (i > 0) {\n serialized.push(this.labels[i]);\n }\n serialized.push(this.outputs[i].serialize());\n }\n return serialized;\n }\n}\n\nexport default Step;\n","/*\n * Copyright (C) 2008 Apple Inc. All Rights Reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions\n * are met:\n * 1. Redistributions of source code must retain the above copyright\n * notice, this list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright\n * notice, this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n *\n * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY\n * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\n * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR\n * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,\n * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,\n * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY\n * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * Ported from Webkit\n * http://svn.webkit.org/repository/webkit/trunk/Source/WebCore/platform/graphics/UnitBezier.h\n */\n\nmodule.exports = UnitBezier;\n\nfunction UnitBezier(p1x, p1y, p2x, p2y) {\n // Calculate the polynomial coefficients, implicit first and last control points are (0,0) and (1,1).\n this.cx = 3.0 * p1x;\n this.bx = 3.0 * (p2x - p1x) - this.cx;\n this.ax = 1.0 - this.cx - this.bx;\n\n this.cy = 3.0 * p1y;\n this.by = 3.0 * (p2y - p1y) - this.cy;\n this.ay = 1.0 - this.cy - this.by;\n\n this.p1x = p1x;\n this.p1y = p2y;\n this.p2x = p2x;\n this.p2y = p2y;\n}\n\nUnitBezier.prototype.sampleCurveX = function(t) {\n // `ax t^3 + bx t^2 + cx t' expanded using Horner's rule.\n return ((this.ax * t + this.bx) * t + this.cx) * t;\n};\n\nUnitBezier.prototype.sampleCurveY = function(t) {\n return ((this.ay * t + this.by) * t + this.cy) * t;\n};\n\nUnitBezier.prototype.sampleCurveDerivativeX = function(t) {\n return (3.0 * this.ax * t + 2.0 * this.bx) * t + this.cx;\n};\n\nUnitBezier.prototype.solveCurveX = function(x, epsilon) {\n if (typeof epsilon === 'undefined') epsilon = 1e-6;\n\n var t0, t1, t2, x2, i;\n\n // First try a few iterations of Newton's method -- normally very fast.\n for (t2 = x, i = 0; i < 8; i++) {\n\n x2 = this.sampleCurveX(t2) - x;\n if (Math.abs(x2) < epsilon) return t2;\n\n var d2 = this.sampleCurveDerivativeX(t2);\n if (Math.abs(d2) < 1e-6) break;\n\n t2 = t2 - x2 / d2;\n }\n\n // Fall back to the bisection method for reliability.\n t0 = 0.0;\n t1 = 1.0;\n t2 = x;\n\n if (t2 < t0) return t0;\n if (t2 > t1) return t1;\n\n while (t0 < t1) {\n\n x2 = this.sampleCurveX(t2);\n if (Math.abs(x2 - x) < epsilon) return t2;\n\n if (x > x2) {\n t0 = t2;\n } else {\n t1 = t2;\n }\n\n t2 = (t1 - t0) * 0.5 + t0;\n }\n\n // Failure.\n return t2;\n};\n\nUnitBezier.prototype.solve = function(x, epsilon) {\n return this.sampleCurveY(this.solveCurveX(x, epsilon));\n};\n","// @flow\n\nimport Color from './color';\n\nexport function number(a: number, b: number, t: number) {\n return (a * (1 - t)) + (b * t);\n}\n\nexport function color(from: Color, to: Color, t: number) {\n return new Color(\n number(from.r, to.r, t),\n number(from.g, to.g, t),\n number(from.b, to.b, t),\n number(from.a, to.a, t)\n );\n}\n\nexport function array(from: Array<number>, to: Array<number>, t: number): Array<number> {\n return from.map((d, i) => {\n return number(d, to[i], t);\n });\n}\n","// @flow\n\nimport Color from './color';\n\nimport {number as interpolateNumber} from './interpolate';\n\ntype LABColor = {\n l: number,\n a: number,\n b: number,\n alpha: number\n};\n\ntype HCLColor = {\n h: number,\n c: number,\n l: number,\n alpha: number\n};\n\n// Constants\nconst Xn = 0.950470, // D65 standard referent\n Yn = 1,\n Zn = 1.088830,\n t0 = 4 / 29,\n t1 = 6 / 29,\n t2 = 3 * t1 * t1,\n t3 = t1 * t1 * t1,\n deg2rad = Math.PI / 180,\n rad2deg = 180 / Math.PI;\n\n// Utilities\nfunction xyz2lab(t) {\n return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;\n}\n\nfunction lab2xyz(t) {\n return t > t1 ? t * t * t : t2 * (t - t0);\n}\n\nfunction xyz2rgb(x) {\n return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);\n}\n\nfunction rgb2xyz(x) {\n x /= 255;\n return x <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);\n}\n\n// LAB\nfunction rgbToLab(rgbColor: Color): LABColor {\n const b = rgb2xyz(rgbColor.r),\n a = rgb2xyz(rgbColor.g),\n l = rgb2xyz(rgbColor.b),\n x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn),\n y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.0721750 * l) / Yn),\n z = xyz2lab((0.0193339 * b + 0.1191920 * a + 0.9503041 * l) / Zn);\n\n return {\n l: 116 * y - 16,\n a: 500 * (x - y),\n b: 200 * (y - z),\n alpha: rgbColor.a\n };\n}\n\nfunction labToRgb(labColor: LABColor): Color {\n let y = (labColor.l + 16) / 116,\n x = isNaN(labColor.a) ? y : y + labColor.a / 500,\n z = isNaN(labColor.b) ? y : y - labColor.b / 200;\n y = Yn * lab2xyz(y);\n x = Xn * lab2xyz(x);\n z = Zn * lab2xyz(z);\n return new Color(\n xyz2rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z), // D65 -> sRGB\n xyz2rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z),\n xyz2rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z),\n labColor.alpha\n );\n}\n\nfunction interpolateLab(from: LABColor, to: LABColor, t: number) {\n return {\n l: interpolateNumber(from.l, to.l, t),\n a: interpolateNumber(from.a, to.a, t),\n b: interpolateNumber(from.b, to.b, t),\n alpha: interpolateNumber(from.alpha, to.alpha, t)\n };\n}\n\n// HCL\nfunction rgbToHcl(rgbColor: Color): HCLColor {\n const {l, a, b} = rgbToLab(rgbColor);\n const h = Math.atan2(b, a) * rad2deg;\n return {\n h: h < 0 ? h + 360 : h,\n c: Math.sqrt(a * a + b * b),\n l,\n alpha: rgbColor.a\n };\n}\n\nfunction hclToRgb(hclColor: HCLColor): Color {\n const h = hclColor.h * deg2rad,\n c = hclColor.c,\n l = hclColor.l;\n return labToRgb({\n l,\n a: Math.cos(h) * c,\n b: Math.sin(h) * c,\n alpha: hclColor.alpha\n });\n}\n\nfunction interpolateHue(a: number, b: number, t: number) {\n const d = b - a;\n return a + t * (d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d);\n}\n\nfunction interpolateHcl(from: HCLColor, to: HCLColor, t: number) {\n return {\n h: interpolateHue(from.h, to.h, t),\n c: interpolateNumber(from.c, to.c, t),\n l: interpolateNumber(from.l, to.l, t),\n alpha: interpolateNumber(from.alpha, to.alpha, t)\n };\n}\n\nexport const lab = {\n forward: rgbToLab,\n reverse: labToRgb,\n interpolate: interpolateLab\n};\n\nexport const hcl = {\n forward: rgbToHcl,\n reverse: hclToRgb,\n interpolate: interpolateHcl\n};\n","// @flow\n\nimport UnitBezier from '@mapbox/unitbezier';\n\nimport * as interpolate from '../../util/interpolate';\nimport { toString, NumberType, ColorType } from '../types';\nimport { findStopLessThanOrEqualTo } from '../stops';\nimport { hcl, lab } from '../../util/color_spaces';\n\nimport type { Stops } from '../stops';\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\nimport type { Value } from '../values';\nimport type { Type } from '../types';\n\nexport type InterpolationType =\n { name: 'linear' } |\n { name: 'exponential', base: number } |\n { name: 'cubic-bezier', controlPoints: [number, number, number, number] };\n\nclass Interpolate implements Expression {\n type: Type;\n\n operator: 'interpolate' | 'interpolate-hcl' | 'interpolate-lab';\n interpolation: InterpolationType;\n input: Expression;\n labels: Array<number>;\n outputs: Array<Expression>;\n\n constructor(type: Type, operator: 'interpolate' | 'interpolate-hcl' | 'interpolate-lab', interpolation: InterpolationType, input: Expression, stops: Stops) {\n this.type = type;\n this.operator = operator;\n this.interpolation = interpolation;\n this.input = input;\n\n this.labels = [];\n this.outputs = [];\n for (const [label, expression] of stops) {\n this.labels.push(label);\n this.outputs.push(expression);\n }\n }\n\n static interpolationFactor(interpolation: InterpolationType, input: number, lower: number, upper: number) {\n let t = 0;\n if (interpolation.name === 'exponential') {\n t = exponentialInterpolation(input, interpolation.base, lower, upper);\n } else if (interpolation.name === 'linear') {\n t = exponentialInterpolation(input, 1, lower, upper);\n } else if (interpolation.name === 'cubic-bezier') {\n const c = interpolation.controlPoints;\n const ub = new UnitBezier(c[0], c[1], c[2], c[3]);\n t = ub.solve(exponentialInterpolation(input, 1, lower, upper));\n }\n return t;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n let [operator, interpolation, input, ...rest] = args;\n\n if (!Array.isArray(interpolation) || interpolation.length === 0) {\n return context.error(`Expected an interpolation type expression.`, 1);\n }\n\n if (interpolation[0] === 'linear') {\n interpolation = { name: 'linear' };\n } else if (interpolation[0] === 'exponential') {\n const base = interpolation[1];\n if (typeof base !== 'number')\n return context.error(`Exponential interpolation requires a numeric base.`, 1, 1);\n interpolation = {\n name: 'exponential',\n base\n };\n } else if (interpolation[0] === 'cubic-bezier') {\n const controlPoints = interpolation.slice(1);\n if (\n controlPoints.length !== 4 ||\n controlPoints.some(t => typeof t !== 'number' || t < 0 || t > 1)\n ) {\n return context.error('Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.', 1);\n }\n\n interpolation = {\n name: 'cubic-bezier',\n controlPoints: (controlPoints: any)\n };\n } else {\n return context.error(`Unknown interpolation type ${String(interpolation[0])}`, 1, 0);\n }\n\n if (args.length - 1 < 4) {\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n }\n\n if ((args.length - 1) % 2 !== 0) {\n return context.error(`Expected an even number of arguments.`);\n }\n\n input = context.parse(input, 2, NumberType);\n if (!input) return null;\n\n const stops: Stops = [];\n\n let outputType: Type = (null: any);\n if (operator === 'interpolate-hcl' || operator === 'interpolate-lab') {\n outputType = ColorType;\n } else if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n\n for (let i = 0; i < rest.length; i += 2) {\n const label = rest[i];\n const value = rest[i + 1];\n\n const labelKey = i + 3;\n const valueKey = i + 4;\n\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"interpolate\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"interpolate\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n\n const parsed = context.parse(value, valueKey, outputType);\n if (!parsed) return null;\n outputType = outputType || parsed.type;\n stops.push([label, parsed]);\n }\n\n if (outputType.kind !== 'number' &&\n outputType.kind !== 'color' &&\n !(\n outputType.kind === 'array' &&\n outputType.itemType.kind === 'number' &&\n typeof outputType.N === 'number'\n )\n ) {\n return context.error(`Type ${toString(outputType)} is not interpolatable.`);\n }\n\n return new Interpolate(outputType, (operator: any), interpolation, input, stops);\n }\n\n evaluate(ctx: EvaluationContext) {\n const labels = this.labels;\n const outputs = this.outputs;\n\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n\n const value = ((this.input.evaluate(ctx): any): number);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n\n const stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n\n const index = findStopLessThanOrEqualTo(labels, value);\n const lower = labels[index];\n const upper = labels[index + 1];\n const t = Interpolate.interpolationFactor(this.interpolation, value, lower, upper);\n\n const outputLower = outputs[index].evaluate(ctx);\n const outputUpper = outputs[index + 1].evaluate(ctx);\n\n if (this.operator === 'interpolate') {\n return (interpolate[this.type.kind.toLowerCase()]: any)(outputLower, outputUpper, t); // eslint-disable-line import/namespace\n } else if (this.operator === 'interpolate-hcl') {\n return hcl.reverse(hcl.interpolate(hcl.forward(outputLower), hcl.forward(outputUpper), t));\n } else {\n return lab.reverse(lab.interpolate(lab.forward(outputLower), lab.forward(outputUpper), t));\n }\n }\n\n eachChild(fn: (Expression) => void) {\n fn(this.input);\n for (const expression of this.outputs) {\n fn(expression);\n }\n }\n\n possibleOutputs(): Array<Value | void> {\n return [].concat(...this.outputs.map((output) => output.possibleOutputs()));\n }\n\n serialize(): Array<mixed> {\n let interpolation;\n if (this.interpolation.name === 'linear') {\n interpolation = [\"linear\"];\n } else if (this.interpolation.name === 'exponential') {\n if (this.interpolation.base === 1) {\n interpolation = [\"linear\"];\n } else {\n interpolation = [\"exponential\", this.interpolation.base];\n }\n } else {\n interpolation = [\"cubic-bezier\" ].concat(this.interpolation.controlPoints);\n }\n\n const serialized = [this.operator, interpolation, this.input.serialize()];\n\n for (let i = 0; i < this.labels.length; i++) {\n serialized.push(\n this.labels[i],\n this.outputs[i].serialize()\n );\n }\n return serialized;\n }\n}\n\n/**\n * Returns a ratio that can be used to interpolate between exponential function\n * stops.\n * How it works: Two consecutive stop values define a (scaled and shifted) exponential function `f(x) = a * base^x + b`, where `base` is the user-specified base,\n * and `a` and `b` are constants affording sufficient degrees of freedom to fit\n * the function to the given stops.\n *\n * Here's a bit of algebra that lets us compute `f(x)` directly from the stop\n * values without explicitly solving for `a` and `b`:\n *\n * First stop value: `f(x0) = y0 = a * base^x0 + b`\n * Second stop value: `f(x1) = y1 = a * base^x1 + b`\n * => `y1 - y0 = a(base^x1 - base^x0)`\n * => `a = (y1 - y0)/(base^x1 - base^x0)`\n *\n * Desired value: `f(x) = y = a * base^x + b`\n * => `f(x) = y0 + a * (base^x - base^x0)`\n *\n * From the above, we can replace the `a` in `a * (base^x - base^x0)` and do a\n * little algebra:\n * ```\n * a * (base^x - base^x0) = (y1 - y0)/(base^x1 - base^x0) * (base^x - base^x0)\n * = (y1 - y0) * (base^x - base^x0) / (base^x1 - base^x0)\n * ```\n *\n * If we let `(base^x - base^x0) / (base^x1 base^x0)`, then we have\n * `f(x) = y0 + (y1 - y0) * ratio`. In other words, `ratio` may be treated as\n * an interpolation factor between the two stops' output values.\n *\n * (Note: a slightly different form for `ratio`,\n * `(base^(x-x0) - 1) / (base^(x1-x0) - 1) `, is equivalent, but requires fewer\n * expensive `Math.pow()` operations.)\n *\n * @private\n*/\nfunction exponentialInterpolation(input, base, lowerValue, upperValue) {\n const difference = upperValue - lowerValue;\n const progress = input - lowerValue;\n\n if (difference === 0) {\n return 0;\n } else if (base === 1) {\n return progress / difference;\n } else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n\nexport default Interpolate;\n","// @flow\n\nimport assert from 'assert';\n\nimport { checkSubtype, ValueType } from '../types';\n\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\nimport type { Value } from '../values';\nimport type { Type } from '../types';\n\nclass Coalesce implements Expression {\n type: Type;\n args: Array<Expression>;\n\n constructor(type: Type, args: Array<Expression>) {\n this.type = type;\n this.args = args;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n if (args.length < 2) {\n return context.error(\"Expectected at least one argument.\");\n }\n let outputType: Type = (null: any);\n const expectedType = context.expectedType;\n if (expectedType && expectedType.kind !== 'value') {\n outputType = expectedType;\n }\n const parsedArgs = [];\n\n for (const arg of args.slice(1)) {\n const parsed = context.parse(arg, 1 + parsedArgs.length, outputType, undefined, {typeAnnotation: 'omit'});\n if (!parsed) return null;\n outputType = outputType || parsed.type;\n parsedArgs.push(parsed);\n }\n assert(outputType);\n\n // Above, we parse arguments without inferred type annotation so that\n // they don't produce a runtime error for `null` input, which would\n // preempt the desired null-coalescing behavior.\n // Thus, if any of our arguments would have needed an annotation, we\n // need to wrap the enclosing coalesce expression with it instead.\n const needsAnnotation = expectedType &&\n parsedArgs.some(arg => checkSubtype(expectedType, arg.type));\n\n return needsAnnotation ?\n new Coalesce(ValueType, parsedArgs) :\n new Coalesce((outputType: any), parsedArgs);\n }\n\n evaluate(ctx: EvaluationContext) {\n let result = null;\n for (const arg of this.args) {\n result = arg.evaluate(ctx);\n if (result !== null) break;\n }\n return result;\n }\n\n eachChild(fn: (Expression) => void) {\n this.args.forEach(fn);\n }\n\n possibleOutputs(): Array<Value | void> {\n return [].concat(...this.args.map((arg) => arg.possibleOutputs()));\n }\n\n serialize() {\n const serialized = [\"coalesce\"];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Coalesce;\n","// @flow\n\nimport type { Type } from '../types';\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\n\nclass Let implements Expression {\n type: Type;\n bindings: Array<[string, Expression]>;\n result: Expression;\n\n constructor(bindings: Array<[string, Expression]>, result: Expression) {\n this.type = result.type;\n this.bindings = [].concat(bindings);\n this.result = result;\n }\n\n evaluate(ctx: EvaluationContext) {\n return this.result.evaluate(ctx);\n }\n\n eachChild(fn: (Expression) => void) {\n for (const binding of this.bindings) {\n fn(binding[1]);\n }\n fn(this.result);\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n if (args.length < 4)\n return context.error(`Expected at least 3 arguments, but found ${args.length - 1} instead.`);\n\n const bindings: Array<[string, Expression]> = [];\n for (let i = 1; i < args.length - 1; i += 2) {\n const name = args[i];\n\n if (typeof name !== 'string') {\n return context.error(`Expected string, but found ${typeof name} instead.`, i);\n }\n\n if (/[^a-zA-Z0-9_]/.test(name)) {\n return context.error(`Variable names must contain only alphanumeric characters or '_'.`, i);\n }\n\n const value = context.parse(args[i + 1], i + 1);\n if (!value) return null;\n\n bindings.push([name, value]);\n }\n\n const result = context.parse(args[args.length - 1], args.length - 1, context.expectedType, bindings);\n if (!result) return null;\n\n return new Let(bindings, result);\n }\n\n possibleOutputs() {\n return this.result.possibleOutputs();\n }\n\n serialize() {\n const serialized = [\"let\"];\n for (const [name, expr] of this.bindings) {\n serialized.push(name, expr.serialize());\n }\n serialized.push(this.result.serialize());\n return serialized;\n }\n}\n\nexport default Let;\n","// @flow\n\nimport { array, ValueType, NumberType } from '../types';\n\nimport RuntimeError from '../runtime_error';\n\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\nimport type { Type, ArrayType } from '../types';\nimport type { Value } from '../values';\n\nclass At implements Expression {\n type: Type;\n index: Expression;\n input: Expression;\n\n constructor(type: Type, index: Expression, input: Expression) {\n this.type = type;\n this.index = index;\n this.input = input;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n if (args.length !== 3)\n return context.error(`Expected 2 arguments, but found ${args.length - 1} instead.`);\n\n const index = context.parse(args[1], 1, NumberType);\n const input = context.parse(args[2], 2, array(context.expectedType || ValueType));\n\n if (!index || !input) return null;\n\n const t: ArrayType = (input.type: any);\n return new At(t.itemType, index, input);\n }\n\n evaluate(ctx: EvaluationContext) {\n const index = ((this.index.evaluate(ctx): any): number);\n const array = ((this.input.evaluate(ctx): any): Array<Value>);\n\n if (index < 0) {\n throw new RuntimeError(`Array index out of bounds: ${index} < 0.`);\n }\n\n if (index >= array.length) {\n throw new RuntimeError(`Array index out of bounds: ${index} > ${array.length - 1}.`);\n }\n\n if (index !== Math.floor(index)) {\n throw new RuntimeError(`Array index must be an integer, but found ${index} instead.`);\n }\n\n return array[index];\n }\n\n eachChild(fn: (Expression) => void) {\n fn(this.index);\n fn(this.input);\n }\n\n possibleOutputs() {\n return [undefined];\n }\n\n serialize() {\n return [\"at\", this.index.serialize(), this.input.serialize()];\n }\n}\n\nexport default At;\n","// @flow\n\nimport assert from 'assert';\n\nimport { typeOf } from '../values';\nimport { ValueType, type Type } from '../types';\n\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\nimport type { Value } from '../values';\n\n// Map input label values to output expression index\ntype Cases = {[number | string]: number};\n\nclass Match implements Expression {\n type: Type;\n inputType: Type;\n\n input: Expression;\n cases: Cases;\n outputs: Array<Expression>;\n otherwise: Expression;\n\n constructor(inputType: Type, outputType: Type, input: Expression, cases: Cases, outputs: Array<Expression>, otherwise: Expression) {\n this.inputType = inputType;\n this.type = outputType;\n this.input = input;\n this.cases = cases;\n this.outputs = outputs;\n this.otherwise = otherwise;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n if (args.length < 5)\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n if (args.length % 2 !== 1)\n return context.error(`Expected an even number of arguments.`);\n\n let inputType;\n let outputType;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n const cases = {};\n const outputs = [];\n for (let i = 2; i < args.length - 1; i += 2) {\n let labels = args[i];\n const value = args[i + 1];\n\n if (!Array.isArray(labels)) {\n labels = [labels];\n }\n\n const labelContext = context.concat(i);\n if (labels.length === 0) {\n return labelContext.error('Expected at least one branch label.');\n }\n\n for (const label of labels) {\n if (typeof label !== 'number' && typeof label !== 'string') {\n return labelContext.error(`Branch labels must be numbers or strings.`);\n } else if (typeof label === 'number' && Math.abs(label) > Number.MAX_SAFE_INTEGER) {\n return labelContext.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);\n\n } else if (typeof label === 'number' && Math.floor(label) !== label) {\n return labelContext.error(`Numeric branch labels must be integer values.`);\n\n } else if (!inputType) {\n inputType = typeOf(label);\n } else if (labelContext.checkSubtype(inputType, typeOf(label))) {\n return null;\n }\n\n if (typeof cases[String(label)] !== 'undefined') {\n return labelContext.error('Branch labels must be unique.');\n }\n\n cases[String(label)] = outputs.length;\n }\n\n const result = context.parse(value, i, outputType);\n if (!result) return null;\n outputType = outputType || result.type;\n outputs.push(result);\n }\n\n const input = context.parse(args[1], 1, ValueType);\n if (!input) return null;\n\n const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise) return null;\n\n assert(inputType && outputType);\n\n if (input.type.kind !== 'value' && context.concat(1).checkSubtype((inputType: any), input.type)) {\n return null;\n }\n\n return new Match((inputType: any), (outputType: any), input, cases, outputs, otherwise);\n }\n\n evaluate(ctx: EvaluationContext) {\n const input = (this.input.evaluate(ctx): any);\n const output = (typeOf(input) === this.inputType && this.outputs[this.cases[input]]) || this.otherwise;\n return output.evaluate(ctx);\n }\n\n eachChild(fn: (Expression) => void) {\n fn(this.input);\n this.outputs.forEach(fn);\n fn(this.otherwise);\n }\n\n possibleOutputs(): Array<Value | void> {\n return []\n .concat(...this.outputs.map((out) => out.possibleOutputs()))\n .concat(this.otherwise.possibleOutputs());\n }\n\n serialize(): Array<mixed> {\n const serialized = [\"match\", this.input.serialize()];\n\n // Sort so serialization has an arbitrary defined order, even though\n // branch order doesn't affect evaluation\n const sortedLabels = Object.keys(this.cases).sort();\n\n // Group branches by unique match expression to support condensed\n // serializations of the form [case1, case2, ...] -> matchExpression\n const groupedByOutput: Array<[number, Array<number | string>]> = [];\n const outputLookup: {[index: number]: number} = {}; // lookup index into groupedByOutput for a given output expression\n for (const label of sortedLabels) {\n const outputIndex = outputLookup[this.cases[label]];\n if (outputIndex === undefined) {\n // First time seeing this output, add it to the end of the grouped list\n outputLookup[this.cases[label]] = groupedByOutput.length;\n groupedByOutput.push([this.cases[label], [label]]);\n } else {\n // We've seen this expression before, add the label to that output's group\n groupedByOutput[outputIndex][1].push(label);\n }\n }\n\n const coerceLabel = (label) => this.inputType.kind === 'number' ? Number(label) : label;\n\n for (const [outputIndex, labels] of groupedByOutput) {\n if (labels.length === 1) {\n // Only a single label matches this output expression\n serialized.push(coerceLabel(labels[0]));\n } else {\n // Array of literal labels pointing to this output expression\n serialized.push(labels.map(coerceLabel));\n }\n serialized.push(this.outputs[outputIndex].serialize());\n }\n serialized.push(this.otherwise.serialize());\n return serialized;\n }\n}\n\nexport default Match;\n","// @flow\n\nimport assert from 'assert';\n\nimport { BooleanType } from '../types';\n\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\nimport type { Value } from '../values';\nimport type { Type } from '../types';\n\ntype Branches = Array<[Expression, Expression]>;\n\nclass Case implements Expression {\n type: Type;\n\n branches: Branches;\n otherwise: Expression;\n\n constructor(type: Type, branches: Branches, otherwise: Expression) {\n this.type = type;\n this.branches = branches;\n this.otherwise = otherwise;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n if (args.length < 4)\n return context.error(`Expected at least 3 arguments, but found only ${args.length - 1}.`);\n if (args.length % 2 !== 0)\n return context.error(`Expected an odd number of arguments.`);\n\n let outputType: ?Type;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n\n const branches = [];\n for (let i = 1; i < args.length - 1; i += 2) {\n const test = context.parse(args[i], i, BooleanType);\n if (!test) return null;\n\n const result = context.parse(args[i + 1], i + 1, outputType);\n if (!result) return null;\n\n branches.push([test, result]);\n\n outputType = outputType || result.type;\n }\n\n const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise) return null;\n\n assert(outputType);\n return new Case((outputType: any), branches, otherwise);\n }\n\n evaluate(ctx: EvaluationContext) {\n for (const [test, expression] of this.branches) {\n if (test.evaluate(ctx)) {\n return expression.evaluate(ctx);\n }\n }\n return this.otherwise.evaluate(ctx);\n }\n\n eachChild(fn: (Expression) => void) {\n for (const [test, expression] of this.branches) {\n fn(test);\n fn(expression);\n }\n fn(this.otherwise);\n }\n\n possibleOutputs(): Array<Value | void> {\n return []\n .concat(...this.branches.map(([_, out]) => out.possibleOutputs()))\n .concat(this.otherwise.possibleOutputs());\n }\n\n serialize() {\n const serialized = [\"case\"];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Case;\n","// @flow\n\nimport { toString, ValueType, BooleanType, CollatorType } from '../types';\nimport Assertion from './assertion';\nimport { typeOf } from '../values';\nimport RuntimeError from '../runtime_error';\n\nimport type { Expression } from '../expression';\nimport type EvaluationContext from '../evaluation_context';\nimport type ParsingContext from '../parsing_context';\nimport type { Type } from '../types';\n\ntype ComparisonOperator = '==' | '!=' | '<' | '>' | '<=' | '>=' ;\n\nfunction isComparableType(op: ComparisonOperator, type: Type) {\n if (op === '==' || op === '!=') {\n // equality operator\n return type.kind === 'boolean' ||\n type.kind === 'string' ||\n type.kind === 'number' ||\n type.kind === 'null' ||\n type.kind === 'value';\n } else {\n // ordering operator\n return type.kind === 'string' ||\n type.kind === 'number' ||\n type.kind === 'value';\n }\n}\n\n\nfunction eq(ctx, a, b) { return a === b; }\nfunction neq(ctx, a, b) { return a !== b; }\nfunction lt(ctx, a, b) { return a < b; }\nfunction gt(ctx, a, b) { return a > b; }\nfunction lteq(ctx, a, b) { return a <= b; }\nfunction gteq(ctx, a, b) { return a >= b; }\n\nfunction eqCollate(ctx, a, b, c) { return c.compare(a, b) === 0; }\nfunction neqCollate(ctx, a, b, c) { return !eqCollate(ctx, a, b, c); }\nfunction ltCollate(ctx, a, b, c) { return c.compare(a, b) < 0; }\nfunction gtCollate(ctx, a, b, c) { return c.compare(a, b) > 0; }\nfunction lteqCollate(ctx, a, b, c) { return c.compare(a, b) <= 0; }\nfunction gteqCollate(ctx, a, b, c) { return c.compare(a, b) >= 0; }\n\n/**\n * Special form for comparison operators, implementing the signatures:\n * - (T, T, ?Collator) => boolean\n * - (T, value, ?Collator) => boolean\n * - (value, T, ?Collator) => boolean\n *\n * For inequalities, T must be either value, string, or number. For ==/!=, it\n * can also be boolean or null.\n *\n * Equality semantics are equivalent to Javascript's strict equality (===/!==)\n * -- i.e., when the arguments' types don't match, == evaluates to false, != to\n * true.\n *\n * When types don't match in an ordering comparison, a runtime error is thrown.\n *\n * @private\n */\nfunction makeComparison(op: ComparisonOperator, compareBasic, compareWithCollator) {\n const isOrderComparison = op !== '==' && op !== '!=';\n\n return class Comparison implements Expression {\n type: Type;\n lhs: Expression;\n rhs: Expression;\n collator: ?Expression;\n hasUntypedArgument: boolean;\n\n constructor(lhs: Expression, rhs: Expression, collator: ?Expression) {\n this.type = BooleanType;\n this.lhs = lhs;\n this.rhs = rhs;\n this.collator = collator;\n this.hasUntypedArgument = lhs.type.kind === 'value' || rhs.type.kind === 'value';\n }\n\n static parse(args: Array<mixed>, context: ParsingContext): ?Expression {\n if (args.length !== 3 && args.length !== 4)\n return context.error(`Expected two or three arguments.`);\n\n const op: ComparisonOperator = (args[0]: any);\n\n let lhs = context.parse(args[1], 1, ValueType);\n if (!lhs) return null;\n if (!isComparableType(op, lhs.type)) {\n return context.concat(1).error(`\"${op}\" comparisons are not supported for type '${toString(lhs.type)}'.`);\n }\n let rhs = context.parse(args[2], 2, ValueType);\n if (!rhs) return null;\n if (!isComparableType(op, rhs.type)) {\n return context.concat(2).error(`\"${op}\" comparisons are not supported for type '${toString(rhs.type)}'.`);\n }\n\n if (\n lhs.type.kind !== rhs.type.kind &&\n lhs.type.kind !== 'value' &&\n rhs.type.kind !== 'value'\n ) {\n return context.error(`Cannot compare types '${toString(lhs.type)}' and '${toString(rhs.type)}'.`);\n }\n\n if (isOrderComparison) {\n // typing rules specific to less/greater than operators\n if (lhs.type.kind === 'value' && rhs.type.kind !== 'value') {\n // (value, T)\n lhs = new Assertion(rhs.type, [lhs]);\n } else if (lhs.type.kind !== 'value' && rhs.type.kind === 'value') {\n // (T, value)\n rhs = new Assertion(lhs.type, [rhs]);\n }\n }\n\n let collator = null;\n if (args.length === 4) {\n if (\n lhs.type.kind !== 'string' &&\n rhs.type.kind !== 'string' &&\n lhs.type.kind !== 'value' &&\n rhs.type.kind !== 'value'\n ) {\n return context.error(`Cannot use collator to compare non-string types.`);\n }\n collator = context.parse(args[3], 3, CollatorType);\n if (!collator) return null;\n }\n\n return new Comparison(lhs, rhs, collator);\n }\n\n evaluate(ctx: EvaluationContext) {\n const lhs = this.lhs.evaluate(ctx);\n const rhs = this.rhs.evaluate(ctx);\n\n if (isOrderComparison && this.hasUntypedArgument) {\n const lt = typeOf(lhs);\n const rt = typeOf(rhs);\n // check that type is string or number, and equal\n if (lt.kind !== rt.kind || !(lt.kind === 'string' || lt.kind === 'number')) {\n throw new RuntimeError(`Expected arguments for \"${op}\" to be (string, string) or (number, number), but found (${lt.kind}, ${rt.kind}) instead.`);\n }\n }\n\n if (this.collator && !isOrderComparison && this.hasUntypedArgument) {\n const lt = typeOf(lhs);\n const rt = typeOf(rhs);\n if (lt.kind !== 'string' || rt.kind !== 'string') {\n return compareBasic(ctx, lhs, rhs);\n }\n }\n\n return this.collator ?\n compareWithCollator(ctx, lhs, rhs, this.collator.evaluate(ctx)) :\n compareBasic(ctx, lhs, rhs);\n }\n\n eachChild(fn: (Expression) => void) {\n fn(this.lhs);\n fn(this.rhs);\n if (this.collator) {\n fn(this.collator);\n }\n }\n\n possibleOutputs() {\n return [true, false];\n }\n\n serialize() {\n const serialized = [op];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n };\n}\n\nexport const Equals = makeComparison('==', eq, eqCollate);\nexport const NotEquals = makeComparison('!=', neq, neqCollate);\nexport const LessThan = makeComparison('<', lt, ltCollate);\nexport const GreaterThan = makeComparison('>', gt, gtCollate);\nexport const LessThanOrEqual = makeComparison('<=', lteq, lteqCollate);\nexport const GreaterThanOrEqual = makeComparison('>=', gteq, gteqCollate);\n","// @flow\n\nimport { NumberType, toString } from '../types';\n\nimport { typeOf } from '../values';\nimport RuntimeError from '../runtime_error';\n\nimport type { Expression } from '../expression';\nimport type ParsingContext from '../parsing_context';\nimport type EvaluationContext from '../evaluation_context';\nimport type { Type } from '../types';\n\nclass Length implements Expression {\n type: Type;\n input: Expression;\n\n constructor(input: Expression) {\n this.type = NumberType;\n this.input = input;\n }\n\n static parse(args: Array<mixed>, context: ParsingContext) {\n if (args.length !== 2)\n return context.error(`Expected 1 argument, but found ${args.length - 1} instead.`);\n\n const input = context.parse(args[1], 1);\n if (!input) return null;\n\n if (input.type.kind !== 'array' && input.type.kind !== 'string' && input.type.kind !== 'value')\n return context.error(`Expected argument of type string or array, but found ${toString(input.type)} instead.`);\n\n return new Length(input);\n }\n\n evaluate(ctx: EvaluationContext) {\n const input = this.input.evaluate(ctx);\n if (typeof input === 'string') {\n return input.length;\n } else if (Array.isArray(input)) {\n return input.length;\n } else {\n throw new RuntimeError(`Expected value to be of type string or array, but found ${toString(typeOf(input))} instead.`);\n }\n }\n\n eachChild(fn: (Expression) => void) {\n fn(this.input);\n }\n\n possibleOutputs() {\n return [undefined];\n }\n\n serialize() {\n const serialized = [\"length\"];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Length;\n","// @flow\n\nimport {\n type Type,\n NumberType,\n StringType,\n BooleanType,\n ColorType,\n ObjectType,\n ValueType,\n ErrorType,\n CollatorType,\n array,\n toString as typeToString\n} from '../types';\n\nimport { typeOf, Color, validateRGBA, toString as valueToString } from '../values';\nimport CompoundExpression from '../compound_expression';\nimport RuntimeError from '../runtime_error';\nimport Let from './let';\nimport Var from './var';\nimport Literal from './literal';\nimport Assertion from './assertion';\nimport Coercion from './coercion';\nimport At from './at';\nimport Match from './match';\nimport Case from './case';\nimport Step from './step';\nimport Interpolate from './interpolate';\nimport Coalesce from './coalesce';\nimport {\n Equals,\n NotEquals,\n LessThan,\n GreaterThan,\n LessThanOrEqual,\n GreaterThanOrEqual\n} from './comparison';\nimport CollatorExpression from './collator';\nimport FormatExpression from './format';\nimport Length from './length';\n\nimport type { Varargs } from '../compound_expression';\nimport type { ExpressionRegistry } from '../expression';\n\nconst expressions: ExpressionRegistry = {\n // special forms\n '==': Equals,\n '!=': NotEquals,\n '>': GreaterThan,\n '<': LessThan,\n '>=': GreaterThanOrEqual,\n '<=': LessThanOrEqual,\n 'array': Assertion,\n 'at': At,\n 'boolean': Assertion,\n 'case': Case,\n 'coalesce': Coalesce,\n 'collator': CollatorExpression,\n 'format': FormatExpression,\n 'interpolate': Interpolate,\n 'interpolate-hcl': Interpolate,\n 'interpolate-lab': Interpolate,\n 'length': Length,\n 'let': Let,\n 'literal': Literal,\n 'match': Match,\n 'number': Assertion,\n 'object': Assertion,\n 'step': Step,\n 'string': Assertion,\n 'to-boolean': Coercion,\n 'to-color': Coercion,\n 'to-number': Coercion,\n 'to-string': Coercion,\n 'var': Var\n};\n\nfunction rgba(ctx, [r, g, b, a]) {\n r = r.evaluate(ctx);\n g = g.evaluate(ctx);\n b = b.evaluate(ctx);\n const alpha = a ? a.evaluate(ctx) : 1;\n const error = validateRGBA(r, g, b, alpha);\n if (error) throw new RuntimeError(error);\n return new Color(r / 255 * alpha, g / 255 * alpha, b / 255 * alpha, alpha);\n}\n\nfunction has(key, obj) {\n return key in obj;\n}\n\nfunction get(key, obj) {\n const v = obj[key];\n return typeof v === 'undefined' ? null : v;\n}\n\nfunction binarySearch(v, a, i, j) {\n while (i <= j) {\n const m = (i + j) >> 1;\n if (a[m] === v)\n return true;\n if (a[m] > v)\n j = m - 1;\n else\n i = m + 1;\n }\n return false;\n}\n\nfunction varargs(type: Type): Varargs {\n return { type };\n}\n\nCompoundExpression.register(expressions, {\n 'error': [\n ErrorType,\n [StringType],\n (ctx, [v]) => { throw new RuntimeError(v.evaluate(ctx)); }\n ],\n 'typeof': [\n StringType,\n [ValueType],\n (ctx, [v]) => typeToString(typeOf(v.evaluate(ctx)))\n ],\n 'to-rgba': [\n array(NumberType, 4),\n [ColorType],\n (ctx, [v]) => {\n return v.evaluate(ctx).toArray();\n }\n ],\n 'rgb': [\n ColorType,\n [NumberType, NumberType, NumberType],\n rgba\n ],\n 'rgba': [\n ColorType,\n [NumberType, NumberType, NumberType, NumberType],\n rgba\n ],\n 'has': {\n type: BooleanType,\n overloads: [\n [\n [StringType],\n (ctx, [key]) => has(key.evaluate(ctx), ctx.properties())\n ], [\n [StringType, ObjectType],\n (ctx, [key, obj]) => has(key.evaluate(ctx), obj.evaluate(ctx))\n ]\n ]\n },\n 'get': {\n type: ValueType,\n overloads: [\n [\n [StringType],\n (ctx, [key]) => get(key.evaluate(ctx), ctx.properties())\n ], [\n [StringType, ObjectType],\n (ctx, [key, obj]) => get(key.evaluate(ctx), obj.evaluate(ctx))\n ]\n ]\n },\n 'feature-state': [\n ValueType,\n [StringType],\n (ctx, [key]) => get(key.evaluate(ctx), ctx.featureState || {})\n ],\n 'properties': [\n ObjectType,\n [],\n (ctx) => ctx.properties()\n ],\n 'geometry-type': [\n StringType,\n [],\n (ctx) => ctx.geometryType()\n ],\n 'id': [\n ValueType,\n [],\n (ctx) => ctx.id()\n ],\n 'zoom': [\n NumberType,\n [],\n (ctx) => ctx.globals.zoom\n ],\n 'heatmap-density': [\n NumberType,\n [],\n (ctx) => ctx.globals.heatmapDensity || 0\n ],\n 'line-progress': [\n NumberType,\n [],\n (ctx) => ctx.globals.lineProgress || 0\n ],\n '+': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => {\n let result = 0;\n for (const arg of args) {\n result += arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '*': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => {\n let result = 1;\n for (const arg of args) {\n result *= arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '-': {\n type: NumberType,\n overloads: [\n [\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) - b.evaluate(ctx)\n ], [\n [NumberType],\n (ctx, [a]) => -a.evaluate(ctx)\n ]\n ]\n },\n '/': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) / b.evaluate(ctx)\n ],\n '%': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) % b.evaluate(ctx)\n ],\n 'ln2': [\n NumberType,\n [],\n () => Math.LN2\n ],\n 'pi': [\n NumberType,\n [],\n () => Math.PI\n ],\n 'e': [\n NumberType,\n [],\n () => Math.E\n ],\n '^': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [b, e]) => Math.pow(b.evaluate(ctx), e.evaluate(ctx))\n ],\n 'sqrt': [\n NumberType,\n [NumberType],\n (ctx, [x]) => Math.sqrt(x.evaluate(ctx))\n ],\n 'log10': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN10\n ],\n 'ln': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx))\n ],\n 'log2': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN2\n ],\n 'sin': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.sin(n.evaluate(ctx))\n ],\n 'cos': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.cos(n.evaluate(ctx))\n ],\n 'tan': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.tan(n.evaluate(ctx))\n ],\n 'asin': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.asin(n.evaluate(ctx))\n ],\n 'acos': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.acos(n.evaluate(ctx))\n ],\n 'atan': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.atan(n.evaluate(ctx))\n ],\n 'min': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => Math.min(...args.map(arg => arg.evaluate(ctx)))\n ],\n 'max': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => Math.max(...args.map(arg => arg.evaluate(ctx)))\n ],\n 'abs': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.abs(n.evaluate(ctx))\n ],\n 'round': [\n NumberType,\n [NumberType],\n (ctx, [n]) => {\n const v = n.evaluate(ctx);\n // Javascript's Math.round() rounds towards +Infinity for halfway\n // values, even when they're negative. It's more common to round\n // away from 0 (e.g., this is what python and C++ do)\n return v < 0 ? -Math.round(-v) : Math.round(v);\n }\n ],\n 'floor': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.floor(n.evaluate(ctx))\n ],\n 'ceil': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.ceil(n.evaluate(ctx))\n ],\n 'filter-==': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => ctx.properties()[(k: any).value] === (v: any).value\n ],\n 'filter-id-==': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => ctx.id() === (v: any).value\n ],\n 'filter-type-==': [\n BooleanType,\n [StringType],\n (ctx, [v]) => ctx.geometryType() === (v: any).value\n ],\n 'filter-<': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter-id-<': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter->': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-id->': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-<=': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter-id-<=': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter->=': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-id->=': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-has': [\n BooleanType,\n [ValueType],\n (ctx, [k]) => (k: any).value in ctx.properties()\n ],\n 'filter-has-id': [\n BooleanType,\n [],\n (ctx) => ctx.id() !== null\n ],\n 'filter-type-in': [\n BooleanType,\n [array(StringType)],\n (ctx, [v]) => (v: any).value.indexOf(ctx.geometryType()) >= 0\n ],\n 'filter-id-in': [\n BooleanType,\n [array(ValueType)],\n (ctx, [v]) => (v: any).value.indexOf(ctx.id()) >= 0\n ],\n 'filter-in-small': [\n BooleanType,\n [StringType, array(ValueType)],\n // assumes v is an array literal\n (ctx, [k, v]) => (v: any).value.indexOf(ctx.properties()[(k: any).value]) >= 0\n ],\n 'filter-in-large': [\n BooleanType,\n [StringType, array(ValueType)],\n // assumes v is a array literal with values sorted in ascending order and of a single type\n (ctx, [k, v]) => binarySearch(ctx.properties()[(k: any).value], (v: any).value, 0, (v: any).value.length - 1)\n ],\n 'all': {\n type: BooleanType,\n overloads: [\n [\n [BooleanType, BooleanType],\n (ctx, [a, b]) => a.evaluate(ctx) && b.evaluate(ctx)\n ],\n [\n varargs(BooleanType),\n (ctx, args) => {\n for (const arg of args) {\n if (!arg.evaluate(ctx))\n return false;\n }\n return true;\n }\n ]\n ]\n },\n 'any': {\n type: BooleanType,\n overloads: [\n [\n [BooleanType, BooleanType],\n (ctx, [a, b]) => a.evaluate(ctx) || b.evaluate(ctx)\n ],\n [\n varargs(BooleanType),\n (ctx, args) => {\n for (const arg of args) {\n if (arg.evaluate(ctx))\n return true;\n }\n return false;\n }\n ]\n ]\n },\n '!': [\n BooleanType,\n [BooleanType],\n (ctx, [b]) => !b.evaluate(ctx)\n ],\n 'is-supported-script': [\n BooleanType,\n [StringType],\n // At parse time this will always return true, so we need to exclude this expression with isGlobalPropertyConstant\n (ctx, [s]) => {\n const isSupportedScript = ctx.globals && ctx.globals.isSupportedScript;\n if (isSupportedScript) {\n return isSupportedScript(s.evaluate(ctx));\n }\n return true;\n }\n ],\n 'upcase': [\n StringType,\n [StringType],\n (ctx, [s]) => s.evaluate(ctx).toUpperCase()\n ],\n 'downcase': [\n StringType,\n [StringType],\n (ctx, [s]) => s.evaluate(ctx).toLowerCase()\n ],\n 'concat': [\n StringType,\n varargs(ValueType),\n (ctx, args) => args.map(arg => valueToString(arg.evaluate(ctx))).join('')\n ],\n 'resolved-locale': [\n StringType,\n [CollatorType],\n (ctx, [collator]) => collator.evaluate(ctx).resolvedLocale()\n ]\n});\n\nexport default expressions;\n","// @flow\n\n/**\n * A type used for returning and propagating errors. The first element of the union\n * represents success and contains a value, and the second represents an error and\n * contains an error value.\n * @private\n */\nexport type Result<T, E> =\n | {| result: 'success', value: T |}\n | {| result: 'error', value: E |};\n\nexport function success<T, E>(value: T): Result<T, E> {\n return { result: 'success', value };\n}\n\nexport function error<T, E>(value: E): Result<T, E> {\n return { result: 'error', value };\n}\n","// @flow\n\nimport type {StylePropertySpecification} from '../style-spec';\n\nexport function supportsPropertyExpression(spec: StylePropertySpecification): boolean {\n return spec['property-type'] === 'data-driven' || spec['property-type'] === 'cross-faded-data-driven';\n}\n\nexport function supportsZoomExpression(spec: StylePropertySpecification): boolean {\n return !!spec.expression && spec.expression.parameters.indexOf('zoom') > -1;\n}\n\nexport function supportsInterpolation(spec: StylePropertySpecification): boolean {\n return !!spec.expression && spec.expression.interpolated;\n}\n","\nexport default function getType(val) {\n if (val instanceof Number) {\n return 'number';\n } else if (val instanceof String) {\n return 'string';\n } else if (val instanceof Boolean) {\n return 'boolean';\n } else if (Array.isArray(val)) {\n return 'array';\n } else if (val === null) {\n return 'null';\n } else {\n return typeof val;\n }\n}\n","\nimport * as colorSpaces from '../util/color_spaces';\nimport Color from '../util/color';\nimport extend from '../util/extend';\nimport getType from '../util/get_type';\nimport * as interpolate from '../util/interpolate';\nimport Interpolate from '../expression/definitions/interpolate';\nimport Formatted from '../expression/types/formatted';\nimport { supportsInterpolation } from '../util/properties';\n\nexport function isFunction(value) {\n return typeof value === 'object' && value !== null && !Array.isArray(value);\n}\n\nfunction identityFunction(x) {\n return x;\n}\n\nexport function createFunction(parameters, propertySpec) {\n const isColor = propertySpec.type === 'color';\n const zoomAndFeatureDependent = parameters.stops && typeof parameters.stops[0][0] === 'object';\n const featureDependent = zoomAndFeatureDependent || parameters.property !== undefined;\n const zoomDependent = zoomAndFeatureDependent || !featureDependent;\n const type = parameters.type || (supportsInterpolation(propertySpec) ? 'exponential' : 'interval');\n\n if (isColor) {\n parameters = extend({}, parameters);\n\n if (parameters.stops) {\n parameters.stops = parameters.stops.map((stop) => {\n return [stop[0], Color.parse(stop[1])];\n });\n }\n\n if (parameters.default) {\n parameters.default = Color.parse(parameters.default);\n } else {\n parameters.default = Color.parse(propertySpec.default);\n }\n }\n\n if (parameters.colorSpace && parameters.colorSpace !== 'rgb' && !colorSpaces[parameters.colorSpace]) { // eslint-disable-line import/namespace\n throw new Error(`Unknown color space: ${parameters.colorSpace}`);\n }\n\n let innerFun;\n let hashedStops;\n let categoricalKeyType;\n if (type === 'exponential') {\n innerFun = evaluateExponentialFunction;\n } else if (type === 'interval') {\n innerFun = evaluateIntervalFunction;\n } else if (type === 'categorical') {\n innerFun = evaluateCategoricalFunction;\n\n // For categorical functions, generate an Object as a hashmap of the stops for fast searching\n hashedStops = Object.create(null);\n for (const stop of parameters.stops) {\n hashedStops[stop[0]] = stop[1];\n }\n\n // Infer key type based on first stop key-- used to encforce strict type checking later\n categoricalKeyType = typeof parameters.stops[0][0];\n\n } else if (type === 'identity') {\n innerFun = evaluateIdentityFunction;\n } else {\n throw new Error(`Unknown function type \"${type}\"`);\n }\n\n if (zoomAndFeatureDependent) {\n const featureFunctions = {};\n const zoomStops = [];\n for (let s = 0; s < parameters.stops.length; s++) {\n const stop = parameters.stops[s];\n const zoom = stop[0].zoom;\n if (featureFunctions[zoom] === undefined) {\n featureFunctions[zoom] = {\n zoom,\n type: parameters.type,\n property: parameters.property,\n default: parameters.default,\n stops: []\n };\n zoomStops.push(zoom);\n }\n featureFunctions[zoom].stops.push([stop[0].value, stop[1]]);\n }\n\n const featureFunctionStops = [];\n for (const z of zoomStops) {\n featureFunctionStops.push([featureFunctions[z].zoom, createFunction(featureFunctions[z], propertySpec)]);\n }\n\n return {\n kind: 'composite',\n interpolationFactor: Interpolate.interpolationFactor.bind(undefined, {name: 'linear'}),\n zoomStops: featureFunctionStops.map(s => s[0]),\n evaluate({zoom}, properties) {\n return evaluateExponentialFunction({\n stops: featureFunctionStops,\n base: parameters.base\n }, propertySpec, zoom).evaluate(zoom, properties);\n }\n };\n } else if (zoomDependent) {\n return {\n kind: 'camera',\n interpolationFactor: type === 'exponential' ?\n Interpolate.interpolationFactor.bind(undefined, {name: 'exponential', base: parameters.base !== undefined ? parameters.base : 1}) :\n () => 0,\n zoomStops: parameters.stops.map(s => s[0]),\n evaluate: ({zoom}) => innerFun(parameters, propertySpec, zoom, hashedStops, categoricalKeyType)\n };\n } else {\n return {\n kind: 'source',\n evaluate(_, feature) {\n const value = feature && feature.properties ? feature.properties[parameters.property] : undefined;\n if (value === undefined) {\n return coalesce(parameters.default, propertySpec.default);\n }\n return innerFun(parameters, propertySpec, value, hashedStops, categoricalKeyType);\n }\n };\n }\n}\n\nfunction coalesce(a, b, c) {\n if (a !== undefined) return a;\n if (b !== undefined) return b;\n if (c !== undefined) return c;\n}\n\nfunction evaluateCategoricalFunction(parameters, propertySpec, input, hashedStops, keyType) {\n const evaluated = typeof input === keyType ? hashedStops[input] : undefined; // Enforce strict typing on input\n return coalesce(evaluated, parameters.default, propertySpec.default);\n}\n\nfunction evaluateIntervalFunction(parameters, propertySpec, input) {\n // Edge cases\n if (getType(input) !== 'number') return coalesce(parameters.default, propertySpec.default);\n const n = parameters.stops.length;\n if (n === 1) return parameters.stops[0][1];\n if (input <= parameters.stops[0][0]) return parameters.stops[0][1];\n if (input >= parameters.stops[n - 1][0]) return parameters.stops[n - 1][1];\n\n const index = findStopLessThanOrEqualTo(parameters.stops, input);\n\n return parameters.stops[index][1];\n}\n\nfunction evaluateExponentialFunction(parameters, propertySpec, input) {\n const base = parameters.base !== undefined ? parameters.base : 1;\n\n // Edge cases\n if (getType(input) !== 'number') return coalesce(parameters.default, propertySpec.default);\n const n = parameters.stops.length;\n if (n === 1) return parameters.stops[0][1];\n if (input <= parameters.stops[0][0]) return parameters.stops[0][1];\n if (input >= parameters.stops[n - 1][0]) return parameters.stops[n - 1][1];\n\n const index = findStopLessThanOrEqualTo(parameters.stops, input);\n const t = interpolationFactor(\n input, base,\n parameters.stops[index][0],\n parameters.stops[index + 1][0]);\n\n const outputLower = parameters.stops[index][1];\n const outputUpper = parameters.stops[index + 1][1];\n let interp = interpolate[propertySpec.type] || identityFunction; // eslint-disable-line import/namespace\n\n if (parameters.colorSpace && parameters.colorSpace !== 'rgb') {\n const colorspace = colorSpaces[parameters.colorSpace]; // eslint-disable-line import/namespace\n interp = (a, b) => colorspace.reverse(colorspace.interpolate(colorspace.forward(a), colorspace.forward(b), t));\n }\n\n if (typeof outputLower.evaluate === 'function') {\n return {\n evaluate(...args) {\n const evaluatedLower = outputLower.evaluate.apply(undefined, args);\n const evaluatedUpper = outputUpper.evaluate.apply(undefined, args);\n // Special case for fill-outline-color, which has no spec default.\n if (evaluatedLower === undefined || evaluatedUpper === undefined) {\n return undefined;\n }\n return interp(evaluatedLower, evaluatedUpper, t);\n }\n };\n }\n\n return interp(outputLower, outputUpper, t);\n}\n\nfunction evaluateIdentityFunction(parameters, propertySpec, input) {\n if (propertySpec.type === 'color') {\n input = Color.parse(input);\n } else if (propertySpec.type === 'formatted') {\n input = Formatted.fromString(input.toString());\n } else if (getType(input) !== propertySpec.type && (propertySpec.type !== 'enum' || !propertySpec.values[input])) {\n input = undefined;\n }\n return coalesce(input, parameters.default, propertySpec.default);\n}\n\n/**\n * Returns the index of the last stop <= input, or 0 if it doesn't exist.\n *\n * @private\n */\nfunction findStopLessThanOrEqualTo(stops, input) {\n const n = stops.length;\n let lowerIndex = 0;\n let upperIndex = n - 1;\n let currentIndex = 0;\n let currentValue, upperValue;\n\n while (lowerIndex <= upperIndex) {\n currentIndex = Math.floor((lowerIndex + upperIndex) / 2);\n currentValue = stops[currentIndex][0];\n upperValue = stops[currentIndex + 1][0];\n if (input === currentValue || input > currentValue && input < upperValue) { // Search complete\n return currentIndex;\n } else if (currentValue < input) {\n lowerIndex = currentIndex + 1;\n } else if (currentValue > input) {\n upperIndex = currentIndex - 1;\n }\n }\n\n return Math.max(currentIndex - 1, 0);\n}\n\n/**\n * Returns a ratio that can be used to interpolate between exponential function\n * stops.\n *\n * How it works:\n * Two consecutive stop values define a (scaled and shifted) exponential\n * function `f(x) = a * base^x + b`, where `base` is the user-specified base,\n * and `a` and `b` are constants affording sufficient degrees of freedom to fit\n * the function to the given stops.\n *\n * Here's a bit of algebra that lets us compute `f(x)` directly from the stop\n * values without explicitly solving for `a` and `b`:\n *\n * First stop value: `f(x0) = y0 = a * base^x0 + b`\n * Second stop value: `f(x1) = y1 = a * base^x1 + b`\n * => `y1 - y0 = a(base^x1 - base^x0)`\n * => `a = (y1 - y0)/(base^x1 - base^x0)`\n *\n * Desired value: `f(x) = y = a * base^x + b`\n * => `f(x) = y0 + a * (base^x - base^x0)`\n *\n * From the above, we can replace the `a` in `a * (base^x - base^x0)` and do a\n * little algebra:\n * ```\n * a * (base^x - base^x0) = (y1 - y0)/(base^x1 - base^x0) * (base^x - base^x0)\n * = (y1 - y0) * (base^x - base^x0) / (base^x1 - base^x0)\n * ```\n *\n * If we let `(base^x - base^x0) / (base^x1 base^x0)`, then we have\n * `f(x) = y0 + (y1 - y0) * ratio`. In other words, `ratio` may be treated as\n * an interpolation factor between the two stops' output values.\n *\n * (Note: a slightly different form for `ratio`,\n * `(base^(x-x0) - 1) / (base^(x1-x0) - 1) `, is equivalent, but requires fewer\n * expensive `Math.pow()` operations.)\n *\n * @private\n */\nfunction interpolationFactor(input, base, lowerValue, upperValue) {\n const difference = upperValue - lowerValue;\n const progress = input - lowerValue;\n\n if (difference === 0) {\n return 0;\n } else if (base === 1) {\n return progress / difference;\n } else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n","// @flow\n\nimport assert from 'assert';\n\nimport extend from '../util/extend';\nimport ParsingError from './parsing_error';\nimport ParsingContext from './parsing_context';\nimport EvaluationContext from './evaluation_context';\nimport CompoundExpression from './compound_expression';\nimport Step from './definitions/step';\nimport Interpolate from './definitions/interpolate';\nimport Coalesce from './definitions/coalesce';\nimport Let from './definitions/let';\nimport definitions from './definitions';\nimport * as isConstant from './is_constant';\nimport RuntimeError from './runtime_error';\nimport { success, error } from '../util/result';\nimport { supportsPropertyExpression, supportsZoomExpression, supportsInterpolation } from '../util/properties';\n\nimport type {Type, EvaluationKind} from './types';\nimport type {Value} from './values';\nimport type {Expression} from './expression';\nimport type {StylePropertySpecification} from '../style-spec';\nimport type {Result} from '../util/result';\nimport type {InterpolationType} from './definitions/interpolate';\nimport type {PropertyValueSpecification} from '../types';\n\nexport type Feature = {\n +type: 1 | 2 | 3 | 'Unknown' | 'Point' | 'MultiPoint' | 'LineString' | 'MultiLineString' | 'Polygon' | 'MultiPolygon',\n +id?: any,\n +properties: {[string]: any},\n +patterns?: {[string]: {\"min\": string, \"mid\": string, \"max\": string}}\n};\n\nexport type FeatureState = {[string]: any};\n\nexport type GlobalProperties = $ReadOnly<{\n zoom: number,\n heatmapDensity?: number,\n lineProgress?: number,\n isSupportedScript?: (string) => boolean\n}>;\n\nexport class StyleExpression {\n expression: Expression;\n\n _evaluator: EvaluationContext;\n _defaultValue: Value;\n _warningHistory: {[key: string]: boolean};\n _enumValues: ?{[string]: any};\n\n constructor(expression: Expression, propertySpec: StylePropertySpecification) {\n this.expression = expression;\n this._warningHistory = {};\n this._evaluator = new EvaluationContext();\n this._defaultValue = getDefaultValue(propertySpec);\n this._enumValues = propertySpec.type === 'enum' ? propertySpec.values : null;\n }\n\n evaluateWithoutErrorHandling(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState): any {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature;\n this._evaluator.featureState = featureState;\n\n return this.expression.evaluate(this._evaluator);\n }\n\n evaluate(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState): any {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature || null;\n this._evaluator.featureState = featureState || null;\n\n try {\n const val = this.expression.evaluate(this._evaluator);\n if (val === null || val === undefined) {\n return this._defaultValue;\n }\n if (this._enumValues && !(val in this._enumValues)) {\n throw new RuntimeError(`Expected value to be one of ${Object.keys(this._enumValues).map(v => JSON.stringify(v)).join(', ')}, but found ${JSON.stringify(val)} instead.`);\n }\n return val;\n } catch (e) {\n if (!this._warningHistory[e.message]) {\n this._warningHistory[e.message] = true;\n if (typeof console !== 'undefined') {\n console.warn(e.message);\n }\n }\n return this._defaultValue;\n }\n }\n}\n\nexport function isExpression(expression: mixed) {\n return Array.isArray(expression) && expression.length > 0 &&\n typeof expression[0] === 'string' && expression[0] in definitions;\n}\n\n/**\n * Parse and typecheck the given style spec JSON expression. If\n * options.defaultValue is provided, then the resulting StyleExpression's\n * `evaluate()` method will handle errors by logging a warning (once per\n * message) and returning the default value. Otherwise, it will throw\n * evaluation errors.\n *\n * @private\n */\nexport function createExpression(expression: mixed, propertySpec: StylePropertySpecification): Result<StyleExpression, Array<ParsingError>> {\n const parser = new ParsingContext(definitions, [], getExpectedType(propertySpec));\n\n // For string-valued properties, coerce to string at the top level rather than asserting.\n const parsed = parser.parse(expression, undefined, undefined, undefined,\n propertySpec.type === 'string' ? {typeAnnotation: 'coerce'} : undefined);\n\n if (!parsed) {\n assert(parser.errors.length > 0);\n return error(parser.errors);\n }\n\n return success(new StyleExpression(parsed, propertySpec));\n}\n\nexport class ZoomConstantExpression<Kind: EvaluationKind> {\n kind: Kind;\n isStateDependent: boolean;\n _styleExpression: StyleExpression;\n\n constructor(kind: Kind, expression: StyleExpression) {\n this.kind = kind;\n this._styleExpression = expression;\n this.isStateDependent = kind !== ('constant': EvaluationKind) && !isConstant.isStateConstant(expression.expression);\n }\n\n evaluateWithoutErrorHandling(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState): any {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState);\n }\n\n evaluate(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState): any {\n return this._styleExpression.evaluate(globals, feature, featureState);\n }\n}\n\nexport class ZoomDependentExpression<Kind: EvaluationKind> {\n kind: Kind;\n zoomStops: Array<number>;\n isStateDependent: boolean;\n\n _styleExpression: StyleExpression;\n _interpolationType: ?InterpolationType;\n\n constructor(kind: Kind, expression: StyleExpression, zoomCurve: Step | Interpolate) {\n this.kind = kind;\n this.zoomStops = zoomCurve.labels;\n this._styleExpression = expression;\n this.isStateDependent = kind !== ('camera': EvaluationKind) && !isConstant.isStateConstant(expression.expression);\n if (zoomCurve instanceof Interpolate) {\n this._interpolationType = zoomCurve.interpolation;\n }\n }\n\n evaluateWithoutErrorHandling(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState): any {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState);\n }\n\n evaluate(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState): any {\n return this._styleExpression.evaluate(globals, feature, featureState);\n }\n\n interpolationFactor(input: number, lower: number, upper: number): number {\n if (this._interpolationType) {\n return Interpolate.interpolationFactor(this._interpolationType, input, lower, upper);\n } else {\n return 0;\n }\n }\n}\n\nexport type ConstantExpression = {\n kind: 'constant',\n +evaluate: (globals: GlobalProperties, feature?: Feature) => any,\n}\n\nexport type SourceExpression = {\n kind: 'source',\n isStateDependent: boolean,\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState) => any,\n};\n\nexport type CameraExpression = {\n kind: 'camera',\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState) => any,\n +interpolationFactor: (input: number, lower: number, upper: number) => number,\n zoomStops: Array<number>\n};\n\nexport type CompositeExpression = {\n kind: 'composite',\n isStateDependent: boolean,\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState) => any,\n +interpolationFactor: (input: number, lower: number, upper: number) => number,\n zoomStops: Array<number>\n};\n\nexport type StylePropertyExpression =\n | ConstantExpression\n | SourceExpression\n | CameraExpression\n | CompositeExpression;\n\nexport function createPropertyExpression(expression: mixed, propertySpec: StylePropertySpecification): Result<StylePropertyExpression, Array<ParsingError>> {\n expression = createExpression(expression, propertySpec);\n if (expression.result === 'error') {\n return expression;\n }\n\n const parsed = expression.value.expression;\n\n const isFeatureConstant = isConstant.isFeatureConstant(parsed);\n if (!isFeatureConstant && !supportsPropertyExpression(propertySpec)) {\n return error([new ParsingError('', 'data expressions not supported')]);\n }\n\n const isZoomConstant = isConstant.isGlobalPropertyConstant(parsed, ['zoom']);\n if (!isZoomConstant && !supportsZoomExpression(propertySpec)) {\n return error([new ParsingError('', 'zoom expressions not supported')]);\n }\n\n const zoomCurve = findZoomCurve(parsed);\n if (!zoomCurve && !isZoomConstant) {\n return error([new ParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.')]);\n } else if (zoomCurve instanceof ParsingError) {\n return error([zoomCurve]);\n } else if (zoomCurve instanceof Interpolate && !supportsInterpolation(propertySpec)) {\n return error([new ParsingError('', '\"interpolate\" expressions cannot be used with this property')]);\n }\n\n if (!zoomCurve) {\n return success(isFeatureConstant ?\n (new ZoomConstantExpression('constant', expression.value): ConstantExpression) :\n (new ZoomConstantExpression('source', expression.value): SourceExpression));\n }\n\n return success(isFeatureConstant ?\n (new ZoomDependentExpression('camera', expression.value, zoomCurve): CameraExpression) :\n (new ZoomDependentExpression('composite', expression.value, zoomCurve): CompositeExpression));\n}\n\nimport { isFunction, createFunction } from '../function';\nimport { Color } from './values';\n\n// serialization wrapper for old-style stop functions normalized to the\n// expression interface\nexport class StylePropertyFunction<T> {\n _parameters: PropertyValueSpecification<T>;\n _specification: StylePropertySpecification;\n\n kind: EvaluationKind;\n evaluate: (globals: GlobalProperties, feature?: Feature) => any;\n interpolationFactor: ?(input: number, lower: number, upper: number) => number;\n zoomStops: ?Array<number>;\n\n constructor(parameters: PropertyValueSpecification<T>, specification: StylePropertySpecification) {\n this._parameters = parameters;\n this._specification = specification;\n extend(this, createFunction(this._parameters, this._specification));\n }\n\n static deserialize(serialized: {_parameters: PropertyValueSpecification<T>, _specification: StylePropertySpecification}) {\n return ((new StylePropertyFunction(serialized._parameters, serialized._specification)): StylePropertyFunction<T>);\n }\n\n static serialize(input: StylePropertyFunction<T>) {\n return {\n _parameters: input._parameters,\n _specification: input._specification\n };\n }\n}\n\nexport function normalizePropertyExpression<T>(value: PropertyValueSpecification<T>, specification: StylePropertySpecification): StylePropertyExpression {\n if (isFunction(value)) {\n return (new StylePropertyFunction(value, specification): any);\n\n } else if (isExpression(value)) {\n const expression = createPropertyExpression(value, specification);\n if (expression.result === 'error') {\n // this should have been caught in validation\n throw new Error(expression.value.map(err => `${err.key}: ${err.message}`).join(', '));\n }\n return expression.value;\n\n } else {\n let constant: any = value;\n if (typeof value === 'string' && specification.type === 'color') {\n constant = Color.parse(value);\n }\n return {\n kind: 'constant',\n evaluate: () => constant\n };\n }\n}\n\n// Zoom-dependent expressions may only use [\"zoom\"] as the input to a top-level \"step\" or \"interpolate\"\n// expression (collectively referred to as a \"curve\"). The curve may be wrapped in one or more \"let\" or\n// \"coalesce\" expressions.\nfunction findZoomCurve(expression: Expression): Step | Interpolate | ParsingError | null {\n let result = null;\n if (expression instanceof Let) {\n result = findZoomCurve(expression.result);\n\n } else if (expression instanceof Coalesce) {\n for (const arg of expression.args) {\n result = findZoomCurve(arg);\n if (result) {\n break;\n }\n }\n\n } else if ((expression instanceof Step || expression instanceof Interpolate) &&\n expression.input instanceof CompoundExpression &&\n expression.input.name === 'zoom') {\n\n result = expression;\n }\n\n if (result instanceof ParsingError) {\n return result;\n }\n\n expression.eachChild((child) => {\n const childResult = findZoomCurve(child);\n if (childResult instanceof ParsingError) {\n result = childResult;\n } else if (!result && childResult) {\n result = new ParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.');\n } else if (result && childResult && result !== childResult) {\n result = new ParsingError('', 'Only one zoom-based \"step\" or \"interpolate\" subexpression may be used in an expression.');\n }\n });\n\n return result;\n}\n\nimport { ColorType, StringType, NumberType, BooleanType, ValueType, FormattedType, array } from './types';\n\nfunction getExpectedType(spec: StylePropertySpecification): Type {\n const types = {\n color: ColorType,\n string: StringType,\n number: NumberType,\n enum: StringType,\n boolean: BooleanType,\n formatted: FormattedType\n };\n\n if (spec.type === 'array') {\n return array(types[spec.value] || ValueType, spec.length);\n }\n\n return types[spec.type];\n}\n\nfunction getDefaultValue(spec: StylePropertySpecification): Value {\n if (spec.type === 'color' && isFunction(spec.default)) {\n // Special case for heatmap-color: it uses the 'default:' to define a\n // default color ramp, but createExpression expects a simple value to fall\n // back to in case of runtime errors\n return new Color(0, 0, 0, 0);\n } else if (spec.type === 'color') {\n return Color.parse(spec.default) || null;\n } else if (spec.default === undefined) {\n return null;\n } else {\n return spec.default;\n }\n}\n","// @flow\n\nimport assert from 'assert';\nimport type {StylePropertySpecification} from '../style-spec';\n\nexport default convertFunction;\n\nfunction convertLiteral(value) {\n return typeof value === 'object' ? ['literal', value] : value;\n}\n\nfunction convertFunction(parameters: any, propertySpec: StylePropertySpecification) {\n let stops = parameters.stops;\n if (!stops) {\n // identity function\n return convertIdentityFunction(parameters, propertySpec);\n }\n\n const zoomAndFeatureDependent = stops && typeof stops[0][0] === 'object';\n const featureDependent = zoomAndFeatureDependent || parameters.property !== undefined;\n const zoomDependent = zoomAndFeatureDependent || !featureDependent;\n\n stops = stops.map((stop) => {\n if (!featureDependent && propertySpec.tokens && typeof stop[1] === 'string') {\n return [stop[0], convertTokenString(stop[1])];\n }\n return [stop[0], convertLiteral(stop[1])];\n });\n\n if (zoomAndFeatureDependent) {\n return convertZoomAndPropertyFunction(parameters, propertySpec, stops);\n } else if (zoomDependent) {\n return convertZoomFunction(parameters, propertySpec, stops);\n } else {\n return convertPropertyFunction(parameters, propertySpec, stops);\n }\n}\n\nfunction convertIdentityFunction(parameters, propertySpec): Array<mixed> {\n const get = ['get', parameters.property];\n\n if (parameters.default === undefined) {\n // By default, expressions for string-valued properties get coerced. To preserve\n // legacy function semantics, insert an explicit assertion instead.\n return propertySpec.type === 'string' ? ['string', get] : get;\n } else if (propertySpec.type === 'enum') {\n return [\n 'match',\n get,\n Object.keys(propertySpec.values),\n get,\n parameters.default\n ];\n } else {\n const expression = [propertySpec.type === 'color' ? 'to-color' : propertySpec.type, get, convertLiteral(parameters.default)];\n if (propertySpec.type === 'array') {\n expression.splice(1, 0, propertySpec.value, propertySpec.length || null);\n }\n return expression;\n }\n}\n\nfunction getInterpolateOperator(parameters) {\n switch (parameters.colorSpace) {\n case 'hcl': return 'interpolate-hcl';\n case 'lab': return 'interpolate-lab';\n default: return 'interpolate';\n }\n}\n\nfunction convertZoomAndPropertyFunction(parameters, propertySpec, stops) {\n const featureFunctionParameters = {};\n const featureFunctionStops = {};\n const zoomStops = [];\n for (let s = 0; s < stops.length; s++) {\n const stop = stops[s];\n const zoom = stop[0].zoom;\n if (featureFunctionParameters[zoom] === undefined) {\n featureFunctionParameters[zoom] = {\n zoom,\n type: parameters.type,\n property: parameters.property,\n default: parameters.default,\n };\n featureFunctionStops[zoom] = [];\n zoomStops.push(zoom);\n }\n featureFunctionStops[zoom].push([stop[0].value, stop[1]]);\n }\n\n // the interpolation type for the zoom dimension of a zoom-and-property\n // function is determined directly from the style property specification\n // for which it's being used: linear for interpolatable properties, step\n // otherwise.\n const functionType = getFunctionType({}, propertySpec);\n if (functionType === 'exponential') {\n const expression = [getInterpolateOperator(parameters), ['linear'], ['zoom']];\n\n for (const z of zoomStops) {\n const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]);\n appendStopPair(expression, z, output, false);\n }\n\n return expression;\n } else {\n const expression = ['step', ['zoom']];\n\n for (const z of zoomStops) {\n const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]);\n appendStopPair(expression, z, output, true);\n }\n\n fixupDegenerateStepCurve(expression);\n\n return expression;\n }\n}\n\nfunction coalesce(a, b) {\n if (a !== undefined) return a;\n if (b !== undefined) return b;\n}\n\nfunction convertPropertyFunction(parameters, propertySpec, stops) {\n const type = getFunctionType(parameters, propertySpec);\n const get = ['get', parameters.property];\n if (type === 'categorical' && typeof stops[0][0] === 'boolean') {\n assert(parameters.stops.length > 0 && parameters.stops.length <= 2);\n const expression = ['case'];\n for (const stop of stops) {\n expression.push(['==', get, stop[0]], stop[1]);\n }\n expression.push(convertLiteral(coalesce(parameters.default, propertySpec.default)));\n return expression;\n } else if (type === 'categorical') {\n const expression = ['match', get];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], false);\n }\n expression.push(convertLiteral(coalesce(parameters.default, propertySpec.default)));\n return expression;\n } else if (type === 'interval') {\n const expression = ['step', ['number', get]];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], true);\n }\n fixupDegenerateStepCurve(expression);\n return parameters.default === undefined ? expression : [\n 'case',\n ['==', ['typeof', get], 'number'],\n expression,\n convertLiteral(parameters.default)\n ];\n } else if (type === 'exponential') {\n const base = parameters.base !== undefined ? parameters.base : 1;\n const expression = [getInterpolateOperator(parameters), ['exponential', base], ['number', get]];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], false);\n }\n return parameters.default === undefined ? expression : [\n 'case',\n ['==', ['typeof', get], 'number'],\n expression,\n convertLiteral(parameters.default)\n ];\n } else {\n throw new Error(`Unknown property function type ${type}`);\n }\n}\n\nfunction convertZoomFunction(parameters, propertySpec, stops, input = ['zoom']) {\n const type = getFunctionType(parameters, propertySpec);\n let expression;\n let isStep = false;\n if (type === 'interval') {\n expression = ['step', input];\n isStep = true;\n } else if (type === 'exponential') {\n const base = parameters.base !== undefined ? parameters.base : 1;\n expression = [getInterpolateOperator(parameters), ['exponential', base], input];\n } else {\n throw new Error(`Unknown zoom function type \"${type}\"`);\n }\n\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], isStep);\n }\n\n fixupDegenerateStepCurve(expression);\n\n return expression;\n}\n\nfunction fixupDegenerateStepCurve(expression) {\n // degenerate step curve (i.e. a constant function): add a noop stop\n if (expression[0] === 'step' && expression.length === 3) {\n expression.push(0);\n expression.push(expression[3]);\n }\n}\n\nfunction appendStopPair(curve, input, output, isStep) {\n // Skip duplicate stop values. They were not validated for functions, but they are for expressions.\n // https://github.com/mapbox/mapbox-gl-js/issues/4107\n if (curve.length > 3 && input === curve[curve.length - 2]) {\n return;\n }\n // step curves don't get the first input value, as it is redundant.\n if (!(isStep && curve.length === 2)) {\n curve.push(input);\n }\n curve.push(output);\n}\n\nfunction getFunctionType(parameters, propertySpec) {\n if (parameters.type) {\n return parameters.type;\n } else {\n assert(propertySpec.expression);\n return (propertySpec.expression: any).interpolated ? 'exponential' : 'interval';\n }\n}\n\n// \"String with {name} token\" => [\"concat\", \"String with \", [\"get\", \"name\"], \" token\"]\nexport function convertTokenString(s: string) {\n const result = ['concat'];\n const re = /{([^{}]+)}/g;\n let pos = 0;\n for (let match = re.exec(s); match !== null; match = re.exec(s)) {\n const literal = s.slice(pos, re.lastIndex - match[0].length);\n pos = re.lastIndex;\n if (literal.length > 0) result.push(literal);\n result.push(['get', match[1]]);\n }\n\n if (result.length === 1) {\n return s;\n }\n\n if (pos < s.length) {\n result.push(s.slice(pos));\n } else if (result.length === 2) {\n return ['to-string', result[1]];\n }\n\n return result;\n}\n\n","// @flow\n\nimport { createExpression } from '../expression';\n\nimport type {GlobalProperties} from '../expression';\nexport type FeatureFilter = (globalProperties: GlobalProperties, feature: VectorTileFeature) => boolean;\n\nexport default createFilter;\nexport { isExpressionFilter };\n\nfunction isExpressionFilter(filter: any) {\n if (filter === true || filter === false) {\n return true;\n }\n\n if (!Array.isArray(filter) || filter.length === 0) {\n return false;\n }\n switch (filter[0]) {\n case 'has':\n return filter.length >= 2 && filter[1] !== '$id' && filter[1] !== '$type';\n\n case 'in':\n case '!in':\n case '!has':\n case 'none':\n return false;\n\n case '==':\n case '!=':\n case '>':\n case '>=':\n case '<':\n case '<=':\n return filter.length !== 3 || (Array.isArray(filter[1]) || Array.isArray(filter[2]));\n\n case 'any':\n case 'all':\n for (const f of filter.slice(1)) {\n if (!isExpressionFilter(f) && typeof f !== 'boolean') {\n return false;\n }\n }\n return true;\n\n default:\n return true;\n }\n}\n\nconst filterSpec = {\n 'type': 'boolean',\n 'default': false,\n 'transition': false,\n 'property-type': 'data-driven',\n 'expression': {\n 'interpolated': false,\n 'parameters': ['zoom', 'feature']\n }\n};\n\n/**\n * Given a filter expressed as nested arrays, return a new function\n * that evaluates whether a given feature (with a .properties or .tags property)\n * passes its test.\n *\n * @private\n * @param {Array} filter mapbox gl filter\n * @returns {Function} filter-evaluating function\n */\nfunction createFilter(filter: any): FeatureFilter {\n if (filter === null || filter === undefined) {\n return () => true;\n }\n\n if (!isExpressionFilter(filter)) {\n filter = convertFilter(filter);\n }\n\n const compiled = createExpression(filter, filterSpec);\n if (compiled.result === 'error') {\n throw new Error(compiled.value.map(err => `${err.key}: ${err.message}`).join(', '));\n } else {\n return (globalProperties: GlobalProperties, feature: VectorTileFeature) => compiled.value.evaluate(globalProperties, feature);\n }\n}\n\n// Comparison function to sort numbers and strings\nfunction compare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n\nfunction convertFilter(filter: ?Array<any>): mixed {\n if (!filter) return true;\n const op = filter[0];\n if (filter.length <= 1) return (op !== 'any');\n const converted =\n op === '==' ? convertComparisonOp(filter[1], filter[2], '==') :\n op === '!=' ? convertNegation(convertComparisonOp(filter[1], filter[2], '==')) :\n op === '<' ||\n op === '>' ||\n op === '<=' ||\n op === '>=' ? convertComparisonOp(filter[1], filter[2], op) :\n op === 'any' ? convertDisjunctionOp(filter.slice(1)) :\n op === 'all' ? ['all'].concat(filter.slice(1).map(convertFilter)) :\n op === 'none' ? ['all'].concat(filter.slice(1).map(convertFilter).map(convertNegation)) :\n op === 'in' ? convertInOp(filter[1], filter.slice(2)) :\n op === '!in' ? convertNegation(convertInOp(filter[1], filter.slice(2))) :\n op === 'has' ? convertHasOp(filter[1]) :\n op === '!has' ? convertNegation(convertHasOp(filter[1])) :\n true;\n return converted;\n}\n\nfunction convertComparisonOp(property: string, value: any, op: string) {\n switch (property) {\n case '$type':\n return [`filter-type-${op}`, value];\n case '$id':\n return [`filter-id-${op}`, value];\n default:\n return [`filter-${op}`, property, value];\n }\n}\n\nfunction convertDisjunctionOp(filters: Array<Array<any>>) {\n return ['any'].concat(filters.map(convertFilter));\n}\n\nfunction convertInOp(property: string, values: Array<any>) {\n if (values.length === 0) { return false; }\n switch (property) {\n case '$type':\n return [`filter-type-in`, ['literal', values]];\n case '$id':\n return [`filter-id-in`, ['literal', values]];\n default:\n if (values.length > 200 && !values.some(v => typeof v !== typeof values[0])) {\n return ['filter-in-large', property, ['literal', values.sort(compare)]];\n } else {\n return ['filter-in-small', property, ['literal', values]];\n }\n }\n}\n\nfunction convertHasOp(property: string) {\n switch (property) {\n case '$type':\n return true;\n case '$id':\n return [`filter-has-id`];\n default:\n return [`filter-has`, property];\n }\n}\n\nfunction convertNegation(filter: mixed) {\n return ['!', filter];\n}\n","// @flow\n\nimport { isExpressionFilter } from './index';\n\nimport type { FilterSpecification } from '../types';\n\ntype ExpectedTypes = {[string]: 'string' | 'number' | 'boolean'};\n\n/**\n * Convert the given legacy filter to (the JSON representation of) an\n * equivalent expression\n * @private\n */\nexport default function convertFilter(filter: FilterSpecification): mixed {\n return _convertFilter(filter, {});\n}\n\n/*\n * Convert the given filter to an expression, storing the expected types for\n * any feature properties referenced in expectedTypes.\n *\n * These expected types are needed in order to construct preflight type checks\n * needed for handling 'any' filters. A preflight type check is necessary in\n * order to mimic legacy filters' semantics around expected type mismatches.\n * For example, consider the legacy filter:\n *\n * [\"any\", [\"all\", [\">\", \"y\", 0], [\">\", \"y\", 0]], [\">\", \"x\", 0]]\n *\n * Naively, we might convert this to the expression:\n *\n * [\"any\", [\"all\", [\">\", [\"get\", \"y\"], 0], [\">\", [\"get\", \"z\"], 0]], [\">\", [\"get\", \"x\"], 0]]\n *\n * But if we tried to evaluate this against, say `{x: 1, y: null, z: 0}`, the\n * [\">\", [\"get\", \"y\"], 0] would cause an evaluation error, leading to the\n * entire filter returning false. Legacy filter semantics, though, ask for\n * [\">\", \"y\", 0] to simply return `false` when `y` is of the wrong type,\n * allowing the subsequent terms of the outer \"any\" expression to be evaluated\n * (resulting, in this case, in a `true` value, because x > 0).\n *\n * We account for this by inserting a preflight type-checking expression before\n * each \"any\" term, allowing us to avoid evaluating the actual converted filter\n * if any type mismatches would cause it to produce an evalaution error:\n *\n * [\"any\",\n * [\"case\",\n * [\"all\", [\"==\", [\"typeof\", [\"get\", \"y\"]], \"number\"], [\"==\", [\"typeof\", [\"get\", \"z\"], \"number]],\n * [\"all\", [\">\", [\"get\", \"y\"], 0], [\">\", [\"get\", \"z\"], 0]],\n * false\n * ],\n * [\"case\",\n * [\"==\", [\"typeof\", [\"get\", \"x\"], \"number\"]],\n * [\">\", [\"get\", \"x\"], 0],\n * false\n * ]\n * ]\n *\n * An alternative, possibly more direct approach would be to use type checks\n * in the conversion of each comparison operator, so that the converted version\n * of each individual ==, >=, etc. would mimic the legacy filter semantics. The\n * downside of this approach is that it can lead to many more type checks than\n * would otherwise be necessary: outside the context of an \"any\" expression,\n * bailing out due to a runtime type error (expression semantics) and returning\n * false (legacy filter semantics) are equivalent: they cause the filter to\n * produce a `false` result.\n */\nfunction _convertFilter(filter: FilterSpecification, expectedTypes: ExpectedTypes): mixed {\n if (isExpressionFilter(filter)) { return filter; }\n\n if (!filter) return true;\n const op = filter[0];\n if (filter.length <= 1) return (op !== 'any');\n\n let converted;\n\n if (\n op === '==' ||\n op === '!=' ||\n op === '<' ||\n op === '>' ||\n op === '<=' ||\n op === '>='\n ) {\n const [, property, value] = (filter: any);\n converted = convertComparisonOp(property, value, op, expectedTypes);\n } else if (op === 'any') {\n const children = (filter: any).slice(1).map(f => {\n const types = {};\n const child = _convertFilter(f, types);\n const typechecks = runtimeTypeChecks(types);\n return typechecks === true ? child : ['case', typechecks, child, false];\n });\n return ['any'].concat(children);\n } else if (op === 'all') {\n const children = (filter: any).slice(1).map(f => _convertFilter(f, expectedTypes));\n return children.length > 1 ? ['all'].concat(children) : [].concat(...children);\n } else if (op === 'none') {\n return ['!', _convertFilter(['any'].concat(filter.slice(1)), {})];\n } else if (op === 'in') {\n converted = convertInOp((filter[1]: any), filter.slice(2));\n } else if (op === '!in') {\n converted = convertInOp((filter[1]: any), filter.slice(2), true);\n } else if (op === 'has') {\n converted = convertHasOp((filter[1]: any));\n } else if (op === '!has') {\n converted = ['!', convertHasOp((filter[1]: any))];\n } else {\n converted = true;\n }\n\n return converted;\n}\n\n// Given a set of feature properties and an expected type for each one,\n// construct an boolean expression that tests whether each property has the\n// right type.\n// E.g.: for {name: 'string', population: 'number'}, return\n// [ 'all',\n// ['==', ['typeof', ['get', 'name'], 'string']],\n// ['==', ['typeof', ['get', 'population'], 'number]]\n// ]\nfunction runtimeTypeChecks(expectedTypes: ExpectedTypes) {\n const conditions = [];\n for (const property in expectedTypes) {\n const get = property === '$id' ? ['id'] : ['get', property];\n conditions.push(['==', ['typeof', get], expectedTypes[property]]);\n }\n if (conditions.length === 0) return true;\n if (conditions.length === 1) return conditions[0];\n return ['all'].concat(conditions);\n}\n\nfunction convertComparisonOp(property: string, value: any, op: string, expectedTypes: ?ExpectedTypes) {\n let get;\n if (property === '$type') {\n return [op, ['geometry-type'], value];\n } else if (property === '$id') {\n get = ['id'];\n } else {\n get = ['get', property];\n }\n\n if (expectedTypes && value !== null) {\n const type = ((typeof value): any);\n expectedTypes[property] = type;\n }\n\n if (op === '==' && property !== '$id' && value === null) {\n return [\n 'all',\n ['has', property], // missing property != null for legacy filters\n ['==', get, null]\n ];\n } else if (op === '!=' && property !== '$id' && value === null) {\n return [\n 'any',\n ['!', ['has', property]], // missing property != null for legacy filters\n ['!=', get, null]\n ];\n }\n\n return [op, get, value];\n}\n\nfunction convertInOp(property: string, values: Array<any>, negate = false) {\n if (values.length === 0) return negate;\n\n let get;\n if (property === '$type') {\n get = ['geometry-type'];\n } else if (property === '$id') {\n get = ['id'];\n } else {\n get = ['get', property];\n }\n\n // Determine if the list of values to be searched is homogenously typed.\n // If so (and if the type is string or number), then we can use a\n // [match, input, [...values], true, false] construction rather than a\n // bunch of `==` tests.\n let uniformTypes = true;\n const type = typeof values[0];\n for (const value of values) {\n if (typeof value !== type) {\n uniformTypes = false;\n break;\n }\n }\n\n if (uniformTypes && (type === 'string' || type === 'number')) {\n return ['match', get, values, !negate, negate];\n }\n\n return [ negate ? 'all' : 'any' ].concat(\n values.map(v => [negate ? '!=' : '==', get, v])\n );\n}\n\nfunction convertHasOp(property: string) {\n if (property === '$type') {\n return true;\n } else if (property === '$id') {\n return ['!=', ['id'], null];\n } else {\n return ['has', property];\n }\n}\n","// @flow\n\n/**\n * Deeply compares two object literals.\n *\n * @private\n */\nfunction deepEqual(a: ?mixed, b: ?mixed): boolean {\n if (Array.isArray(a)) {\n if (!Array.isArray(b) || a.length !== b.length) return false;\n for (let i = 0; i < a.length; i++) {\n if (!deepEqual(a[i], b[i])) return false;\n }\n return true;\n }\n if (typeof a === 'object' && a !== null && b !== null) {\n if (!(typeof b === 'object')) return false;\n const keys = Object.keys(a);\n if (keys.length !== Object.keys(b).length) return false;\n for (const key in a) {\n if (!deepEqual(a[key], b[key])) return false;\n }\n return true;\n }\n return a === b;\n}\n\nexport default deepEqual;\n","\nimport isEqual from './util/deep_equal';\n\nconst operations = {\n\n /*\n * { command: 'setStyle', args: [stylesheet] }\n */\n setStyle: 'setStyle',\n\n /*\n * { command: 'addLayer', args: [layer, 'beforeLayerId'] }\n */\n addLayer: 'addLayer',\n\n /*\n * { command: 'removeLayer', args: ['layerId'] }\n */\n removeLayer: 'removeLayer',\n\n /*\n * { command: 'setPaintProperty', args: ['layerId', 'prop', value] }\n */\n setPaintProperty: 'setPaintProperty',\n\n /*\n * { command: 'setLayoutProperty', args: ['layerId', 'prop', value] }\n */\n setLayoutProperty: 'setLayoutProperty',\n\n /*\n * { command: 'setFilter', args: ['layerId', filter] }\n */\n setFilter: 'setFilter',\n\n /*\n * { command: 'addSource', args: ['sourceId', source] }\n */\n addSource: 'addSource',\n\n /*\n * { command: 'removeSource', args: ['sourceId'] }\n */\n removeSource: 'removeSource',\n\n /*\n * { command: 'setGeoJSONSourceData', args: ['sourceId', data] }\n */\n setGeoJSONSourceData: 'setGeoJSONSourceData',\n\n /*\n * { command: 'setLayerZoomRange', args: ['layerId', 0, 22] }\n */\n setLayerZoomRange: 'setLayerZoomRange',\n\n /*\n * { command: 'setLayerProperty', args: ['layerId', 'prop', value] }\n */\n setLayerProperty: 'setLayerProperty',\n\n /*\n * { command: 'setCenter', args: [[lon, lat]] }\n */\n setCenter: 'setCenter',\n\n /*\n * { command: 'setZoom', args: [zoom] }\n */\n setZoom: 'setZoom',\n\n /*\n * { command: 'setBearing', args: [bearing] }\n */\n setBearing: 'setBearing',\n\n /*\n * { command: 'setPitch', args: [pitch] }\n */\n setPitch: 'setPitch',\n\n /*\n * { command: 'setSprite', args: ['spriteUrl'] }\n */\n setSprite: 'setSprite',\n\n /*\n * { command: 'setGlyphs', args: ['glyphsUrl'] }\n */\n setGlyphs: 'setGlyphs',\n\n /*\n * { command: 'setTransition', args: [transition] }\n */\n setTransition: 'setTransition',\n\n /*\n * { command: 'setLighting', args: [lightProperties] }\n */\n setLight: 'setLight'\n\n};\n\nfunction addSource(sourceId, after, commands) {\n commands.push({ command: operations.addSource, args: [sourceId, after[sourceId]] });\n}\n\nfunction removeSource(sourceId, commands, sourcesRemoved) {\n commands.push({ command: operations.removeSource, args: [sourceId] });\n sourcesRemoved[sourceId] = true;\n}\n\nfunction updateSource(sourceId, after, commands, sourcesRemoved) {\n removeSource(sourceId, commands, sourcesRemoved);\n addSource(sourceId, after, commands);\n}\n\nfunction canUpdateGeoJSON(before, after, sourceId) {\n let prop;\n for (prop in before[sourceId]) {\n if (!before[sourceId].hasOwnProperty(prop)) continue;\n if (prop !== 'data' && !isEqual(before[sourceId][prop], after[sourceId][prop])) {\n return false;\n }\n }\n for (prop in after[sourceId]) {\n if (!after[sourceId].hasOwnProperty(prop)) continue;\n if (prop !== 'data' && !isEqual(before[sourceId][prop], after[sourceId][prop])) {\n return false;\n }\n }\n return true;\n}\n\nfunction diffSources(before, after, commands, sourcesRemoved) {\n before = before || {};\n after = after || {};\n\n let sourceId;\n\n // look for sources to remove\n for (sourceId in before) {\n if (!before.hasOwnProperty(sourceId)) continue;\n if (!after.hasOwnProperty(sourceId)) {\n removeSource(sourceId, commands, sourcesRemoved);\n }\n }\n\n // look for sources to add/update\n for (sourceId in after) {\n if (!after.hasOwnProperty(sourceId)) continue;\n if (!before.hasOwnProperty(sourceId)) {\n addSource(sourceId, after, commands);\n } else if (!isEqual(before[sourceId], after[sourceId])) {\n if (before[sourceId].type === 'geojson' && after[sourceId].type === 'geojson' && canUpdateGeoJSON(before, after, sourceId)) {\n commands.push({ command: operations.setGeoJSONSourceData, args: [sourceId, after[sourceId].data] });\n } else {\n // no update command, must remove then add\n updateSource(sourceId, after, commands, sourcesRemoved);\n }\n }\n }\n}\n\nfunction diffLayerPropertyChanges(before, after, commands, layerId, klass, command) {\n before = before || {};\n after = after || {};\n\n let prop;\n\n for (prop in before) {\n if (!before.hasOwnProperty(prop)) continue;\n if (!isEqual(before[prop], after[prop])) {\n commands.push({ command, args: [layerId, prop, after[prop], klass] });\n }\n }\n for (prop in after) {\n if (!after.hasOwnProperty(prop) || before.hasOwnProperty(prop)) continue;\n if (!isEqual(before[prop], after[prop])) {\n commands.push({ command, args: [layerId, prop, after[prop], klass] });\n }\n }\n}\n\nfunction pluckId(layer) {\n return layer.id;\n}\nfunction indexById(group, layer) {\n group[layer.id] = layer;\n return group;\n}\n\nfunction diffLayers(before, after, commands) {\n before = before || [];\n after = after || [];\n\n // order of layers by id\n const beforeOrder = before.map(pluckId);\n const afterOrder = after.map(pluckId);\n\n // index of layer by id\n const beforeIndex = before.reduce(indexById, {});\n const afterIndex = after.reduce(indexById, {});\n\n // track order of layers as if they have been mutated\n const tracker = beforeOrder.slice();\n\n // layers that have been added do not need to be diffed\n const clean = Object.create(null);\n\n let i, d, layerId, beforeLayer, afterLayer, insertBeforeLayerId, prop;\n\n // remove layers\n for (i = 0, d = 0; i < beforeOrder.length; i++) {\n layerId = beforeOrder[i];\n if (!afterIndex.hasOwnProperty(layerId)) {\n commands.push({ command: operations.removeLayer, args: [layerId] });\n tracker.splice(tracker.indexOf(layerId, d), 1);\n } else {\n // limit where in tracker we need to look for a match\n d++;\n }\n }\n\n // add/reorder layers\n for (i = 0, d = 0; i < afterOrder.length; i++) {\n // work backwards as insert is before an existing layer\n layerId = afterOrder[afterOrder.length - 1 - i];\n\n if (tracker[tracker.length - 1 - i] === layerId) continue;\n\n if (beforeIndex.hasOwnProperty(layerId)) {\n // remove the layer before we insert at the correct position\n commands.push({ command: operations.removeLayer, args: [layerId] });\n tracker.splice(tracker.lastIndexOf(layerId, tracker.length - d), 1);\n } else {\n // limit where in tracker we need to look for a match\n d++;\n }\n\n // add layer at correct position\n insertBeforeLayerId = tracker[tracker.length - i];\n commands.push({ command: operations.addLayer, args: [afterIndex[layerId], insertBeforeLayerId] });\n tracker.splice(tracker.length - i, 0, layerId);\n clean[layerId] = true;\n }\n\n // update layers\n for (i = 0; i < afterOrder.length; i++) {\n layerId = afterOrder[i];\n beforeLayer = beforeIndex[layerId];\n afterLayer = afterIndex[layerId];\n\n // no need to update if previously added (new or moved)\n if (clean[layerId] || isEqual(beforeLayer, afterLayer)) continue;\n\n // If source, source-layer, or type have changes, then remove the layer\n // and add it back 'from scratch'.\n if (!isEqual(beforeLayer.source, afterLayer.source) || !isEqual(beforeLayer['source-layer'], afterLayer['source-layer']) || !isEqual(beforeLayer.type, afterLayer.type)) {\n commands.push({ command: operations.removeLayer, args: [layerId] });\n // we add the layer back at the same position it was already in, so\n // there's no need to update the `tracker`\n insertBeforeLayerId = tracker[tracker.lastIndexOf(layerId) + 1];\n commands.push({ command: operations.addLayer, args: [afterLayer, insertBeforeLayerId] });\n continue;\n }\n\n // layout, paint, filter, minzoom, maxzoom\n diffLayerPropertyChanges(beforeLayer.layout, afterLayer.layout, commands, layerId, null, operations.setLayoutProperty);\n diffLayerPropertyChanges(beforeLayer.paint, afterLayer.paint, commands, layerId, null, operations.setPaintProperty);\n if (!isEqual(beforeLayer.filter, afterLayer.filter)) {\n commands.push({ command: operations.setFilter, args: [layerId, afterLayer.filter] });\n }\n if (!isEqual(beforeLayer.minzoom, afterLayer.minzoom) || !isEqual(beforeLayer.maxzoom, afterLayer.maxzoom)) {\n commands.push({ command: operations.setLayerZoomRange, args: [layerId, afterLayer.minzoom, afterLayer.maxzoom] });\n }\n\n // handle all other layer props, including paint.*\n for (prop in beforeLayer) {\n if (!beforeLayer.hasOwnProperty(prop)) continue;\n if (prop === 'layout' || prop === 'paint' || prop === 'filter' ||\n prop === 'metadata' || prop === 'minzoom' || prop === 'maxzoom') continue;\n if (prop.indexOf('paint.') === 0) {\n diffLayerPropertyChanges(beforeLayer[prop], afterLayer[prop], commands, layerId, prop.slice(6), operations.setPaintProperty);\n } else if (!isEqual(beforeLayer[prop], afterLayer[prop])) {\n commands.push({ command: operations.setLayerProperty, args: [layerId, prop, afterLayer[prop]] });\n }\n }\n for (prop in afterLayer) {\n if (!afterLayer.hasOwnProperty(prop) || beforeLayer.hasOwnProperty(prop)) continue;\n if (prop === 'layout' || prop === 'paint' || prop === 'filter' ||\n prop === 'metadata' || prop === 'minzoom' || prop === 'maxzoom') continue;\n if (prop.indexOf('paint.') === 0) {\n diffLayerPropertyChanges(beforeLayer[prop], afterLayer[prop], commands, layerId, prop.slice(6), operations.setPaintProperty);\n } else if (!isEqual(beforeLayer[prop], afterLayer[prop])) {\n commands.push({ command: operations.setLayerProperty, args: [layerId, prop, afterLayer[prop]] });\n }\n }\n }\n}\n\n/**\n * Diff two stylesheet\n *\n * Creates semanticly aware diffs that can easily be applied at runtime.\n * Operations produced by the diff closely resemble the mapbox-gl-js API. Any\n * error creating the diff will fall back to the 'setStyle' operation.\n *\n * Example diff:\n * [\n * { command: 'setConstant', args: ['@water', '#0000FF'] },\n * { command: 'setPaintProperty', args: ['background', 'background-color', 'black'] }\n * ]\n *\n * @private\n * @param {*} [before] stylesheet to compare from\n * @param {*} after stylesheet to compare to\n * @returns Array list of changes\n */\nfunction diffStyles(before, after) {\n if (!before) return [{ command: operations.setStyle, args: [after] }];\n\n let commands = [];\n\n try {\n // Handle changes to top-level properties\n if (!isEqual(before.version, after.version)) {\n return [{ command: operations.setStyle, args: [after] }];\n }\n if (!isEqual(before.center, after.center)) {\n commands.push({ command: operations.setCenter, args: [after.center] });\n }\n if (!isEqual(before.zoom, after.zoom)) {\n commands.push({ command: operations.setZoom, args: [after.zoom] });\n }\n if (!isEqual(before.bearing, after.bearing)) {\n commands.push({ command: operations.setBearing, args: [after.bearing] });\n }\n if (!isEqual(before.pitch, after.pitch)) {\n commands.push({ command: operations.setPitch, args: [after.pitch] });\n }\n if (!isEqual(before.sprite, after.sprite)) {\n commands.push({ command: operations.setSprite, args: [after.sprite] });\n }\n if (!isEqual(before.glyphs, after.glyphs)) {\n commands.push({ command: operations.setGlyphs, args: [after.glyphs] });\n }\n if (!isEqual(before.transition, after.transition)) {\n commands.push({ command: operations.setTransition, args: [after.transition] });\n }\n if (!isEqual(before.light, after.light)) {\n commands.push({ command: operations.setLight, args: [after.light] });\n }\n\n // Handle changes to `sources`\n // If a source is to be removed, we also--before the removeSource\n // command--need to remove all the style layers that depend on it.\n const sourcesRemoved = {};\n\n // First collect the {add,remove}Source commands\n const removeOrAddSourceCommands = [];\n diffSources(before.sources, after.sources, removeOrAddSourceCommands, sourcesRemoved);\n\n // Push a removeLayer command for each style layer that depends on a\n // source that's being removed.\n // Also, exclude any such layers them from the input to `diffLayers`\n // below, so that diffLayers produces the appropriate `addLayers`\n // command\n const beforeLayers = [];\n if (before.layers) {\n before.layers.forEach((layer) => {\n if (sourcesRemoved[layer.source]) {\n commands.push({ command: operations.removeLayer, args: [layer.id] });\n } else {\n beforeLayers.push(layer);\n }\n });\n }\n commands = commands.concat(removeOrAddSourceCommands);\n\n // Handle changes to `layers`\n diffLayers(beforeLayers, after.layers, commands);\n\n } catch (e) {\n // fall back to setStyle\n console.warn('Unable to compute style diff:', e);\n commands = [{ command: operations.setStyle, args: [after] }];\n }\n\n return commands;\n}\n\nexport default diffStyles;\nexport { operations };\n","\nexport default class ValidationError {\n constructor(key, value, message, identifier) {\n this.message = (key ? `${key}: ` : '') + message;\n if (identifier) this.identifier = identifier;\n\n if (value !== null && value !== undefined && value.__line__) {\n this.line = value.__line__;\n }\n }\n}\n","\nfunction ParsingError(error) {\n this.error = error;\n this.message = error.message;\n const match = error.message.match(/line (\\d+)/);\n this.line = match ? parseInt(match[1], 10) : 0;\n}\n\nexport default ParsingError;\n","\nimport ValidationError from '../error/validation_error';\n\nexport default function validateConstants(options) {\n const key = options.key;\n const constants = options.value;\n\n if (constants) {\n return [new ValidationError(key, constants, 'constants have been deprecated as of v8')];\n } else {\n return [];\n }\n}\n","\n// Turn jsonlint-lines-primitives objects into primitive objects\nexport function unbundle(value) {\n if (value instanceof Number || value instanceof String || value instanceof Boolean) {\n return value.valueOf();\n } else {\n return value;\n }\n}\n\nexport function deepUnbundle(value) {\n if (Array.isArray(value)) {\n return value.map(deepUnbundle);\n }\n return unbundle(value);\n}\n\n","\nimport ValidationError from '../error/validation_error';\nimport getType from '../util/get_type';\nimport validateSpec from './validate';\n\nexport default function validateObject(options) {\n const key = options.key;\n const object = options.value;\n const elementSpecs = options.valueSpec || {};\n const elementValidators = options.objectElementValidators || {};\n const style = options.style;\n const styleSpec = options.styleSpec;\n let errors = [];\n\n const type = getType(object);\n if (type !== 'object') {\n return [new ValidationError(key, object, `object expected, ${type} found`)];\n }\n\n for (const objectKey in object) {\n const elementSpecKey = objectKey.split('.')[0]; // treat 'paint.*' as 'paint'\n const elementSpec = elementSpecs[elementSpecKey] || elementSpecs['*'];\n\n let validateElement;\n if (elementValidators[elementSpecKey]) {\n validateElement = elementValidators[elementSpecKey];\n } else if (elementSpecs[elementSpecKey]) {\n validateElement = validateSpec;\n } else if (elementValidators['*']) {\n validateElement = elementValidators['*'];\n } else if (elementSpecs['*']) {\n validateElement = validateSpec;\n } else {\n errors.push(new ValidationError(key, object[objectKey], `unknown property \"${objectKey}\"`));\n continue;\n }\n\n errors = errors.concat(validateElement({\n key: (key ? `${key}.` : key) + objectKey,\n value: object[objectKey],\n valueSpec: elementSpec,\n style,\n styleSpec,\n object,\n objectKey\n }, object));\n }\n\n for (const elementSpecKey in elementSpecs) {\n // Don't check `required` when there's a custom validator for that property.\n if (elementValidators[elementSpecKey]) {\n continue;\n }\n\n if (elementSpecs[elementSpecKey].required && elementSpecs[elementSpecKey]['default'] === undefined && object[elementSpecKey] === undefined) {\n errors.push(new ValidationError(key, object, `missing required property \"${elementSpecKey}\"`));\n }\n }\n\n return errors;\n}\n","\nimport getType from '../util/get_type';\nimport validate from './validate';\nimport ValidationError from '../error/validation_error';\n\nexport default function validateArray(options) {\n const array = options.value;\n const arraySpec = options.valueSpec;\n const style = options.style;\n const styleSpec = options.styleSpec;\n const key = options.key;\n const validateArrayElement = options.arrayElementValidator || validate;\n\n if (getType(array) !== 'array') {\n return [new ValidationError(key, array, `array expected, ${getType(array)} found`)];\n }\n\n if (arraySpec.length && array.length !== arraySpec.length) {\n return [new ValidationError(key, array, `array length ${arraySpec.length} expected, length ${array.length} found`)];\n }\n\n if (arraySpec['min-length'] && array.length < arraySpec['min-length']) {\n return [new ValidationError(key, array, `array length at least ${arraySpec['min-length']} expected, length ${array.length} found`)];\n }\n\n let arrayElementSpec = {\n \"type\": arraySpec.value\n };\n\n if (styleSpec.$version < 7) {\n arrayElementSpec.function = arraySpec.function;\n }\n\n if (getType(arraySpec.value) === 'object') {\n arrayElementSpec = arraySpec.value;\n }\n\n let errors = [];\n for (let i = 0; i < array.length; i++) {\n errors = errors.concat(validateArrayElement({\n array,\n arrayIndex: i,\n value: array[i],\n valueSpec: arrayElementSpec,\n style,\n styleSpec,\n key: `${key}[${i}]`\n }));\n }\n return errors;\n}\n","\nimport getType from '../util/get_type';\nimport ValidationError from '../error/validation_error';\n\nexport default function validateNumber(options) {\n const key = options.key;\n const value = options.value;\n const valueSpec = options.valueSpec;\n const type = getType(value);\n\n if (type !== 'number') {\n return [new ValidationError(key, value, `number expected, ${type} found`)];\n }\n\n if ('minimum' in valueSpec && value < valueSpec.minimum) {\n return [new ValidationError(key, value, `${value} is less than the minimum value ${valueSpec.minimum}`)];\n }\n\n if ('maximum' in valueSpec && value > valueSpec.maximum) {\n return [new ValidationError(key, value, `${value} is greater than the maximum value ${valueSpec.maximum}`)];\n }\n\n return [];\n}\n","\nimport ValidationError from '../error/validation_error';\nimport getType from '../util/get_type';\nimport validate from './validate';\nimport validateObject from './validate_object';\nimport validateArray from './validate_array';\nimport validateNumber from './validate_number';\nimport { isExpression } from '../expression';\nimport { unbundle, deepUnbundle } from '../util/unbundle_jsonlint';\nimport {\n supportsPropertyExpression,\n supportsZoomExpression,\n supportsInterpolation\n} from '../util/properties';\n\nexport default function validateFunction(options) {\n const functionValueSpec = options.valueSpec;\n const functionType = unbundle(options.value.type);\n let stopKeyType;\n let stopDomainValues = {};\n let previousStopDomainValue;\n let previousStopDomainZoom;\n\n const isZoomFunction = functionType !== 'categorical' && options.value.property === undefined;\n const isPropertyFunction = !isZoomFunction;\n const isZoomAndPropertyFunction =\n getType(options.value.stops) === 'array' &&\n getType(options.value.stops[0]) === 'array' &&\n getType(options.value.stops[0][0]) === 'object';\n\n const errors = validateObject({\n key: options.key,\n value: options.value,\n valueSpec: options.styleSpec.function,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n stops: validateFunctionStops,\n default: validateFunctionDefault\n }\n });\n\n if (functionType === 'identity' && isZoomFunction) {\n errors.push(new ValidationError(options.key, options.value, 'missing required property \"property\"'));\n }\n\n if (functionType !== 'identity' && !options.value.stops) {\n errors.push(new ValidationError(options.key, options.value, 'missing required property \"stops\"'));\n }\n\n if (functionType === 'exponential' && options.valueSpec.expression && !supportsInterpolation(options.valueSpec)) {\n errors.push(new ValidationError(options.key, options.value, 'exponential functions not supported'));\n }\n\n if (options.styleSpec.$version >= 8) {\n if (isPropertyFunction && !supportsPropertyExpression(options.valueSpec)) {\n errors.push(new ValidationError(options.key, options.value, 'property functions not supported'));\n } else if (isZoomFunction && !supportsZoomExpression(options.valueSpec)) {\n errors.push(new ValidationError(options.key, options.value, 'zoom functions not supported'));\n }\n }\n\n if ((functionType === 'categorical' || isZoomAndPropertyFunction) && options.value.property === undefined) {\n errors.push(new ValidationError(options.key, options.value, '\"property\" property is required'));\n }\n\n return errors;\n\n function validateFunctionStops(options) {\n if (functionType === 'identity') {\n return [new ValidationError(options.key, options.value, 'identity function may not have a \"stops\" property')];\n }\n\n let errors = [];\n const value = options.value;\n\n errors = errors.concat(validateArray({\n key: options.key,\n value,\n valueSpec: options.valueSpec,\n style: options.style,\n styleSpec: options.styleSpec,\n arrayElementValidator: validateFunctionStop\n }));\n\n if (getType(value) === 'array' && value.length === 0) {\n errors.push(new ValidationError(options.key, value, 'array must have at least one stop'));\n }\n\n return errors;\n }\n\n function validateFunctionStop(options) {\n let errors = [];\n const value = options.value;\n const key = options.key;\n\n if (getType(value) !== 'array') {\n return [new ValidationError(key, value, `array expected, ${getType(value)} found`)];\n }\n\n if (value.length !== 2) {\n return [new ValidationError(key, value, `array length 2 expected, length ${value.length} found`)];\n }\n\n if (isZoomAndPropertyFunction) {\n if (getType(value[0]) !== 'object') {\n return [new ValidationError(key, value, `object expected, ${getType(value[0])} found`)];\n }\n if (value[0].zoom === undefined) {\n return [new ValidationError(key, value, 'object stop key must have zoom')];\n }\n if (value[0].value === undefined) {\n return [new ValidationError(key, value, 'object stop key must have value')];\n }\n if (previousStopDomainZoom && previousStopDomainZoom > unbundle(value[0].zoom)) {\n return [new ValidationError(key, value[0].zoom, 'stop zoom values must appear in ascending order')];\n }\n if (unbundle(value[0].zoom) !== previousStopDomainZoom) {\n previousStopDomainZoom = unbundle(value[0].zoom);\n previousStopDomainValue = undefined;\n stopDomainValues = {};\n }\n errors = errors.concat(validateObject({\n key: `${key}[0]`,\n value: value[0],\n valueSpec: { zoom: {} },\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: { zoom: validateNumber, value: validateStopDomainValue }\n }));\n } else {\n errors = errors.concat(validateStopDomainValue({\n key: `${key}[0]`,\n value: value[0],\n valueSpec: {},\n style: options.style,\n styleSpec: options.styleSpec\n }, value));\n }\n\n if (isExpression(deepUnbundle(value[1]))) {\n return errors.concat([new ValidationError(`${key}[1]`, value[1], 'expressions are not allowed in function stops.')]);\n }\n\n return errors.concat(validate({\n key: `${key}[1]`,\n value: value[1],\n valueSpec: functionValueSpec,\n style: options.style,\n styleSpec: options.styleSpec\n }));\n }\n\n function validateStopDomainValue(options, stop) {\n const type = getType(options.value);\n const value = unbundle(options.value);\n\n const reportValue = options.value !== null ? options.value : stop;\n\n if (!stopKeyType) {\n stopKeyType = type;\n } else if (type !== stopKeyType) {\n return [new ValidationError(options.key, reportValue, `${type} stop domain type must match previous stop domain type ${stopKeyType}`)];\n }\n\n if (type !== 'number' && type !== 'string' && type !== 'boolean') {\n return [new ValidationError(options.key, reportValue, 'stop domain value must be a number, string, or boolean')];\n }\n\n if (type !== 'number' && functionType !== 'categorical') {\n let message = `number expected, ${type} found`;\n if (supportsPropertyExpression(functionValueSpec) && functionType === undefined) {\n message += '\\nIf you intended to use a categorical function, specify `\"type\": \"categorical\"`.';\n }\n return [new ValidationError(options.key, reportValue, message)];\n }\n\n if (functionType === 'categorical' && type === 'number' && (!isFinite(value) || Math.floor(value) !== value)) {\n return [new ValidationError(options.key, reportValue, `integer expected, found ${value}`)];\n }\n\n if (functionType !== 'categorical' && type === 'number' && previousStopDomainValue !== undefined && value < previousStopDomainValue) {\n return [new ValidationError(options.key, reportValue, 'stop domain values must appear in ascending order')];\n } else {\n previousStopDomainValue = value;\n }\n\n if (functionType === 'categorical' && value in stopDomainValues) {\n return [new ValidationError(options.key, reportValue, 'stop domain values must be unique')];\n } else {\n stopDomainValues[value] = true;\n }\n\n return [];\n }\n\n function validateFunctionDefault(options) {\n return validate({\n key: options.key,\n value: options.value,\n valueSpec: functionValueSpec,\n style: options.style,\n styleSpec: options.styleSpec\n });\n }\n}\n","// @flow\n\nimport ValidationError from '../error/validation_error';\n\nimport { createExpression, createPropertyExpression } from '../expression';\nimport { deepUnbundle } from '../util/unbundle_jsonlint';\nimport { isStateConstant } from '../expression/is_constant';\n\nexport default function validateExpression(options: any): Array<ValidationError> {\n const expression = (options.expressionContext === 'property' ? createPropertyExpression : createExpression)(deepUnbundle(options.value), options.valueSpec);\n if (expression.result === 'error') {\n return expression.value.map((error) => {\n return new ValidationError(`${options.key}${error.key}`, options.value, error.message);\n });\n }\n\n if (options.expressionContext === 'property' && (options.propertyKey === 'text-font') &&\n (expression.value: any)._styleExpression.expression.possibleOutputs().indexOf(undefined) !== -1) {\n return [new ValidationError(options.key, options.value, `Invalid data expression for \"${options.propertyKey}\". Output values must be contained as literals within the expression.`)];\n }\n\n if (options.expressionContext === 'property' && options.propertyType === 'layout' &&\n (!isStateConstant((expression.value: any)._styleExpression.expression))) {\n return [new ValidationError(options.key, options.value, '\"feature-state\" data expressions are not supported with layout properties.')];\n }\n\n if (options.expressionContext === 'filter' && !isStateConstant((expression.value: any).expression)) {\n return [new ValidationError(options.key, options.value, '\"feature-state\" data expressions are not supported with filters.')];\n }\n\n return [];\n}\n","\nimport ValidationError from '../error/validation_error';\nimport { unbundle } from '../util/unbundle_jsonlint';\n\nexport default function validateEnum(options) {\n const key = options.key;\n const value = options.value;\n const valueSpec = options.valueSpec;\n const errors = [];\n\n if (Array.isArray(valueSpec.values)) { // <=v7\n if (valueSpec.values.indexOf(unbundle(value)) === -1) {\n errors.push(new ValidationError(key, value, `expected one of [${valueSpec.values.join(', ')}], ${JSON.stringify(value)} found`));\n }\n } else { // >=v8\n if (Object.keys(valueSpec.values).indexOf(unbundle(value)) === -1) {\n errors.push(new ValidationError(key, value, `expected one of [${Object.keys(valueSpec.values).join(', ')}], ${JSON.stringify(value)} found`));\n }\n }\n return errors;\n}\n","\nimport ValidationError from '../error/validation_error';\nimport validateExpression from './validate_expression';\nimport validateEnum from './validate_enum';\nimport getType from '../util/get_type';\nimport { unbundle, deepUnbundle } from '../util/unbundle_jsonlint';\nimport extend from '../util/extend';\nimport { isExpressionFilter } from '../feature_filter';\n\nexport default function validateFilter(options) {\n if (isExpressionFilter(deepUnbundle(options.value))) {\n return validateExpression(extend({}, options, {\n expressionContext: 'filter',\n valueSpec: { value: 'boolean' }\n }));\n } else {\n return validateNonExpressionFilter(options);\n }\n}\n\nfunction validateNonExpressionFilter(options) {\n const value = options.value;\n const key = options.key;\n\n if (getType(value) !== 'array') {\n return [new ValidationError(key, value, `array expected, ${getType(value)} found`)];\n }\n\n const styleSpec = options.styleSpec;\n let type;\n\n let errors = [];\n\n if (value.length < 1) {\n return [new ValidationError(key, value, 'filter array must have at least 1 element')];\n }\n\n errors = errors.concat(validateEnum({\n key: `${key}[0]`,\n value: value[0],\n valueSpec: styleSpec.filter_operator,\n style: options.style,\n styleSpec: options.styleSpec\n }));\n\n switch (unbundle(value[0])) {\n case '<':\n case '<=':\n case '>':\n case '>=':\n if (value.length >= 2 && unbundle(value[1]) === '$type') {\n errors.push(new ValidationError(key, value, `\"$type\" cannot be use with operator \"${value[0]}\"`));\n }\n /* falls through */\n case '==':\n case '!=':\n if (value.length !== 3) {\n errors.push(new ValidationError(key, value, `filter array for operator \"${value[0]}\" must have 3 elements`));\n }\n /* falls through */\n case 'in':\n case '!in':\n if (value.length >= 2) {\n type = getType(value[1]);\n if (type !== 'string') {\n errors.push(new ValidationError(`${key}[1]`, value[1], `string expected, ${type} found`));\n }\n }\n for (let i = 2; i < value.length; i++) {\n type = getType(value[i]);\n if (unbundle(value[1]) === '$type') {\n errors = errors.concat(validateEnum({\n key: `${key}[${i}]`,\n value: value[i],\n valueSpec: styleSpec.geometry_type,\n style: options.style,\n styleSpec: options.styleSpec\n }));\n } else if (type !== 'string' && type !== 'number' && type !== 'boolean') {\n errors.push(new ValidationError(`${key}[${i}]`, value[i], `string, number, or boolean expected, ${type} found`));\n }\n }\n break;\n\n case 'any':\n case 'all':\n case 'none':\n for (let i = 1; i < value.length; i++) {\n errors = errors.concat(validateNonExpressionFilter({\n key: `${key}[${i}]`,\n value: value[i],\n style: options.style,\n styleSpec: options.styleSpec\n }));\n }\n break;\n\n case 'has':\n case '!has':\n type = getType(value[1]);\n if (value.length !== 2) {\n errors.push(new ValidationError(key, value, `filter array for \"${value[0]}\" operator must have 2 elements`));\n } else if (type !== 'string') {\n errors.push(new ValidationError(`${key}[1]`, value[1], `string expected, ${type} found`));\n }\n break;\n\n }\n\n return errors;\n}\n","\nimport validate from './validate';\nimport ValidationError from '../error/validation_error';\nimport getType from '../util/get_type';\nimport { isFunction } from '../function';\nimport { unbundle, deepUnbundle } from '../util/unbundle_jsonlint';\nimport { supportsPropertyExpression } from '../util/properties';\n\nexport default function validateProperty(options, propertyType) {\n const key = options.key;\n const style = options.style;\n const styleSpec = options.styleSpec;\n const value = options.value;\n const propertyKey = options.objectKey;\n const layerSpec = styleSpec[`${propertyType}_${options.layerType}`];\n\n if (!layerSpec) return [];\n\n const transitionMatch = propertyKey.match(/^(.*)-transition$/);\n if (propertyType === 'paint' && transitionMatch && layerSpec[transitionMatch[1]] && layerSpec[transitionMatch[1]].transition) {\n return validate({\n key,\n value,\n valueSpec: styleSpec.transition,\n style,\n styleSpec\n });\n }\n\n const valueSpec = options.valueSpec || layerSpec[propertyKey];\n if (!valueSpec) {\n return [new ValidationError(key, value, `unknown property \"${propertyKey}\"`)];\n }\n\n let tokenMatch;\n if (getType(value) === 'string' && supportsPropertyExpression(valueSpec) && !valueSpec.tokens && (tokenMatch = /^{([^}]+)}$/.exec(value))) {\n return [new ValidationError(\n key, value,\n `\"${propertyKey}\" does not support interpolation syntax\\n` +\n `Use an identity property function instead: \\`{ \"type\": \"identity\", \"property\": ${JSON.stringify(tokenMatch[1])} }\\`.`)];\n }\n\n const errors = [];\n\n if (options.layerType === 'symbol') {\n if (propertyKey === 'text-field' && style && !style.glyphs) {\n errors.push(new ValidationError(key, value, 'use of \"text-field\" requires a style \"glyphs\" property'));\n }\n if (propertyKey === 'text-font' && isFunction(deepUnbundle(value)) && unbundle(value.type) === 'identity') {\n errors.push(new ValidationError(key, value, '\"text-font\" does not support identity functions'));\n }\n }\n\n return errors.concat(validate({\n key: options.key,\n value,\n valueSpec,\n style,\n styleSpec,\n expressionContext: 'property',\n propertyType,\n propertyKey\n }));\n}\n","\nimport validateProperty from './validate_property';\n\nexport default function validatePaintProperty(options) {\n return validateProperty(options, 'paint');\n}\n","\nimport validateProperty from './validate_property';\n\nexport default function validateLayoutProperty(options) {\n return validateProperty(options, 'layout');\n}\n","\nimport ValidationError from '../error/validation_error';\nimport { unbundle } from '../util/unbundle_jsonlint';\nimport validateObject from './validate_object';\nimport validateFilter from './validate_filter';\nimport validatePaintProperty from './validate_paint_property';\nimport validateLayoutProperty from './validate_layout_property';\nimport validateSpec from './validate';\nimport extend from '../util/extend';\n\nexport default function validateLayer(options) {\n let errors = [];\n\n const layer = options.value;\n const key = options.key;\n const style = options.style;\n const styleSpec = options.styleSpec;\n\n if (!layer.type && !layer.ref) {\n errors.push(new ValidationError(key, layer, 'either \"type\" or \"ref\" is required'));\n }\n let type = unbundle(layer.type);\n const ref = unbundle(layer.ref);\n\n if (layer.id) {\n const layerId = unbundle(layer.id);\n for (let i = 0; i < options.arrayIndex; i++) {\n const otherLayer = style.layers[i];\n if (unbundle(otherLayer.id) === layerId) {\n errors.push(new ValidationError(key, layer.id, `duplicate layer id \"${layer.id}\", previously used at line ${otherLayer.id.__line__}`));\n }\n }\n }\n\n if ('ref' in layer) {\n ['type', 'source', 'source-layer', 'filter', 'layout'].forEach((p) => {\n if (p in layer) {\n errors.push(new ValidationError(key, layer[p], `\"${p}\" is prohibited for ref layers`));\n }\n });\n\n let parent;\n\n style.layers.forEach((layer) => {\n if (unbundle(layer.id) === ref) parent = layer;\n });\n\n if (!parent) {\n errors.push(new ValidationError(key, layer.ref, `ref layer \"${ref}\" not found`));\n } else if (parent.ref) {\n errors.push(new ValidationError(key, layer.ref, 'ref cannot reference another ref layer'));\n } else {\n type = unbundle(parent.type);\n }\n } else if (type !== 'background') {\n if (!layer.source) {\n errors.push(new ValidationError(key, layer, 'missing required property \"source\"'));\n } else {\n const source = style.sources && style.sources[layer.source];\n const sourceType = source && unbundle(source.type);\n if (!source) {\n errors.push(new ValidationError(key, layer.source, `source \"${layer.source}\" not found`));\n } else if (sourceType === 'vector' && type === 'raster') {\n errors.push(new ValidationError(key, layer.source, `layer \"${layer.id}\" requires a raster source`));\n } else if (sourceType === 'raster' && type !== 'raster') {\n errors.push(new ValidationError(key, layer.source, `layer \"${layer.id}\" requires a vector source`));\n } else if (sourceType === 'vector' && !layer['source-layer']) {\n errors.push(new ValidationError(key, layer, `layer \"${layer.id}\" must specify a \"source-layer\"`));\n } else if (sourceType === 'raster-dem' && type !== 'hillshade') {\n errors.push(new ValidationError(key, layer.source, 'raster-dem source can only be used with layer type \\'hillshade\\'.'));\n } else if (type === 'line' && layer.paint && layer.paint['line-gradient'] &&\n (sourceType !== 'geojson' || !source.lineMetrics)) {\n errors.push(new ValidationError(key, layer, `layer \"${layer.id}\" specifies a line-gradient, which requires a GeoJSON source with \\`lineMetrics\\` enabled.`));\n }\n }\n }\n\n errors = errors.concat(validateObject({\n key,\n value: layer,\n valueSpec: styleSpec.layer,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n '*'() {\n return [];\n },\n // We don't want to enforce the spec's `\"requires\": true` for backward compatibility with refs;\n // the actual requirement is validated above. See https://github.com/mapbox/mapbox-gl-js/issues/5772.\n type() {\n return validateSpec({\n key: `${key}.type`,\n value: layer.type,\n valueSpec: styleSpec.layer.type,\n style: options.style,\n styleSpec: options.styleSpec,\n object: layer,\n objectKey: 'type'\n });\n },\n filter: validateFilter,\n layout(options) {\n return validateObject({\n layer,\n key: options.key,\n value: options.value,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n '*'(options) {\n return validateLayoutProperty(extend({layerType: type}, options));\n }\n }\n });\n },\n paint(options) {\n return validateObject({\n layer,\n key: options.key,\n value: options.value,\n style: options.style,\n styleSpec: options.styleSpec,\n objectElementValidators: {\n '*'(options) {\n return validatePaintProperty(extend({layerType: type}, options));\n }\n }\n });\n }\n }\n }));\n\n return errors;\n}\n","\nimport ValidationError from '../error/validation_error';\nimport { unbundle } from '../util/unbundle_jsonlint';\nimport validateObject from './validate_object';\nimport validateEnum from './validate_enum';\n\nexport default function validateSource(options) {\n const value = options.value;\n const key = options.key;\n const styleSpec = options.styleSpec;\n const style = options.style;\n\n if (!value.type) {\n return [new ValidationError(key, value, '\"type\" is required')];\n }\n\n const type = unbundle(value.type);\n let errors = [];\n\n switch (type) {\n case 'vector':\n case 'raster':\n case 'raster-dem':\n errors = errors.concat(validateObject({\n key,\n value,\n valueSpec: styleSpec[`source_${type.replace('-', '_')}`],\n style: options.style,\n styleSpec\n }));\n if ('url' in value) {\n for (const prop in value) {\n if (['type', 'url', 'tileSize'].indexOf(prop) < 0) {\n errors.push(new ValidationError(`${key}.${prop}`, value[prop], `a source with a \"url\" property may not include a \"${prop}\" property`));\n }\n }\n }\n return errors;\n\n case 'geojson':\n return validateObject({\n key,\n value,\n valueSpec: styleSpec.source_geojson,\n style,\n styleSpec\n });\n\n case 'video':\n return validateObject({\n key,\n value,\n valueSpec: styleSpec.source_video,\n style,\n styleSpec\n });\n\n case 'image':\n return validateObject({\n key,\n value,\n valueSpec: styleSpec.source_image,\n style,\n styleSpec\n });\n\n case 'canvas':\n errors.push(new ValidationError(key, null, `Please use runtime APIs to add canvas sources, rather than including them in stylesheets.`, 'source.canvas'));\n return errors;\n\n default:\n return validateEnum({\n key: `${key}.type`,\n value: value.type,\n valueSpec: {values: ['vector', 'raster', 'raster-dem', 'geojson', 'video', 'image']},\n style,\n styleSpec\n });\n }\n}\n","\nimport ValidationError from '../error/validation_error';\nimport getType from '../util/get_type';\nimport validate from './validate';\n\nexport default function validateLight(options) {\n const light = options.value;\n const styleSpec = options.styleSpec;\n const lightSpec = styleSpec.light;\n const style = options.style;\n\n let errors = [];\n\n const rootType = getType(light);\n if (light === undefined) {\n return errors;\n } else if (rootType !== 'object') {\n errors = errors.concat([new ValidationError('light', light, `object expected, ${rootType} found`)]);\n return errors;\n }\n\n for (const key in light) {\n const transitionMatch = key.match(/^(.*)-transition$/);\n\n if (transitionMatch && lightSpec[transitionMatch[1]] && lightSpec[transitionMatch[1]].transition) {\n errors = errors.concat(validate({\n key,\n value: light[key],\n valueSpec: styleSpec.transition,\n style,\n styleSpec\n }));\n } else if (lightSpec[key]) {\n errors = errors.concat(validate({\n key,\n value: light[key],\n valueSpec: lightSpec[key],\n style,\n styleSpec\n }));\n } else {\n errors = errors.concat([new ValidationError(key, light[key], `unknown property \"${key}\"`)]);\n }\n }\n\n return errors;\n}\n","\nimport getType from '../util/get_type';\nimport ValidationError from '../error/validation_error';\n\nexport default function validateString(options) {\n const value = options.value;\n const key = options.key;\n const type = getType(value);\n\n if (type !== 'string') {\n return [new ValidationError(key, value, `string expected, ${type} found`)];\n }\n\n return [];\n}\n","\nimport extend from '../util/extend';\nimport { unbundle, deepUnbundle } from '../util/unbundle_jsonlint';\nimport { isExpression } from '../expression';\nimport { isFunction } from '../function';\n\nimport validateFunction from './validate_function';\nimport validateExpression from './validate_expression';\nimport validateObject from './validate_object';\nimport validateArray from './validate_array';\nimport validateBoolean from './validate_boolean';\nimport validateNumber from './validate_number';\nimport validateColor from './validate_color';\nimport validateConstants from './validate_constants';\nimport validateEnum from './validate_enum';\nimport validateFilter from './validate_filter';\nimport validateLayer from './validate_layer';\nimport validateSource from './validate_source';\nimport validateLight from './validate_light';\nimport validateString from './validate_string';\nimport validateFormatted from './validate_formatted';\n\nconst VALIDATORS = {\n '*'() {\n return [];\n },\n 'array': validateArray,\n 'boolean': validateBoolean,\n 'number': validateNumber,\n 'color': validateColor,\n 'constants': validateConstants,\n 'enum': validateEnum,\n 'filter': validateFilter,\n 'function': validateFunction,\n 'layer': validateLayer,\n 'object': validateObject,\n 'source': validateSource,\n 'light': validateLight,\n 'string': validateString,\n 'formatted': validateFormatted\n};\n\n\n// Main recursive validation function. Tracks:\n//\n// - key: string representing location of validation in style tree. Used only\n// for more informative error reporting.\n// - value: current value from style being evaluated. May be anything from a\n// high level object that needs to be descended into deeper or a simple\n// scalar value.\n// - valueSpec: current spec being evaluated. Tracks value.\n// - styleSpec: current full spec being evaluated.\n\nexport default function validate(options) {\n const value = options.value;\n const valueSpec = options.valueSpec;\n const styleSpec = options.styleSpec;\n\n if (valueSpec.expression && isFunction(unbundle(value))) {\n return validateFunction(options);\n\n } else if (valueSpec.expression && isExpression(deepUnbundle(value))) {\n return validateExpression(options);\n\n } else if (valueSpec.type && VALIDATORS[valueSpec.type]) {\n return VALIDATORS[valueSpec.type](options);\n\n } else {\n const valid = validateObject(extend({}, options, {\n valueSpec: valueSpec.type ? styleSpec[valueSpec.type] : valueSpec\n }));\n return valid;\n }\n}\n","\nimport getType from '../util/get_type';\nimport ValidationError from '../error/validation_error';\n\nexport default function validateBoolean(options) {\n const value = options.value;\n const key = options.key;\n const type = getType(value);\n\n if (type !== 'boolean') {\n return [new ValidationError(key, value, `boolean expected, ${type} found`)];\n }\n\n return [];\n}\n","\nimport ValidationError from '../error/validation_error';\nimport getType from '../util/get_type';\nimport { parseCSSColor } from 'csscolorparser';\n\nexport default function validateColor(options) {\n const key = options.key;\n const value = options.value;\n const type = getType(value);\n\n if (type !== 'string') {\n return [new ValidationError(key, value, `color expected, ${type} found`)];\n }\n\n if (parseCSSColor(value) === null) {\n return [new ValidationError(key, value, `color expected, \"${value}\" found`)];\n }\n\n return [];\n}\n","// @flow\nimport validateExpression from './validate_expression';\nimport validateString from './validate_string';\n\nexport default function validateFormatted(options: any) {\n if (validateString(options).length === 0) {\n return [];\n }\n\n return validateExpression(options);\n}\n","\nimport ValidationError from '../error/validation_error';\nimport validateString from './validate_string';\n\nexport default function(options) {\n const value = options.value;\n const key = options.key;\n\n const errors = validateString(options);\n if (errors.length) return errors;\n\n if (value.indexOf('{fontstack}') === -1) {\n errors.push(new ValidationError(key, value, '\"glyphs\" url must include a \"{fontstack}\" token'));\n }\n\n if (value.indexOf('{range}') === -1) {\n errors.push(new ValidationError(key, value, '\"glyphs\" url must include a \"{range}\" token'));\n }\n\n return errors;\n}\n","\nimport validateConstants from './validate/validate_constants';\nimport validate from './validate/validate';\nimport latestStyleSpec from './reference/latest';\nimport validateGlyphsURL from './validate/validate_glyphs_url';\n\nimport validateSource from './validate/validate_source';\nimport validateLight from './validate/validate_light';\nimport validateLayer from './validate/validate_layer';\nimport validateFilter from './validate/validate_filter';\nimport validatePaintProperty from './validate/validate_paint_property';\nimport validateLayoutProperty from './validate/validate_layout_property';\n\n/**\n * Validate a Mapbox GL style against the style specification. This entrypoint,\n * `mapbox-gl-style-spec/lib/validate_style.min`, is designed to produce as\n * small a browserify bundle as possible by omitting unnecessary functionality\n * and legacy style specifications.\n *\n * @private\n * @param {Object} style The style to be validated.\n * @param {Object} [styleSpec] The style specification to validate against.\n * If omitted, the latest style spec is used.\n * @returns {Array<ValidationError>}\n * @example\n * var validate = require('mapbox-gl-style-spec/lib/validate_style.min');\n * var errors = validate(style);\n */\nfunction validateStyleMin(style, styleSpec) {\n styleSpec = styleSpec || latestStyleSpec;\n\n let errors = [];\n\n errors = errors.concat(validate({\n key: '',\n value: style,\n valueSpec: styleSpec.$root,\n styleSpec,\n style,\n objectElementValidators: {\n glyphs: validateGlyphsURL,\n '*'() {\n return [];\n }\n }\n }));\n\n if (style.constants) {\n errors = errors.concat(validateConstants({\n key: 'constants',\n value: style.constants,\n style,\n styleSpec\n }));\n }\n\n return sortErrors(errors);\n}\n\nvalidateStyleMin.source = wrapCleanErrors(validateSource);\nvalidateStyleMin.light = wrapCleanErrors(validateLight);\nvalidateStyleMin.layer = wrapCleanErrors(validateLayer);\nvalidateStyleMin.filter = wrapCleanErrors(validateFilter);\nvalidateStyleMin.paintProperty = wrapCleanErrors(validatePaintProperty);\nvalidateStyleMin.layoutProperty = wrapCleanErrors(validateLayoutProperty);\n\nfunction sortErrors(errors) {\n return [].concat(errors).sort((a, b) => {\n return a.line - b.line;\n });\n}\n\nfunction wrapCleanErrors(inner) {\n return function(...args) {\n return sortErrors(inner.apply(this, args));\n };\n}\n\nexport default validateStyleMin;\n","/* parser generated by jison 0.4.15 */\n/*\n Returns a Parser object of the following structure:\n\n Parser: {\n yy: {}\n }\n\n Parser.prototype: {\n yy: {},\n trace: function(),\n symbols_: {associative list: name ==> number},\n terminals_: {associative list: number ==> name},\n productions_: [...],\n performAction: function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$),\n table: [...],\n defaultActions: {...},\n parseError: function(str, hash),\n parse: function(input),\n\n lexer: {\n EOF: 1,\n parseError: function(str, hash),\n setInput: function(input),\n input: function(),\n unput: function(str),\n more: function(),\n less: function(n),\n pastInput: function(),\n upcomingInput: function(),\n showPosition: function(),\n test_match: function(regex_match_array, rule_index),\n next: function(),\n lex: function(),\n begin: function(condition),\n popState: function(),\n _currentRules: function(),\n topState: function(),\n pushState: function(condition),\n\n options: {\n ranges: boolean (optional: true ==> token location info will include a .range[] member)\n flex: boolean (optional: true ==> flex-like lexing behaviour where the rules are tested exhaustively to find the longest match)\n backtrack_lexer: boolean (optional: true ==> lexer regexes are tested in order and for each matching regex the action code is invoked; the lexer terminates the scan when a token is returned by the action code)\n },\n\n performAction: function(yy, yy_, $avoiding_name_collisions, YY_START),\n rules: [...],\n conditions: {associative list: name ==> set},\n }\n }\n\n\n token location info (@$, _$, etc.): {\n first_line: n,\n last_line: n,\n first_column: n,\n last_column: n,\n range: [start_number, end_number] (where the numbers are indexes into the input string, regular zero-based)\n }\n\n\n the parseError function receives a 'hash' object with these members for lexer and parser errors: {\n text: (matched text)\n token: (the produced terminal token, if any)\n line: (yylineno)\n }\n while parser (grammar) errors will also provide these members, i.e. parser errors deliver a superset of attributes: {\n loc: (yylloc)\n expected: (string describing the set of expected tokens)\n recoverable: (boolean: TRUE when the parser has a error recovery rule available for this particular error)\n }\n*/\nvar parser = (function(){\nvar o=function(k,v,o,l){for(o=o||{},l=k.length;l--;o[k[l]]=v);return o},$V0=[1,12],$V1=[1,13],$V2=[1,9],$V3=[1,10],$V4=[1,11],$V5=[1,14],$V6=[1,15],$V7=[14,18,22,24],$V8=[18,22],$V9=[22,24];\nvar parser = {trace: function trace() { },\nyy: {},\nsymbols_: {\"error\":2,\"JSONString\":3,\"STRING\":4,\"JSONNumber\":5,\"NUMBER\":6,\"JSONNullLiteral\":7,\"NULL\":8,\"JSONBooleanLiteral\":9,\"TRUE\":10,\"FALSE\":11,\"JSONText\":12,\"JSONValue\":13,\"EOF\":14,\"JSONObject\":15,\"JSONArray\":16,\"{\":17,\"}\":18,\"JSONMemberList\":19,\"JSONMember\":20,\":\":21,\",\":22,\"[\":23,\"]\":24,\"JSONElementList\":25,\"$accept\":0,\"$end\":1},\nterminals_: {2:\"error\",4:\"STRING\",6:\"NUMBER\",8:\"NULL\",10:\"TRUE\",11:\"FALSE\",14:\"EOF\",17:\"{\",18:\"}\",21:\":\",22:\",\",23:\"[\",24:\"]\"},\nproductions_: [0,[3,1],[5,1],[7,1],[9,1],[9,1],[12,2],[13,1],[13,1],[13,1],[13,1],[13,1],[13,1],[15,2],[15,3],[20,3],[19,1],[19,3],[16,2],[16,3],[25,1],[25,3]],\nperformAction: function anonymous(yytext, yyleng, yylineno, yy, yystate /* action[1] */, $$ /* vstack */, _$ /* lstack */) {\n/* this == yyval */\n\nvar $0 = $$.length - 1;\nswitch (yystate) {\ncase 1:\n // replace escaped characters with actual character\n this.$ = new String(yytext.replace(/\\\\(\\\\|\")/g, \"$\"+\"1\")\n .replace(/\\\\n/g,'\\n')\n .replace(/\\\\r/g,'\\r')\n .replace(/\\\\t/g,'\\t')\n .replace(/\\\\v/g,'\\v')\n .replace(/\\\\f/g,'\\f')\n .replace(/\\\\b/g,'\\b'));\n this.$.__line__ = this._$.first_line;\n \nbreak;\ncase 2:\n\n this.$ = new Number(yytext);\n this.$.__line__ = this._$.first_line;\n \nbreak;\ncase 3:\n\n this.$ = null;\n \nbreak;\ncase 4:\n\n this.$ = new Boolean(true);\n this.$.__line__ = this._$.first_line;\n \nbreak;\ncase 5:\n\n this.$ = new Boolean(false);\n this.$.__line__ = this._$.first_line;\n \nbreak;\ncase 6:\nreturn this.$ = $$[$0-1];\nbreak;\ncase 13:\nthis.$ = {}; Object.defineProperty(this.$, '__line__', {\n value: this._$.first_line,\n enumerable: false\n })\nbreak;\ncase 14: case 19:\nthis.$ = $$[$0-1]; Object.defineProperty(this.$, '__line__', {\n value: this._$.first_line,\n enumerable: false\n })\nbreak;\ncase 15:\nthis.$ = [$$[$0-2], $$[$0]];\nbreak;\ncase 16:\nthis.$ = {}; this.$[$$[$0][0]] = $$[$0][1];\nbreak;\ncase 17:\nthis.$ = $$[$0-2]; $$[$0-2][$$[$0][0]] = $$[$0][1];\nbreak;\ncase 18:\nthis.$ = []; Object.defineProperty(this.$, '__line__', {\n value: this._$.first_line,\n enumerable: false\n })\nbreak;\ncase 20:\nthis.$ = [$$[$0]];\nbreak;\ncase 21:\nthis.$ = $$[$0-2]; $$[$0-2].push($$[$0]);\nbreak;\n}\n},\ntable: [{3:5,4:$V0,5:6,6:$V1,7:3,8:$V2,9:4,10:$V3,11:$V4,12:1,13:2,15:7,16:8,17:$V5,23:$V6},{1:[3]},{14:[1,16]},o($V7,[2,7]),o($V7,[2,8]),o($V7,[2,9]),o($V7,[2,10]),o($V7,[2,11]),o($V7,[2,12]),o($V7,[2,3]),o($V7,[2,4]),o($V7,[2,5]),o([14,18,21,22,24],[2,1]),o($V7,[2,2]),{3:20,4:$V0,18:[1,17],19:18,20:19},{3:5,4:$V0,5:6,6:$V1,7:3,8:$V2,9:4,10:$V3,11:$V4,13:23,15:7,16:8,17:$V5,23:$V6,24:[1,21],25:22},{1:[2,6]},o($V7,[2,13]),{18:[1,24],22:[1,25]},o($V8,[2,16]),{21:[1,26]},o($V7,[2,18]),{22:[1,28],24:[1,27]},o($V9,[2,20]),o($V7,[2,14]),{3:20,4:$V0,20:29},{3:5,4:$V0,5:6,6:$V1,7:3,8:$V2,9:4,10:$V3,11:$V4,13:30,15:7,16:8,17:$V5,23:$V6},o($V7,[2,19]),{3:5,4:$V0,5:6,6:$V1,7:3,8:$V2,9:4,10:$V3,11:$V4,13:31,15:7,16:8,17:$V5,23:$V6},o($V8,[2,17]),o($V8,[2,15]),o($V9,[2,21])],\ndefaultActions: {16:[2,6]},\nparseError: function parseError(str, hash) {\n if (hash.recoverable) {\n this.trace(str);\n } else {\n throw new Error(str);\n }\n},\nparse: function parse(input) {\n var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = '', yylineno = 0, yyleng = 0, recovering = 0, TERROR = 2, EOF = 1;\n var args = lstack.slice.call(arguments, 1);\n var lexer = Object.create(this.lexer);\n var sharedState = { yy: {} };\n for (var k in this.yy) {\n if (Object.prototype.hasOwnProperty.call(this.yy, k)) {\n sharedState.yy[k] = this.yy[k];\n }\n }\n lexer.setInput(input, sharedState.yy);\n sharedState.yy.lexer = lexer;\n sharedState.yy.parser = this;\n if (typeof lexer.yylloc == 'undefined') {\n lexer.yylloc = {};\n }\n var yyloc = lexer.yylloc;\n lstack.push(yyloc);\n var ranges = lexer.options && lexer.options.ranges;\n if (typeof sharedState.yy.parseError === 'function') {\n this.parseError = sharedState.yy.parseError;\n } else {\n this.parseError = Object.getPrototypeOf(this).parseError;\n }\n function popStack(n) {\n stack.length = stack.length - 2 * n;\n vstack.length = vstack.length - n;\n lstack.length = lstack.length - n;\n }\n _token_stack:\n function lex() {\n var token;\n token = lexer.lex() || EOF;\n if (typeof token !== 'number') {\n token = self.symbols_[token] || token;\n }\n return token;\n }\n var symbol, preErrorSymbol, state, action, a, r, yyval = {}, p, len, newState, expected;\n while (true) {\n state = stack[stack.length - 1];\n if (this.defaultActions[state]) {\n action = this.defaultActions[state];\n } else {\n if (symbol === null || typeof symbol == 'undefined') {\n symbol = lex();\n }\n action = table[state] && table[state][symbol];\n }\n if (typeof action === 'undefined' || !action.length || !action[0]) {\n var errStr = '';\n expected = [];\n for (p in table[state]) {\n if (this.terminals_[p] && p > TERROR) {\n expected.push('\\'' + this.terminals_[p] + '\\'');\n }\n }\n if (lexer.showPosition) {\n errStr = 'Parse error on line ' + (yylineno + 1) + ':\\n' + lexer.showPosition() + '\\nExpecting ' + expected.join(', ') + ', got \\'' + (this.terminals_[symbol] || symbol) + '\\'';\n } else {\n errStr = 'Parse error on line ' + (yylineno + 1) + ': Unexpected ' + (symbol == EOF ? 'end of input' : '\\'' + (this.terminals_[symbol] || symbol) + '\\'');\n }\n this.parseError(errStr, {\n text: lexer.match,\n token: this.terminals_[symbol] || symbol,\n line: lexer.yylineno,\n loc: yyloc,\n expected: expected\n });\n }\n if (action[0] instanceof Array && action.length > 1) {\n throw new Error('Parse Error: multiple actions possible at state: ' + state + ', token: ' + symbol);\n }\n switch (action[0]) {\n case 1:\n stack.push(symbol);\n vstack.push(lexer.yytext);\n lstack.push(lexer.yylloc);\n stack.push(action[1]);\n symbol = null;\n if (!preErrorSymbol) {\n yyleng = lexer.yyleng;\n yytext = lexer.yytext;\n yylineno = lexer.yylineno;\n yyloc = lexer.yylloc;\n if (recovering > 0) {\n recovering--;\n }\n } else {\n symbol = preErrorSymbol;\n preErrorSymbol = null;\n }\n break;\n case 2:\n len = this.productions_[action[1]][1];\n yyval.$ = vstack[vstack.length - len];\n yyval._$ = {\n first_line: lstack[lstack.length - (len || 1)].first_line,\n last_line: lstack[lstack.length - 1].last_line,\n first_column: lstack[lstack.length - (len || 1)].first_column,\n last_column: lstack[lstack.length - 1].last_column\n };\n if (ranges) {\n yyval._$.range = [\n lstack[lstack.length - (len || 1)].range[0],\n lstack[lstack.length - 1].range[1]\n ];\n }\n r = this.performAction.apply(yyval, [\n yytext,\n yyleng,\n yylineno,\n sharedState.yy,\n action[1],\n vstack,\n lstack\n ].concat(args));\n if (typeof r !== 'undefined') {\n return r;\n }\n if (len) {\n stack = stack.slice(0, -1 * len * 2);\n vstack = vstack.slice(0, -1 * len);\n lstack = lstack.slice(0, -1 * len);\n }\n stack.push(this.productions_[action[1]][0]);\n vstack.push(yyval.$);\n lstack.push(yyval._$);\n newState = table[stack[stack.length - 2]][stack[stack.length - 1]];\n stack.push(newState);\n break;\n case 3:\n return true;\n }\n }\n return true;\n}};\n/* generated by jison-lex 0.3.4 */\nvar lexer = (function(){\nvar lexer = ({\n\nEOF:1,\n\nparseError:function parseError(str, hash) {\n if (this.yy.parser) {\n this.yy.parser.parseError(str, hash);\n } else {\n throw new Error(str);\n }\n },\n\n// resets the lexer, sets new input\nsetInput:function (input, yy) {\n this.yy = yy || this.yy || {};\n this._input = input;\n this._more = this._backtrack = this.done = false;\n this.yylineno = this.yyleng = 0;\n this.yytext = this.matched = this.match = '';\n this.conditionStack = ['INITIAL'];\n this.yylloc = {\n first_line: 1,\n first_column: 0,\n last_line: 1,\n last_column: 0\n };\n if (this.options.ranges) {\n this.yylloc.range = [0,0];\n }\n this.offset = 0;\n return this;\n },\n\n// consumes and returns one char from the input\ninput:function () {\n var ch = this._input[0];\n this.yytext += ch;\n this.yyleng++;\n this.offset++;\n this.match += ch;\n this.matched += ch;\n var lines = ch.match(/(?:\\r\\n?|\\n).*/g);\n if (lines) {\n this.yylineno++;\n this.yylloc.last_line++;\n } else {\n this.yylloc.last_column++;\n }\n if (this.options.ranges) {\n this.yylloc.range[1]++;\n }\n\n this._input = this._input.slice(1);\n return ch;\n },\n\n// unshifts one char (or a string) into the input\nunput:function (ch) {\n var len = ch.length;\n var lines = ch.split(/(?:\\r\\n?|\\n)/g);\n\n this._input = ch + this._input;\n this.yytext = this.yytext.substr(0, this.yytext.length - len);\n //this.yyleng -= len;\n this.offset -= len;\n var oldLines = this.match.split(/(?:\\r\\n?|\\n)/g);\n this.match = this.match.substr(0, this.match.length - 1);\n this.matched = this.matched.substr(0, this.matched.length - 1);\n\n if (lines.length - 1) {\n this.yylineno -= lines.length - 1;\n }\n var r = this.yylloc.range;\n\n this.yylloc = {\n first_line: this.yylloc.first_line,\n last_line: this.yylineno + 1,\n first_column: this.yylloc.first_column,\n last_column: lines ?\n (lines.length === oldLines.length ? this.yylloc.first_column : 0)\n + oldLines[oldLines.length - lines.length].length - lines[0].length :\n this.yylloc.first_column - len\n };\n\n if (this.options.ranges) {\n this.yylloc.range = [r[0], r[0] + this.yyleng - len];\n }\n this.yyleng = this.yytext.length;\n return this;\n },\n\n// When called from action, caches matched text and appends it on next action\nmore:function () {\n this._more = true;\n return this;\n },\n\n// When called from action, signals the lexer that this rule fails to match the input, so the next matching rule (regex) should be tested instead.\nreject:function () {\n if (this.options.backtrack_lexer) {\n this._backtrack = true;\n } else {\n return this.parseError('Lexical error on line ' + (this.yylineno + 1) + '. You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).\\n' + this.showPosition(), {\n text: \"\",\n token: null,\n line: this.yylineno\n });\n\n }\n return this;\n },\n\n// retain first n characters of the match\nless:function (n) {\n this.unput(this.match.slice(n));\n },\n\n// displays already matched input, i.e. for error messages\npastInput:function () {\n var past = this.matched.substr(0, this.matched.length - this.match.length);\n return (past.length > 20 ? '...':'') + past.substr(-20).replace(/\\n/g, \"\");\n },\n\n// displays upcoming input, i.e. for error messages\nupcomingInput:function () {\n var next = this.match;\n if (next.length < 20) {\n next += this._input.substr(0, 20-next.length);\n }\n return (next.substr(0,20) + (next.length > 20 ? '...' : '')).replace(/\\n/g, \"\");\n },\n\n// displays the character position where the lexing error occurred, i.e. for error messages\nshowPosition:function () {\n var pre = this.pastInput();\n var c = new Array(pre.length + 1).join(\"-\");\n return pre + this.upcomingInput() + \"\\n\" + c + \"^\";\n },\n\n// test the lexed token: return FALSE when not a match, otherwise return token\ntest_match:function (match, indexed_rule) {\n var token,\n lines,\n backup;\n\n if (this.options.backtrack_lexer) {\n // save context\n backup = {\n yylineno: this.yylineno,\n yylloc: {\n first_line: this.yylloc.first_line,\n last_line: this.last_line,\n first_column: this.yylloc.first_column,\n last_column: this.yylloc.last_column\n },\n yytext: this.yytext,\n match: this.match,\n matches: this.matches,\n matched: this.matched,\n yyleng: this.yyleng,\n offset: this.offset,\n _more: this._more,\n _input: this._input,\n yy: this.yy,\n conditionStack: this.conditionStack.slice(0),\n done: this.done\n };\n if (this.options.ranges) {\n backup.yylloc.range = this.yylloc.range.slice(0);\n }\n }\n\n lines = match[0].match(/(?:\\r\\n?|\\n).*/g);\n if (lines) {\n this.yylineno += lines.length;\n }\n this.yylloc = {\n first_line: this.yylloc.last_line,\n last_line: this.yylineno + 1,\n first_column: this.yylloc.last_column,\n last_column: lines ?\n lines[lines.length - 1].length - lines[lines.length - 1].match(/\\r?\\n?/)[0].length :\n this.yylloc.last_column + match[0].length\n };\n this.yytext += match[0];\n this.match += match[0];\n this.matches = match;\n this.yyleng = this.yytext.length;\n if (this.options.ranges) {\n this.yylloc.range = [this.offset, this.offset += this.yyleng];\n }\n this._more = false;\n this._backtrack = false;\n this._input = this._input.slice(match[0].length);\n this.matched += match[0];\n token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]);\n if (this.done && this._input) {\n this.done = false;\n }\n if (token) {\n return token;\n } else if (this._backtrack) {\n // recover context\n for (var k in backup) {\n this[k] = backup[k];\n }\n return false; // rule action called reject() implying the next rule should be tested instead.\n }\n return false;\n },\n\n// return next match in input\nnext:function () {\n if (this.done) {\n return this.EOF;\n }\n if (!this._input) {\n this.done = true;\n }\n\n var token,\n match,\n tempMatch,\n index;\n if (!this._more) {\n this.yytext = '';\n this.match = '';\n }\n var rules = this._currentRules();\n for (var i = 0; i < rules.length; i++) {\n tempMatch = this._input.match(this.rules[rules[i]]);\n if (tempMatch && (!match || tempMatch[0].length > match[0].length)) {\n match = tempMatch;\n index = i;\n if (this.options.backtrack_lexer) {\n token = this.test_match(tempMatch, rules[i]);\n if (token !== false) {\n return token;\n } else if (this._backtrack) {\n match = false;\n continue; // rule action called reject() implying a rule MISmatch.\n } else {\n // else: this is a lexer rule which consumes input without producing a token (e.g. whitespace)\n return false;\n }\n } else if (!this.options.flex) {\n break;\n }\n }\n }\n if (match) {\n token = this.test_match(match, rules[index]);\n if (token !== false) {\n return token;\n }\n // else: this is a lexer rule which consumes input without producing a token (e.g. whitespace)\n return false;\n }\n if (this._input === \"\") {\n return this.EOF;\n } else {\n return this.parseError('Lexical error on line ' + (this.yylineno + 1) + '. Unrecognized text.\\n' + this.showPosition(), {\n text: \"\",\n token: null,\n line: this.yylineno\n });\n }\n },\n\n// return next match that has a token\nlex:function lex() {\n var r = this.next();\n if (r) {\n return r;\n } else {\n return this.lex();\n }\n },\n\n// activates a new lexer condition state (pushes the new lexer condition state onto the condition stack)\nbegin:function begin(condition) {\n this.conditionStack.push(condition);\n },\n\n// pop the previously active lexer condition state off the condition stack\npopState:function popState() {\n var n = this.conditionStack.length - 1;\n if (n > 0) {\n return this.conditionStack.pop();\n } else {\n return this.conditionStack[0];\n }\n },\n\n// produce the lexer rule set which is active for the currently active lexer condition state\n_currentRules:function _currentRules() {\n if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) {\n return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules;\n } else {\n return this.conditions[\"INITIAL\"].rules;\n }\n },\n\n// return the currently active lexer condition state; when an index argument is provided it produces the N-th previous condition state, if available\ntopState:function topState(n) {\n n = this.conditionStack.length - 1 - Math.abs(n || 0);\n if (n >= 0) {\n return this.conditionStack[n];\n } else {\n return \"INITIAL\";\n }\n },\n\n// alias for begin(condition)\npushState:function pushState(condition) {\n this.begin(condition);\n },\n\n// return the number of states currently on the stack\nstateStackSize:function stateStackSize() {\n return this.conditionStack.length;\n },\noptions: {},\nperformAction: function anonymous(yy,yy_,$avoiding_name_collisions,YY_START) {\nvar YYSTATE=YY_START;\nswitch($avoiding_name_collisions) {\ncase 0:/* skip whitespace */\nbreak;\ncase 1:return 6\nbreak;\ncase 2:yy_.yytext = yy_.yytext.substr(1,yy_.yyleng-2); return 4\nbreak;\ncase 3:return 17\nbreak;\ncase 4:return 18\nbreak;\ncase 5:return 23\nbreak;\ncase 6:return 24\nbreak;\ncase 7:return 22\nbreak;\ncase 8:return 21\nbreak;\ncase 9:return 10\nbreak;\ncase 10:return 11\nbreak;\ncase 11:return 8\nbreak;\ncase 12:return 14\nbreak;\ncase 13:return 'INVALID'\nbreak;\n}\n},\nrules: [/^(?:\\s+)/,/^(?:(-?([0-9]|[1-9][0-9]+))(\\.[0-9]+)?([eE][-+]?[0-9]+)?\\b)/,/^(?:\"(?:\\\\[\\\\\"bfnrt/]|\\\\u[a-fA-F0-9]{4}|[^\\\\\\0-\\x09\\x0a-\\x1f\"])*\")/,/^(?:\\{)/,/^(?:\\})/,/^(?:\\[)/,/^(?:\\])/,/^(?:,)/,/^(?::)/,/^(?:true\\b)/,/^(?:false\\b)/,/^(?:null\\b)/,/^(?:$)/,/^(?:.)/],\nconditions: {\"INITIAL\":{\"rules\":[0,1,2,3,4,5,6,7,8,9,10,11,12,13],\"inclusive\":true}}\n});\nreturn lexer;\n})();\nparser.lexer = lexer;\nfunction Parser () {\n this.yy = {};\n}\nParser.prototype = parser;parser.Parser = Parser;\nreturn new Parser;\n})();\n\n\nif (typeof require !== 'undefined' && typeof exports !== 'undefined') {\nexports.parser = parser;\nexports.Parser = parser.Parser;\nexports.parse = function () { return parser.parse.apply(parser, arguments); };\n}\n","\nimport validateStyleMin from './validate_style.min';\nimport ParsingError from './error/parsing_error';\nimport jsonlint from '@mapbox/jsonlint-lines-primitives';\nimport {v8} from './style-spec';\n\n/**\n * Validate a Mapbox GL style against the style specification.\n *\n * @private\n * @alias validate\n * @param {Object|String|Buffer} style The style to be validated. If a `String`\n * or `Buffer` is provided, the returned errors will contain line numbers.\n * @param {Object} [styleSpec] The style specification to validate against.\n * If omitted, the spec version is inferred from the stylesheet.\n * @returns {Array<ValidationError|ParsingError>}\n * @example\n * var validate = require('mapbox-gl-style-spec').validate;\n * var style = fs.readFileSync('./style.json', 'utf8');\n * var errors = validate(style);\n */\n\nexport default function validateStyle(style, styleSpec) {\n if (style instanceof String || typeof style === 'string' || style instanceof Buffer) {\n try {\n style = jsonlint.parse(style.toString());\n } catch (e) {\n return [new ParsingError(e)];\n }\n }\n\n styleSpec = styleSpec || v8;\n\n return validateStyleMin(style, styleSpec);\n}\n\nexport const source = validateStyleMin.source;\nexport const light = validateStyleMin.light;\nexport const layer = validateStyleMin.layer;\nexport const filter = validateStyleMin.filter;\nexport const paintProperty = validateStyleMin.paintProperty;\nexport const layoutProperty = validateStyleMin.layoutProperty;\n","\nimport migrateToV8 from './migrate/v8';\nimport migrateToExpressions from './migrate/expressions';\n\n/**\n * Migrate a Mapbox GL Style to the latest version.\n *\n * @private\n * @alias migrate\n * @param {object} style a Mapbox GL Style\n * @returns {Object} a migrated style\n * @example\n * var fs = require('fs');\n * var migrate = require('mapbox-gl-style-spec').migrate;\n * var style = fs.readFileSync('./style.json', 'utf8');\n * fs.writeFileSync('./style.json', JSON.stringify(migrate(style)));\n */\nexport default function(style) {\n let migrated = false;\n\n if (style.version === 7) {\n style = migrateToV8(style);\n migrated = true;\n }\n\n if (style.version === 8) {\n migrated = migrateToExpressions(style);\n migrated = true;\n }\n\n if (!migrated) {\n throw new Error('cannot migrate from', style.version);\n }\n\n return style;\n}\n","// @flow\n\nimport {\n eachLayer,\n eachProperty\n} from '../visit';\nimport { isExpression } from '../expression';\nimport convertFunction, {convertTokenString} from '../function/convert';\nimport convertFilter from '../feature_filter/convert';\n\nimport type { StyleSpecification } from '../types';\n\n/**\n * Migrate the given style object in place to use expressions. Specifically,\n * this will convert (a) \"stop\" functions, and (b) legacy filters to their\n * expression equivalents.\n */\nexport default function(style: StyleSpecification) {\n const converted = [];\n\n eachLayer(style, (layer) => {\n if (layer.filter) {\n layer.filter = (convertFilter(layer.filter): any);\n }\n });\n\n eachProperty(style, {paint: true, layout: true}, ({path, value, reference, set}) => {\n if (isExpression(value)) return;\n if (typeof value === 'object' && !Array.isArray(value)) {\n set(convertFunction(value, reference));\n converted.push(path.join('.'));\n } else if (reference.tokens && typeof value === 'string') {\n set(convertTokenString(value));\n }\n });\n\n return style;\n}\n\n","\nexport default function (style) {\n const styleIDs = [];\n const sourceIDs = [];\n const compositedSourceLayers = [];\n\n for (const id in style.sources) {\n const source = style.sources[id];\n\n if (source.type !== \"vector\")\n continue;\n\n const match = /^mapbox:\\/\\/(.*)/.exec(source.url);\n if (!match)\n continue;\n\n styleIDs.push(id);\n sourceIDs.push(match[1]);\n }\n\n if (styleIDs.length < 2)\n return style;\n\n styleIDs.forEach((id) => {\n delete style.sources[id];\n });\n\n const compositeID = sourceIDs.join(\",\");\n\n style.sources[compositeID] = {\n \"type\": \"vector\",\n \"url\": `mapbox://${compositeID}`\n };\n\n style.layers.forEach((layer) => {\n if (styleIDs.indexOf(layer.source) >= 0) {\n layer.source = compositeID;\n\n if ('source-layer' in layer) {\n if (compositedSourceLayers.indexOf(layer['source-layer']) >= 0) {\n throw new Error('Conflicting source layer names');\n } else {\n compositedSourceLayers.push(layer['source-layer']);\n }\n }\n }\n });\n\n return style;\n}\n","\nexport default ['type', 'source', 'source-layer', 'minzoom', 'maxzoom', 'filter', 'layout'];\n","\nimport refProperties from './util/ref_properties';\n\nfunction deref(layer, parent) {\n const result = {};\n\n for (const k in layer) {\n if (k !== 'ref') {\n result[k] = layer[k];\n }\n }\n\n refProperties.forEach((k) => {\n if (k in parent) {\n result[k] = parent[k];\n }\n });\n\n return result;\n}\n\nexport default derefLayers;\n\n/**\n * Given an array of layers, some of which may contain `ref` properties\n * whose value is the `id` of another property, return a new array where\n * such layers have been augmented with the 'type', 'source', etc. properties\n * from the parent layer, and the `ref` property has been removed.\n *\n * The input is not modified. The output may contain references to portions\n * of the input.\n *\n * @private\n * @param {Array<Layer>} layers\n * @returns {Array<Layer>}\n */\nfunction derefLayers(layers) {\n layers = layers.slice();\n\n const map = Object.create(null);\n for (let i = 0; i < layers.length; i++) {\n map[layers[i].id] = layers[i];\n }\n\n for (let i = 0; i < layers.length; i++) {\n if ('ref' in layers[i]) {\n layers[i] = deref(layers[i], map[layers[i].ref]);\n }\n }\n\n return layers;\n}\n","\nimport deref from '../deref';\n\nfunction eachLayer(style, callback) {\n for (const k in style.layers) {\n callback(style.layers[k]);\n }\n}\n\nexport default function(style) {\n style.version = 9;\n\n // remove user-specified refs\n style.layers = deref(style.layers);\n\n // remove class-specific paint properties\n eachLayer(style, (layer) => {\n for (const k in layer) {\n if (/paint\\..*/.test(k)) {\n delete layer[k];\n }\n }\n });\n\n return style;\n}\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: https://codemirror.net/LICENSE\n\n// This is CodeMirror (https://codemirror.net), a code editor\n// implemented in JavaScript on top of the browser's DOM.\n//\n// You can find some technical background for some of the code below\n// at http://marijnhaverbeke.nl/blog/#cm-internals .\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global.CodeMirror = factory());\n}(this, (function () { 'use strict';\n\n // Kludges for bugs and behavior differences that can't be feature\n // detected are enabled based on userAgent etc sniffing.\n var userAgent = navigator.userAgent;\n var platform = navigator.platform;\n\n var gecko = /gecko\\/\\d/i.test(userAgent);\n var ie_upto10 = /MSIE \\d/.test(userAgent);\n var ie_11up = /Trident\\/(?:[7-9]|\\d{2,})\\..*rv:(\\d+)/.exec(userAgent);\n var edge = /Edge\\/(\\d+)/.exec(userAgent);\n var ie = ie_upto10 || ie_11up || edge;\n var ie_version = ie && (ie_upto10 ? document.documentMode || 6 : +(edge || ie_11up)[1]);\n var webkit = !edge && /WebKit\\//.test(userAgent);\n var qtwebkit = webkit && /Qt\\/\\d+\\.\\d+/.test(userAgent);\n var chrome = !edge && /Chrome\\//.test(userAgent);\n var presto = /Opera\\//.test(userAgent);\n var safari = /Apple Computer/.test(navigator.vendor);\n var mac_geMountainLion = /Mac OS X 1\\d\\D([8-9]|\\d\\d)\\D/.test(userAgent);\n var phantom = /PhantomJS/.test(userAgent);\n\n var ios = !edge && /AppleWebKit/.test(userAgent) && /Mobile\\/\\w+/.test(userAgent);\n var android = /Android/.test(userAgent);\n // This is woefully incomplete. Suggestions for alternative methods welcome.\n var mobile = ios || android || /webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent);\n var mac = ios || /Mac/.test(platform);\n var chromeOS = /\\bCrOS\\b/.test(userAgent);\n var windows = /win/i.test(platform);\n\n var presto_version = presto && userAgent.match(/Version\\/(\\d*\\.\\d*)/);\n if (presto_version) { presto_version = Number(presto_version[1]); }\n if (presto_version && presto_version >= 15) { presto = false; webkit = true; }\n // Some browsers use the wrong event properties to signal cmd/ctrl on OS X\n var flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11));\n var captureRightClick = gecko || (ie && ie_version >= 9);\n\n function classTest(cls) { return new RegExp(\"(^|\\\\s)\" + cls + \"(?:$|\\\\s)\\\\s*\") }\n\n var rmClass = function(node, cls) {\n var current = node.className;\n var match = classTest(cls).exec(current);\n if (match) {\n var after = current.slice(match.index + match[0].length);\n node.className = current.slice(0, match.index) + (after ? match[1] + after : \"\");\n }\n };\n\n function removeChildren(e) {\n for (var count = e.childNodes.length; count > 0; --count)\n { e.removeChild(e.firstChild); }\n return e\n }\n\n function removeChildrenAndAdd(parent, e) {\n return removeChildren(parent).appendChild(e)\n }\n\n function elt(tag, content, className, style) {\n var e = document.createElement(tag);\n if (className) { e.className = className; }\n if (style) { e.style.cssText = style; }\n if (typeof content == \"string\") { e.appendChild(document.createTextNode(content)); }\n else if (content) { for (var i = 0; i < content.length; ++i) { e.appendChild(content[i]); } }\n return e\n }\n // wrapper for elt, which removes the elt from the accessibility tree\n function eltP(tag, content, className, style) {\n var e = elt(tag, content, className, style);\n e.setAttribute(\"role\", \"presentation\");\n return e\n }\n\n var range;\n if (document.createRange) { range = function(node, start, end, endNode) {\n var r = document.createRange();\n r.setEnd(endNode || node, end);\n r.setStart(node, start);\n return r\n }; }\n else { range = function(node, start, end) {\n var r = document.body.createTextRange();\n try { r.moveToElementText(node.parentNode); }\n catch(e) { return r }\n r.collapse(true);\n r.moveEnd(\"character\", end);\n r.moveStart(\"character\", start);\n return r\n }; }\n\n function contains(parent, child) {\n if (child.nodeType == 3) // Android browser always returns false when child is a textnode\n { child = child.parentNode; }\n if (parent.contains)\n { return parent.contains(child) }\n do {\n if (child.nodeType == 11) { child = child.host; }\n if (child == parent) { return true }\n } while (child = child.parentNode)\n }\n\n function activeElt() {\n // IE and Edge may throw an \"Unspecified Error\" when accessing document.activeElement.\n // IE < 10 will throw when accessed while the page is loading or in an iframe.\n // IE > 9 and Edge will throw when accessed in an iframe if document.body is unavailable.\n var activeElement;\n try {\n activeElement = document.activeElement;\n } catch(e) {\n activeElement = document.body || null;\n }\n while (activeElement && activeElement.shadowRoot && activeElement.shadowRoot.activeElement)\n { activeElement = activeElement.shadowRoot.activeElement; }\n return activeElement\n }\n\n function addClass(node, cls) {\n var current = node.className;\n if (!classTest(cls).test(current)) { node.className += (current ? \" \" : \"\") + cls; }\n }\n function joinClasses(a, b) {\n var as = a.split(\" \");\n for (var i = 0; i < as.length; i++)\n { if (as[i] && !classTest(as[i]).test(b)) { b += \" \" + as[i]; } }\n return b\n }\n\n var selectInput = function(node) { node.select(); };\n if (ios) // Mobile Safari apparently has a bug where select() is broken.\n { selectInput = function(node) { node.selectionStart = 0; node.selectionEnd = node.value.length; }; }\n else if (ie) // Suppress mysterious IE10 errors\n { selectInput = function(node) { try { node.select(); } catch(_e) {} }; }\n\n function bind(f) {\n var args = Array.prototype.slice.call(arguments, 1);\n return function(){return f.apply(null, args)}\n }\n\n function copyObj(obj, target, overwrite) {\n if (!target) { target = {}; }\n for (var prop in obj)\n { if (obj.hasOwnProperty(prop) && (overwrite !== false || !target.hasOwnProperty(prop)))\n { target[prop] = obj[prop]; } }\n return target\n }\n\n // Counts the column offset in a string, taking tabs into account.\n // Used mostly to find indentation.\n function countColumn(string, end, tabSize, startIndex, startValue) {\n if (end == null) {\n end = string.search(/[^\\s\\u00a0]/);\n if (end == -1) { end = string.length; }\n }\n for (var i = startIndex || 0, n = startValue || 0;;) {\n var nextTab = string.indexOf(\"\\t\", i);\n if (nextTab < 0 || nextTab >= end)\n { return n + (end - i) }\n n += nextTab - i;\n n += tabSize - (n % tabSize);\n i = nextTab + 1;\n }\n }\n\n var Delayed = function() {this.id = null;};\n Delayed.prototype.set = function (ms, f) {\n clearTimeout(this.id);\n this.id = setTimeout(f, ms);\n };\n\n function indexOf(array, elt) {\n for (var i = 0; i < array.length; ++i)\n { if (array[i] == elt) { return i } }\n return -1\n }\n\n // Number of pixels added to scroller and sizer to hide scrollbar\n var scrollerGap = 30;\n\n // Returned or thrown by various protocols to signal 'I'm not\n // handling this'.\n var Pass = {toString: function(){return \"CodeMirror.Pass\"}};\n\n // Reused option objects for setSelection & friends\n var sel_dontScroll = {scroll: false}, sel_mouse = {origin: \"*mouse\"}, sel_move = {origin: \"+move\"};\n\n // The inverse of countColumn -- find the offset that corresponds to\n // a particular column.\n function findColumn(string, goal, tabSize) {\n for (var pos = 0, col = 0;;) {\n var nextTab = string.indexOf(\"\\t\", pos);\n if (nextTab == -1) { nextTab = string.length; }\n var skipped = nextTab - pos;\n if (nextTab == string.length || col + skipped >= goal)\n { return pos + Math.min(skipped, goal - col) }\n col += nextTab - pos;\n col += tabSize - (col % tabSize);\n pos = nextTab + 1;\n if (col >= goal) { return pos }\n }\n }\n\n var spaceStrs = [\"\"];\n function spaceStr(n) {\n while (spaceStrs.length <= n)\n { spaceStrs.push(lst(spaceStrs) + \" \"); }\n return spaceStrs[n]\n }\n\n function lst(arr) { return arr[arr.length-1] }\n\n function map(array, f) {\n var out = [];\n for (var i = 0; i < array.length; i++) { out[i] = f(array[i], i); }\n return out\n }\n\n function insertSorted(array, value, score) {\n var pos = 0, priority = score(value);\n while (pos < array.length && score(array[pos]) <= priority) { pos++; }\n array.splice(pos, 0, value);\n }\n\n function nothing() {}\n\n function createObj(base, props) {\n var inst;\n if (Object.create) {\n inst = Object.create(base);\n } else {\n nothing.prototype = base;\n inst = new nothing();\n }\n if (props) { copyObj(props, inst); }\n return inst\n }\n\n var nonASCIISingleCaseWordChar = /[\\u00df\\u0587\\u0590-\\u05f4\\u0600-\\u06ff\\u3040-\\u309f\\u30a0-\\u30ff\\u3400-\\u4db5\\u4e00-\\u9fcc\\uac00-\\ud7af]/;\n function isWordCharBasic(ch) {\n return /\\w/.test(ch) || ch > \"\\x80\" &&\n (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch))\n }\n function isWordChar(ch, helper) {\n if (!helper) { return isWordCharBasic(ch) }\n if (helper.source.indexOf(\"\\\\w\") > -1 && isWordCharBasic(ch)) { return true }\n return helper.test(ch)\n }\n\n function isEmpty(obj) {\n for (var n in obj) { if (obj.hasOwnProperty(n) && obj[n]) { return false } }\n return true\n }\n\n // Extending unicode characters. A series of a non-extending char +\n // any number of extending chars is treated as a single unit as far\n // as editing and measuring is concerned. This is not fully correct,\n // since some scripts/fonts/browsers also treat other configurations\n // of code points as a group.\n var extendingChars = /[\\u0300-\\u036f\\u0483-\\u0489\\u0591-\\u05bd\\u05bf\\u05c1\\u05c2\\u05c4\\u05c5\\u05c7\\u0610-\\u061a\\u064b-\\u065e\\u0670\\u06d6-\\u06dc\\u06de-\\u06e4\\u06e7\\u06e8\\u06ea-\\u06ed\\u0711\\u0730-\\u074a\\u07a6-\\u07b0\\u07eb-\\u07f3\\u0816-\\u0819\\u081b-\\u0823\\u0825-\\u0827\\u0829-\\u082d\\u0900-\\u0902\\u093c\\u0941-\\u0948\\u094d\\u0951-\\u0955\\u0962\\u0963\\u0981\\u09bc\\u09be\\u09c1-\\u09c4\\u09cd\\u09d7\\u09e2\\u09e3\\u0a01\\u0a02\\u0a3c\\u0a41\\u0a42\\u0a47\\u0a48\\u0a4b-\\u0a4d\\u0a51\\u0a70\\u0a71\\u0a75\\u0a81\\u0a82\\u0abc\\u0ac1-\\u0ac5\\u0ac7\\u0ac8\\u0acd\\u0ae2\\u0ae3\\u0b01\\u0b3c\\u0b3e\\u0b3f\\u0b41-\\u0b44\\u0b4d\\u0b56\\u0b57\\u0b62\\u0b63\\u0b82\\u0bbe\\u0bc0\\u0bcd\\u0bd7\\u0c3e-\\u0c40\\u0c46-\\u0c48\\u0c4a-\\u0c4d\\u0c55\\u0c56\\u0c62\\u0c63\\u0cbc\\u0cbf\\u0cc2\\u0cc6\\u0ccc\\u0ccd\\u0cd5\\u0cd6\\u0ce2\\u0ce3\\u0d3e\\u0d41-\\u0d44\\u0d4d\\u0d57\\u0d62\\u0d63\\u0dca\\u0dcf\\u0dd2-\\u0dd4\\u0dd6\\u0ddf\\u0e31\\u0e34-\\u0e3a\\u0e47-\\u0e4e\\u0eb1\\u0eb4-\\u0eb9\\u0ebb\\u0ebc\\u0ec8-\\u0ecd\\u0f18\\u0f19\\u0f35\\u0f37\\u0f39\\u0f71-\\u0f7e\\u0f80-\\u0f84\\u0f86\\u0f87\\u0f90-\\u0f97\\u0f99-\\u0fbc\\u0fc6\\u102d-\\u1030\\u1032-\\u1037\\u1039\\u103a\\u103d\\u103e\\u1058\\u1059\\u105e-\\u1060\\u1071-\\u1074\\u1082\\u1085\\u1086\\u108d\\u109d\\u135f\\u1712-\\u1714\\u1732-\\u1734\\u1752\\u1753\\u1772\\u1773\\u17b7-\\u17bd\\u17c6\\u17c9-\\u17d3\\u17dd\\u180b-\\u180d\\u18a9\\u1920-\\u1922\\u1927\\u1928\\u1932\\u1939-\\u193b\\u1a17\\u1a18\\u1a56\\u1a58-\\u1a5e\\u1a60\\u1a62\\u1a65-\\u1a6c\\u1a73-\\u1a7c\\u1a7f\\u1b00-\\u1b03\\u1b34\\u1b36-\\u1b3a\\u1b3c\\u1b42\\u1b6b-\\u1b73\\u1b80\\u1b81\\u1ba2-\\u1ba5\\u1ba8\\u1ba9\\u1c2c-\\u1c33\\u1c36\\u1c37\\u1cd0-\\u1cd2\\u1cd4-\\u1ce0\\u1ce2-\\u1ce8\\u1ced\\u1dc0-\\u1de6\\u1dfd-\\u1dff\\u200c\\u200d\\u20d0-\\u20f0\\u2cef-\\u2cf1\\u2de0-\\u2dff\\u302a-\\u302f\\u3099\\u309a\\ua66f-\\ua672\\ua67c\\ua67d\\ua6f0\\ua6f1\\ua802\\ua806\\ua80b\\ua825\\ua826\\ua8c4\\ua8e0-\\ua8f1\\ua926-\\ua92d\\ua947-\\ua951\\ua980-\\ua982\\ua9b3\\ua9b6-\\ua9b9\\ua9bc\\uaa29-\\uaa2e\\uaa31\\uaa32\\uaa35\\uaa36\\uaa43\\uaa4c\\uaab0\\uaab2-\\uaab4\\uaab7\\uaab8\\uaabe\\uaabf\\uaac1\\uabe5\\uabe8\\uabed\\udc00-\\udfff\\ufb1e\\ufe00-\\ufe0f\\ufe20-\\ufe26\\uff9e\\uff9f]/;\n function isExtendingChar(ch) { return ch.charCodeAt(0) >= 768 && extendingChars.test(ch) }\n\n // Returns a number from the range [`0`; `str.length`] unless `pos` is outside that range.\n function skipExtendingChars(str, pos, dir) {\n while ((dir < 0 ? pos > 0 : pos < str.length) && isExtendingChar(str.charAt(pos))) { pos += dir; }\n return pos\n }\n\n // Returns the value from the range [`from`; `to`] that satisfies\n // `pred` and is closest to `from`. Assumes that at least `to`\n // satisfies `pred`. Supports `from` being greater than `to`.\n function findFirst(pred, from, to) {\n // At any point we are certain `to` satisfies `pred`, don't know\n // whether `from` does.\n var dir = from > to ? -1 : 1;\n for (;;) {\n if (from == to) { return from }\n var midF = (from + to) / 2, mid = dir < 0 ? Math.ceil(midF) : Math.floor(midF);\n if (mid == from) { return pred(mid) ? from : to }\n if (pred(mid)) { to = mid; }\n else { from = mid + dir; }\n }\n }\n\n // The display handles the DOM integration, both for input reading\n // and content drawing. It holds references to DOM nodes and\n // display-related state.\n\n function Display(place, doc, input) {\n var d = this;\n this.input = input;\n\n // Covers bottom-right square when both scrollbars are present.\n d.scrollbarFiller = elt(\"div\", null, \"CodeMirror-scrollbar-filler\");\n d.scrollbarFiller.setAttribute(\"cm-not-content\", \"true\");\n // Covers bottom of gutter when coverGutterNextToScrollbar is on\n // and h scrollbar is present.\n d.gutterFiller = elt(\"div\", null, \"CodeMirror-gutter-filler\");\n d.gutterFiller.setAttribute(\"cm-not-content\", \"true\");\n // Will contain the actual code, positioned to cover the viewport.\n d.lineDiv = eltP(\"div\", null, \"CodeMirror-code\");\n // Elements are added to these to represent selection and cursors.\n d.selectionDiv = elt(\"div\", null, null, \"position: relative; z-index: 1\");\n d.cursorDiv = elt(\"div\", null, \"CodeMirror-cursors\");\n // A visibility: hidden element used to find the size of things.\n d.measure = elt(\"div\", null, \"CodeMirror-measure\");\n // When lines outside of the viewport are measured, they are drawn in this.\n d.lineMeasure = elt(\"div\", null, \"CodeMirror-measure\");\n // Wraps everything that needs to exist inside the vertically-padded coordinate system\n d.lineSpace = eltP(\"div\", [d.measure, d.lineMeasure, d.selectionDiv, d.cursorDiv, d.lineDiv],\n null, \"position: relative; outline: none\");\n var lines = eltP(\"div\", [d.lineSpace], \"CodeMirror-lines\");\n // Moved around its parent to cover visible view.\n d.mover = elt(\"div\", [lines], null, \"position: relative\");\n // Set to the height of the document, allowing scrolling.\n d.sizer = elt(\"div\", [d.mover], \"CodeMirror-sizer\");\n d.sizerWidth = null;\n // Behavior of elts with overflow: auto and padding is\n // inconsistent across browsers. This is used to ensure the\n // scrollable area is big enough.\n d.heightForcer = elt(\"div\", null, null, \"position: absolute; height: \" + scrollerGap + \"px; width: 1px;\");\n // Will contain the gutters, if any.\n d.gutters = elt(\"div\", null, \"CodeMirror-gutters\");\n d.lineGutter = null;\n // Actual scrollable element.\n d.scroller = elt(\"div\", [d.sizer, d.heightForcer, d.gutters], \"CodeMirror-scroll\");\n d.scroller.setAttribute(\"tabIndex\", \"-1\");\n // The element in which the editor lives.\n d.wrapper = elt(\"div\", [d.scrollbarFiller, d.gutterFiller, d.scroller], \"CodeMirror\");\n\n // Work around IE7 z-index bug (not perfect, hence IE7 not really being supported)\n if (ie && ie_version < 8) { d.gutters.style.zIndex = -1; d.scroller.style.paddingRight = 0; }\n if (!webkit && !(gecko && mobile)) { d.scroller.draggable = true; }\n\n if (place) {\n if (place.appendChild) { place.appendChild(d.wrapper); }\n else { place(d.wrapper); }\n }\n\n // Current rendered range (may be bigger than the view window).\n d.viewFrom = d.viewTo = doc.first;\n d.reportedViewFrom = d.reportedViewTo = doc.first;\n // Information about the rendered lines.\n d.view = [];\n d.renderedView = null;\n // Holds info about a single rendered line when it was rendered\n // for measurement, while not in view.\n d.externalMeasured = null;\n // Empty space (in pixels) above the view\n d.viewOffset = 0;\n d.lastWrapHeight = d.lastWrapWidth = 0;\n d.updateLineNumbers = null;\n\n d.nativeBarWidth = d.barHeight = d.barWidth = 0;\n d.scrollbarsClipped = false;\n\n // Used to only resize the line number gutter when necessary (when\n // the amount of lines crosses a boundary that makes its width change)\n d.lineNumWidth = d.lineNumInnerWidth = d.lineNumChars = null;\n // Set to true when a non-horizontal-scrolling line widget is\n // added. As an optimization, line widget aligning is skipped when\n // this is false.\n d.alignWidgets = false;\n\n d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n\n // Tracks the maximum line length so that the horizontal scrollbar\n // can be kept static when scrolling.\n d.maxLine = null;\n d.maxLineLength = 0;\n d.maxLineChanged = false;\n\n // Used for measuring wheel scrolling granularity\n d.wheelDX = d.wheelDY = d.wheelStartX = d.wheelStartY = null;\n\n // True when shift is held down.\n d.shift = false;\n\n // Used to track whether anything happened since the context menu\n // was opened.\n d.selForContextMenu = null;\n\n d.activeTouch = null;\n\n input.init(d);\n }\n\n // Find the line object corresponding to the given line number.\n function getLine(doc, n) {\n n -= doc.first;\n if (n < 0 || n >= doc.size) { throw new Error(\"There is no line \" + (n + doc.first) + \" in the document.\") }\n var chunk = doc;\n while (!chunk.lines) {\n for (var i = 0;; ++i) {\n var child = chunk.children[i], sz = child.chunkSize();\n if (n < sz) { chunk = child; break }\n n -= sz;\n }\n }\n return chunk.lines[n]\n }\n\n // Get the part of a document between two positions, as an array of\n // strings.\n function getBetween(doc, start, end) {\n var out = [], n = start.line;\n doc.iter(start.line, end.line + 1, function (line) {\n var text = line.text;\n if (n == end.line) { text = text.slice(0, end.ch); }\n if (n == start.line) { text = text.slice(start.ch); }\n out.push(text);\n ++n;\n });\n return out\n }\n // Get the lines between from and to, as array of strings.\n function getLines(doc, from, to) {\n var out = [];\n doc.iter(from, to, function (line) { out.push(line.text); }); // iter aborts when callback returns truthy value\n return out\n }\n\n // Update the height of a line, propagating the height change\n // upwards to parent nodes.\n function updateLineHeight(line, height) {\n var diff = height - line.height;\n if (diff) { for (var n = line; n; n = n.parent) { n.height += diff; } }\n }\n\n // Given a line object, find its line number by walking up through\n // its parent links.\n function lineNo(line) {\n if (line.parent == null) { return null }\n var cur = line.parent, no = indexOf(cur.lines, line);\n for (var chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) {\n for (var i = 0;; ++i) {\n if (chunk.children[i] == cur) { break }\n no += chunk.children[i].chunkSize();\n }\n }\n return no + cur.first\n }\n\n // Find the line at the given vertical position, using the height\n // information in the document tree.\n function lineAtHeight(chunk, h) {\n var n = chunk.first;\n outer: do {\n for (var i$1 = 0; i$1 < chunk.children.length; ++i$1) {\n var child = chunk.children[i$1], ch = child.height;\n if (h < ch) { chunk = child; continue outer }\n h -= ch;\n n += child.chunkSize();\n }\n return n\n } while (!chunk.lines)\n var i = 0;\n for (; i < chunk.lines.length; ++i) {\n var line = chunk.lines[i], lh = line.height;\n if (h < lh) { break }\n h -= lh;\n }\n return n + i\n }\n\n function isLine(doc, l) {return l >= doc.first && l < doc.first + doc.size}\n\n function lineNumberFor(options, i) {\n return String(options.lineNumberFormatter(i + options.firstLineNumber))\n }\n\n // A Pos instance represents a position within the text.\n function Pos(line, ch, sticky) {\n if ( sticky === void 0 ) sticky = null;\n\n if (!(this instanceof Pos)) { return new Pos(line, ch, sticky) }\n this.line = line;\n this.ch = ch;\n this.sticky = sticky;\n }\n\n // Compare two positions, return 0 if they are the same, a negative\n // number when a is less, and a positive number otherwise.\n function cmp(a, b) { return a.line - b.line || a.ch - b.ch }\n\n function equalCursorPos(a, b) { return a.sticky == b.sticky && cmp(a, b) == 0 }\n\n function copyPos(x) {return Pos(x.line, x.ch)}\n function maxPos(a, b) { return cmp(a, b) < 0 ? b : a }\n function minPos(a, b) { return cmp(a, b) < 0 ? a : b }\n\n // Most of the external API clips given positions to make sure they\n // actually exist within the document.\n function clipLine(doc, n) {return Math.max(doc.first, Math.min(n, doc.first + doc.size - 1))}\n function clipPos(doc, pos) {\n if (pos.line < doc.first) { return Pos(doc.first, 0) }\n var last = doc.first + doc.size - 1;\n if (pos.line > last) { return Pos(last, getLine(doc, last).text.length) }\n return clipToLen(pos, getLine(doc, pos.line).text.length)\n }\n function clipToLen(pos, linelen) {\n var ch = pos.ch;\n if (ch == null || ch > linelen) { return Pos(pos.line, linelen) }\n else if (ch < 0) { return Pos(pos.line, 0) }\n else { return pos }\n }\n function clipPosArray(doc, array) {\n var out = [];\n for (var i = 0; i < array.length; i++) { out[i] = clipPos(doc, array[i]); }\n return out\n }\n\n // Optimize some code when these features are not used.\n var sawReadOnlySpans = false, sawCollapsedSpans = false;\n\n function seeReadOnlySpans() {\n sawReadOnlySpans = true;\n }\n\n function seeCollapsedSpans() {\n sawCollapsedSpans = true;\n }\n\n // TEXTMARKER SPANS\n\n function MarkedSpan(marker, from, to) {\n this.marker = marker;\n this.from = from; this.to = to;\n }\n\n // Search an array of spans for a span matching the given marker.\n function getMarkedSpanFor(spans, marker) {\n if (spans) { for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if (span.marker == marker) { return span }\n } }\n }\n // Remove a span from an array, returning undefined if no spans are\n // left (we don't store arrays for lines without spans).\n function removeMarkedSpan(spans, span) {\n var r;\n for (var i = 0; i < spans.length; ++i)\n { if (spans[i] != span) { (r || (r = [])).push(spans[i]); } }\n return r\n }\n // Add a span to a line.\n function addMarkedSpan(line, span) {\n line.markedSpans = line.markedSpans ? line.markedSpans.concat([span]) : [span];\n span.marker.attachLine(line);\n }\n\n // Used for the algorithm that adjusts markers for a change in the\n // document. These functions cut an array of spans at a given\n // character position, returning an array of remaining chunks (or\n // undefined if nothing remains).\n function markedSpansBefore(old, startCh, isInsert) {\n var nw;\n if (old) { for (var i = 0; i < old.length; ++i) {\n var span = old[i], marker = span.marker;\n var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= startCh : span.from < startCh);\n if (startsBefore || span.from == startCh && marker.type == \"bookmark\" && (!isInsert || !span.marker.insertLeft)) {\n var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= startCh : span.to > startCh)\n ;(nw || (nw = [])).push(new MarkedSpan(marker, span.from, endsAfter ? null : span.to));\n }\n } }\n return nw\n }\n function markedSpansAfter(old, endCh, isInsert) {\n var nw;\n if (old) { for (var i = 0; i < old.length; ++i) {\n var span = old[i], marker = span.marker;\n var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= endCh : span.to > endCh);\n if (endsAfter || span.from == endCh && marker.type == \"bookmark\" && (!isInsert || span.marker.insertLeft)) {\n var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= endCh : span.from < endCh)\n ;(nw || (nw = [])).push(new MarkedSpan(marker, startsBefore ? null : span.from - endCh,\n span.to == null ? null : span.to - endCh));\n }\n } }\n return nw\n }\n\n // Given a change object, compute the new set of marker spans that\n // cover the line in which the change took place. Removes spans\n // entirely within the change, reconnects spans belonging to the\n // same marker that appear on both sides of the change, and cuts off\n // spans partially within the change. Returns an array of span\n // arrays with one element for each line in (after) the change.\n function stretchSpansOverChange(doc, change) {\n if (change.full) { return null }\n var oldFirst = isLine(doc, change.from.line) && getLine(doc, change.from.line).markedSpans;\n var oldLast = isLine(doc, change.to.line) && getLine(doc, change.to.line).markedSpans;\n if (!oldFirst && !oldLast) { return null }\n\n var startCh = change.from.ch, endCh = change.to.ch, isInsert = cmp(change.from, change.to) == 0;\n // Get the spans that 'stick out' on both sides\n var first = markedSpansBefore(oldFirst, startCh, isInsert);\n var last = markedSpansAfter(oldLast, endCh, isInsert);\n\n // Next, merge those two ends\n var sameLine = change.text.length == 1, offset = lst(change.text).length + (sameLine ? startCh : 0);\n if (first) {\n // Fix up .to properties of first\n for (var i = 0; i < first.length; ++i) {\n var span = first[i];\n if (span.to == null) {\n var found = getMarkedSpanFor(last, span.marker);\n if (!found) { span.to = startCh; }\n else if (sameLine) { span.to = found.to == null ? null : found.to + offset; }\n }\n }\n }\n if (last) {\n // Fix up .from in last (or move them into first in case of sameLine)\n for (var i$1 = 0; i$1 < last.length; ++i$1) {\n var span$1 = last[i$1];\n if (span$1.to != null) { span$1.to += offset; }\n if (span$1.from == null) {\n var found$1 = getMarkedSpanFor(first, span$1.marker);\n if (!found$1) {\n span$1.from = offset;\n if (sameLine) { (first || (first = [])).push(span$1); }\n }\n } else {\n span$1.from += offset;\n if (sameLine) { (first || (first = [])).push(span$1); }\n }\n }\n }\n // Make sure we didn't create any zero-length spans\n if (first) { first = clearEmptySpans(first); }\n if (last && last != first) { last = clearEmptySpans(last); }\n\n var newMarkers = [first];\n if (!sameLine) {\n // Fill gap with whole-line-spans\n var gap = change.text.length - 2, gapMarkers;\n if (gap > 0 && first)\n { for (var i$2 = 0; i$2 < first.length; ++i$2)\n { if (first[i$2].to == null)\n { (gapMarkers || (gapMarkers = [])).push(new MarkedSpan(first[i$2].marker, null, null)); } } }\n for (var i$3 = 0; i$3 < gap; ++i$3)\n { newMarkers.push(gapMarkers); }\n newMarkers.push(last);\n }\n return newMarkers\n }\n\n // Remove spans that are empty and don't have a clearWhenEmpty\n // option of false.\n function clearEmptySpans(spans) {\n for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if (span.from != null && span.from == span.to && span.marker.clearWhenEmpty !== false)\n { spans.splice(i--, 1); }\n }\n if (!spans.length) { return null }\n return spans\n }\n\n // Used to 'clip' out readOnly ranges when making a change.\n function removeReadOnlyRanges(doc, from, to) {\n var markers = null;\n doc.iter(from.line, to.line + 1, function (line) {\n if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) {\n var mark = line.markedSpans[i].marker;\n if (mark.readOnly && (!markers || indexOf(markers, mark) == -1))\n { (markers || (markers = [])).push(mark); }\n } }\n });\n if (!markers) { return null }\n var parts = [{from: from, to: to}];\n for (var i = 0; i < markers.length; ++i) {\n var mk = markers[i], m = mk.find(0);\n for (var j = 0; j < parts.length; ++j) {\n var p = parts[j];\n if (cmp(p.to, m.from) < 0 || cmp(p.from, m.to) > 0) { continue }\n var newParts = [j, 1], dfrom = cmp(p.from, m.from), dto = cmp(p.to, m.to);\n if (dfrom < 0 || !mk.inclusiveLeft && !dfrom)\n { newParts.push({from: p.from, to: m.from}); }\n if (dto > 0 || !mk.inclusiveRight && !dto)\n { newParts.push({from: m.to, to: p.to}); }\n parts.splice.apply(parts, newParts);\n j += newParts.length - 3;\n }\n }\n return parts\n }\n\n // Connect or disconnect spans from a line.\n function detachMarkedSpans(line) {\n var spans = line.markedSpans;\n if (!spans) { return }\n for (var i = 0; i < spans.length; ++i)\n { spans[i].marker.detachLine(line); }\n line.markedSpans = null;\n }\n function attachMarkedSpans(line, spans) {\n if (!spans) { return }\n for (var i = 0; i < spans.length; ++i)\n { spans[i].marker.attachLine(line); }\n line.markedSpans = spans;\n }\n\n // Helpers used when computing which overlapping collapsed span\n // counts as the larger one.\n function extraLeft(marker) { return marker.inclusiveLeft ? -1 : 0 }\n function extraRight(marker) { return marker.inclusiveRight ? 1 : 0 }\n\n // Returns a number indicating which of two overlapping collapsed\n // spans is larger (and thus includes the other). Falls back to\n // comparing ids when the spans cover exactly the same range.\n function compareCollapsedMarkers(a, b) {\n var lenDiff = a.lines.length - b.lines.length;\n if (lenDiff != 0) { return lenDiff }\n var aPos = a.find(), bPos = b.find();\n var fromCmp = cmp(aPos.from, bPos.from) || extraLeft(a) - extraLeft(b);\n if (fromCmp) { return -fromCmp }\n var toCmp = cmp(aPos.to, bPos.to) || extraRight(a) - extraRight(b);\n if (toCmp) { return toCmp }\n return b.id - a.id\n }\n\n // Find out whether a line ends or starts in a collapsed span. If\n // so, return the marker for that span.\n function collapsedSpanAtSide(line, start) {\n var sps = sawCollapsedSpans && line.markedSpans, found;\n if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) {\n sp = sps[i];\n if (sp.marker.collapsed && (start ? sp.from : sp.to) == null &&\n (!found || compareCollapsedMarkers(found, sp.marker) < 0))\n { found = sp.marker; }\n } }\n return found\n }\n function collapsedSpanAtStart(line) { return collapsedSpanAtSide(line, true) }\n function collapsedSpanAtEnd(line) { return collapsedSpanAtSide(line, false) }\n\n function collapsedSpanAround(line, ch) {\n var sps = sawCollapsedSpans && line.markedSpans, found;\n if (sps) { for (var i = 0; i < sps.length; ++i) {\n var sp = sps[i];\n if (sp.marker.collapsed && (sp.from == null || sp.from < ch) && (sp.to == null || sp.to > ch) &&\n (!found || compareCollapsedMarkers(found, sp.marker) < 0)) { found = sp.marker; }\n } }\n return found\n }\n\n // Test whether there exists a collapsed span that partially\n // overlaps (covers the start or end, but not both) of a new span.\n // Such overlap is not allowed.\n function conflictingCollapsedRange(doc, lineNo$$1, from, to, marker) {\n var line = getLine(doc, lineNo$$1);\n var sps = sawCollapsedSpans && line.markedSpans;\n if (sps) { for (var i = 0; i < sps.length; ++i) {\n var sp = sps[i];\n if (!sp.marker.collapsed) { continue }\n var found = sp.marker.find(0);\n var fromCmp = cmp(found.from, from) || extraLeft(sp.marker) - extraLeft(marker);\n var toCmp = cmp(found.to, to) || extraRight(sp.marker) - extraRight(marker);\n if (fromCmp >= 0 && toCmp <= 0 || fromCmp <= 0 && toCmp >= 0) { continue }\n if (fromCmp <= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.to, from) >= 0 : cmp(found.to, from) > 0) ||\n fromCmp >= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.from, to) <= 0 : cmp(found.from, to) < 0))\n { return true }\n } }\n }\n\n // A visual line is a line as drawn on the screen. Folding, for\n // example, can cause multiple logical lines to appear on the same\n // visual line. This finds the start of the visual line that the\n // given line is part of (usually that is the line itself).\n function visualLine(line) {\n var merged;\n while (merged = collapsedSpanAtStart(line))\n { line = merged.find(-1, true).line; }\n return line\n }\n\n function visualLineEnd(line) {\n var merged;\n while (merged = collapsedSpanAtEnd(line))\n { line = merged.find(1, true).line; }\n return line\n }\n\n // Returns an array of logical lines that continue the visual line\n // started by the argument, or undefined if there are no such lines.\n function visualLineContinued(line) {\n var merged, lines;\n while (merged = collapsedSpanAtEnd(line)) {\n line = merged.find(1, true).line\n ;(lines || (lines = [])).push(line);\n }\n return lines\n }\n\n // Get the line number of the start of the visual line that the\n // given line number is part of.\n function visualLineNo(doc, lineN) {\n var line = getLine(doc, lineN), vis = visualLine(line);\n if (line == vis) { return lineN }\n return lineNo(vis)\n }\n\n // Get the line number of the start of the next visual line after\n // the given line.\n function visualLineEndNo(doc, lineN) {\n if (lineN > doc.lastLine()) { return lineN }\n var line = getLine(doc, lineN), merged;\n if (!lineIsHidden(doc, line)) { return lineN }\n while (merged = collapsedSpanAtEnd(line))\n { line = merged.find(1, true).line; }\n return lineNo(line) + 1\n }\n\n // Compute whether a line is hidden. Lines count as hidden when they\n // are part of a visual line that starts with another line, or when\n // they are entirely covered by collapsed, non-widget span.\n function lineIsHidden(doc, line) {\n var sps = sawCollapsedSpans && line.markedSpans;\n if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) {\n sp = sps[i];\n if (!sp.marker.collapsed) { continue }\n if (sp.from == null) { return true }\n if (sp.marker.widgetNode) { continue }\n if (sp.from == 0 && sp.marker.inclusiveLeft && lineIsHiddenInner(doc, line, sp))\n { return true }\n } }\n }\n function lineIsHiddenInner(doc, line, span) {\n if (span.to == null) {\n var end = span.marker.find(1, true);\n return lineIsHiddenInner(doc, end.line, getMarkedSpanFor(end.line.markedSpans, span.marker))\n }\n if (span.marker.inclusiveRight && span.to == line.text.length)\n { return true }\n for (var sp = (void 0), i = 0; i < line.markedSpans.length; ++i) {\n sp = line.markedSpans[i];\n if (sp.marker.collapsed && !sp.marker.widgetNode && sp.from == span.to &&\n (sp.to == null || sp.to != span.from) &&\n (sp.marker.inclusiveLeft || span.marker.inclusiveRight) &&\n lineIsHiddenInner(doc, line, sp)) { return true }\n }\n }\n\n // Find the height above the given line.\n function heightAtLine(lineObj) {\n lineObj = visualLine(lineObj);\n\n var h = 0, chunk = lineObj.parent;\n for (var i = 0; i < chunk.lines.length; ++i) {\n var line = chunk.lines[i];\n if (line == lineObj) { break }\n else { h += line.height; }\n }\n for (var p = chunk.parent; p; chunk = p, p = chunk.parent) {\n for (var i$1 = 0; i$1 < p.children.length; ++i$1) {\n var cur = p.children[i$1];\n if (cur == chunk) { break }\n else { h += cur.height; }\n }\n }\n return h\n }\n\n // Compute the character length of a line, taking into account\n // collapsed ranges (see markText) that might hide parts, and join\n // other lines onto it.\n function lineLength(line) {\n if (line.height == 0) { return 0 }\n var len = line.text.length, merged, cur = line;\n while (merged = collapsedSpanAtStart(cur)) {\n var found = merged.find(0, true);\n cur = found.from.line;\n len += found.from.ch - found.to.ch;\n }\n cur = line;\n while (merged = collapsedSpanAtEnd(cur)) {\n var found$1 = merged.find(0, true);\n len -= cur.text.length - found$1.from.ch;\n cur = found$1.to.line;\n len += cur.text.length - found$1.to.ch;\n }\n return len\n }\n\n // Find the longest line in the document.\n function findMaxLine(cm) {\n var d = cm.display, doc = cm.doc;\n d.maxLine = getLine(doc, doc.first);\n d.maxLineLength = lineLength(d.maxLine);\n d.maxLineChanged = true;\n doc.iter(function (line) {\n var len = lineLength(line);\n if (len > d.maxLineLength) {\n d.maxLineLength = len;\n d.maxLine = line;\n }\n });\n }\n\n // BIDI HELPERS\n\n function iterateBidiSections(order, from, to, f) {\n if (!order) { return f(from, to, \"ltr\", 0) }\n var found = false;\n for (var i = 0; i < order.length; ++i) {\n var part = order[i];\n if (part.from < to && part.to > from || from == to && part.to == from) {\n f(Math.max(part.from, from), Math.min(part.to, to), part.level == 1 ? \"rtl\" : \"ltr\", i);\n found = true;\n }\n }\n if (!found) { f(from, to, \"ltr\"); }\n }\n\n var bidiOther = null;\n function getBidiPartAt(order, ch, sticky) {\n var found;\n bidiOther = null;\n for (var i = 0; i < order.length; ++i) {\n var cur = order[i];\n if (cur.from < ch && cur.to > ch) { return i }\n if (cur.to == ch) {\n if (cur.from != cur.to && sticky == \"before\") { found = i; }\n else { bidiOther = i; }\n }\n if (cur.from == ch) {\n if (cur.from != cur.to && sticky != \"before\") { found = i; }\n else { bidiOther = i; }\n }\n }\n return found != null ? found : bidiOther\n }\n\n // Bidirectional ordering algorithm\n // See http://unicode.org/reports/tr9/tr9-13.html for the algorithm\n // that this (partially) implements.\n\n // One-char codes used for character types:\n // L (L): Left-to-Right\n // R (R): Right-to-Left\n // r (AL): Right-to-Left Arabic\n // 1 (EN): European Number\n // + (ES): European Number Separator\n // % (ET): European Number Terminator\n // n (AN): Arabic Number\n // , (CS): Common Number Separator\n // m (NSM): Non-Spacing Mark\n // b (BN): Boundary Neutral\n // s (B): Paragraph Separator\n // t (S): Segment Separator\n // w (WS): Whitespace\n // N (ON): Other Neutrals\n\n // Returns null if characters are ordered as they appear\n // (left-to-right), or an array of sections ({from, to, level}\n // objects) in the order in which they occur visually.\n var bidiOrdering = (function() {\n // Character types for codepoints 0 to 0xff\n var lowTypes = \"bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN\";\n // Character types for codepoints 0x600 to 0x6f9\n var arabicTypes = \"nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111\";\n function charType(code) {\n if (code <= 0xf7) { return lowTypes.charAt(code) }\n else if (0x590 <= code && code <= 0x5f4) { return \"R\" }\n else if (0x600 <= code && code <= 0x6f9) { return arabicTypes.charAt(code - 0x600) }\n else if (0x6ee <= code && code <= 0x8ac) { return \"r\" }\n else if (0x2000 <= code && code <= 0x200b) { return \"w\" }\n else if (code == 0x200c) { return \"b\" }\n else { return \"L\" }\n }\n\n var bidiRE = /[\\u0590-\\u05f4\\u0600-\\u06ff\\u0700-\\u08ac]/;\n var isNeutral = /[stwN]/, isStrong = /[LRr]/, countsAsLeft = /[Lb1n]/, countsAsNum = /[1n]/;\n\n function BidiSpan(level, from, to) {\n this.level = level;\n this.from = from; this.to = to;\n }\n\n return function(str, direction) {\n var outerType = direction == \"ltr\" ? \"L\" : \"R\";\n\n if (str.length == 0 || direction == \"ltr\" && !bidiRE.test(str)) { return false }\n var len = str.length, types = [];\n for (var i = 0; i < len; ++i)\n { types.push(charType(str.charCodeAt(i))); }\n\n // W1. Examine each non-spacing mark (NSM) in the level run, and\n // change the type of the NSM to the type of the previous\n // character. If the NSM is at the start of the level run, it will\n // get the type of sor.\n for (var i$1 = 0, prev = outerType; i$1 < len; ++i$1) {\n var type = types[i$1];\n if (type == \"m\") { types[i$1] = prev; }\n else { prev = type; }\n }\n\n // W2. Search backwards from each instance of a European number\n // until the first strong type (R, L, AL, or sor) is found. If an\n // AL is found, change the type of the European number to Arabic\n // number.\n // W3. Change all ALs to R.\n for (var i$2 = 0, cur = outerType; i$2 < len; ++i$2) {\n var type$1 = types[i$2];\n if (type$1 == \"1\" && cur == \"r\") { types[i$2] = \"n\"; }\n else if (isStrong.test(type$1)) { cur = type$1; if (type$1 == \"r\") { types[i$2] = \"R\"; } }\n }\n\n // W4. A single European separator between two European numbers\n // changes to a European number. A single common separator between\n // two numbers of the same type changes to that type.\n for (var i$3 = 1, prev$1 = types[0]; i$3 < len - 1; ++i$3) {\n var type$2 = types[i$3];\n if (type$2 == \"+\" && prev$1 == \"1\" && types[i$3+1] == \"1\") { types[i$3] = \"1\"; }\n else if (type$2 == \",\" && prev$1 == types[i$3+1] &&\n (prev$1 == \"1\" || prev$1 == \"n\")) { types[i$3] = prev$1; }\n prev$1 = type$2;\n }\n\n // W5. A sequence of European terminators adjacent to European\n // numbers changes to all European numbers.\n // W6. Otherwise, separators and terminators change to Other\n // Neutral.\n for (var i$4 = 0; i$4 < len; ++i$4) {\n var type$3 = types[i$4];\n if (type$3 == \",\") { types[i$4] = \"N\"; }\n else if (type$3 == \"%\") {\n var end = (void 0);\n for (end = i$4 + 1; end < len && types[end] == \"%\"; ++end) {}\n var replace = (i$4 && types[i$4-1] == \"!\") || (end < len && types[end] == \"1\") ? \"1\" : \"N\";\n for (var j = i$4; j < end; ++j) { types[j] = replace; }\n i$4 = end - 1;\n }\n }\n\n // W7. Search backwards from each instance of a European number\n // until the first strong type (R, L, or sor) is found. If an L is\n // found, then change the type of the European number to L.\n for (var i$5 = 0, cur$1 = outerType; i$5 < len; ++i$5) {\n var type$4 = types[i$5];\n if (cur$1 == \"L\" && type$4 == \"1\") { types[i$5] = \"L\"; }\n else if (isStrong.test(type$4)) { cur$1 = type$4; }\n }\n\n // N1. A sequence of neutrals takes the direction of the\n // surrounding strong text if the text on both sides has the same\n // direction. European and Arabic numbers act as if they were R in\n // terms of their influence on neutrals. Start-of-level-run (sor)\n // and end-of-level-run (eor) are used at level run boundaries.\n // N2. Any remaining neutrals take the embedding direction.\n for (var i$6 = 0; i$6 < len; ++i$6) {\n if (isNeutral.test(types[i$6])) {\n var end$1 = (void 0);\n for (end$1 = i$6 + 1; end$1 < len && isNeutral.test(types[end$1]); ++end$1) {}\n var before = (i$6 ? types[i$6-1] : outerType) == \"L\";\n var after = (end$1 < len ? types[end$1] : outerType) == \"L\";\n var replace$1 = before == after ? (before ? \"L\" : \"R\") : outerType;\n for (var j$1 = i$6; j$1 < end$1; ++j$1) { types[j$1] = replace$1; }\n i$6 = end$1 - 1;\n }\n }\n\n // Here we depart from the documented algorithm, in order to avoid\n // building up an actual levels array. Since there are only three\n // levels (0, 1, 2) in an implementation that doesn't take\n // explicit embedding into account, we can build up the order on\n // the fly, without following the level-based algorithm.\n var order = [], m;\n for (var i$7 = 0; i$7 < len;) {\n if (countsAsLeft.test(types[i$7])) {\n var start = i$7;\n for (++i$7; i$7 < len && countsAsLeft.test(types[i$7]); ++i$7) {}\n order.push(new BidiSpan(0, start, i$7));\n } else {\n var pos = i$7, at = order.length;\n for (++i$7; i$7 < len && types[i$7] != \"L\"; ++i$7) {}\n for (var j$2 = pos; j$2 < i$7;) {\n if (countsAsNum.test(types[j$2])) {\n if (pos < j$2) { order.splice(at, 0, new BidiSpan(1, pos, j$2)); }\n var nstart = j$2;\n for (++j$2; j$2 < i$7 && countsAsNum.test(types[j$2]); ++j$2) {}\n order.splice(at, 0, new BidiSpan(2, nstart, j$2));\n pos = j$2;\n } else { ++j$2; }\n }\n if (pos < i$7) { order.splice(at, 0, new BidiSpan(1, pos, i$7)); }\n }\n }\n if (direction == \"ltr\") {\n if (order[0].level == 1 && (m = str.match(/^\\s+/))) {\n order[0].from = m[0].length;\n order.unshift(new BidiSpan(0, 0, m[0].length));\n }\n if (lst(order).level == 1 && (m = str.match(/\\s+$/))) {\n lst(order).to -= m[0].length;\n order.push(new BidiSpan(0, len - m[0].length, len));\n }\n }\n\n return direction == \"rtl\" ? order.reverse() : order\n }\n })();\n\n // Get the bidi ordering for the given line (and cache it). Returns\n // false for lines that are fully left-to-right, and an array of\n // BidiSpan objects otherwise.\n function getOrder(line, direction) {\n var order = line.order;\n if (order == null) { order = line.order = bidiOrdering(line.text, direction); }\n return order\n }\n\n // EVENT HANDLING\n\n // Lightweight event framework. on/off also work on DOM nodes,\n // registering native DOM handlers.\n\n var noHandlers = [];\n\n var on = function(emitter, type, f) {\n if (emitter.addEventListener) {\n emitter.addEventListener(type, f, false);\n } else if (emitter.attachEvent) {\n emitter.attachEvent(\"on\" + type, f);\n } else {\n var map$$1 = emitter._handlers || (emitter._handlers = {});\n map$$1[type] = (map$$1[type] || noHandlers).concat(f);\n }\n };\n\n function getHandlers(emitter, type) {\n return emitter._handlers && emitter._handlers[type] || noHandlers\n }\n\n function off(emitter, type, f) {\n if (emitter.removeEventListener) {\n emitter.removeEventListener(type, f, false);\n } else if (emitter.detachEvent) {\n emitter.detachEvent(\"on\" + type, f);\n } else {\n var map$$1 = emitter._handlers, arr = map$$1 && map$$1[type];\n if (arr) {\n var index = indexOf(arr, f);\n if (index > -1)\n { map$$1[type] = arr.slice(0, index).concat(arr.slice(index + 1)); }\n }\n }\n }\n\n function signal(emitter, type /*, values...*/) {\n var handlers = getHandlers(emitter, type);\n if (!handlers.length) { return }\n var args = Array.prototype.slice.call(arguments, 2);\n for (var i = 0; i < handlers.length; ++i) { handlers[i].apply(null, args); }\n }\n\n // The DOM events that CodeMirror handles can be overridden by\n // registering a (non-DOM) handler on the editor for the event name,\n // and preventDefault-ing the event in that handler.\n function signalDOMEvent(cm, e, override) {\n if (typeof e == \"string\")\n { e = {type: e, preventDefault: function() { this.defaultPrevented = true; }}; }\n signal(cm, override || e.type, cm, e);\n return e_defaultPrevented(e) || e.codemirrorIgnore\n }\n\n function signalCursorActivity(cm) {\n var arr = cm._handlers && cm._handlers.cursorActivity;\n if (!arr) { return }\n var set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = []);\n for (var i = 0; i < arr.length; ++i) { if (indexOf(set, arr[i]) == -1)\n { set.push(arr[i]); } }\n }\n\n function hasHandler(emitter, type) {\n return getHandlers(emitter, type).length > 0\n }\n\n // Add on and off methods to a constructor's prototype, to make\n // registering events on such objects more convenient.\n function eventMixin(ctor) {\n ctor.prototype.on = function(type, f) {on(this, type, f);};\n ctor.prototype.off = function(type, f) {off(this, type, f);};\n }\n\n // Due to the fact that we still support jurassic IE versions, some\n // compatibility wrappers are needed.\n\n function e_preventDefault(e) {\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n }\n function e_stopPropagation(e) {\n if (e.stopPropagation) { e.stopPropagation(); }\n else { e.cancelBubble = true; }\n }\n function e_defaultPrevented(e) {\n return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false\n }\n function e_stop(e) {e_preventDefault(e); e_stopPropagation(e);}\n\n function e_target(e) {return e.target || e.srcElement}\n function e_button(e) {\n var b = e.which;\n if (b == null) {\n if (e.button & 1) { b = 1; }\n else if (e.button & 2) { b = 3; }\n else if (e.button & 4) { b = 2; }\n }\n if (mac && e.ctrlKey && b == 1) { b = 3; }\n return b\n }\n\n // Detect drag-and-drop\n var dragAndDrop = function() {\n // There is *some* kind of drag-and-drop support in IE6-8, but I\n // couldn't get it to work yet.\n if (ie && ie_version < 9) { return false }\n var div = elt('div');\n return \"draggable\" in div || \"dragDrop\" in div\n }();\n\n var zwspSupported;\n function zeroWidthElement(measure) {\n if (zwspSupported == null) {\n var test = elt(\"span\", \"\\u200b\");\n removeChildrenAndAdd(measure, elt(\"span\", [test, document.createTextNode(\"x\")]));\n if (measure.firstChild.offsetHeight != 0)\n { zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8); }\n }\n var node = zwspSupported ? elt(\"span\", \"\\u200b\") :\n elt(\"span\", \"\\u00a0\", null, \"display: inline-block; width: 1px; margin-right: -1px\");\n node.setAttribute(\"cm-text\", \"\");\n return node\n }\n\n // Feature-detect IE's crummy client rect reporting for bidi text\n var badBidiRects;\n function hasBadBidiRects(measure) {\n if (badBidiRects != null) { return badBidiRects }\n var txt = removeChildrenAndAdd(measure, document.createTextNode(\"A\\u062eA\"));\n var r0 = range(txt, 0, 1).getBoundingClientRect();\n var r1 = range(txt, 1, 2).getBoundingClientRect();\n removeChildren(measure);\n if (!r0 || r0.left == r0.right) { return false } // Safari returns null in some cases (#2780)\n return badBidiRects = (r1.right - r0.right < 3)\n }\n\n // See if \"\".split is the broken IE version, if so, provide an\n // alternative way to split lines.\n var splitLinesAuto = \"\\n\\nb\".split(/\\n/).length != 3 ? function (string) {\n var pos = 0, result = [], l = string.length;\n while (pos <= l) {\n var nl = string.indexOf(\"\\n\", pos);\n if (nl == -1) { nl = string.length; }\n var line = string.slice(pos, string.charAt(nl - 1) == \"\\r\" ? nl - 1 : nl);\n var rt = line.indexOf(\"\\r\");\n if (rt != -1) {\n result.push(line.slice(0, rt));\n pos += rt + 1;\n } else {\n result.push(line);\n pos = nl + 1;\n }\n }\n return result\n } : function (string) { return string.split(/\\r\\n?|\\n/); };\n\n var hasSelection = window.getSelection ? function (te) {\n try { return te.selectionStart != te.selectionEnd }\n catch(e) { return false }\n } : function (te) {\n var range$$1;\n try {range$$1 = te.ownerDocument.selection.createRange();}\n catch(e) {}\n if (!range$$1 || range$$1.parentElement() != te) { return false }\n return range$$1.compareEndPoints(\"StartToEnd\", range$$1) != 0\n };\n\n var hasCopyEvent = (function () {\n var e = elt(\"div\");\n if (\"oncopy\" in e) { return true }\n e.setAttribute(\"oncopy\", \"return;\");\n return typeof e.oncopy == \"function\"\n })();\n\n var badZoomedRects = null;\n function hasBadZoomedRects(measure) {\n if (badZoomedRects != null) { return badZoomedRects }\n var node = removeChildrenAndAdd(measure, elt(\"span\", \"x\"));\n var normal = node.getBoundingClientRect();\n var fromRange = range(node, 0, 1).getBoundingClientRect();\n return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1\n }\n\n // Known modes, by name and by MIME\n var modes = {}, mimeModes = {};\n\n // Extra arguments are stored as the mode's dependencies, which is\n // used by (legacy) mechanisms like loadmode.js to automatically\n // load a mode. (Preferred mechanism is the require/define calls.)\n function defineMode(name, mode) {\n if (arguments.length > 2)\n { mode.dependencies = Array.prototype.slice.call(arguments, 2); }\n modes[name] = mode;\n }\n\n function defineMIME(mime, spec) {\n mimeModes[mime] = spec;\n }\n\n // Given a MIME type, a {name, ...options} config object, or a name\n // string, return a mode config object.\n function resolveMode(spec) {\n if (typeof spec == \"string\" && mimeModes.hasOwnProperty(spec)) {\n spec = mimeModes[spec];\n } else if (spec && typeof spec.name == \"string\" && mimeModes.hasOwnProperty(spec.name)) {\n var found = mimeModes[spec.name];\n if (typeof found == \"string\") { found = {name: found}; }\n spec = createObj(found, spec);\n spec.name = found.name;\n } else if (typeof spec == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+xml$/.test(spec)) {\n return resolveMode(\"application/xml\")\n } else if (typeof spec == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+json$/.test(spec)) {\n return resolveMode(\"application/json\")\n }\n if (typeof spec == \"string\") { return {name: spec} }\n else { return spec || {name: \"null\"} }\n }\n\n // Given a mode spec (anything that resolveMode accepts), find and\n // initialize an actual mode object.\n function getMode(options, spec) {\n spec = resolveMode(spec);\n var mfactory = modes[spec.name];\n if (!mfactory) { return getMode(options, \"text/plain\") }\n var modeObj = mfactory(options, spec);\n if (modeExtensions.hasOwnProperty(spec.name)) {\n var exts = modeExtensions[spec.name];\n for (var prop in exts) {\n if (!exts.hasOwnProperty(prop)) { continue }\n if (modeObj.hasOwnProperty(prop)) { modeObj[\"_\" + prop] = modeObj[prop]; }\n modeObj[prop] = exts[prop];\n }\n }\n modeObj.name = spec.name;\n if (spec.helperType) { modeObj.helperType = spec.helperType; }\n if (spec.modeProps) { for (var prop$1 in spec.modeProps)\n { modeObj[prop$1] = spec.modeProps[prop$1]; } }\n\n return modeObj\n }\n\n // This can be used to attach properties to mode objects from\n // outside the actual mode definition.\n var modeExtensions = {};\n function extendMode(mode, properties) {\n var exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : (modeExtensions[mode] = {});\n copyObj(properties, exts);\n }\n\n function copyState(mode, state) {\n if (state === true) { return state }\n if (mode.copyState) { return mode.copyState(state) }\n var nstate = {};\n for (var n in state) {\n var val = state[n];\n if (val instanceof Array) { val = val.concat([]); }\n nstate[n] = val;\n }\n return nstate\n }\n\n // Given a mode and a state (for that mode), find the inner mode and\n // state at the position that the state refers to.\n function innerMode(mode, state) {\n var info;\n while (mode.innerMode) {\n info = mode.innerMode(state);\n if (!info || info.mode == mode) { break }\n state = info.state;\n mode = info.mode;\n }\n return info || {mode: mode, state: state}\n }\n\n function startState(mode, a1, a2) {\n return mode.startState ? mode.startState(a1, a2) : true\n }\n\n // STRING STREAM\n\n // Fed to the mode parsers, provides helper functions to make\n // parsers more succinct.\n\n var StringStream = function(string, tabSize, lineOracle) {\n this.pos = this.start = 0;\n this.string = string;\n this.tabSize = tabSize || 8;\n this.lastColumnPos = this.lastColumnValue = 0;\n this.lineStart = 0;\n this.lineOracle = lineOracle;\n };\n\n StringStream.prototype.eol = function () {return this.pos >= this.string.length};\n StringStream.prototype.sol = function () {return this.pos == this.lineStart};\n StringStream.prototype.peek = function () {return this.string.charAt(this.pos) || undefined};\n StringStream.prototype.next = function () {\n if (this.pos < this.string.length)\n { return this.string.charAt(this.pos++) }\n };\n StringStream.prototype.eat = function (match) {\n var ch = this.string.charAt(this.pos);\n var ok;\n if (typeof match == \"string\") { ok = ch == match; }\n else { ok = ch && (match.test ? match.test(ch) : match(ch)); }\n if (ok) {++this.pos; return ch}\n };\n StringStream.prototype.eatWhile = function (match) {\n var start = this.pos;\n while (this.eat(match)){}\n return this.pos > start\n };\n StringStream.prototype.eatSpace = function () {\n var this$1 = this;\n\n var start = this.pos;\n while (/[\\s\\u00a0]/.test(this.string.charAt(this.pos))) { ++this$1.pos; }\n return this.pos > start\n };\n StringStream.prototype.skipToEnd = function () {this.pos = this.string.length;};\n StringStream.prototype.skipTo = function (ch) {\n var found = this.string.indexOf(ch, this.pos);\n if (found > -1) {this.pos = found; return true}\n };\n StringStream.prototype.backUp = function (n) {this.pos -= n;};\n StringStream.prototype.column = function () {\n if (this.lastColumnPos < this.start) {\n this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue);\n this.lastColumnPos = this.start;\n }\n return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0)\n };\n StringStream.prototype.indentation = function () {\n return countColumn(this.string, null, this.tabSize) -\n (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0)\n };\n StringStream.prototype.match = function (pattern, consume, caseInsensitive) {\n if (typeof pattern == \"string\") {\n var cased = function (str) { return caseInsensitive ? str.toLowerCase() : str; };\n var substr = this.string.substr(this.pos, pattern.length);\n if (cased(substr) == cased(pattern)) {\n if (consume !== false) { this.pos += pattern.length; }\n return true\n }\n } else {\n var match = this.string.slice(this.pos).match(pattern);\n if (match && match.index > 0) { return null }\n if (match && consume !== false) { this.pos += match[0].length; }\n return match\n }\n };\n StringStream.prototype.current = function (){return this.string.slice(this.start, this.pos)};\n StringStream.prototype.hideFirstChars = function (n, inner) {\n this.lineStart += n;\n try { return inner() }\n finally { this.lineStart -= n; }\n };\n StringStream.prototype.lookAhead = function (n) {\n var oracle = this.lineOracle;\n return oracle && oracle.lookAhead(n)\n };\n StringStream.prototype.baseToken = function () {\n var oracle = this.lineOracle;\n return oracle && oracle.baseToken(this.pos)\n };\n\n var SavedContext = function(state, lookAhead) {\n this.state = state;\n this.lookAhead = lookAhead;\n };\n\n var Context = function(doc, state, line, lookAhead) {\n this.state = state;\n this.doc = doc;\n this.line = line;\n this.maxLookAhead = lookAhead || 0;\n this.baseTokens = null;\n this.baseTokenPos = 1;\n };\n\n Context.prototype.lookAhead = function (n) {\n var line = this.doc.getLine(this.line + n);\n if (line != null && n > this.maxLookAhead) { this.maxLookAhead = n; }\n return line\n };\n\n Context.prototype.baseToken = function (n) {\n var this$1 = this;\n\n if (!this.baseTokens) { return null }\n while (this.baseTokens[this.baseTokenPos] <= n)\n { this$1.baseTokenPos += 2; }\n var type = this.baseTokens[this.baseTokenPos + 1];\n return {type: type && type.replace(/( |^)overlay .*/, \"\"),\n size: this.baseTokens[this.baseTokenPos] - n}\n };\n\n Context.prototype.nextLine = function () {\n this.line++;\n if (this.maxLookAhead > 0) { this.maxLookAhead--; }\n };\n\n Context.fromSaved = function (doc, saved, line) {\n if (saved instanceof SavedContext)\n { return new Context(doc, copyState(doc.mode, saved.state), line, saved.lookAhead) }\n else\n { return new Context(doc, copyState(doc.mode, saved), line) }\n };\n\n Context.prototype.save = function (copy) {\n var state = copy !== false ? copyState(this.doc.mode, this.state) : this.state;\n return this.maxLookAhead > 0 ? new SavedContext(state, this.maxLookAhead) : state\n };\n\n\n // Compute a style array (an array starting with a mode generation\n // -- for invalidation -- followed by pairs of end positions and\n // style strings), which is used to highlight the tokens on the\n // line.\n function highlightLine(cm, line, context, forceToEnd) {\n // A styles array always starts with a number identifying the\n // mode/overlays that it is based on (for easy invalidation).\n var st = [cm.state.modeGen], lineClasses = {};\n // Compute the base array of styles\n runMode(cm, line.text, cm.doc.mode, context, function (end, style) { return st.push(end, style); },\n lineClasses, forceToEnd);\n var state = context.state;\n\n // Run overlays, adjust style array.\n var loop = function ( o ) {\n context.baseTokens = st;\n var overlay = cm.state.overlays[o], i = 1, at = 0;\n context.state = true;\n runMode(cm, line.text, overlay.mode, context, function (end, style) {\n var start = i;\n // Ensure there's a token end at the current position, and that i points at it\n while (at < end) {\n var i_end = st[i];\n if (i_end > end)\n { st.splice(i, 1, end, st[i+1], i_end); }\n i += 2;\n at = Math.min(end, i_end);\n }\n if (!style) { return }\n if (overlay.opaque) {\n st.splice(start, i - start, end, \"overlay \" + style);\n i = start + 2;\n } else {\n for (; start < i; start += 2) {\n var cur = st[start+1];\n st[start+1] = (cur ? cur + \" \" : \"\") + \"overlay \" + style;\n }\n }\n }, lineClasses);\n context.state = state;\n context.baseTokens = null;\n context.baseTokenPos = 1;\n };\n\n for (var o = 0; o < cm.state.overlays.length; ++o) loop( o );\n\n return {styles: st, classes: lineClasses.bgClass || lineClasses.textClass ? lineClasses : null}\n }\n\n function getLineStyles(cm, line, updateFrontier) {\n if (!line.styles || line.styles[0] != cm.state.modeGen) {\n var context = getContextBefore(cm, lineNo(line));\n var resetState = line.text.length > cm.options.maxHighlightLength && copyState(cm.doc.mode, context.state);\n var result = highlightLine(cm, line, context);\n if (resetState) { context.state = resetState; }\n line.stateAfter = context.save(!resetState);\n line.styles = result.styles;\n if (result.classes) { line.styleClasses = result.classes; }\n else if (line.styleClasses) { line.styleClasses = null; }\n if (updateFrontier === cm.doc.highlightFrontier)\n { cm.doc.modeFrontier = Math.max(cm.doc.modeFrontier, ++cm.doc.highlightFrontier); }\n }\n return line.styles\n }\n\n function getContextBefore(cm, n, precise) {\n var doc = cm.doc, display = cm.display;\n if (!doc.mode.startState) { return new Context(doc, true, n) }\n var start = findStartLine(cm, n, precise);\n var saved = start > doc.first && getLine(doc, start - 1).stateAfter;\n var context = saved ? Context.fromSaved(doc, saved, start) : new Context(doc, startState(doc.mode), start);\n\n doc.iter(start, n, function (line) {\n processLine(cm, line.text, context);\n var pos = context.line;\n line.stateAfter = pos == n - 1 || pos % 5 == 0 || pos >= display.viewFrom && pos < display.viewTo ? context.save() : null;\n context.nextLine();\n });\n if (precise) { doc.modeFrontier = context.line; }\n return context\n }\n\n // Lightweight form of highlight -- proceed over this line and\n // update state, but don't save a style array. Used for lines that\n // aren't currently visible.\n function processLine(cm, text, context, startAt) {\n var mode = cm.doc.mode;\n var stream = new StringStream(text, cm.options.tabSize, context);\n stream.start = stream.pos = startAt || 0;\n if (text == \"\") { callBlankLine(mode, context.state); }\n while (!stream.eol()) {\n readToken(mode, stream, context.state);\n stream.start = stream.pos;\n }\n }\n\n function callBlankLine(mode, state) {\n if (mode.blankLine) { return mode.blankLine(state) }\n if (!mode.innerMode) { return }\n var inner = innerMode(mode, state);\n if (inner.mode.blankLine) { return inner.mode.blankLine(inner.state) }\n }\n\n function readToken(mode, stream, state, inner) {\n for (var i = 0; i < 10; i++) {\n if (inner) { inner[0] = innerMode(mode, state).mode; }\n var style = mode.token(stream, state);\n if (stream.pos > stream.start) { return style }\n }\n throw new Error(\"Mode \" + mode.name + \" failed to advance stream.\")\n }\n\n var Token = function(stream, type, state) {\n this.start = stream.start; this.end = stream.pos;\n this.string = stream.current();\n this.type = type || null;\n this.state = state;\n };\n\n // Utility for getTokenAt and getLineTokens\n function takeToken(cm, pos, precise, asArray) {\n var doc = cm.doc, mode = doc.mode, style;\n pos = clipPos(doc, pos);\n var line = getLine(doc, pos.line), context = getContextBefore(cm, pos.line, precise);\n var stream = new StringStream(line.text, cm.options.tabSize, context), tokens;\n if (asArray) { tokens = []; }\n while ((asArray || stream.pos < pos.ch) && !stream.eol()) {\n stream.start = stream.pos;\n style = readToken(mode, stream, context.state);\n if (asArray) { tokens.push(new Token(stream, style, copyState(doc.mode, context.state))); }\n }\n return asArray ? tokens : new Token(stream, style, context.state)\n }\n\n function extractLineClasses(type, output) {\n if (type) { for (;;) {\n var lineClass = type.match(/(?:^|\\s+)line-(background-)?(\\S+)/);\n if (!lineClass) { break }\n type = type.slice(0, lineClass.index) + type.slice(lineClass.index + lineClass[0].length);\n var prop = lineClass[1] ? \"bgClass\" : \"textClass\";\n if (output[prop] == null)\n { output[prop] = lineClass[2]; }\n else if (!(new RegExp(\"(?:^|\\s)\" + lineClass[2] + \"(?:$|\\s)\")).test(output[prop]))\n { output[prop] += \" \" + lineClass[2]; }\n } }\n return type\n }\n\n // Run the given mode's parser over a line, calling f for each token.\n function runMode(cm, text, mode, context, f, lineClasses, forceToEnd) {\n var flattenSpans = mode.flattenSpans;\n if (flattenSpans == null) { flattenSpans = cm.options.flattenSpans; }\n var curStart = 0, curStyle = null;\n var stream = new StringStream(text, cm.options.tabSize, context), style;\n var inner = cm.options.addModeClass && [null];\n if (text == \"\") { extractLineClasses(callBlankLine(mode, context.state), lineClasses); }\n while (!stream.eol()) {\n if (stream.pos > cm.options.maxHighlightLength) {\n flattenSpans = false;\n if (forceToEnd) { processLine(cm, text, context, stream.pos); }\n stream.pos = text.length;\n style = null;\n } else {\n style = extractLineClasses(readToken(mode, stream, context.state, inner), lineClasses);\n }\n if (inner) {\n var mName = inner[0].name;\n if (mName) { style = \"m-\" + (style ? mName + \" \" + style : mName); }\n }\n if (!flattenSpans || curStyle != style) {\n while (curStart < stream.start) {\n curStart = Math.min(stream.start, curStart + 5000);\n f(curStart, curStyle);\n }\n curStyle = style;\n }\n stream.start = stream.pos;\n }\n while (curStart < stream.pos) {\n // Webkit seems to refuse to render text nodes longer than 57444\n // characters, and returns inaccurate measurements in nodes\n // starting around 5000 chars.\n var pos = Math.min(stream.pos, curStart + 5000);\n f(pos, curStyle);\n curStart = pos;\n }\n }\n\n // Finds the line to start with when starting a parse. Tries to\n // find a line with a stateAfter, so that it can start with a\n // valid state. If that fails, it returns the line with the\n // smallest indentation, which tends to need the least context to\n // parse correctly.\n function findStartLine(cm, n, precise) {\n var minindent, minline, doc = cm.doc;\n var lim = precise ? -1 : n - (cm.doc.mode.innerMode ? 1000 : 100);\n for (var search = n; search > lim; --search) {\n if (search <= doc.first) { return doc.first }\n var line = getLine(doc, search - 1), after = line.stateAfter;\n if (after && (!precise || search + (after instanceof SavedContext ? after.lookAhead : 0) <= doc.modeFrontier))\n { return search }\n var indented = countColumn(line.text, null, cm.options.tabSize);\n if (minline == null || minindent > indented) {\n minline = search - 1;\n minindent = indented;\n }\n }\n return minline\n }\n\n function retreatFrontier(doc, n) {\n doc.modeFrontier = Math.min(doc.modeFrontier, n);\n if (doc.highlightFrontier < n - 10) { return }\n var start = doc.first;\n for (var line = n - 1; line > start; line--) {\n var saved = getLine(doc, line).stateAfter;\n // change is on 3\n // state on line 1 looked ahead 2 -- so saw 3\n // test 1 + 2 < 3 should cover this\n if (saved && (!(saved instanceof SavedContext) || line + saved.lookAhead < n)) {\n start = line + 1;\n break\n }\n }\n doc.highlightFrontier = Math.min(doc.highlightFrontier, start);\n }\n\n // LINE DATA STRUCTURE\n\n // Line objects. These hold state related to a line, including\n // highlighting info (the styles array).\n var Line = function(text, markedSpans, estimateHeight) {\n this.text = text;\n attachMarkedSpans(this, markedSpans);\n this.height = estimateHeight ? estimateHeight(this) : 1;\n };\n\n Line.prototype.lineNo = function () { return lineNo(this) };\n eventMixin(Line);\n\n // Change the content (text, markers) of a line. Automatically\n // invalidates cached information and tries to re-estimate the\n // line's height.\n function updateLine(line, text, markedSpans, estimateHeight) {\n line.text = text;\n if (line.stateAfter) { line.stateAfter = null; }\n if (line.styles) { line.styles = null; }\n if (line.order != null) { line.order = null; }\n detachMarkedSpans(line);\n attachMarkedSpans(line, markedSpans);\n var estHeight = estimateHeight ? estimateHeight(line) : 1;\n if (estHeight != line.height) { updateLineHeight(line, estHeight); }\n }\n\n // Detach a line from the document tree and its markers.\n function cleanUpLine(line) {\n line.parent = null;\n detachMarkedSpans(line);\n }\n\n // Convert a style as returned by a mode (either null, or a string\n // containing one or more styles) to a CSS style. This is cached,\n // and also looks for line-wide styles.\n var styleToClassCache = {}, styleToClassCacheWithMode = {};\n function interpretTokenStyle(style, options) {\n if (!style || /^\\s*$/.test(style)) { return null }\n var cache = options.addModeClass ? styleToClassCacheWithMode : styleToClassCache;\n return cache[style] ||\n (cache[style] = style.replace(/\\S+/g, \"cm-$&\"))\n }\n\n // Render the DOM representation of the text of a line. Also builds\n // up a 'line map', which points at the DOM nodes that represent\n // specific stretches of text, and is used by the measuring code.\n // The returned object contains the DOM node, this map, and\n // information about line-wide styles that were set by the mode.\n function buildLineContent(cm, lineView) {\n // The padding-right forces the element to have a 'border', which\n // is needed on Webkit to be able to get line-level bounding\n // rectangles for it (in measureChar).\n var content = eltP(\"span\", null, null, webkit ? \"padding-right: .1px\" : null);\n var builder = {pre: eltP(\"pre\", [content], \"CodeMirror-line\"), content: content,\n col: 0, pos: 0, cm: cm,\n trailingSpace: false,\n splitSpaces: cm.getOption(\"lineWrapping\")};\n lineView.measure = {};\n\n // Iterate over the logical lines that make up this visual line.\n for (var i = 0; i <= (lineView.rest ? lineView.rest.length : 0); i++) {\n var line = i ? lineView.rest[i - 1] : lineView.line, order = (void 0);\n builder.pos = 0;\n builder.addToken = buildToken;\n // Optionally wire in some hacks into the token-rendering\n // algorithm, to deal with browser quirks.\n if (hasBadBidiRects(cm.display.measure) && (order = getOrder(line, cm.doc.direction)))\n { builder.addToken = buildTokenBadBidi(builder.addToken, order); }\n builder.map = [];\n var allowFrontierUpdate = lineView != cm.display.externalMeasured && lineNo(line);\n insertLineContent(line, builder, getLineStyles(cm, line, allowFrontierUpdate));\n if (line.styleClasses) {\n if (line.styleClasses.bgClass)\n { builder.bgClass = joinClasses(line.styleClasses.bgClass, builder.bgClass || \"\"); }\n if (line.styleClasses.textClass)\n { builder.textClass = joinClasses(line.styleClasses.textClass, builder.textClass || \"\"); }\n }\n\n // Ensure at least a single node is present, for measuring.\n if (builder.map.length == 0)\n { builder.map.push(0, 0, builder.content.appendChild(zeroWidthElement(cm.display.measure))); }\n\n // Store the map and a cache object for the current logical line\n if (i == 0) {\n lineView.measure.map = builder.map;\n lineView.measure.cache = {};\n } else {\n (lineView.measure.maps || (lineView.measure.maps = [])).push(builder.map)\n ;(lineView.measure.caches || (lineView.measure.caches = [])).push({});\n }\n }\n\n // See issue #2901\n if (webkit) {\n var last = builder.content.lastChild;\n if (/\\bcm-tab\\b/.test(last.className) || (last.querySelector && last.querySelector(\".cm-tab\")))\n { builder.content.className = \"cm-tab-wrap-hack\"; }\n }\n\n signal(cm, \"renderLine\", cm, lineView.line, builder.pre);\n if (builder.pre.className)\n { builder.textClass = joinClasses(builder.pre.className, builder.textClass || \"\"); }\n\n return builder\n }\n\n function defaultSpecialCharPlaceholder(ch) {\n var token = elt(\"span\", \"\\u2022\", \"cm-invalidchar\");\n token.title = \"\\\\u\" + ch.charCodeAt(0).toString(16);\n token.setAttribute(\"aria-label\", token.title);\n return token\n }\n\n // Build up the DOM representation for a single token, and add it to\n // the line map. Takes care to render special characters separately.\n function buildToken(builder, text, style, startStyle, endStyle, css, attributes) {\n if (!text) { return }\n var displayText = builder.splitSpaces ? splitSpaces(text, builder.trailingSpace) : text;\n var special = builder.cm.state.specialChars, mustWrap = false;\n var content;\n if (!special.test(text)) {\n builder.col += text.length;\n content = document.createTextNode(displayText);\n builder.map.push(builder.pos, builder.pos + text.length, content);\n if (ie && ie_version < 9) { mustWrap = true; }\n builder.pos += text.length;\n } else {\n content = document.createDocumentFragment();\n var pos = 0;\n while (true) {\n special.lastIndex = pos;\n var m = special.exec(text);\n var skipped = m ? m.index - pos : text.length - pos;\n if (skipped) {\n var txt = document.createTextNode(displayText.slice(pos, pos + skipped));\n if (ie && ie_version < 9) { content.appendChild(elt(\"span\", [txt])); }\n else { content.appendChild(txt); }\n builder.map.push(builder.pos, builder.pos + skipped, txt);\n builder.col += skipped;\n builder.pos += skipped;\n }\n if (!m) { break }\n pos += skipped + 1;\n var txt$1 = (void 0);\n if (m[0] == \"\\t\") {\n var tabSize = builder.cm.options.tabSize, tabWidth = tabSize - builder.col % tabSize;\n txt$1 = content.appendChild(elt(\"span\", spaceStr(tabWidth), \"cm-tab\"));\n txt$1.setAttribute(\"role\", \"presentation\");\n txt$1.setAttribute(\"cm-text\", \"\\t\");\n builder.col += tabWidth;\n } else if (m[0] == \"\\r\" || m[0] == \"\\n\") {\n txt$1 = content.appendChild(elt(\"span\", m[0] == \"\\r\" ? \"\\u240d\" : \"\\u2424\", \"cm-invalidchar\"));\n txt$1.setAttribute(\"cm-text\", m[0]);\n builder.col += 1;\n } else {\n txt$1 = builder.cm.options.specialCharPlaceholder(m[0]);\n txt$1.setAttribute(\"cm-text\", m[0]);\n if (ie && ie_version < 9) { content.appendChild(elt(\"span\", [txt$1])); }\n else { content.appendChild(txt$1); }\n builder.col += 1;\n }\n builder.map.push(builder.pos, builder.pos + 1, txt$1);\n builder.pos++;\n }\n }\n builder.trailingSpace = displayText.charCodeAt(text.length - 1) == 32;\n if (style || startStyle || endStyle || mustWrap || css) {\n var fullStyle = style || \"\";\n if (startStyle) { fullStyle += startStyle; }\n if (endStyle) { fullStyle += endStyle; }\n var token = elt(\"span\", [content], fullStyle, css);\n if (attributes) {\n for (var attr in attributes) { if (attributes.hasOwnProperty(attr) && attr != \"style\" && attr != \"class\")\n { token.setAttribute(attr, attributes[attr]); } }\n }\n return builder.content.appendChild(token)\n }\n builder.content.appendChild(content);\n }\n\n // Change some spaces to NBSP to prevent the browser from collapsing\n // trailing spaces at the end of a line when rendering text (issue #1362).\n function splitSpaces(text, trailingBefore) {\n if (text.length > 1 && !/ /.test(text)) { return text }\n var spaceBefore = trailingBefore, result = \"\";\n for (var i = 0; i < text.length; i++) {\n var ch = text.charAt(i);\n if (ch == \" \" && spaceBefore && (i == text.length - 1 || text.charCodeAt(i + 1) == 32))\n { ch = \"\\u00a0\"; }\n result += ch;\n spaceBefore = ch == \" \";\n }\n return result\n }\n\n // Work around nonsense dimensions being reported for stretches of\n // right-to-left text.\n function buildTokenBadBidi(inner, order) {\n return function (builder, text, style, startStyle, endStyle, css, attributes) {\n style = style ? style + \" cm-force-border\" : \"cm-force-border\";\n var start = builder.pos, end = start + text.length;\n for (;;) {\n // Find the part that overlaps with the start of this text\n var part = (void 0);\n for (var i = 0; i < order.length; i++) {\n part = order[i];\n if (part.to > start && part.from <= start) { break }\n }\n if (part.to >= end) { return inner(builder, text, style, startStyle, endStyle, css, attributes) }\n inner(builder, text.slice(0, part.to - start), style, startStyle, null, css, attributes);\n startStyle = null;\n text = text.slice(part.to - start);\n start = part.to;\n }\n }\n }\n\n function buildCollapsedSpan(builder, size, marker, ignoreWidget) {\n var widget = !ignoreWidget && marker.widgetNode;\n if (widget) { builder.map.push(builder.pos, builder.pos + size, widget); }\n if (!ignoreWidget && builder.cm.display.input.needsContentAttribute) {\n if (!widget)\n { widget = builder.content.appendChild(document.createElement(\"span\")); }\n widget.setAttribute(\"cm-marker\", marker.id);\n }\n if (widget) {\n builder.cm.display.input.setUneditable(widget);\n builder.content.appendChild(widget);\n }\n builder.pos += size;\n builder.trailingSpace = false;\n }\n\n // Outputs a number of spans to make up a line, taking highlighting\n // and marked text into account.\n function insertLineContent(line, builder, styles) {\n var spans = line.markedSpans, allText = line.text, at = 0;\n if (!spans) {\n for (var i$1 = 1; i$1 < styles.length; i$1+=2)\n { builder.addToken(builder, allText.slice(at, at = styles[i$1]), interpretTokenStyle(styles[i$1+1], builder.cm.options)); }\n return\n }\n\n var len = allText.length, pos = 0, i = 1, text = \"\", style, css;\n var nextChange = 0, spanStyle, spanEndStyle, spanStartStyle, collapsed, attributes;\n for (;;) {\n if (nextChange == pos) { // Update current marker set\n spanStyle = spanEndStyle = spanStartStyle = css = \"\";\n attributes = null;\n collapsed = null; nextChange = Infinity;\n var foundBookmarks = [], endStyles = (void 0);\n for (var j = 0; j < spans.length; ++j) {\n var sp = spans[j], m = sp.marker;\n if (m.type == \"bookmark\" && sp.from == pos && m.widgetNode) {\n foundBookmarks.push(m);\n } else if (sp.from <= pos && (sp.to == null || sp.to > pos || m.collapsed && sp.to == pos && sp.from == pos)) {\n if (sp.to != null && sp.to != pos && nextChange > sp.to) {\n nextChange = sp.to;\n spanEndStyle = \"\";\n }\n if (m.className) { spanStyle += \" \" + m.className; }\n if (m.css) { css = (css ? css + \";\" : \"\") + m.css; }\n if (m.startStyle && sp.from == pos) { spanStartStyle += \" \" + m.startStyle; }\n if (m.endStyle && sp.to == nextChange) { (endStyles || (endStyles = [])).push(m.endStyle, sp.to); }\n // support for the old title property\n // https://github.com/codemirror/CodeMirror/pull/5673\n if (m.title) { (attributes || (attributes = {})).title = m.title; }\n if (m.attributes) {\n for (var attr in m.attributes)\n { (attributes || (attributes = {}))[attr] = m.attributes[attr]; }\n }\n if (m.collapsed && (!collapsed || compareCollapsedMarkers(collapsed.marker, m) < 0))\n { collapsed = sp; }\n } else if (sp.from > pos && nextChange > sp.from) {\n nextChange = sp.from;\n }\n }\n if (endStyles) { for (var j$1 = 0; j$1 < endStyles.length; j$1 += 2)\n { if (endStyles[j$1 + 1] == nextChange) { spanEndStyle += \" \" + endStyles[j$1]; } } }\n\n if (!collapsed || collapsed.from == pos) { for (var j$2 = 0; j$2 < foundBookmarks.length; ++j$2)\n { buildCollapsedSpan(builder, 0, foundBookmarks[j$2]); } }\n if (collapsed && (collapsed.from || 0) == pos) {\n buildCollapsedSpan(builder, (collapsed.to == null ? len + 1 : collapsed.to) - pos,\n collapsed.marker, collapsed.from == null);\n if (collapsed.to == null) { return }\n if (collapsed.to == pos) { collapsed = false; }\n }\n }\n if (pos >= len) { break }\n\n var upto = Math.min(len, nextChange);\n while (true) {\n if (text) {\n var end = pos + text.length;\n if (!collapsed) {\n var tokenText = end > upto ? text.slice(0, upto - pos) : text;\n builder.addToken(builder, tokenText, style ? style + spanStyle : spanStyle,\n spanStartStyle, pos + tokenText.length == nextChange ? spanEndStyle : \"\", css, attributes);\n }\n if (end >= upto) {text = text.slice(upto - pos); pos = upto; break}\n pos = end;\n spanStartStyle = \"\";\n }\n text = allText.slice(at, at = styles[i++]);\n style = interpretTokenStyle(styles[i++], builder.cm.options);\n }\n }\n }\n\n\n // These objects are used to represent the visible (currently drawn)\n // part of the document. A LineView may correspond to multiple\n // logical lines, if those are connected by collapsed ranges.\n function LineView(doc, line, lineN) {\n // The starting line\n this.line = line;\n // Continuing lines, if any\n this.rest = visualLineContinued(line);\n // Number of logical lines in this visual line\n this.size = this.rest ? lineNo(lst(this.rest)) - lineN + 1 : 1;\n this.node = this.text = null;\n this.hidden = lineIsHidden(doc, line);\n }\n\n // Create a range of LineView objects for the given lines.\n function buildViewArray(cm, from, to) {\n var array = [], nextPos;\n for (var pos = from; pos < to; pos = nextPos) {\n var view = new LineView(cm.doc, getLine(cm.doc, pos), pos);\n nextPos = pos + view.size;\n array.push(view);\n }\n return array\n }\n\n var operationGroup = null;\n\n function pushOperation(op) {\n if (operationGroup) {\n operationGroup.ops.push(op);\n } else {\n op.ownsGroup = operationGroup = {\n ops: [op],\n delayedCallbacks: []\n };\n }\n }\n\n function fireCallbacksForOps(group) {\n // Calls delayed callbacks and cursorActivity handlers until no\n // new ones appear\n var callbacks = group.delayedCallbacks, i = 0;\n do {\n for (; i < callbacks.length; i++)\n { callbacks[i].call(null); }\n for (var j = 0; j < group.ops.length; j++) {\n var op = group.ops[j];\n if (op.cursorActivityHandlers)\n { while (op.cursorActivityCalled < op.cursorActivityHandlers.length)\n { op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm); } }\n }\n } while (i < callbacks.length)\n }\n\n function finishOperation(op, endCb) {\n var group = op.ownsGroup;\n if (!group) { return }\n\n try { fireCallbacksForOps(group); }\n finally {\n operationGroup = null;\n endCb(group);\n }\n }\n\n var orphanDelayedCallbacks = null;\n\n // Often, we want to signal events at a point where we are in the\n // middle of some work, but don't want the handler to start calling\n // other methods on the editor, which might be in an inconsistent\n // state or simply not expect any other events to happen.\n // signalLater looks whether there are any handlers, and schedules\n // them to be executed when the last operation ends, or, if no\n // operation is active, when a timeout fires.\n function signalLater(emitter, type /*, values...*/) {\n var arr = getHandlers(emitter, type);\n if (!arr.length) { return }\n var args = Array.prototype.slice.call(arguments, 2), list;\n if (operationGroup) {\n list = operationGroup.delayedCallbacks;\n } else if (orphanDelayedCallbacks) {\n list = orphanDelayedCallbacks;\n } else {\n list = orphanDelayedCallbacks = [];\n setTimeout(fireOrphanDelayed, 0);\n }\n var loop = function ( i ) {\n list.push(function () { return arr[i].apply(null, args); });\n };\n\n for (var i = 0; i < arr.length; ++i)\n loop( i );\n }\n\n function fireOrphanDelayed() {\n var delayed = orphanDelayedCallbacks;\n orphanDelayedCallbacks = null;\n for (var i = 0; i < delayed.length; ++i) { delayed[i](); }\n }\n\n // When an aspect of a line changes, a string is added to\n // lineView.changes. This updates the relevant part of the line's\n // DOM structure.\n function updateLineForChanges(cm, lineView, lineN, dims) {\n for (var j = 0; j < lineView.changes.length; j++) {\n var type = lineView.changes[j];\n if (type == \"text\") { updateLineText(cm, lineView); }\n else if (type == \"gutter\") { updateLineGutter(cm, lineView, lineN, dims); }\n else if (type == \"class\") { updateLineClasses(cm, lineView); }\n else if (type == \"widget\") { updateLineWidgets(cm, lineView, dims); }\n }\n lineView.changes = null;\n }\n\n // Lines with gutter elements, widgets or a background class need to\n // be wrapped, and have the extra elements added to the wrapper div\n function ensureLineWrapped(lineView) {\n if (lineView.node == lineView.text) {\n lineView.node = elt(\"div\", null, null, \"position: relative\");\n if (lineView.text.parentNode)\n { lineView.text.parentNode.replaceChild(lineView.node, lineView.text); }\n lineView.node.appendChild(lineView.text);\n if (ie && ie_version < 8) { lineView.node.style.zIndex = 2; }\n }\n return lineView.node\n }\n\n function updateLineBackground(cm, lineView) {\n var cls = lineView.bgClass ? lineView.bgClass + \" \" + (lineView.line.bgClass || \"\") : lineView.line.bgClass;\n if (cls) { cls += \" CodeMirror-linebackground\"; }\n if (lineView.background) {\n if (cls) { lineView.background.className = cls; }\n else { lineView.background.parentNode.removeChild(lineView.background); lineView.background = null; }\n } else if (cls) {\n var wrap = ensureLineWrapped(lineView);\n lineView.background = wrap.insertBefore(elt(\"div\", null, cls), wrap.firstChild);\n cm.display.input.setUneditable(lineView.background);\n }\n }\n\n // Wrapper around buildLineContent which will reuse the structure\n // in display.externalMeasured when possible.\n function getLineContent(cm, lineView) {\n var ext = cm.display.externalMeasured;\n if (ext && ext.line == lineView.line) {\n cm.display.externalMeasured = null;\n lineView.measure = ext.measure;\n return ext.built\n }\n return buildLineContent(cm, lineView)\n }\n\n // Redraw the line's text. Interacts with the background and text\n // classes because the mode may output tokens that influence these\n // classes.\n function updateLineText(cm, lineView) {\n var cls = lineView.text.className;\n var built = getLineContent(cm, lineView);\n if (lineView.text == lineView.node) { lineView.node = built.pre; }\n lineView.text.parentNode.replaceChild(built.pre, lineView.text);\n lineView.text = built.pre;\n if (built.bgClass != lineView.bgClass || built.textClass != lineView.textClass) {\n lineView.bgClass = built.bgClass;\n lineView.textClass = built.textClass;\n updateLineClasses(cm, lineView);\n } else if (cls) {\n lineView.text.className = cls;\n }\n }\n\n function updateLineClasses(cm, lineView) {\n updateLineBackground(cm, lineView);\n if (lineView.line.wrapClass)\n { ensureLineWrapped(lineView).className = lineView.line.wrapClass; }\n else if (lineView.node != lineView.text)\n { lineView.node.className = \"\"; }\n var textClass = lineView.textClass ? lineView.textClass + \" \" + (lineView.line.textClass || \"\") : lineView.line.textClass;\n lineView.text.className = textClass || \"\";\n }\n\n function updateLineGutter(cm, lineView, lineN, dims) {\n if (lineView.gutter) {\n lineView.node.removeChild(lineView.gutter);\n lineView.gutter = null;\n }\n if (lineView.gutterBackground) {\n lineView.node.removeChild(lineView.gutterBackground);\n lineView.gutterBackground = null;\n }\n if (lineView.line.gutterClass) {\n var wrap = ensureLineWrapped(lineView);\n lineView.gutterBackground = elt(\"div\", null, \"CodeMirror-gutter-background \" + lineView.line.gutterClass,\n (\"left: \" + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + \"px; width: \" + (dims.gutterTotalWidth) + \"px\"));\n cm.display.input.setUneditable(lineView.gutterBackground);\n wrap.insertBefore(lineView.gutterBackground, lineView.text);\n }\n var markers = lineView.line.gutterMarkers;\n if (cm.options.lineNumbers || markers) {\n var wrap$1 = ensureLineWrapped(lineView);\n var gutterWrap = lineView.gutter = elt(\"div\", null, \"CodeMirror-gutter-wrapper\", (\"left: \" + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + \"px\"));\n cm.display.input.setUneditable(gutterWrap);\n wrap$1.insertBefore(gutterWrap, lineView.text);\n if (lineView.line.gutterClass)\n { gutterWrap.className += \" \" + lineView.line.gutterClass; }\n if (cm.options.lineNumbers && (!markers || !markers[\"CodeMirror-linenumbers\"]))\n { lineView.lineNumber = gutterWrap.appendChild(\n elt(\"div\", lineNumberFor(cm.options, lineN),\n \"CodeMirror-linenumber CodeMirror-gutter-elt\",\n (\"left: \" + (dims.gutterLeft[\"CodeMirror-linenumbers\"]) + \"px; width: \" + (cm.display.lineNumInnerWidth) + \"px\"))); }\n if (markers) { for (var k = 0; k < cm.options.gutters.length; ++k) {\n var id = cm.options.gutters[k], found = markers.hasOwnProperty(id) && markers[id];\n if (found)\n { gutterWrap.appendChild(elt(\"div\", [found], \"CodeMirror-gutter-elt\",\n (\"left: \" + (dims.gutterLeft[id]) + \"px; width: \" + (dims.gutterWidth[id]) + \"px\"))); }\n } }\n }\n }\n\n function updateLineWidgets(cm, lineView, dims) {\n if (lineView.alignable) { lineView.alignable = null; }\n for (var node = lineView.node.firstChild, next = (void 0); node; node = next) {\n next = node.nextSibling;\n if (node.className == \"CodeMirror-linewidget\")\n { lineView.node.removeChild(node); }\n }\n insertLineWidgets(cm, lineView, dims);\n }\n\n // Build a line's DOM representation from scratch\n function buildLineElement(cm, lineView, lineN, dims) {\n var built = getLineContent(cm, lineView);\n lineView.text = lineView.node = built.pre;\n if (built.bgClass) { lineView.bgClass = built.bgClass; }\n if (built.textClass) { lineView.textClass = built.textClass; }\n\n updateLineClasses(cm, lineView);\n updateLineGutter(cm, lineView, lineN, dims);\n insertLineWidgets(cm, lineView, dims);\n return lineView.node\n }\n\n // A lineView may contain multiple logical lines (when merged by\n // collapsed spans). The widgets for all of them need to be drawn.\n function insertLineWidgets(cm, lineView, dims) {\n insertLineWidgetsFor(cm, lineView.line, lineView, dims, true);\n if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++)\n { insertLineWidgetsFor(cm, lineView.rest[i], lineView, dims, false); } }\n }\n\n function insertLineWidgetsFor(cm, line, lineView, dims, allowAbove) {\n if (!line.widgets) { return }\n var wrap = ensureLineWrapped(lineView);\n for (var i = 0, ws = line.widgets; i < ws.length; ++i) {\n var widget = ws[i], node = elt(\"div\", [widget.node], \"CodeMirror-linewidget\");\n if (!widget.handleMouseEvents) { node.setAttribute(\"cm-ignore-events\", \"true\"); }\n positionLineWidget(widget, node, lineView, dims);\n cm.display.input.setUneditable(node);\n if (allowAbove && widget.above)\n { wrap.insertBefore(node, lineView.gutter || lineView.text); }\n else\n { wrap.appendChild(node); }\n signalLater(widget, \"redraw\");\n }\n }\n\n function positionLineWidget(widget, node, lineView, dims) {\n if (widget.noHScroll) {\n (lineView.alignable || (lineView.alignable = [])).push(node);\n var width = dims.wrapperWidth;\n node.style.left = dims.fixedPos + \"px\";\n if (!widget.coverGutter) {\n width -= dims.gutterTotalWidth;\n node.style.paddingLeft = dims.gutterTotalWidth + \"px\";\n }\n node.style.width = width + \"px\";\n }\n if (widget.coverGutter) {\n node.style.zIndex = 5;\n node.style.position = \"relative\";\n if (!widget.noHScroll) { node.style.marginLeft = -dims.gutterTotalWidth + \"px\"; }\n }\n }\n\n function widgetHeight(widget) {\n if (widget.height != null) { return widget.height }\n var cm = widget.doc.cm;\n if (!cm) { return 0 }\n if (!contains(document.body, widget.node)) {\n var parentStyle = \"position: relative;\";\n if (widget.coverGutter)\n { parentStyle += \"margin-left: -\" + cm.display.gutters.offsetWidth + \"px;\"; }\n if (widget.noHScroll)\n { parentStyle += \"width: \" + cm.display.wrapper.clientWidth + \"px;\"; }\n removeChildrenAndAdd(cm.display.measure, elt(\"div\", [widget.node], null, parentStyle));\n }\n return widget.height = widget.node.parentNode.offsetHeight\n }\n\n // Return true when the given mouse event happened in a widget\n function eventInWidget(display, e) {\n for (var n = e_target(e); n != display.wrapper; n = n.parentNode) {\n if (!n || (n.nodeType == 1 && n.getAttribute(\"cm-ignore-events\") == \"true\") ||\n (n.parentNode == display.sizer && n != display.mover))\n { return true }\n }\n }\n\n // POSITION MEASUREMENT\n\n function paddingTop(display) {return display.lineSpace.offsetTop}\n function paddingVert(display) {return display.mover.offsetHeight - display.lineSpace.offsetHeight}\n function paddingH(display) {\n if (display.cachedPaddingH) { return display.cachedPaddingH }\n var e = removeChildrenAndAdd(display.measure, elt(\"pre\", \"x\"));\n var style = window.getComputedStyle ? window.getComputedStyle(e) : e.currentStyle;\n var data = {left: parseInt(style.paddingLeft), right: parseInt(style.paddingRight)};\n if (!isNaN(data.left) && !isNaN(data.right)) { display.cachedPaddingH = data; }\n return data\n }\n\n function scrollGap(cm) { return scrollerGap - cm.display.nativeBarWidth }\n function displayWidth(cm) {\n return cm.display.scroller.clientWidth - scrollGap(cm) - cm.display.barWidth\n }\n function displayHeight(cm) {\n return cm.display.scroller.clientHeight - scrollGap(cm) - cm.display.barHeight\n }\n\n // Ensure the lineView.wrapping.heights array is populated. This is\n // an array of bottom offsets for the lines that make up a drawn\n // line. When lineWrapping is on, there might be more than one\n // height.\n function ensureLineHeights(cm, lineView, rect) {\n var wrapping = cm.options.lineWrapping;\n var curWidth = wrapping && displayWidth(cm);\n if (!lineView.measure.heights || wrapping && lineView.measure.width != curWidth) {\n var heights = lineView.measure.heights = [];\n if (wrapping) {\n lineView.measure.width = curWidth;\n var rects = lineView.text.firstChild.getClientRects();\n for (var i = 0; i < rects.length - 1; i++) {\n var cur = rects[i], next = rects[i + 1];\n if (Math.abs(cur.bottom - next.bottom) > 2)\n { heights.push((cur.bottom + next.top) / 2 - rect.top); }\n }\n }\n heights.push(rect.bottom - rect.top);\n }\n }\n\n // Find a line map (mapping character offsets to text nodes) and a\n // measurement cache for the given line number. (A line view might\n // contain multiple lines when collapsed ranges are present.)\n function mapFromLineView(lineView, line, lineN) {\n if (lineView.line == line)\n { return {map: lineView.measure.map, cache: lineView.measure.cache} }\n for (var i = 0; i < lineView.rest.length; i++)\n { if (lineView.rest[i] == line)\n { return {map: lineView.measure.maps[i], cache: lineView.measure.caches[i]} } }\n for (var i$1 = 0; i$1 < lineView.rest.length; i$1++)\n { if (lineNo(lineView.rest[i$1]) > lineN)\n { return {map: lineView.measure.maps[i$1], cache: lineView.measure.caches[i$1], before: true} } }\n }\n\n // Render a line into the hidden node display.externalMeasured. Used\n // when measurement is needed for a line that's not in the viewport.\n function updateExternalMeasurement(cm, line) {\n line = visualLine(line);\n var lineN = lineNo(line);\n var view = cm.display.externalMeasured = new LineView(cm.doc, line, lineN);\n view.lineN = lineN;\n var built = view.built = buildLineContent(cm, view);\n view.text = built.pre;\n removeChildrenAndAdd(cm.display.lineMeasure, built.pre);\n return view\n }\n\n // Get a {top, bottom, left, right} box (in line-local coordinates)\n // for a given character.\n function measureChar(cm, line, ch, bias) {\n return measureCharPrepared(cm, prepareMeasureForLine(cm, line), ch, bias)\n }\n\n // Find a line view that corresponds to the given line number.\n function findViewForLine(cm, lineN) {\n if (lineN >= cm.display.viewFrom && lineN < cm.display.viewTo)\n { return cm.display.view[findViewIndex(cm, lineN)] }\n var ext = cm.display.externalMeasured;\n if (ext && lineN >= ext.lineN && lineN < ext.lineN + ext.size)\n { return ext }\n }\n\n // Measurement can be split in two steps, the set-up work that\n // applies to the whole line, and the measurement of the actual\n // character. Functions like coordsChar, that need to do a lot of\n // measurements in a row, can thus ensure that the set-up work is\n // only done once.\n function prepareMeasureForLine(cm, line) {\n var lineN = lineNo(line);\n var view = findViewForLine(cm, lineN);\n if (view && !view.text) {\n view = null;\n } else if (view && view.changes) {\n updateLineForChanges(cm, view, lineN, getDimensions(cm));\n cm.curOp.forceUpdate = true;\n }\n if (!view)\n { view = updateExternalMeasurement(cm, line); }\n\n var info = mapFromLineView(view, line, lineN);\n return {\n line: line, view: view, rect: null,\n map: info.map, cache: info.cache, before: info.before,\n hasHeights: false\n }\n }\n\n // Given a prepared measurement object, measures the position of an\n // actual character (or fetches it from the cache).\n function measureCharPrepared(cm, prepared, ch, bias, varHeight) {\n if (prepared.before) { ch = -1; }\n var key = ch + (bias || \"\"), found;\n if (prepared.cache.hasOwnProperty(key)) {\n found = prepared.cache[key];\n } else {\n if (!prepared.rect)\n { prepared.rect = prepared.view.text.getBoundingClientRect(); }\n if (!prepared.hasHeights) {\n ensureLineHeights(cm, prepared.view, prepared.rect);\n prepared.hasHeights = true;\n }\n found = measureCharInner(cm, prepared, ch, bias);\n if (!found.bogus) { prepared.cache[key] = found; }\n }\n return {left: found.left, right: found.right,\n top: varHeight ? found.rtop : found.top,\n bottom: varHeight ? found.rbottom : found.bottom}\n }\n\n var nullRect = {left: 0, right: 0, top: 0, bottom: 0};\n\n function nodeAndOffsetInLineMap(map$$1, ch, bias) {\n var node, start, end, collapse, mStart, mEnd;\n // First, search the line map for the text node corresponding to,\n // or closest to, the target character.\n for (var i = 0; i < map$$1.length; i += 3) {\n mStart = map$$1[i];\n mEnd = map$$1[i + 1];\n if (ch < mStart) {\n start = 0; end = 1;\n collapse = \"left\";\n } else if (ch < mEnd) {\n start = ch - mStart;\n end = start + 1;\n } else if (i == map$$1.length - 3 || ch == mEnd && map$$1[i + 3] > ch) {\n end = mEnd - mStart;\n start = end - 1;\n if (ch >= mEnd) { collapse = \"right\"; }\n }\n if (start != null) {\n node = map$$1[i + 2];\n if (mStart == mEnd && bias == (node.insertLeft ? \"left\" : \"right\"))\n { collapse = bias; }\n if (bias == \"left\" && start == 0)\n { while (i && map$$1[i - 2] == map$$1[i - 3] && map$$1[i - 1].insertLeft) {\n node = map$$1[(i -= 3) + 2];\n collapse = \"left\";\n } }\n if (bias == \"right\" && start == mEnd - mStart)\n { while (i < map$$1.length - 3 && map$$1[i + 3] == map$$1[i + 4] && !map$$1[i + 5].insertLeft) {\n node = map$$1[(i += 3) + 2];\n collapse = \"right\";\n } }\n break\n }\n }\n return {node: node, start: start, end: end, collapse: collapse, coverStart: mStart, coverEnd: mEnd}\n }\n\n function getUsefulRect(rects, bias) {\n var rect = nullRect;\n if (bias == \"left\") { for (var i = 0; i < rects.length; i++) {\n if ((rect = rects[i]).left != rect.right) { break }\n } } else { for (var i$1 = rects.length - 1; i$1 >= 0; i$1--) {\n if ((rect = rects[i$1]).left != rect.right) { break }\n } }\n return rect\n }\n\n function measureCharInner(cm, prepared, ch, bias) {\n var place = nodeAndOffsetInLineMap(prepared.map, ch, bias);\n var node = place.node, start = place.start, end = place.end, collapse = place.collapse;\n\n var rect;\n if (node.nodeType == 3) { // If it is a text node, use a range to retrieve the coordinates.\n for (var i$1 = 0; i$1 < 4; i$1++) { // Retry a maximum of 4 times when nonsense rectangles are returned\n while (start && isExtendingChar(prepared.line.text.charAt(place.coverStart + start))) { --start; }\n while (place.coverStart + end < place.coverEnd && isExtendingChar(prepared.line.text.charAt(place.coverStart + end))) { ++end; }\n if (ie && ie_version < 9 && start == 0 && end == place.coverEnd - place.coverStart)\n { rect = node.parentNode.getBoundingClientRect(); }\n else\n { rect = getUsefulRect(range(node, start, end).getClientRects(), bias); }\n if (rect.left || rect.right || start == 0) { break }\n end = start;\n start = start - 1;\n collapse = \"right\";\n }\n if (ie && ie_version < 11) { rect = maybeUpdateRectForZooming(cm.display.measure, rect); }\n } else { // If it is a widget, simply get the box for the whole widget.\n if (start > 0) { collapse = bias = \"right\"; }\n var rects;\n if (cm.options.lineWrapping && (rects = node.getClientRects()).length > 1)\n { rect = rects[bias == \"right\" ? rects.length - 1 : 0]; }\n else\n { rect = node.getBoundingClientRect(); }\n }\n if (ie && ie_version < 9 && !start && (!rect || !rect.left && !rect.right)) {\n var rSpan = node.parentNode.getClientRects()[0];\n if (rSpan)\n { rect = {left: rSpan.left, right: rSpan.left + charWidth(cm.display), top: rSpan.top, bottom: rSpan.bottom}; }\n else\n { rect = nullRect; }\n }\n\n var rtop = rect.top - prepared.rect.top, rbot = rect.bottom - prepared.rect.top;\n var mid = (rtop + rbot) / 2;\n var heights = prepared.view.measure.heights;\n var i = 0;\n for (; i < heights.length - 1; i++)\n { if (mid < heights[i]) { break } }\n var top = i ? heights[i - 1] : 0, bot = heights[i];\n var result = {left: (collapse == \"right\" ? rect.right : rect.left) - prepared.rect.left,\n right: (collapse == \"left\" ? rect.left : rect.right) - prepared.rect.left,\n top: top, bottom: bot};\n if (!rect.left && !rect.right) { result.bogus = true; }\n if (!cm.options.singleCursorHeightPerLine) { result.rtop = rtop; result.rbottom = rbot; }\n\n return result\n }\n\n // Work around problem with bounding client rects on ranges being\n // returned incorrectly when zoomed on IE10 and below.\n function maybeUpdateRectForZooming(measure, rect) {\n if (!window.screen || screen.logicalXDPI == null ||\n screen.logicalXDPI == screen.deviceXDPI || !hasBadZoomedRects(measure))\n { return rect }\n var scaleX = screen.logicalXDPI / screen.deviceXDPI;\n var scaleY = screen.logicalYDPI / screen.deviceYDPI;\n return {left: rect.left * scaleX, right: rect.right * scaleX,\n top: rect.top * scaleY, bottom: rect.bottom * scaleY}\n }\n\n function clearLineMeasurementCacheFor(lineView) {\n if (lineView.measure) {\n lineView.measure.cache = {};\n lineView.measure.heights = null;\n if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++)\n { lineView.measure.caches[i] = {}; } }\n }\n }\n\n function clearLineMeasurementCache(cm) {\n cm.display.externalMeasure = null;\n removeChildren(cm.display.lineMeasure);\n for (var i = 0; i < cm.display.view.length; i++)\n { clearLineMeasurementCacheFor(cm.display.view[i]); }\n }\n\n function clearCaches(cm) {\n clearLineMeasurementCache(cm);\n cm.display.cachedCharWidth = cm.display.cachedTextHeight = cm.display.cachedPaddingH = null;\n if (!cm.options.lineWrapping) { cm.display.maxLineChanged = true; }\n cm.display.lineNumChars = null;\n }\n\n function pageScrollX() {\n // Work around https://bugs.chromium.org/p/chromium/issues/detail?id=489206\n // which causes page_Offset and bounding client rects to use\n // different reference viewports and invalidate our calculations.\n if (chrome && android) { return -(document.body.getBoundingClientRect().left - parseInt(getComputedStyle(document.body).marginLeft)) }\n return window.pageXOffset || (document.documentElement || document.body).scrollLeft\n }\n function pageScrollY() {\n if (chrome && android) { return -(document.body.getBoundingClientRect().top - parseInt(getComputedStyle(document.body).marginTop)) }\n return window.pageYOffset || (document.documentElement || document.body).scrollTop\n }\n\n function widgetTopHeight(lineObj) {\n var height = 0;\n if (lineObj.widgets) { for (var i = 0; i < lineObj.widgets.length; ++i) { if (lineObj.widgets[i].above)\n { height += widgetHeight(lineObj.widgets[i]); } } }\n return height\n }\n\n // Converts a {top, bottom, left, right} box from line-local\n // coordinates into another coordinate system. Context may be one of\n // \"line\", \"div\" (display.lineDiv), \"local\"./null (editor), \"window\",\n // or \"page\".\n function intoCoordSystem(cm, lineObj, rect, context, includeWidgets) {\n if (!includeWidgets) {\n var height = widgetTopHeight(lineObj);\n rect.top += height; rect.bottom += height;\n }\n if (context == \"line\") { return rect }\n if (!context) { context = \"local\"; }\n var yOff = heightAtLine(lineObj);\n if (context == \"local\") { yOff += paddingTop(cm.display); }\n else { yOff -= cm.display.viewOffset; }\n if (context == \"page\" || context == \"window\") {\n var lOff = cm.display.lineSpace.getBoundingClientRect();\n yOff += lOff.top + (context == \"window\" ? 0 : pageScrollY());\n var xOff = lOff.left + (context == \"window\" ? 0 : pageScrollX());\n rect.left += xOff; rect.right += xOff;\n }\n rect.top += yOff; rect.bottom += yOff;\n return rect\n }\n\n // Coverts a box from \"div\" coords to another coordinate system.\n // Context may be \"window\", \"page\", \"div\", or \"local\"./null.\n function fromCoordSystem(cm, coords, context) {\n if (context == \"div\") { return coords }\n var left = coords.left, top = coords.top;\n // First move into \"page\" coordinate system\n if (context == \"page\") {\n left -= pageScrollX();\n top -= pageScrollY();\n } else if (context == \"local\" || !context) {\n var localBox = cm.display.sizer.getBoundingClientRect();\n left += localBox.left;\n top += localBox.top;\n }\n\n var lineSpaceBox = cm.display.lineSpace.getBoundingClientRect();\n return {left: left - lineSpaceBox.left, top: top - lineSpaceBox.top}\n }\n\n function charCoords(cm, pos, context, lineObj, bias) {\n if (!lineObj) { lineObj = getLine(cm.doc, pos.line); }\n return intoCoordSystem(cm, lineObj, measureChar(cm, lineObj, pos.ch, bias), context)\n }\n\n // Returns a box for a given cursor position, which may have an\n // 'other' property containing the position of the secondary cursor\n // on a bidi boundary.\n // A cursor Pos(line, char, \"before\") is on the same visual line as `char - 1`\n // and after `char - 1` in writing order of `char - 1`\n // A cursor Pos(line, char, \"after\") is on the same visual line as `char`\n // and before `char` in writing order of `char`\n // Examples (upper-case letters are RTL, lower-case are LTR):\n // Pos(0, 1, ...)\n // before after\n // ab a|b a|b\n // aB a|B aB|\n // Ab |Ab A|b\n // AB B|A B|A\n // Every position after the last character on a line is considered to stick\n // to the last character on the line.\n function cursorCoords(cm, pos, context, lineObj, preparedMeasure, varHeight) {\n lineObj = lineObj || getLine(cm.doc, pos.line);\n if (!preparedMeasure) { preparedMeasure = prepareMeasureForLine(cm, lineObj); }\n function get(ch, right) {\n var m = measureCharPrepared(cm, preparedMeasure, ch, right ? \"right\" : \"left\", varHeight);\n if (right) { m.left = m.right; } else { m.right = m.left; }\n return intoCoordSystem(cm, lineObj, m, context)\n }\n var order = getOrder(lineObj, cm.doc.direction), ch = pos.ch, sticky = pos.sticky;\n if (ch >= lineObj.text.length) {\n ch = lineObj.text.length;\n sticky = \"before\";\n } else if (ch <= 0) {\n ch = 0;\n sticky = \"after\";\n }\n if (!order) { return get(sticky == \"before\" ? ch - 1 : ch, sticky == \"before\") }\n\n function getBidi(ch, partPos, invert) {\n var part = order[partPos], right = part.level == 1;\n return get(invert ? ch - 1 : ch, right != invert)\n }\n var partPos = getBidiPartAt(order, ch, sticky);\n var other = bidiOther;\n var val = getBidi(ch, partPos, sticky == \"before\");\n if (other != null) { val.other = getBidi(ch, other, sticky != \"before\"); }\n return val\n }\n\n // Used to cheaply estimate the coordinates for a position. Used for\n // intermediate scroll updates.\n function estimateCoords(cm, pos) {\n var left = 0;\n pos = clipPos(cm.doc, pos);\n if (!cm.options.lineWrapping) { left = charWidth(cm.display) * pos.ch; }\n var lineObj = getLine(cm.doc, pos.line);\n var top = heightAtLine(lineObj) + paddingTop(cm.display);\n return {left: left, right: left, top: top, bottom: top + lineObj.height}\n }\n\n // Positions returned by coordsChar contain some extra information.\n // xRel is the relative x position of the input coordinates compared\n // to the found position (so xRel > 0 means the coordinates are to\n // the right of the character position, for example). When outside\n // is true, that means the coordinates lie outside the line's\n // vertical range.\n function PosWithInfo(line, ch, sticky, outside, xRel) {\n var pos = Pos(line, ch, sticky);\n pos.xRel = xRel;\n if (outside) { pos.outside = true; }\n return pos\n }\n\n // Compute the character position closest to the given coordinates.\n // Input must be lineSpace-local (\"div\" coordinate system).\n function coordsChar(cm, x, y) {\n var doc = cm.doc;\n y += cm.display.viewOffset;\n if (y < 0) { return PosWithInfo(doc.first, 0, null, true, -1) }\n var lineN = lineAtHeight(doc, y), last = doc.first + doc.size - 1;\n if (lineN > last)\n { return PosWithInfo(doc.first + doc.size - 1, getLine(doc, last).text.length, null, true, 1) }\n if (x < 0) { x = 0; }\n\n var lineObj = getLine(doc, lineN);\n for (;;) {\n var found = coordsCharInner(cm, lineObj, lineN, x, y);\n var collapsed = collapsedSpanAround(lineObj, found.ch + (found.xRel > 0 ? 1 : 0));\n if (!collapsed) { return found }\n var rangeEnd = collapsed.find(1);\n if (rangeEnd.line == lineN) { return rangeEnd }\n lineObj = getLine(doc, lineN = rangeEnd.line);\n }\n }\n\n function wrappedLineExtent(cm, lineObj, preparedMeasure, y) {\n y -= widgetTopHeight(lineObj);\n var end = lineObj.text.length;\n var begin = findFirst(function (ch) { return measureCharPrepared(cm, preparedMeasure, ch - 1).bottom <= y; }, end, 0);\n end = findFirst(function (ch) { return measureCharPrepared(cm, preparedMeasure, ch).top > y; }, begin, end);\n return {begin: begin, end: end}\n }\n\n function wrappedLineExtentChar(cm, lineObj, preparedMeasure, target) {\n if (!preparedMeasure) { preparedMeasure = prepareMeasureForLine(cm, lineObj); }\n var targetTop = intoCoordSystem(cm, lineObj, measureCharPrepared(cm, preparedMeasure, target), \"line\").top;\n return wrappedLineExtent(cm, lineObj, preparedMeasure, targetTop)\n }\n\n // Returns true if the given side of a box is after the given\n // coordinates, in top-to-bottom, left-to-right order.\n function boxIsAfter(box, x, y, left) {\n return box.bottom <= y ? false : box.top > y ? true : (left ? box.left : box.right) > x\n }\n\n function coordsCharInner(cm, lineObj, lineNo$$1, x, y) {\n // Move y into line-local coordinate space\n y -= heightAtLine(lineObj);\n var preparedMeasure = prepareMeasureForLine(cm, lineObj);\n // When directly calling `measureCharPrepared`, we have to adjust\n // for the widgets at this line.\n var widgetHeight$$1 = widgetTopHeight(lineObj);\n var begin = 0, end = lineObj.text.length, ltr = true;\n\n var order = getOrder(lineObj, cm.doc.direction);\n // If the line isn't plain left-to-right text, first figure out\n // which bidi section the coordinates fall into.\n if (order) {\n var part = (cm.options.lineWrapping ? coordsBidiPartWrapped : coordsBidiPart)\n (cm, lineObj, lineNo$$1, preparedMeasure, order, x, y);\n ltr = part.level != 1;\n // The awkward -1 offsets are needed because findFirst (called\n // on these below) will treat its first bound as inclusive,\n // second as exclusive, but we want to actually address the\n // characters in the part's range\n begin = ltr ? part.from : part.to - 1;\n end = ltr ? part.to : part.from - 1;\n }\n\n // A binary search to find the first character whose bounding box\n // starts after the coordinates. If we run across any whose box wrap\n // the coordinates, store that.\n var chAround = null, boxAround = null;\n var ch = findFirst(function (ch) {\n var box = measureCharPrepared(cm, preparedMeasure, ch);\n box.top += widgetHeight$$1; box.bottom += widgetHeight$$1;\n if (!boxIsAfter(box, x, y, false)) { return false }\n if (box.top <= y && box.left <= x) {\n chAround = ch;\n boxAround = box;\n }\n return true\n }, begin, end);\n\n var baseX, sticky, outside = false;\n // If a box around the coordinates was found, use that\n if (boxAround) {\n // Distinguish coordinates nearer to the left or right side of the box\n var atLeft = x - boxAround.left < boxAround.right - x, atStart = atLeft == ltr;\n ch = chAround + (atStart ? 0 : 1);\n sticky = atStart ? \"after\" : \"before\";\n baseX = atLeft ? boxAround.left : boxAround.right;\n } else {\n // (Adjust for extended bound, if necessary.)\n if (!ltr && (ch == end || ch == begin)) { ch++; }\n // To determine which side to associate with, get the box to the\n // left of the character and compare it's vertical position to the\n // coordinates\n sticky = ch == 0 ? \"after\" : ch == lineObj.text.length ? \"before\" :\n (measureCharPrepared(cm, preparedMeasure, ch - (ltr ? 1 : 0)).bottom + widgetHeight$$1 <= y) == ltr ?\n \"after\" : \"before\";\n // Now get accurate coordinates for this place, in order to get a\n // base X position\n var coords = cursorCoords(cm, Pos(lineNo$$1, ch, sticky), \"line\", lineObj, preparedMeasure);\n baseX = coords.left;\n outside = y < coords.top || y >= coords.bottom;\n }\n\n ch = skipExtendingChars(lineObj.text, ch, 1);\n return PosWithInfo(lineNo$$1, ch, sticky, outside, x - baseX)\n }\n\n function coordsBidiPart(cm, lineObj, lineNo$$1, preparedMeasure, order, x, y) {\n // Bidi parts are sorted left-to-right, and in a non-line-wrapping\n // situation, we can take this ordering to correspond to the visual\n // ordering. This finds the first part whose end is after the given\n // coordinates.\n var index = findFirst(function (i) {\n var part = order[i], ltr = part.level != 1;\n return boxIsAfter(cursorCoords(cm, Pos(lineNo$$1, ltr ? part.to : part.from, ltr ? \"before\" : \"after\"),\n \"line\", lineObj, preparedMeasure), x, y, true)\n }, 0, order.length - 1);\n var part = order[index];\n // If this isn't the first part, the part's start is also after\n // the coordinates, and the coordinates aren't on the same line as\n // that start, move one part back.\n if (index > 0) {\n var ltr = part.level != 1;\n var start = cursorCoords(cm, Pos(lineNo$$1, ltr ? part.from : part.to, ltr ? \"after\" : \"before\"),\n \"line\", lineObj, preparedMeasure);\n if (boxIsAfter(start, x, y, true) && start.top > y)\n { part = order[index - 1]; }\n }\n return part\n }\n\n function coordsBidiPartWrapped(cm, lineObj, _lineNo, preparedMeasure, order, x, y) {\n // In a wrapped line, rtl text on wrapping boundaries can do things\n // that don't correspond to the ordering in our `order` array at\n // all, so a binary search doesn't work, and we want to return a\n // part that only spans one line so that the binary search in\n // coordsCharInner is safe. As such, we first find the extent of the\n // wrapped line, and then do a flat search in which we discard any\n // spans that aren't on the line.\n var ref = wrappedLineExtent(cm, lineObj, preparedMeasure, y);\n var begin = ref.begin;\n var end = ref.end;\n if (/\\s/.test(lineObj.text.charAt(end - 1))) { end--; }\n var part = null, closestDist = null;\n for (var i = 0; i < order.length; i++) {\n var p = order[i];\n if (p.from >= end || p.to <= begin) { continue }\n var ltr = p.level != 1;\n var endX = measureCharPrepared(cm, preparedMeasure, ltr ? Math.min(end, p.to) - 1 : Math.max(begin, p.from)).right;\n // Weigh against spans ending before this, so that they are only\n // picked if nothing ends after\n var dist = endX < x ? x - endX + 1e9 : endX - x;\n if (!part || closestDist > dist) {\n part = p;\n closestDist = dist;\n }\n }\n if (!part) { part = order[order.length - 1]; }\n // Clip the part to the wrapped line.\n if (part.from < begin) { part = {from: begin, to: part.to, level: part.level}; }\n if (part.to > end) { part = {from: part.from, to: end, level: part.level}; }\n return part\n }\n\n var measureText;\n // Compute the default text height.\n function textHeight(display) {\n if (display.cachedTextHeight != null) { return display.cachedTextHeight }\n if (measureText == null) {\n measureText = elt(\"pre\");\n // Measure a bunch of lines, for browsers that compute\n // fractional heights.\n for (var i = 0; i < 49; ++i) {\n measureText.appendChild(document.createTextNode(\"x\"));\n measureText.appendChild(elt(\"br\"));\n }\n measureText.appendChild(document.createTextNode(\"x\"));\n }\n removeChildrenAndAdd(display.measure, measureText);\n var height = measureText.offsetHeight / 50;\n if (height > 3) { display.cachedTextHeight = height; }\n removeChildren(display.measure);\n return height || 1\n }\n\n // Compute the default character width.\n function charWidth(display) {\n if (display.cachedCharWidth != null) { return display.cachedCharWidth }\n var anchor = elt(\"span\", \"xxxxxxxxxx\");\n var pre = elt(\"pre\", [anchor]);\n removeChildrenAndAdd(display.measure, pre);\n var rect = anchor.getBoundingClientRect(), width = (rect.right - rect.left) / 10;\n if (width > 2) { display.cachedCharWidth = width; }\n return width || 10\n }\n\n // Do a bulk-read of the DOM positions and sizes needed to draw the\n // view, so that we don't interleave reading and writing to the DOM.\n function getDimensions(cm) {\n var d = cm.display, left = {}, width = {};\n var gutterLeft = d.gutters.clientLeft;\n for (var n = d.gutters.firstChild, i = 0; n; n = n.nextSibling, ++i) {\n left[cm.options.gutters[i]] = n.offsetLeft + n.clientLeft + gutterLeft;\n width[cm.options.gutters[i]] = n.clientWidth;\n }\n return {fixedPos: compensateForHScroll(d),\n gutterTotalWidth: d.gutters.offsetWidth,\n gutterLeft: left,\n gutterWidth: width,\n wrapperWidth: d.wrapper.clientWidth}\n }\n\n // Computes display.scroller.scrollLeft + display.gutters.offsetWidth,\n // but using getBoundingClientRect to get a sub-pixel-accurate\n // result.\n function compensateForHScroll(display) {\n return display.scroller.getBoundingClientRect().left - display.sizer.getBoundingClientRect().left\n }\n\n // Returns a function that estimates the height of a line, to use as\n // first approximation until the line becomes visible (and is thus\n // properly measurable).\n function estimateHeight(cm) {\n var th = textHeight(cm.display), wrapping = cm.options.lineWrapping;\n var perLine = wrapping && Math.max(5, cm.display.scroller.clientWidth / charWidth(cm.display) - 3);\n return function (line) {\n if (lineIsHidden(cm.doc, line)) { return 0 }\n\n var widgetsHeight = 0;\n if (line.widgets) { for (var i = 0; i < line.widgets.length; i++) {\n if (line.widgets[i].height) { widgetsHeight += line.widgets[i].height; }\n } }\n\n if (wrapping)\n { return widgetsHeight + (Math.ceil(line.text.length / perLine) || 1) * th }\n else\n { return widgetsHeight + th }\n }\n }\n\n function estimateLineHeights(cm) {\n var doc = cm.doc, est = estimateHeight(cm);\n doc.iter(function (line) {\n var estHeight = est(line);\n if (estHeight != line.height) { updateLineHeight(line, estHeight); }\n });\n }\n\n // Given a mouse event, find the corresponding position. If liberal\n // is false, it checks whether a gutter or scrollbar was clicked,\n // and returns null if it was. forRect is used by rectangular\n // selections, and tries to estimate a character position even for\n // coordinates beyond the right of the text.\n function posFromMouse(cm, e, liberal, forRect) {\n var display = cm.display;\n if (!liberal && e_target(e).getAttribute(\"cm-not-content\") == \"true\") { return null }\n\n var x, y, space = display.lineSpace.getBoundingClientRect();\n // Fails unpredictably on IE[67] when mouse is dragged around quickly.\n try { x = e.clientX - space.left; y = e.clientY - space.top; }\n catch (e) { return null }\n var coords = coordsChar(cm, x, y), line;\n if (forRect && coords.xRel == 1 && (line = getLine(cm.doc, coords.line).text).length == coords.ch) {\n var colDiff = countColumn(line, line.length, cm.options.tabSize) - line.length;\n coords = Pos(coords.line, Math.max(0, Math.round((x - paddingH(cm.display).left) / charWidth(cm.display)) - colDiff));\n }\n return coords\n }\n\n // Find the view element corresponding to a given line. Return null\n // when the line isn't visible.\n function findViewIndex(cm, n) {\n if (n >= cm.display.viewTo) { return null }\n n -= cm.display.viewFrom;\n if (n < 0) { return null }\n var view = cm.display.view;\n for (var i = 0; i < view.length; i++) {\n n -= view[i].size;\n if (n < 0) { return i }\n }\n }\n\n function updateSelection(cm) {\n cm.display.input.showSelection(cm.display.input.prepareSelection());\n }\n\n function prepareSelection(cm, primary) {\n if ( primary === void 0 ) primary = true;\n\n var doc = cm.doc, result = {};\n var curFragment = result.cursors = document.createDocumentFragment();\n var selFragment = result.selection = document.createDocumentFragment();\n\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n if (!primary && i == doc.sel.primIndex) { continue }\n var range$$1 = doc.sel.ranges[i];\n if (range$$1.from().line >= cm.display.viewTo || range$$1.to().line < cm.display.viewFrom) { continue }\n var collapsed = range$$1.empty();\n if (collapsed || cm.options.showCursorWhenSelecting)\n { drawSelectionCursor(cm, range$$1.head, curFragment); }\n if (!collapsed)\n { drawSelectionRange(cm, range$$1, selFragment); }\n }\n return result\n }\n\n // Draws a cursor for the given range\n function drawSelectionCursor(cm, head, output) {\n var pos = cursorCoords(cm, head, \"div\", null, null, !cm.options.singleCursorHeightPerLine);\n\n var cursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor\"));\n cursor.style.left = pos.left + \"px\";\n cursor.style.top = pos.top + \"px\";\n cursor.style.height = Math.max(0, pos.bottom - pos.top) * cm.options.cursorHeight + \"px\";\n\n if (pos.other) {\n // Secondary cursor, shown when on a 'jump' in bi-directional text\n var otherCursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor CodeMirror-secondarycursor\"));\n otherCursor.style.display = \"\";\n otherCursor.style.left = pos.other.left + \"px\";\n otherCursor.style.top = pos.other.top + \"px\";\n otherCursor.style.height = (pos.other.bottom - pos.other.top) * .85 + \"px\";\n }\n }\n\n function cmpCoords(a, b) { return a.top - b.top || a.left - b.left }\n\n // Draws the given range as a highlighted selection\n function drawSelectionRange(cm, range$$1, output) {\n var display = cm.display, doc = cm.doc;\n var fragment = document.createDocumentFragment();\n var padding = paddingH(cm.display), leftSide = padding.left;\n var rightSide = Math.max(display.sizerWidth, displayWidth(cm) - display.sizer.offsetLeft) - padding.right;\n var docLTR = doc.direction == \"ltr\";\n\n function add(left, top, width, bottom) {\n if (top < 0) { top = 0; }\n top = Math.round(top);\n bottom = Math.round(bottom);\n fragment.appendChild(elt(\"div\", null, \"CodeMirror-selected\", (\"position: absolute; left: \" + left + \"px;\\n top: \" + top + \"px; width: \" + (width == null ? rightSide - left : width) + \"px;\\n height: \" + (bottom - top) + \"px\")));\n }\n\n function drawForLine(line, fromArg, toArg) {\n var lineObj = getLine(doc, line);\n var lineLen = lineObj.text.length;\n var start, end;\n function coords(ch, bias) {\n return charCoords(cm, Pos(line, ch), \"div\", lineObj, bias)\n }\n\n function wrapX(pos, dir, side) {\n var extent = wrappedLineExtentChar(cm, lineObj, null, pos);\n var prop = (dir == \"ltr\") == (side == \"after\") ? \"left\" : \"right\";\n var ch = side == \"after\" ? extent.begin : extent.end - (/\\s/.test(lineObj.text.charAt(extent.end - 1)) ? 2 : 1);\n return coords(ch, prop)[prop]\n }\n\n var order = getOrder(lineObj, doc.direction);\n iterateBidiSections(order, fromArg || 0, toArg == null ? lineLen : toArg, function (from, to, dir, i) {\n var ltr = dir == \"ltr\";\n var fromPos = coords(from, ltr ? \"left\" : \"right\");\n var toPos = coords(to - 1, ltr ? \"right\" : \"left\");\n\n var openStart = fromArg == null && from == 0, openEnd = toArg == null && to == lineLen;\n var first = i == 0, last = !order || i == order.length - 1;\n if (toPos.top - fromPos.top <= 3) { // Single line\n var openLeft = (docLTR ? openStart : openEnd) && first;\n var openRight = (docLTR ? openEnd : openStart) && last;\n var left = openLeft ? leftSide : (ltr ? fromPos : toPos).left;\n var right = openRight ? rightSide : (ltr ? toPos : fromPos).right;\n add(left, fromPos.top, right - left, fromPos.bottom);\n } else { // Multiple lines\n var topLeft, topRight, botLeft, botRight;\n if (ltr) {\n topLeft = docLTR && openStart && first ? leftSide : fromPos.left;\n topRight = docLTR ? rightSide : wrapX(from, dir, \"before\");\n botLeft = docLTR ? leftSide : wrapX(to, dir, \"after\");\n botRight = docLTR && openEnd && last ? rightSide : toPos.right;\n } else {\n topLeft = !docLTR ? leftSide : wrapX(from, dir, \"before\");\n topRight = !docLTR && openStart && first ? rightSide : fromPos.right;\n botLeft = !docLTR && openEnd && last ? leftSide : toPos.left;\n botRight = !docLTR ? rightSide : wrapX(to, dir, \"after\");\n }\n add(topLeft, fromPos.top, topRight - topLeft, fromPos.bottom);\n if (fromPos.bottom < toPos.top) { add(leftSide, fromPos.bottom, null, toPos.top); }\n add(botLeft, toPos.top, botRight - botLeft, toPos.bottom);\n }\n\n if (!start || cmpCoords(fromPos, start) < 0) { start = fromPos; }\n if (cmpCoords(toPos, start) < 0) { start = toPos; }\n if (!end || cmpCoords(fromPos, end) < 0) { end = fromPos; }\n if (cmpCoords(toPos, end) < 0) { end = toPos; }\n });\n return {start: start, end: end}\n }\n\n var sFrom = range$$1.from(), sTo = range$$1.to();\n if (sFrom.line == sTo.line) {\n drawForLine(sFrom.line, sFrom.ch, sTo.ch);\n } else {\n var fromLine = getLine(doc, sFrom.line), toLine = getLine(doc, sTo.line);\n var singleVLine = visualLine(fromLine) == visualLine(toLine);\n var leftEnd = drawForLine(sFrom.line, sFrom.ch, singleVLine ? fromLine.text.length + 1 : null).end;\n var rightStart = drawForLine(sTo.line, singleVLine ? 0 : null, sTo.ch).start;\n if (singleVLine) {\n if (leftEnd.top < rightStart.top - 2) {\n add(leftEnd.right, leftEnd.top, null, leftEnd.bottom);\n add(leftSide, rightStart.top, rightStart.left, rightStart.bottom);\n } else {\n add(leftEnd.right, leftEnd.top, rightStart.left - leftEnd.right, leftEnd.bottom);\n }\n }\n if (leftEnd.bottom < rightStart.top)\n { add(leftSide, leftEnd.bottom, null, rightStart.top); }\n }\n\n output.appendChild(fragment);\n }\n\n // Cursor-blinking\n function restartBlink(cm) {\n if (!cm.state.focused) { return }\n var display = cm.display;\n clearInterval(display.blinker);\n var on = true;\n display.cursorDiv.style.visibility = \"\";\n if (cm.options.cursorBlinkRate > 0)\n { display.blinker = setInterval(function () { return display.cursorDiv.style.visibility = (on = !on) ? \"\" : \"hidden\"; },\n cm.options.cursorBlinkRate); }\n else if (cm.options.cursorBlinkRate < 0)\n { display.cursorDiv.style.visibility = \"hidden\"; }\n }\n\n function ensureFocus(cm) {\n if (!cm.state.focused) { cm.display.input.focus(); onFocus(cm); }\n }\n\n function delayBlurEvent(cm) {\n cm.state.delayingBlurEvent = true;\n setTimeout(function () { if (cm.state.delayingBlurEvent) {\n cm.state.delayingBlurEvent = false;\n onBlur(cm);\n } }, 100);\n }\n\n function onFocus(cm, e) {\n if (cm.state.delayingBlurEvent) { cm.state.delayingBlurEvent = false; }\n\n if (cm.options.readOnly == \"nocursor\") { return }\n if (!cm.state.focused) {\n signal(cm, \"focus\", cm, e);\n cm.state.focused = true;\n addClass(cm.display.wrapper, \"CodeMirror-focused\");\n // This test prevents this from firing when a context\n // menu is closed (since the input reset would kill the\n // select-all detection hack)\n if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) {\n cm.display.input.reset();\n if (webkit) { setTimeout(function () { return cm.display.input.reset(true); }, 20); } // Issue #1730\n }\n cm.display.input.receivedFocus();\n }\n restartBlink(cm);\n }\n function onBlur(cm, e) {\n if (cm.state.delayingBlurEvent) { return }\n\n if (cm.state.focused) {\n signal(cm, \"blur\", cm, e);\n cm.state.focused = false;\n rmClass(cm.display.wrapper, \"CodeMirror-focused\");\n }\n clearInterval(cm.display.blinker);\n setTimeout(function () { if (!cm.state.focused) { cm.display.shift = false; } }, 150);\n }\n\n // Read the actual heights of the rendered lines, and update their\n // stored heights to match.\n function updateHeightsInViewport(cm) {\n var display = cm.display;\n var prevBottom = display.lineDiv.offsetTop;\n for (var i = 0; i < display.view.length; i++) {\n var cur = display.view[i], wrapping = cm.options.lineWrapping;\n var height = (void 0), width = 0;\n if (cur.hidden) { continue }\n if (ie && ie_version < 8) {\n var bot = cur.node.offsetTop + cur.node.offsetHeight;\n height = bot - prevBottom;\n prevBottom = bot;\n } else {\n var box = cur.node.getBoundingClientRect();\n height = box.bottom - box.top;\n // Check that lines don't extend past the right of the current\n // editor width\n if (!wrapping && cur.text.firstChild)\n { width = cur.text.firstChild.getBoundingClientRect().right - box.left - 1; }\n }\n var diff = cur.line.height - height;\n if (height < 2) { height = textHeight(display); }\n if (diff > .005 || diff < -.005) {\n updateLineHeight(cur.line, height);\n updateWidgetHeight(cur.line);\n if (cur.rest) { for (var j = 0; j < cur.rest.length; j++)\n { updateWidgetHeight(cur.rest[j]); } }\n }\n if (width > cm.display.sizerWidth) {\n var chWidth = Math.ceil(width / charWidth(cm.display));\n if (chWidth > cm.display.maxLineLength) {\n cm.display.maxLineLength = chWidth;\n cm.display.maxLine = cur.line;\n cm.display.maxLineChanged = true;\n }\n }\n }\n }\n\n // Read and store the height of line widgets associated with the\n // given line.\n function updateWidgetHeight(line) {\n if (line.widgets) { for (var i = 0; i < line.widgets.length; ++i) {\n var w = line.widgets[i], parent = w.node.parentNode;\n if (parent) { w.height = parent.offsetHeight; }\n } }\n }\n\n // Compute the lines that are visible in a given viewport (defaults\n // the the current scroll position). viewport may contain top,\n // height, and ensure (see op.scrollToPos) properties.\n function visibleLines(display, doc, viewport) {\n var top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop;\n top = Math.floor(top - paddingTop(display));\n var bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight;\n\n var from = lineAtHeight(doc, top), to = lineAtHeight(doc, bottom);\n // Ensure is a {from: {line, ch}, to: {line, ch}} object, and\n // forces those lines into the viewport (if possible).\n if (viewport && viewport.ensure) {\n var ensureFrom = viewport.ensure.from.line, ensureTo = viewport.ensure.to.line;\n if (ensureFrom < from) {\n from = ensureFrom;\n to = lineAtHeight(doc, heightAtLine(getLine(doc, ensureFrom)) + display.wrapper.clientHeight);\n } else if (Math.min(ensureTo, doc.lastLine()) >= to) {\n from = lineAtHeight(doc, heightAtLine(getLine(doc, ensureTo)) - display.wrapper.clientHeight);\n to = ensureTo;\n }\n }\n return {from: from, to: Math.max(to, from + 1)}\n }\n\n // Re-align line numbers and gutter marks to compensate for\n // horizontal scrolling.\n function alignHorizontally(cm) {\n var display = cm.display, view = display.view;\n if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) { return }\n var comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft;\n var gutterW = display.gutters.offsetWidth, left = comp + \"px\";\n for (var i = 0; i < view.length; i++) { if (!view[i].hidden) {\n if (cm.options.fixedGutter) {\n if (view[i].gutter)\n { view[i].gutter.style.left = left; }\n if (view[i].gutterBackground)\n { view[i].gutterBackground.style.left = left; }\n }\n var align = view[i].alignable;\n if (align) { for (var j = 0; j < align.length; j++)\n { align[j].style.left = left; } }\n } }\n if (cm.options.fixedGutter)\n { display.gutters.style.left = (comp + gutterW) + \"px\"; }\n }\n\n // Used to ensure that the line number gutter is still the right\n // size for the current document size. Returns true when an update\n // is needed.\n function maybeUpdateLineNumberWidth(cm) {\n if (!cm.options.lineNumbers) { return false }\n var doc = cm.doc, last = lineNumberFor(cm.options, doc.first + doc.size - 1), display = cm.display;\n if (last.length != display.lineNumChars) {\n var test = display.measure.appendChild(elt(\"div\", [elt(\"div\", last)],\n \"CodeMirror-linenumber CodeMirror-gutter-elt\"));\n var innerW = test.firstChild.offsetWidth, padding = test.offsetWidth - innerW;\n display.lineGutter.style.width = \"\";\n display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1;\n display.lineNumWidth = display.lineNumInnerWidth + padding;\n display.lineNumChars = display.lineNumInnerWidth ? last.length : -1;\n display.lineGutter.style.width = display.lineNumWidth + \"px\";\n updateGutterSpace(cm);\n return true\n }\n return false\n }\n\n // SCROLLING THINGS INTO VIEW\n\n // If an editor sits on the top or bottom of the window, partially\n // scrolled out of view, this ensures that the cursor is visible.\n function maybeScrollWindow(cm, rect) {\n if (signalDOMEvent(cm, \"scrollCursorIntoView\")) { return }\n\n var display = cm.display, box = display.sizer.getBoundingClientRect(), doScroll = null;\n if (rect.top + box.top < 0) { doScroll = true; }\n else if (rect.bottom + box.top > (window.innerHeight || document.documentElement.clientHeight)) { doScroll = false; }\n if (doScroll != null && !phantom) {\n var scrollNode = elt(\"div\", \"\\u200b\", null, (\"position: absolute;\\n top: \" + (rect.top - display.viewOffset - paddingTop(cm.display)) + \"px;\\n height: \" + (rect.bottom - rect.top + scrollGap(cm) + display.barHeight) + \"px;\\n left: \" + (rect.left) + \"px; width: \" + (Math.max(2, rect.right - rect.left)) + \"px;\"));\n cm.display.lineSpace.appendChild(scrollNode);\n scrollNode.scrollIntoView(doScroll);\n cm.display.lineSpace.removeChild(scrollNode);\n }\n }\n\n // Scroll a given position into view (immediately), verifying that\n // it actually became visible (as line heights are accurately\n // measured, the position of something may 'drift' during drawing).\n function scrollPosIntoView(cm, pos, end, margin) {\n if (margin == null) { margin = 0; }\n var rect;\n if (!cm.options.lineWrapping && pos == end) {\n // Set pos and end to the cursor positions around the character pos sticks to\n // If pos.sticky == \"before\", that is around pos.ch - 1, otherwise around pos.ch\n // If pos == Pos(_, 0, \"before\"), pos and end are unchanged\n pos = pos.ch ? Pos(pos.line, pos.sticky == \"before\" ? pos.ch - 1 : pos.ch, \"after\") : pos;\n end = pos.sticky == \"before\" ? Pos(pos.line, pos.ch + 1, \"before\") : pos;\n }\n for (var limit = 0; limit < 5; limit++) {\n var changed = false;\n var coords = cursorCoords(cm, pos);\n var endCoords = !end || end == pos ? coords : cursorCoords(cm, end);\n rect = {left: Math.min(coords.left, endCoords.left),\n top: Math.min(coords.top, endCoords.top) - margin,\n right: Math.max(coords.left, endCoords.left),\n bottom: Math.max(coords.bottom, endCoords.bottom) + margin};\n var scrollPos = calculateScrollPos(cm, rect);\n var startTop = cm.doc.scrollTop, startLeft = cm.doc.scrollLeft;\n if (scrollPos.scrollTop != null) {\n updateScrollTop(cm, scrollPos.scrollTop);\n if (Math.abs(cm.doc.scrollTop - startTop) > 1) { changed = true; }\n }\n if (scrollPos.scrollLeft != null) {\n setScrollLeft(cm, scrollPos.scrollLeft);\n if (Math.abs(cm.doc.scrollLeft - startLeft) > 1) { changed = true; }\n }\n if (!changed) { break }\n }\n return rect\n }\n\n // Scroll a given set of coordinates into view (immediately).\n function scrollIntoView(cm, rect) {\n var scrollPos = calculateScrollPos(cm, rect);\n if (scrollPos.scrollTop != null) { updateScrollTop(cm, scrollPos.scrollTop); }\n if (scrollPos.scrollLeft != null) { setScrollLeft(cm, scrollPos.scrollLeft); }\n }\n\n // Calculate a new scroll position needed to scroll the given\n // rectangle into view. Returns an object with scrollTop and\n // scrollLeft properties. When these are undefined, the\n // vertical/horizontal position does not need to be adjusted.\n function calculateScrollPos(cm, rect) {\n var display = cm.display, snapMargin = textHeight(cm.display);\n if (rect.top < 0) { rect.top = 0; }\n var screentop = cm.curOp && cm.curOp.scrollTop != null ? cm.curOp.scrollTop : display.scroller.scrollTop;\n var screen = displayHeight(cm), result = {};\n if (rect.bottom - rect.top > screen) { rect.bottom = rect.top + screen; }\n var docBottom = cm.doc.height + paddingVert(display);\n var atTop = rect.top < snapMargin, atBottom = rect.bottom > docBottom - snapMargin;\n if (rect.top < screentop) {\n result.scrollTop = atTop ? 0 : rect.top;\n } else if (rect.bottom > screentop + screen) {\n var newTop = Math.min(rect.top, (atBottom ? docBottom : rect.bottom) - screen);\n if (newTop != screentop) { result.scrollTop = newTop; }\n }\n\n var screenleft = cm.curOp && cm.curOp.scrollLeft != null ? cm.curOp.scrollLeft : display.scroller.scrollLeft;\n var screenw = displayWidth(cm) - (cm.options.fixedGutter ? display.gutters.offsetWidth : 0);\n var tooWide = rect.right - rect.left > screenw;\n if (tooWide) { rect.right = rect.left + screenw; }\n if (rect.left < 10)\n { result.scrollLeft = 0; }\n else if (rect.left < screenleft)\n { result.scrollLeft = Math.max(0, rect.left - (tooWide ? 0 : 10)); }\n else if (rect.right > screenw + screenleft - 3)\n { result.scrollLeft = rect.right + (tooWide ? 0 : 10) - screenw; }\n return result\n }\n\n // Store a relative adjustment to the scroll position in the current\n // operation (to be applied when the operation finishes).\n function addToScrollTop(cm, top) {\n if (top == null) { return }\n resolveScrollToPos(cm);\n cm.curOp.scrollTop = (cm.curOp.scrollTop == null ? cm.doc.scrollTop : cm.curOp.scrollTop) + top;\n }\n\n // Make sure that at the end of the operation the current cursor is\n // shown.\n function ensureCursorVisible(cm) {\n resolveScrollToPos(cm);\n var cur = cm.getCursor();\n cm.curOp.scrollToPos = {from: cur, to: cur, margin: cm.options.cursorScrollMargin};\n }\n\n function scrollToCoords(cm, x, y) {\n if (x != null || y != null) { resolveScrollToPos(cm); }\n if (x != null) { cm.curOp.scrollLeft = x; }\n if (y != null) { cm.curOp.scrollTop = y; }\n }\n\n function scrollToRange(cm, range$$1) {\n resolveScrollToPos(cm);\n cm.curOp.scrollToPos = range$$1;\n }\n\n // When an operation has its scrollToPos property set, and another\n // scroll action is applied before the end of the operation, this\n // 'simulates' scrolling that position into view in a cheap way, so\n // that the effect of intermediate scroll commands is not ignored.\n function resolveScrollToPos(cm) {\n var range$$1 = cm.curOp.scrollToPos;\n if (range$$1) {\n cm.curOp.scrollToPos = null;\n var from = estimateCoords(cm, range$$1.from), to = estimateCoords(cm, range$$1.to);\n scrollToCoordsRange(cm, from, to, range$$1.margin);\n }\n }\n\n function scrollToCoordsRange(cm, from, to, margin) {\n var sPos = calculateScrollPos(cm, {\n left: Math.min(from.left, to.left),\n top: Math.min(from.top, to.top) - margin,\n right: Math.max(from.right, to.right),\n bottom: Math.max(from.bottom, to.bottom) + margin\n });\n scrollToCoords(cm, sPos.scrollLeft, sPos.scrollTop);\n }\n\n // Sync the scrollable area and scrollbars, ensure the viewport\n // covers the visible area.\n function updateScrollTop(cm, val) {\n if (Math.abs(cm.doc.scrollTop - val) < 2) { return }\n if (!gecko) { updateDisplaySimple(cm, {top: val}); }\n setScrollTop(cm, val, true);\n if (gecko) { updateDisplaySimple(cm); }\n startWorker(cm, 100);\n }\n\n function setScrollTop(cm, val, forceScroll) {\n val = Math.min(cm.display.scroller.scrollHeight - cm.display.scroller.clientHeight, val);\n if (cm.display.scroller.scrollTop == val && !forceScroll) { return }\n cm.doc.scrollTop = val;\n cm.display.scrollbars.setScrollTop(val);\n if (cm.display.scroller.scrollTop != val) { cm.display.scroller.scrollTop = val; }\n }\n\n // Sync scroller and scrollbar, ensure the gutter elements are\n // aligned.\n function setScrollLeft(cm, val, isScroller, forceScroll) {\n val = Math.min(val, cm.display.scroller.scrollWidth - cm.display.scroller.clientWidth);\n if ((isScroller ? val == cm.doc.scrollLeft : Math.abs(cm.doc.scrollLeft - val) < 2) && !forceScroll) { return }\n cm.doc.scrollLeft = val;\n alignHorizontally(cm);\n if (cm.display.scroller.scrollLeft != val) { cm.display.scroller.scrollLeft = val; }\n cm.display.scrollbars.setScrollLeft(val);\n }\n\n // SCROLLBARS\n\n // Prepare DOM reads needed to update the scrollbars. Done in one\n // shot to minimize update/measure roundtrips.\n function measureForScrollbars(cm) {\n var d = cm.display, gutterW = d.gutters.offsetWidth;\n var docH = Math.round(cm.doc.height + paddingVert(cm.display));\n return {\n clientHeight: d.scroller.clientHeight,\n viewHeight: d.wrapper.clientHeight,\n scrollWidth: d.scroller.scrollWidth, clientWidth: d.scroller.clientWidth,\n viewWidth: d.wrapper.clientWidth,\n barLeft: cm.options.fixedGutter ? gutterW : 0,\n docHeight: docH,\n scrollHeight: docH + scrollGap(cm) + d.barHeight,\n nativeBarWidth: d.nativeBarWidth,\n gutterWidth: gutterW\n }\n }\n\n var NativeScrollbars = function(place, scroll, cm) {\n this.cm = cm;\n var vert = this.vert = elt(\"div\", [elt(\"div\", null, null, \"min-width: 1px\")], \"CodeMirror-vscrollbar\");\n var horiz = this.horiz = elt(\"div\", [elt(\"div\", null, null, \"height: 100%; min-height: 1px\")], \"CodeMirror-hscrollbar\");\n vert.tabIndex = horiz.tabIndex = -1;\n place(vert); place(horiz);\n\n on(vert, \"scroll\", function () {\n if (vert.clientHeight) { scroll(vert.scrollTop, \"vertical\"); }\n });\n on(horiz, \"scroll\", function () {\n if (horiz.clientWidth) { scroll(horiz.scrollLeft, \"horizontal\"); }\n });\n\n this.checkedZeroWidth = false;\n // Need to set a minimum width to see the scrollbar on IE7 (but must not set it on IE8).\n if (ie && ie_version < 8) { this.horiz.style.minHeight = this.vert.style.minWidth = \"18px\"; }\n };\n\n NativeScrollbars.prototype.update = function (measure) {\n var needsH = measure.scrollWidth > measure.clientWidth + 1;\n var needsV = measure.scrollHeight > measure.clientHeight + 1;\n var sWidth = measure.nativeBarWidth;\n\n if (needsV) {\n this.vert.style.display = \"block\";\n this.vert.style.bottom = needsH ? sWidth + \"px\" : \"0\";\n var totalHeight = measure.viewHeight - (needsH ? sWidth : 0);\n // A bug in IE8 can cause this value to be negative, so guard it.\n this.vert.firstChild.style.height =\n Math.max(0, measure.scrollHeight - measure.clientHeight + totalHeight) + \"px\";\n } else {\n this.vert.style.display = \"\";\n this.vert.firstChild.style.height = \"0\";\n }\n\n if (needsH) {\n this.horiz.style.display = \"block\";\n this.horiz.style.right = needsV ? sWidth + \"px\" : \"0\";\n this.horiz.style.left = measure.barLeft + \"px\";\n var totalWidth = measure.viewWidth - measure.barLeft - (needsV ? sWidth : 0);\n this.horiz.firstChild.style.width =\n Math.max(0, measure.scrollWidth - measure.clientWidth + totalWidth) + \"px\";\n } else {\n this.horiz.style.display = \"\";\n this.horiz.firstChild.style.width = \"0\";\n }\n\n if (!this.checkedZeroWidth && measure.clientHeight > 0) {\n if (sWidth == 0) { this.zeroWidthHack(); }\n this.checkedZeroWidth = true;\n }\n\n return {right: needsV ? sWidth : 0, bottom: needsH ? sWidth : 0}\n };\n\n NativeScrollbars.prototype.setScrollLeft = function (pos) {\n if (this.horiz.scrollLeft != pos) { this.horiz.scrollLeft = pos; }\n if (this.disableHoriz) { this.enableZeroWidthBar(this.horiz, this.disableHoriz, \"horiz\"); }\n };\n\n NativeScrollbars.prototype.setScrollTop = function (pos) {\n if (this.vert.scrollTop != pos) { this.vert.scrollTop = pos; }\n if (this.disableVert) { this.enableZeroWidthBar(this.vert, this.disableVert, \"vert\"); }\n };\n\n NativeScrollbars.prototype.zeroWidthHack = function () {\n var w = mac && !mac_geMountainLion ? \"12px\" : \"18px\";\n this.horiz.style.height = this.vert.style.width = w;\n this.horiz.style.pointerEvents = this.vert.style.pointerEvents = \"none\";\n this.disableHoriz = new Delayed;\n this.disableVert = new Delayed;\n };\n\n NativeScrollbars.prototype.enableZeroWidthBar = function (bar, delay, type) {\n bar.style.pointerEvents = \"auto\";\n function maybeDisable() {\n // To find out whether the scrollbar is still visible, we\n // check whether the element under the pixel in the bottom\n // right corner of the scrollbar box is the scrollbar box\n // itself (when the bar is still visible) or its filler child\n // (when the bar is hidden). If it is still visible, we keep\n // it enabled, if it's hidden, we disable pointer events.\n var box = bar.getBoundingClientRect();\n var elt$$1 = type == \"vert\" ? document.elementFromPoint(box.right - 1, (box.top + box.bottom) / 2)\n : document.elementFromPoint((box.right + box.left) / 2, box.bottom - 1);\n if (elt$$1 != bar) { bar.style.pointerEvents = \"none\"; }\n else { delay.set(1000, maybeDisable); }\n }\n delay.set(1000, maybeDisable);\n };\n\n NativeScrollbars.prototype.clear = function () {\n var parent = this.horiz.parentNode;\n parent.removeChild(this.horiz);\n parent.removeChild(this.vert);\n };\n\n var NullScrollbars = function () {};\n\n NullScrollbars.prototype.update = function () { return {bottom: 0, right: 0} };\n NullScrollbars.prototype.setScrollLeft = function () {};\n NullScrollbars.prototype.setScrollTop = function () {};\n NullScrollbars.prototype.clear = function () {};\n\n function updateScrollbars(cm, measure) {\n if (!measure) { measure = measureForScrollbars(cm); }\n var startWidth = cm.display.barWidth, startHeight = cm.display.barHeight;\n updateScrollbarsInner(cm, measure);\n for (var i = 0; i < 4 && startWidth != cm.display.barWidth || startHeight != cm.display.barHeight; i++) {\n if (startWidth != cm.display.barWidth && cm.options.lineWrapping)\n { updateHeightsInViewport(cm); }\n updateScrollbarsInner(cm, measureForScrollbars(cm));\n startWidth = cm.display.barWidth; startHeight = cm.display.barHeight;\n }\n }\n\n // Re-synchronize the fake scrollbars with the actual size of the\n // content.\n function updateScrollbarsInner(cm, measure) {\n var d = cm.display;\n var sizes = d.scrollbars.update(measure);\n\n d.sizer.style.paddingRight = (d.barWidth = sizes.right) + \"px\";\n d.sizer.style.paddingBottom = (d.barHeight = sizes.bottom) + \"px\";\n d.heightForcer.style.borderBottom = sizes.bottom + \"px solid transparent\";\n\n if (sizes.right && sizes.bottom) {\n d.scrollbarFiller.style.display = \"block\";\n d.scrollbarFiller.style.height = sizes.bottom + \"px\";\n d.scrollbarFiller.style.width = sizes.right + \"px\";\n } else { d.scrollbarFiller.style.display = \"\"; }\n if (sizes.bottom && cm.options.coverGutterNextToScrollbar && cm.options.fixedGutter) {\n d.gutterFiller.style.display = \"block\";\n d.gutterFiller.style.height = sizes.bottom + \"px\";\n d.gutterFiller.style.width = measure.gutterWidth + \"px\";\n } else { d.gutterFiller.style.display = \"\"; }\n }\n\n var scrollbarModel = {\"native\": NativeScrollbars, \"null\": NullScrollbars};\n\n function initScrollbars(cm) {\n if (cm.display.scrollbars) {\n cm.display.scrollbars.clear();\n if (cm.display.scrollbars.addClass)\n { rmClass(cm.display.wrapper, cm.display.scrollbars.addClass); }\n }\n\n cm.display.scrollbars = new scrollbarModel[cm.options.scrollbarStyle](function (node) {\n cm.display.wrapper.insertBefore(node, cm.display.scrollbarFiller);\n // Prevent clicks in the scrollbars from killing focus\n on(node, \"mousedown\", function () {\n if (cm.state.focused) { setTimeout(function () { return cm.display.input.focus(); }, 0); }\n });\n node.setAttribute(\"cm-not-content\", \"true\");\n }, function (pos, axis) {\n if (axis == \"horizontal\") { setScrollLeft(cm, pos); }\n else { updateScrollTop(cm, pos); }\n }, cm);\n if (cm.display.scrollbars.addClass)\n { addClass(cm.display.wrapper, cm.display.scrollbars.addClass); }\n }\n\n // Operations are used to wrap a series of changes to the editor\n // state in such a way that each change won't have to update the\n // cursor and display (which would be awkward, slow, and\n // error-prone). Instead, display updates are batched and then all\n // combined and executed at once.\n\n var nextOpId = 0;\n // Start a new operation.\n function startOperation(cm) {\n cm.curOp = {\n cm: cm,\n viewChanged: false, // Flag that indicates that lines might need to be redrawn\n startHeight: cm.doc.height, // Used to detect need to update scrollbar\n forceUpdate: false, // Used to force a redraw\n updateInput: 0, // Whether to reset the input textarea\n typing: false, // Whether this reset should be careful to leave existing text (for compositing)\n changeObjs: null, // Accumulated changes, for firing change events\n cursorActivityHandlers: null, // Set of handlers to fire cursorActivity on\n cursorActivityCalled: 0, // Tracks which cursorActivity handlers have been called already\n selectionChanged: false, // Whether the selection needs to be redrawn\n updateMaxLine: false, // Set when the widest line needs to be determined anew\n scrollLeft: null, scrollTop: null, // Intermediate scroll position, not pushed to DOM yet\n scrollToPos: null, // Used to scroll to a specific position\n focus: false,\n id: ++nextOpId // Unique ID\n };\n pushOperation(cm.curOp);\n }\n\n // Finish an operation, updating the display and signalling delayed events\n function endOperation(cm) {\n var op = cm.curOp;\n if (op) { finishOperation(op, function (group) {\n for (var i = 0; i < group.ops.length; i++)\n { group.ops[i].cm.curOp = null; }\n endOperations(group);\n }); }\n }\n\n // The DOM updates done when an operation finishes are batched so\n // that the minimum number of relayouts are required.\n function endOperations(group) {\n var ops = group.ops;\n for (var i = 0; i < ops.length; i++) // Read DOM\n { endOperation_R1(ops[i]); }\n for (var i$1 = 0; i$1 < ops.length; i$1++) // Write DOM (maybe)\n { endOperation_W1(ops[i$1]); }\n for (var i$2 = 0; i$2 < ops.length; i$2++) // Read DOM\n { endOperation_R2(ops[i$2]); }\n for (var i$3 = 0; i$3 < ops.length; i$3++) // Write DOM (maybe)\n { endOperation_W2(ops[i$3]); }\n for (var i$4 = 0; i$4 < ops.length; i$4++) // Read DOM\n { endOperation_finish(ops[i$4]); }\n }\n\n function endOperation_R1(op) {\n var cm = op.cm, display = cm.display;\n maybeClipScrollbars(cm);\n if (op.updateMaxLine) { findMaxLine(cm); }\n\n op.mustUpdate = op.viewChanged || op.forceUpdate || op.scrollTop != null ||\n op.scrollToPos && (op.scrollToPos.from.line < display.viewFrom ||\n op.scrollToPos.to.line >= display.viewTo) ||\n display.maxLineChanged && cm.options.lineWrapping;\n op.update = op.mustUpdate &&\n new DisplayUpdate(cm, op.mustUpdate && {top: op.scrollTop, ensure: op.scrollToPos}, op.forceUpdate);\n }\n\n function endOperation_W1(op) {\n op.updatedDisplay = op.mustUpdate && updateDisplayIfNeeded(op.cm, op.update);\n }\n\n function endOperation_R2(op) {\n var cm = op.cm, display = cm.display;\n if (op.updatedDisplay) { updateHeightsInViewport(cm); }\n\n op.barMeasure = measureForScrollbars(cm);\n\n // If the max line changed since it was last measured, measure it,\n // and ensure the document's width matches it.\n // updateDisplay_W2 will use these properties to do the actual resizing\n if (display.maxLineChanged && !cm.options.lineWrapping) {\n op.adjustWidthTo = measureChar(cm, display.maxLine, display.maxLine.text.length).left + 3;\n cm.display.sizerWidth = op.adjustWidthTo;\n op.barMeasure.scrollWidth =\n Math.max(display.scroller.clientWidth, display.sizer.offsetLeft + op.adjustWidthTo + scrollGap(cm) + cm.display.barWidth);\n op.maxScrollLeft = Math.max(0, display.sizer.offsetLeft + op.adjustWidthTo - displayWidth(cm));\n }\n\n if (op.updatedDisplay || op.selectionChanged)\n { op.preparedSelection = display.input.prepareSelection(); }\n }\n\n function endOperation_W2(op) {\n var cm = op.cm;\n\n if (op.adjustWidthTo != null) {\n cm.display.sizer.style.minWidth = op.adjustWidthTo + \"px\";\n if (op.maxScrollLeft < cm.doc.scrollLeft)\n { setScrollLeft(cm, Math.min(cm.display.scroller.scrollLeft, op.maxScrollLeft), true); }\n cm.display.maxLineChanged = false;\n }\n\n var takeFocus = op.focus && op.focus == activeElt();\n if (op.preparedSelection)\n { cm.display.input.showSelection(op.preparedSelection, takeFocus); }\n if (op.updatedDisplay || op.startHeight != cm.doc.height)\n { updateScrollbars(cm, op.barMeasure); }\n if (op.updatedDisplay)\n { setDocumentHeight(cm, op.barMeasure); }\n\n if (op.selectionChanged) { restartBlink(cm); }\n\n if (cm.state.focused && op.updateInput)\n { cm.display.input.reset(op.typing); }\n if (takeFocus) { ensureFocus(op.cm); }\n }\n\n function endOperation_finish(op) {\n var cm = op.cm, display = cm.display, doc = cm.doc;\n\n if (op.updatedDisplay) { postUpdateDisplay(cm, op.update); }\n\n // Abort mouse wheel delta measurement, when scrolling explicitly\n if (display.wheelStartX != null && (op.scrollTop != null || op.scrollLeft != null || op.scrollToPos))\n { display.wheelStartX = display.wheelStartY = null; }\n\n // Propagate the scroll position to the actual DOM scroller\n if (op.scrollTop != null) { setScrollTop(cm, op.scrollTop, op.forceScroll); }\n\n if (op.scrollLeft != null) { setScrollLeft(cm, op.scrollLeft, true, true); }\n // If we need to scroll a specific position into view, do so.\n if (op.scrollToPos) {\n var rect = scrollPosIntoView(cm, clipPos(doc, op.scrollToPos.from),\n clipPos(doc, op.scrollToPos.to), op.scrollToPos.margin);\n maybeScrollWindow(cm, rect);\n }\n\n // Fire events for markers that are hidden/unidden by editing or\n // undoing\n var hidden = op.maybeHiddenMarkers, unhidden = op.maybeUnhiddenMarkers;\n if (hidden) { for (var i = 0; i < hidden.length; ++i)\n { if (!hidden[i].lines.length) { signal(hidden[i], \"hide\"); } } }\n if (unhidden) { for (var i$1 = 0; i$1 < unhidden.length; ++i$1)\n { if (unhidden[i$1].lines.length) { signal(unhidden[i$1], \"unhide\"); } } }\n\n if (display.wrapper.offsetHeight)\n { doc.scrollTop = cm.display.scroller.scrollTop; }\n\n // Fire change events, and delayed event handlers\n if (op.changeObjs)\n { signal(cm, \"changes\", cm, op.changeObjs); }\n if (op.update)\n { op.update.finish(); }\n }\n\n // Run the given function in an operation\n function runInOp(cm, f) {\n if (cm.curOp) { return f() }\n startOperation(cm);\n try { return f() }\n finally { endOperation(cm); }\n }\n // Wraps a function in an operation. Returns the wrapped function.\n function operation(cm, f) {\n return function() {\n if (cm.curOp) { return f.apply(cm, arguments) }\n startOperation(cm);\n try { return f.apply(cm, arguments) }\n finally { endOperation(cm); }\n }\n }\n // Used to add methods to editor and doc instances, wrapping them in\n // operations.\n function methodOp(f) {\n return function() {\n if (this.curOp) { return f.apply(this, arguments) }\n startOperation(this);\n try { return f.apply(this, arguments) }\n finally { endOperation(this); }\n }\n }\n function docMethodOp(f) {\n return function() {\n var cm = this.cm;\n if (!cm || cm.curOp) { return f.apply(this, arguments) }\n startOperation(cm);\n try { return f.apply(this, arguments) }\n finally { endOperation(cm); }\n }\n }\n\n // Updates the display.view data structure for a given change to the\n // document. From and to are in pre-change coordinates. Lendiff is\n // the amount of lines added or subtracted by the change. This is\n // used for changes that span multiple lines, or change the way\n // lines are divided into visual lines. regLineChange (below)\n // registers single-line changes.\n function regChange(cm, from, to, lendiff) {\n if (from == null) { from = cm.doc.first; }\n if (to == null) { to = cm.doc.first + cm.doc.size; }\n if (!lendiff) { lendiff = 0; }\n\n var display = cm.display;\n if (lendiff && to < display.viewTo &&\n (display.updateLineNumbers == null || display.updateLineNumbers > from))\n { display.updateLineNumbers = from; }\n\n cm.curOp.viewChanged = true;\n\n if (from >= display.viewTo) { // Change after\n if (sawCollapsedSpans && visualLineNo(cm.doc, from) < display.viewTo)\n { resetView(cm); }\n } else if (to <= display.viewFrom) { // Change before\n if (sawCollapsedSpans && visualLineEndNo(cm.doc, to + lendiff) > display.viewFrom) {\n resetView(cm);\n } else {\n display.viewFrom += lendiff;\n display.viewTo += lendiff;\n }\n } else if (from <= display.viewFrom && to >= display.viewTo) { // Full overlap\n resetView(cm);\n } else if (from <= display.viewFrom) { // Top overlap\n var cut = viewCuttingPoint(cm, to, to + lendiff, 1);\n if (cut) {\n display.view = display.view.slice(cut.index);\n display.viewFrom = cut.lineN;\n display.viewTo += lendiff;\n } else {\n resetView(cm);\n }\n } else if (to >= display.viewTo) { // Bottom overlap\n var cut$1 = viewCuttingPoint(cm, from, from, -1);\n if (cut$1) {\n display.view = display.view.slice(0, cut$1.index);\n display.viewTo = cut$1.lineN;\n } else {\n resetView(cm);\n }\n } else { // Gap in the middle\n var cutTop = viewCuttingPoint(cm, from, from, -1);\n var cutBot = viewCuttingPoint(cm, to, to + lendiff, 1);\n if (cutTop && cutBot) {\n display.view = display.view.slice(0, cutTop.index)\n .concat(buildViewArray(cm, cutTop.lineN, cutBot.lineN))\n .concat(display.view.slice(cutBot.index));\n display.viewTo += lendiff;\n } else {\n resetView(cm);\n }\n }\n\n var ext = display.externalMeasured;\n if (ext) {\n if (to < ext.lineN)\n { ext.lineN += lendiff; }\n else if (from < ext.lineN + ext.size)\n { display.externalMeasured = null; }\n }\n }\n\n // Register a change to a single line. Type must be one of \"text\",\n // \"gutter\", \"class\", \"widget\"\n function regLineChange(cm, line, type) {\n cm.curOp.viewChanged = true;\n var display = cm.display, ext = cm.display.externalMeasured;\n if (ext && line >= ext.lineN && line < ext.lineN + ext.size)\n { display.externalMeasured = null; }\n\n if (line < display.viewFrom || line >= display.viewTo) { return }\n var lineView = display.view[findViewIndex(cm, line)];\n if (lineView.node == null) { return }\n var arr = lineView.changes || (lineView.changes = []);\n if (indexOf(arr, type) == -1) { arr.push(type); }\n }\n\n // Clear the view.\n function resetView(cm) {\n cm.display.viewFrom = cm.display.viewTo = cm.doc.first;\n cm.display.view = [];\n cm.display.viewOffset = 0;\n }\n\n function viewCuttingPoint(cm, oldN, newN, dir) {\n var index = findViewIndex(cm, oldN), diff, view = cm.display.view;\n if (!sawCollapsedSpans || newN == cm.doc.first + cm.doc.size)\n { return {index: index, lineN: newN} }\n var n = cm.display.viewFrom;\n for (var i = 0; i < index; i++)\n { n += view[i].size; }\n if (n != oldN) {\n if (dir > 0) {\n if (index == view.length - 1) { return null }\n diff = (n + view[index].size) - oldN;\n index++;\n } else {\n diff = n - oldN;\n }\n oldN += diff; newN += diff;\n }\n while (visualLineNo(cm.doc, newN) != newN) {\n if (index == (dir < 0 ? 0 : view.length - 1)) { return null }\n newN += dir * view[index - (dir < 0 ? 1 : 0)].size;\n index += dir;\n }\n return {index: index, lineN: newN}\n }\n\n // Force the view to cover a given range, adding empty view element\n // or clipping off existing ones as needed.\n function adjustView(cm, from, to) {\n var display = cm.display, view = display.view;\n if (view.length == 0 || from >= display.viewTo || to <= display.viewFrom) {\n display.view = buildViewArray(cm, from, to);\n display.viewFrom = from;\n } else {\n if (display.viewFrom > from)\n { display.view = buildViewArray(cm, from, display.viewFrom).concat(display.view); }\n else if (display.viewFrom < from)\n { display.view = display.view.slice(findViewIndex(cm, from)); }\n display.viewFrom = from;\n if (display.viewTo < to)\n { display.view = display.view.concat(buildViewArray(cm, display.viewTo, to)); }\n else if (display.viewTo > to)\n { display.view = display.view.slice(0, findViewIndex(cm, to)); }\n }\n display.viewTo = to;\n }\n\n // Count the number of lines in the view whose DOM representation is\n // out of date (or nonexistent).\n function countDirtyView(cm) {\n var view = cm.display.view, dirty = 0;\n for (var i = 0; i < view.length; i++) {\n var lineView = view[i];\n if (!lineView.hidden && (!lineView.node || lineView.changes)) { ++dirty; }\n }\n return dirty\n }\n\n // HIGHLIGHT WORKER\n\n function startWorker(cm, time) {\n if (cm.doc.highlightFrontier < cm.display.viewTo)\n { cm.state.highlight.set(time, bind(highlightWorker, cm)); }\n }\n\n function highlightWorker(cm) {\n var doc = cm.doc;\n if (doc.highlightFrontier >= cm.display.viewTo) { return }\n var end = +new Date + cm.options.workTime;\n var context = getContextBefore(cm, doc.highlightFrontier);\n var changedLines = [];\n\n doc.iter(context.line, Math.min(doc.first + doc.size, cm.display.viewTo + 500), function (line) {\n if (context.line >= cm.display.viewFrom) { // Visible\n var oldStyles = line.styles;\n var resetState = line.text.length > cm.options.maxHighlightLength ? copyState(doc.mode, context.state) : null;\n var highlighted = highlightLine(cm, line, context, true);\n if (resetState) { context.state = resetState; }\n line.styles = highlighted.styles;\n var oldCls = line.styleClasses, newCls = highlighted.classes;\n if (newCls) { line.styleClasses = newCls; }\n else if (oldCls) { line.styleClasses = null; }\n var ischange = !oldStyles || oldStyles.length != line.styles.length ||\n oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass);\n for (var i = 0; !ischange && i < oldStyles.length; ++i) { ischange = oldStyles[i] != line.styles[i]; }\n if (ischange) { changedLines.push(context.line); }\n line.stateAfter = context.save();\n context.nextLine();\n } else {\n if (line.text.length <= cm.options.maxHighlightLength)\n { processLine(cm, line.text, context); }\n line.stateAfter = context.line % 5 == 0 ? context.save() : null;\n context.nextLine();\n }\n if (+new Date > end) {\n startWorker(cm, cm.options.workDelay);\n return true\n }\n });\n doc.highlightFrontier = context.line;\n doc.modeFrontier = Math.max(doc.modeFrontier, context.line);\n if (changedLines.length) { runInOp(cm, function () {\n for (var i = 0; i < changedLines.length; i++)\n { regLineChange(cm, changedLines[i], \"text\"); }\n }); }\n }\n\n // DISPLAY DRAWING\n\n var DisplayUpdate = function(cm, viewport, force) {\n var display = cm.display;\n\n this.viewport = viewport;\n // Store some values that we'll need later (but don't want to force a relayout for)\n this.visible = visibleLines(display, cm.doc, viewport);\n this.editorIsHidden = !display.wrapper.offsetWidth;\n this.wrapperHeight = display.wrapper.clientHeight;\n this.wrapperWidth = display.wrapper.clientWidth;\n this.oldDisplayWidth = displayWidth(cm);\n this.force = force;\n this.dims = getDimensions(cm);\n this.events = [];\n };\n\n DisplayUpdate.prototype.signal = function (emitter, type) {\n if (hasHandler(emitter, type))\n { this.events.push(arguments); }\n };\n DisplayUpdate.prototype.finish = function () {\n var this$1 = this;\n\n for (var i = 0; i < this.events.length; i++)\n { signal.apply(null, this$1.events[i]); }\n };\n\n function maybeClipScrollbars(cm) {\n var display = cm.display;\n if (!display.scrollbarsClipped && display.scroller.offsetWidth) {\n display.nativeBarWidth = display.scroller.offsetWidth - display.scroller.clientWidth;\n display.heightForcer.style.height = scrollGap(cm) + \"px\";\n display.sizer.style.marginBottom = -display.nativeBarWidth + \"px\";\n display.sizer.style.borderRightWidth = scrollGap(cm) + \"px\";\n display.scrollbarsClipped = true;\n }\n }\n\n function selectionSnapshot(cm) {\n if (cm.hasFocus()) { return null }\n var active = activeElt();\n if (!active || !contains(cm.display.lineDiv, active)) { return null }\n var result = {activeElt: active};\n if (window.getSelection) {\n var sel = window.getSelection();\n if (sel.anchorNode && sel.extend && contains(cm.display.lineDiv, sel.anchorNode)) {\n result.anchorNode = sel.anchorNode;\n result.anchorOffset = sel.anchorOffset;\n result.focusNode = sel.focusNode;\n result.focusOffset = sel.focusOffset;\n }\n }\n return result\n }\n\n function restoreSelection(snapshot) {\n if (!snapshot || !snapshot.activeElt || snapshot.activeElt == activeElt()) { return }\n snapshot.activeElt.focus();\n if (snapshot.anchorNode && contains(document.body, snapshot.anchorNode) && contains(document.body, snapshot.focusNode)) {\n var sel = window.getSelection(), range$$1 = document.createRange();\n range$$1.setEnd(snapshot.anchorNode, snapshot.anchorOffset);\n range$$1.collapse(false);\n sel.removeAllRanges();\n sel.addRange(range$$1);\n sel.extend(snapshot.focusNode, snapshot.focusOffset);\n }\n }\n\n // Does the actual updating of the line display. Bails out\n // (returning false) when there is nothing to be done and forced is\n // false.\n function updateDisplayIfNeeded(cm, update) {\n var display = cm.display, doc = cm.doc;\n\n if (update.editorIsHidden) {\n resetView(cm);\n return false\n }\n\n // Bail out if the visible area is already rendered and nothing changed.\n if (!update.force &&\n update.visible.from >= display.viewFrom && update.visible.to <= display.viewTo &&\n (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo) &&\n display.renderedView == display.view && countDirtyView(cm) == 0)\n { return false }\n\n if (maybeUpdateLineNumberWidth(cm)) {\n resetView(cm);\n update.dims = getDimensions(cm);\n }\n\n // Compute a suitable new viewport (from & to)\n var end = doc.first + doc.size;\n var from = Math.max(update.visible.from - cm.options.viewportMargin, doc.first);\n var to = Math.min(end, update.visible.to + cm.options.viewportMargin);\n if (display.viewFrom < from && from - display.viewFrom < 20) { from = Math.max(doc.first, display.viewFrom); }\n if (display.viewTo > to && display.viewTo - to < 20) { to = Math.min(end, display.viewTo); }\n if (sawCollapsedSpans) {\n from = visualLineNo(cm.doc, from);\n to = visualLineEndNo(cm.doc, to);\n }\n\n var different = from != display.viewFrom || to != display.viewTo ||\n display.lastWrapHeight != update.wrapperHeight || display.lastWrapWidth != update.wrapperWidth;\n adjustView(cm, from, to);\n\n display.viewOffset = heightAtLine(getLine(cm.doc, display.viewFrom));\n // Position the mover div to align with the current scroll position\n cm.display.mover.style.top = display.viewOffset + \"px\";\n\n var toUpdate = countDirtyView(cm);\n if (!different && toUpdate == 0 && !update.force && display.renderedView == display.view &&\n (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo))\n { return false }\n\n // For big changes, we hide the enclosing element during the\n // update, since that speeds up the operations on most browsers.\n var selSnapshot = selectionSnapshot(cm);\n if (toUpdate > 4) { display.lineDiv.style.display = \"none\"; }\n patchDisplay(cm, display.updateLineNumbers, update.dims);\n if (toUpdate > 4) { display.lineDiv.style.display = \"\"; }\n display.renderedView = display.view;\n // There might have been a widget with a focused element that got\n // hidden or updated, if so re-focus it.\n restoreSelection(selSnapshot);\n\n // Prevent selection and cursors from interfering with the scroll\n // width and height.\n removeChildren(display.cursorDiv);\n removeChildren(display.selectionDiv);\n display.gutters.style.height = display.sizer.style.minHeight = 0;\n\n if (different) {\n display.lastWrapHeight = update.wrapperHeight;\n display.lastWrapWidth = update.wrapperWidth;\n startWorker(cm, 400);\n }\n\n display.updateLineNumbers = null;\n\n return true\n }\n\n function postUpdateDisplay(cm, update) {\n var viewport = update.viewport;\n\n for (var first = true;; first = false) {\n if (!first || !cm.options.lineWrapping || update.oldDisplayWidth == displayWidth(cm)) {\n // Clip forced viewport to actual scrollable area.\n if (viewport && viewport.top != null)\n { viewport = {top: Math.min(cm.doc.height + paddingVert(cm.display) - displayHeight(cm), viewport.top)}; }\n // Updated line heights might result in the drawn area not\n // actually covering the viewport. Keep looping until it does.\n update.visible = visibleLines(cm.display, cm.doc, viewport);\n if (update.visible.from >= cm.display.viewFrom && update.visible.to <= cm.display.viewTo)\n { break }\n }\n if (!updateDisplayIfNeeded(cm, update)) { break }\n updateHeightsInViewport(cm);\n var barMeasure = measureForScrollbars(cm);\n updateSelection(cm);\n updateScrollbars(cm, barMeasure);\n setDocumentHeight(cm, barMeasure);\n update.force = false;\n }\n\n update.signal(cm, \"update\", cm);\n if (cm.display.viewFrom != cm.display.reportedViewFrom || cm.display.viewTo != cm.display.reportedViewTo) {\n update.signal(cm, \"viewportChange\", cm, cm.display.viewFrom, cm.display.viewTo);\n cm.display.reportedViewFrom = cm.display.viewFrom; cm.display.reportedViewTo = cm.display.viewTo;\n }\n }\n\n function updateDisplaySimple(cm, viewport) {\n var update = new DisplayUpdate(cm, viewport);\n if (updateDisplayIfNeeded(cm, update)) {\n updateHeightsInViewport(cm);\n postUpdateDisplay(cm, update);\n var barMeasure = measureForScrollbars(cm);\n updateSelection(cm);\n updateScrollbars(cm, barMeasure);\n setDocumentHeight(cm, barMeasure);\n update.finish();\n }\n }\n\n // Sync the actual display DOM structure with display.view, removing\n // nodes for lines that are no longer in view, and creating the ones\n // that are not there yet, and updating the ones that are out of\n // date.\n function patchDisplay(cm, updateNumbersFrom, dims) {\n var display = cm.display, lineNumbers = cm.options.lineNumbers;\n var container = display.lineDiv, cur = container.firstChild;\n\n function rm(node) {\n var next = node.nextSibling;\n // Works around a throw-scroll bug in OS X Webkit\n if (webkit && mac && cm.display.currentWheelTarget == node)\n { node.style.display = \"none\"; }\n else\n { node.parentNode.removeChild(node); }\n return next\n }\n\n var view = display.view, lineN = display.viewFrom;\n // Loop over the elements in the view, syncing cur (the DOM nodes\n // in display.lineDiv) with the view as we go.\n for (var i = 0; i < view.length; i++) {\n var lineView = view[i];\n if (lineView.hidden) ; else if (!lineView.node || lineView.node.parentNode != container) { // Not drawn yet\n var node = buildLineElement(cm, lineView, lineN, dims);\n container.insertBefore(node, cur);\n } else { // Already drawn\n while (cur != lineView.node) { cur = rm(cur); }\n var updateNumber = lineNumbers && updateNumbersFrom != null &&\n updateNumbersFrom <= lineN && lineView.lineNumber;\n if (lineView.changes) {\n if (indexOf(lineView.changes, \"gutter\") > -1) { updateNumber = false; }\n updateLineForChanges(cm, lineView, lineN, dims);\n }\n if (updateNumber) {\n removeChildren(lineView.lineNumber);\n lineView.lineNumber.appendChild(document.createTextNode(lineNumberFor(cm.options, lineN)));\n }\n cur = lineView.node.nextSibling;\n }\n lineN += lineView.size;\n }\n while (cur) { cur = rm(cur); }\n }\n\n function updateGutterSpace(cm) {\n var width = cm.display.gutters.offsetWidth;\n cm.display.sizer.style.marginLeft = width + \"px\";\n }\n\n function setDocumentHeight(cm, measure) {\n cm.display.sizer.style.minHeight = measure.docHeight + \"px\";\n cm.display.heightForcer.style.top = measure.docHeight + \"px\";\n cm.display.gutters.style.height = (measure.docHeight + cm.display.barHeight + scrollGap(cm)) + \"px\";\n }\n\n // Rebuild the gutter elements, ensure the margin to the left of the\n // code matches their width.\n function updateGutters(cm) {\n var gutters = cm.display.gutters, specs = cm.options.gutters;\n removeChildren(gutters);\n var i = 0;\n for (; i < specs.length; ++i) {\n var gutterClass = specs[i];\n var gElt = gutters.appendChild(elt(\"div\", null, \"CodeMirror-gutter \" + gutterClass));\n if (gutterClass == \"CodeMirror-linenumbers\") {\n cm.display.lineGutter = gElt;\n gElt.style.width = (cm.display.lineNumWidth || 1) + \"px\";\n }\n }\n gutters.style.display = i ? \"\" : \"none\";\n updateGutterSpace(cm);\n }\n\n // Make sure the gutters options contains the element\n // \"CodeMirror-linenumbers\" when the lineNumbers option is true.\n function setGuttersForLineNumbers(options) {\n var found = indexOf(options.gutters, \"CodeMirror-linenumbers\");\n if (found == -1 && options.lineNumbers) {\n options.gutters = options.gutters.concat([\"CodeMirror-linenumbers\"]);\n } else if (found > -1 && !options.lineNumbers) {\n options.gutters = options.gutters.slice(0);\n options.gutters.splice(found, 1);\n }\n }\n\n // Since the delta values reported on mouse wheel events are\n // unstandardized between browsers and even browser versions, and\n // generally horribly unpredictable, this code starts by measuring\n // the scroll effect that the first few mouse wheel events have,\n // and, from that, detects the way it can convert deltas to pixel\n // offsets afterwards.\n //\n // The reason we want to know the amount a wheel event will scroll\n // is that it gives us a chance to update the display before the\n // actual scrolling happens, reducing flickering.\n\n var wheelSamples = 0, wheelPixelsPerUnit = null;\n // Fill in a browser-detected starting value on browsers where we\n // know one. These don't have to be accurate -- the result of them\n // being wrong would just be a slight flicker on the first wheel\n // scroll (if it is large enough).\n if (ie) { wheelPixelsPerUnit = -.53; }\n else if (gecko) { wheelPixelsPerUnit = 15; }\n else if (chrome) { wheelPixelsPerUnit = -.7; }\n else if (safari) { wheelPixelsPerUnit = -1/3; }\n\n function wheelEventDelta(e) {\n var dx = e.wheelDeltaX, dy = e.wheelDeltaY;\n if (dx == null && e.detail && e.axis == e.HORIZONTAL_AXIS) { dx = e.detail; }\n if (dy == null && e.detail && e.axis == e.VERTICAL_AXIS) { dy = e.detail; }\n else if (dy == null) { dy = e.wheelDelta; }\n return {x: dx, y: dy}\n }\n function wheelEventPixels(e) {\n var delta = wheelEventDelta(e);\n delta.x *= wheelPixelsPerUnit;\n delta.y *= wheelPixelsPerUnit;\n return delta\n }\n\n function onScrollWheel(cm, e) {\n var delta = wheelEventDelta(e), dx = delta.x, dy = delta.y;\n\n var display = cm.display, scroll = display.scroller;\n // Quit if there's nothing to scroll here\n var canScrollX = scroll.scrollWidth > scroll.clientWidth;\n var canScrollY = scroll.scrollHeight > scroll.clientHeight;\n if (!(dx && canScrollX || dy && canScrollY)) { return }\n\n // Webkit browsers on OS X abort momentum scrolls when the target\n // of the scroll event is removed from the scrollable element.\n // This hack (see related code in patchDisplay) makes sure the\n // element is kept around.\n if (dy && mac && webkit) {\n outer: for (var cur = e.target, view = display.view; cur != scroll; cur = cur.parentNode) {\n for (var i = 0; i < view.length; i++) {\n if (view[i].node == cur) {\n cm.display.currentWheelTarget = cur;\n break outer\n }\n }\n }\n }\n\n // On some browsers, horizontal scrolling will cause redraws to\n // happen before the gutter has been realigned, causing it to\n // wriggle around in a most unseemly way. When we have an\n // estimated pixels/delta value, we just handle horizontal\n // scrolling entirely here. It'll be slightly off from native, but\n // better than glitching out.\n if (dx && !gecko && !presto && wheelPixelsPerUnit != null) {\n if (dy && canScrollY)\n { updateScrollTop(cm, Math.max(0, scroll.scrollTop + dy * wheelPixelsPerUnit)); }\n setScrollLeft(cm, Math.max(0, scroll.scrollLeft + dx * wheelPixelsPerUnit));\n // Only prevent default scrolling if vertical scrolling is\n // actually possible. Otherwise, it causes vertical scroll\n // jitter on OSX trackpads when deltaX is small and deltaY\n // is large (issue #3579)\n if (!dy || (dy && canScrollY))\n { e_preventDefault(e); }\n display.wheelStartX = null; // Abort measurement, if in progress\n return\n }\n\n // 'Project' the visible viewport to cover the area that is being\n // scrolled into view (if we know enough to estimate it).\n if (dy && wheelPixelsPerUnit != null) {\n var pixels = dy * wheelPixelsPerUnit;\n var top = cm.doc.scrollTop, bot = top + display.wrapper.clientHeight;\n if (pixels < 0) { top = Math.max(0, top + pixels - 50); }\n else { bot = Math.min(cm.doc.height, bot + pixels + 50); }\n updateDisplaySimple(cm, {top: top, bottom: bot});\n }\n\n if (wheelSamples < 20) {\n if (display.wheelStartX == null) {\n display.wheelStartX = scroll.scrollLeft; display.wheelStartY = scroll.scrollTop;\n display.wheelDX = dx; display.wheelDY = dy;\n setTimeout(function () {\n if (display.wheelStartX == null) { return }\n var movedX = scroll.scrollLeft - display.wheelStartX;\n var movedY = scroll.scrollTop - display.wheelStartY;\n var sample = (movedY && display.wheelDY && movedY / display.wheelDY) ||\n (movedX && display.wheelDX && movedX / display.wheelDX);\n display.wheelStartX = display.wheelStartY = null;\n if (!sample) { return }\n wheelPixelsPerUnit = (wheelPixelsPerUnit * wheelSamples + sample) / (wheelSamples + 1);\n ++wheelSamples;\n }, 200);\n } else {\n display.wheelDX += dx; display.wheelDY += dy;\n }\n }\n }\n\n // Selection objects are immutable. A new one is created every time\n // the selection changes. A selection is one or more non-overlapping\n // (and non-touching) ranges, sorted, and an integer that indicates\n // which one is the primary selection (the one that's scrolled into\n // view, that getCursor returns, etc).\n var Selection = function(ranges, primIndex) {\n this.ranges = ranges;\n this.primIndex = primIndex;\n };\n\n Selection.prototype.primary = function () { return this.ranges[this.primIndex] };\n\n Selection.prototype.equals = function (other) {\n var this$1 = this;\n\n if (other == this) { return true }\n if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) { return false }\n for (var i = 0; i < this.ranges.length; i++) {\n var here = this$1.ranges[i], there = other.ranges[i];\n if (!equalCursorPos(here.anchor, there.anchor) || !equalCursorPos(here.head, there.head)) { return false }\n }\n return true\n };\n\n Selection.prototype.deepCopy = function () {\n var this$1 = this;\n\n var out = [];\n for (var i = 0; i < this.ranges.length; i++)\n { out[i] = new Range(copyPos(this$1.ranges[i].anchor), copyPos(this$1.ranges[i].head)); }\n return new Selection(out, this.primIndex)\n };\n\n Selection.prototype.somethingSelected = function () {\n var this$1 = this;\n\n for (var i = 0; i < this.ranges.length; i++)\n { if (!this$1.ranges[i].empty()) { return true } }\n return false\n };\n\n Selection.prototype.contains = function (pos, end) {\n var this$1 = this;\n\n if (!end) { end = pos; }\n for (var i = 0; i < this.ranges.length; i++) {\n var range = this$1.ranges[i];\n if (cmp(end, range.from()) >= 0 && cmp(pos, range.to()) <= 0)\n { return i }\n }\n return -1\n };\n\n var Range = function(anchor, head) {\n this.anchor = anchor; this.head = head;\n };\n\n Range.prototype.from = function () { return minPos(this.anchor, this.head) };\n Range.prototype.to = function () { return maxPos(this.anchor, this.head) };\n Range.prototype.empty = function () { return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch };\n\n // Take an unsorted, potentially overlapping set of ranges, and\n // build a selection out of it. 'Consumes' ranges array (modifying\n // it).\n function normalizeSelection(cm, ranges, primIndex) {\n var mayTouch = cm && cm.options.selectionsMayTouch;\n var prim = ranges[primIndex];\n ranges.sort(function (a, b) { return cmp(a.from(), b.from()); });\n primIndex = indexOf(ranges, prim);\n for (var i = 1; i < ranges.length; i++) {\n var cur = ranges[i], prev = ranges[i - 1];\n var diff = cmp(prev.to(), cur.from());\n if (mayTouch && !cur.empty() ? diff > 0 : diff >= 0) {\n var from = minPos(prev.from(), cur.from()), to = maxPos(prev.to(), cur.to());\n var inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head;\n if (i <= primIndex) { --primIndex; }\n ranges.splice(--i, 2, new Range(inv ? to : from, inv ? from : to));\n }\n }\n return new Selection(ranges, primIndex)\n }\n\n function simpleSelection(anchor, head) {\n return new Selection([new Range(anchor, head || anchor)], 0)\n }\n\n // Compute the position of the end of a change (its 'to' property\n // refers to the pre-change end).\n function changeEnd(change) {\n if (!change.text) { return change.to }\n return Pos(change.from.line + change.text.length - 1,\n lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0))\n }\n\n // Adjust a position to refer to the post-change position of the\n // same text, or the end of the change if the change covers it.\n function adjustForChange(pos, change) {\n if (cmp(pos, change.from) < 0) { return pos }\n if (cmp(pos, change.to) <= 0) { return changeEnd(change) }\n\n var line = pos.line + change.text.length - (change.to.line - change.from.line) - 1, ch = pos.ch;\n if (pos.line == change.to.line) { ch += changeEnd(change).ch - change.to.ch; }\n return Pos(line, ch)\n }\n\n function computeSelAfterChange(doc, change) {\n var out = [];\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n var range = doc.sel.ranges[i];\n out.push(new Range(adjustForChange(range.anchor, change),\n adjustForChange(range.head, change)));\n }\n return normalizeSelection(doc.cm, out, doc.sel.primIndex)\n }\n\n function offsetPos(pos, old, nw) {\n if (pos.line == old.line)\n { return Pos(nw.line, pos.ch - old.ch + nw.ch) }\n else\n { return Pos(nw.line + (pos.line - old.line), pos.ch) }\n }\n\n // Used by replaceSelections to allow moving the selection to the\n // start or around the replaced test. Hint may be \"start\" or \"around\".\n function computeReplacedSel(doc, changes, hint) {\n var out = [];\n var oldPrev = Pos(doc.first, 0), newPrev = oldPrev;\n for (var i = 0; i < changes.length; i++) {\n var change = changes[i];\n var from = offsetPos(change.from, oldPrev, newPrev);\n var to = offsetPos(changeEnd(change), oldPrev, newPrev);\n oldPrev = change.to;\n newPrev = to;\n if (hint == \"around\") {\n var range = doc.sel.ranges[i], inv = cmp(range.head, range.anchor) < 0;\n out[i] = new Range(inv ? to : from, inv ? from : to);\n } else {\n out[i] = new Range(from, from);\n }\n }\n return new Selection(out, doc.sel.primIndex)\n }\n\n // Used to get the editor into a consistent state again when options change.\n\n function loadMode(cm) {\n cm.doc.mode = getMode(cm.options, cm.doc.modeOption);\n resetModeState(cm);\n }\n\n function resetModeState(cm) {\n cm.doc.iter(function (line) {\n if (line.stateAfter) { line.stateAfter = null; }\n if (line.styles) { line.styles = null; }\n });\n cm.doc.modeFrontier = cm.doc.highlightFrontier = cm.doc.first;\n startWorker(cm, 100);\n cm.state.modeGen++;\n if (cm.curOp) { regChange(cm); }\n }\n\n // DOCUMENT DATA STRUCTURE\n\n // By default, updates that start and end at the beginning of a line\n // are treated specially, in order to make the association of line\n // widgets and marker elements with the text behave more intuitive.\n function isWholeLineUpdate(doc, change) {\n return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == \"\" &&\n (!doc.cm || doc.cm.options.wholeLineUpdateBefore)\n }\n\n // Perform a change on the document data structure.\n function updateDoc(doc, change, markedSpans, estimateHeight$$1) {\n function spansFor(n) {return markedSpans ? markedSpans[n] : null}\n function update(line, text, spans) {\n updateLine(line, text, spans, estimateHeight$$1);\n signalLater(line, \"change\", line, change);\n }\n function linesFor(start, end) {\n var result = [];\n for (var i = start; i < end; ++i)\n { result.push(new Line(text[i], spansFor(i), estimateHeight$$1)); }\n return result\n }\n\n var from = change.from, to = change.to, text = change.text;\n var firstLine = getLine(doc, from.line), lastLine = getLine(doc, to.line);\n var lastText = lst(text), lastSpans = spansFor(text.length - 1), nlines = to.line - from.line;\n\n // Adjust the line structure\n if (change.full) {\n doc.insert(0, linesFor(0, text.length));\n doc.remove(text.length, doc.size - text.length);\n } else if (isWholeLineUpdate(doc, change)) {\n // This is a whole-line replace. Treated specially to make\n // sure line objects move the way they are supposed to.\n var added = linesFor(0, text.length - 1);\n update(lastLine, lastLine.text, lastSpans);\n if (nlines) { doc.remove(from.line, nlines); }\n if (added.length) { doc.insert(from.line, added); }\n } else if (firstLine == lastLine) {\n if (text.length == 1) {\n update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans);\n } else {\n var added$1 = linesFor(1, text.length - 1);\n added$1.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight$$1));\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n doc.insert(from.line + 1, added$1);\n }\n } else if (text.length == 1) {\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0));\n doc.remove(from.line + 1, nlines);\n } else {\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans);\n var added$2 = linesFor(1, text.length - 1);\n if (nlines > 1) { doc.remove(from.line + 1, nlines - 1); }\n doc.insert(from.line + 1, added$2);\n }\n\n signalLater(doc, \"change\", doc, change);\n }\n\n // Call f for all linked documents.\n function linkedDocs(doc, f, sharedHistOnly) {\n function propagate(doc, skip, sharedHist) {\n if (doc.linked) { for (var i = 0; i < doc.linked.length; ++i) {\n var rel = doc.linked[i];\n if (rel.doc == skip) { continue }\n var shared = sharedHist && rel.sharedHist;\n if (sharedHistOnly && !shared) { continue }\n f(rel.doc, shared);\n propagate(rel.doc, doc, shared);\n } }\n }\n propagate(doc, null, true);\n }\n\n // Attach a document to an editor.\n function attachDoc(cm, doc) {\n if (doc.cm) { throw new Error(\"This document is already in use.\") }\n cm.doc = doc;\n doc.cm = cm;\n estimateLineHeights(cm);\n loadMode(cm);\n setDirectionClass(cm);\n if (!cm.options.lineWrapping) { findMaxLine(cm); }\n cm.options.mode = doc.modeOption;\n regChange(cm);\n }\n\n function setDirectionClass(cm) {\n (cm.doc.direction == \"rtl\" ? addClass : rmClass)(cm.display.lineDiv, \"CodeMirror-rtl\");\n }\n\n function directionChanged(cm) {\n runInOp(cm, function () {\n setDirectionClass(cm);\n regChange(cm);\n });\n }\n\n function History(startGen) {\n // Arrays of change events and selections. Doing something adds an\n // event to done and clears undo. Undoing moves events from done\n // to undone, redoing moves them in the other direction.\n this.done = []; this.undone = [];\n this.undoDepth = Infinity;\n // Used to track when changes can be merged into a single undo\n // event\n this.lastModTime = this.lastSelTime = 0;\n this.lastOp = this.lastSelOp = null;\n this.lastOrigin = this.lastSelOrigin = null;\n // Used by the isClean() method\n this.generation = this.maxGeneration = startGen || 1;\n }\n\n // Create a history change event from an updateDoc-style change\n // object.\n function historyChangeFromChange(doc, change) {\n var histChange = {from: copyPos(change.from), to: changeEnd(change), text: getBetween(doc, change.from, change.to)};\n attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1);\n linkedDocs(doc, function (doc) { return attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1); }, true);\n return histChange\n }\n\n // Pop all selection events off the end of a history array. Stop at\n // a change event.\n function clearSelectionEvents(array) {\n while (array.length) {\n var last = lst(array);\n if (last.ranges) { array.pop(); }\n else { break }\n }\n }\n\n // Find the top change event in the history. Pop off selection\n // events that are in the way.\n function lastChangeEvent(hist, force) {\n if (force) {\n clearSelectionEvents(hist.done);\n return lst(hist.done)\n } else if (hist.done.length && !lst(hist.done).ranges) {\n return lst(hist.done)\n } else if (hist.done.length > 1 && !hist.done[hist.done.length - 2].ranges) {\n hist.done.pop();\n return lst(hist.done)\n }\n }\n\n // Register a change in the history. Merges changes that are within\n // a single operation, or are close together with an origin that\n // allows merging (starting with \"+\") into a single event.\n function addChangeToHistory(doc, change, selAfter, opId) {\n var hist = doc.history;\n hist.undone.length = 0;\n var time = +new Date, cur;\n var last;\n\n if ((hist.lastOp == opId ||\n hist.lastOrigin == change.origin && change.origin &&\n ((change.origin.charAt(0) == \"+\" && hist.lastModTime > time - (doc.cm ? doc.cm.options.historyEventDelay : 500)) ||\n change.origin.charAt(0) == \"*\")) &&\n (cur = lastChangeEvent(hist, hist.lastOp == opId))) {\n // Merge this change into the last event\n last = lst(cur.changes);\n if (cmp(change.from, change.to) == 0 && cmp(change.from, last.to) == 0) {\n // Optimized case for simple insertion -- don't want to add\n // new changesets for every character typed\n last.to = changeEnd(change);\n } else {\n // Add new sub-event\n cur.changes.push(historyChangeFromChange(doc, change));\n }\n } else {\n // Can not be merged, start a new event.\n var before = lst(hist.done);\n if (!before || !before.ranges)\n { pushSelectionToHistory(doc.sel, hist.done); }\n cur = {changes: [historyChangeFromChange(doc, change)],\n generation: hist.generation};\n hist.done.push(cur);\n while (hist.done.length > hist.undoDepth) {\n hist.done.shift();\n if (!hist.done[0].ranges) { hist.done.shift(); }\n }\n }\n hist.done.push(selAfter);\n hist.generation = ++hist.maxGeneration;\n hist.lastModTime = hist.lastSelTime = time;\n hist.lastOp = hist.lastSelOp = opId;\n hist.lastOrigin = hist.lastSelOrigin = change.origin;\n\n if (!last) { signal(doc, \"historyAdded\"); }\n }\n\n function selectionEventCanBeMerged(doc, origin, prev, sel) {\n var ch = origin.charAt(0);\n return ch == \"*\" ||\n ch == \"+\" &&\n prev.ranges.length == sel.ranges.length &&\n prev.somethingSelected() == sel.somethingSelected() &&\n new Date - doc.history.lastSelTime <= (doc.cm ? doc.cm.options.historyEventDelay : 500)\n }\n\n // Called whenever the selection changes, sets the new selection as\n // the pending selection in the history, and pushes the old pending\n // selection into the 'done' array when it was significantly\n // different (in number of selected ranges, emptiness, or time).\n function addSelectionToHistory(doc, sel, opId, options) {\n var hist = doc.history, origin = options && options.origin;\n\n // A new event is started when the previous origin does not match\n // the current, or the origins don't allow matching. Origins\n // starting with * are always merged, those starting with + are\n // merged when similar and close together in time.\n if (opId == hist.lastSelOp ||\n (origin && hist.lastSelOrigin == origin &&\n (hist.lastModTime == hist.lastSelTime && hist.lastOrigin == origin ||\n selectionEventCanBeMerged(doc, origin, lst(hist.done), sel))))\n { hist.done[hist.done.length - 1] = sel; }\n else\n { pushSelectionToHistory(sel, hist.done); }\n\n hist.lastSelTime = +new Date;\n hist.lastSelOrigin = origin;\n hist.lastSelOp = opId;\n if (options && options.clearRedo !== false)\n { clearSelectionEvents(hist.undone); }\n }\n\n function pushSelectionToHistory(sel, dest) {\n var top = lst(dest);\n if (!(top && top.ranges && top.equals(sel)))\n { dest.push(sel); }\n }\n\n // Used to store marked span information in the history.\n function attachLocalSpans(doc, change, from, to) {\n var existing = change[\"spans_\" + doc.id], n = 0;\n doc.iter(Math.max(doc.first, from), Math.min(doc.first + doc.size, to), function (line) {\n if (line.markedSpans)\n { (existing || (existing = change[\"spans_\" + doc.id] = {}))[n] = line.markedSpans; }\n ++n;\n });\n }\n\n // When un/re-doing restores text containing marked spans, those\n // that have been explicitly cleared should not be restored.\n function removeClearedSpans(spans) {\n if (!spans) { return null }\n var out;\n for (var i = 0; i < spans.length; ++i) {\n if (spans[i].marker.explicitlyCleared) { if (!out) { out = spans.slice(0, i); } }\n else if (out) { out.push(spans[i]); }\n }\n return !out ? spans : out.length ? out : null\n }\n\n // Retrieve and filter the old marked spans stored in a change event.\n function getOldSpans(doc, change) {\n var found = change[\"spans_\" + doc.id];\n if (!found) { return null }\n var nw = [];\n for (var i = 0; i < change.text.length; ++i)\n { nw.push(removeClearedSpans(found[i])); }\n return nw\n }\n\n // Used for un/re-doing changes from the history. Combines the\n // result of computing the existing spans with the set of spans that\n // existed in the history (so that deleting around a span and then\n // undoing brings back the span).\n function mergeOldSpans(doc, change) {\n var old = getOldSpans(doc, change);\n var stretched = stretchSpansOverChange(doc, change);\n if (!old) { return stretched }\n if (!stretched) { return old }\n\n for (var i = 0; i < old.length; ++i) {\n var oldCur = old[i], stretchCur = stretched[i];\n if (oldCur && stretchCur) {\n spans: for (var j = 0; j < stretchCur.length; ++j) {\n var span = stretchCur[j];\n for (var k = 0; k < oldCur.length; ++k)\n { if (oldCur[k].marker == span.marker) { continue spans } }\n oldCur.push(span);\n }\n } else if (stretchCur) {\n old[i] = stretchCur;\n }\n }\n return old\n }\n\n // Used both to provide a JSON-safe object in .getHistory, and, when\n // detaching a document, to split the history in two\n function copyHistoryArray(events, newGroup, instantiateSel) {\n var copy = [];\n for (var i = 0; i < events.length; ++i) {\n var event = events[i];\n if (event.ranges) {\n copy.push(instantiateSel ? Selection.prototype.deepCopy.call(event) : event);\n continue\n }\n var changes = event.changes, newChanges = [];\n copy.push({changes: newChanges});\n for (var j = 0; j < changes.length; ++j) {\n var change = changes[j], m = (void 0);\n newChanges.push({from: change.from, to: change.to, text: change.text});\n if (newGroup) { for (var prop in change) { if (m = prop.match(/^spans_(\\d+)$/)) {\n if (indexOf(newGroup, Number(m[1])) > -1) {\n lst(newChanges)[prop] = change[prop];\n delete change[prop];\n }\n } } }\n }\n }\n return copy\n }\n\n // The 'scroll' parameter given to many of these indicated whether\n // the new cursor position should be scrolled into view after\n // modifying the selection.\n\n // If shift is held or the extend flag is set, extends a range to\n // include a given position (and optionally a second position).\n // Otherwise, simply returns the range between the given positions.\n // Used for cursor motion and such.\n function extendRange(range, head, other, extend) {\n if (extend) {\n var anchor = range.anchor;\n if (other) {\n var posBefore = cmp(head, anchor) < 0;\n if (posBefore != (cmp(other, anchor) < 0)) {\n anchor = head;\n head = other;\n } else if (posBefore != (cmp(head, other) < 0)) {\n head = other;\n }\n }\n return new Range(anchor, head)\n } else {\n return new Range(other || head, head)\n }\n }\n\n // Extend the primary selection range, discard the rest.\n function extendSelection(doc, head, other, options, extend) {\n if (extend == null) { extend = doc.cm && (doc.cm.display.shift || doc.extend); }\n setSelection(doc, new Selection([extendRange(doc.sel.primary(), head, other, extend)], 0), options);\n }\n\n // Extend all selections (pos is an array of selections with length\n // equal the number of selections)\n function extendSelections(doc, heads, options) {\n var out = [];\n var extend = doc.cm && (doc.cm.display.shift || doc.extend);\n for (var i = 0; i < doc.sel.ranges.length; i++)\n { out[i] = extendRange(doc.sel.ranges[i], heads[i], null, extend); }\n var newSel = normalizeSelection(doc.cm, out, doc.sel.primIndex);\n setSelection(doc, newSel, options);\n }\n\n // Updates a single range in the selection.\n function replaceOneSelection(doc, i, range, options) {\n var ranges = doc.sel.ranges.slice(0);\n ranges[i] = range;\n setSelection(doc, normalizeSelection(doc.cm, ranges, doc.sel.primIndex), options);\n }\n\n // Reset the selection to a single range.\n function setSimpleSelection(doc, anchor, head, options) {\n setSelection(doc, simpleSelection(anchor, head), options);\n }\n\n // Give beforeSelectionChange handlers a change to influence a\n // selection update.\n function filterSelectionChange(doc, sel, options) {\n var obj = {\n ranges: sel.ranges,\n update: function(ranges) {\n var this$1 = this;\n\n this.ranges = [];\n for (var i = 0; i < ranges.length; i++)\n { this$1.ranges[i] = new Range(clipPos(doc, ranges[i].anchor),\n clipPos(doc, ranges[i].head)); }\n },\n origin: options && options.origin\n };\n signal(doc, \"beforeSelectionChange\", doc, obj);\n if (doc.cm) { signal(doc.cm, \"beforeSelectionChange\", doc.cm, obj); }\n if (obj.ranges != sel.ranges) { return normalizeSelection(doc.cm, obj.ranges, obj.ranges.length - 1) }\n else { return sel }\n }\n\n function setSelectionReplaceHistory(doc, sel, options) {\n var done = doc.history.done, last = lst(done);\n if (last && last.ranges) {\n done[done.length - 1] = sel;\n setSelectionNoUndo(doc, sel, options);\n } else {\n setSelection(doc, sel, options);\n }\n }\n\n // Set a new selection.\n function setSelection(doc, sel, options) {\n setSelectionNoUndo(doc, sel, options);\n addSelectionToHistory(doc, doc.sel, doc.cm ? doc.cm.curOp.id : NaN, options);\n }\n\n function setSelectionNoUndo(doc, sel, options) {\n if (hasHandler(doc, \"beforeSelectionChange\") || doc.cm && hasHandler(doc.cm, \"beforeSelectionChange\"))\n { sel = filterSelectionChange(doc, sel, options); }\n\n var bias = options && options.bias ||\n (cmp(sel.primary().head, doc.sel.primary().head) < 0 ? -1 : 1);\n setSelectionInner(doc, skipAtomicInSelection(doc, sel, bias, true));\n\n if (!(options && options.scroll === false) && doc.cm)\n { ensureCursorVisible(doc.cm); }\n }\n\n function setSelectionInner(doc, sel) {\n if (sel.equals(doc.sel)) { return }\n\n doc.sel = sel;\n\n if (doc.cm) {\n doc.cm.curOp.updateInput = 1;\n doc.cm.curOp.selectionChanged = true;\n signalCursorActivity(doc.cm);\n }\n signalLater(doc, \"cursorActivity\", doc);\n }\n\n // Verify that the selection does not partially select any atomic\n // marked ranges.\n function reCheckSelection(doc) {\n setSelectionInner(doc, skipAtomicInSelection(doc, doc.sel, null, false));\n }\n\n // Return a selection that does not partially select any atomic\n // ranges.\n function skipAtomicInSelection(doc, sel, bias, mayClear) {\n var out;\n for (var i = 0; i < sel.ranges.length; i++) {\n var range = sel.ranges[i];\n var old = sel.ranges.length == doc.sel.ranges.length && doc.sel.ranges[i];\n var newAnchor = skipAtomic(doc, range.anchor, old && old.anchor, bias, mayClear);\n var newHead = skipAtomic(doc, range.head, old && old.head, bias, mayClear);\n if (out || newAnchor != range.anchor || newHead != range.head) {\n if (!out) { out = sel.ranges.slice(0, i); }\n out[i] = new Range(newAnchor, newHead);\n }\n }\n return out ? normalizeSelection(doc.cm, out, sel.primIndex) : sel\n }\n\n function skipAtomicInner(doc, pos, oldPos, dir, mayClear) {\n var line = getLine(doc, pos.line);\n if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) {\n var sp = line.markedSpans[i], m = sp.marker;\n if ((sp.from == null || (m.inclusiveLeft ? sp.from <= pos.ch : sp.from < pos.ch)) &&\n (sp.to == null || (m.inclusiveRight ? sp.to >= pos.ch : sp.to > pos.ch))) {\n if (mayClear) {\n signal(m, \"beforeCursorEnter\");\n if (m.explicitlyCleared) {\n if (!line.markedSpans) { break }\n else {--i; continue}\n }\n }\n if (!m.atomic) { continue }\n\n if (oldPos) {\n var near = m.find(dir < 0 ? 1 : -1), diff = (void 0);\n if (dir < 0 ? m.inclusiveRight : m.inclusiveLeft)\n { near = movePos(doc, near, -dir, near && near.line == pos.line ? line : null); }\n if (near && near.line == pos.line && (diff = cmp(near, oldPos)) && (dir < 0 ? diff < 0 : diff > 0))\n { return skipAtomicInner(doc, near, pos, dir, mayClear) }\n }\n\n var far = m.find(dir < 0 ? -1 : 1);\n if (dir < 0 ? m.inclusiveLeft : m.inclusiveRight)\n { far = movePos(doc, far, dir, far.line == pos.line ? line : null); }\n return far ? skipAtomicInner(doc, far, pos, dir, mayClear) : null\n }\n } }\n return pos\n }\n\n // Ensure a given position is not inside an atomic range.\n function skipAtomic(doc, pos, oldPos, bias, mayClear) {\n var dir = bias || 1;\n var found = skipAtomicInner(doc, pos, oldPos, dir, mayClear) ||\n (!mayClear && skipAtomicInner(doc, pos, oldPos, dir, true)) ||\n skipAtomicInner(doc, pos, oldPos, -dir, mayClear) ||\n (!mayClear && skipAtomicInner(doc, pos, oldPos, -dir, true));\n if (!found) {\n doc.cantEdit = true;\n return Pos(doc.first, 0)\n }\n return found\n }\n\n function movePos(doc, pos, dir, line) {\n if (dir < 0 && pos.ch == 0) {\n if (pos.line > doc.first) { return clipPos(doc, Pos(pos.line - 1)) }\n else { return null }\n } else if (dir > 0 && pos.ch == (line || getLine(doc, pos.line)).text.length) {\n if (pos.line < doc.first + doc.size - 1) { return Pos(pos.line + 1, 0) }\n else { return null }\n } else {\n return new Pos(pos.line, pos.ch + dir)\n }\n }\n\n function selectAll(cm) {\n cm.setSelection(Pos(cm.firstLine(), 0), Pos(cm.lastLine()), sel_dontScroll);\n }\n\n // UPDATING\n\n // Allow \"beforeChange\" event handlers to influence a change\n function filterChange(doc, change, update) {\n var obj = {\n canceled: false,\n from: change.from,\n to: change.to,\n text: change.text,\n origin: change.origin,\n cancel: function () { return obj.canceled = true; }\n };\n if (update) { obj.update = function (from, to, text, origin) {\n if (from) { obj.from = clipPos(doc, from); }\n if (to) { obj.to = clipPos(doc, to); }\n if (text) { obj.text = text; }\n if (origin !== undefined) { obj.origin = origin; }\n }; }\n signal(doc, \"beforeChange\", doc, obj);\n if (doc.cm) { signal(doc.cm, \"beforeChange\", doc.cm, obj); }\n\n if (obj.canceled) {\n if (doc.cm) { doc.cm.curOp.updateInput = 2; }\n return null\n }\n return {from: obj.from, to: obj.to, text: obj.text, origin: obj.origin}\n }\n\n // Apply a change to a document, and add it to the document's\n // history, and propagating it to all linked documents.\n function makeChange(doc, change, ignoreReadOnly) {\n if (doc.cm) {\n if (!doc.cm.curOp) { return operation(doc.cm, makeChange)(doc, change, ignoreReadOnly) }\n if (doc.cm.state.suppressEdits) { return }\n }\n\n if (hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\")) {\n change = filterChange(doc, change, true);\n if (!change) { return }\n }\n\n // Possibly split or suppress the update based on the presence\n // of read-only spans in its range.\n var split = sawReadOnlySpans && !ignoreReadOnly && removeReadOnlyRanges(doc, change.from, change.to);\n if (split) {\n for (var i = split.length - 1; i >= 0; --i)\n { makeChangeInner(doc, {from: split[i].from, to: split[i].to, text: i ? [\"\"] : change.text, origin: change.origin}); }\n } else {\n makeChangeInner(doc, change);\n }\n }\n\n function makeChangeInner(doc, change) {\n if (change.text.length == 1 && change.text[0] == \"\" && cmp(change.from, change.to) == 0) { return }\n var selAfter = computeSelAfterChange(doc, change);\n addChangeToHistory(doc, change, selAfter, doc.cm ? doc.cm.curOp.id : NaN);\n\n makeChangeSingleDoc(doc, change, selAfter, stretchSpansOverChange(doc, change));\n var rebased = [];\n\n linkedDocs(doc, function (doc, sharedHist) {\n if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n rebaseHist(doc.history, change);\n rebased.push(doc.history);\n }\n makeChangeSingleDoc(doc, change, null, stretchSpansOverChange(doc, change));\n });\n }\n\n // Revert a change stored in a document's history.\n function makeChangeFromHistory(doc, type, allowSelectionOnly) {\n var suppress = doc.cm && doc.cm.state.suppressEdits;\n if (suppress && !allowSelectionOnly) { return }\n\n var hist = doc.history, event, selAfter = doc.sel;\n var source = type == \"undo\" ? hist.done : hist.undone, dest = type == \"undo\" ? hist.undone : hist.done;\n\n // Verify that there is a useable event (so that ctrl-z won't\n // needlessly clear selection events)\n var i = 0;\n for (; i < source.length; i++) {\n event = source[i];\n if (allowSelectionOnly ? event.ranges && !event.equals(doc.sel) : !event.ranges)\n { break }\n }\n if (i == source.length) { return }\n hist.lastOrigin = hist.lastSelOrigin = null;\n\n for (;;) {\n event = source.pop();\n if (event.ranges) {\n pushSelectionToHistory(event, dest);\n if (allowSelectionOnly && !event.equals(doc.sel)) {\n setSelection(doc, event, {clearRedo: false});\n return\n }\n selAfter = event;\n } else if (suppress) {\n source.push(event);\n return\n } else { break }\n }\n\n // Build up a reverse change object to add to the opposite history\n // stack (redo when undoing, and vice versa).\n var antiChanges = [];\n pushSelectionToHistory(selAfter, dest);\n dest.push({changes: antiChanges, generation: hist.generation});\n hist.generation = event.generation || ++hist.maxGeneration;\n\n var filter = hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\");\n\n var loop = function ( i ) {\n var change = event.changes[i];\n change.origin = type;\n if (filter && !filterChange(doc, change, false)) {\n source.length = 0;\n return {}\n }\n\n antiChanges.push(historyChangeFromChange(doc, change));\n\n var after = i ? computeSelAfterChange(doc, change) : lst(source);\n makeChangeSingleDoc(doc, change, after, mergeOldSpans(doc, change));\n if (!i && doc.cm) { doc.cm.scrollIntoView({from: change.from, to: changeEnd(change)}); }\n var rebased = [];\n\n // Propagate to the linked documents\n linkedDocs(doc, function (doc, sharedHist) {\n if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n rebaseHist(doc.history, change);\n rebased.push(doc.history);\n }\n makeChangeSingleDoc(doc, change, null, mergeOldSpans(doc, change));\n });\n };\n\n for (var i$1 = event.changes.length - 1; i$1 >= 0; --i$1) {\n var returned = loop( i$1 );\n\n if ( returned ) return returned.v;\n }\n }\n\n // Sub-views need their line numbers shifted when text is added\n // above or below them in the parent document.\n function shiftDoc(doc, distance) {\n if (distance == 0) { return }\n doc.first += distance;\n doc.sel = new Selection(map(doc.sel.ranges, function (range) { return new Range(\n Pos(range.anchor.line + distance, range.anchor.ch),\n Pos(range.head.line + distance, range.head.ch)\n ); }), doc.sel.primIndex);\n if (doc.cm) {\n regChange(doc.cm, doc.first, doc.first - distance, distance);\n for (var d = doc.cm.display, l = d.viewFrom; l < d.viewTo; l++)\n { regLineChange(doc.cm, l, \"gutter\"); }\n }\n }\n\n // More lower-level change function, handling only a single document\n // (not linked ones).\n function makeChangeSingleDoc(doc, change, selAfter, spans) {\n if (doc.cm && !doc.cm.curOp)\n { return operation(doc.cm, makeChangeSingleDoc)(doc, change, selAfter, spans) }\n\n if (change.to.line < doc.first) {\n shiftDoc(doc, change.text.length - 1 - (change.to.line - change.from.line));\n return\n }\n if (change.from.line > doc.lastLine()) { return }\n\n // Clip the change to the size of this doc\n if (change.from.line < doc.first) {\n var shift = change.text.length - 1 - (doc.first - change.from.line);\n shiftDoc(doc, shift);\n change = {from: Pos(doc.first, 0), to: Pos(change.to.line + shift, change.to.ch),\n text: [lst(change.text)], origin: change.origin};\n }\n var last = doc.lastLine();\n if (change.to.line > last) {\n change = {from: change.from, to: Pos(last, getLine(doc, last).text.length),\n text: [change.text[0]], origin: change.origin};\n }\n\n change.removed = getBetween(doc, change.from, change.to);\n\n if (!selAfter) { selAfter = computeSelAfterChange(doc, change); }\n if (doc.cm) { makeChangeSingleDocInEditor(doc.cm, change, spans); }\n else { updateDoc(doc, change, spans); }\n setSelectionNoUndo(doc, selAfter, sel_dontScroll);\n }\n\n // Handle the interaction of a change to a document with the editor\n // that this document is part of.\n function makeChangeSingleDocInEditor(cm, change, spans) {\n var doc = cm.doc, display = cm.display, from = change.from, to = change.to;\n\n var recomputeMaxLength = false, checkWidthStart = from.line;\n if (!cm.options.lineWrapping) {\n checkWidthStart = lineNo(visualLine(getLine(doc, from.line)));\n doc.iter(checkWidthStart, to.line + 1, function (line) {\n if (line == display.maxLine) {\n recomputeMaxLength = true;\n return true\n }\n });\n }\n\n if (doc.sel.contains(change.from, change.to) > -1)\n { signalCursorActivity(cm); }\n\n updateDoc(doc, change, spans, estimateHeight(cm));\n\n if (!cm.options.lineWrapping) {\n doc.iter(checkWidthStart, from.line + change.text.length, function (line) {\n var len = lineLength(line);\n if (len > display.maxLineLength) {\n display.maxLine = line;\n display.maxLineLength = len;\n display.maxLineChanged = true;\n recomputeMaxLength = false;\n }\n });\n if (recomputeMaxLength) { cm.curOp.updateMaxLine = true; }\n }\n\n retreatFrontier(doc, from.line);\n startWorker(cm, 400);\n\n var lendiff = change.text.length - (to.line - from.line) - 1;\n // Remember that these lines changed, for updating the display\n if (change.full)\n { regChange(cm); }\n else if (from.line == to.line && change.text.length == 1 && !isWholeLineUpdate(cm.doc, change))\n { regLineChange(cm, from.line, \"text\"); }\n else\n { regChange(cm, from.line, to.line + 1, lendiff); }\n\n var changesHandler = hasHandler(cm, \"changes\"), changeHandler = hasHandler(cm, \"change\");\n if (changeHandler || changesHandler) {\n var obj = {\n from: from, to: to,\n text: change.text,\n removed: change.removed,\n origin: change.origin\n };\n if (changeHandler) { signalLater(cm, \"change\", cm, obj); }\n if (changesHandler) { (cm.curOp.changeObjs || (cm.curOp.changeObjs = [])).push(obj); }\n }\n cm.display.selForContextMenu = null;\n }\n\n function replaceRange(doc, code, from, to, origin) {\n var assign;\n\n if (!to) { to = from; }\n if (cmp(to, from) < 0) { (assign = [to, from], from = assign[0], to = assign[1]); }\n if (typeof code == \"string\") { code = doc.splitLines(code); }\n makeChange(doc, {from: from, to: to, text: code, origin: origin});\n }\n\n // Rebasing/resetting history to deal with externally-sourced changes\n\n function rebaseHistSelSingle(pos, from, to, diff) {\n if (to < pos.line) {\n pos.line += diff;\n } else if (from < pos.line) {\n pos.line = from;\n pos.ch = 0;\n }\n }\n\n // Tries to rebase an array of history events given a change in the\n // document. If the change touches the same lines as the event, the\n // event, and everything 'behind' it, is discarded. If the change is\n // before the event, the event's positions are updated. Uses a\n // copy-on-write scheme for the positions, to avoid having to\n // reallocate them all on every rebase, but also avoid problems with\n // shared position objects being unsafely updated.\n function rebaseHistArray(array, from, to, diff) {\n for (var i = 0; i < array.length; ++i) {\n var sub = array[i], ok = true;\n if (sub.ranges) {\n if (!sub.copied) { sub = array[i] = sub.deepCopy(); sub.copied = true; }\n for (var j = 0; j < sub.ranges.length; j++) {\n rebaseHistSelSingle(sub.ranges[j].anchor, from, to, diff);\n rebaseHistSelSingle(sub.ranges[j].head, from, to, diff);\n }\n continue\n }\n for (var j$1 = 0; j$1 < sub.changes.length; ++j$1) {\n var cur = sub.changes[j$1];\n if (to < cur.from.line) {\n cur.from = Pos(cur.from.line + diff, cur.from.ch);\n cur.to = Pos(cur.to.line + diff, cur.to.ch);\n } else if (from <= cur.to.line) {\n ok = false;\n break\n }\n }\n if (!ok) {\n array.splice(0, i + 1);\n i = 0;\n }\n }\n }\n\n function rebaseHist(hist, change) {\n var from = change.from.line, to = change.to.line, diff = change.text.length - (to - from) - 1;\n rebaseHistArray(hist.done, from, to, diff);\n rebaseHistArray(hist.undone, from, to, diff);\n }\n\n // Utility for applying a change to a line by handle or number,\n // returning the number and optionally registering the line as\n // changed.\n function changeLine(doc, handle, changeType, op) {\n var no = handle, line = handle;\n if (typeof handle == \"number\") { line = getLine(doc, clipLine(doc, handle)); }\n else { no = lineNo(handle); }\n if (no == null) { return null }\n if (op(line, no) && doc.cm) { regLineChange(doc.cm, no, changeType); }\n return line\n }\n\n // The document is represented as a BTree consisting of leaves, with\n // chunk of lines in them, and branches, with up to ten leaves or\n // other branch nodes below them. The top node is always a branch\n // node, and is the document object itself (meaning it has\n // additional methods and properties).\n //\n // All nodes have parent links. The tree is used both to go from\n // line numbers to line objects, and to go from objects to numbers.\n // It also indexes by height, and is used to convert between height\n // and line object, and to find the total height of the document.\n //\n // See also http://marijnhaverbeke.nl/blog/codemirror-line-tree.html\n\n function LeafChunk(lines) {\n var this$1 = this;\n\n this.lines = lines;\n this.parent = null;\n var height = 0;\n for (var i = 0; i < lines.length; ++i) {\n lines[i].parent = this$1;\n height += lines[i].height;\n }\n this.height = height;\n }\n\n LeafChunk.prototype = {\n chunkSize: function() { return this.lines.length },\n\n // Remove the n lines at offset 'at'.\n removeInner: function(at, n) {\n var this$1 = this;\n\n for (var i = at, e = at + n; i < e; ++i) {\n var line = this$1.lines[i];\n this$1.height -= line.height;\n cleanUpLine(line);\n signalLater(line, \"delete\");\n }\n this.lines.splice(at, n);\n },\n\n // Helper used to collapse a small branch into a single leaf.\n collapse: function(lines) {\n lines.push.apply(lines, this.lines);\n },\n\n // Insert the given array of lines at offset 'at', count them as\n // having the given height.\n insertInner: function(at, lines, height) {\n var this$1 = this;\n\n this.height += height;\n this.lines = this.lines.slice(0, at).concat(lines).concat(this.lines.slice(at));\n for (var i = 0; i < lines.length; ++i) { lines[i].parent = this$1; }\n },\n\n // Used to iterate over a part of the tree.\n iterN: function(at, n, op) {\n var this$1 = this;\n\n for (var e = at + n; at < e; ++at)\n { if (op(this$1.lines[at])) { return true } }\n }\n };\n\n function BranchChunk(children) {\n var this$1 = this;\n\n this.children = children;\n var size = 0, height = 0;\n for (var i = 0; i < children.length; ++i) {\n var ch = children[i];\n size += ch.chunkSize(); height += ch.height;\n ch.parent = this$1;\n }\n this.size = size;\n this.height = height;\n this.parent = null;\n }\n\n BranchChunk.prototype = {\n chunkSize: function() { return this.size },\n\n removeInner: function(at, n) {\n var this$1 = this;\n\n this.size -= n;\n for (var i = 0; i < this.children.length; ++i) {\n var child = this$1.children[i], sz = child.chunkSize();\n if (at < sz) {\n var rm = Math.min(n, sz - at), oldHeight = child.height;\n child.removeInner(at, rm);\n this$1.height -= oldHeight - child.height;\n if (sz == rm) { this$1.children.splice(i--, 1); child.parent = null; }\n if ((n -= rm) == 0) { break }\n at = 0;\n } else { at -= sz; }\n }\n // If the result is smaller than 25 lines, ensure that it is a\n // single leaf node.\n if (this.size - n < 25 &&\n (this.children.length > 1 || !(this.children[0] instanceof LeafChunk))) {\n var lines = [];\n this.collapse(lines);\n this.children = [new LeafChunk(lines)];\n this.children[0].parent = this;\n }\n },\n\n collapse: function(lines) {\n var this$1 = this;\n\n for (var i = 0; i < this.children.length; ++i) { this$1.children[i].collapse(lines); }\n },\n\n insertInner: function(at, lines, height) {\n var this$1 = this;\n\n this.size += lines.length;\n this.height += height;\n for (var i = 0; i < this.children.length; ++i) {\n var child = this$1.children[i], sz = child.chunkSize();\n if (at <= sz) {\n child.insertInner(at, lines, height);\n if (child.lines && child.lines.length > 50) {\n // To avoid memory thrashing when child.lines is huge (e.g. first view of a large file), it's never spliced.\n // Instead, small slices are taken. They're taken in order because sequential memory accesses are fastest.\n var remaining = child.lines.length % 25 + 25;\n for (var pos = remaining; pos < child.lines.length;) {\n var leaf = new LeafChunk(child.lines.slice(pos, pos += 25));\n child.height -= leaf.height;\n this$1.children.splice(++i, 0, leaf);\n leaf.parent = this$1;\n }\n child.lines = child.lines.slice(0, remaining);\n this$1.maybeSpill();\n }\n break\n }\n at -= sz;\n }\n },\n\n // When a node has grown, check whether it should be split.\n maybeSpill: function() {\n if (this.children.length <= 10) { return }\n var me = this;\n do {\n var spilled = me.children.splice(me.children.length - 5, 5);\n var sibling = new BranchChunk(spilled);\n if (!me.parent) { // Become the parent node\n var copy = new BranchChunk(me.children);\n copy.parent = me;\n me.children = [copy, sibling];\n me = copy;\n } else {\n me.size -= sibling.size;\n me.height -= sibling.height;\n var myIndex = indexOf(me.parent.children, me);\n me.parent.children.splice(myIndex + 1, 0, sibling);\n }\n sibling.parent = me.parent;\n } while (me.children.length > 10)\n me.parent.maybeSpill();\n },\n\n iterN: function(at, n, op) {\n var this$1 = this;\n\n for (var i = 0; i < this.children.length; ++i) {\n var child = this$1.children[i], sz = child.chunkSize();\n if (at < sz) {\n var used = Math.min(n, sz - at);\n if (child.iterN(at, used, op)) { return true }\n if ((n -= used) == 0) { break }\n at = 0;\n } else { at -= sz; }\n }\n }\n };\n\n // Line widgets are block elements displayed above or below a line.\n\n var LineWidget = function(doc, node, options) {\n var this$1 = this;\n\n if (options) { for (var opt in options) { if (options.hasOwnProperty(opt))\n { this$1[opt] = options[opt]; } } }\n this.doc = doc;\n this.node = node;\n };\n\n LineWidget.prototype.clear = function () {\n var this$1 = this;\n\n var cm = this.doc.cm, ws = this.line.widgets, line = this.line, no = lineNo(line);\n if (no == null || !ws) { return }\n for (var i = 0; i < ws.length; ++i) { if (ws[i] == this$1) { ws.splice(i--, 1); } }\n if (!ws.length) { line.widgets = null; }\n var height = widgetHeight(this);\n updateLineHeight(line, Math.max(0, line.height - height));\n if (cm) {\n runInOp(cm, function () {\n adjustScrollWhenAboveVisible(cm, line, -height);\n regLineChange(cm, no, \"widget\");\n });\n signalLater(cm, \"lineWidgetCleared\", cm, this, no);\n }\n };\n\n LineWidget.prototype.changed = function () {\n var this$1 = this;\n\n var oldH = this.height, cm = this.doc.cm, line = this.line;\n this.height = null;\n var diff = widgetHeight(this) - oldH;\n if (!diff) { return }\n if (!lineIsHidden(this.doc, line)) { updateLineHeight(line, line.height + diff); }\n if (cm) {\n runInOp(cm, function () {\n cm.curOp.forceUpdate = true;\n adjustScrollWhenAboveVisible(cm, line, diff);\n signalLater(cm, \"lineWidgetChanged\", cm, this$1, lineNo(line));\n });\n }\n };\n eventMixin(LineWidget);\n\n function adjustScrollWhenAboveVisible(cm, line, diff) {\n if (heightAtLine(line) < ((cm.curOp && cm.curOp.scrollTop) || cm.doc.scrollTop))\n { addToScrollTop(cm, diff); }\n }\n\n function addLineWidget(doc, handle, node, options) {\n var widget = new LineWidget(doc, node, options);\n var cm = doc.cm;\n if (cm && widget.noHScroll) { cm.display.alignWidgets = true; }\n changeLine(doc, handle, \"widget\", function (line) {\n var widgets = line.widgets || (line.widgets = []);\n if (widget.insertAt == null) { widgets.push(widget); }\n else { widgets.splice(Math.min(widgets.length - 1, Math.max(0, widget.insertAt)), 0, widget); }\n widget.line = line;\n if (cm && !lineIsHidden(doc, line)) {\n var aboveVisible = heightAtLine(line) < doc.scrollTop;\n updateLineHeight(line, line.height + widgetHeight(widget));\n if (aboveVisible) { addToScrollTop(cm, widget.height); }\n cm.curOp.forceUpdate = true;\n }\n return true\n });\n if (cm) { signalLater(cm, \"lineWidgetAdded\", cm, widget, typeof handle == \"number\" ? handle : lineNo(handle)); }\n return widget\n }\n\n // TEXTMARKERS\n\n // Created with markText and setBookmark methods. A TextMarker is a\n // handle that can be used to clear or find a marked position in the\n // document. Line objects hold arrays (markedSpans) containing\n // {from, to, marker} object pointing to such marker objects, and\n // indicating that such a marker is present on that line. Multiple\n // lines may point to the same marker when it spans across lines.\n // The spans will have null for their from/to properties when the\n // marker continues beyond the start/end of the line. Markers have\n // links back to the lines they currently touch.\n\n // Collapsed markers have unique ids, in order to be able to order\n // them, which is needed for uniquely determining an outer marker\n // when they overlap (they may nest, but not partially overlap).\n var nextMarkerId = 0;\n\n var TextMarker = function(doc, type) {\n this.lines = [];\n this.type = type;\n this.doc = doc;\n this.id = ++nextMarkerId;\n };\n\n // Clear the marker.\n TextMarker.prototype.clear = function () {\n var this$1 = this;\n\n if (this.explicitlyCleared) { return }\n var cm = this.doc.cm, withOp = cm && !cm.curOp;\n if (withOp) { startOperation(cm); }\n if (hasHandler(this, \"clear\")) {\n var found = this.find();\n if (found) { signalLater(this, \"clear\", found.from, found.to); }\n }\n var min = null, max = null;\n for (var i = 0; i < this.lines.length; ++i) {\n var line = this$1.lines[i];\n var span = getMarkedSpanFor(line.markedSpans, this$1);\n if (cm && !this$1.collapsed) { regLineChange(cm, lineNo(line), \"text\"); }\n else if (cm) {\n if (span.to != null) { max = lineNo(line); }\n if (span.from != null) { min = lineNo(line); }\n }\n line.markedSpans = removeMarkedSpan(line.markedSpans, span);\n if (span.from == null && this$1.collapsed && !lineIsHidden(this$1.doc, line) && cm)\n { updateLineHeight(line, textHeight(cm.display)); }\n }\n if (cm && this.collapsed && !cm.options.lineWrapping) { for (var i$1 = 0; i$1 < this.lines.length; ++i$1) {\n var visual = visualLine(this$1.lines[i$1]), len = lineLength(visual);\n if (len > cm.display.maxLineLength) {\n cm.display.maxLine = visual;\n cm.display.maxLineLength = len;\n cm.display.maxLineChanged = true;\n }\n } }\n\n if (min != null && cm && this.collapsed) { regChange(cm, min, max + 1); }\n this.lines.length = 0;\n this.explicitlyCleared = true;\n if (this.atomic && this.doc.cantEdit) {\n this.doc.cantEdit = false;\n if (cm) { reCheckSelection(cm.doc); }\n }\n if (cm) { signalLater(cm, \"markerCleared\", cm, this, min, max); }\n if (withOp) { endOperation(cm); }\n if (this.parent) { this.parent.clear(); }\n };\n\n // Find the position of the marker in the document. Returns a {from,\n // to} object by default. Side can be passed to get a specific side\n // -- 0 (both), -1 (left), or 1 (right). When lineObj is true, the\n // Pos objects returned contain a line object, rather than a line\n // number (used to prevent looking up the same line twice).\n TextMarker.prototype.find = function (side, lineObj) {\n var this$1 = this;\n\n if (side == null && this.type == \"bookmark\") { side = 1; }\n var from, to;\n for (var i = 0; i < this.lines.length; ++i) {\n var line = this$1.lines[i];\n var span = getMarkedSpanFor(line.markedSpans, this$1);\n if (span.from != null) {\n from = Pos(lineObj ? line : lineNo(line), span.from);\n if (side == -1) { return from }\n }\n if (span.to != null) {\n to = Pos(lineObj ? line : lineNo(line), span.to);\n if (side == 1) { return to }\n }\n }\n return from && {from: from, to: to}\n };\n\n // Signals that the marker's widget changed, and surrounding layout\n // should be recomputed.\n TextMarker.prototype.changed = function () {\n var this$1 = this;\n\n var pos = this.find(-1, true), widget = this, cm = this.doc.cm;\n if (!pos || !cm) { return }\n runInOp(cm, function () {\n var line = pos.line, lineN = lineNo(pos.line);\n var view = findViewForLine(cm, lineN);\n if (view) {\n clearLineMeasurementCacheFor(view);\n cm.curOp.selectionChanged = cm.curOp.forceUpdate = true;\n }\n cm.curOp.updateMaxLine = true;\n if (!lineIsHidden(widget.doc, line) && widget.height != null) {\n var oldHeight = widget.height;\n widget.height = null;\n var dHeight = widgetHeight(widget) - oldHeight;\n if (dHeight)\n { updateLineHeight(line, line.height + dHeight); }\n }\n signalLater(cm, \"markerChanged\", cm, this$1);\n });\n };\n\n TextMarker.prototype.attachLine = function (line) {\n if (!this.lines.length && this.doc.cm) {\n var op = this.doc.cm.curOp;\n if (!op.maybeHiddenMarkers || indexOf(op.maybeHiddenMarkers, this) == -1)\n { (op.maybeUnhiddenMarkers || (op.maybeUnhiddenMarkers = [])).push(this); }\n }\n this.lines.push(line);\n };\n\n TextMarker.prototype.detachLine = function (line) {\n this.lines.splice(indexOf(this.lines, line), 1);\n if (!this.lines.length && this.doc.cm) {\n var op = this.doc.cm.curOp\n ;(op.maybeHiddenMarkers || (op.maybeHiddenMarkers = [])).push(this);\n }\n };\n eventMixin(TextMarker);\n\n // Create a marker, wire it up to the right lines, and\n function markText(doc, from, to, options, type) {\n // Shared markers (across linked documents) are handled separately\n // (markTextShared will call out to this again, once per\n // document).\n if (options && options.shared) { return markTextShared(doc, from, to, options, type) }\n // Ensure we are in an operation.\n if (doc.cm && !doc.cm.curOp) { return operation(doc.cm, markText)(doc, from, to, options, type) }\n\n var marker = new TextMarker(doc, type), diff = cmp(from, to);\n if (options) { copyObj(options, marker, false); }\n // Don't connect empty markers unless clearWhenEmpty is false\n if (diff > 0 || diff == 0 && marker.clearWhenEmpty !== false)\n { return marker }\n if (marker.replacedWith) {\n // Showing up as a widget implies collapsed (widget replaces text)\n marker.collapsed = true;\n marker.widgetNode = eltP(\"span\", [marker.replacedWith], \"CodeMirror-widget\");\n if (!options.handleMouseEvents) { marker.widgetNode.setAttribute(\"cm-ignore-events\", \"true\"); }\n if (options.insertLeft) { marker.widgetNode.insertLeft = true; }\n }\n if (marker.collapsed) {\n if (conflictingCollapsedRange(doc, from.line, from, to, marker) ||\n from.line != to.line && conflictingCollapsedRange(doc, to.line, from, to, marker))\n { throw new Error(\"Inserting collapsed marker partially overlapping an existing one\") }\n seeCollapsedSpans();\n }\n\n if (marker.addToHistory)\n { addChangeToHistory(doc, {from: from, to: to, origin: \"markText\"}, doc.sel, NaN); }\n\n var curLine = from.line, cm = doc.cm, updateMaxLine;\n doc.iter(curLine, to.line + 1, function (line) {\n if (cm && marker.collapsed && !cm.options.lineWrapping && visualLine(line) == cm.display.maxLine)\n { updateMaxLine = true; }\n if (marker.collapsed && curLine != from.line) { updateLineHeight(line, 0); }\n addMarkedSpan(line, new MarkedSpan(marker,\n curLine == from.line ? from.ch : null,\n curLine == to.line ? to.ch : null));\n ++curLine;\n });\n // lineIsHidden depends on the presence of the spans, so needs a second pass\n if (marker.collapsed) { doc.iter(from.line, to.line + 1, function (line) {\n if (lineIsHidden(doc, line)) { updateLineHeight(line, 0); }\n }); }\n\n if (marker.clearOnEnter) { on(marker, \"beforeCursorEnter\", function () { return marker.clear(); }); }\n\n if (marker.readOnly) {\n seeReadOnlySpans();\n if (doc.history.done.length || doc.history.undone.length)\n { doc.clearHistory(); }\n }\n if (marker.collapsed) {\n marker.id = ++nextMarkerId;\n marker.atomic = true;\n }\n if (cm) {\n // Sync editor state\n if (updateMaxLine) { cm.curOp.updateMaxLine = true; }\n if (marker.collapsed)\n { regChange(cm, from.line, to.line + 1); }\n else if (marker.className || marker.startStyle || marker.endStyle || marker.css ||\n marker.attributes || marker.title)\n { for (var i = from.line; i <= to.line; i++) { regLineChange(cm, i, \"text\"); } }\n if (marker.atomic) { reCheckSelection(cm.doc); }\n signalLater(cm, \"markerAdded\", cm, marker);\n }\n return marker\n }\n\n // SHARED TEXTMARKERS\n\n // A shared marker spans multiple linked documents. It is\n // implemented as a meta-marker-object controlling multiple normal\n // markers.\n var SharedTextMarker = function(markers, primary) {\n var this$1 = this;\n\n this.markers = markers;\n this.primary = primary;\n for (var i = 0; i < markers.length; ++i)\n { markers[i].parent = this$1; }\n };\n\n SharedTextMarker.prototype.clear = function () {\n var this$1 = this;\n\n if (this.explicitlyCleared) { return }\n this.explicitlyCleared = true;\n for (var i = 0; i < this.markers.length; ++i)\n { this$1.markers[i].clear(); }\n signalLater(this, \"clear\");\n };\n\n SharedTextMarker.prototype.find = function (side, lineObj) {\n return this.primary.find(side, lineObj)\n };\n eventMixin(SharedTextMarker);\n\n function markTextShared(doc, from, to, options, type) {\n options = copyObj(options);\n options.shared = false;\n var markers = [markText(doc, from, to, options, type)], primary = markers[0];\n var widget = options.widgetNode;\n linkedDocs(doc, function (doc) {\n if (widget) { options.widgetNode = widget.cloneNode(true); }\n markers.push(markText(doc, clipPos(doc, from), clipPos(doc, to), options, type));\n for (var i = 0; i < doc.linked.length; ++i)\n { if (doc.linked[i].isParent) { return } }\n primary = lst(markers);\n });\n return new SharedTextMarker(markers, primary)\n }\n\n function findSharedMarkers(doc) {\n return doc.findMarks(Pos(doc.first, 0), doc.clipPos(Pos(doc.lastLine())), function (m) { return m.parent; })\n }\n\n function copySharedMarkers(doc, markers) {\n for (var i = 0; i < markers.length; i++) {\n var marker = markers[i], pos = marker.find();\n var mFrom = doc.clipPos(pos.from), mTo = doc.clipPos(pos.to);\n if (cmp(mFrom, mTo)) {\n var subMark = markText(doc, mFrom, mTo, marker.primary, marker.primary.type);\n marker.markers.push(subMark);\n subMark.parent = marker;\n }\n }\n }\n\n function detachSharedMarkers(markers) {\n var loop = function ( i ) {\n var marker = markers[i], linked = [marker.primary.doc];\n linkedDocs(marker.primary.doc, function (d) { return linked.push(d); });\n for (var j = 0; j < marker.markers.length; j++) {\n var subMarker = marker.markers[j];\n if (indexOf(linked, subMarker.doc) == -1) {\n subMarker.parent = null;\n marker.markers.splice(j--, 1);\n }\n }\n };\n\n for (var i = 0; i < markers.length; i++) loop( i );\n }\n\n var nextDocId = 0;\n var Doc = function(text, mode, firstLine, lineSep, direction) {\n if (!(this instanceof Doc)) { return new Doc(text, mode, firstLine, lineSep, direction) }\n if (firstLine == null) { firstLine = 0; }\n\n BranchChunk.call(this, [new LeafChunk([new Line(\"\", null)])]);\n this.first = firstLine;\n this.scrollTop = this.scrollLeft = 0;\n this.cantEdit = false;\n this.cleanGeneration = 1;\n this.modeFrontier = this.highlightFrontier = firstLine;\n var start = Pos(firstLine, 0);\n this.sel = simpleSelection(start);\n this.history = new History(null);\n this.id = ++nextDocId;\n this.modeOption = mode;\n this.lineSep = lineSep;\n this.direction = (direction == \"rtl\") ? \"rtl\" : \"ltr\";\n this.extend = false;\n\n if (typeof text == \"string\") { text = this.splitLines(text); }\n updateDoc(this, {from: start, to: start, text: text});\n setSelection(this, simpleSelection(start), sel_dontScroll);\n };\n\n Doc.prototype = createObj(BranchChunk.prototype, {\n constructor: Doc,\n // Iterate over the document. Supports two forms -- with only one\n // argument, it calls that for each line in the document. With\n // three, it iterates over the range given by the first two (with\n // the second being non-inclusive).\n iter: function(from, to, op) {\n if (op) { this.iterN(from - this.first, to - from, op); }\n else { this.iterN(this.first, this.first + this.size, from); }\n },\n\n // Non-public interface for adding and removing lines.\n insert: function(at, lines) {\n var height = 0;\n for (var i = 0; i < lines.length; ++i) { height += lines[i].height; }\n this.insertInner(at - this.first, lines, height);\n },\n remove: function(at, n) { this.removeInner(at - this.first, n); },\n\n // From here, the methods are part of the public interface. Most\n // are also available from CodeMirror (editor) instances.\n\n getValue: function(lineSep) {\n var lines = getLines(this, this.first, this.first + this.size);\n if (lineSep === false) { return lines }\n return lines.join(lineSep || this.lineSeparator())\n },\n setValue: docMethodOp(function(code) {\n var top = Pos(this.first, 0), last = this.first + this.size - 1;\n makeChange(this, {from: top, to: Pos(last, getLine(this, last).text.length),\n text: this.splitLines(code), origin: \"setValue\", full: true}, true);\n if (this.cm) { scrollToCoords(this.cm, 0, 0); }\n setSelection(this, simpleSelection(top), sel_dontScroll);\n }),\n replaceRange: function(code, from, to, origin) {\n from = clipPos(this, from);\n to = to ? clipPos(this, to) : from;\n replaceRange(this, code, from, to, origin);\n },\n getRange: function(from, to, lineSep) {\n var lines = getBetween(this, clipPos(this, from), clipPos(this, to));\n if (lineSep === false) { return lines }\n return lines.join(lineSep || this.lineSeparator())\n },\n\n getLine: function(line) {var l = this.getLineHandle(line); return l && l.text},\n\n getLineHandle: function(line) {if (isLine(this, line)) { return getLine(this, line) }},\n getLineNumber: function(line) {return lineNo(line)},\n\n getLineHandleVisualStart: function(line) {\n if (typeof line == \"number\") { line = getLine(this, line); }\n return visualLine(line)\n },\n\n lineCount: function() {return this.size},\n firstLine: function() {return this.first},\n lastLine: function() {return this.first + this.size - 1},\n\n clipPos: function(pos) {return clipPos(this, pos)},\n\n getCursor: function(start) {\n var range$$1 = this.sel.primary(), pos;\n if (start == null || start == \"head\") { pos = range$$1.head; }\n else if (start == \"anchor\") { pos = range$$1.anchor; }\n else if (start == \"end\" || start == \"to\" || start === false) { pos = range$$1.to(); }\n else { pos = range$$1.from(); }\n return pos\n },\n listSelections: function() { return this.sel.ranges },\n somethingSelected: function() {return this.sel.somethingSelected()},\n\n setCursor: docMethodOp(function(line, ch, options) {\n setSimpleSelection(this, clipPos(this, typeof line == \"number\" ? Pos(line, ch || 0) : line), null, options);\n }),\n setSelection: docMethodOp(function(anchor, head, options) {\n setSimpleSelection(this, clipPos(this, anchor), clipPos(this, head || anchor), options);\n }),\n extendSelection: docMethodOp(function(head, other, options) {\n extendSelection(this, clipPos(this, head), other && clipPos(this, other), options);\n }),\n extendSelections: docMethodOp(function(heads, options) {\n extendSelections(this, clipPosArray(this, heads), options);\n }),\n extendSelectionsBy: docMethodOp(function(f, options) {\n var heads = map(this.sel.ranges, f);\n extendSelections(this, clipPosArray(this, heads), options);\n }),\n setSelections: docMethodOp(function(ranges, primary, options) {\n var this$1 = this;\n\n if (!ranges.length) { return }\n var out = [];\n for (var i = 0; i < ranges.length; i++)\n { out[i] = new Range(clipPos(this$1, ranges[i].anchor),\n clipPos(this$1, ranges[i].head)); }\n if (primary == null) { primary = Math.min(ranges.length - 1, this.sel.primIndex); }\n setSelection(this, normalizeSelection(this.cm, out, primary), options);\n }),\n addSelection: docMethodOp(function(anchor, head, options) {\n var ranges = this.sel.ranges.slice(0);\n ranges.push(new Range(clipPos(this, anchor), clipPos(this, head || anchor)));\n setSelection(this, normalizeSelection(this.cm, ranges, ranges.length - 1), options);\n }),\n\n getSelection: function(lineSep) {\n var this$1 = this;\n\n var ranges = this.sel.ranges, lines;\n for (var i = 0; i < ranges.length; i++) {\n var sel = getBetween(this$1, ranges[i].from(), ranges[i].to());\n lines = lines ? lines.concat(sel) : sel;\n }\n if (lineSep === false) { return lines }\n else { return lines.join(lineSep || this.lineSeparator()) }\n },\n getSelections: function(lineSep) {\n var this$1 = this;\n\n var parts = [], ranges = this.sel.ranges;\n for (var i = 0; i < ranges.length; i++) {\n var sel = getBetween(this$1, ranges[i].from(), ranges[i].to());\n if (lineSep !== false) { sel = sel.join(lineSep || this$1.lineSeparator()); }\n parts[i] = sel;\n }\n return parts\n },\n replaceSelection: function(code, collapse, origin) {\n var dup = [];\n for (var i = 0; i < this.sel.ranges.length; i++)\n { dup[i] = code; }\n this.replaceSelections(dup, collapse, origin || \"+input\");\n },\n replaceSelections: docMethodOp(function(code, collapse, origin) {\n var this$1 = this;\n\n var changes = [], sel = this.sel;\n for (var i = 0; i < sel.ranges.length; i++) {\n var range$$1 = sel.ranges[i];\n changes[i] = {from: range$$1.from(), to: range$$1.to(), text: this$1.splitLines(code[i]), origin: origin};\n }\n var newSel = collapse && collapse != \"end\" && computeReplacedSel(this, changes, collapse);\n for (var i$1 = changes.length - 1; i$1 >= 0; i$1--)\n { makeChange(this$1, changes[i$1]); }\n if (newSel) { setSelectionReplaceHistory(this, newSel); }\n else if (this.cm) { ensureCursorVisible(this.cm); }\n }),\n undo: docMethodOp(function() {makeChangeFromHistory(this, \"undo\");}),\n redo: docMethodOp(function() {makeChangeFromHistory(this, \"redo\");}),\n undoSelection: docMethodOp(function() {makeChangeFromHistory(this, \"undo\", true);}),\n redoSelection: docMethodOp(function() {makeChangeFromHistory(this, \"redo\", true);}),\n\n setExtending: function(val) {this.extend = val;},\n getExtending: function() {return this.extend},\n\n historySize: function() {\n var hist = this.history, done = 0, undone = 0;\n for (var i = 0; i < hist.done.length; i++) { if (!hist.done[i].ranges) { ++done; } }\n for (var i$1 = 0; i$1 < hist.undone.length; i$1++) { if (!hist.undone[i$1].ranges) { ++undone; } }\n return {undo: done, redo: undone}\n },\n clearHistory: function() {this.history = new History(this.history.maxGeneration);},\n\n markClean: function() {\n this.cleanGeneration = this.changeGeneration(true);\n },\n changeGeneration: function(forceSplit) {\n if (forceSplit)\n { this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null; }\n return this.history.generation\n },\n isClean: function (gen) {\n return this.history.generation == (gen || this.cleanGeneration)\n },\n\n getHistory: function() {\n return {done: copyHistoryArray(this.history.done),\n undone: copyHistoryArray(this.history.undone)}\n },\n setHistory: function(histData) {\n var hist = this.history = new History(this.history.maxGeneration);\n hist.done = copyHistoryArray(histData.done.slice(0), null, true);\n hist.undone = copyHistoryArray(histData.undone.slice(0), null, true);\n },\n\n setGutterMarker: docMethodOp(function(line, gutterID, value) {\n return changeLine(this, line, \"gutter\", function (line) {\n var markers = line.gutterMarkers || (line.gutterMarkers = {});\n markers[gutterID] = value;\n if (!value && isEmpty(markers)) { line.gutterMarkers = null; }\n return true\n })\n }),\n\n clearGutter: docMethodOp(function(gutterID) {\n var this$1 = this;\n\n this.iter(function (line) {\n if (line.gutterMarkers && line.gutterMarkers[gutterID]) {\n changeLine(this$1, line, \"gutter\", function () {\n line.gutterMarkers[gutterID] = null;\n if (isEmpty(line.gutterMarkers)) { line.gutterMarkers = null; }\n return true\n });\n }\n });\n }),\n\n lineInfo: function(line) {\n var n;\n if (typeof line == \"number\") {\n if (!isLine(this, line)) { return null }\n n = line;\n line = getLine(this, line);\n if (!line) { return null }\n } else {\n n = lineNo(line);\n if (n == null) { return null }\n }\n return {line: n, handle: line, text: line.text, gutterMarkers: line.gutterMarkers,\n textClass: line.textClass, bgClass: line.bgClass, wrapClass: line.wrapClass,\n widgets: line.widgets}\n },\n\n addLineClass: docMethodOp(function(handle, where, cls) {\n return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function (line) {\n var prop = where == \"text\" ? \"textClass\"\n : where == \"background\" ? \"bgClass\"\n : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n if (!line[prop]) { line[prop] = cls; }\n else if (classTest(cls).test(line[prop])) { return false }\n else { line[prop] += \" \" + cls; }\n return true\n })\n }),\n removeLineClass: docMethodOp(function(handle, where, cls) {\n return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function (line) {\n var prop = where == \"text\" ? \"textClass\"\n : where == \"background\" ? \"bgClass\"\n : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n var cur = line[prop];\n if (!cur) { return false }\n else if (cls == null) { line[prop] = null; }\n else {\n var found = cur.match(classTest(cls));\n if (!found) { return false }\n var end = found.index + found[0].length;\n line[prop] = cur.slice(0, found.index) + (!found.index || end == cur.length ? \"\" : \" \") + cur.slice(end) || null;\n }\n return true\n })\n }),\n\n addLineWidget: docMethodOp(function(handle, node, options) {\n return addLineWidget(this, handle, node, options)\n }),\n removeLineWidget: function(widget) { widget.clear(); },\n\n markText: function(from, to, options) {\n return markText(this, clipPos(this, from), clipPos(this, to), options, options && options.type || \"range\")\n },\n setBookmark: function(pos, options) {\n var realOpts = {replacedWith: options && (options.nodeType == null ? options.widget : options),\n insertLeft: options && options.insertLeft,\n clearWhenEmpty: false, shared: options && options.shared,\n handleMouseEvents: options && options.handleMouseEvents};\n pos = clipPos(this, pos);\n return markText(this, pos, pos, realOpts, \"bookmark\")\n },\n findMarksAt: function(pos) {\n pos = clipPos(this, pos);\n var markers = [], spans = getLine(this, pos.line).markedSpans;\n if (spans) { for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if ((span.from == null || span.from <= pos.ch) &&\n (span.to == null || span.to >= pos.ch))\n { markers.push(span.marker.parent || span.marker); }\n } }\n return markers\n },\n findMarks: function(from, to, filter) {\n from = clipPos(this, from); to = clipPos(this, to);\n var found = [], lineNo$$1 = from.line;\n this.iter(from.line, to.line + 1, function (line) {\n var spans = line.markedSpans;\n if (spans) { for (var i = 0; i < spans.length; i++) {\n var span = spans[i];\n if (!(span.to != null && lineNo$$1 == from.line && from.ch >= span.to ||\n span.from == null && lineNo$$1 != from.line ||\n span.from != null && lineNo$$1 == to.line && span.from >= to.ch) &&\n (!filter || filter(span.marker)))\n { found.push(span.marker.parent || span.marker); }\n } }\n ++lineNo$$1;\n });\n return found\n },\n getAllMarks: function() {\n var markers = [];\n this.iter(function (line) {\n var sps = line.markedSpans;\n if (sps) { for (var i = 0; i < sps.length; ++i)\n { if (sps[i].from != null) { markers.push(sps[i].marker); } } }\n });\n return markers\n },\n\n posFromIndex: function(off) {\n var ch, lineNo$$1 = this.first, sepSize = this.lineSeparator().length;\n this.iter(function (line) {\n var sz = line.text.length + sepSize;\n if (sz > off) { ch = off; return true }\n off -= sz;\n ++lineNo$$1;\n });\n return clipPos(this, Pos(lineNo$$1, ch))\n },\n indexFromPos: function (coords) {\n coords = clipPos(this, coords);\n var index = coords.ch;\n if (coords.line < this.first || coords.ch < 0) { return 0 }\n var sepSize = this.lineSeparator().length;\n this.iter(this.first, coords.line, function (line) { // iter aborts when callback returns a truthy value\n index += line.text.length + sepSize;\n });\n return index\n },\n\n copy: function(copyHistory) {\n var doc = new Doc(getLines(this, this.first, this.first + this.size),\n this.modeOption, this.first, this.lineSep, this.direction);\n doc.scrollTop = this.scrollTop; doc.scrollLeft = this.scrollLeft;\n doc.sel = this.sel;\n doc.extend = false;\n if (copyHistory) {\n doc.history.undoDepth = this.history.undoDepth;\n doc.setHistory(this.getHistory());\n }\n return doc\n },\n\n linkedDoc: function(options) {\n if (!options) { options = {}; }\n var from = this.first, to = this.first + this.size;\n if (options.from != null && options.from > from) { from = options.from; }\n if (options.to != null && options.to < to) { to = options.to; }\n var copy = new Doc(getLines(this, from, to), options.mode || this.modeOption, from, this.lineSep, this.direction);\n if (options.sharedHist) { copy.history = this.history\n ; }(this.linked || (this.linked = [])).push({doc: copy, sharedHist: options.sharedHist});\n copy.linked = [{doc: this, isParent: true, sharedHist: options.sharedHist}];\n copySharedMarkers(copy, findSharedMarkers(this));\n return copy\n },\n unlinkDoc: function(other) {\n var this$1 = this;\n\n if (other instanceof CodeMirror) { other = other.doc; }\n if (this.linked) { for (var i = 0; i < this.linked.length; ++i) {\n var link = this$1.linked[i];\n if (link.doc != other) { continue }\n this$1.linked.splice(i, 1);\n other.unlinkDoc(this$1);\n detachSharedMarkers(findSharedMarkers(this$1));\n break\n } }\n // If the histories were shared, split them again\n if (other.history == this.history) {\n var splitIds = [other.id];\n linkedDocs(other, function (doc) { return splitIds.push(doc.id); }, true);\n other.history = new History(null);\n other.history.done = copyHistoryArray(this.history.done, splitIds);\n other.history.undone = copyHistoryArray(this.history.undone, splitIds);\n }\n },\n iterLinkedDocs: function(f) {linkedDocs(this, f);},\n\n getMode: function() {return this.mode},\n getEditor: function() {return this.cm},\n\n splitLines: function(str) {\n if (this.lineSep) { return str.split(this.lineSep) }\n return splitLinesAuto(str)\n },\n lineSeparator: function() { return this.lineSep || \"\\n\" },\n\n setDirection: docMethodOp(function (dir) {\n if (dir != \"rtl\") { dir = \"ltr\"; }\n if (dir == this.direction) { return }\n this.direction = dir;\n this.iter(function (line) { return line.order = null; });\n if (this.cm) { directionChanged(this.cm); }\n })\n });\n\n // Public alias.\n Doc.prototype.eachLine = Doc.prototype.iter;\n\n // Kludge to work around strange IE behavior where it'll sometimes\n // re-fire a series of drag-related events right after the drop (#1551)\n var lastDrop = 0;\n\n function onDrop(e) {\n var cm = this;\n clearDragCursor(cm);\n if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e))\n { return }\n e_preventDefault(e);\n if (ie) { lastDrop = +new Date; }\n var pos = posFromMouse(cm, e, true), files = e.dataTransfer.files;\n if (!pos || cm.isReadOnly()) { return }\n // Might be a file drop, in which case we simply extract the text\n // and insert it.\n if (files && files.length && window.FileReader && window.File) {\n var n = files.length, text = Array(n), read = 0;\n var loadFile = function (file, i) {\n if (cm.options.allowDropFileTypes &&\n indexOf(cm.options.allowDropFileTypes, file.type) == -1)\n { return }\n\n var reader = new FileReader;\n reader.onload = operation(cm, function () {\n var content = reader.result;\n if (/[\\x00-\\x08\\x0e-\\x1f]{2}/.test(content)) { content = \"\"; }\n text[i] = content;\n if (++read == n) {\n pos = clipPos(cm.doc, pos);\n var change = {from: pos, to: pos,\n text: cm.doc.splitLines(text.join(cm.doc.lineSeparator())),\n origin: \"paste\"};\n makeChange(cm.doc, change);\n setSelectionReplaceHistory(cm.doc, simpleSelection(pos, changeEnd(change)));\n }\n });\n reader.readAsText(file);\n };\n for (var i = 0; i < n; ++i) { loadFile(files[i], i); }\n } else { // Normal drop\n // Don't do a replace if the drop happened inside of the selected text.\n if (cm.state.draggingText && cm.doc.sel.contains(pos) > -1) {\n cm.state.draggingText(e);\n // Ensure the editor is re-focused\n setTimeout(function () { return cm.display.input.focus(); }, 20);\n return\n }\n try {\n var text$1 = e.dataTransfer.getData(\"Text\");\n if (text$1) {\n var selected;\n if (cm.state.draggingText && !cm.state.draggingText.copy)\n { selected = cm.listSelections(); }\n setSelectionNoUndo(cm.doc, simpleSelection(pos, pos));\n if (selected) { for (var i$1 = 0; i$1 < selected.length; ++i$1)\n { replaceRange(cm.doc, \"\", selected[i$1].anchor, selected[i$1].head, \"drag\"); } }\n cm.replaceSelection(text$1, \"around\", \"paste\");\n cm.display.input.focus();\n }\n }\n catch(e){}\n }\n }\n\n function onDragStart(cm, e) {\n if (ie && (!cm.state.draggingText || +new Date - lastDrop < 100)) { e_stop(e); return }\n if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) { return }\n\n e.dataTransfer.setData(\"Text\", cm.getSelection());\n e.dataTransfer.effectAllowed = \"copyMove\";\n\n // Use dummy image instead of default browsers image.\n // Recent Safari (~6.0.2) have a tendency to segfault when this happens, so we don't do it there.\n if (e.dataTransfer.setDragImage && !safari) {\n var img = elt(\"img\", null, null, \"position: fixed; left: 0; top: 0;\");\n img.src = \"data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\";\n if (presto) {\n img.width = img.height = 1;\n cm.display.wrapper.appendChild(img);\n // Force a relayout, or Opera won't use our image for some obscure reason\n img._top = img.offsetTop;\n }\n e.dataTransfer.setDragImage(img, 0, 0);\n if (presto) { img.parentNode.removeChild(img); }\n }\n }\n\n function onDragOver(cm, e) {\n var pos = posFromMouse(cm, e);\n if (!pos) { return }\n var frag = document.createDocumentFragment();\n drawSelectionCursor(cm, pos, frag);\n if (!cm.display.dragCursor) {\n cm.display.dragCursor = elt(\"div\", null, \"CodeMirror-cursors CodeMirror-dragcursors\");\n cm.display.lineSpace.insertBefore(cm.display.dragCursor, cm.display.cursorDiv);\n }\n removeChildrenAndAdd(cm.display.dragCursor, frag);\n }\n\n function clearDragCursor(cm) {\n if (cm.display.dragCursor) {\n cm.display.lineSpace.removeChild(cm.display.dragCursor);\n cm.display.dragCursor = null;\n }\n }\n\n // These must be handled carefully, because naively registering a\n // handler for each editor will cause the editors to never be\n // garbage collected.\n\n function forEachCodeMirror(f) {\n if (!document.getElementsByClassName) { return }\n var byClass = document.getElementsByClassName(\"CodeMirror\"), editors = [];\n for (var i = 0; i < byClass.length; i++) {\n var cm = byClass[i].CodeMirror;\n if (cm) { editors.push(cm); }\n }\n if (editors.length) { editors[0].operation(function () {\n for (var i = 0; i < editors.length; i++) { f(editors[i]); }\n }); }\n }\n\n var globalsRegistered = false;\n function ensureGlobalHandlers() {\n if (globalsRegistered) { return }\n registerGlobalHandlers();\n globalsRegistered = true;\n }\n function registerGlobalHandlers() {\n // When the window resizes, we need to refresh active editors.\n var resizeTimer;\n on(window, \"resize\", function () {\n if (resizeTimer == null) { resizeTimer = setTimeout(function () {\n resizeTimer = null;\n forEachCodeMirror(onResize);\n }, 100); }\n });\n // When the window loses focus, we want to show the editor as blurred\n on(window, \"blur\", function () { return forEachCodeMirror(onBlur); });\n }\n // Called when the window resizes\n function onResize(cm) {\n var d = cm.display;\n // Might be a text scaling operation, clear size caches.\n d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n d.scrollbarsClipped = false;\n cm.setSize();\n }\n\n var keyNames = {\n 3: \"Pause\", 8: \"Backspace\", 9: \"Tab\", 13: \"Enter\", 16: \"Shift\", 17: \"Ctrl\", 18: \"Alt\",\n 19: \"Pause\", 20: \"CapsLock\", 27: \"Esc\", 32: \"Space\", 33: \"PageUp\", 34: \"PageDown\", 35: \"End\",\n 36: \"Home\", 37: \"Left\", 38: \"Up\", 39: \"Right\", 40: \"Down\", 44: \"PrintScrn\", 45: \"Insert\",\n 46: \"Delete\", 59: \";\", 61: \"=\", 91: \"Mod\", 92: \"Mod\", 93: \"Mod\",\n 106: \"*\", 107: \"=\", 109: \"-\", 110: \".\", 111: \"/\", 127: \"Delete\", 145: \"ScrollLock\",\n 173: \"-\", 186: \";\", 187: \"=\", 188: \",\", 189: \"-\", 190: \".\", 191: \"/\", 192: \"`\", 219: \"[\", 220: \"\\\\\",\n 221: \"]\", 222: \"'\", 63232: \"Up\", 63233: \"Down\", 63234: \"Left\", 63235: \"Right\", 63272: \"Delete\",\n 63273: \"Home\", 63275: \"End\", 63276: \"PageUp\", 63277: \"PageDown\", 63302: \"Insert\"\n };\n\n // Number keys\n for (var i = 0; i < 10; i++) { keyNames[i + 48] = keyNames[i + 96] = String(i); }\n // Alphabetic keys\n for (var i$1 = 65; i$1 <= 90; i$1++) { keyNames[i$1] = String.fromCharCode(i$1); }\n // Function keys\n for (var i$2 = 1; i$2 <= 12; i$2++) { keyNames[i$2 + 111] = keyNames[i$2 + 63235] = \"F\" + i$2; }\n\n var keyMap = {};\n\n keyMap.basic = {\n \"Left\": \"goCharLeft\", \"Right\": \"goCharRight\", \"Up\": \"goLineUp\", \"Down\": \"goLineDown\",\n \"End\": \"goLineEnd\", \"Home\": \"goLineStartSmart\", \"PageUp\": \"goPageUp\", \"PageDown\": \"goPageDown\",\n \"Delete\": \"delCharAfter\", \"Backspace\": \"delCharBefore\", \"Shift-Backspace\": \"delCharBefore\",\n \"Tab\": \"defaultTab\", \"Shift-Tab\": \"indentAuto\",\n \"Enter\": \"newlineAndIndent\", \"Insert\": \"toggleOverwrite\",\n \"Esc\": \"singleSelection\"\n };\n // Note that the save and find-related commands aren't defined by\n // default. User code or addons can define them. Unknown commands\n // are simply ignored.\n keyMap.pcDefault = {\n \"Ctrl-A\": \"selectAll\", \"Ctrl-D\": \"deleteLine\", \"Ctrl-Z\": \"undo\", \"Shift-Ctrl-Z\": \"redo\", \"Ctrl-Y\": \"redo\",\n \"Ctrl-Home\": \"goDocStart\", \"Ctrl-End\": \"goDocEnd\", \"Ctrl-Up\": \"goLineUp\", \"Ctrl-Down\": \"goLineDown\",\n \"Ctrl-Left\": \"goGroupLeft\", \"Ctrl-Right\": \"goGroupRight\", \"Alt-Left\": \"goLineStart\", \"Alt-Right\": \"goLineEnd\",\n \"Ctrl-Backspace\": \"delGroupBefore\", \"Ctrl-Delete\": \"delGroupAfter\", \"Ctrl-S\": \"save\", \"Ctrl-F\": \"find\",\n \"Ctrl-G\": \"findNext\", \"Shift-Ctrl-G\": \"findPrev\", \"Shift-Ctrl-F\": \"replace\", \"Shift-Ctrl-R\": \"replaceAll\",\n \"Ctrl-[\": \"indentLess\", \"Ctrl-]\": \"indentMore\",\n \"Ctrl-U\": \"undoSelection\", \"Shift-Ctrl-U\": \"redoSelection\", \"Alt-U\": \"redoSelection\",\n \"fallthrough\": \"basic\"\n };\n // Very basic readline/emacs-style bindings, which are standard on Mac.\n keyMap.emacsy = {\n \"Ctrl-F\": \"goCharRight\", \"Ctrl-B\": \"goCharLeft\", \"Ctrl-P\": \"goLineUp\", \"Ctrl-N\": \"goLineDown\",\n \"Alt-F\": \"goWordRight\", \"Alt-B\": \"goWordLeft\", \"Ctrl-A\": \"goLineStart\", \"Ctrl-E\": \"goLineEnd\",\n \"Ctrl-V\": \"goPageDown\", \"Shift-Ctrl-V\": \"goPageUp\", \"Ctrl-D\": \"delCharAfter\", \"Ctrl-H\": \"delCharBefore\",\n \"Alt-D\": \"delWordAfter\", \"Alt-Backspace\": \"delWordBefore\", \"Ctrl-K\": \"killLine\", \"Ctrl-T\": \"transposeChars\",\n \"Ctrl-O\": \"openLine\"\n };\n keyMap.macDefault = {\n \"Cmd-A\": \"selectAll\", \"Cmd-D\": \"deleteLine\", \"Cmd-Z\": \"undo\", \"Shift-Cmd-Z\": \"redo\", \"Cmd-Y\": \"redo\",\n \"Cmd-Home\": \"goDocStart\", \"Cmd-Up\": \"goDocStart\", \"Cmd-End\": \"goDocEnd\", \"Cmd-Down\": \"goDocEnd\", \"Alt-Left\": \"goGroupLeft\",\n \"Alt-Right\": \"goGroupRight\", \"Cmd-Left\": \"goLineLeft\", \"Cmd-Right\": \"goLineRight\", \"Alt-Backspace\": \"delGroupBefore\",\n \"Ctrl-Alt-Backspace\": \"delGroupAfter\", \"Alt-Delete\": \"delGroupAfter\", \"Cmd-S\": \"save\", \"Cmd-F\": \"find\",\n \"Cmd-G\": \"findNext\", \"Shift-Cmd-G\": \"findPrev\", \"Cmd-Alt-F\": \"replace\", \"Shift-Cmd-Alt-F\": \"replaceAll\",\n \"Cmd-[\": \"indentLess\", \"Cmd-]\": \"indentMore\", \"Cmd-Backspace\": \"delWrappedLineLeft\", \"Cmd-Delete\": \"delWrappedLineRight\",\n \"Cmd-U\": \"undoSelection\", \"Shift-Cmd-U\": \"redoSelection\", \"Ctrl-Up\": \"goDocStart\", \"Ctrl-Down\": \"goDocEnd\",\n \"fallthrough\": [\"basic\", \"emacsy\"]\n };\n keyMap[\"default\"] = mac ? keyMap.macDefault : keyMap.pcDefault;\n\n // KEYMAP DISPATCH\n\n function normalizeKeyName(name) {\n var parts = name.split(/-(?!$)/);\n name = parts[parts.length - 1];\n var alt, ctrl, shift, cmd;\n for (var i = 0; i < parts.length - 1; i++) {\n var mod = parts[i];\n if (/^(cmd|meta|m)$/i.test(mod)) { cmd = true; }\n else if (/^a(lt)?$/i.test(mod)) { alt = true; }\n else if (/^(c|ctrl|control)$/i.test(mod)) { ctrl = true; }\n else if (/^s(hift)?$/i.test(mod)) { shift = true; }\n else { throw new Error(\"Unrecognized modifier name: \" + mod) }\n }\n if (alt) { name = \"Alt-\" + name; }\n if (ctrl) { name = \"Ctrl-\" + name; }\n if (cmd) { name = \"Cmd-\" + name; }\n if (shift) { name = \"Shift-\" + name; }\n return name\n }\n\n // This is a kludge to keep keymaps mostly working as raw objects\n // (backwards compatibility) while at the same time support features\n // like normalization and multi-stroke key bindings. It compiles a\n // new normalized keymap, and then updates the old object to reflect\n // this.\n function normalizeKeyMap(keymap) {\n var copy = {};\n for (var keyname in keymap) { if (keymap.hasOwnProperty(keyname)) {\n var value = keymap[keyname];\n if (/^(name|fallthrough|(de|at)tach)$/.test(keyname)) { continue }\n if (value == \"...\") { delete keymap[keyname]; continue }\n\n var keys = map(keyname.split(\" \"), normalizeKeyName);\n for (var i = 0; i < keys.length; i++) {\n var val = (void 0), name = (void 0);\n if (i == keys.length - 1) {\n name = keys.join(\" \");\n val = value;\n } else {\n name = keys.slice(0, i + 1).join(\" \");\n val = \"...\";\n }\n var prev = copy[name];\n if (!prev) { copy[name] = val; }\n else if (prev != val) { throw new Error(\"Inconsistent bindings for \" + name) }\n }\n delete keymap[keyname];\n } }\n for (var prop in copy) { keymap[prop] = copy[prop]; }\n return keymap\n }\n\n function lookupKey(key, map$$1, handle, context) {\n map$$1 = getKeyMap(map$$1);\n var found = map$$1.call ? map$$1.call(key, context) : map$$1[key];\n if (found === false) { return \"nothing\" }\n if (found === \"...\") { return \"multi\" }\n if (found != null && handle(found)) { return \"handled\" }\n\n if (map$$1.fallthrough) {\n if (Object.prototype.toString.call(map$$1.fallthrough) != \"[object Array]\")\n { return lookupKey(key, map$$1.fallthrough, handle, context) }\n for (var i = 0; i < map$$1.fallthrough.length; i++) {\n var result = lookupKey(key, map$$1.fallthrough[i], handle, context);\n if (result) { return result }\n }\n }\n }\n\n // Modifier key presses don't count as 'real' key presses for the\n // purpose of keymap fallthrough.\n function isModifierKey(value) {\n var name = typeof value == \"string\" ? value : keyNames[value.keyCode];\n return name == \"Ctrl\" || name == \"Alt\" || name == \"Shift\" || name == \"Mod\"\n }\n\n function addModifierNames(name, event, noShift) {\n var base = name;\n if (event.altKey && base != \"Alt\") { name = \"Alt-\" + name; }\n if ((flipCtrlCmd ? event.metaKey : event.ctrlKey) && base != \"Ctrl\") { name = \"Ctrl-\" + name; }\n if ((flipCtrlCmd ? event.ctrlKey : event.metaKey) && base != \"Cmd\") { name = \"Cmd-\" + name; }\n if (!noShift && event.shiftKey && base != \"Shift\") { name = \"Shift-\" + name; }\n return name\n }\n\n // Look up the name of a key as indicated by an event object.\n function keyName(event, noShift) {\n if (presto && event.keyCode == 34 && event[\"char\"]) { return false }\n var name = keyNames[event.keyCode];\n if (name == null || event.altGraphKey) { return false }\n // Ctrl-ScrollLock has keyCode 3, same as Ctrl-Pause,\n // so we'll use event.code when available (Chrome 48+, FF 38+, Safari 10.1+)\n if (event.keyCode == 3 && event.code) { name = event.code; }\n return addModifierNames(name, event, noShift)\n }\n\n function getKeyMap(val) {\n return typeof val == \"string\" ? keyMap[val] : val\n }\n\n // Helper for deleting text near the selection(s), used to implement\n // backspace, delete, and similar functionality.\n function deleteNearSelection(cm, compute) {\n var ranges = cm.doc.sel.ranges, kill = [];\n // Build up a set of ranges to kill first, merging overlapping\n // ranges.\n for (var i = 0; i < ranges.length; i++) {\n var toKill = compute(ranges[i]);\n while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) {\n var replaced = kill.pop();\n if (cmp(replaced.from, toKill.from) < 0) {\n toKill.from = replaced.from;\n break\n }\n }\n kill.push(toKill);\n }\n // Next, remove those actual ranges.\n runInOp(cm, function () {\n for (var i = kill.length - 1; i >= 0; i--)\n { replaceRange(cm.doc, \"\", kill[i].from, kill[i].to, \"+delete\"); }\n ensureCursorVisible(cm);\n });\n }\n\n function moveCharLogically(line, ch, dir) {\n var target = skipExtendingChars(line.text, ch + dir, dir);\n return target < 0 || target > line.text.length ? null : target\n }\n\n function moveLogically(line, start, dir) {\n var ch = moveCharLogically(line, start.ch, dir);\n return ch == null ? null : new Pos(start.line, ch, dir < 0 ? \"after\" : \"before\")\n }\n\n function endOfLine(visually, cm, lineObj, lineNo, dir) {\n if (visually) {\n var order = getOrder(lineObj, cm.doc.direction);\n if (order) {\n var part = dir < 0 ? lst(order) : order[0];\n var moveInStorageOrder = (dir < 0) == (part.level == 1);\n var sticky = moveInStorageOrder ? \"after\" : \"before\";\n var ch;\n // With a wrapped rtl chunk (possibly spanning multiple bidi parts),\n // it could be that the last bidi part is not on the last visual line,\n // since visual lines contain content order-consecutive chunks.\n // Thus, in rtl, we are looking for the first (content-order) character\n // in the rtl chunk that is on the last line (that is, the same line\n // as the last (content-order) character).\n if (part.level > 0 || cm.doc.direction == \"rtl\") {\n var prep = prepareMeasureForLine(cm, lineObj);\n ch = dir < 0 ? lineObj.text.length - 1 : 0;\n var targetTop = measureCharPrepared(cm, prep, ch).top;\n ch = findFirst(function (ch) { return measureCharPrepared(cm, prep, ch).top == targetTop; }, (dir < 0) == (part.level == 1) ? part.from : part.to - 1, ch);\n if (sticky == \"before\") { ch = moveCharLogically(lineObj, ch, 1); }\n } else { ch = dir < 0 ? part.to : part.from; }\n return new Pos(lineNo, ch, sticky)\n }\n }\n return new Pos(lineNo, dir < 0 ? lineObj.text.length : 0, dir < 0 ? \"before\" : \"after\")\n }\n\n function moveVisually(cm, line, start, dir) {\n var bidi = getOrder(line, cm.doc.direction);\n if (!bidi) { return moveLogically(line, start, dir) }\n if (start.ch >= line.text.length) {\n start.ch = line.text.length;\n start.sticky = \"before\";\n } else if (start.ch <= 0) {\n start.ch = 0;\n start.sticky = \"after\";\n }\n var partPos = getBidiPartAt(bidi, start.ch, start.sticky), part = bidi[partPos];\n if (cm.doc.direction == \"ltr\" && part.level % 2 == 0 && (dir > 0 ? part.to > start.ch : part.from < start.ch)) {\n // Case 1: We move within an ltr part in an ltr editor. Even with wrapped lines,\n // nothing interesting happens.\n return moveLogically(line, start, dir)\n }\n\n var mv = function (pos, dir) { return moveCharLogically(line, pos instanceof Pos ? pos.ch : pos, dir); };\n var prep;\n var getWrappedLineExtent = function (ch) {\n if (!cm.options.lineWrapping) { return {begin: 0, end: line.text.length} }\n prep = prep || prepareMeasureForLine(cm, line);\n return wrappedLineExtentChar(cm, line, prep, ch)\n };\n var wrappedLineExtent = getWrappedLineExtent(start.sticky == \"before\" ? mv(start, -1) : start.ch);\n\n if (cm.doc.direction == \"rtl\" || part.level == 1) {\n var moveInStorageOrder = (part.level == 1) == (dir < 0);\n var ch = mv(start, moveInStorageOrder ? 1 : -1);\n if (ch != null && (!moveInStorageOrder ? ch >= part.from && ch >= wrappedLineExtent.begin : ch <= part.to && ch <= wrappedLineExtent.end)) {\n // Case 2: We move within an rtl part or in an rtl editor on the same visual line\n var sticky = moveInStorageOrder ? \"before\" : \"after\";\n return new Pos(start.line, ch, sticky)\n }\n }\n\n // Case 3: Could not move within this bidi part in this visual line, so leave\n // the current bidi part\n\n var searchInVisualLine = function (partPos, dir, wrappedLineExtent) {\n var getRes = function (ch, moveInStorageOrder) { return moveInStorageOrder\n ? new Pos(start.line, mv(ch, 1), \"before\")\n : new Pos(start.line, ch, \"after\"); };\n\n for (; partPos >= 0 && partPos < bidi.length; partPos += dir) {\n var part = bidi[partPos];\n var moveInStorageOrder = (dir > 0) == (part.level != 1);\n var ch = moveInStorageOrder ? wrappedLineExtent.begin : mv(wrappedLineExtent.end, -1);\n if (part.from <= ch && ch < part.to) { return getRes(ch, moveInStorageOrder) }\n ch = moveInStorageOrder ? part.from : mv(part.to, -1);\n if (wrappedLineExtent.begin <= ch && ch < wrappedLineExtent.end) { return getRes(ch, moveInStorageOrder) }\n }\n };\n\n // Case 3a: Look for other bidi parts on the same visual line\n var res = searchInVisualLine(partPos + dir, dir, wrappedLineExtent);\n if (res) { return res }\n\n // Case 3b: Look for other bidi parts on the next visual line\n var nextCh = dir > 0 ? wrappedLineExtent.end : mv(wrappedLineExtent.begin, -1);\n if (nextCh != null && !(dir > 0 && nextCh == line.text.length)) {\n res = searchInVisualLine(dir > 0 ? 0 : bidi.length - 1, dir, getWrappedLineExtent(nextCh));\n if (res) { return res }\n }\n\n // Case 4: Nowhere to move\n return null\n }\n\n // Commands are parameter-less actions that can be performed on an\n // editor, mostly used for keybindings.\n var commands = {\n selectAll: selectAll,\n singleSelection: function (cm) { return cm.setSelection(cm.getCursor(\"anchor\"), cm.getCursor(\"head\"), sel_dontScroll); },\n killLine: function (cm) { return deleteNearSelection(cm, function (range) {\n if (range.empty()) {\n var len = getLine(cm.doc, range.head.line).text.length;\n if (range.head.ch == len && range.head.line < cm.lastLine())\n { return {from: range.head, to: Pos(range.head.line + 1, 0)} }\n else\n { return {from: range.head, to: Pos(range.head.line, len)} }\n } else {\n return {from: range.from(), to: range.to()}\n }\n }); },\n deleteLine: function (cm) { return deleteNearSelection(cm, function (range) { return ({\n from: Pos(range.from().line, 0),\n to: clipPos(cm.doc, Pos(range.to().line + 1, 0))\n }); }); },\n delLineLeft: function (cm) { return deleteNearSelection(cm, function (range) { return ({\n from: Pos(range.from().line, 0), to: range.from()\n }); }); },\n delWrappedLineLeft: function (cm) { return deleteNearSelection(cm, function (range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var leftPos = cm.coordsChar({left: 0, top: top}, \"div\");\n return {from: leftPos, to: range.from()}\n }); },\n delWrappedLineRight: function (cm) { return deleteNearSelection(cm, function (range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var rightPos = cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, \"div\");\n return {from: range.from(), to: rightPos }\n }); },\n undo: function (cm) { return cm.undo(); },\n redo: function (cm) { return cm.redo(); },\n undoSelection: function (cm) { return cm.undoSelection(); },\n redoSelection: function (cm) { return cm.redoSelection(); },\n goDocStart: function (cm) { return cm.extendSelection(Pos(cm.firstLine(), 0)); },\n goDocEnd: function (cm) { return cm.extendSelection(Pos(cm.lastLine())); },\n goLineStart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStart(cm, range.head.line); },\n {origin: \"+move\", bias: 1}\n ); },\n goLineStartSmart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStartSmart(cm, range.head); },\n {origin: \"+move\", bias: 1}\n ); },\n goLineEnd: function (cm) { return cm.extendSelectionsBy(function (range) { return lineEnd(cm, range.head.line); },\n {origin: \"+move\", bias: -1}\n ); },\n goLineRight: function (cm) { return cm.extendSelectionsBy(function (range) {\n var top = cm.cursorCoords(range.head, \"div\").top + 5;\n return cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, \"div\")\n }, sel_move); },\n goLineLeft: function (cm) { return cm.extendSelectionsBy(function (range) {\n var top = cm.cursorCoords(range.head, \"div\").top + 5;\n return cm.coordsChar({left: 0, top: top}, \"div\")\n }, sel_move); },\n goLineLeftSmart: function (cm) { return cm.extendSelectionsBy(function (range) {\n var top = cm.cursorCoords(range.head, \"div\").top + 5;\n var pos = cm.coordsChar({left: 0, top: top}, \"div\");\n if (pos.ch < cm.getLine(pos.line).search(/\\S/)) { return lineStartSmart(cm, range.head) }\n return pos\n }, sel_move); },\n goLineUp: function (cm) { return cm.moveV(-1, \"line\"); },\n goLineDown: function (cm) { return cm.moveV(1, \"line\"); },\n goPageUp: function (cm) { return cm.moveV(-1, \"page\"); },\n goPageDown: function (cm) { return cm.moveV(1, \"page\"); },\n goCharLeft: function (cm) { return cm.moveH(-1, \"char\"); },\n goCharRight: function (cm) { return cm.moveH(1, \"char\"); },\n goColumnLeft: function (cm) { return cm.moveH(-1, \"column\"); },\n goColumnRight: function (cm) { return cm.moveH(1, \"column\"); },\n goWordLeft: function (cm) { return cm.moveH(-1, \"word\"); },\n goGroupRight: function (cm) { return cm.moveH(1, \"group\"); },\n goGroupLeft: function (cm) { return cm.moveH(-1, \"group\"); },\n goWordRight: function (cm) { return cm.moveH(1, \"word\"); },\n delCharBefore: function (cm) { return cm.deleteH(-1, \"char\"); },\n delCharAfter: function (cm) { return cm.deleteH(1, \"char\"); },\n delWordBefore: function (cm) { return cm.deleteH(-1, \"word\"); },\n delWordAfter: function (cm) { return cm.deleteH(1, \"word\"); },\n delGroupBefore: function (cm) { return cm.deleteH(-1, \"group\"); },\n delGroupAfter: function (cm) { return cm.deleteH(1, \"group\"); },\n indentAuto: function (cm) { return cm.indentSelection(\"smart\"); },\n indentMore: function (cm) { return cm.indentSelection(\"add\"); },\n indentLess: function (cm) { return cm.indentSelection(\"subtract\"); },\n insertTab: function (cm) { return cm.replaceSelection(\"\\t\"); },\n insertSoftTab: function (cm) {\n var spaces = [], ranges = cm.listSelections(), tabSize = cm.options.tabSize;\n for (var i = 0; i < ranges.length; i++) {\n var pos = ranges[i].from();\n var col = countColumn(cm.getLine(pos.line), pos.ch, tabSize);\n spaces.push(spaceStr(tabSize - col % tabSize));\n }\n cm.replaceSelections(spaces);\n },\n defaultTab: function (cm) {\n if (cm.somethingSelected()) { cm.indentSelection(\"add\"); }\n else { cm.execCommand(\"insertTab\"); }\n },\n // Swap the two chars left and right of each selection's head.\n // Move cursor behind the two swapped characters afterwards.\n //\n // Doesn't consider line feeds a character.\n // Doesn't scan more than one line above to find a character.\n // Doesn't do anything on an empty line.\n // Doesn't do anything with non-empty selections.\n transposeChars: function (cm) { return runInOp(cm, function () {\n var ranges = cm.listSelections(), newSel = [];\n for (var i = 0; i < ranges.length; i++) {\n if (!ranges[i].empty()) { continue }\n var cur = ranges[i].head, line = getLine(cm.doc, cur.line).text;\n if (line) {\n if (cur.ch == line.length) { cur = new Pos(cur.line, cur.ch - 1); }\n if (cur.ch > 0) {\n cur = new Pos(cur.line, cur.ch + 1);\n cm.replaceRange(line.charAt(cur.ch - 1) + line.charAt(cur.ch - 2),\n Pos(cur.line, cur.ch - 2), cur, \"+transpose\");\n } else if (cur.line > cm.doc.first) {\n var prev = getLine(cm.doc, cur.line - 1).text;\n if (prev) {\n cur = new Pos(cur.line, 1);\n cm.replaceRange(line.charAt(0) + cm.doc.lineSeparator() +\n prev.charAt(prev.length - 1),\n Pos(cur.line - 1, prev.length - 1), cur, \"+transpose\");\n }\n }\n }\n newSel.push(new Range(cur, cur));\n }\n cm.setSelections(newSel);\n }); },\n newlineAndIndent: function (cm) { return runInOp(cm, function () {\n var sels = cm.listSelections();\n for (var i = sels.length - 1; i >= 0; i--)\n { cm.replaceRange(cm.doc.lineSeparator(), sels[i].anchor, sels[i].head, \"+input\"); }\n sels = cm.listSelections();\n for (var i$1 = 0; i$1 < sels.length; i$1++)\n { cm.indentLine(sels[i$1].from().line, null, true); }\n ensureCursorVisible(cm);\n }); },\n openLine: function (cm) { return cm.replaceSelection(\"\\n\", \"start\"); },\n toggleOverwrite: function (cm) { return cm.toggleOverwrite(); }\n };\n\n\n function lineStart(cm, lineN) {\n var line = getLine(cm.doc, lineN);\n var visual = visualLine(line);\n if (visual != line) { lineN = lineNo(visual); }\n return endOfLine(true, cm, visual, lineN, 1)\n }\n function lineEnd(cm, lineN) {\n var line = getLine(cm.doc, lineN);\n var visual = visualLineEnd(line);\n if (visual != line) { lineN = lineNo(visual); }\n return endOfLine(true, cm, line, lineN, -1)\n }\n function lineStartSmart(cm, pos) {\n var start = lineStart(cm, pos.line);\n var line = getLine(cm.doc, start.line);\n var order = getOrder(line, cm.doc.direction);\n if (!order || order[0].level == 0) {\n var firstNonWS = Math.max(0, line.text.search(/\\S/));\n var inWS = pos.line == start.line && pos.ch <= firstNonWS && pos.ch;\n return Pos(start.line, inWS ? 0 : firstNonWS, start.sticky)\n }\n return start\n }\n\n // Run a handler that was bound to a key.\n function doHandleBinding(cm, bound, dropShift) {\n if (typeof bound == \"string\") {\n bound = commands[bound];\n if (!bound) { return false }\n }\n // Ensure previous input has been read, so that the handler sees a\n // consistent view of the document\n cm.display.input.ensurePolled();\n var prevShift = cm.display.shift, done = false;\n try {\n if (cm.isReadOnly()) { cm.state.suppressEdits = true; }\n if (dropShift) { cm.display.shift = false; }\n done = bound(cm) != Pass;\n } finally {\n cm.display.shift = prevShift;\n cm.state.suppressEdits = false;\n }\n return done\n }\n\n function lookupKeyForEditor(cm, name, handle) {\n for (var i = 0; i < cm.state.keyMaps.length; i++) {\n var result = lookupKey(name, cm.state.keyMaps[i], handle, cm);\n if (result) { return result }\n }\n return (cm.options.extraKeys && lookupKey(name, cm.options.extraKeys, handle, cm))\n || lookupKey(name, cm.options.keyMap, handle, cm)\n }\n\n // Note that, despite the name, this function is also used to check\n // for bound mouse clicks.\n\n var stopSeq = new Delayed;\n\n function dispatchKey(cm, name, e, handle) {\n var seq = cm.state.keySeq;\n if (seq) {\n if (isModifierKey(name)) { return \"handled\" }\n if (/\\'$/.test(name))\n { cm.state.keySeq = null; }\n else\n { stopSeq.set(50, function () {\n if (cm.state.keySeq == seq) {\n cm.state.keySeq = null;\n cm.display.input.reset();\n }\n }); }\n if (dispatchKeyInner(cm, seq + \" \" + name, e, handle)) { return true }\n }\n return dispatchKeyInner(cm, name, e, handle)\n }\n\n function dispatchKeyInner(cm, name, e, handle) {\n var result = lookupKeyForEditor(cm, name, handle);\n\n if (result == \"multi\")\n { cm.state.keySeq = name; }\n if (result == \"handled\")\n { signalLater(cm, \"keyHandled\", cm, name, e); }\n\n if (result == \"handled\" || result == \"multi\") {\n e_preventDefault(e);\n restartBlink(cm);\n }\n\n return !!result\n }\n\n // Handle a key from the keydown event.\n function handleKeyBinding(cm, e) {\n var name = keyName(e, true);\n if (!name) { return false }\n\n if (e.shiftKey && !cm.state.keySeq) {\n // First try to resolve full name (including 'Shift-'). Failing\n // that, see if there is a cursor-motion command (starting with\n // 'go') bound to the keyname without 'Shift-'.\n return dispatchKey(cm, \"Shift-\" + name, e, function (b) { return doHandleBinding(cm, b, true); })\n || dispatchKey(cm, name, e, function (b) {\n if (typeof b == \"string\" ? /^go[A-Z]/.test(b) : b.motion)\n { return doHandleBinding(cm, b) }\n })\n } else {\n return dispatchKey(cm, name, e, function (b) { return doHandleBinding(cm, b); })\n }\n }\n\n // Handle a key from the keypress event\n function handleCharBinding(cm, e, ch) {\n return dispatchKey(cm, \"'\" + ch + \"'\", e, function (b) { return doHandleBinding(cm, b, true); })\n }\n\n var lastStoppedKey = null;\n function onKeyDown(e) {\n var cm = this;\n cm.curOp.focus = activeElt();\n if (signalDOMEvent(cm, e)) { return }\n // IE does strange things with escape.\n if (ie && ie_version < 11 && e.keyCode == 27) { e.returnValue = false; }\n var code = e.keyCode;\n cm.display.shift = code == 16 || e.shiftKey;\n var handled = handleKeyBinding(cm, e);\n if (presto) {\n lastStoppedKey = handled ? code : null;\n // Opera has no cut event... we try to at least catch the key combo\n if (!handled && code == 88 && !hasCopyEvent && (mac ? e.metaKey : e.ctrlKey))\n { cm.replaceSelection(\"\", null, \"cut\"); }\n }\n\n // Turn mouse into crosshair when Alt is held on Mac.\n if (code == 18 && !/\\bCodeMirror-crosshair\\b/.test(cm.display.lineDiv.className))\n { showCrossHair(cm); }\n }\n\n function showCrossHair(cm) {\n var lineDiv = cm.display.lineDiv;\n addClass(lineDiv, \"CodeMirror-crosshair\");\n\n function up(e) {\n if (e.keyCode == 18 || !e.altKey) {\n rmClass(lineDiv, \"CodeMirror-crosshair\");\n off(document, \"keyup\", up);\n off(document, \"mouseover\", up);\n }\n }\n on(document, \"keyup\", up);\n on(document, \"mouseover\", up);\n }\n\n function onKeyUp(e) {\n if (e.keyCode == 16) { this.doc.sel.shift = false; }\n signalDOMEvent(this, e);\n }\n\n function onKeyPress(e) {\n var cm = this;\n if (eventInWidget(cm.display, e) || signalDOMEvent(cm, e) || e.ctrlKey && !e.altKey || mac && e.metaKey) { return }\n var keyCode = e.keyCode, charCode = e.charCode;\n if (presto && keyCode == lastStoppedKey) {lastStoppedKey = null; e_preventDefault(e); return}\n if ((presto && (!e.which || e.which < 10)) && handleKeyBinding(cm, e)) { return }\n var ch = String.fromCharCode(charCode == null ? keyCode : charCode);\n // Some browsers fire keypress events for backspace\n if (ch == \"\\x08\") { return }\n if (handleCharBinding(cm, e, ch)) { return }\n cm.display.input.onKeyPress(e);\n }\n\n var DOUBLECLICK_DELAY = 400;\n\n var PastClick = function(time, pos, button) {\n this.time = time;\n this.pos = pos;\n this.button = button;\n };\n\n PastClick.prototype.compare = function (time, pos, button) {\n return this.time + DOUBLECLICK_DELAY > time &&\n cmp(pos, this.pos) == 0 && button == this.button\n };\n\n var lastClick, lastDoubleClick;\n function clickRepeat(pos, button) {\n var now = +new Date;\n if (lastDoubleClick && lastDoubleClick.compare(now, pos, button)) {\n lastClick = lastDoubleClick = null;\n return \"triple\"\n } else if (lastClick && lastClick.compare(now, pos, button)) {\n lastDoubleClick = new PastClick(now, pos, button);\n lastClick = null;\n return \"double\"\n } else {\n lastClick = new PastClick(now, pos, button);\n lastDoubleClick = null;\n return \"single\"\n }\n }\n\n // A mouse down can be a single click, double click, triple click,\n // start of selection drag, start of text drag, new cursor\n // (ctrl-click), rectangle drag (alt-drag), or xwin\n // middle-click-paste. Or it might be a click on something we should\n // not interfere with, such as a scrollbar or widget.\n function onMouseDown(e) {\n var cm = this, display = cm.display;\n if (signalDOMEvent(cm, e) || display.activeTouch && display.input.supportsTouch()) { return }\n display.input.ensurePolled();\n display.shift = e.shiftKey;\n\n if (eventInWidget(display, e)) {\n if (!webkit) {\n // Briefly turn off draggability, to allow widgets to do\n // normal dragging things.\n display.scroller.draggable = false;\n setTimeout(function () { return display.scroller.draggable = true; }, 100);\n }\n return\n }\n if (clickInGutter(cm, e)) { return }\n var pos = posFromMouse(cm, e), button = e_button(e), repeat = pos ? clickRepeat(pos, button) : \"single\";\n window.focus();\n\n // #3261: make sure, that we're not starting a second selection\n if (button == 1 && cm.state.selectingText)\n { cm.state.selectingText(e); }\n\n if (pos && handleMappedButton(cm, button, pos, repeat, e)) { return }\n\n if (button == 1) {\n if (pos) { leftButtonDown(cm, pos, repeat, e); }\n else if (e_target(e) == display.scroller) { e_preventDefault(e); }\n } else if (button == 2) {\n if (pos) { extendSelection(cm.doc, pos); }\n setTimeout(function () { return display.input.focus(); }, 20);\n } else if (button == 3) {\n if (captureRightClick) { cm.display.input.onContextMenu(e); }\n else { delayBlurEvent(cm); }\n }\n }\n\n function handleMappedButton(cm, button, pos, repeat, event) {\n var name = \"Click\";\n if (repeat == \"double\") { name = \"Double\" + name; }\n else if (repeat == \"triple\") { name = \"Triple\" + name; }\n name = (button == 1 ? \"Left\" : button == 2 ? \"Middle\" : \"Right\") + name;\n\n return dispatchKey(cm, addModifierNames(name, event), event, function (bound) {\n if (typeof bound == \"string\") { bound = commands[bound]; }\n if (!bound) { return false }\n var done = false;\n try {\n if (cm.isReadOnly()) { cm.state.suppressEdits = true; }\n done = bound(cm, pos) != Pass;\n } finally {\n cm.state.suppressEdits = false;\n }\n return done\n })\n }\n\n function configureMouse(cm, repeat, event) {\n var option = cm.getOption(\"configureMouse\");\n var value = option ? option(cm, repeat, event) : {};\n if (value.unit == null) {\n var rect = chromeOS ? event.shiftKey && event.metaKey : event.altKey;\n value.unit = rect ? \"rectangle\" : repeat == \"single\" ? \"char\" : repeat == \"double\" ? \"word\" : \"line\";\n }\n if (value.extend == null || cm.doc.extend) { value.extend = cm.doc.extend || event.shiftKey; }\n if (value.addNew == null) { value.addNew = mac ? event.metaKey : event.ctrlKey; }\n if (value.moveOnDrag == null) { value.moveOnDrag = !(mac ? event.altKey : event.ctrlKey); }\n return value\n }\n\n function leftButtonDown(cm, pos, repeat, event) {\n if (ie) { setTimeout(bind(ensureFocus, cm), 0); }\n else { cm.curOp.focus = activeElt(); }\n\n var behavior = configureMouse(cm, repeat, event);\n\n var sel = cm.doc.sel, contained;\n if (cm.options.dragDrop && dragAndDrop && !cm.isReadOnly() &&\n repeat == \"single\" && (contained = sel.contains(pos)) > -1 &&\n (cmp((contained = sel.ranges[contained]).from(), pos) < 0 || pos.xRel > 0) &&\n (cmp(contained.to(), pos) > 0 || pos.xRel < 0))\n { leftButtonStartDrag(cm, event, pos, behavior); }\n else\n { leftButtonSelect(cm, event, pos, behavior); }\n }\n\n // Start a text drag. When it ends, see if any dragging actually\n // happen, and treat as a click if it didn't.\n function leftButtonStartDrag(cm, event, pos, behavior) {\n var display = cm.display, moved = false;\n var dragEnd = operation(cm, function (e) {\n if (webkit) { display.scroller.draggable = false; }\n cm.state.draggingText = false;\n off(display.wrapper.ownerDocument, \"mouseup\", dragEnd);\n off(display.wrapper.ownerDocument, \"mousemove\", mouseMove);\n off(display.scroller, \"dragstart\", dragStart);\n off(display.scroller, \"drop\", dragEnd);\n if (!moved) {\n e_preventDefault(e);\n if (!behavior.addNew)\n { extendSelection(cm.doc, pos, null, null, behavior.extend); }\n // Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081)\n if (webkit || ie && ie_version == 9)\n { setTimeout(function () {display.wrapper.ownerDocument.body.focus(); display.input.focus();}, 20); }\n else\n { display.input.focus(); }\n }\n });\n var mouseMove = function(e2) {\n moved = moved || Math.abs(event.clientX - e2.clientX) + Math.abs(event.clientY - e2.clientY) >= 10;\n };\n var dragStart = function () { return moved = true; };\n // Let the drag handler handle this.\n if (webkit) { display.scroller.draggable = true; }\n cm.state.draggingText = dragEnd;\n dragEnd.copy = !behavior.moveOnDrag;\n // IE's approach to draggable\n if (display.scroller.dragDrop) { display.scroller.dragDrop(); }\n on(display.wrapper.ownerDocument, \"mouseup\", dragEnd);\n on(display.wrapper.ownerDocument, \"mousemove\", mouseMove);\n on(display.scroller, \"dragstart\", dragStart);\n on(display.scroller, \"drop\", dragEnd);\n\n delayBlurEvent(cm);\n setTimeout(function () { return display.input.focus(); }, 20);\n }\n\n function rangeForUnit(cm, pos, unit) {\n if (unit == \"char\") { return new Range(pos, pos) }\n if (unit == \"word\") { return cm.findWordAt(pos) }\n if (unit == \"line\") { return new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0))) }\n var result = unit(cm, pos);\n return new Range(result.from, result.to)\n }\n\n // Normal selection, as opposed to text dragging.\n function leftButtonSelect(cm, event, start, behavior) {\n var display = cm.display, doc = cm.doc;\n e_preventDefault(event);\n\n var ourRange, ourIndex, startSel = doc.sel, ranges = startSel.ranges;\n if (behavior.addNew && !behavior.extend) {\n ourIndex = doc.sel.contains(start);\n if (ourIndex > -1)\n { ourRange = ranges[ourIndex]; }\n else\n { ourRange = new Range(start, start); }\n } else {\n ourRange = doc.sel.primary();\n ourIndex = doc.sel.primIndex;\n }\n\n if (behavior.unit == \"rectangle\") {\n if (!behavior.addNew) { ourRange = new Range(start, start); }\n start = posFromMouse(cm, event, true, true);\n ourIndex = -1;\n } else {\n var range$$1 = rangeForUnit(cm, start, behavior.unit);\n if (behavior.extend)\n { ourRange = extendRange(ourRange, range$$1.anchor, range$$1.head, behavior.extend); }\n else\n { ourRange = range$$1; }\n }\n\n if (!behavior.addNew) {\n ourIndex = 0;\n setSelection(doc, new Selection([ourRange], 0), sel_mouse);\n startSel = doc.sel;\n } else if (ourIndex == -1) {\n ourIndex = ranges.length;\n setSelection(doc, normalizeSelection(cm, ranges.concat([ourRange]), ourIndex),\n {scroll: false, origin: \"*mouse\"});\n } else if (ranges.length > 1 && ranges[ourIndex].empty() && behavior.unit == \"char\" && !behavior.extend) {\n setSelection(doc, normalizeSelection(cm, ranges.slice(0, ourIndex).concat(ranges.slice(ourIndex + 1)), 0),\n {scroll: false, origin: \"*mouse\"});\n startSel = doc.sel;\n } else {\n replaceOneSelection(doc, ourIndex, ourRange, sel_mouse);\n }\n\n var lastPos = start;\n function extendTo(pos) {\n if (cmp(lastPos, pos) == 0) { return }\n lastPos = pos;\n\n if (behavior.unit == \"rectangle\") {\n var ranges = [], tabSize = cm.options.tabSize;\n var startCol = countColumn(getLine(doc, start.line).text, start.ch, tabSize);\n var posCol = countColumn(getLine(doc, pos.line).text, pos.ch, tabSize);\n var left = Math.min(startCol, posCol), right = Math.max(startCol, posCol);\n for (var line = Math.min(start.line, pos.line), end = Math.min(cm.lastLine(), Math.max(start.line, pos.line));\n line <= end; line++) {\n var text = getLine(doc, line).text, leftPos = findColumn(text, left, tabSize);\n if (left == right)\n { ranges.push(new Range(Pos(line, leftPos), Pos(line, leftPos))); }\n else if (text.length > leftPos)\n { ranges.push(new Range(Pos(line, leftPos), Pos(line, findColumn(text, right, tabSize)))); }\n }\n if (!ranges.length) { ranges.push(new Range(start, start)); }\n setSelection(doc, normalizeSelection(cm, startSel.ranges.slice(0, ourIndex).concat(ranges), ourIndex),\n {origin: \"*mouse\", scroll: false});\n cm.scrollIntoView(pos);\n } else {\n var oldRange = ourRange;\n var range$$1 = rangeForUnit(cm, pos, behavior.unit);\n var anchor = oldRange.anchor, head;\n if (cmp(range$$1.anchor, anchor) > 0) {\n head = range$$1.head;\n anchor = minPos(oldRange.from(), range$$1.anchor);\n } else {\n head = range$$1.anchor;\n anchor = maxPos(oldRange.to(), range$$1.head);\n }\n var ranges$1 = startSel.ranges.slice(0);\n ranges$1[ourIndex] = bidiSimplify(cm, new Range(clipPos(doc, anchor), head));\n setSelection(doc, normalizeSelection(cm, ranges$1, ourIndex), sel_mouse);\n }\n }\n\n var editorSize = display.wrapper.getBoundingClientRect();\n // Used to ensure timeout re-tries don't fire when another extend\n // happened in the meantime (clearTimeout isn't reliable -- at\n // least on Chrome, the timeouts still happen even when cleared,\n // if the clear happens after their scheduled firing time).\n var counter = 0;\n\n function extend(e) {\n var curCount = ++counter;\n var cur = posFromMouse(cm, e, true, behavior.unit == \"rectangle\");\n if (!cur) { return }\n if (cmp(cur, lastPos) != 0) {\n cm.curOp.focus = activeElt();\n extendTo(cur);\n var visible = visibleLines(display, doc);\n if (cur.line >= visible.to || cur.line < visible.from)\n { setTimeout(operation(cm, function () {if (counter == curCount) { extend(e); }}), 150); }\n } else {\n var outside = e.clientY < editorSize.top ? -20 : e.clientY > editorSize.bottom ? 20 : 0;\n if (outside) { setTimeout(operation(cm, function () {\n if (counter != curCount) { return }\n display.scroller.scrollTop += outside;\n extend(e);\n }), 50); }\n }\n }\n\n function done(e) {\n cm.state.selectingText = false;\n counter = Infinity;\n e_preventDefault(e);\n display.input.focus();\n off(display.wrapper.ownerDocument, \"mousemove\", move);\n off(display.wrapper.ownerDocument, \"mouseup\", up);\n doc.history.lastSelOrigin = null;\n }\n\n var move = operation(cm, function (e) {\n if (e.buttons === 0 || !e_button(e)) { done(e); }\n else { extend(e); }\n });\n var up = operation(cm, done);\n cm.state.selectingText = up;\n on(display.wrapper.ownerDocument, \"mousemove\", move);\n on(display.wrapper.ownerDocument, \"mouseup\", up);\n }\n\n // Used when mouse-selecting to adjust the anchor to the proper side\n // of a bidi jump depending on the visual position of the head.\n function bidiSimplify(cm, range$$1) {\n var anchor = range$$1.anchor;\n var head = range$$1.head;\n var anchorLine = getLine(cm.doc, anchor.line);\n if (cmp(anchor, head) == 0 && anchor.sticky == head.sticky) { return range$$1 }\n var order = getOrder(anchorLine);\n if (!order) { return range$$1 }\n var index = getBidiPartAt(order, anchor.ch, anchor.sticky), part = order[index];\n if (part.from != anchor.ch && part.to != anchor.ch) { return range$$1 }\n var boundary = index + ((part.from == anchor.ch) == (part.level != 1) ? 0 : 1);\n if (boundary == 0 || boundary == order.length) { return range$$1 }\n\n // Compute the relative visual position of the head compared to the\n // anchor (<0 is to the left, >0 to the right)\n var leftSide;\n if (head.line != anchor.line) {\n leftSide = (head.line - anchor.line) * (cm.doc.direction == \"ltr\" ? 1 : -1) > 0;\n } else {\n var headIndex = getBidiPartAt(order, head.ch, head.sticky);\n var dir = headIndex - index || (head.ch - anchor.ch) * (part.level == 1 ? -1 : 1);\n if (headIndex == boundary - 1 || headIndex == boundary)\n { leftSide = dir < 0; }\n else\n { leftSide = dir > 0; }\n }\n\n var usePart = order[boundary + (leftSide ? -1 : 0)];\n var from = leftSide == (usePart.level == 1);\n var ch = from ? usePart.from : usePart.to, sticky = from ? \"after\" : \"before\";\n return anchor.ch == ch && anchor.sticky == sticky ? range$$1 : new Range(new Pos(anchor.line, ch, sticky), head)\n }\n\n\n // Determines whether an event happened in the gutter, and fires the\n // handlers for the corresponding event.\n function gutterEvent(cm, e, type, prevent) {\n var mX, mY;\n if (e.touches) {\n mX = e.touches[0].clientX;\n mY = e.touches[0].clientY;\n } else {\n try { mX = e.clientX; mY = e.clientY; }\n catch(e) { return false }\n }\n if (mX >= Math.floor(cm.display.gutters.getBoundingClientRect().right)) { return false }\n if (prevent) { e_preventDefault(e); }\n\n var display = cm.display;\n var lineBox = display.lineDiv.getBoundingClientRect();\n\n if (mY > lineBox.bottom || !hasHandler(cm, type)) { return e_defaultPrevented(e) }\n mY -= lineBox.top - display.viewOffset;\n\n for (var i = 0; i < cm.options.gutters.length; ++i) {\n var g = display.gutters.childNodes[i];\n if (g && g.getBoundingClientRect().right >= mX) {\n var line = lineAtHeight(cm.doc, mY);\n var gutter = cm.options.gutters[i];\n signal(cm, type, cm, line, gutter, e);\n return e_defaultPrevented(e)\n }\n }\n }\n\n function clickInGutter(cm, e) {\n return gutterEvent(cm, e, \"gutterClick\", true)\n }\n\n // CONTEXT MENU HANDLING\n\n // To make the context menu work, we need to briefly unhide the\n // textarea (making it as unobtrusive as possible) to let the\n // right-click take effect on it.\n function onContextMenu(cm, e) {\n if (eventInWidget(cm.display, e) || contextMenuInGutter(cm, e)) { return }\n if (signalDOMEvent(cm, e, \"contextmenu\")) { return }\n if (!captureRightClick) { cm.display.input.onContextMenu(e); }\n }\n\n function contextMenuInGutter(cm, e) {\n if (!hasHandler(cm, \"gutterContextMenu\")) { return false }\n return gutterEvent(cm, e, \"gutterContextMenu\", false)\n }\n\n function themeChanged(cm) {\n cm.display.wrapper.className = cm.display.wrapper.className.replace(/\\s*cm-s-\\S+/g, \"\") +\n cm.options.theme.replace(/(^|\\s)\\s*/g, \" cm-s-\");\n clearCaches(cm);\n }\n\n var Init = {toString: function(){return \"CodeMirror.Init\"}};\n\n var defaults = {};\n var optionHandlers = {};\n\n function defineOptions(CodeMirror) {\n var optionHandlers = CodeMirror.optionHandlers;\n\n function option(name, deflt, handle, notOnInit) {\n CodeMirror.defaults[name] = deflt;\n if (handle) { optionHandlers[name] =\n notOnInit ? function (cm, val, old) {if (old != Init) { handle(cm, val, old); }} : handle; }\n }\n\n CodeMirror.defineOption = option;\n\n // Passed to option handlers when there is no old value.\n CodeMirror.Init = Init;\n\n // These two are, on init, called from the constructor because they\n // have to be initialized before the editor can start at all.\n option(\"value\", \"\", function (cm, val) { return cm.setValue(val); }, true);\n option(\"mode\", null, function (cm, val) {\n cm.doc.modeOption = val;\n loadMode(cm);\n }, true);\n\n option(\"indentUnit\", 2, loadMode, true);\n option(\"indentWithTabs\", false);\n option(\"smartIndent\", true);\n option(\"tabSize\", 4, function (cm) {\n resetModeState(cm);\n clearCaches(cm);\n regChange(cm);\n }, true);\n\n option(\"lineSeparator\", null, function (cm, val) {\n cm.doc.lineSep = val;\n if (!val) { return }\n var newBreaks = [], lineNo = cm.doc.first;\n cm.doc.iter(function (line) {\n for (var pos = 0;;) {\n var found = line.text.indexOf(val, pos);\n if (found == -1) { break }\n pos = found + val.length;\n newBreaks.push(Pos(lineNo, found));\n }\n lineNo++;\n });\n for (var i = newBreaks.length - 1; i >= 0; i--)\n { replaceRange(cm.doc, val, newBreaks[i], Pos(newBreaks[i].line, newBreaks[i].ch + val.length)); }\n });\n option(\"specialChars\", /[\\u0000-\\u001f\\u007f-\\u009f\\u00ad\\u061c\\u200b-\\u200f\\u2028\\u2029\\ufeff]/g, function (cm, val, old) {\n cm.state.specialChars = new RegExp(val.source + (val.test(\"\\t\") ? \"\" : \"|\\t\"), \"g\");\n if (old != Init) { cm.refresh(); }\n });\n option(\"specialCharPlaceholder\", defaultSpecialCharPlaceholder, function (cm) { return cm.refresh(); }, true);\n option(\"electricChars\", true);\n option(\"inputStyle\", mobile ? \"contenteditable\" : \"textarea\", function () {\n throw new Error(\"inputStyle can not (yet) be changed in a running editor\") // FIXME\n }, true);\n option(\"spellcheck\", false, function (cm, val) { return cm.getInputField().spellcheck = val; }, true);\n option(\"rtlMoveVisually\", !windows);\n option(\"wholeLineUpdateBefore\", true);\n\n option(\"theme\", \"default\", function (cm) {\n themeChanged(cm);\n guttersChanged(cm);\n }, true);\n option(\"keyMap\", \"default\", function (cm, val, old) {\n var next = getKeyMap(val);\n var prev = old != Init && getKeyMap(old);\n if (prev && prev.detach) { prev.detach(cm, next); }\n if (next.attach) { next.attach(cm, prev || null); }\n });\n option(\"extraKeys\", null);\n option(\"configureMouse\", null);\n\n option(\"lineWrapping\", false, wrappingChanged, true);\n option(\"gutters\", [], function (cm) {\n setGuttersForLineNumbers(cm.options);\n guttersChanged(cm);\n }, true);\n option(\"fixedGutter\", true, function (cm, val) {\n cm.display.gutters.style.left = val ? compensateForHScroll(cm.display) + \"px\" : \"0\";\n cm.refresh();\n }, true);\n option(\"coverGutterNextToScrollbar\", false, function (cm) { return updateScrollbars(cm); }, true);\n option(\"scrollbarStyle\", \"native\", function (cm) {\n initScrollbars(cm);\n updateScrollbars(cm);\n cm.display.scrollbars.setScrollTop(cm.doc.scrollTop);\n cm.display.scrollbars.setScrollLeft(cm.doc.scrollLeft);\n }, true);\n option(\"lineNumbers\", false, function (cm) {\n setGuttersForLineNumbers(cm.options);\n guttersChanged(cm);\n }, true);\n option(\"firstLineNumber\", 1, guttersChanged, true);\n option(\"lineNumberFormatter\", function (integer) { return integer; }, guttersChanged, true);\n option(\"showCursorWhenSelecting\", false, updateSelection, true);\n\n option(\"resetSelectionOnContextMenu\", true);\n option(\"lineWiseCopyCut\", true);\n option(\"pasteLinesPerSelection\", true);\n option(\"selectionsMayTouch\", false);\n\n option(\"readOnly\", false, function (cm, val) {\n if (val == \"nocursor\") {\n onBlur(cm);\n cm.display.input.blur();\n }\n cm.display.input.readOnlyChanged(val);\n });\n option(\"disableInput\", false, function (cm, val) {if (!val) { cm.display.input.reset(); }}, true);\n option(\"dragDrop\", true, dragDropChanged);\n option(\"allowDropFileTypes\", null);\n\n option(\"cursorBlinkRate\", 530);\n option(\"cursorScrollMargin\", 0);\n option(\"cursorHeight\", 1, updateSelection, true);\n option(\"singleCursorHeightPerLine\", true, updateSelection, true);\n option(\"workTime\", 100);\n option(\"workDelay\", 100);\n option(\"flattenSpans\", true, resetModeState, true);\n option(\"addModeClass\", false, resetModeState, true);\n option(\"pollInterval\", 100);\n option(\"undoDepth\", 200, function (cm, val) { return cm.doc.history.undoDepth = val; });\n option(\"historyEventDelay\", 1250);\n option(\"viewportMargin\", 10, function (cm) { return cm.refresh(); }, true);\n option(\"maxHighlightLength\", 10000, resetModeState, true);\n option(\"moveInputWithCursor\", true, function (cm, val) {\n if (!val) { cm.display.input.resetPosition(); }\n });\n\n option(\"tabindex\", null, function (cm, val) { return cm.display.input.getField().tabIndex = val || \"\"; });\n option(\"autofocus\", null);\n option(\"direction\", \"ltr\", function (cm, val) { return cm.doc.setDirection(val); }, true);\n option(\"phrases\", null);\n }\n\n function guttersChanged(cm) {\n updateGutters(cm);\n regChange(cm);\n alignHorizontally(cm);\n }\n\n function dragDropChanged(cm, value, old) {\n var wasOn = old && old != Init;\n if (!value != !wasOn) {\n var funcs = cm.display.dragFunctions;\n var toggle = value ? on : off;\n toggle(cm.display.scroller, \"dragstart\", funcs.start);\n toggle(cm.display.scroller, \"dragenter\", funcs.enter);\n toggle(cm.display.scroller, \"dragover\", funcs.over);\n toggle(cm.display.scroller, \"dragleave\", funcs.leave);\n toggle(cm.display.scroller, \"drop\", funcs.drop);\n }\n }\n\n function wrappingChanged(cm) {\n if (cm.options.lineWrapping) {\n addClass(cm.display.wrapper, \"CodeMirror-wrap\");\n cm.display.sizer.style.minWidth = \"\";\n cm.display.sizerWidth = null;\n } else {\n rmClass(cm.display.wrapper, \"CodeMirror-wrap\");\n findMaxLine(cm);\n }\n estimateLineHeights(cm);\n regChange(cm);\n clearCaches(cm);\n setTimeout(function () { return updateScrollbars(cm); }, 100);\n }\n\n // A CodeMirror instance represents an editor. This is the object\n // that user code is usually dealing with.\n\n function CodeMirror(place, options) {\n var this$1 = this;\n\n if (!(this instanceof CodeMirror)) { return new CodeMirror(place, options) }\n\n this.options = options = options ? copyObj(options) : {};\n // Determine effective options based on given values and defaults.\n copyObj(defaults, options, false);\n setGuttersForLineNumbers(options);\n\n var doc = options.value;\n if (typeof doc == \"string\") { doc = new Doc(doc, options.mode, null, options.lineSeparator, options.direction); }\n else if (options.mode) { doc.modeOption = options.mode; }\n this.doc = doc;\n\n var input = new CodeMirror.inputStyles[options.inputStyle](this);\n var display = this.display = new Display(place, doc, input);\n display.wrapper.CodeMirror = this;\n updateGutters(this);\n themeChanged(this);\n if (options.lineWrapping)\n { this.display.wrapper.className += \" CodeMirror-wrap\"; }\n initScrollbars(this);\n\n this.state = {\n keyMaps: [], // stores maps added by addKeyMap\n overlays: [], // highlighting overlays, as added by addOverlay\n modeGen: 0, // bumped when mode/overlay changes, used to invalidate highlighting info\n overwrite: false,\n delayingBlurEvent: false,\n focused: false,\n suppressEdits: false, // used to disable editing during key handlers when in readOnly mode\n pasteIncoming: false, cutIncoming: false, // help recognize paste/cut edits in input.poll\n selectingText: false,\n draggingText: false,\n highlight: new Delayed(), // stores highlight worker timeout\n keySeq: null, // Unfinished key sequence\n specialChars: null\n };\n\n if (options.autofocus && !mobile) { display.input.focus(); }\n\n // Override magic textarea content restore that IE sometimes does\n // on our hidden textarea on reload\n if (ie && ie_version < 11) { setTimeout(function () { return this$1.display.input.reset(true); }, 20); }\n\n registerEventHandlers(this);\n ensureGlobalHandlers();\n\n startOperation(this);\n this.curOp.forceUpdate = true;\n attachDoc(this, doc);\n\n if ((options.autofocus && !mobile) || this.hasFocus())\n { setTimeout(bind(onFocus, this), 20); }\n else\n { onBlur(this); }\n\n for (var opt in optionHandlers) { if (optionHandlers.hasOwnProperty(opt))\n { optionHandlers[opt](this$1, options[opt], Init); } }\n maybeUpdateLineNumberWidth(this);\n if (options.finishInit) { options.finishInit(this); }\n for (var i = 0; i < initHooks.length; ++i) { initHooks[i](this$1); }\n endOperation(this);\n // Suppress optimizelegibility in Webkit, since it breaks text\n // measuring on line wrapping boundaries.\n if (webkit && options.lineWrapping &&\n getComputedStyle(display.lineDiv).textRendering == \"optimizelegibility\")\n { display.lineDiv.style.textRendering = \"auto\"; }\n }\n\n // The default configuration options.\n CodeMirror.defaults = defaults;\n // Functions to run when options are changed.\n CodeMirror.optionHandlers = optionHandlers;\n\n // Attach the necessary event handlers when initializing the editor\n function registerEventHandlers(cm) {\n var d = cm.display;\n on(d.scroller, \"mousedown\", operation(cm, onMouseDown));\n // Older IE's will not fire a second mousedown for a double click\n if (ie && ie_version < 11)\n { on(d.scroller, \"dblclick\", operation(cm, function (e) {\n if (signalDOMEvent(cm, e)) { return }\n var pos = posFromMouse(cm, e);\n if (!pos || clickInGutter(cm, e) || eventInWidget(cm.display, e)) { return }\n e_preventDefault(e);\n var word = cm.findWordAt(pos);\n extendSelection(cm.doc, word.anchor, word.head);\n })); }\n else\n { on(d.scroller, \"dblclick\", function (e) { return signalDOMEvent(cm, e) || e_preventDefault(e); }); }\n // Some browsers fire contextmenu *after* opening the menu, at\n // which point we can't mess with it anymore. Context menu is\n // handled in onMouseDown for these browsers.\n on(d.scroller, \"contextmenu\", function (e) { return onContextMenu(cm, e); });\n\n // Used to suppress mouse event handling when a touch happens\n var touchFinished, prevTouch = {end: 0};\n function finishTouch() {\n if (d.activeTouch) {\n touchFinished = setTimeout(function () { return d.activeTouch = null; }, 1000);\n prevTouch = d.activeTouch;\n prevTouch.end = +new Date;\n }\n }\n function isMouseLikeTouchEvent(e) {\n if (e.touches.length != 1) { return false }\n var touch = e.touches[0];\n return touch.radiusX <= 1 && touch.radiusY <= 1\n }\n function farAway(touch, other) {\n if (other.left == null) { return true }\n var dx = other.left - touch.left, dy = other.top - touch.top;\n return dx * dx + dy * dy > 20 * 20\n }\n on(d.scroller, \"touchstart\", function (e) {\n if (!signalDOMEvent(cm, e) && !isMouseLikeTouchEvent(e) && !clickInGutter(cm, e)) {\n d.input.ensurePolled();\n clearTimeout(touchFinished);\n var now = +new Date;\n d.activeTouch = {start: now, moved: false,\n prev: now - prevTouch.end <= 300 ? prevTouch : null};\n if (e.touches.length == 1) {\n d.activeTouch.left = e.touches[0].pageX;\n d.activeTouch.top = e.touches[0].pageY;\n }\n }\n });\n on(d.scroller, \"touchmove\", function () {\n if (d.activeTouch) { d.activeTouch.moved = true; }\n });\n on(d.scroller, \"touchend\", function (e) {\n var touch = d.activeTouch;\n if (touch && !eventInWidget(d, e) && touch.left != null &&\n !touch.moved && new Date - touch.start < 300) {\n var pos = cm.coordsChar(d.activeTouch, \"page\"), range;\n if (!touch.prev || farAway(touch, touch.prev)) // Single tap\n { range = new Range(pos, pos); }\n else if (!touch.prev.prev || farAway(touch, touch.prev.prev)) // Double tap\n { range = cm.findWordAt(pos); }\n else // Triple tap\n { range = new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0))); }\n cm.setSelection(range.anchor, range.head);\n cm.focus();\n e_preventDefault(e);\n }\n finishTouch();\n });\n on(d.scroller, \"touchcancel\", finishTouch);\n\n // Sync scrolling between fake scrollbars and real scrollable\n // area, ensure viewport is updated when scrolling.\n on(d.scroller, \"scroll\", function () {\n if (d.scroller.clientHeight) {\n updateScrollTop(cm, d.scroller.scrollTop);\n setScrollLeft(cm, d.scroller.scrollLeft, true);\n signal(cm, \"scroll\", cm);\n }\n });\n\n // Listen to wheel events in order to try and update the viewport on time.\n on(d.scroller, \"mousewheel\", function (e) { return onScrollWheel(cm, e); });\n on(d.scroller, \"DOMMouseScroll\", function (e) { return onScrollWheel(cm, e); });\n\n // Prevent wrapper from ever scrolling\n on(d.wrapper, \"scroll\", function () { return d.wrapper.scrollTop = d.wrapper.scrollLeft = 0; });\n\n d.dragFunctions = {\n enter: function (e) {if (!signalDOMEvent(cm, e)) { e_stop(e); }},\n over: function (e) {if (!signalDOMEvent(cm, e)) { onDragOver(cm, e); e_stop(e); }},\n start: function (e) { return onDragStart(cm, e); },\n drop: operation(cm, onDrop),\n leave: function (e) {if (!signalDOMEvent(cm, e)) { clearDragCursor(cm); }}\n };\n\n var inp = d.input.getField();\n on(inp, \"keyup\", function (e) { return onKeyUp.call(cm, e); });\n on(inp, \"keydown\", operation(cm, onKeyDown));\n on(inp, \"keypress\", operation(cm, onKeyPress));\n on(inp, \"focus\", function (e) { return onFocus(cm, e); });\n on(inp, \"blur\", function (e) { return onBlur(cm, e); });\n }\n\n var initHooks = [];\n CodeMirror.defineInitHook = function (f) { return initHooks.push(f); };\n\n // Indent the given line. The how parameter can be \"smart\",\n // \"add\"/null, \"subtract\", or \"prev\". When aggressive is false\n // (typically set to true for forced single-line indents), empty\n // lines are not indented, and places where the mode returns Pass\n // are left alone.\n function indentLine(cm, n, how, aggressive) {\n var doc = cm.doc, state;\n if (how == null) { how = \"add\"; }\n if (how == \"smart\") {\n // Fall back to \"prev\" when the mode doesn't have an indentation\n // method.\n if (!doc.mode.indent) { how = \"prev\"; }\n else { state = getContextBefore(cm, n).state; }\n }\n\n var tabSize = cm.options.tabSize;\n var line = getLine(doc, n), curSpace = countColumn(line.text, null, tabSize);\n if (line.stateAfter) { line.stateAfter = null; }\n var curSpaceString = line.text.match(/^\\s*/)[0], indentation;\n if (!aggressive && !/\\S/.test(line.text)) {\n indentation = 0;\n how = \"not\";\n } else if (how == \"smart\") {\n indentation = doc.mode.indent(state, line.text.slice(curSpaceString.length), line.text);\n if (indentation == Pass || indentation > 150) {\n if (!aggressive) { return }\n how = \"prev\";\n }\n }\n if (how == \"prev\") {\n if (n > doc.first) { indentation = countColumn(getLine(doc, n-1).text, null, tabSize); }\n else { indentation = 0; }\n } else if (how == \"add\") {\n indentation = curSpace + cm.options.indentUnit;\n } else if (how == \"subtract\") {\n indentation = curSpace - cm.options.indentUnit;\n } else if (typeof how == \"number\") {\n indentation = curSpace + how;\n }\n indentation = Math.max(0, indentation);\n\n var indentString = \"\", pos = 0;\n if (cm.options.indentWithTabs)\n { for (var i = Math.floor(indentation / tabSize); i; --i) {pos += tabSize; indentString += \"\\t\";} }\n if (pos < indentation) { indentString += spaceStr(indentation - pos); }\n\n if (indentString != curSpaceString) {\n replaceRange(doc, indentString, Pos(n, 0), Pos(n, curSpaceString.length), \"+input\");\n line.stateAfter = null;\n return true\n } else {\n // Ensure that, if the cursor was in the whitespace at the start\n // of the line, it is moved to the end of that space.\n for (var i$1 = 0; i$1 < doc.sel.ranges.length; i$1++) {\n var range = doc.sel.ranges[i$1];\n if (range.head.line == n && range.head.ch < curSpaceString.length) {\n var pos$1 = Pos(n, curSpaceString.length);\n replaceOneSelection(doc, i$1, new Range(pos$1, pos$1));\n break\n }\n }\n }\n }\n\n // This will be set to a {lineWise: bool, text: [string]} object, so\n // that, when pasting, we know what kind of selections the copied\n // text was made out of.\n var lastCopied = null;\n\n function setLastCopied(newLastCopied) {\n lastCopied = newLastCopied;\n }\n\n function applyTextInput(cm, inserted, deleted, sel, origin) {\n var doc = cm.doc;\n cm.display.shift = false;\n if (!sel) { sel = doc.sel; }\n\n var paste = cm.state.pasteIncoming || origin == \"paste\";\n var textLines = splitLinesAuto(inserted), multiPaste = null;\n // When pasting N lines into N selections, insert one line per selection\n if (paste && sel.ranges.length > 1) {\n if (lastCopied && lastCopied.text.join(\"\\n\") == inserted) {\n if (sel.ranges.length % lastCopied.text.length == 0) {\n multiPaste = [];\n for (var i = 0; i < lastCopied.text.length; i++)\n { multiPaste.push(doc.splitLines(lastCopied.text[i])); }\n }\n } else if (textLines.length == sel.ranges.length && cm.options.pasteLinesPerSelection) {\n multiPaste = map(textLines, function (l) { return [l]; });\n }\n }\n\n var updateInput = cm.curOp.updateInput;\n // Normal behavior is to insert the new text into every selection\n for (var i$1 = sel.ranges.length - 1; i$1 >= 0; i$1--) {\n var range$$1 = sel.ranges[i$1];\n var from = range$$1.from(), to = range$$1.to();\n if (range$$1.empty()) {\n if (deleted && deleted > 0) // Handle deletion\n { from = Pos(from.line, from.ch - deleted); }\n else if (cm.state.overwrite && !paste) // Handle overwrite\n { to = Pos(to.line, Math.min(getLine(doc, to.line).text.length, to.ch + lst(textLines).length)); }\n else if (paste && lastCopied && lastCopied.lineWise && lastCopied.text.join(\"\\n\") == inserted)\n { from = to = Pos(from.line, 0); }\n }\n var changeEvent = {from: from, to: to, text: multiPaste ? multiPaste[i$1 % multiPaste.length] : textLines,\n origin: origin || (paste ? \"paste\" : cm.state.cutIncoming ? \"cut\" : \"+input\")};\n makeChange(cm.doc, changeEvent);\n signalLater(cm, \"inputRead\", cm, changeEvent);\n }\n if (inserted && !paste)\n { triggerElectric(cm, inserted); }\n\n ensureCursorVisible(cm);\n if (cm.curOp.updateInput < 2) { cm.curOp.updateInput = updateInput; }\n cm.curOp.typing = true;\n cm.state.pasteIncoming = cm.state.cutIncoming = false;\n }\n\n function handlePaste(e, cm) {\n var pasted = e.clipboardData && e.clipboardData.getData(\"Text\");\n if (pasted) {\n e.preventDefault();\n if (!cm.isReadOnly() && !cm.options.disableInput)\n { runInOp(cm, function () { return applyTextInput(cm, pasted, 0, null, \"paste\"); }); }\n return true\n }\n }\n\n function triggerElectric(cm, inserted) {\n // When an 'electric' character is inserted, immediately trigger a reindent\n if (!cm.options.electricChars || !cm.options.smartIndent) { return }\n var sel = cm.doc.sel;\n\n for (var i = sel.ranges.length - 1; i >= 0; i--) {\n var range$$1 = sel.ranges[i];\n if (range$$1.head.ch > 100 || (i && sel.ranges[i - 1].head.line == range$$1.head.line)) { continue }\n var mode = cm.getModeAt(range$$1.head);\n var indented = false;\n if (mode.electricChars) {\n for (var j = 0; j < mode.electricChars.length; j++)\n { if (inserted.indexOf(mode.electricChars.charAt(j)) > -1) {\n indented = indentLine(cm, range$$1.head.line, \"smart\");\n break\n } }\n } else if (mode.electricInput) {\n if (mode.electricInput.test(getLine(cm.doc, range$$1.head.line).text.slice(0, range$$1.head.ch)))\n { indented = indentLine(cm, range$$1.head.line, \"smart\"); }\n }\n if (indented) { signalLater(cm, \"electricInput\", cm, range$$1.head.line); }\n }\n }\n\n function copyableRanges(cm) {\n var text = [], ranges = [];\n for (var i = 0; i < cm.doc.sel.ranges.length; i++) {\n var line = cm.doc.sel.ranges[i].head.line;\n var lineRange = {anchor: Pos(line, 0), head: Pos(line + 1, 0)};\n ranges.push(lineRange);\n text.push(cm.getRange(lineRange.anchor, lineRange.head));\n }\n return {text: text, ranges: ranges}\n }\n\n function disableBrowserMagic(field, spellcheck) {\n field.setAttribute(\"autocorrect\", \"off\");\n field.setAttribute(\"autocapitalize\", \"off\");\n field.setAttribute(\"spellcheck\", !!spellcheck);\n }\n\n function hiddenTextarea() {\n var te = elt(\"textarea\", null, null, \"position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; outline: none\");\n var div = elt(\"div\", [te], null, \"overflow: hidden; position: relative; width: 3px; height: 0px;\");\n // The textarea is kept positioned near the cursor to prevent the\n // fact that it'll be scrolled into view on input from scrolling\n // our fake cursor out of view. On webkit, when wrap=off, paste is\n // very slow. So make the area wide instead.\n if (webkit) { te.style.width = \"1000px\"; }\n else { te.setAttribute(\"wrap\", \"off\"); }\n // If border: 0; -- iOS fails to open keyboard (issue #1287)\n if (ios) { te.style.border = \"1px solid black\"; }\n disableBrowserMagic(te);\n return div\n }\n\n // The publicly visible API. Note that methodOp(f) means\n // 'wrap f in an operation, performed on its `this` parameter'.\n\n // This is not the complete set of editor methods. Most of the\n // methods defined on the Doc type are also injected into\n // CodeMirror.prototype, for backwards compatibility and\n // convenience.\n\n function addEditorMethods(CodeMirror) {\n var optionHandlers = CodeMirror.optionHandlers;\n\n var helpers = CodeMirror.helpers = {};\n\n CodeMirror.prototype = {\n constructor: CodeMirror,\n focus: function(){window.focus(); this.display.input.focus();},\n\n setOption: function(option, value) {\n var options = this.options, old = options[option];\n if (options[option] == value && option != \"mode\") { return }\n options[option] = value;\n if (optionHandlers.hasOwnProperty(option))\n { operation(this, optionHandlers[option])(this, value, old); }\n signal(this, \"optionChange\", this, option);\n },\n\n getOption: function(option) {return this.options[option]},\n getDoc: function() {return this.doc},\n\n addKeyMap: function(map$$1, bottom) {\n this.state.keyMaps[bottom ? \"push\" : \"unshift\"](getKeyMap(map$$1));\n },\n removeKeyMap: function(map$$1) {\n var maps = this.state.keyMaps;\n for (var i = 0; i < maps.length; ++i)\n { if (maps[i] == map$$1 || maps[i].name == map$$1) {\n maps.splice(i, 1);\n return true\n } }\n },\n\n addOverlay: methodOp(function(spec, options) {\n var mode = spec.token ? spec : CodeMirror.getMode(this.options, spec);\n if (mode.startState) { throw new Error(\"Overlays may not be stateful.\") }\n insertSorted(this.state.overlays,\n {mode: mode, modeSpec: spec, opaque: options && options.opaque,\n priority: (options && options.priority) || 0},\n function (overlay) { return overlay.priority; });\n this.state.modeGen++;\n regChange(this);\n }),\n removeOverlay: methodOp(function(spec) {\n var this$1 = this;\n\n var overlays = this.state.overlays;\n for (var i = 0; i < overlays.length; ++i) {\n var cur = overlays[i].modeSpec;\n if (cur == spec || typeof spec == \"string\" && cur.name == spec) {\n overlays.splice(i, 1);\n this$1.state.modeGen++;\n regChange(this$1);\n return\n }\n }\n }),\n\n indentLine: methodOp(function(n, dir, aggressive) {\n if (typeof dir != \"string\" && typeof dir != \"number\") {\n if (dir == null) { dir = this.options.smartIndent ? \"smart\" : \"prev\"; }\n else { dir = dir ? \"add\" : \"subtract\"; }\n }\n if (isLine(this.doc, n)) { indentLine(this, n, dir, aggressive); }\n }),\n indentSelection: methodOp(function(how) {\n var this$1 = this;\n\n var ranges = this.doc.sel.ranges, end = -1;\n for (var i = 0; i < ranges.length; i++) {\n var range$$1 = ranges[i];\n if (!range$$1.empty()) {\n var from = range$$1.from(), to = range$$1.to();\n var start = Math.max(end, from.line);\n end = Math.min(this$1.lastLine(), to.line - (to.ch ? 0 : 1)) + 1;\n for (var j = start; j < end; ++j)\n { indentLine(this$1, j, how); }\n var newRanges = this$1.doc.sel.ranges;\n if (from.ch == 0 && ranges.length == newRanges.length && newRanges[i].from().ch > 0)\n { replaceOneSelection(this$1.doc, i, new Range(from, newRanges[i].to()), sel_dontScroll); }\n } else if (range$$1.head.line > end) {\n indentLine(this$1, range$$1.head.line, how, true);\n end = range$$1.head.line;\n if (i == this$1.doc.sel.primIndex) { ensureCursorVisible(this$1); }\n }\n }\n }),\n\n // Fetch the parser token for a given character. Useful for hacks\n // that want to inspect the mode state (say, for completion).\n getTokenAt: function(pos, precise) {\n return takeToken(this, pos, precise)\n },\n\n getLineTokens: function(line, precise) {\n return takeToken(this, Pos(line), precise, true)\n },\n\n getTokenTypeAt: function(pos) {\n pos = clipPos(this.doc, pos);\n var styles = getLineStyles(this, getLine(this.doc, pos.line));\n var before = 0, after = (styles.length - 1) / 2, ch = pos.ch;\n var type;\n if (ch == 0) { type = styles[2]; }\n else { for (;;) {\n var mid = (before + after) >> 1;\n if ((mid ? styles[mid * 2 - 1] : 0) >= ch) { after = mid; }\n else if (styles[mid * 2 + 1] < ch) { before = mid + 1; }\n else { type = styles[mid * 2 + 2]; break }\n } }\n var cut = type ? type.indexOf(\"overlay \") : -1;\n return cut < 0 ? type : cut == 0 ? null : type.slice(0, cut - 1)\n },\n\n getModeAt: function(pos) {\n var mode = this.doc.mode;\n if (!mode.innerMode) { return mode }\n return CodeMirror.innerMode(mode, this.getTokenAt(pos).state).mode\n },\n\n getHelper: function(pos, type) {\n return this.getHelpers(pos, type)[0]\n },\n\n getHelpers: function(pos, type) {\n var this$1 = this;\n\n var found = [];\n if (!helpers.hasOwnProperty(type)) { return found }\n var help = helpers[type], mode = this.getModeAt(pos);\n if (typeof mode[type] == \"string\") {\n if (help[mode[type]]) { found.push(help[mode[type]]); }\n } else if (mode[type]) {\n for (var i = 0; i < mode[type].length; i++) {\n var val = help[mode[type][i]];\n if (val) { found.push(val); }\n }\n } else if (mode.helperType && help[mode.helperType]) {\n found.push(help[mode.helperType]);\n } else if (help[mode.name]) {\n found.push(help[mode.name]);\n }\n for (var i$1 = 0; i$1 < help._global.length; i$1++) {\n var cur = help._global[i$1];\n if (cur.pred(mode, this$1) && indexOf(found, cur.val) == -1)\n { found.push(cur.val); }\n }\n return found\n },\n\n getStateAfter: function(line, precise) {\n var doc = this.doc;\n line = clipLine(doc, line == null ? doc.first + doc.size - 1: line);\n return getContextBefore(this, line + 1, precise).state\n },\n\n cursorCoords: function(start, mode) {\n var pos, range$$1 = this.doc.sel.primary();\n if (start == null) { pos = range$$1.head; }\n else if (typeof start == \"object\") { pos = clipPos(this.doc, start); }\n else { pos = start ? range$$1.from() : range$$1.to(); }\n return cursorCoords(this, pos, mode || \"page\")\n },\n\n charCoords: function(pos, mode) {\n return charCoords(this, clipPos(this.doc, pos), mode || \"page\")\n },\n\n coordsChar: function(coords, mode) {\n coords = fromCoordSystem(this, coords, mode || \"page\");\n return coordsChar(this, coords.left, coords.top)\n },\n\n lineAtHeight: function(height, mode) {\n height = fromCoordSystem(this, {top: height, left: 0}, mode || \"page\").top;\n return lineAtHeight(this.doc, height + this.display.viewOffset)\n },\n heightAtLine: function(line, mode, includeWidgets) {\n var end = false, lineObj;\n if (typeof line == \"number\") {\n var last = this.doc.first + this.doc.size - 1;\n if (line < this.doc.first) { line = this.doc.first; }\n else if (line > last) { line = last; end = true; }\n lineObj = getLine(this.doc, line);\n } else {\n lineObj = line;\n }\n return intoCoordSystem(this, lineObj, {top: 0, left: 0}, mode || \"page\", includeWidgets || end).top +\n (end ? this.doc.height - heightAtLine(lineObj) : 0)\n },\n\n defaultTextHeight: function() { return textHeight(this.display) },\n defaultCharWidth: function() { return charWidth(this.display) },\n\n getViewport: function() { return {from: this.display.viewFrom, to: this.display.viewTo}},\n\n addWidget: function(pos, node, scroll, vert, horiz) {\n var display = this.display;\n pos = cursorCoords(this, clipPos(this.doc, pos));\n var top = pos.bottom, left = pos.left;\n node.style.position = \"absolute\";\n node.setAttribute(\"cm-ignore-events\", \"true\");\n this.display.input.setUneditable(node);\n display.sizer.appendChild(node);\n if (vert == \"over\") {\n top = pos.top;\n } else if (vert == \"above\" || vert == \"near\") {\n var vspace = Math.max(display.wrapper.clientHeight, this.doc.height),\n hspace = Math.max(display.sizer.clientWidth, display.lineSpace.clientWidth);\n // Default to positioning above (if specified and possible); otherwise default to positioning below\n if ((vert == 'above' || pos.bottom + node.offsetHeight > vspace) && pos.top > node.offsetHeight)\n { top = pos.top - node.offsetHeight; }\n else if (pos.bottom + node.offsetHeight <= vspace)\n { top = pos.bottom; }\n if (left + node.offsetWidth > hspace)\n { left = hspace - node.offsetWidth; }\n }\n node.style.top = top + \"px\";\n node.style.left = node.style.right = \"\";\n if (horiz == \"right\") {\n left = display.sizer.clientWidth - node.offsetWidth;\n node.style.right = \"0px\";\n } else {\n if (horiz == \"left\") { left = 0; }\n else if (horiz == \"middle\") { left = (display.sizer.clientWidth - node.offsetWidth) / 2; }\n node.style.left = left + \"px\";\n }\n if (scroll)\n { scrollIntoView(this, {left: left, top: top, right: left + node.offsetWidth, bottom: top + node.offsetHeight}); }\n },\n\n triggerOnKeyDown: methodOp(onKeyDown),\n triggerOnKeyPress: methodOp(onKeyPress),\n triggerOnKeyUp: onKeyUp,\n triggerOnMouseDown: methodOp(onMouseDown),\n\n execCommand: function(cmd) {\n if (commands.hasOwnProperty(cmd))\n { return commands[cmd].call(null, this) }\n },\n\n triggerElectric: methodOp(function(text) { triggerElectric(this, text); }),\n\n findPosH: function(from, amount, unit, visually) {\n var this$1 = this;\n\n var dir = 1;\n if (amount < 0) { dir = -1; amount = -amount; }\n var cur = clipPos(this.doc, from);\n for (var i = 0; i < amount; ++i) {\n cur = findPosH(this$1.doc, cur, dir, unit, visually);\n if (cur.hitSide) { break }\n }\n return cur\n },\n\n moveH: methodOp(function(dir, unit) {\n var this$1 = this;\n\n this.extendSelectionsBy(function (range$$1) {\n if (this$1.display.shift || this$1.doc.extend || range$$1.empty())\n { return findPosH(this$1.doc, range$$1.head, dir, unit, this$1.options.rtlMoveVisually) }\n else\n { return dir < 0 ? range$$1.from() : range$$1.to() }\n }, sel_move);\n }),\n\n deleteH: methodOp(function(dir, unit) {\n var sel = this.doc.sel, doc = this.doc;\n if (sel.somethingSelected())\n { doc.replaceSelection(\"\", null, \"+delete\"); }\n else\n { deleteNearSelection(this, function (range$$1) {\n var other = findPosH(doc, range$$1.head, dir, unit, false);\n return dir < 0 ? {from: other, to: range$$1.head} : {from: range$$1.head, to: other}\n }); }\n }),\n\n findPosV: function(from, amount, unit, goalColumn) {\n var this$1 = this;\n\n var dir = 1, x = goalColumn;\n if (amount < 0) { dir = -1; amount = -amount; }\n var cur = clipPos(this.doc, from);\n for (var i = 0; i < amount; ++i) {\n var coords = cursorCoords(this$1, cur, \"div\");\n if (x == null) { x = coords.left; }\n else { coords.left = x; }\n cur = findPosV(this$1, coords, dir, unit);\n if (cur.hitSide) { break }\n }\n return cur\n },\n\n moveV: methodOp(function(dir, unit) {\n var this$1 = this;\n\n var doc = this.doc, goals = [];\n var collapse = !this.display.shift && !doc.extend && doc.sel.somethingSelected();\n doc.extendSelectionsBy(function (range$$1) {\n if (collapse)\n { return dir < 0 ? range$$1.from() : range$$1.to() }\n var headPos = cursorCoords(this$1, range$$1.head, \"div\");\n if (range$$1.goalColumn != null) { headPos.left = range$$1.goalColumn; }\n goals.push(headPos.left);\n var pos = findPosV(this$1, headPos, dir, unit);\n if (unit == \"page\" && range$$1 == doc.sel.primary())\n { addToScrollTop(this$1, charCoords(this$1, pos, \"div\").top - headPos.top); }\n return pos\n }, sel_move);\n if (goals.length) { for (var i = 0; i < doc.sel.ranges.length; i++)\n { doc.sel.ranges[i].goalColumn = goals[i]; } }\n }),\n\n // Find the word at the given position (as returned by coordsChar).\n findWordAt: function(pos) {\n var doc = this.doc, line = getLine(doc, pos.line).text;\n var start = pos.ch, end = pos.ch;\n if (line) {\n var helper = this.getHelper(pos, \"wordChars\");\n if ((pos.sticky == \"before\" || end == line.length) && start) { --start; } else { ++end; }\n var startChar = line.charAt(start);\n var check = isWordChar(startChar, helper)\n ? function (ch) { return isWordChar(ch, helper); }\n : /\\s/.test(startChar) ? function (ch) { return /\\s/.test(ch); }\n : function (ch) { return (!/\\s/.test(ch) && !isWordChar(ch)); };\n while (start > 0 && check(line.charAt(start - 1))) { --start; }\n while (end < line.length && check(line.charAt(end))) { ++end; }\n }\n return new Range(Pos(pos.line, start), Pos(pos.line, end))\n },\n\n toggleOverwrite: function(value) {\n if (value != null && value == this.state.overwrite) { return }\n if (this.state.overwrite = !this.state.overwrite)\n { addClass(this.display.cursorDiv, \"CodeMirror-overwrite\"); }\n else\n { rmClass(this.display.cursorDiv, \"CodeMirror-overwrite\"); }\n\n signal(this, \"overwriteToggle\", this, this.state.overwrite);\n },\n hasFocus: function() { return this.display.input.getField() == activeElt() },\n isReadOnly: function() { return !!(this.options.readOnly || this.doc.cantEdit) },\n\n scrollTo: methodOp(function (x, y) { scrollToCoords(this, x, y); }),\n getScrollInfo: function() {\n var scroller = this.display.scroller;\n return {left: scroller.scrollLeft, top: scroller.scrollTop,\n height: scroller.scrollHeight - scrollGap(this) - this.display.barHeight,\n width: scroller.scrollWidth - scrollGap(this) - this.display.barWidth,\n clientHeight: displayHeight(this), clientWidth: displayWidth(this)}\n },\n\n scrollIntoView: methodOp(function(range$$1, margin) {\n if (range$$1 == null) {\n range$$1 = {from: this.doc.sel.primary().head, to: null};\n if (margin == null) { margin = this.options.cursorScrollMargin; }\n } else if (typeof range$$1 == \"number\") {\n range$$1 = {from: Pos(range$$1, 0), to: null};\n } else if (range$$1.from == null) {\n range$$1 = {from: range$$1, to: null};\n }\n if (!range$$1.to) { range$$1.to = range$$1.from; }\n range$$1.margin = margin || 0;\n\n if (range$$1.from.line != null) {\n scrollToRange(this, range$$1);\n } else {\n scrollToCoordsRange(this, range$$1.from, range$$1.to, range$$1.margin);\n }\n }),\n\n setSize: methodOp(function(width, height) {\n var this$1 = this;\n\n var interpret = function (val) { return typeof val == \"number\" || /^\\d+$/.test(String(val)) ? val + \"px\" : val; };\n if (width != null) { this.display.wrapper.style.width = interpret(width); }\n if (height != null) { this.display.wrapper.style.height = interpret(height); }\n if (this.options.lineWrapping) { clearLineMeasurementCache(this); }\n var lineNo$$1 = this.display.viewFrom;\n this.doc.iter(lineNo$$1, this.display.viewTo, function (line) {\n if (line.widgets) { for (var i = 0; i < line.widgets.length; i++)\n { if (line.widgets[i].noHScroll) { regLineChange(this$1, lineNo$$1, \"widget\"); break } } }\n ++lineNo$$1;\n });\n this.curOp.forceUpdate = true;\n signal(this, \"refresh\", this);\n }),\n\n operation: function(f){return runInOp(this, f)},\n startOperation: function(){return startOperation(this)},\n endOperation: function(){return endOperation(this)},\n\n refresh: methodOp(function() {\n var oldHeight = this.display.cachedTextHeight;\n regChange(this);\n this.curOp.forceUpdate = true;\n clearCaches(this);\n scrollToCoords(this, this.doc.scrollLeft, this.doc.scrollTop);\n updateGutterSpace(this);\n if (oldHeight == null || Math.abs(oldHeight - textHeight(this.display)) > .5)\n { estimateLineHeights(this); }\n signal(this, \"refresh\", this);\n }),\n\n swapDoc: methodOp(function(doc) {\n var old = this.doc;\n old.cm = null;\n attachDoc(this, doc);\n clearCaches(this);\n this.display.input.reset();\n scrollToCoords(this, doc.scrollLeft, doc.scrollTop);\n this.curOp.forceScroll = true;\n signalLater(this, \"swapDoc\", this, old);\n return old\n }),\n\n phrase: function(phraseText) {\n var phrases = this.options.phrases;\n return phrases && Object.prototype.hasOwnProperty.call(phrases, phraseText) ? phrases[phraseText] : phraseText\n },\n\n getInputField: function(){return this.display.input.getField()},\n getWrapperElement: function(){return this.display.wrapper},\n getScrollerElement: function(){return this.display.scroller},\n getGutterElement: function(){return this.display.gutters}\n };\n eventMixin(CodeMirror);\n\n CodeMirror.registerHelper = function(type, name, value) {\n if (!helpers.hasOwnProperty(type)) { helpers[type] = CodeMirror[type] = {_global: []}; }\n helpers[type][name] = value;\n };\n CodeMirror.registerGlobalHelper = function(type, name, predicate, value) {\n CodeMirror.registerHelper(type, name, value);\n helpers[type]._global.push({pred: predicate, val: value});\n };\n }\n\n // Used for horizontal relative motion. Dir is -1 or 1 (left or\n // right), unit can be \"char\", \"column\" (like char, but doesn't\n // cross line boundaries), \"word\" (across next word), or \"group\" (to\n // the start of next group of word or non-word-non-whitespace\n // chars). The visually param controls whether, in right-to-left\n // text, direction 1 means to move towards the next index in the\n // string, or towards the character to the right of the current\n // position. The resulting position will have a hitSide=true\n // property if it reached the end of the document.\n function findPosH(doc, pos, dir, unit, visually) {\n var oldPos = pos;\n var origDir = dir;\n var lineObj = getLine(doc, pos.line);\n function findNextLine() {\n var l = pos.line + dir;\n if (l < doc.first || l >= doc.first + doc.size) { return false }\n pos = new Pos(l, pos.ch, pos.sticky);\n return lineObj = getLine(doc, l)\n }\n function moveOnce(boundToLine) {\n var next;\n if (visually) {\n next = moveVisually(doc.cm, lineObj, pos, dir);\n } else {\n next = moveLogically(lineObj, pos, dir);\n }\n if (next == null) {\n if (!boundToLine && findNextLine())\n { pos = endOfLine(visually, doc.cm, lineObj, pos.line, dir); }\n else\n { return false }\n } else {\n pos = next;\n }\n return true\n }\n\n if (unit == \"char\") {\n moveOnce();\n } else if (unit == \"column\") {\n moveOnce(true);\n } else if (unit == \"word\" || unit == \"group\") {\n var sawType = null, group = unit == \"group\";\n var helper = doc.cm && doc.cm.getHelper(pos, \"wordChars\");\n for (var first = true;; first = false) {\n if (dir < 0 && !moveOnce(!first)) { break }\n var cur = lineObj.text.charAt(pos.ch) || \"\\n\";\n var type = isWordChar(cur, helper) ? \"w\"\n : group && cur == \"\\n\" ? \"n\"\n : !group || /\\s/.test(cur) ? null\n : \"p\";\n if (group && !first && !type) { type = \"s\"; }\n if (sawType && sawType != type) {\n if (dir < 0) {dir = 1; moveOnce(); pos.sticky = \"after\";}\n break\n }\n\n if (type) { sawType = type; }\n if (dir > 0 && !moveOnce(!first)) { break }\n }\n }\n var result = skipAtomic(doc, pos, oldPos, origDir, true);\n if (equalCursorPos(oldPos, result)) { result.hitSide = true; }\n return result\n }\n\n // For relative vertical movement. Dir may be -1 or 1. Unit can be\n // \"page\" or \"line\". The resulting position will have a hitSide=true\n // property if it reached the end of the document.\n function findPosV(cm, pos, dir, unit) {\n var doc = cm.doc, x = pos.left, y;\n if (unit == \"page\") {\n var pageSize = Math.min(cm.display.wrapper.clientHeight, window.innerHeight || document.documentElement.clientHeight);\n var moveAmount = Math.max(pageSize - .5 * textHeight(cm.display), 3);\n y = (dir > 0 ? pos.bottom : pos.top) + dir * moveAmount;\n\n } else if (unit == \"line\") {\n y = dir > 0 ? pos.bottom + 3 : pos.top - 3;\n }\n var target;\n for (;;) {\n target = coordsChar(cm, x, y);\n if (!target.outside) { break }\n if (dir < 0 ? y <= 0 : y >= doc.height) { target.hitSide = true; break }\n y += dir * 5;\n }\n return target\n }\n\n // CONTENTEDITABLE INPUT STYLE\n\n var ContentEditableInput = function(cm) {\n this.cm = cm;\n this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null;\n this.polling = new Delayed();\n this.composing = null;\n this.gracePeriod = false;\n this.readDOMTimeout = null;\n };\n\n ContentEditableInput.prototype.init = function (display) {\n var this$1 = this;\n\n var input = this, cm = input.cm;\n var div = input.div = display.lineDiv;\n disableBrowserMagic(div, cm.options.spellcheck);\n\n on(div, \"paste\", function (e) {\n if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return }\n // IE doesn't fire input events, so we schedule a read for the pasted content in this way\n if (ie_version <= 11) { setTimeout(operation(cm, function () { return this$1.updateFromDOM(); }), 20); }\n });\n\n on(div, \"compositionstart\", function (e) {\n this$1.composing = {data: e.data, done: false};\n });\n on(div, \"compositionupdate\", function (e) {\n if (!this$1.composing) { this$1.composing = {data: e.data, done: false}; }\n });\n on(div, \"compositionend\", function (e) {\n if (this$1.composing) {\n if (e.data != this$1.composing.data) { this$1.readFromDOMSoon(); }\n this$1.composing.done = true;\n }\n });\n\n on(div, \"touchstart\", function () { return input.forceCompositionEnd(); });\n\n on(div, \"input\", function () {\n if (!this$1.composing) { this$1.readFromDOMSoon(); }\n });\n\n function onCopyCut(e) {\n if (signalDOMEvent(cm, e)) { return }\n if (cm.somethingSelected()) {\n setLastCopied({lineWise: false, text: cm.getSelections()});\n if (e.type == \"cut\") { cm.replaceSelection(\"\", null, \"cut\"); }\n } else if (!cm.options.lineWiseCopyCut) {\n return\n } else {\n var ranges = copyableRanges(cm);\n setLastCopied({lineWise: true, text: ranges.text});\n if (e.type == \"cut\") {\n cm.operation(function () {\n cm.setSelections(ranges.ranges, 0, sel_dontScroll);\n cm.replaceSelection(\"\", null, \"cut\");\n });\n }\n }\n if (e.clipboardData) {\n e.clipboardData.clearData();\n var content = lastCopied.text.join(\"\\n\");\n // iOS exposes the clipboard API, but seems to discard content inserted into it\n e.clipboardData.setData(\"Text\", content);\n if (e.clipboardData.getData(\"Text\") == content) {\n e.preventDefault();\n return\n }\n }\n // Old-fashioned briefly-focus-a-textarea hack\n var kludge = hiddenTextarea(), te = kludge.firstChild;\n cm.display.lineSpace.insertBefore(kludge, cm.display.lineSpace.firstChild);\n te.value = lastCopied.text.join(\"\\n\");\n var hadFocus = document.activeElement;\n selectInput(te);\n setTimeout(function () {\n cm.display.lineSpace.removeChild(kludge);\n hadFocus.focus();\n if (hadFocus == div) { input.showPrimarySelection(); }\n }, 50);\n }\n on(div, \"copy\", onCopyCut);\n on(div, \"cut\", onCopyCut);\n };\n\n ContentEditableInput.prototype.prepareSelection = function () {\n var result = prepareSelection(this.cm, false);\n result.focus = this.cm.state.focused;\n return result\n };\n\n ContentEditableInput.prototype.showSelection = function (info, takeFocus) {\n if (!info || !this.cm.display.view.length) { return }\n if (info.focus || takeFocus) { this.showPrimarySelection(); }\n this.showMultipleSelections(info);\n };\n\n ContentEditableInput.prototype.getSelection = function () {\n return this.cm.display.wrapper.ownerDocument.getSelection()\n };\n\n ContentEditableInput.prototype.showPrimarySelection = function () {\n var sel = this.getSelection(), cm = this.cm, prim = cm.doc.sel.primary();\n var from = prim.from(), to = prim.to();\n\n if (cm.display.viewTo == cm.display.viewFrom || from.line >= cm.display.viewTo || to.line < cm.display.viewFrom) {\n sel.removeAllRanges();\n return\n }\n\n var curAnchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);\n var curFocus = domToPos(cm, sel.focusNode, sel.focusOffset);\n if (curAnchor && !curAnchor.bad && curFocus && !curFocus.bad &&\n cmp(minPos(curAnchor, curFocus), from) == 0 &&\n cmp(maxPos(curAnchor, curFocus), to) == 0)\n { return }\n\n var view = cm.display.view;\n var start = (from.line >= cm.display.viewFrom && posToDOM(cm, from)) ||\n {node: view[0].measure.map[2], offset: 0};\n var end = to.line < cm.display.viewTo && posToDOM(cm, to);\n if (!end) {\n var measure = view[view.length - 1].measure;\n var map$$1 = measure.maps ? measure.maps[measure.maps.length - 1] : measure.map;\n end = {node: map$$1[map$$1.length - 1], offset: map$$1[map$$1.length - 2] - map$$1[map$$1.length - 3]};\n }\n\n if (!start || !end) {\n sel.removeAllRanges();\n return\n }\n\n var old = sel.rangeCount && sel.getRangeAt(0), rng;\n try { rng = range(start.node, start.offset, end.offset, end.node); }\n catch(e) {} // Our model of the DOM might be outdated, in which case the range we try to set can be impossible\n if (rng) {\n if (!gecko && cm.state.focused) {\n sel.collapse(start.node, start.offset);\n if (!rng.collapsed) {\n sel.removeAllRanges();\n sel.addRange(rng);\n }\n } else {\n sel.removeAllRanges();\n sel.addRange(rng);\n }\n if (old && sel.anchorNode == null) { sel.addRange(old); }\n else if (gecko) { this.startGracePeriod(); }\n }\n this.rememberSelection();\n };\n\n ContentEditableInput.prototype.startGracePeriod = function () {\n var this$1 = this;\n\n clearTimeout(this.gracePeriod);\n this.gracePeriod = setTimeout(function () {\n this$1.gracePeriod = false;\n if (this$1.selectionChanged())\n { this$1.cm.operation(function () { return this$1.cm.curOp.selectionChanged = true; }); }\n }, 20);\n };\n\n ContentEditableInput.prototype.showMultipleSelections = function (info) {\n removeChildrenAndAdd(this.cm.display.cursorDiv, info.cursors);\n removeChildrenAndAdd(this.cm.display.selectionDiv, info.selection);\n };\n\n ContentEditableInput.prototype.rememberSelection = function () {\n var sel = this.getSelection();\n this.lastAnchorNode = sel.anchorNode; this.lastAnchorOffset = sel.anchorOffset;\n this.lastFocusNode = sel.focusNode; this.lastFocusOffset = sel.focusOffset;\n };\n\n ContentEditableInput.prototype.selectionInEditor = function () {\n var sel = this.getSelection();\n if (!sel.rangeCount) { return false }\n var node = sel.getRangeAt(0).commonAncestorContainer;\n return contains(this.div, node)\n };\n\n ContentEditableInput.prototype.focus = function () {\n if (this.cm.options.readOnly != \"nocursor\") {\n if (!this.selectionInEditor())\n { this.showSelection(this.prepareSelection(), true); }\n this.div.focus();\n }\n };\n ContentEditableInput.prototype.blur = function () { this.div.blur(); };\n ContentEditableInput.prototype.getField = function () { return this.div };\n\n ContentEditableInput.prototype.supportsTouch = function () { return true };\n\n ContentEditableInput.prototype.receivedFocus = function () {\n var input = this;\n if (this.selectionInEditor())\n { this.pollSelection(); }\n else\n { runInOp(this.cm, function () { return input.cm.curOp.selectionChanged = true; }); }\n\n function poll() {\n if (input.cm.state.focused) {\n input.pollSelection();\n input.polling.set(input.cm.options.pollInterval, poll);\n }\n }\n this.polling.set(this.cm.options.pollInterval, poll);\n };\n\n ContentEditableInput.prototype.selectionChanged = function () {\n var sel = this.getSelection();\n return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset ||\n sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset\n };\n\n ContentEditableInput.prototype.pollSelection = function () {\n if (this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged()) { return }\n var sel = this.getSelection(), cm = this.cm;\n // On Android Chrome (version 56, at least), backspacing into an\n // uneditable block element will put the cursor in that element,\n // and then, because it's not editable, hide the virtual keyboard.\n // Because Android doesn't allow us to actually detect backspace\n // presses in a sane way, this code checks for when that happens\n // and simulates a backspace press in this case.\n if (android && chrome && this.cm.options.gutters.length && isInGutter(sel.anchorNode)) {\n this.cm.triggerOnKeyDown({type: \"keydown\", keyCode: 8, preventDefault: Math.abs});\n this.blur();\n this.focus();\n return\n }\n if (this.composing) { return }\n this.rememberSelection();\n var anchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);\n var head = domToPos(cm, sel.focusNode, sel.focusOffset);\n if (anchor && head) { runInOp(cm, function () {\n setSelection(cm.doc, simpleSelection(anchor, head), sel_dontScroll);\n if (anchor.bad || head.bad) { cm.curOp.selectionChanged = true; }\n }); }\n };\n\n ContentEditableInput.prototype.pollContent = function () {\n if (this.readDOMTimeout != null) {\n clearTimeout(this.readDOMTimeout);\n this.readDOMTimeout = null;\n }\n\n var cm = this.cm, display = cm.display, sel = cm.doc.sel.primary();\n var from = sel.from(), to = sel.to();\n if (from.ch == 0 && from.line > cm.firstLine())\n { from = Pos(from.line - 1, getLine(cm.doc, from.line - 1).length); }\n if (to.ch == getLine(cm.doc, to.line).text.length && to.line < cm.lastLine())\n { to = Pos(to.line + 1, 0); }\n if (from.line < display.viewFrom || to.line > display.viewTo - 1) { return false }\n\n var fromIndex, fromLine, fromNode;\n if (from.line == display.viewFrom || (fromIndex = findViewIndex(cm, from.line)) == 0) {\n fromLine = lineNo(display.view[0].line);\n fromNode = display.view[0].node;\n } else {\n fromLine = lineNo(display.view[fromIndex].line);\n fromNode = display.view[fromIndex - 1].node.nextSibling;\n }\n var toIndex = findViewIndex(cm, to.line);\n var toLine, toNode;\n if (toIndex == display.view.length - 1) {\n toLine = display.viewTo - 1;\n toNode = display.lineDiv.lastChild;\n } else {\n toLine = lineNo(display.view[toIndex + 1].line) - 1;\n toNode = display.view[toIndex + 1].node.previousSibling;\n }\n\n if (!fromNode) { return false }\n var newText = cm.doc.splitLines(domTextBetween(cm, fromNode, toNode, fromLine, toLine));\n var oldText = getBetween(cm.doc, Pos(fromLine, 0), Pos(toLine, getLine(cm.doc, toLine).text.length));\n while (newText.length > 1 && oldText.length > 1) {\n if (lst(newText) == lst(oldText)) { newText.pop(); oldText.pop(); toLine--; }\n else if (newText[0] == oldText[0]) { newText.shift(); oldText.shift(); fromLine++; }\n else { break }\n }\n\n var cutFront = 0, cutEnd = 0;\n var newTop = newText[0], oldTop = oldText[0], maxCutFront = Math.min(newTop.length, oldTop.length);\n while (cutFront < maxCutFront && newTop.charCodeAt(cutFront) == oldTop.charCodeAt(cutFront))\n { ++cutFront; }\n var newBot = lst(newText), oldBot = lst(oldText);\n var maxCutEnd = Math.min(newBot.length - (newText.length == 1 ? cutFront : 0),\n oldBot.length - (oldText.length == 1 ? cutFront : 0));\n while (cutEnd < maxCutEnd &&\n newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1))\n { ++cutEnd; }\n // Try to move start of change to start of selection if ambiguous\n if (newText.length == 1 && oldText.length == 1 && fromLine == from.line) {\n while (cutFront && cutFront > from.ch &&\n newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) {\n cutFront--;\n cutEnd++;\n }\n }\n\n newText[newText.length - 1] = newBot.slice(0, newBot.length - cutEnd).replace(/^\\u200b+/, \"\");\n newText[0] = newText[0].slice(cutFront).replace(/\\u200b+$/, \"\");\n\n var chFrom = Pos(fromLine, cutFront);\n var chTo = Pos(toLine, oldText.length ? lst(oldText).length - cutEnd : 0);\n if (newText.length > 1 || newText[0] || cmp(chFrom, chTo)) {\n replaceRange(cm.doc, newText, chFrom, chTo, \"+input\");\n return true\n }\n };\n\n ContentEditableInput.prototype.ensurePolled = function () {\n this.forceCompositionEnd();\n };\n ContentEditableInput.prototype.reset = function () {\n this.forceCompositionEnd();\n };\n ContentEditableInput.prototype.forceCompositionEnd = function () {\n if (!this.composing) { return }\n clearTimeout(this.readDOMTimeout);\n this.composing = null;\n this.updateFromDOM();\n this.div.blur();\n this.div.focus();\n };\n ContentEditableInput.prototype.readFromDOMSoon = function () {\n var this$1 = this;\n\n if (this.readDOMTimeout != null) { return }\n this.readDOMTimeout = setTimeout(function () {\n this$1.readDOMTimeout = null;\n if (this$1.composing) {\n if (this$1.composing.done) { this$1.composing = null; }\n else { return }\n }\n this$1.updateFromDOM();\n }, 80);\n };\n\n ContentEditableInput.prototype.updateFromDOM = function () {\n var this$1 = this;\n\n if (this.cm.isReadOnly() || !this.pollContent())\n { runInOp(this.cm, function () { return regChange(this$1.cm); }); }\n };\n\n ContentEditableInput.prototype.setUneditable = function (node) {\n node.contentEditable = \"false\";\n };\n\n ContentEditableInput.prototype.onKeyPress = function (e) {\n if (e.charCode == 0 || this.composing) { return }\n e.preventDefault();\n if (!this.cm.isReadOnly())\n { operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0); }\n };\n\n ContentEditableInput.prototype.readOnlyChanged = function (val) {\n this.div.contentEditable = String(val != \"nocursor\");\n };\n\n ContentEditableInput.prototype.onContextMenu = function () {};\n ContentEditableInput.prototype.resetPosition = function () {};\n\n ContentEditableInput.prototype.needsContentAttribute = true;\n\n function posToDOM(cm, pos) {\n var view = findViewForLine(cm, pos.line);\n if (!view || view.hidden) { return null }\n var line = getLine(cm.doc, pos.line);\n var info = mapFromLineView(view, line, pos.line);\n\n var order = getOrder(line, cm.doc.direction), side = \"left\";\n if (order) {\n var partPos = getBidiPartAt(order, pos.ch);\n side = partPos % 2 ? \"right\" : \"left\";\n }\n var result = nodeAndOffsetInLineMap(info.map, pos.ch, side);\n result.offset = result.collapse == \"right\" ? result.end : result.start;\n return result\n }\n\n function isInGutter(node) {\n for (var scan = node; scan; scan = scan.parentNode)\n { if (/CodeMirror-gutter-wrapper/.test(scan.className)) { return true } }\n return false\n }\n\n function badPos(pos, bad) { if (bad) { pos.bad = true; } return pos }\n\n function domTextBetween(cm, from, to, fromLine, toLine) {\n var text = \"\", closing = false, lineSep = cm.doc.lineSeparator(), extraLinebreak = false;\n function recognizeMarker(id) { return function (marker) { return marker.id == id; } }\n function close() {\n if (closing) {\n text += lineSep;\n if (extraLinebreak) { text += lineSep; }\n closing = extraLinebreak = false;\n }\n }\n function addText(str) {\n if (str) {\n close();\n text += str;\n }\n }\n function walk(node) {\n if (node.nodeType == 1) {\n var cmText = node.getAttribute(\"cm-text\");\n if (cmText) {\n addText(cmText);\n return\n }\n var markerID = node.getAttribute(\"cm-marker\"), range$$1;\n if (markerID) {\n var found = cm.findMarks(Pos(fromLine, 0), Pos(toLine + 1, 0), recognizeMarker(+markerID));\n if (found.length && (range$$1 = found[0].find(0)))\n { addText(getBetween(cm.doc, range$$1.from, range$$1.to).join(lineSep)); }\n return\n }\n if (node.getAttribute(\"contenteditable\") == \"false\") { return }\n var isBlock = /^(pre|div|p|li|table|br)$/i.test(node.nodeName);\n if (!/^br$/i.test(node.nodeName) && node.textContent.length == 0) { return }\n\n if (isBlock) { close(); }\n for (var i = 0; i < node.childNodes.length; i++)\n { walk(node.childNodes[i]); }\n\n if (/^(pre|p)$/i.test(node.nodeName)) { extraLinebreak = true; }\n if (isBlock) { closing = true; }\n } else if (node.nodeType == 3) {\n addText(node.nodeValue.replace(/\\u200b/g, \"\").replace(/\\u00a0/g, \" \"));\n }\n }\n for (;;) {\n walk(from);\n if (from == to) { break }\n from = from.nextSibling;\n extraLinebreak = false;\n }\n return text\n }\n\n function domToPos(cm, node, offset) {\n var lineNode;\n if (node == cm.display.lineDiv) {\n lineNode = cm.display.lineDiv.childNodes[offset];\n if (!lineNode) { return badPos(cm.clipPos(Pos(cm.display.viewTo - 1)), true) }\n node = null; offset = 0;\n } else {\n for (lineNode = node;; lineNode = lineNode.parentNode) {\n if (!lineNode || lineNode == cm.display.lineDiv) { return null }\n if (lineNode.parentNode && lineNode.parentNode == cm.display.lineDiv) { break }\n }\n }\n for (var i = 0; i < cm.display.view.length; i++) {\n var lineView = cm.display.view[i];\n if (lineView.node == lineNode)\n { return locateNodeInLineView(lineView, node, offset) }\n }\n }\n\n function locateNodeInLineView(lineView, node, offset) {\n var wrapper = lineView.text.firstChild, bad = false;\n if (!node || !contains(wrapper, node)) { return badPos(Pos(lineNo(lineView.line), 0), true) }\n if (node == wrapper) {\n bad = true;\n node = wrapper.childNodes[offset];\n offset = 0;\n if (!node) {\n var line = lineView.rest ? lst(lineView.rest) : lineView.line;\n return badPos(Pos(lineNo(line), line.text.length), bad)\n }\n }\n\n var textNode = node.nodeType == 3 ? node : null, topNode = node;\n if (!textNode && node.childNodes.length == 1 && node.firstChild.nodeType == 3) {\n textNode = node.firstChild;\n if (offset) { offset = textNode.nodeValue.length; }\n }\n while (topNode.parentNode != wrapper) { topNode = topNode.parentNode; }\n var measure = lineView.measure, maps = measure.maps;\n\n function find(textNode, topNode, offset) {\n for (var i = -1; i < (maps ? maps.length : 0); i++) {\n var map$$1 = i < 0 ? measure.map : maps[i];\n for (var j = 0; j < map$$1.length; j += 3) {\n var curNode = map$$1[j + 2];\n if (curNode == textNode || curNode == topNode) {\n var line = lineNo(i < 0 ? lineView.line : lineView.rest[i]);\n var ch = map$$1[j] + offset;\n if (offset < 0 || curNode != textNode) { ch = map$$1[j + (offset ? 1 : 0)]; }\n return Pos(line, ch)\n }\n }\n }\n }\n var found = find(textNode, topNode, offset);\n if (found) { return badPos(found, bad) }\n\n // FIXME this is all really shaky. might handle the few cases it needs to handle, but likely to cause problems\n for (var after = topNode.nextSibling, dist = textNode ? textNode.nodeValue.length - offset : 0; after; after = after.nextSibling) {\n found = find(after, after.firstChild, 0);\n if (found)\n { return badPos(Pos(found.line, found.ch - dist), bad) }\n else\n { dist += after.textContent.length; }\n }\n for (var before = topNode.previousSibling, dist$1 = offset; before; before = before.previousSibling) {\n found = find(before, before.firstChild, -1);\n if (found)\n { return badPos(Pos(found.line, found.ch + dist$1), bad) }\n else\n { dist$1 += before.textContent.length; }\n }\n }\n\n // TEXTAREA INPUT STYLE\n\n var TextareaInput = function(cm) {\n this.cm = cm;\n // See input.poll and input.reset\n this.prevInput = \"\";\n\n // Flag that indicates whether we expect input to appear real soon\n // now (after some event like 'keypress' or 'input') and are\n // polling intensively.\n this.pollingFast = false;\n // Self-resetting timeout for the poller\n this.polling = new Delayed();\n // Used to work around IE issue with selection being forgotten when focus moves away from textarea\n this.hasSelection = false;\n this.composing = null;\n };\n\n TextareaInput.prototype.init = function (display) {\n var this$1 = this;\n\n var input = this, cm = this.cm;\n this.createField(display);\n var te = this.textarea;\n\n display.wrapper.insertBefore(this.wrapper, display.wrapper.firstChild);\n\n // Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore)\n if (ios) { te.style.width = \"0px\"; }\n\n on(te, \"input\", function () {\n if (ie && ie_version >= 9 && this$1.hasSelection) { this$1.hasSelection = null; }\n input.poll();\n });\n\n on(te, \"paste\", function (e) {\n if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return }\n\n cm.state.pasteIncoming = true;\n input.fastPoll();\n });\n\n function prepareCopyCut(e) {\n if (signalDOMEvent(cm, e)) { return }\n if (cm.somethingSelected()) {\n setLastCopied({lineWise: false, text: cm.getSelections()});\n } else if (!cm.options.lineWiseCopyCut) {\n return\n } else {\n var ranges = copyableRanges(cm);\n setLastCopied({lineWise: true, text: ranges.text});\n if (e.type == \"cut\") {\n cm.setSelections(ranges.ranges, null, sel_dontScroll);\n } else {\n input.prevInput = \"\";\n te.value = ranges.text.join(\"\\n\");\n selectInput(te);\n }\n }\n if (e.type == \"cut\") { cm.state.cutIncoming = true; }\n }\n on(te, \"cut\", prepareCopyCut);\n on(te, \"copy\", prepareCopyCut);\n\n on(display.scroller, \"paste\", function (e) {\n if (eventInWidget(display, e) || signalDOMEvent(cm, e)) { return }\n cm.state.pasteIncoming = true;\n input.focus();\n });\n\n // Prevent normal selection in the editor (we handle our own)\n on(display.lineSpace, \"selectstart\", function (e) {\n if (!eventInWidget(display, e)) { e_preventDefault(e); }\n });\n\n on(te, \"compositionstart\", function () {\n var start = cm.getCursor(\"from\");\n if (input.composing) { input.composing.range.clear(); }\n input.composing = {\n start: start,\n range: cm.markText(start, cm.getCursor(\"to\"), {className: \"CodeMirror-composing\"})\n };\n });\n on(te, \"compositionend\", function () {\n if (input.composing) {\n input.poll();\n input.composing.range.clear();\n input.composing = null;\n }\n });\n };\n\n TextareaInput.prototype.createField = function (_display) {\n // Wraps and hides input textarea\n this.wrapper = hiddenTextarea();\n // The semihidden textarea that is focused when the editor is\n // focused, and receives input.\n this.textarea = this.wrapper.firstChild;\n };\n\n TextareaInput.prototype.prepareSelection = function () {\n // Redraw the selection and/or cursor\n var cm = this.cm, display = cm.display, doc = cm.doc;\n var result = prepareSelection(cm);\n\n // Move the hidden textarea near the cursor to prevent scrolling artifacts\n if (cm.options.moveInputWithCursor) {\n var headPos = cursorCoords(cm, doc.sel.primary().head, \"div\");\n var wrapOff = display.wrapper.getBoundingClientRect(), lineOff = display.lineDiv.getBoundingClientRect();\n result.teTop = Math.max(0, Math.min(display.wrapper.clientHeight - 10,\n headPos.top + lineOff.top - wrapOff.top));\n result.teLeft = Math.max(0, Math.min(display.wrapper.clientWidth - 10,\n headPos.left + lineOff.left - wrapOff.left));\n }\n\n return result\n };\n\n TextareaInput.prototype.showSelection = function (drawn) {\n var cm = this.cm, display = cm.display;\n removeChildrenAndAdd(display.cursorDiv, drawn.cursors);\n removeChildrenAndAdd(display.selectionDiv, drawn.selection);\n if (drawn.teTop != null) {\n this.wrapper.style.top = drawn.teTop + \"px\";\n this.wrapper.style.left = drawn.teLeft + \"px\";\n }\n };\n\n // Reset the input to correspond to the selection (or to be empty,\n // when not typing and nothing is selected)\n TextareaInput.prototype.reset = function (typing) {\n if (this.contextMenuPending || this.composing) { return }\n var cm = this.cm;\n if (cm.somethingSelected()) {\n this.prevInput = \"\";\n var content = cm.getSelection();\n this.textarea.value = content;\n if (cm.state.focused) { selectInput(this.textarea); }\n if (ie && ie_version >= 9) { this.hasSelection = content; }\n } else if (!typing) {\n this.prevInput = this.textarea.value = \"\";\n if (ie && ie_version >= 9) { this.hasSelection = null; }\n }\n };\n\n TextareaInput.prototype.getField = function () { return this.textarea };\n\n TextareaInput.prototype.supportsTouch = function () { return false };\n\n TextareaInput.prototype.focus = function () {\n if (this.cm.options.readOnly != \"nocursor\" && (!mobile || activeElt() != this.textarea)) {\n try { this.textarea.focus(); }\n catch (e) {} // IE8 will throw if the textarea is display: none or not in DOM\n }\n };\n\n TextareaInput.prototype.blur = function () { this.textarea.blur(); };\n\n TextareaInput.prototype.resetPosition = function () {\n this.wrapper.style.top = this.wrapper.style.left = 0;\n };\n\n TextareaInput.prototype.receivedFocus = function () { this.slowPoll(); };\n\n // Poll for input changes, using the normal rate of polling. This\n // runs as long as the editor is focused.\n TextareaInput.prototype.slowPoll = function () {\n var this$1 = this;\n\n if (this.pollingFast) { return }\n this.polling.set(this.cm.options.pollInterval, function () {\n this$1.poll();\n if (this$1.cm.state.focused) { this$1.slowPoll(); }\n });\n };\n\n // When an event has just come in that is likely to add or change\n // something in the input textarea, we poll faster, to ensure that\n // the change appears on the screen quickly.\n TextareaInput.prototype.fastPoll = function () {\n var missed = false, input = this;\n input.pollingFast = true;\n function p() {\n var changed = input.poll();\n if (!changed && !missed) {missed = true; input.polling.set(60, p);}\n else {input.pollingFast = false; input.slowPoll();}\n }\n input.polling.set(20, p);\n };\n\n // Read input from the textarea, and update the document to match.\n // When something is selected, it is present in the textarea, and\n // selected (unless it is huge, in which case a placeholder is\n // used). When nothing is selected, the cursor sits after previously\n // seen text (can be empty), which is stored in prevInput (we must\n // not reset the textarea when typing, because that breaks IME).\n TextareaInput.prototype.poll = function () {\n var this$1 = this;\n\n var cm = this.cm, input = this.textarea, prevInput = this.prevInput;\n // Since this is called a *lot*, try to bail out as cheaply as\n // possible when it is clear that nothing happened. hasSelection\n // will be the case when there is a lot of text in the textarea,\n // in which case reading its value would be expensive.\n if (this.contextMenuPending || !cm.state.focused ||\n (hasSelection(input) && !prevInput && !this.composing) ||\n cm.isReadOnly() || cm.options.disableInput || cm.state.keySeq)\n { return false }\n\n var text = input.value;\n // If nothing changed, bail.\n if (text == prevInput && !cm.somethingSelected()) { return false }\n // Work around nonsensical selection resetting in IE9/10, and\n // inexplicable appearance of private area unicode characters on\n // some key combos in Mac (#2689).\n if (ie && ie_version >= 9 && this.hasSelection === text ||\n mac && /[\\uf700-\\uf7ff]/.test(text)) {\n cm.display.input.reset();\n return false\n }\n\n if (cm.doc.sel == cm.display.selForContextMenu) {\n var first = text.charCodeAt(0);\n if (first == 0x200b && !prevInput) { prevInput = \"\\u200b\"; }\n if (first == 0x21da) { this.reset(); return this.cm.execCommand(\"undo\") }\n }\n // Find the part of the input that is actually new\n var same = 0, l = Math.min(prevInput.length, text.length);\n while (same < l && prevInput.charCodeAt(same) == text.charCodeAt(same)) { ++same; }\n\n runInOp(cm, function () {\n applyTextInput(cm, text.slice(same), prevInput.length - same,\n null, this$1.composing ? \"*compose\" : null);\n\n // Don't leave long text in the textarea, since it makes further polling slow\n if (text.length > 1000 || text.indexOf(\"\\n\") > -1) { input.value = this$1.prevInput = \"\"; }\n else { this$1.prevInput = text; }\n\n if (this$1.composing) {\n this$1.composing.range.clear();\n this$1.composing.range = cm.markText(this$1.composing.start, cm.getCursor(\"to\"),\n {className: \"CodeMirror-composing\"});\n }\n });\n return true\n };\n\n TextareaInput.prototype.ensurePolled = function () {\n if (this.pollingFast && this.poll()) { this.pollingFast = false; }\n };\n\n TextareaInput.prototype.onKeyPress = function () {\n if (ie && ie_version >= 9) { this.hasSelection = null; }\n this.fastPoll();\n };\n\n TextareaInput.prototype.onContextMenu = function (e) {\n var input = this, cm = input.cm, display = cm.display, te = input.textarea;\n if (input.contextMenuPending) { input.contextMenuPending(); }\n var pos = posFromMouse(cm, e), scrollPos = display.scroller.scrollTop;\n if (!pos || presto) { return } // Opera is difficult.\n\n // Reset the current text selection only if the click is done outside of the selection\n // and 'resetSelectionOnContextMenu' option is true.\n var reset = cm.options.resetSelectionOnContextMenu;\n if (reset && cm.doc.sel.contains(pos) == -1)\n { operation(cm, setSelection)(cm.doc, simpleSelection(pos), sel_dontScroll); }\n\n var oldCSS = te.style.cssText, oldWrapperCSS = input.wrapper.style.cssText;\n var wrapperBox = input.wrapper.offsetParent.getBoundingClientRect();\n input.wrapper.style.cssText = \"position: static\";\n te.style.cssText = \"position: absolute; width: 30px; height: 30px;\\n top: \" + (e.clientY - wrapperBox.top - 5) + \"px; left: \" + (e.clientX - wrapperBox.left - 5) + \"px;\\n z-index: 1000; background: \" + (ie ? \"rgba(255, 255, 255, .05)\" : \"transparent\") + \";\\n outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);\";\n var oldScrollY;\n if (webkit) { oldScrollY = window.scrollY; } // Work around Chrome issue (#2712)\n display.input.focus();\n if (webkit) { window.scrollTo(null, oldScrollY); }\n display.input.reset();\n // Adds \"Select all\" to context menu in FF\n if (!cm.somethingSelected()) { te.value = input.prevInput = \" \"; }\n input.contextMenuPending = rehide;\n display.selForContextMenu = cm.doc.sel;\n clearTimeout(display.detectingSelectAll);\n\n // Select-all will be greyed out if there's nothing to select, so\n // this adds a zero-width space so that we can later check whether\n // it got selected.\n function prepareSelectAllHack() {\n if (te.selectionStart != null) {\n var selected = cm.somethingSelected();\n var extval = \"\\u200b\" + (selected ? te.value : \"\");\n te.value = \"\\u21da\"; // Used to catch context-menu undo\n te.value = extval;\n input.prevInput = selected ? \"\" : \"\\u200b\";\n te.selectionStart = 1; te.selectionEnd = extval.length;\n // Re-set this, in case some other handler touched the\n // selection in the meantime.\n display.selForContextMenu = cm.doc.sel;\n }\n }\n function rehide() {\n if (input.contextMenuPending != rehide) { return }\n input.contextMenuPending = false;\n input.wrapper.style.cssText = oldWrapperCSS;\n te.style.cssText = oldCSS;\n if (ie && ie_version < 9) { display.scrollbars.setScrollTop(display.scroller.scrollTop = scrollPos); }\n\n // Try to detect the user choosing select-all\n if (te.selectionStart != null) {\n if (!ie || (ie && ie_version < 9)) { prepareSelectAllHack(); }\n var i = 0, poll = function () {\n if (display.selForContextMenu == cm.doc.sel && te.selectionStart == 0 &&\n te.selectionEnd > 0 && input.prevInput == \"\\u200b\") {\n operation(cm, selectAll)(cm);\n } else if (i++ < 10) {\n display.detectingSelectAll = setTimeout(poll, 500);\n } else {\n display.selForContextMenu = null;\n display.input.reset();\n }\n };\n display.detectingSelectAll = setTimeout(poll, 200);\n }\n }\n\n if (ie && ie_version >= 9) { prepareSelectAllHack(); }\n if (captureRightClick) {\n e_stop(e);\n var mouseup = function () {\n off(window, \"mouseup\", mouseup);\n setTimeout(rehide, 20);\n };\n on(window, \"mouseup\", mouseup);\n } else {\n setTimeout(rehide, 50);\n }\n };\n\n TextareaInput.prototype.readOnlyChanged = function (val) {\n if (!val) { this.reset(); }\n this.textarea.disabled = val == \"nocursor\";\n };\n\n TextareaInput.prototype.setUneditable = function () {};\n\n TextareaInput.prototype.needsContentAttribute = false;\n\n function fromTextArea(textarea, options) {\n options = options ? copyObj(options) : {};\n options.value = textarea.value;\n if (!options.tabindex && textarea.tabIndex)\n { options.tabindex = textarea.tabIndex; }\n if (!options.placeholder && textarea.placeholder)\n { options.placeholder = textarea.placeholder; }\n // Set autofocus to true if this textarea is focused, or if it has\n // autofocus and no other element is focused.\n if (options.autofocus == null) {\n var hasFocus = activeElt();\n options.autofocus = hasFocus == textarea ||\n textarea.getAttribute(\"autofocus\") != null && hasFocus == document.body;\n }\n\n function save() {textarea.value = cm.getValue();}\n\n var realSubmit;\n if (textarea.form) {\n on(textarea.form, \"submit\", save);\n // Deplorable hack to make the submit method do the right thing.\n if (!options.leaveSubmitMethodAlone) {\n var form = textarea.form;\n realSubmit = form.submit;\n try {\n var wrappedSubmit = form.submit = function () {\n save();\n form.submit = realSubmit;\n form.submit();\n form.submit = wrappedSubmit;\n };\n } catch(e) {}\n }\n }\n\n options.finishInit = function (cm) {\n cm.save = save;\n cm.getTextArea = function () { return textarea; };\n cm.toTextArea = function () {\n cm.toTextArea = isNaN; // Prevent this from being ran twice\n save();\n textarea.parentNode.removeChild(cm.getWrapperElement());\n textarea.style.display = \"\";\n if (textarea.form) {\n off(textarea.form, \"submit\", save);\n if (typeof textarea.form.submit == \"function\")\n { textarea.form.submit = realSubmit; }\n }\n };\n };\n\n textarea.style.display = \"none\";\n var cm = CodeMirror(function (node) { return textarea.parentNode.insertBefore(node, textarea.nextSibling); },\n options);\n return cm\n }\n\n function addLegacyProps(CodeMirror) {\n CodeMirror.off = off;\n CodeMirror.on = on;\n CodeMirror.wheelEventPixels = wheelEventPixels;\n CodeMirror.Doc = Doc;\n CodeMirror.splitLines = splitLinesAuto;\n CodeMirror.countColumn = countColumn;\n CodeMirror.findColumn = findColumn;\n CodeMirror.isWordChar = isWordCharBasic;\n CodeMirror.Pass = Pass;\n CodeMirror.signal = signal;\n CodeMirror.Line = Line;\n CodeMirror.changeEnd = changeEnd;\n CodeMirror.scrollbarModel = scrollbarModel;\n CodeMirror.Pos = Pos;\n CodeMirror.cmpPos = cmp;\n CodeMirror.modes = modes;\n CodeMirror.mimeModes = mimeModes;\n CodeMirror.resolveMode = resolveMode;\n CodeMirror.getMode = getMode;\n CodeMirror.modeExtensions = modeExtensions;\n CodeMirror.extendMode = extendMode;\n CodeMirror.copyState = copyState;\n CodeMirror.startState = startState;\n CodeMirror.innerMode = innerMode;\n CodeMirror.commands = commands;\n CodeMirror.keyMap = keyMap;\n CodeMirror.keyName = keyName;\n CodeMirror.isModifierKey = isModifierKey;\n CodeMirror.lookupKey = lookupKey;\n CodeMirror.normalizeKeyMap = normalizeKeyMap;\n CodeMirror.StringStream = StringStream;\n CodeMirror.SharedTextMarker = SharedTextMarker;\n CodeMirror.TextMarker = TextMarker;\n CodeMirror.LineWidget = LineWidget;\n CodeMirror.e_preventDefault = e_preventDefault;\n CodeMirror.e_stopPropagation = e_stopPropagation;\n CodeMirror.e_stop = e_stop;\n CodeMirror.addClass = addClass;\n CodeMirror.contains = contains;\n CodeMirror.rmClass = rmClass;\n CodeMirror.keyNames = keyNames;\n }\n\n // EDITOR CONSTRUCTOR\n\n defineOptions(CodeMirror);\n\n addEditorMethods(CodeMirror);\n\n // Set up methods on CodeMirror's prototype to redirect to the editor's document.\n var dontDelegate = \"iter insert remove copy getEditor constructor\".split(\" \");\n for (var prop in Doc.prototype) { if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0)\n { CodeMirror.prototype[prop] = (function(method) {\n return function() {return method.apply(this.doc, arguments)}\n })(Doc.prototype[prop]); } }\n\n eventMixin(Doc);\n CodeMirror.inputStyles = {\"textarea\": TextareaInput, \"contenteditable\": ContentEditableInput};\n\n // Extra arguments are stored as the mode's dependencies, which is\n // used by (legacy) mechanisms like loadmode.js to automatically\n // load a mode. (Preferred mechanism is the require/define calls.)\n CodeMirror.defineMode = function(name/*, mode, …*/) {\n if (!CodeMirror.defaults.mode && name != \"null\") { CodeMirror.defaults.mode = name; }\n defineMode.apply(this, arguments);\n };\n\n CodeMirror.defineMIME = defineMIME;\n\n // Minimal default mode.\n CodeMirror.defineMode(\"null\", function () { return ({token: function (stream) { return stream.skipToEnd(); }}); });\n CodeMirror.defineMIME(\"text/plain\", \"null\");\n\n // EXTENSIONS\n\n CodeMirror.defineExtension = function (name, func) {\n CodeMirror.prototype[name] = func;\n };\n CodeMirror.defineDocExtension = function (name, func) {\n Doc.prototype[name] = func;\n };\n\n CodeMirror.fromTextArea = fromTextArea;\n\n addLegacyProps(CodeMirror);\n\n CodeMirror.version = \"5.42.2\";\n\n return CodeMirror;\n\n})));\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: https://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n \"use strict\";\n\n CodeMirror.defineMode(\"elm\", function() {\n\n function switchState(source, setState, f) {\n setState(f);\n return f(source, setState);\n }\n\n // These should all be Unicode extended, as per the Haskell 2010 report\n var smallRE = /[a-z_]/;\n var largeRE = /[A-Z]/;\n var digitRE = /[0-9]/;\n var hexitRE = /[0-9A-Fa-f]/;\n var octitRE = /[0-7]/;\n var idRE = /[a-z_A-Z0-9\\']/;\n var symbolRE = /[-!#$%&*+.\\/<=>?@\\\\^|~:\\u03BB\\u2192]/;\n var specialRE = /[(),;[\\]`{}]/;\n var whiteCharRE = /[ \\t\\v\\f]/; // newlines are handled in tokenizer\n\n function normal() {\n return function (source, setState) {\n if (source.eatWhile(whiteCharRE)) {\n return null;\n }\n\n var ch = source.next();\n if (specialRE.test(ch)) {\n if (ch == '{' && source.eat('-')) {\n var t = \"comment\";\n if (source.eat('#')) t = \"meta\";\n return switchState(source, setState, ncomment(t, 1));\n }\n return null;\n }\n\n if (ch == '\\'') {\n if (source.eat('\\\\'))\n source.next(); // should handle other escapes here\n else\n source.next();\n\n if (source.eat('\\''))\n return \"string\";\n return \"error\";\n }\n\n if (ch == '\"') {\n return switchState(source, setState, stringLiteral);\n }\n\n if (largeRE.test(ch)) {\n source.eatWhile(idRE);\n if (source.eat('.'))\n return \"qualifier\";\n return \"variable-2\";\n }\n\n if (smallRE.test(ch)) {\n var isDef = source.pos === 1;\n source.eatWhile(idRE);\n return isDef ? \"type\" : \"variable\";\n }\n\n if (digitRE.test(ch)) {\n if (ch == '0') {\n if (source.eat(/[xX]/)) {\n source.eatWhile(hexitRE); // should require at least 1\n return \"integer\";\n }\n if (source.eat(/[oO]/)) {\n source.eatWhile(octitRE); // should require at least 1\n return \"number\";\n }\n }\n source.eatWhile(digitRE);\n var t = \"number\";\n if (source.eat('.')) {\n t = \"number\";\n source.eatWhile(digitRE); // should require at least 1\n }\n if (source.eat(/[eE]/)) {\n t = \"number\";\n source.eat(/[-+]/);\n source.eatWhile(digitRE); // should require at least 1\n }\n return t;\n }\n\n if (symbolRE.test(ch)) {\n if (ch == '-' && source.eat(/-/)) {\n source.eatWhile(/-/);\n if (!source.eat(symbolRE)) {\n source.skipToEnd();\n return \"comment\";\n }\n }\n source.eatWhile(symbolRE);\n return \"builtin\";\n }\n\n return \"error\";\n }\n }\n\n function ncomment(type, nest) {\n if (nest == 0) {\n return normal();\n }\n return function(source, setState) {\n var currNest = nest;\n while (!source.eol()) {\n var ch = source.next();\n if (ch == '{' && source.eat('-')) {\n ++currNest;\n } else if (ch == '-' && source.eat('}')) {\n --currNest;\n if (currNest == 0) {\n setState(normal());\n return type;\n }\n }\n }\n setState(ncomment(type, currNest));\n return type;\n }\n }\n\n function stringLiteral(source, setState) {\n while (!source.eol()) {\n var ch = source.next();\n if (ch == '\"') {\n setState(normal());\n return \"string\";\n }\n if (ch == '\\\\') {\n if (source.eol() || source.eat(whiteCharRE)) {\n setState(stringGap);\n return \"string\";\n }\n if (!source.eat('&')) source.next(); // should handle other escapes here\n }\n }\n setState(normal());\n return \"error\";\n }\n\n function stringGap(source, setState) {\n if (source.eat('\\\\')) {\n return switchState(source, setState, stringLiteral);\n }\n source.next();\n setState(normal());\n return \"error\";\n }\n\n\n var wellKnownWords = (function() {\n var wkw = {};\n\n var keywords = [\n \"case\", \"of\", \"as\",\n \"if\", \"then\", \"else\",\n \"let\", \"in\",\n \"infix\", \"infixl\", \"infixr\",\n \"type\", \"alias\",\n \"input\", \"output\", \"foreign\", \"loopback\",\n \"module\", \"where\", \"import\", \"exposing\",\n \"_\", \"..\", \"|\", \":\", \"=\", \"\\\\\", \"\\\"\", \"->\", \"<-\"\n ];\n\n for (var i = keywords.length; i--;)\n wkw[keywords[i]] = \"keyword\";\n\n return wkw;\n })();\n\n\n\n return {\n startState: function () { return { f: normal() }; },\n copyState: function (s) { return { f: s.f }; },\n\n token: function(stream, state) {\n var t = state.f(stream, function(s) { state.f = s; });\n var w = stream.current();\n return (wellKnownWords.hasOwnProperty(w)) ? wellKnownWords[w] : t;\n }\n };\n\n });\n\n CodeMirror.defineMIME(\"text/x-elm\", \"elm\");\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: https://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n\"use strict\";\n\nCodeMirror.defineMode(\"javascript\", function(config, parserConfig) {\n var indentUnit = config.indentUnit;\n var statementIndent = parserConfig.statementIndent;\n var jsonldMode = parserConfig.jsonld;\n var jsonMode = parserConfig.json || jsonldMode;\n var isTS = parserConfig.typescript;\n var wordRE = parserConfig.wordCharacters || /[\\w$\\xa1-\\uffff]/;\n\n // Tokenizer\n\n var keywords = function(){\n function kw(type) {return {type: type, style: \"keyword\"};}\n var A = kw(\"keyword a\"), B = kw(\"keyword b\"), C = kw(\"keyword c\"), D = kw(\"keyword d\");\n var operator = kw(\"operator\"), atom = {type: \"atom\", style: \"atom\"};\n\n return {\n \"if\": kw(\"if\"), \"while\": A, \"with\": A, \"else\": B, \"do\": B, \"try\": B, \"finally\": B,\n \"return\": D, \"break\": D, \"continue\": D, \"new\": kw(\"new\"), \"delete\": C, \"void\": C, \"throw\": C,\n \"debugger\": kw(\"debugger\"), \"var\": kw(\"var\"), \"const\": kw(\"var\"), \"let\": kw(\"var\"),\n \"function\": kw(\"function\"), \"catch\": kw(\"catch\"),\n \"for\": kw(\"for\"), \"switch\": kw(\"switch\"), \"case\": kw(\"case\"), \"default\": kw(\"default\"),\n \"in\": operator, \"typeof\": operator, \"instanceof\": operator,\n \"true\": atom, \"false\": atom, \"null\": atom, \"undefined\": atom, \"NaN\": atom, \"Infinity\": atom,\n \"this\": kw(\"this\"), \"class\": kw(\"class\"), \"super\": kw(\"atom\"),\n \"yield\": C, \"export\": kw(\"export\"), \"import\": kw(\"import\"), \"extends\": C,\n \"await\": C\n };\n }();\n\n var isOperatorChar = /[+\\-*&%=<>!?|~^@]/;\n var isJsonldKeyword = /^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)\"/;\n\n function readRegexp(stream) {\n var escaped = false, next, inSet = false;\n while ((next = stream.next()) != null) {\n if (!escaped) {\n if (next == \"/\" && !inSet) return;\n if (next == \"[\") inSet = true;\n else if (inSet && next == \"]\") inSet = false;\n }\n escaped = !escaped && next == \"\\\\\";\n }\n }\n\n // Used as scratch variables to communicate multiple values without\n // consing up tons of objects.\n var type, content;\n function ret(tp, style, cont) {\n type = tp; content = cont;\n return style;\n }\n function tokenBase(stream, state) {\n var ch = stream.next();\n if (ch == '\"' || ch == \"'\") {\n state.tokenize = tokenString(ch);\n return state.tokenize(stream, state);\n } else if (ch == \".\" && stream.match(/^\\d+(?:[eE][+\\-]?\\d+)?/)) {\n return ret(\"number\", \"number\");\n } else if (ch == \".\" && stream.match(\"..\")) {\n return ret(\"spread\", \"meta\");\n } else if (/[\\[\\]{}\\(\\),;\\:\\.]/.test(ch)) {\n return ret(ch);\n } else if (ch == \"=\" && stream.eat(\">\")) {\n return ret(\"=>\", \"operator\");\n } else if (ch == \"0\" && stream.match(/^(?:x[\\da-f]+|o[0-7]+|b[01]+)n?/i)) {\n return ret(\"number\", \"number\");\n } else if (/\\d/.test(ch)) {\n stream.match(/^\\d*(?:n|(?:\\.\\d*)?(?:[eE][+\\-]?\\d+)?)?/);\n return ret(\"number\", \"number\");\n } else if (ch == \"/\") {\n if (stream.eat(\"*\")) {\n state.tokenize = tokenComment;\n return tokenComment(stream, state);\n } else if (stream.eat(\"/\")) {\n stream.skipToEnd();\n return ret(\"comment\", \"comment\");\n } else if (expressionAllowed(stream, state, 1)) {\n readRegexp(stream);\n stream.match(/^\\b(([gimyus])(?![gimyus]*\\2))+\\b/);\n return ret(\"regexp\", \"string-2\");\n } else {\n stream.eat(\"=\");\n return ret(\"operator\", \"operator\", stream.current());\n }\n } else if (ch == \"`\") {\n state.tokenize = tokenQuasi;\n return tokenQuasi(stream, state);\n } else if (ch == \"#\") {\n stream.skipToEnd();\n return ret(\"error\", \"error\");\n } else if (isOperatorChar.test(ch)) {\n if (ch != \">\" || !state.lexical || state.lexical.type != \">\") {\n if (stream.eat(\"=\")) {\n if (ch == \"!\" || ch == \"=\") stream.eat(\"=\")\n } else if (/[<>*+\\-]/.test(ch)) {\n stream.eat(ch)\n if (ch == \">\") stream.eat(ch)\n }\n }\n return ret(\"operator\", \"operator\", stream.current());\n } else if (wordRE.test(ch)) {\n stream.eatWhile(wordRE);\n var word = stream.current()\n if (state.lastType != \".\") {\n if (keywords.propertyIsEnumerable(word)) {\n var kw = keywords[word]\n return ret(kw.type, kw.style, word)\n }\n if (word == \"async\" && stream.match(/^(\\s|\\/\\*.*?\\*\\/)*[\\[\\(\\w]/, false))\n return ret(\"async\", \"keyword\", word)\n }\n return ret(\"variable\", \"variable\", word)\n }\n }\n\n function tokenString(quote) {\n return function(stream, state) {\n var escaped = false, next;\n if (jsonldMode && stream.peek() == \"@\" && stream.match(isJsonldKeyword)){\n state.tokenize = tokenBase;\n return ret(\"jsonld-keyword\", \"meta\");\n }\n while ((next = stream.next()) != null) {\n if (next == quote && !escaped) break;\n escaped = !escaped && next == \"\\\\\";\n }\n if (!escaped) state.tokenize = tokenBase;\n return ret(\"string\", \"string\");\n };\n }\n\n function tokenComment(stream, state) {\n var maybeEnd = false, ch;\n while (ch = stream.next()) {\n if (ch == \"/\" && maybeEnd) {\n state.tokenize = tokenBase;\n break;\n }\n maybeEnd = (ch == \"*\");\n }\n return ret(\"comment\", \"comment\");\n }\n\n function tokenQuasi(stream, state) {\n var escaped = false, next;\n while ((next = stream.next()) != null) {\n if (!escaped && (next == \"`\" || next == \"$\" && stream.eat(\"{\"))) {\n state.tokenize = tokenBase;\n break;\n }\n escaped = !escaped && next == \"\\\\\";\n }\n return ret(\"quasi\", \"string-2\", stream.current());\n }\n\n var brackets = \"([{}])\";\n // This is a crude lookahead trick to try and notice that we're\n // parsing the argument patterns for a fat-arrow function before we\n // actually hit the arrow token. It only works if the arrow is on\n // the same line as the arguments and there's no strange noise\n // (comments) in between. Fallback is to only notice when we hit the\n // arrow, and not declare the arguments as locals for the arrow\n // body.\n function findFatArrow(stream, state) {\n if (state.fatArrowAt) state.fatArrowAt = null;\n var arrow = stream.string.indexOf(\"=>\", stream.start);\n if (arrow < 0) return;\n\n if (isTS) { // Try to skip TypeScript return type declarations after the arguments\n var m = /:\\s*(?:\\w+(?:<[^>]*>|\\[\\])?|\\{[^}]*\\})\\s*$/.exec(stream.string.slice(stream.start, arrow))\n if (m) arrow = m.index\n }\n\n var depth = 0, sawSomething = false;\n for (var pos = arrow - 1; pos >= 0; --pos) {\n var ch = stream.string.charAt(pos);\n var bracket = brackets.indexOf(ch);\n if (bracket >= 0 && bracket < 3) {\n if (!depth) { ++pos; break; }\n if (--depth == 0) { if (ch == \"(\") sawSomething = true; break; }\n } else if (bracket >= 3 && bracket < 6) {\n ++depth;\n } else if (wordRE.test(ch)) {\n sawSomething = true;\n } else if (/[\"'\\/]/.test(ch)) {\n return;\n } else if (sawSomething && !depth) {\n ++pos;\n break;\n }\n }\n if (sawSomething && !depth) state.fatArrowAt = pos;\n }\n\n // Parser\n\n var atomicTypes = {\"atom\": true, \"number\": true, \"variable\": true, \"string\": true, \"regexp\": true, \"this\": true, \"jsonld-keyword\": true};\n\n function JSLexical(indented, column, type, align, prev, info) {\n this.indented = indented;\n this.column = column;\n this.type = type;\n this.prev = prev;\n this.info = info;\n if (align != null) this.align = align;\n }\n\n function inScope(state, varname) {\n for (var v = state.localVars; v; v = v.next)\n if (v.name == varname) return true;\n for (var cx = state.context; cx; cx = cx.prev) {\n for (var v = cx.vars; v; v = v.next)\n if (v.name == varname) return true;\n }\n }\n\n function parseJS(state, style, type, content, stream) {\n var cc = state.cc;\n // Communicate our context to the combinators.\n // (Less wasteful than consing up a hundred closures on every call.)\n cx.state = state; cx.stream = stream; cx.marked = null, cx.cc = cc; cx.style = style;\n\n if (!state.lexical.hasOwnProperty(\"align\"))\n state.lexical.align = true;\n\n while(true) {\n var combinator = cc.length ? cc.pop() : jsonMode ? expression : statement;\n if (combinator(type, content)) {\n while(cc.length && cc[cc.length - 1].lex)\n cc.pop()();\n if (cx.marked) return cx.marked;\n if (type == \"variable\" && inScope(state, content)) return \"variable-2\";\n return style;\n }\n }\n }\n\n // Combinator utils\n\n var cx = {state: null, column: null, marked: null, cc: null};\n function pass() {\n for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]);\n }\n function cont() {\n pass.apply(null, arguments);\n return true;\n }\n function inList(name, list) {\n for (var v = list; v; v = v.next) if (v.name == name) return true\n return false;\n }\n function register(varname) {\n var state = cx.state;\n cx.marked = \"def\";\n if (state.context) {\n if (state.lexical.info == \"var\" && state.context && state.context.block) {\n // FIXME function decls are also not block scoped\n var newContext = registerVarScoped(varname, state.context)\n if (newContext != null) {\n state.context = newContext\n return\n }\n } else if (!inList(varname, state.localVars)) {\n state.localVars = new Var(varname, state.localVars)\n return\n }\n }\n // Fall through means this is global\n if (parserConfig.globalVars && !inList(varname, state.globalVars))\n state.globalVars = new Var(varname, state.globalVars)\n }\n function registerVarScoped(varname, context) {\n if (!context) {\n return null\n } else if (context.block) {\n var inner = registerVarScoped(varname, context.prev)\n if (!inner) return null\n if (inner == context.prev) return context\n return new Context(inner, context.vars, true)\n } else if (inList(varname, context.vars)) {\n return context\n } else {\n return new Context(context.prev, new Var(varname, context.vars), false)\n }\n }\n\n function isModifier(name) {\n return name == \"public\" || name == \"private\" || name == \"protected\" || name == \"abstract\" || name == \"readonly\"\n }\n\n // Combinators\n\n function Context(prev, vars, block) { this.prev = prev; this.vars = vars; this.block = block }\n function Var(name, next) { this.name = name; this.next = next }\n\n var defaultVars = new Var(\"this\", new Var(\"arguments\", null))\n function pushcontext() {\n cx.state.context = new Context(cx.state.context, cx.state.localVars, false)\n cx.state.localVars = defaultVars\n }\n function pushblockcontext() {\n cx.state.context = new Context(cx.state.context, cx.state.localVars, true)\n cx.state.localVars = null\n }\n function popcontext() {\n cx.state.localVars = cx.state.context.vars\n cx.state.context = cx.state.context.prev\n }\n popcontext.lex = true\n function pushlex(type, info) {\n var result = function() {\n var state = cx.state, indent = state.indented;\n if (state.lexical.type == \"stat\") indent = state.lexical.indented;\n else for (var outer = state.lexical; outer && outer.type == \")\" && outer.align; outer = outer.prev)\n indent = outer.indented;\n state.lexical = new JSLexical(indent, cx.stream.column(), type, null, state.lexical, info);\n };\n result.lex = true;\n return result;\n }\n function poplex() {\n var state = cx.state;\n if (state.lexical.prev) {\n if (state.lexical.type == \")\")\n state.indented = state.lexical.indented;\n state.lexical = state.lexical.prev;\n }\n }\n poplex.lex = true;\n\n function expect(wanted) {\n function exp(type) {\n if (type == wanted) return cont();\n else if (wanted == \";\" || type == \"}\" || type == \")\" || type == \"]\") return pass();\n else return cont(exp);\n };\n return exp;\n }\n\n function statement(type, value) {\n if (type == \"var\") return cont(pushlex(\"vardef\", value), vardef, expect(\";\"), poplex);\n if (type == \"keyword a\") return cont(pushlex(\"form\"), parenExpr, statement, poplex);\n if (type == \"keyword b\") return cont(pushlex(\"form\"), statement, poplex);\n if (type == \"keyword d\") return cx.stream.match(/^\\s*$/, false) ? cont() : cont(pushlex(\"stat\"), maybeexpression, expect(\";\"), poplex);\n if (type == \"debugger\") return cont(expect(\";\"));\n if (type == \"{\") return cont(pushlex(\"}\"), pushblockcontext, block, poplex, popcontext);\n if (type == \";\") return cont();\n if (type == \"if\") {\n if (cx.state.lexical.info == \"else\" && cx.state.cc[cx.state.cc.length - 1] == poplex)\n cx.state.cc.pop()();\n return cont(pushlex(\"form\"), parenExpr, statement, poplex, maybeelse);\n }\n if (type == \"function\") return cont(functiondef);\n if (type == \"for\") return cont(pushlex(\"form\"), forspec, statement, poplex);\n if (type == \"class\" || (isTS && value == \"interface\")) { cx.marked = \"keyword\"; return cont(pushlex(\"form\"), className, poplex); }\n if (type == \"variable\") {\n if (isTS && value == \"declare\") {\n cx.marked = \"keyword\"\n return cont(statement)\n } else if (isTS && (value == \"module\" || value == \"enum\" || value == \"type\") && cx.stream.match(/^\\s*\\w/, false)) {\n cx.marked = \"keyword\"\n if (value == \"enum\") return cont(enumdef);\n else if (value == \"type\") return cont(typeexpr, expect(\"operator\"), typeexpr, expect(\";\"));\n else return cont(pushlex(\"form\"), pattern, expect(\"{\"), pushlex(\"}\"), block, poplex, poplex)\n } else if (isTS && value == \"namespace\") {\n cx.marked = \"keyword\"\n return cont(pushlex(\"form\"), expression, block, poplex)\n } else if (isTS && value == \"abstract\") {\n cx.marked = \"keyword\"\n return cont(statement)\n } else {\n return cont(pushlex(\"stat\"), maybelabel);\n }\n }\n if (type == \"switch\") return cont(pushlex(\"form\"), parenExpr, expect(\"{\"), pushlex(\"}\", \"switch\"), pushblockcontext,\n block, poplex, poplex, popcontext);\n if (type == \"case\") return cont(expression, expect(\":\"));\n if (type == \"default\") return cont(expect(\":\"));\n if (type == \"catch\") return cont(pushlex(\"form\"), pushcontext, maybeCatchBinding, statement, poplex, popcontext);\n if (type == \"export\") return cont(pushlex(\"stat\"), afterExport, poplex);\n if (type == \"import\") return cont(pushlex(\"stat\"), afterImport, poplex);\n if (type == \"async\") return cont(statement)\n if (value == \"@\") return cont(expression, statement)\n return pass(pushlex(\"stat\"), expression, expect(\";\"), poplex);\n }\n function maybeCatchBinding(type) {\n if (type == \"(\") return cont(funarg, expect(\")\"))\n }\n function expression(type, value) {\n return expressionInner(type, value, false);\n }\n function expressionNoComma(type, value) {\n return expressionInner(type, value, true);\n }\n function parenExpr(type) {\n if (type != \"(\") return pass()\n return cont(pushlex(\")\"), expression, expect(\")\"), poplex)\n }\n function expressionInner(type, value, noComma) {\n if (cx.state.fatArrowAt == cx.stream.start) {\n var body = noComma ? arrowBodyNoComma : arrowBody;\n if (type == \"(\") return cont(pushcontext, pushlex(\")\"), commasep(funarg, \")\"), poplex, expect(\"=>\"), body, popcontext);\n else if (type == \"variable\") return pass(pushcontext, pattern, expect(\"=>\"), body, popcontext);\n }\n\n var maybeop = noComma ? maybeoperatorNoComma : maybeoperatorComma;\n if (atomicTypes.hasOwnProperty(type)) return cont(maybeop);\n if (type == \"function\") return cont(functiondef, maybeop);\n if (type == \"class\" || (isTS && value == \"interface\")) { cx.marked = \"keyword\"; return cont(pushlex(\"form\"), classExpression, poplex); }\n if (type == \"keyword c\" || type == \"async\") return cont(noComma ? expressionNoComma : expression);\n if (type == \"(\") return cont(pushlex(\")\"), maybeexpression, expect(\")\"), poplex, maybeop);\n if (type == \"operator\" || type == \"spread\") return cont(noComma ? expressionNoComma : expression);\n if (type == \"[\") return cont(pushlex(\"]\"), arrayLiteral, poplex, maybeop);\n if (type == \"{\") return contCommasep(objprop, \"}\", null, maybeop);\n if (type == \"quasi\") return pass(quasi, maybeop);\n if (type == \"new\") return cont(maybeTarget(noComma));\n if (type == \"import\") return cont(expression);\n return cont();\n }\n function maybeexpression(type) {\n if (type.match(/[;\\}\\)\\],]/)) return pass();\n return pass(expression);\n }\n\n function maybeoperatorComma(type, value) {\n if (type == \",\") return cont(expression);\n return maybeoperatorNoComma(type, value, false);\n }\n function maybeoperatorNoComma(type, value, noComma) {\n var me = noComma == false ? maybeoperatorComma : maybeoperatorNoComma;\n var expr = noComma == false ? expression : expressionNoComma;\n if (type == \"=>\") return cont(pushcontext, noComma ? arrowBodyNoComma : arrowBody, popcontext);\n if (type == \"operator\") {\n if (/\\+\\+|--/.test(value) || isTS && value == \"!\") return cont(me);\n if (isTS && value == \"<\" && cx.stream.match(/^([^>]|<.*?>)*>\\s*\\(/, false))\n return cont(pushlex(\">\"), commasep(typeexpr, \">\"), poplex, me);\n if (value == \"?\") return cont(expression, expect(\":\"), expr);\n return cont(expr);\n }\n if (type == \"quasi\") { return pass(quasi, me); }\n if (type == \";\") return;\n if (type == \"(\") return contCommasep(expressionNoComma, \")\", \"call\", me);\n if (type == \".\") return cont(property, me);\n if (type == \"[\") return cont(pushlex(\"]\"), maybeexpression, expect(\"]\"), poplex, me);\n if (isTS && value == \"as\") { cx.marked = \"keyword\"; return cont(typeexpr, me) }\n if (type == \"regexp\") {\n cx.state.lastType = cx.marked = \"operator\"\n cx.stream.backUp(cx.stream.pos - cx.stream.start - 1)\n return cont(expr)\n }\n }\n function quasi(type, value) {\n if (type != \"quasi\") return pass();\n if (value.slice(value.length - 2) != \"${\") return cont(quasi);\n return cont(expression, continueQuasi);\n }\n function continueQuasi(type) {\n if (type == \"}\") {\n cx.marked = \"string-2\";\n cx.state.tokenize = tokenQuasi;\n return cont(quasi);\n }\n }\n function arrowBody(type) {\n findFatArrow(cx.stream, cx.state);\n return pass(type == \"{\" ? statement : expression);\n }\n function arrowBodyNoComma(type) {\n findFatArrow(cx.stream, cx.state);\n return pass(type == \"{\" ? statement : expressionNoComma);\n }\n function maybeTarget(noComma) {\n return function(type) {\n if (type == \".\") return cont(noComma ? targetNoComma : target);\n else if (type == \"variable\" && isTS) return cont(maybeTypeArgs, noComma ? maybeoperatorNoComma : maybeoperatorComma)\n else return pass(noComma ? expressionNoComma : expression);\n };\n }\n function target(_, value) {\n if (value == \"target\") { cx.marked = \"keyword\"; return cont(maybeoperatorComma); }\n }\n function targetNoComma(_, value) {\n if (value == \"target\") { cx.marked = \"keyword\"; return cont(maybeoperatorNoComma); }\n }\n function maybelabel(type) {\n if (type == \":\") return cont(poplex, statement);\n return pass(maybeoperatorComma, expect(\";\"), poplex);\n }\n function property(type) {\n if (type == \"variable\") {cx.marked = \"property\"; return cont();}\n }\n function objprop(type, value) {\n if (type == \"async\") {\n cx.marked = \"property\";\n return cont(objprop);\n } else if (type == \"variable\" || cx.style == \"keyword\") {\n cx.marked = \"property\";\n if (value == \"get\" || value == \"set\") return cont(getterSetter);\n var m // Work around fat-arrow-detection complication for detecting typescript typed arrow params\n if (isTS && cx.state.fatArrowAt == cx.stream.start && (m = cx.stream.match(/^\\s*:\\s*/, false)))\n cx.state.fatArrowAt = cx.stream.pos + m[0].length\n return cont(afterprop);\n } else if (type == \"number\" || type == \"string\") {\n cx.marked = jsonldMode ? \"property\" : (cx.style + \" property\");\n return cont(afterprop);\n } else if (type == \"jsonld-keyword\") {\n return cont(afterprop);\n } else if (isTS && isModifier(value)) {\n cx.marked = \"keyword\"\n return cont(objprop)\n } else if (type == \"[\") {\n return cont(expression, maybetype, expect(\"]\"), afterprop);\n } else if (type == \"spread\") {\n return cont(expressionNoComma, afterprop);\n } else if (value == \"*\") {\n cx.marked = \"keyword\";\n return cont(objprop);\n } else if (type == \":\") {\n return pass(afterprop)\n }\n }\n function getterSetter(type) {\n if (type != \"variable\") return pass(afterprop);\n cx.marked = \"property\";\n return cont(functiondef);\n }\n function afterprop(type) {\n if (type == \":\") return cont(expressionNoComma);\n if (type == \"(\") return pass(functiondef);\n }\n function commasep(what, end, sep) {\n function proceed(type, value) {\n if (sep ? sep.indexOf(type) > -1 : type == \",\") {\n var lex = cx.state.lexical;\n if (lex.info == \"call\") lex.pos = (lex.pos || 0) + 1;\n return cont(function(type, value) {\n if (type == end || value == end) return pass()\n return pass(what)\n }, proceed);\n }\n if (type == end || value == end) return cont();\n return cont(expect(end));\n }\n return function(type, value) {\n if (type == end || value == end) return cont();\n return pass(what, proceed);\n };\n }\n function contCommasep(what, end, info) {\n for (var i = 3; i < arguments.length; i++)\n cx.cc.push(arguments[i]);\n return cont(pushlex(end, info), commasep(what, end), poplex);\n }\n function block(type) {\n if (type == \"}\") return cont();\n return pass(statement, block);\n }\n function maybetype(type, value) {\n if (isTS) {\n if (type == \":\") return cont(typeexpr);\n if (value == \"?\") return cont(maybetype);\n }\n }\n function mayberettype(type) {\n if (isTS && type == \":\") {\n if (cx.stream.match(/^\\s*\\w+\\s+is\\b/, false)) return cont(expression, isKW, typeexpr)\n else return cont(typeexpr)\n }\n }\n function isKW(_, value) {\n if (value == \"is\") {\n cx.marked = \"keyword\"\n return cont()\n }\n }\n function typeexpr(type, value) {\n if (value == \"keyof\" || value == \"typeof\") {\n cx.marked = \"keyword\"\n return cont(value == \"keyof\" ? typeexpr : expressionNoComma)\n }\n if (type == \"variable\" || value == \"void\") {\n cx.marked = \"type\"\n return cont(afterType)\n }\n if (type == \"string\" || type == \"number\" || type == \"atom\") return cont(afterType);\n if (type == \"[\") return cont(pushlex(\"]\"), commasep(typeexpr, \"]\", \",\"), poplex, afterType)\n if (type == \"{\") return cont(pushlex(\"}\"), commasep(typeprop, \"}\", \",;\"), poplex, afterType)\n if (type == \"(\") return cont(commasep(typearg, \")\"), maybeReturnType)\n if (type == \"<\") return cont(commasep(typeexpr, \">\"), typeexpr)\n }\n function maybeReturnType(type) {\n if (type == \"=>\") return cont(typeexpr)\n }\n function typeprop(type, value) {\n if (type == \"variable\" || cx.style == \"keyword\") {\n cx.marked = \"property\"\n return cont(typeprop)\n } else if (value == \"?\") {\n return cont(typeprop)\n } else if (type == \":\") {\n return cont(typeexpr)\n } else if (type == \"[\") {\n return cont(expression, maybetype, expect(\"]\"), typeprop)\n }\n }\n function typearg(type, value) {\n if (type == \"variable\" && cx.stream.match(/^\\s*[?:]/, false) || value == \"?\") return cont(typearg)\n if (type == \":\") return cont(typeexpr)\n return pass(typeexpr)\n }\n function afterType(type, value) {\n if (value == \"<\") return cont(pushlex(\">\"), commasep(typeexpr, \">\"), poplex, afterType)\n if (value == \"|\" || type == \".\" || value == \"&\") return cont(typeexpr)\n if (type == \"[\") return cont(expect(\"]\"), afterType)\n if (value == \"extends\" || value == \"implements\") { cx.marked = \"keyword\"; return cont(typeexpr) }\n }\n function maybeTypeArgs(_, value) {\n if (value == \"<\") return cont(pushlex(\">\"), commasep(typeexpr, \">\"), poplex, afterType)\n }\n function typeparam() {\n return pass(typeexpr, maybeTypeDefault)\n }\n function maybeTypeDefault(_, value) {\n if (value == \"=\") return cont(typeexpr)\n }\n function vardef(_, value) {\n if (value == \"enum\") {cx.marked = \"keyword\"; return cont(enumdef)}\n return pass(pattern, maybetype, maybeAssign, vardefCont);\n }\n function pattern(type, value) {\n if (isTS && isModifier(value)) { cx.marked = \"keyword\"; return cont(pattern) }\n if (type == \"variable\") { register(value); return cont(); }\n if (type == \"spread\") return cont(pattern);\n if (type == \"[\") return contCommasep(eltpattern, \"]\");\n if (type == \"{\") return contCommasep(proppattern, \"}\");\n }\n function proppattern(type, value) {\n if (type == \"variable\" && !cx.stream.match(/^\\s*:/, false)) {\n register(value);\n return cont(maybeAssign);\n }\n if (type == \"variable\") cx.marked = \"property\";\n if (type == \"spread\") return cont(pattern);\n if (type == \"}\") return pass();\n if (type == \"[\") return cont(expression, expect(']'), expect(':'), proppattern);\n return cont(expect(\":\"), pattern, maybeAssign);\n }\n function eltpattern() {\n return pass(pattern, maybeAssign)\n }\n function maybeAssign(_type, value) {\n if (value == \"=\") return cont(expressionNoComma);\n }\n function vardefCont(type) {\n if (type == \",\") return cont(vardef);\n }\n function maybeelse(type, value) {\n if (type == \"keyword b\" && value == \"else\") return cont(pushlex(\"form\", \"else\"), statement, poplex);\n }\n function forspec(type, value) {\n if (value == \"await\") return cont(forspec);\n if (type == \"(\") return cont(pushlex(\")\"), forspec1, expect(\")\"), poplex);\n }\n function forspec1(type) {\n if (type == \"var\") return cont(vardef, expect(\";\"), forspec2);\n if (type == \";\") return cont(forspec2);\n if (type == \"variable\") return cont(formaybeinof);\n return pass(expression, expect(\";\"), forspec2);\n }\n function formaybeinof(_type, value) {\n if (value == \"in\" || value == \"of\") { cx.marked = \"keyword\"; return cont(expression); }\n return cont(maybeoperatorComma, forspec2);\n }\n function forspec2(type, value) {\n if (type == \";\") return cont(forspec3);\n if (value == \"in\" || value == \"of\") { cx.marked = \"keyword\"; return cont(expression); }\n return pass(expression, expect(\";\"), forspec3);\n }\n function forspec3(type) {\n if (type != \")\") cont(expression);\n }\n function functiondef(type, value) {\n if (value == \"*\") {cx.marked = \"keyword\"; return cont(functiondef);}\n if (type == \"variable\") {register(value); return cont(functiondef);}\n if (type == \"(\") return cont(pushcontext, pushlex(\")\"), commasep(funarg, \")\"), poplex, mayberettype, statement, popcontext);\n if (isTS && value == \"<\") return cont(pushlex(\">\"), commasep(typeparam, \">\"), poplex, functiondef)\n }\n function funarg(type, value) {\n if (value == \"@\") cont(expression, funarg)\n if (type == \"spread\") return cont(funarg);\n if (isTS && isModifier(value)) { cx.marked = \"keyword\"; return cont(funarg); }\n return pass(pattern, maybetype, maybeAssign);\n }\n function classExpression(type, value) {\n // Class expressions may have an optional name.\n if (type == \"variable\") return className(type, value);\n return classNameAfter(type, value);\n }\n function className(type, value) {\n if (type == \"variable\") {register(value); return cont(classNameAfter);}\n }\n function classNameAfter(type, value) {\n if (value == \"<\") return cont(pushlex(\">\"), commasep(typeparam, \">\"), poplex, classNameAfter)\n if (value == \"extends\" || value == \"implements\" || (isTS && type == \",\")) {\n if (value == \"implements\") cx.marked = \"keyword\";\n return cont(isTS ? typeexpr : expression, classNameAfter);\n }\n if (type == \"{\") return cont(pushlex(\"}\"), classBody, poplex);\n }\n function classBody(type, value) {\n if (type == \"async\" ||\n (type == \"variable\" &&\n (value == \"static\" || value == \"get\" || value == \"set\" || (isTS && isModifier(value))) &&\n cx.stream.match(/^\\s+[\\w$\\xa1-\\uffff]/, false))) {\n cx.marked = \"keyword\";\n return cont(classBody);\n }\n if (type == \"variable\" || cx.style == \"keyword\") {\n cx.marked = \"property\";\n return cont(isTS ? classfield : functiondef, classBody);\n }\n if (type == \"[\")\n return cont(expression, maybetype, expect(\"]\"), isTS ? classfield : functiondef, classBody)\n if (value == \"*\") {\n cx.marked = \"keyword\";\n return cont(classBody);\n }\n if (type == \";\") return cont(classBody);\n if (type == \"}\") return cont();\n if (value == \"@\") return cont(expression, classBody)\n }\n function classfield(type, value) {\n if (value == \"?\") return cont(classfield)\n if (type == \":\") return cont(typeexpr, maybeAssign)\n if (value == \"=\") return cont(expressionNoComma)\n return pass(functiondef)\n }\n function afterExport(type, value) {\n if (value == \"*\") { cx.marked = \"keyword\"; return cont(maybeFrom, expect(\";\")); }\n if (value == \"default\") { cx.marked = \"keyword\"; return cont(expression, expect(\";\")); }\n if (type == \"{\") return cont(commasep(exportField, \"}\"), maybeFrom, expect(\";\"));\n return pass(statement);\n }\n function exportField(type, value) {\n if (value == \"as\") { cx.marked = \"keyword\"; return cont(expect(\"variable\")); }\n if (type == \"variable\") return pass(expressionNoComma, exportField);\n }\n function afterImport(type) {\n if (type == \"string\") return cont();\n if (type == \"(\") return pass(expression);\n return pass(importSpec, maybeMoreImports, maybeFrom);\n }\n function importSpec(type, value) {\n if (type == \"{\") return contCommasep(importSpec, \"}\");\n if (type == \"variable\") register(value);\n if (value == \"*\") cx.marked = \"keyword\";\n return cont(maybeAs);\n }\n function maybeMoreImports(type) {\n if (type == \",\") return cont(importSpec, maybeMoreImports)\n }\n function maybeAs(_type, value) {\n if (value == \"as\") { cx.marked = \"keyword\"; return cont(importSpec); }\n }\n function maybeFrom(_type, value) {\n if (value == \"from\") { cx.marked = \"keyword\"; return cont(expression); }\n }\n function arrayLiteral(type) {\n if (type == \"]\") return cont();\n return pass(commasep(expressionNoComma, \"]\"));\n }\n function enumdef() {\n return pass(pushlex(\"form\"), pattern, expect(\"{\"), pushlex(\"}\"), commasep(enummember, \"}\"), poplex, poplex)\n }\n function enummember() {\n return pass(pattern, maybeAssign);\n }\n\n function isContinuedStatement(state, textAfter) {\n return state.lastType == \"operator\" || state.lastType == \",\" ||\n isOperatorChar.test(textAfter.charAt(0)) ||\n /[,.]/.test(textAfter.charAt(0));\n }\n\n function expressionAllowed(stream, state, backUp) {\n return state.tokenize == tokenBase &&\n /^(?:operator|sof|keyword [bcd]|case|new|export|default|spread|[\\[{}\\(,;:]|=>)$/.test(state.lastType) ||\n (state.lastType == \"quasi\" && /\\{\\s*$/.test(stream.string.slice(0, stream.pos - (backUp || 0))))\n }\n\n // Interface\n\n return {\n startState: function(basecolumn) {\n var state = {\n tokenize: tokenBase,\n lastType: \"sof\",\n cc: [],\n lexical: new JSLexical((basecolumn || 0) - indentUnit, 0, \"block\", false),\n localVars: parserConfig.localVars,\n context: parserConfig.localVars && new Context(null, null, false),\n indented: basecolumn || 0\n };\n if (parserConfig.globalVars && typeof parserConfig.globalVars == \"object\")\n state.globalVars = parserConfig.globalVars;\n return state;\n },\n\n token: function(stream, state) {\n if (stream.sol()) {\n if (!state.lexical.hasOwnProperty(\"align\"))\n state.lexical.align = false;\n state.indented = stream.indentation();\n findFatArrow(stream, state);\n }\n if (state.tokenize != tokenComment && stream.eatSpace()) return null;\n var style = state.tokenize(stream, state);\n if (type == \"comment\") return style;\n state.lastType = type == \"operator\" && (content == \"++\" || content == \"--\") ? \"incdec\" : type;\n return parseJS(state, style, type, content, stream);\n },\n\n indent: function(state, textAfter) {\n if (state.tokenize == tokenComment) return CodeMirror.Pass;\n if (state.tokenize != tokenBase) return 0;\n var firstChar = textAfter && textAfter.charAt(0), lexical = state.lexical, top\n // Kludge to prevent 'maybelse' from blocking lexical scope pops\n if (!/^\\s*else\\b/.test(textAfter)) for (var i = state.cc.length - 1; i >= 0; --i) {\n var c = state.cc[i];\n if (c == poplex) lexical = lexical.prev;\n else if (c != maybeelse) break;\n }\n while ((lexical.type == \"stat\" || lexical.type == \"form\") &&\n (firstChar == \"}\" || ((top = state.cc[state.cc.length - 1]) &&\n (top == maybeoperatorComma || top == maybeoperatorNoComma) &&\n !/^[,\\.=+\\-*:?[\\(]/.test(textAfter))))\n lexical = lexical.prev;\n if (statementIndent && lexical.type == \")\" && lexical.prev.type == \"stat\")\n lexical = lexical.prev;\n var type = lexical.type, closing = firstChar == type;\n\n if (type == \"vardef\") return lexical.indented + (state.lastType == \"operator\" || state.lastType == \",\" ? lexical.info.length + 1 : 0);\n else if (type == \"form\" && firstChar == \"{\") return lexical.indented;\n else if (type == \"form\") return lexical.indented + indentUnit;\n else if (type == \"stat\")\n return lexical.indented + (isContinuedStatement(state, textAfter) ? statementIndent || indentUnit : 0);\n else if (lexical.info == \"switch\" && !closing && parserConfig.doubleIndentSwitch != false)\n return lexical.indented + (/^(?:case|default)\\b/.test(textAfter) ? indentUnit : 2 * indentUnit);\n else if (lexical.align) return lexical.column + (closing ? 0 : 1);\n else return lexical.indented + (closing ? 0 : indentUnit);\n },\n\n electricInput: /^\\s*(?:case .*?:|default:|\\{|\\})$/,\n blockCommentStart: jsonMode ? null : \"/*\",\n blockCommentEnd: jsonMode ? null : \"*/\",\n blockCommentContinue: jsonMode ? null : \" * \",\n lineComment: jsonMode ? null : \"//\",\n fold: \"brace\",\n closeBrackets: \"()[]{}''\\\"\\\"``\",\n\n helperType: jsonMode ? \"json\" : \"javascript\",\n jsonldMode: jsonldMode,\n jsonMode: jsonMode,\n\n expressionAllowed: expressionAllowed,\n\n skipExpression: function(state) {\n var top = state.cc[state.cc.length - 1]\n if (top == expression || top == expressionNoComma) state.cc.pop()\n }\n };\n});\n\nCodeMirror.registerHelper(\"wordChars\", \"javascript\", /[\\w$]/);\n\nCodeMirror.defineMIME(\"text/javascript\", \"javascript\");\nCodeMirror.defineMIME(\"text/ecmascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/javascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/x-javascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/ecmascript\", \"javascript\");\nCodeMirror.defineMIME(\"application/json\", {name: \"javascript\", json: true});\nCodeMirror.defineMIME(\"application/x-json\", {name: \"javascript\", json: true});\nCodeMirror.defineMIME(\"application/ld+json\", {name: \"javascript\", jsonld: true});\nCodeMirror.defineMIME(\"text/typescript\", { name: \"javascript\", typescript: true });\nCodeMirror.defineMIME(\"application/typescript\", { name: \"javascript\", typescript: true });\n\n});\n","import { Elm } from \"./src/Main.elm\";\nimport { migrate } from \"@mapbox/mapbox-gl-style-spec\";\nimport deref from \"@mapbox/mapbox-gl-style-spec/migrate/v9\"\nimport CodeMirror from \"codemirror/lib/codemirror.js\";\nimport \"codemirror/lib/codemirror.css\";\nimport \"codemirror/theme/base16-light.css\";\nimport \"codemirror/mode/elm/elm.js\";\nimport \"codemirror/mode/javascript/javascript.js\";\n\nvar app = Elm.Main.init({});\n\ncustomElements.define(\n \"code-editor\",\n class extends HTMLElement {\n constructor() {\n super();\n this._editorValue = \"\";\n }\n\n get editorValue() {\n return this._editorValue;\n }\n\n set editorValue(value) {\n if (this._editorValue === value) return;\n this._editorValue = value;\n if (!this._editor) return;\n this._editor.setValue(value);\n }\n\n get readonly() {\n return this._readonly;\n }\n\n set readonly(value) {\n this._readonly = value;\n if (!this._editor) return;\n this._editor.setOption('readonly', value);\n }\n\n get mode() {\n return this._mode;\n }\n\n set mode(value) {\n this._mode = value;\n if (!this._editor) return;\n this._editor.setOption('mode', value);\n }\n\n connectedCallback() {\n this._editor = CodeMirror(this, {\n identUnit: 4,\n mode: this._mode,\n lineNumbers: true,\n value: this._editorValue,\n readOnly: this._readonly,\n lineWrapping: true\n });\n\n this._editor.on(\"changes\", () => {\n this._editorValue = this._editor.getValue();\n console.log(\"changes\", this._editorValue)\n this.dispatchEvent(new CustomEvent(\"editorChanged\", {detail: this._editorValue}));\n });\n\n const {width, height} = this.getBoundingClientRect()\n this._editor.setSize(width, height);\n }\n }\n);\n\napp.ports.requestStyleUpgrade.subscribe(style => {\n try {\n const migrated = deref(migrate(JSON.parse(style)));\n app.ports.styleUpgradeComplete.send({type: 'Ok', result: migrated});\n } catch(error) {\n app.ports.styleUpgradeComplete.send({type: 'Err', error});\n }\n\n});\n"]}
|