-
Notifications
You must be signed in to change notification settings - Fork 0
/
editor.worker.js.map
1 lines (1 loc) · 826 KB
/
editor.worker.js.map
1
{"version":3,"file":"editor.worker.js","mappings":"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","sources":["../webpack/bootstrap","../webpack/runtime/global","../node_modules/monaco-editor/esm/vs/base/common/errors.js","../node_modules/monaco-editor/esm/vs/base/common/functional.js","../node_modules/monaco-editor/esm/vs/base/common/iterator.js","../node_modules/monaco-editor/esm/vs/base/common/lifecycle.js","../node_modules/monaco-editor/esm/vs/base/common/linkedList.js","../node_modules/monaco-editor/esm/vs/nls.js","../node_modules/monaco-editor/esm/vs/base/common/platform.js","../node_modules/monaco-editor/esm/vs/base/common/stopwatch.js","../node_modules/monaco-editor/esm/vs/base/common/event.js","../node_modules/monaco-editor/esm/vs/base/common/types.js","../node_modules/monaco-editor/esm/vs/base/common/lazy.js","../node_modules/monaco-editor/esm/vs/base/common/strings.js","../node_modules/monaco-editor/esm/vs/base/common/cache.js","../node_modules/monaco-editor/esm/vs/base/common/worker/simpleWorker.js","../node_modules/monaco-editor/esm/vs/base/common/process.js","../node_modules/monaco-editor/esm/vs/base/common/diff/diffChange.js","../node_modules/monaco-editor/esm/vs/base/common/hash.js","../node_modules/monaco-editor/esm/vs/base/common/diff/diff.js","../node_modules/monaco-editor/esm/vs/base/common/path.js","../node_modules/monaco-editor/esm/vs/base/common/uri.js","../node_modules/monaco-editor/esm/vs/editor/common/core/position.js","../node_modules/monaco-editor/esm/vs/editor/common/core/range.js","../node_modules/monaco-editor/esm/vs/editor/common/diff/diffComputer.js","../node_modules/monaco-editor/esm/vs/base/common/arrays.js","../node_modules/monaco-editor/esm/vs/base/common/uint.js","../node_modules/monaco-editor/esm/vs/editor/common/model/prefixSumComputer.js","../node_modules/monaco-editor/esm/vs/editor/common/core/wordHelper.js","../node_modules/monaco-editor/esm/vs/editor/common/core/characterClassifier.js","../node_modules/monaco-editor/esm/vs/editor/common/languages/linkComputer.js","../node_modules/monaco-editor/esm/vs/editor/common/languages/supports/inplaceReplaceSupport.js","../node_modules/monaco-editor/esm/vs/base/common/cancellation.js","../node_modules/monaco-editor/esm/vs/base/common/keyCodes.js","../node_modules/monaco-editor/esm/vs/base/common/codicons.js","../node_modules/monaco-editor/esm/vs/editor/common/core/selection.js","../node_modules/monaco-editor/esm/vs/editor/common/tokenizationRegistry.js","../node_modules/monaco-editor/esm/vs/editor/common/languages.js","../node_modules/monaco-editor/esm/vs/editor/common/standalone/standaloneEnums.js","../node_modules/monaco-editor/esm/vs/editor/common/services/editorBaseApi.js","../node_modules/monaco-editor/esm/vs/editor/common/core/wordCharacterClassifier.js","../node_modules/monaco-editor/esm/vs/base/common/objects.js","../node_modules/monaco-editor/esm/vs/editor/common/model.js","../node_modules/monaco-editor/esm/vs/editor/common/model/textModelSearch.js","../node_modules/monaco-editor/esm/vs/editor/common/services/unicodeTextModelHighlighter.js","../node_modules/monaco-editor/esm/vs/editor/common/services/editorSimpleWorker.js","../node_modules/monaco-editor/esm/vs/editor/common/model/mirrorTextModel.js","../node_modules/monaco-editor/esm/vs/editor/editor.worker.js"],"sourcesContent":["// The require scope\nvar __webpack_require__ = {};\n\n","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n// Avoid circular dependency on EventEmitter by implementing a subset of the interface.\nexport class ErrorHandler {\n constructor() {\n this.listeners = [];\n this.unexpectedErrorHandler = function (e) {\n setTimeout(() => {\n if (e.stack) {\n if (ErrorNoTelemetry.isErrorNoTelemetry(e)) {\n throw new ErrorNoTelemetry(e.message + '\\n\\n' + e.stack);\n }\n throw new Error(e.message + '\\n\\n' + e.stack);\n }\n throw e;\n }, 0);\n };\n }\n emit(e) {\n this.listeners.forEach((listener) => {\n listener(e);\n });\n }\n onUnexpectedError(e) {\n this.unexpectedErrorHandler(e);\n this.emit(e);\n }\n // For external errors, we don't want the listeners to be called\n onUnexpectedExternalError(e) {\n this.unexpectedErrorHandler(e);\n }\n}\nexport const errorHandler = new ErrorHandler();\nexport function onUnexpectedError(e) {\n // ignore errors from cancelled promises\n if (!isCancellationError(e)) {\n errorHandler.onUnexpectedError(e);\n }\n return undefined;\n}\nexport function onUnexpectedExternalError(e) {\n // ignore errors from cancelled promises\n if (!isCancellationError(e)) {\n errorHandler.onUnexpectedExternalError(e);\n }\n return undefined;\n}\nexport function transformErrorForSerialization(error) {\n if (error instanceof Error) {\n const { name, message } = error;\n const stack = error.stacktrace || error.stack;\n return {\n $isError: true,\n name,\n message,\n stack,\n noTelemetry: ErrorNoTelemetry.isErrorNoTelemetry(error)\n };\n }\n // return as is\n return error;\n}\nconst canceledName = 'Canceled';\n/**\n * Checks if the given error is a promise in canceled state\n */\nexport function isCancellationError(error) {\n if (error instanceof CancellationError) {\n return true;\n }\n return error instanceof Error && error.name === canceledName && error.message === canceledName;\n}\n// !!!IMPORTANT!!!\n// Do NOT change this class because it is also used as an API-type.\nexport class CancellationError extends Error {\n constructor() {\n super(canceledName);\n this.name = this.message;\n }\n}\n/**\n * @deprecated use {@link CancellationError `new CancellationError()`} instead\n */\nexport function canceled() {\n const error = new Error(canceledName);\n error.name = error.message;\n return error;\n}\nexport function illegalArgument(name) {\n if (name) {\n return new Error(`Illegal argument: ${name}`);\n }\n else {\n return new Error('Illegal argument');\n }\n}\nexport function illegalState(name) {\n if (name) {\n return new Error(`Illegal state: ${name}`);\n }\n else {\n return new Error('Illegal state');\n }\n}\nexport class NotSupportedError extends Error {\n constructor(message) {\n super('NotSupported');\n if (message) {\n this.message = message;\n }\n }\n}\n/**\n * Error that when thrown won't be logged in telemetry as an unhandled error.\n */\nexport class ErrorNoTelemetry extends Error {\n constructor(msg) {\n super(msg);\n this.name = 'ErrorNoTelemetry';\n }\n static fromError(err) {\n if (err instanceof ErrorNoTelemetry) {\n return err;\n }\n const result = new ErrorNoTelemetry();\n result.message = err.message;\n result.stack = err.stack;\n return result;\n }\n static isErrorNoTelemetry(err) {\n return err.name === 'ErrorNoTelemetry';\n }\n}\n/**\n * This error indicates a bug.\n * Do not throw this for invalid user input.\n * Only catch this error to recover gracefully from bugs.\n */\nexport class BugIndicatingError extends Error {\n constructor(message) {\n super(message || 'An unexpected bug occurred.');\n Object.setPrototypeOf(this, BugIndicatingError.prototype);\n // Because we know for sure only buggy code throws this,\n // we definitely want to break here and fix the bug.\n // eslint-disable-next-line no-debugger\n debugger;\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nexport function once(fn) {\n const _this = this;\n let didCall = false;\n let result;\n return function () {\n if (didCall) {\n return result;\n }\n didCall = true;\n result = fn.apply(_this, arguments);\n return result;\n };\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nexport var Iterable;\n(function (Iterable) {\n function is(thing) {\n return thing && typeof thing === 'object' && typeof thing[Symbol.iterator] === 'function';\n }\n Iterable.is = is;\n const _empty = Object.freeze([]);\n function empty() {\n return _empty;\n }\n Iterable.empty = empty;\n function* single(element) {\n yield element;\n }\n Iterable.single = single;\n function from(iterable) {\n return iterable || _empty;\n }\n Iterable.from = from;\n function isEmpty(iterable) {\n return !iterable || iterable[Symbol.iterator]().next().done === true;\n }\n Iterable.isEmpty = isEmpty;\n function first(iterable) {\n return iterable[Symbol.iterator]().next().value;\n }\n Iterable.first = first;\n function some(iterable, predicate) {\n for (const element of iterable) {\n if (predicate(element)) {\n return true;\n }\n }\n return false;\n }\n Iterable.some = some;\n function find(iterable, predicate) {\n for (const element of iterable) {\n if (predicate(element)) {\n return element;\n }\n }\n return undefined;\n }\n Iterable.find = find;\n function* filter(iterable, predicate) {\n for (const element of iterable) {\n if (predicate(element)) {\n yield element;\n }\n }\n }\n Iterable.filter = filter;\n function* map(iterable, fn) {\n let index = 0;\n for (const element of iterable) {\n yield fn(element, index++);\n }\n }\n Iterable.map = map;\n function* concat(...iterables) {\n for (const iterable of iterables) {\n for (const element of iterable) {\n yield element;\n }\n }\n }\n Iterable.concat = concat;\n function* concatNested(iterables) {\n for (const iterable of iterables) {\n for (const element of iterable) {\n yield element;\n }\n }\n }\n Iterable.concatNested = concatNested;\n function reduce(iterable, reducer, initialValue) {\n let value = initialValue;\n for (const element of iterable) {\n value = reducer(value, element);\n }\n return value;\n }\n Iterable.reduce = reduce;\n function forEach(iterable, fn) {\n let index = 0;\n for (const element of iterable) {\n fn(element, index++);\n }\n }\n Iterable.forEach = forEach;\n /**\n * Returns an iterable slice of the array, with the same semantics as `array.slice()`.\n */\n function* slice(arr, from, to = arr.length) {\n if (from < 0) {\n from += arr.length;\n }\n if (to < 0) {\n to += arr.length;\n }\n else if (to > arr.length) {\n to = arr.length;\n }\n for (; from < to; from++) {\n yield arr[from];\n }\n }\n Iterable.slice = slice;\n /**\n * Consumes `atMost` elements from iterable and returns the consumed elements,\n * and an iterable for the rest of the elements.\n */\n function consume(iterable, atMost = Number.POSITIVE_INFINITY) {\n const consumed = [];\n if (atMost === 0) {\n return [consumed, iterable];\n }\n const iterator = iterable[Symbol.iterator]();\n for (let i = 0; i < atMost; i++) {\n const next = iterator.next();\n if (next.done) {\n return [consumed, Iterable.empty()];\n }\n consumed.push(next.value);\n }\n return [consumed, { [Symbol.iterator]() { return iterator; } }];\n }\n Iterable.consume = consume;\n /**\n * Consumes `atMost` elements from iterable and returns the consumed elements,\n * and an iterable for the rest of the elements.\n */\n function collect(iterable) {\n return consume(iterable)[0];\n }\n Iterable.collect = collect;\n /**\n * Returns whether the iterables are the same length and all items are\n * equal using the comparator function.\n */\n function equals(a, b, comparator = (at, bt) => at === bt) {\n const ai = a[Symbol.iterator]();\n const bi = b[Symbol.iterator]();\n while (true) {\n const an = ai.next();\n const bn = bi.next();\n if (an.done !== bn.done) {\n return false;\n }\n else if (an.done) {\n return true;\n }\n else if (!comparator(an.value, bn.value)) {\n return false;\n }\n }\n }\n Iterable.equals = equals;\n})(Iterable || (Iterable = {}));\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { once } from './functional.js';\nimport { Iterable } from './iterator.js';\n/**\n * Enables logging of potentially leaked disposables.\n *\n * A disposable is considered leaked if it is not disposed or not registered as the child of\n * another disposable. This tracking is very simple an only works for classes that either\n * extend Disposable or use a DisposableStore. This means there are a lot of false positives.\n */\nconst TRACK_DISPOSABLES = false;\nlet disposableTracker = null;\nexport function setDisposableTracker(tracker) {\n disposableTracker = tracker;\n}\nif (TRACK_DISPOSABLES) {\n const __is_disposable_tracked__ = '__is_disposable_tracked__';\n setDisposableTracker(new class {\n trackDisposable(x) {\n const stack = new Error('Potentially leaked disposable').stack;\n setTimeout(() => {\n if (!x[__is_disposable_tracked__]) {\n console.log(stack);\n }\n }, 3000);\n }\n setParent(child, parent) {\n if (child && child !== Disposable.None) {\n try {\n child[__is_disposable_tracked__] = true;\n }\n catch (_a) {\n // noop\n }\n }\n }\n markAsDisposed(disposable) {\n if (disposable && disposable !== Disposable.None) {\n try {\n disposable[__is_disposable_tracked__] = true;\n }\n catch (_a) {\n // noop\n }\n }\n }\n markAsSingleton(disposable) { }\n });\n}\nfunction trackDisposable(x) {\n disposableTracker === null || disposableTracker === void 0 ? void 0 : disposableTracker.trackDisposable(x);\n return x;\n}\nfunction markAsDisposed(disposable) {\n disposableTracker === null || disposableTracker === void 0 ? void 0 : disposableTracker.markAsDisposed(disposable);\n}\nfunction setParentOfDisposable(child, parent) {\n disposableTracker === null || disposableTracker === void 0 ? void 0 : disposableTracker.setParent(child, parent);\n}\nfunction setParentOfDisposables(children, parent) {\n if (!disposableTracker) {\n return;\n }\n for (const child of children) {\n disposableTracker.setParent(child, parent);\n }\n}\n/**\n * Indicates that the given object is a singleton which does not need to be disposed.\n*/\nexport function markAsSingleton(singleton) {\n disposableTracker === null || disposableTracker === void 0 ? void 0 : disposableTracker.markAsSingleton(singleton);\n return singleton;\n}\nexport class MultiDisposeError extends Error {\n constructor(errors) {\n super(`Encountered errors while disposing of store. Errors: [${errors.join(', ')}]`);\n this.errors = errors;\n }\n}\nexport function isDisposable(thing) {\n return typeof thing.dispose === 'function' && thing.dispose.length === 0;\n}\nexport function dispose(arg) {\n if (Iterable.is(arg)) {\n const errors = [];\n for (const d of arg) {\n if (d) {\n try {\n d.dispose();\n }\n catch (e) {\n errors.push(e);\n }\n }\n }\n if (errors.length === 1) {\n throw errors[0];\n }\n else if (errors.length > 1) {\n throw new MultiDisposeError(errors);\n }\n return Array.isArray(arg) ? [] : arg;\n }\n else if (arg) {\n arg.dispose();\n return arg;\n }\n}\nexport function combinedDisposable(...disposables) {\n const parent = toDisposable(() => dispose(disposables));\n setParentOfDisposables(disposables, parent);\n return parent;\n}\nexport function toDisposable(fn) {\n const self = trackDisposable({\n dispose: once(() => {\n markAsDisposed(self);\n fn();\n })\n });\n return self;\n}\nexport class DisposableStore {\n constructor() {\n this._toDispose = new Set();\n this._isDisposed = false;\n trackDisposable(this);\n }\n /**\n * Dispose of all registered disposables and mark this object as disposed.\n *\n * Any future disposables added to this object will be disposed of on `add`.\n */\n dispose() {\n if (this._isDisposed) {\n return;\n }\n markAsDisposed(this);\n this._isDisposed = true;\n this.clear();\n }\n /**\n * Returns `true` if this object has been disposed\n */\n get isDisposed() {\n return this._isDisposed;\n }\n /**\n * Dispose of all registered disposables but do not mark this object as disposed.\n */\n clear() {\n try {\n dispose(this._toDispose.values());\n }\n finally {\n this._toDispose.clear();\n }\n }\n add(o) {\n if (!o) {\n return o;\n }\n if (o === this) {\n throw new Error('Cannot register a disposable on itself!');\n }\n setParentOfDisposable(o, this);\n if (this._isDisposed) {\n if (!DisposableStore.DISABLE_DISPOSED_WARNING) {\n console.warn(new Error('Trying to add a disposable to a DisposableStore that has already been disposed of. The added object will be leaked!').stack);\n }\n }\n else {\n this._toDispose.add(o);\n }\n return o;\n }\n}\nDisposableStore.DISABLE_DISPOSED_WARNING = false;\nexport class Disposable {\n constructor() {\n this._store = new DisposableStore();\n trackDisposable(this);\n setParentOfDisposable(this._store, this);\n }\n dispose() {\n markAsDisposed(this);\n this._store.dispose();\n }\n _register(o) {\n if (o === this) {\n throw new Error('Cannot register a disposable on itself!');\n }\n return this._store.add(o);\n }\n}\nDisposable.None = Object.freeze({ dispose() { } });\n/**\n * Manages the lifecycle of a disposable value that may be changed.\n *\n * This ensures that when the disposable value is changed, the previously held disposable is disposed of. You can\n * also register a `MutableDisposable` on a `Disposable` to ensure it is automatically cleaned up.\n */\nexport class MutableDisposable {\n constructor() {\n this._isDisposed = false;\n trackDisposable(this);\n }\n get value() {\n return this._isDisposed ? undefined : this._value;\n }\n set value(value) {\n var _a;\n if (this._isDisposed || value === this._value) {\n return;\n }\n (_a = this._value) === null || _a === void 0 ? void 0 : _a.dispose();\n if (value) {\n setParentOfDisposable(value, this);\n }\n this._value = value;\n }\n clear() {\n this.value = undefined;\n }\n dispose() {\n var _a;\n this._isDisposed = true;\n markAsDisposed(this);\n (_a = this._value) === null || _a === void 0 ? void 0 : _a.dispose();\n this._value = undefined;\n }\n /**\n * Clears the value, but does not dispose it.\n * The old value is returned.\n */\n clearAndLeak() {\n const oldValue = this._value;\n this._value = undefined;\n if (oldValue) {\n setParentOfDisposable(oldValue, null);\n }\n return oldValue;\n }\n}\nexport class RefCountedDisposable {\n constructor(_disposable) {\n this._disposable = _disposable;\n this._counter = 1;\n }\n acquire() {\n this._counter++;\n return this;\n }\n release() {\n if (--this._counter === 0) {\n this._disposable.dispose();\n }\n return this;\n }\n}\n/**\n * A safe disposable can be `unset` so that a leaked reference (listener)\n * can be cut-off.\n */\nexport class SafeDisposable {\n constructor() {\n this.dispose = () => { };\n this.unset = () => { };\n this.isset = () => false;\n trackDisposable(this);\n }\n set(fn) {\n let callback = fn;\n this.unset = () => callback = undefined;\n this.isset = () => callback !== undefined;\n this.dispose = () => {\n if (callback) {\n callback();\n callback = undefined;\n markAsDisposed(this);\n }\n };\n return this;\n }\n}\nexport class ImmortalReference {\n constructor(object) {\n this.object = object;\n }\n dispose() { }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nclass Node {\n constructor(element) {\n this.element = element;\n this.next = Node.Undefined;\n this.prev = Node.Undefined;\n }\n}\nNode.Undefined = new Node(undefined);\nexport class LinkedList {\n constructor() {\n this._first = Node.Undefined;\n this._last = Node.Undefined;\n this._size = 0;\n }\n get size() {\n return this._size;\n }\n isEmpty() {\n return this._first === Node.Undefined;\n }\n clear() {\n let node = this._first;\n while (node !== Node.Undefined) {\n const next = node.next;\n node.prev = Node.Undefined;\n node.next = Node.Undefined;\n node = next;\n }\n this._first = Node.Undefined;\n this._last = Node.Undefined;\n this._size = 0;\n }\n unshift(element) {\n return this._insert(element, false);\n }\n push(element) {\n return this._insert(element, true);\n }\n _insert(element, atTheEnd) {\n const newNode = new Node(element);\n if (this._first === Node.Undefined) {\n this._first = newNode;\n this._last = newNode;\n }\n else if (atTheEnd) {\n // push\n const oldLast = this._last;\n this._last = newNode;\n newNode.prev = oldLast;\n oldLast.next = newNode;\n }\n else {\n // unshift\n const oldFirst = this._first;\n this._first = newNode;\n newNode.next = oldFirst;\n oldFirst.prev = newNode;\n }\n this._size += 1;\n let didRemove = false;\n return () => {\n if (!didRemove) {\n didRemove = true;\n this._remove(newNode);\n }\n };\n }\n shift() {\n if (this._first === Node.Undefined) {\n return undefined;\n }\n else {\n const res = this._first.element;\n this._remove(this._first);\n return res;\n }\n }\n pop() {\n if (this._last === Node.Undefined) {\n return undefined;\n }\n else {\n const res = this._last.element;\n this._remove(this._last);\n return res;\n }\n }\n _remove(node) {\n if (node.prev !== Node.Undefined && node.next !== Node.Undefined) {\n // middle\n const anchor = node.prev;\n anchor.next = node.next;\n node.next.prev = anchor;\n }\n else if (node.prev === Node.Undefined && node.next === Node.Undefined) {\n // only node\n this._first = Node.Undefined;\n this._last = Node.Undefined;\n }\n else if (node.next === Node.Undefined) {\n // last\n this._last = this._last.prev;\n this._last.next = Node.Undefined;\n }\n else if (node.prev === Node.Undefined) {\n // first\n this._first = this._first.next;\n this._first.prev = Node.Undefined;\n }\n // done\n this._size -= 1;\n }\n *[Symbol.iterator]() {\n let node = this._first;\n while (node !== Node.Undefined) {\n yield node.element;\n node = node.next;\n }\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nlet isPseudo = (typeof document !== 'undefined' && document.location && document.location.hash.indexOf('pseudo=true') >= 0);\nconst DEFAULT_TAG = 'i-default';\nfunction _format(message, args) {\n let result;\n if (args.length === 0) {\n result = message;\n }\n else {\n result = message.replace(/\\{(\\d+)\\}/g, (match, rest) => {\n const index = rest[0];\n const arg = args[index];\n let result = match;\n if (typeof arg === 'string') {\n result = arg;\n }\n else if (typeof arg === 'number' || typeof arg === 'boolean' || arg === void 0 || arg === null) {\n result = String(arg);\n }\n return result;\n });\n }\n if (isPseudo) {\n // FF3B and FF3D is the Unicode zenkaku representation for [ and ]\n result = '\\uFF3B' + result.replace(/[aouei]/g, '$&$&') + '\\uFF3D';\n }\n return result;\n}\nfunction findLanguageForModule(config, name) {\n let result = config[name];\n if (result) {\n return result;\n }\n result = config['*'];\n if (result) {\n return result;\n }\n return null;\n}\nfunction endWithSlash(path) {\n if (path.charAt(path.length - 1) === '/') {\n return path;\n }\n return path + '/';\n}\nfunction getMessagesFromTranslationsService(translationServiceUrl, language, name) {\n return __awaiter(this, void 0, void 0, function* () {\n const url = endWithSlash(translationServiceUrl) + endWithSlash(language) + 'vscode/' + endWithSlash(name);\n const res = yield fetch(url);\n if (res.ok) {\n const messages = yield res.json();\n return messages;\n }\n throw new Error(`${res.status} - ${res.statusText}`);\n });\n}\nfunction createScopedLocalize(scope) {\n return function (idx, defaultValue) {\n const restArgs = Array.prototype.slice.call(arguments, 2);\n return _format(scope[idx], restArgs);\n };\n}\nexport function localize(data, message, ...args) {\n return _format(message, args);\n}\nexport function getConfiguredDefaultLocale(_) {\n // This returns undefined because this implementation isn't used and is overwritten by the loader\n // when loaded.\n return undefined;\n}\nexport function setPseudoTranslation(value) {\n isPseudo = value;\n}\n/**\n * Invoked in a built product at run-time\n */\nexport function create(key, data) {\n var _a;\n return {\n localize: createScopedLocalize(data[key]),\n getConfiguredDefaultLocale: (_a = data.getConfiguredDefaultLocale) !== null && _a !== void 0 ? _a : ((_) => undefined)\n };\n}\n/**\n * Invoked by the loader at run-time\n */\nexport function load(name, req, load, config) {\n var _a;\n const pluginConfig = (_a = config['vs/nls']) !== null && _a !== void 0 ? _a : {};\n if (!name || name.length === 0) {\n return load({\n localize: localize,\n getConfiguredDefaultLocale: () => { var _a; return (_a = pluginConfig.availableLanguages) === null || _a === void 0 ? void 0 : _a['*']; }\n });\n }\n const language = pluginConfig.availableLanguages ? findLanguageForModule(pluginConfig.availableLanguages, name) : null;\n const useDefaultLanguage = language === null || language === DEFAULT_TAG;\n let suffix = '.nls';\n if (!useDefaultLanguage) {\n suffix = suffix + '.' + language;\n }\n const messagesLoaded = (messages) => {\n if (Array.isArray(messages)) {\n messages.localize = createScopedLocalize(messages);\n }\n else {\n messages.localize = createScopedLocalize(messages[name]);\n }\n messages.getConfiguredDefaultLocale = () => { var _a; return (_a = pluginConfig.availableLanguages) === null || _a === void 0 ? void 0 : _a['*']; };\n load(messages);\n };\n if (typeof pluginConfig.loadBundle === 'function') {\n pluginConfig.loadBundle(name, language, (err, messages) => {\n // We have an error. Load the English default strings to not fail\n if (err) {\n req([name + '.nls'], messagesLoaded);\n }\n else {\n messagesLoaded(messages);\n }\n });\n }\n else if (pluginConfig.translationServiceUrl && !useDefaultLanguage) {\n (() => __awaiter(this, void 0, void 0, function* () {\n var _b;\n try {\n const messages = yield getMessagesFromTranslationsService(pluginConfig.translationServiceUrl, language, name);\n return messagesLoaded(messages);\n }\n catch (err) {\n // Language is already as generic as it gets, so require default messages\n if (!language.includes('-')) {\n console.error(err);\n return req([name + '.nls'], messagesLoaded);\n }\n try {\n // Since there is a dash, the language configured is a specific sub-language of the same generic language.\n // Since we were unable to load the specific language, try to load the generic language. Ex. we failed to find a\n // Swiss German (de-CH), so try to load the generic German (de) messages instead.\n const genericLanguage = language.split('-')[0];\n const messages = yield getMessagesFromTranslationsService(pluginConfig.translationServiceUrl, genericLanguage, name);\n // We got some messages, so we configure the configuration to use the generic language for this session.\n (_b = pluginConfig.availableLanguages) !== null && _b !== void 0 ? _b : (pluginConfig.availableLanguages = {});\n pluginConfig.availableLanguages['*'] = genericLanguage;\n return messagesLoaded(messages);\n }\n catch (err) {\n console.error(err);\n return req([name + '.nls'], messagesLoaded);\n }\n }\n }))();\n }\n else {\n req([name + suffix], messagesLoaded, (err) => {\n if (suffix === '.nls') {\n console.error('Failed trying to load default language strings', err);\n return;\n }\n console.error(`Failed to load message bundle for language ${language}. Falling back to the default language:`, err);\n req([name + '.nls'], messagesLoaded);\n });\n }\n}\n","var _a;\n/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport * as nls from '../../nls.js';\nconst LANGUAGE_DEFAULT = 'en';\nlet _isWindows = false;\nlet _isMacintosh = false;\nlet _isLinux = false;\nlet _isLinuxSnap = false;\nlet _isNative = false;\nlet _isWeb = false;\nlet _isElectron = false;\nlet _isIOS = false;\nlet _isCI = false;\nlet _locale = undefined;\nlet _language = LANGUAGE_DEFAULT;\nlet _translationsConfigFile = undefined;\nlet _userAgent = undefined;\nexport const globals = (typeof self === 'object' ? self : typeof global === 'object' ? global : {});\nlet nodeProcess = undefined;\nif (typeof globals.vscode !== 'undefined' && typeof globals.vscode.process !== 'undefined') {\n // Native environment (sandboxed)\n nodeProcess = globals.vscode.process;\n}\nelse if (typeof process !== 'undefined') {\n // Native environment (non-sandboxed)\n nodeProcess = process;\n}\nconst isElectronProcess = typeof ((_a = nodeProcess === null || nodeProcess === void 0 ? void 0 : nodeProcess.versions) === null || _a === void 0 ? void 0 : _a.electron) === 'string';\nconst isElectronRenderer = isElectronProcess && (nodeProcess === null || nodeProcess === void 0 ? void 0 : nodeProcess.type) === 'renderer';\n// Web environment\nif (typeof navigator === 'object' && !isElectronRenderer) {\n _userAgent = navigator.userAgent;\n _isWindows = _userAgent.indexOf('Windows') >= 0;\n _isMacintosh = _userAgent.indexOf('Macintosh') >= 0;\n _isIOS = (_userAgent.indexOf('Macintosh') >= 0 || _userAgent.indexOf('iPad') >= 0 || _userAgent.indexOf('iPhone') >= 0) && !!navigator.maxTouchPoints && navigator.maxTouchPoints > 0;\n _isLinux = _userAgent.indexOf('Linux') >= 0;\n _isWeb = true;\n const configuredLocale = nls.getConfiguredDefaultLocale(\n // This call _must_ be done in the file that calls `nls.getConfiguredDefaultLocale`\n // to ensure that the NLS AMD Loader plugin has been loaded and configured.\n // This is because the loader plugin decides what the default locale is based on\n // how it's able to resolve the strings.\n nls.localize({ key: 'ensureLoaderPluginIsLoaded', comment: ['{Locked}'] }, '_'));\n _locale = configuredLocale || LANGUAGE_DEFAULT;\n _language = _locale;\n}\n// Native environment\nelse if (typeof nodeProcess === 'object') {\n _isWindows = (nodeProcess.platform === 'win32');\n _isMacintosh = (nodeProcess.platform === 'darwin');\n _isLinux = (nodeProcess.platform === 'linux');\n _isLinuxSnap = _isLinux && !!nodeProcess.env['SNAP'] && !!nodeProcess.env['SNAP_REVISION'];\n _isElectron = isElectronProcess;\n _isCI = !!nodeProcess.env['CI'] || !!nodeProcess.env['BUILD_ARTIFACTSTAGINGDIRECTORY'];\n _locale = LANGUAGE_DEFAULT;\n _language = LANGUAGE_DEFAULT;\n const rawNlsConfig = nodeProcess.env['VSCODE_NLS_CONFIG'];\n if (rawNlsConfig) {\n try {\n const nlsConfig = JSON.parse(rawNlsConfig);\n const resolved = nlsConfig.availableLanguages['*'];\n _locale = nlsConfig.locale;\n // VSCode's default language is 'en'\n _language = resolved ? resolved : LANGUAGE_DEFAULT;\n _translationsConfigFile = nlsConfig._translationsConfigFile;\n }\n catch (e) {\n }\n }\n _isNative = true;\n}\n// Unknown environment\nelse {\n console.error('Unable to resolve platform.');\n}\nlet _platform = 0 /* Platform.Web */;\nif (_isMacintosh) {\n _platform = 1 /* Platform.Mac */;\n}\nelse if (_isWindows) {\n _platform = 3 /* Platform.Windows */;\n}\nelse if (_isLinux) {\n _platform = 2 /* Platform.Linux */;\n}\nexport const isWindows = _isWindows;\nexport const isMacintosh = _isMacintosh;\nexport const isLinux = _isLinux;\nexport const isNative = _isNative;\nexport const isWeb = _isWeb;\nexport const isWebWorker = (_isWeb && typeof globals.importScripts === 'function');\nexport const isIOS = _isIOS;\nexport const userAgent = _userAgent;\n/**\n * The language used for the user interface. The format of\n * the string is all lower case (e.g. zh-tw for Traditional\n * Chinese)\n */\nexport const language = _language;\nexport const setTimeout0IsFaster = (typeof globals.postMessage === 'function' && !globals.importScripts);\n/**\n * See https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#:~:text=than%204%2C%20then-,set%20timeout%20to%204,-.\n *\n * Works similarly to `setTimeout(0)` but doesn't suffer from the 4ms artificial delay\n * that browsers set when the nesting level is > 5.\n */\nexport const setTimeout0 = (() => {\n if (setTimeout0IsFaster) {\n const pending = [];\n globals.addEventListener('message', (e) => {\n if (e.data && e.data.vscodeScheduleAsyncWork) {\n for (let i = 0, len = pending.length; i < len; i++) {\n const candidate = pending[i];\n if (candidate.id === e.data.vscodeScheduleAsyncWork) {\n pending.splice(i, 1);\n candidate.callback();\n return;\n }\n }\n }\n });\n let lastId = 0;\n return (callback) => {\n const myId = ++lastId;\n pending.push({\n id: myId,\n callback: callback\n });\n globals.postMessage({ vscodeScheduleAsyncWork: myId }, '*');\n };\n }\n return (callback) => setTimeout(callback);\n})();\nexport const OS = (_isMacintosh || _isIOS ? 2 /* OperatingSystem.Macintosh */ : (_isWindows ? 1 /* OperatingSystem.Windows */ : 3 /* OperatingSystem.Linux */));\nlet _isLittleEndian = true;\nlet _isLittleEndianComputed = false;\nexport function isLittleEndian() {\n if (!_isLittleEndianComputed) {\n _isLittleEndianComputed = true;\n const test = new Uint8Array(2);\n test[0] = 1;\n test[1] = 2;\n const view = new Uint16Array(test.buffer);\n _isLittleEndian = (view[0] === (2 << 8) + 1);\n }\n return _isLittleEndian;\n}\nexport const isChrome = !!(userAgent && userAgent.indexOf('Chrome') >= 0);\nexport const isFirefox = !!(userAgent && userAgent.indexOf('Firefox') >= 0);\nexport const isSafari = !!(!isChrome && (userAgent && userAgent.indexOf('Safari') >= 0));\nexport const isEdge = !!(userAgent && userAgent.indexOf('Edg/') >= 0);\nexport const isAndroid = !!(userAgent && userAgent.indexOf('Android') >= 0);\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { globals } from './platform.js';\nconst hasPerformanceNow = (globals.performance && typeof globals.performance.now === 'function');\nexport class StopWatch {\n constructor(highResolution) {\n this._highResolution = hasPerformanceNow && highResolution;\n this._startTime = this._now();\n this._stopTime = -1;\n }\n static create(highResolution = true) {\n return new StopWatch(highResolution);\n }\n stop() {\n this._stopTime = this._now();\n }\n elapsed() {\n if (this._stopTime !== -1) {\n return this._stopTime - this._startTime;\n }\n return this._now() - this._startTime;\n }\n _now() {\n return this._highResolution ? globals.performance.now() : Date.now();\n }\n}\n","import { onUnexpectedError } from './errors.js';\nimport { combinedDisposable, Disposable, DisposableStore, SafeDisposable, toDisposable } from './lifecycle.js';\nimport { LinkedList } from './linkedList.js';\nimport { StopWatch } from './stopwatch.js';\n// -----------------------------------------------------------------------------------------------------------------------\n// Uncomment the next line to print warnings whenever an emitter with listeners is disposed. That is a sign of code smell.\n// -----------------------------------------------------------------------------------------------------------------------\nconst _enableDisposeWithListenerWarning = false;\n// _enableDisposeWithListenerWarning = Boolean(\"TRUE\"); // causes a linter warning so that it cannot be pushed\n// -----------------------------------------------------------------------------------------------------------------------\n// Uncomment the next line to print warnings whenever a snapshotted event is used repeatedly without cleanup.\n// See https://github.com/microsoft/vscode/issues/142851\n// -----------------------------------------------------------------------------------------------------------------------\nconst _enableSnapshotPotentialLeakWarning = false;\nexport var Event;\n(function (Event) {\n Event.None = () => Disposable.None;\n function _addLeakageTraceLogic(options) {\n if (_enableSnapshotPotentialLeakWarning) {\n const { onListenerDidAdd: origListenerDidAdd } = options;\n const stack = Stacktrace.create();\n let count = 0;\n options.onListenerDidAdd = () => {\n if (++count === 2) {\n console.warn('snapshotted emitter LIKELY used public and SHOULD HAVE BEEN created with DisposableStore. snapshotted here');\n stack.print();\n }\n origListenerDidAdd === null || origListenerDidAdd === void 0 ? void 0 : origListenerDidAdd();\n };\n }\n }\n /**\n * Given an event, returns another event which only fires once.\n */\n function once(event) {\n return (listener, thisArgs = null, disposables) => {\n // we need this, in case the event fires during the listener call\n let didFire = false;\n let result = undefined;\n result = event(e => {\n if (didFire) {\n return;\n }\n else if (result) {\n result.dispose();\n }\n else {\n didFire = true;\n }\n return listener.call(thisArgs, e);\n }, null, disposables);\n if (didFire) {\n result.dispose();\n }\n return result;\n };\n }\n Event.once = once;\n /**\n * *NOTE* that this function returns an `Event` and it MUST be called with a `DisposableStore` whenever the returned\n * event is accessible to \"third parties\", e.g the event is a public property. Otherwise a leaked listener on the\n * returned event causes this utility to leak a listener on the original event.\n */\n function map(event, map, disposable) {\n return snapshot((listener, thisArgs = null, disposables) => event(i => listener.call(thisArgs, map(i)), null, disposables), disposable);\n }\n Event.map = map;\n /**\n * *NOTE* that this function returns an `Event` and it MUST be called with a `DisposableStore` whenever the returned\n * event is accessible to \"third parties\", e.g the event is a public property. Otherwise a leaked listener on the\n * returned event causes this utility to leak a listener on the original event.\n */\n function forEach(event, each, disposable) {\n return snapshot((listener, thisArgs = null, disposables) => event(i => { each(i); listener.call(thisArgs, i); }, null, disposables), disposable);\n }\n Event.forEach = forEach;\n function filter(event, filter, disposable) {\n return snapshot((listener, thisArgs = null, disposables) => event(e => filter(e) && listener.call(thisArgs, e), null, disposables), disposable);\n }\n Event.filter = filter;\n /**\n * Given an event, returns the same event but typed as `Event<void>`.\n */\n function signal(event) {\n return event;\n }\n Event.signal = signal;\n function any(...events) {\n return (listener, thisArgs = null, disposables) => combinedDisposable(...events.map(event => event(e => listener.call(thisArgs, e), null, disposables)));\n }\n Event.any = any;\n /**\n * *NOTE* that this function returns an `Event` and it MUST be called with a `DisposableStore` whenever the returned\n * event is accessible to \"third parties\", e.g the event is a public property. Otherwise a leaked listener on the\n * returned event causes this utility to leak a listener on the original event.\n */\n function reduce(event, merge, initial, disposable) {\n let output = initial;\n return map(event, e => {\n output = merge(output, e);\n return output;\n }, disposable);\n }\n Event.reduce = reduce;\n function snapshot(event, disposable) {\n let listener;\n const options = {\n onFirstListenerAdd() {\n listener = event(emitter.fire, emitter);\n },\n onLastListenerRemove() {\n listener === null || listener === void 0 ? void 0 : listener.dispose();\n }\n };\n if (!disposable) {\n _addLeakageTraceLogic(options);\n }\n const emitter = new Emitter(options);\n disposable === null || disposable === void 0 ? void 0 : disposable.add(emitter);\n return emitter.event;\n }\n function debounce(event, merge, delay = 100, leading = false, leakWarningThreshold, disposable) {\n let subscription;\n let output = undefined;\n let handle = undefined;\n let numDebouncedCalls = 0;\n const options = {\n leakWarningThreshold,\n onFirstListenerAdd() {\n subscription = event(cur => {\n numDebouncedCalls++;\n output = merge(output, cur);\n if (leading && !handle) {\n emitter.fire(output);\n output = undefined;\n }\n clearTimeout(handle);\n handle = setTimeout(() => {\n const _output = output;\n output = undefined;\n handle = undefined;\n if (!leading || numDebouncedCalls > 1) {\n emitter.fire(_output);\n }\n numDebouncedCalls = 0;\n }, delay);\n });\n },\n onLastListenerRemove() {\n subscription.dispose();\n }\n };\n if (!disposable) {\n _addLeakageTraceLogic(options);\n }\n const emitter = new Emitter(options);\n disposable === null || disposable === void 0 ? void 0 : disposable.add(emitter);\n return emitter.event;\n }\n Event.debounce = debounce;\n /**\n * *NOTE* that this function returns an `Event` and it MUST be called with a `DisposableStore` whenever the returned\n * event is accessible to \"third parties\", e.g the event is a public property. Otherwise a leaked listener on the\n * returned event causes this utility to leak a listener on the original event.\n */\n function latch(event, equals = (a, b) => a === b, disposable) {\n let firstCall = true;\n let cache;\n return filter(event, value => {\n const shouldEmit = firstCall || !equals(value, cache);\n firstCall = false;\n cache = value;\n return shouldEmit;\n }, disposable);\n }\n Event.latch = latch;\n /**\n * *NOTE* that this function returns an `Event` and it MUST be called with a `DisposableStore` whenever the returned\n * event is accessible to \"third parties\", e.g the event is a public property. Otherwise a leaked listener on the\n * returned event causes this utility to leak a listener on the original event.\n */\n function split(event, isT, disposable) {\n return [\n Event.filter(event, isT, disposable),\n Event.filter(event, e => !isT(e), disposable),\n ];\n }\n Event.split = split;\n /**\n * *NOTE* that this function returns an `Event` and it MUST be called with a `DisposableStore` whenever the returned\n * event is accessible to \"third parties\", e.g the event is a public property. Otherwise a leaked listener on the\n * returned event causes this utility to leak a listener on the original event.\n */\n function buffer(event, flushAfterTimeout = false, _buffer = []) {\n let buffer = _buffer.slice();\n let listener = event(e => {\n if (buffer) {\n buffer.push(e);\n }\n else {\n emitter.fire(e);\n }\n });\n const flush = () => {\n buffer === null || buffer === void 0 ? void 0 : buffer.forEach(e => emitter.fire(e));\n buffer = null;\n };\n const emitter = new Emitter({\n onFirstListenerAdd() {\n if (!listener) {\n listener = event(e => emitter.fire(e));\n }\n },\n onFirstListenerDidAdd() {\n if (buffer) {\n if (flushAfterTimeout) {\n setTimeout(flush);\n }\n else {\n flush();\n }\n }\n },\n onLastListenerRemove() {\n if (listener) {\n listener.dispose();\n }\n listener = null;\n }\n });\n return emitter.event;\n }\n Event.buffer = buffer;\n class ChainableEvent {\n constructor(event) {\n this.event = event;\n this.disposables = new DisposableStore();\n }\n map(fn) {\n return new ChainableEvent(map(this.event, fn, this.disposables));\n }\n forEach(fn) {\n return new ChainableEvent(forEach(this.event, fn, this.disposables));\n }\n filter(fn) {\n return new ChainableEvent(filter(this.event, fn, this.disposables));\n }\n reduce(merge, initial) {\n return new ChainableEvent(reduce(this.event, merge, initial, this.disposables));\n }\n latch() {\n return new ChainableEvent(latch(this.event, undefined, this.disposables));\n }\n debounce(merge, delay = 100, leading = false, leakWarningThreshold) {\n return new ChainableEvent(debounce(this.event, merge, delay, leading, leakWarningThreshold, this.disposables));\n }\n on(listener, thisArgs, disposables) {\n return this.event(listener, thisArgs, disposables);\n }\n once(listener, thisArgs, disposables) {\n return once(this.event)(listener, thisArgs, disposables);\n }\n dispose() {\n this.disposables.dispose();\n }\n }\n function chain(event) {\n return new ChainableEvent(event);\n }\n Event.chain = chain;\n function fromNodeEventEmitter(emitter, eventName, map = id => id) {\n const fn = (...args) => result.fire(map(...args));\n const onFirstListenerAdd = () => emitter.on(eventName, fn);\n const onLastListenerRemove = () => emitter.removeListener(eventName, fn);\n const result = new Emitter({ onFirstListenerAdd, onLastListenerRemove });\n return result.event;\n }\n Event.fromNodeEventEmitter = fromNodeEventEmitter;\n function fromDOMEventEmitter(emitter, eventName, map = id => id) {\n const fn = (...args) => result.fire(map(...args));\n const onFirstListenerAdd = () => emitter.addEventListener(eventName, fn);\n const onLastListenerRemove = () => emitter.removeEventListener(eventName, fn);\n const result = new Emitter({ onFirstListenerAdd, onLastListenerRemove });\n return result.event;\n }\n Event.fromDOMEventEmitter = fromDOMEventEmitter;\n function toPromise(event) {\n return new Promise(resolve => once(event)(resolve));\n }\n Event.toPromise = toPromise;\n function runAndSubscribe(event, handler) {\n handler(undefined);\n return event(e => handler(e));\n }\n Event.runAndSubscribe = runAndSubscribe;\n function runAndSubscribeWithStore(event, handler) {\n let store = null;\n function run(e) {\n store === null || store === void 0 ? void 0 : store.dispose();\n store = new DisposableStore();\n handler(e, store);\n }\n run(undefined);\n const disposable = event(e => run(e));\n return toDisposable(() => {\n disposable.dispose();\n store === null || store === void 0 ? void 0 : store.dispose();\n });\n }\n Event.runAndSubscribeWithStore = runAndSubscribeWithStore;\n class EmitterObserver {\n constructor(obs, store) {\n this.obs = obs;\n this._counter = 0;\n this._hasChanged = false;\n const options = {\n onFirstListenerAdd: () => {\n obs.addObserver(this);\n },\n onLastListenerRemove: () => {\n obs.removeObserver(this);\n }\n };\n if (!store) {\n _addLeakageTraceLogic(options);\n }\n this.emitter = new Emitter(options);\n if (store) {\n store.add(this.emitter);\n }\n }\n beginUpdate(_observable) {\n // console.assert(_observable === this.obs);\n this._counter++;\n }\n handleChange(_observable, _change) {\n this._hasChanged = true;\n }\n endUpdate(_observable) {\n if (--this._counter === 0) {\n if (this._hasChanged) {\n this._hasChanged = false;\n this.emitter.fire(this.obs.get());\n }\n }\n }\n }\n function fromObservable(obs, store) {\n const observer = new EmitterObserver(obs, store);\n return observer.emitter.event;\n }\n Event.fromObservable = fromObservable;\n})(Event || (Event = {}));\nclass EventProfiling {\n constructor(name) {\n this._listenerCount = 0;\n this._invocationCount = 0;\n this._elapsedOverall = 0;\n this._name = `${name}_${EventProfiling._idPool++}`;\n }\n start(listenerCount) {\n this._stopWatch = new StopWatch(true);\n this._listenerCount = listenerCount;\n }\n stop() {\n if (this._stopWatch) {\n const elapsed = this._stopWatch.elapsed();\n this._elapsedOverall += elapsed;\n this._invocationCount += 1;\n console.info(`did FIRE ${this._name}: elapsed_ms: ${elapsed.toFixed(5)}, listener: ${this._listenerCount} (elapsed_overall: ${this._elapsedOverall.toFixed(2)}, invocations: ${this._invocationCount})`);\n this._stopWatch = undefined;\n }\n }\n}\nEventProfiling._idPool = 0;\nlet _globalLeakWarningThreshold = -1;\nclass LeakageMonitor {\n constructor(customThreshold, name = Math.random().toString(18).slice(2, 5)) {\n this.customThreshold = customThreshold;\n this.name = name;\n this._warnCountdown = 0;\n }\n dispose() {\n if (this._stacks) {\n this._stacks.clear();\n }\n }\n check(stack, listenerCount) {\n let threshold = _globalLeakWarningThreshold;\n if (typeof this.customThreshold === 'number') {\n threshold = this.customThreshold;\n }\n if (threshold <= 0 || listenerCount < threshold) {\n return undefined;\n }\n if (!this._stacks) {\n this._stacks = new Map();\n }\n const count = (this._stacks.get(stack.value) || 0);\n this._stacks.set(stack.value, count + 1);\n this._warnCountdown -= 1;\n if (this._warnCountdown <= 0) {\n // only warn on first exceed and then every time the limit\n // is exceeded by 50% again\n this._warnCountdown = threshold * 0.5;\n // find most frequent listener and print warning\n let topStack;\n let topCount = 0;\n for (const [stack, count] of this._stacks) {\n if (!topStack || topCount < count) {\n topStack = stack;\n topCount = count;\n }\n }\n console.warn(`[${this.name}] potential listener LEAK detected, having ${listenerCount} listeners already. MOST frequent listener (${topCount}):`);\n console.warn(topStack);\n }\n return () => {\n const count = (this._stacks.get(stack.value) || 0);\n this._stacks.set(stack.value, count - 1);\n };\n }\n}\nclass Stacktrace {\n constructor(value) {\n this.value = value;\n }\n static create() {\n var _a;\n return new Stacktrace((_a = new Error().stack) !== null && _a !== void 0 ? _a : '');\n }\n print() {\n console.warn(this.value.split('\\n').slice(2).join('\\n'));\n }\n}\nclass Listener {\n constructor(callback, callbackThis, stack) {\n this.callback = callback;\n this.callbackThis = callbackThis;\n this.stack = stack;\n this.subscription = new SafeDisposable();\n }\n invoke(e) {\n this.callback.call(this.callbackThis, e);\n }\n}\n/**\n * The Emitter can be used to expose an Event to the public\n * to fire it from the insides.\n * Sample:\n class Document {\n\n private readonly _onDidChange = new Emitter<(value:string)=>any>();\n\n public onDidChange = this._onDidChange.event;\n\n // getter-style\n // get onDidChange(): Event<(value:string)=>any> {\n // \treturn this._onDidChange.event;\n // }\n\n private _doIt() {\n //...\n this._onDidChange.fire(value);\n }\n }\n */\nexport class Emitter {\n constructor(options) {\n var _a, _b;\n this._disposed = false;\n this._options = options;\n this._leakageMon = _globalLeakWarningThreshold > 0 ? new LeakageMonitor(this._options && this._options.leakWarningThreshold) : undefined;\n this._perfMon = ((_a = this._options) === null || _a === void 0 ? void 0 : _a._profName) ? new EventProfiling(this._options._profName) : undefined;\n this._deliveryQueue = (_b = this._options) === null || _b === void 0 ? void 0 : _b.deliveryQueue;\n }\n dispose() {\n var _a, _b, _c, _d;\n if (!this._disposed) {\n this._disposed = true;\n // It is bad to have listeners at the time of disposing an emitter, it is worst to have listeners keep the emitter\n // alive via the reference that's embedded in their disposables. Therefore we loop over all remaining listeners and\n // unset their subscriptions/disposables. Looping and blaming remaining listeners is done on next tick because the\n // the following programming pattern is very popular:\n //\n // const someModel = this._disposables.add(new ModelObject()); // (1) create and register model\n // this._disposables.add(someModel.onDidChange(() => { ... }); // (2) subscribe and register model-event listener\n // ...later...\n // this._disposables.dispose(); disposes (1) then (2): don't warn after (1) but after the \"overall dispose\" is done\n if (this._listeners) {\n if (_enableDisposeWithListenerWarning) {\n const listeners = Array.from(this._listeners);\n queueMicrotask(() => {\n var _a;\n for (const listener of listeners) {\n if (listener.subscription.isset()) {\n listener.subscription.unset();\n (_a = listener.stack) === null || _a === void 0 ? void 0 : _a.print();\n }\n }\n });\n }\n this._listeners.clear();\n }\n (_a = this._deliveryQueue) === null || _a === void 0 ? void 0 : _a.clear(this);\n (_c = (_b = this._options) === null || _b === void 0 ? void 0 : _b.onLastListenerRemove) === null || _c === void 0 ? void 0 : _c.call(_b);\n (_d = this._leakageMon) === null || _d === void 0 ? void 0 : _d.dispose();\n }\n }\n /**\n * For the public to allow to subscribe\n * to events from this Emitter\n */\n get event() {\n if (!this._event) {\n this._event = (callback, thisArgs, disposables) => {\n var _a, _b, _c;\n if (!this._listeners) {\n this._listeners = new LinkedList();\n }\n const firstListener = this._listeners.isEmpty();\n if (firstListener && ((_a = this._options) === null || _a === void 0 ? void 0 : _a.onFirstListenerAdd)) {\n this._options.onFirstListenerAdd(this);\n }\n let removeMonitor;\n let stack;\n if (this._leakageMon && this._listeners.size >= 30) {\n // check and record this emitter for potential leakage\n stack = Stacktrace.create();\n removeMonitor = this._leakageMon.check(stack, this._listeners.size + 1);\n }\n if (_enableDisposeWithListenerWarning) {\n stack = stack !== null && stack !== void 0 ? stack : Stacktrace.create();\n }\n const listener = new Listener(callback, thisArgs, stack);\n const removeListener = this._listeners.push(listener);\n if (firstListener && ((_b = this._options) === null || _b === void 0 ? void 0 : _b.onFirstListenerDidAdd)) {\n this._options.onFirstListenerDidAdd(this);\n }\n if ((_c = this._options) === null || _c === void 0 ? void 0 : _c.onListenerDidAdd) {\n this._options.onListenerDidAdd(this, callback, thisArgs);\n }\n const result = listener.subscription.set(() => {\n removeMonitor === null || removeMonitor === void 0 ? void 0 : removeMonitor();\n if (!this._disposed) {\n removeListener();\n if (this._options && this._options.onLastListenerRemove) {\n const hasListeners = (this._listeners && !this._listeners.isEmpty());\n if (!hasListeners) {\n this._options.onLastListenerRemove(this);\n }\n }\n }\n });\n if (disposables instanceof DisposableStore) {\n disposables.add(result);\n }\n else if (Array.isArray(disposables)) {\n disposables.push(result);\n }\n return result;\n };\n }\n return this._event;\n }\n /**\n * To be kept private to fire an event to\n * subscribers\n */\n fire(event) {\n var _a, _b;\n if (this._listeners) {\n // put all [listener,event]-pairs into delivery queue\n // then emit all event. an inner/nested event might be\n // the driver of this\n if (!this._deliveryQueue) {\n this._deliveryQueue = new PrivateEventDeliveryQueue();\n }\n for (const listener of this._listeners) {\n this._deliveryQueue.push(this, listener, event);\n }\n // start/stop performance insight collection\n (_a = this._perfMon) === null || _a === void 0 ? void 0 : _a.start(this._deliveryQueue.size);\n this._deliveryQueue.deliver();\n (_b = this._perfMon) === null || _b === void 0 ? void 0 : _b.stop();\n }\n }\n}\nexport class EventDeliveryQueue {\n constructor() {\n this._queue = new LinkedList();\n }\n get size() {\n return this._queue.size;\n }\n push(emitter, listener, event) {\n this._queue.push(new EventDeliveryQueueElement(emitter, listener, event));\n }\n clear(emitter) {\n const newQueue = new LinkedList();\n for (const element of this._queue) {\n if (element.emitter !== emitter) {\n newQueue.push(element);\n }\n }\n this._queue = newQueue;\n }\n deliver() {\n while (this._queue.size > 0) {\n const element = this._queue.shift();\n try {\n element.listener.invoke(element.event);\n }\n catch (e) {\n onUnexpectedError(e);\n }\n }\n }\n}\n/**\n * An `EventDeliveryQueue` that is guaranteed to be used by a single `Emitter`.\n */\nclass PrivateEventDeliveryQueue extends EventDeliveryQueue {\n clear(emitter) {\n // Here we can just clear the entire linked list because\n // all elements are guaranteed to belong to this emitter\n this._queue.clear();\n }\n}\nclass EventDeliveryQueueElement {\n constructor(emitter, listener, event) {\n this.emitter = emitter;\n this.listener = listener;\n this.event = event;\n }\n}\nexport class PauseableEmitter extends Emitter {\n constructor(options) {\n super(options);\n this._isPaused = 0;\n this._eventQueue = new LinkedList();\n this._mergeFn = options === null || options === void 0 ? void 0 : options.merge;\n }\n pause() {\n this._isPaused++;\n }\n resume() {\n if (this._isPaused !== 0 && --this._isPaused === 0) {\n if (this._mergeFn) {\n // use the merge function to create a single composite\n // event. make a copy in case firing pauses this emitter\n const events = Array.from(this._eventQueue);\n this._eventQueue.clear();\n super.fire(this._mergeFn(events));\n }\n else {\n // no merging, fire each event individually and test\n // that this emitter isn't paused halfway through\n while (!this._isPaused && this._eventQueue.size !== 0) {\n super.fire(this._eventQueue.shift());\n }\n }\n }\n }\n fire(event) {\n if (this._listeners) {\n if (this._isPaused !== 0) {\n this._eventQueue.push(event);\n }\n else {\n super.fire(event);\n }\n }\n }\n}\nexport class DebounceEmitter extends PauseableEmitter {\n constructor(options) {\n var _a;\n super(options);\n this._delay = (_a = options.delay) !== null && _a !== void 0 ? _a : 100;\n }\n fire(event) {\n if (!this._handle) {\n this.pause();\n this._handle = setTimeout(() => {\n this._handle = undefined;\n this.resume();\n }, this._delay);\n }\n super.fire(event);\n }\n}\n/**\n * The EventBufferer is useful in situations in which you want\n * to delay firing your events during some code.\n * You can wrap that code and be sure that the event will not\n * be fired during that wrap.\n *\n * ```\n * const emitter: Emitter;\n * const delayer = new EventDelayer();\n * const delayedEvent = delayer.wrapEvent(emitter.event);\n *\n * delayedEvent(console.log);\n *\n * delayer.bufferEvents(() => {\n * emitter.fire(); // event will not be fired yet\n * });\n *\n * // event will only be fired at this point\n * ```\n */\nexport class EventBufferer {\n constructor() {\n this.buffers = [];\n }\n wrapEvent(event) {\n return (listener, thisArgs, disposables) => {\n return event(i => {\n const buffer = this.buffers[this.buffers.length - 1];\n if (buffer) {\n buffer.push(() => listener.call(thisArgs, i));\n }\n else {\n listener.call(thisArgs, i);\n }\n }, undefined, disposables);\n };\n }\n bufferEvents(fn) {\n const buffer = [];\n this.buffers.push(buffer);\n const r = fn();\n this.buffers.pop();\n buffer.forEach(flush => flush());\n return r;\n }\n}\n/**\n * A Relay is an event forwarder which functions as a replugabble event pipe.\n * Once created, you can connect an input event to it and it will simply forward\n * events from that input event through its own `event` property. The `input`\n * can be changed at any point in time.\n */\nexport class Relay {\n constructor() {\n this.listening = false;\n this.inputEvent = Event.None;\n this.inputEventListener = Disposable.None;\n this.emitter = new Emitter({\n onFirstListenerDidAdd: () => {\n this.listening = true;\n this.inputEventListener = this.inputEvent(this.emitter.fire, this.emitter);\n },\n onLastListenerRemove: () => {\n this.listening = false;\n this.inputEventListener.dispose();\n }\n });\n this.event = this.emitter.event;\n }\n set input(event) {\n this.inputEvent = event;\n if (this.listening) {\n this.inputEventListener.dispose();\n this.inputEventListener = event(this.emitter.fire, this.emitter);\n }\n }\n dispose() {\n this.inputEventListener.dispose();\n this.emitter.dispose();\n }\n}\n","/**\n * @returns whether the provided parameter is a JavaScript Array or not.\n */\nexport function isArray(array) {\n return Array.isArray(array);\n}\n/**\n * @returns whether the provided parameter is a JavaScript String or not.\n */\nexport function isString(str) {\n return (typeof str === 'string');\n}\n/**\n *\n * @returns whether the provided parameter is of type `object` but **not**\n *\t`null`, an `array`, a `regexp`, nor a `date`.\n */\nexport function isObject(obj) {\n // The method can't do a type cast since there are type (like strings) which\n // are subclasses of any put not positvely matched by the function. Hence type\n // narrowing results in wrong results.\n return typeof obj === 'object'\n && obj !== null\n && !Array.isArray(obj)\n && !(obj instanceof RegExp)\n && !(obj instanceof Date);\n}\n/**\n *\n * @returns whether the provided parameter is of type `Buffer` or Uint8Array dervived type\n */\nexport function isTypedArray(obj) {\n const TypedArray = Object.getPrototypeOf(Uint8Array);\n return typeof obj === 'object'\n && obj instanceof TypedArray;\n}\n/**\n * In **contrast** to just checking `typeof` this will return `false` for `NaN`.\n * @returns whether the provided parameter is a JavaScript Number or not.\n */\nexport function isNumber(obj) {\n return (typeof obj === 'number' && !isNaN(obj));\n}\n/**\n * @returns whether the provided parameter is an Iterable, casting to the given generic\n */\nexport function isIterable(obj) {\n return !!obj && typeof obj[Symbol.iterator] === 'function';\n}\n/**\n * @returns whether the provided parameter is a JavaScript Boolean or not.\n */\nexport function isBoolean(obj) {\n return (obj === true || obj === false);\n}\n/**\n * @returns whether the provided parameter is undefined.\n */\nexport function isUndefined(obj) {\n return (typeof obj === 'undefined');\n}\n/**\n * @returns whether the provided parameter is defined.\n */\nexport function isDefined(arg) {\n return !isUndefinedOrNull(arg);\n}\n/**\n * @returns whether the provided parameter is undefined or null.\n */\nexport function isUndefinedOrNull(obj) {\n return (isUndefined(obj) || obj === null);\n}\nexport function assertType(condition, type) {\n if (!condition) {\n throw new Error(type ? `Unexpected type, expected '${type}'` : 'Unexpected type');\n }\n}\n/**\n * Asserts that the argument passed in is neither undefined nor null.\n */\nexport function assertIsDefined(arg) {\n if (isUndefinedOrNull(arg)) {\n throw new Error('Assertion Failed: argument is undefined or null');\n }\n return arg;\n}\n/**\n * @returns whether the provided parameter is a JavaScript Function or not.\n */\nexport function isFunction(obj) {\n return (typeof obj === 'function');\n}\nexport function validateConstraints(args, constraints) {\n const len = Math.min(args.length, constraints.length);\n for (let i = 0; i < len; i++) {\n validateConstraint(args[i], constraints[i]);\n }\n}\nexport function validateConstraint(arg, constraint) {\n if (isString(constraint)) {\n if (typeof arg !== constraint) {\n throw new Error(`argument does not match constraint: typeof ${constraint}`);\n }\n }\n else if (isFunction(constraint)) {\n try {\n if (arg instanceof constraint) {\n return;\n }\n }\n catch (_a) {\n // ignore\n }\n if (!isUndefinedOrNull(arg) && arg.constructor === constraint) {\n return;\n }\n if (constraint.length === 1 && constraint.call(undefined, arg) === true) {\n return;\n }\n throw new Error(`argument does not match one of these constraints: arg instanceof constraint, arg.constructor === constraint, nor constraint(arg) === true`);\n }\n}\nexport function getAllPropertyNames(obj) {\n let res = [];\n let proto = Object.getPrototypeOf(obj);\n while (Object.prototype !== proto) {\n res = res.concat(Object.getOwnPropertyNames(proto));\n proto = Object.getPrototypeOf(proto);\n }\n return res;\n}\nexport function getAllMethodNames(obj) {\n const methods = [];\n for (const prop of getAllPropertyNames(obj)) {\n if (typeof obj[prop] === 'function') {\n methods.push(prop);\n }\n }\n return methods;\n}\nexport function createProxyObject(methodNames, invoke) {\n const createProxyMethod = (method) => {\n return function () {\n const args = Array.prototype.slice.call(arguments, 0);\n return invoke(method, args);\n };\n };\n const result = {};\n for (const methodName of methodNames) {\n result[methodName] = createProxyMethod(methodName);\n }\n return result;\n}\n/**\n * Converts null to undefined, passes all other values through.\n */\nexport function withNullAsUndefined(x) {\n return x === null ? undefined : x;\n}\nexport function assertNever(value, message = 'Unreachable') {\n throw new Error(message);\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nexport class Lazy {\n constructor(executor) {\n this.executor = executor;\n this._didRun = false;\n }\n /**\n * True if the lazy value has been resolved.\n */\n hasValue() { return this._didRun; }\n /**\n * Get the wrapped value.\n *\n * This will force evaluation of the lazy value if it has not been resolved yet. Lazy values are only\n * resolved once. `getValue` will re-throw exceptions that are hit while resolving the value\n */\n getValue() {\n if (!this._didRun) {\n try {\n this._value = this.executor();\n }\n catch (err) {\n this._error = err;\n }\n finally {\n this._didRun = true;\n }\n }\n if (this._error) {\n throw this._error;\n }\n return this._value;\n }\n /**\n * Get the wrapped value without forcing evaluation.\n */\n get rawValue() { return this._value; }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nvar _a;\nimport { LRUCachedFunction } from './cache.js';\nimport { Lazy } from './lazy.js';\nexport function isFalsyOrWhitespace(str) {\n if (!str || typeof str !== 'string') {\n return true;\n }\n return str.trim().length === 0;\n}\nconst _formatRegexp = /{(\\d+)}/g;\n/**\n * Helper to produce a string with a variable number of arguments. Insert variable segments\n * into the string using the {n} notation where N is the index of the argument following the string.\n * @param value string to which formatting is applied\n * @param args replacements for {n}-entries\n */\nexport function format(value, ...args) {\n if (args.length === 0) {\n return value;\n }\n return value.replace(_formatRegexp, function (match, group) {\n const idx = parseInt(group, 10);\n return isNaN(idx) || idx < 0 || idx >= args.length ?\n match :\n args[idx];\n });\n}\n/**\n * Converts HTML characters inside the string to use entities instead. Makes the string safe from\n * being used e.g. in HTMLElement.innerHTML.\n */\nexport function escape(html) {\n return html.replace(/[<>&]/g, function (match) {\n switch (match) {\n case '<': return '<';\n case '>': return '>';\n case '&': return '&';\n default: return match;\n }\n });\n}\n/**\n * Escapes regular expression characters in a given string\n */\nexport function escapeRegExpCharacters(value) {\n return value.replace(/[\\\\\\{\\}\\*\\+\\?\\|\\^\\$\\.\\[\\]\\(\\)]/g, '\\\\$&');\n}\n/**\n * Removes all occurrences of needle from the beginning and end of haystack.\n * @param haystack string to trim\n * @param needle the thing to trim (default is a blank)\n */\nexport function trim(haystack, needle = ' ') {\n const trimmed = ltrim(haystack, needle);\n return rtrim(trimmed, needle);\n}\n/**\n * Removes all occurrences of needle from the beginning of haystack.\n * @param haystack string to trim\n * @param needle the thing to trim\n */\nexport function ltrim(haystack, needle) {\n if (!haystack || !needle) {\n return haystack;\n }\n const needleLen = needle.length;\n if (needleLen === 0 || haystack.length === 0) {\n return haystack;\n }\n let offset = 0;\n while (haystack.indexOf(needle, offset) === offset) {\n offset = offset + needleLen;\n }\n return haystack.substring(offset);\n}\n/**\n * Removes all occurrences of needle from the end of haystack.\n * @param haystack string to trim\n * @param needle the thing to trim\n */\nexport function rtrim(haystack, needle) {\n if (!haystack || !needle) {\n return haystack;\n }\n const needleLen = needle.length, haystackLen = haystack.length;\n if (needleLen === 0 || haystackLen === 0) {\n return haystack;\n }\n let offset = haystackLen, idx = -1;\n while (true) {\n idx = haystack.lastIndexOf(needle, offset - 1);\n if (idx === -1 || idx + needleLen !== offset) {\n break;\n }\n if (idx === 0) {\n return '';\n }\n offset = idx;\n }\n return haystack.substring(0, offset);\n}\nexport function convertSimple2RegExpPattern(pattern) {\n return pattern.replace(/[\\-\\\\\\{\\}\\+\\?\\|\\^\\$\\.\\,\\[\\]\\(\\)\\#\\s]/g, '\\\\$&').replace(/[\\*]/g, '.*');\n}\nexport function stripWildcards(pattern) {\n return pattern.replace(/\\*/g, '');\n}\nexport function createRegExp(searchString, isRegex, options = {}) {\n if (!searchString) {\n throw new Error('Cannot create regex from empty string');\n }\n if (!isRegex) {\n searchString = escapeRegExpCharacters(searchString);\n }\n if (options.wholeWord) {\n if (!/\\B/.test(searchString.charAt(0))) {\n searchString = '\\\\b' + searchString;\n }\n if (!/\\B/.test(searchString.charAt(searchString.length - 1))) {\n searchString = searchString + '\\\\b';\n }\n }\n let modifiers = '';\n if (options.global) {\n modifiers += 'g';\n }\n if (!options.matchCase) {\n modifiers += 'i';\n }\n if (options.multiline) {\n modifiers += 'm';\n }\n if (options.unicode) {\n modifiers += 'u';\n }\n return new RegExp(searchString, modifiers);\n}\nexport function regExpLeadsToEndlessLoop(regexp) {\n // Exit early if it's one of these special cases which are meant to match\n // against an empty string\n if (regexp.source === '^' || regexp.source === '^$' || regexp.source === '$' || regexp.source === '^\\\\s*$') {\n return false;\n }\n // We check against an empty string. If the regular expression doesn't advance\n // (e.g. ends in an endless loop) it will match an empty string.\n const match = regexp.exec('');\n return !!(match && regexp.lastIndex === 0);\n}\nexport function regExpFlags(regexp) {\n return (regexp.global ? 'g' : '')\n + (regexp.ignoreCase ? 'i' : '')\n + (regexp.multiline ? 'm' : '')\n + (regexp /* standalone editor compilation */.unicode ? 'u' : '');\n}\nexport function splitLines(str) {\n return str.split(/\\r\\n|\\r|\\n/);\n}\n/**\n * Returns first index of the string that is not whitespace.\n * If string is empty or contains only whitespaces, returns -1\n */\nexport function firstNonWhitespaceIndex(str) {\n for (let i = 0, len = str.length; i < len; i++) {\n const chCode = str.charCodeAt(i);\n if (chCode !== 32 /* CharCode.Space */ && chCode !== 9 /* CharCode.Tab */) {\n return i;\n }\n }\n return -1;\n}\n/**\n * Returns the leading whitespace of the string.\n * If the string contains only whitespaces, returns entire string\n */\nexport function getLeadingWhitespace(str, start = 0, end = str.length) {\n for (let i = start; i < end; i++) {\n const chCode = str.charCodeAt(i);\n if (chCode !== 32 /* CharCode.Space */ && chCode !== 9 /* CharCode.Tab */) {\n return str.substring(start, i);\n }\n }\n return str.substring(start, end);\n}\n/**\n * Returns last index of the string that is not whitespace.\n * If string is empty or contains only whitespaces, returns -1\n */\nexport function lastNonWhitespaceIndex(str, startIndex = str.length - 1) {\n for (let i = startIndex; i >= 0; i--) {\n const chCode = str.charCodeAt(i);\n if (chCode !== 32 /* CharCode.Space */ && chCode !== 9 /* CharCode.Tab */) {\n return i;\n }\n }\n return -1;\n}\nexport function compare(a, b) {\n if (a < b) {\n return -1;\n }\n else if (a > b) {\n return 1;\n }\n else {\n return 0;\n }\n}\nexport function compareSubstring(a, b, aStart = 0, aEnd = a.length, bStart = 0, bEnd = b.length) {\n for (; aStart < aEnd && bStart < bEnd; aStart++, bStart++) {\n const codeA = a.charCodeAt(aStart);\n const codeB = b.charCodeAt(bStart);\n if (codeA < codeB) {\n return -1;\n }\n else if (codeA > codeB) {\n return 1;\n }\n }\n const aLen = aEnd - aStart;\n const bLen = bEnd - bStart;\n if (aLen < bLen) {\n return -1;\n }\n else if (aLen > bLen) {\n return 1;\n }\n return 0;\n}\nexport function compareIgnoreCase(a, b) {\n return compareSubstringIgnoreCase(a, b, 0, a.length, 0, b.length);\n}\nexport function compareSubstringIgnoreCase(a, b, aStart = 0, aEnd = a.length, bStart = 0, bEnd = b.length) {\n for (; aStart < aEnd && bStart < bEnd; aStart++, bStart++) {\n let codeA = a.charCodeAt(aStart);\n let codeB = b.charCodeAt(bStart);\n if (codeA === codeB) {\n // equal\n continue;\n }\n if (codeA >= 128 || codeB >= 128) {\n // not ASCII letters -> fallback to lower-casing strings\n return compareSubstring(a.toLowerCase(), b.toLowerCase(), aStart, aEnd, bStart, bEnd);\n }\n // mapper lower-case ascii letter onto upper-case varinats\n // [97-122] (lower ascii) --> [65-90] (upper ascii)\n if (isLowerAsciiLetter(codeA)) {\n codeA -= 32;\n }\n if (isLowerAsciiLetter(codeB)) {\n codeB -= 32;\n }\n // compare both code points\n const diff = codeA - codeB;\n if (diff === 0) {\n continue;\n }\n return diff;\n }\n const aLen = aEnd - aStart;\n const bLen = bEnd - bStart;\n if (aLen < bLen) {\n return -1;\n }\n else if (aLen > bLen) {\n return 1;\n }\n return 0;\n}\nexport function isAsciiDigit(code) {\n return code >= 48 /* CharCode.Digit0 */ && code <= 57 /* CharCode.Digit9 */;\n}\nexport function isLowerAsciiLetter(code) {\n return code >= 97 /* CharCode.a */ && code <= 122 /* CharCode.z */;\n}\nexport function isUpperAsciiLetter(code) {\n return code >= 65 /* CharCode.A */ && code <= 90 /* CharCode.Z */;\n}\nexport function equalsIgnoreCase(a, b) {\n return a.length === b.length && compareSubstringIgnoreCase(a, b) === 0;\n}\nexport function startsWithIgnoreCase(str, candidate) {\n const candidateLength = candidate.length;\n if (candidate.length > str.length) {\n return false;\n }\n return compareSubstringIgnoreCase(str, candidate, 0, candidateLength) === 0;\n}\n/**\n * @returns the length of the common prefix of the two strings.\n */\nexport function commonPrefixLength(a, b) {\n const len = Math.min(a.length, b.length);\n let i;\n for (i = 0; i < len; i++) {\n if (a.charCodeAt(i) !== b.charCodeAt(i)) {\n return i;\n }\n }\n return len;\n}\n/**\n * @returns the length of the common suffix of the two strings.\n */\nexport function commonSuffixLength(a, b) {\n const len = Math.min(a.length, b.length);\n let i;\n const aLastIndex = a.length - 1;\n const bLastIndex = b.length - 1;\n for (i = 0; i < len; i++) {\n if (a.charCodeAt(aLastIndex - i) !== b.charCodeAt(bLastIndex - i)) {\n return i;\n }\n }\n return len;\n}\n/**\n * See http://en.wikipedia.org/wiki/Surrogate_pair\n */\nexport function isHighSurrogate(charCode) {\n return (0xD800 <= charCode && charCode <= 0xDBFF);\n}\n/**\n * See http://en.wikipedia.org/wiki/Surrogate_pair\n */\nexport function isLowSurrogate(charCode) {\n return (0xDC00 <= charCode && charCode <= 0xDFFF);\n}\n/**\n * See http://en.wikipedia.org/wiki/Surrogate_pair\n */\nexport function computeCodePoint(highSurrogate, lowSurrogate) {\n return ((highSurrogate - 0xD800) << 10) + (lowSurrogate - 0xDC00) + 0x10000;\n}\n/**\n * get the code point that begins at offset `offset`\n */\nexport function getNextCodePoint(str, len, offset) {\n const charCode = str.charCodeAt(offset);\n if (isHighSurrogate(charCode) && offset + 1 < len) {\n const nextCharCode = str.charCodeAt(offset + 1);\n if (isLowSurrogate(nextCharCode)) {\n return computeCodePoint(charCode, nextCharCode);\n }\n }\n return charCode;\n}\n/**\n * get the code point that ends right before offset `offset`\n */\nfunction getPrevCodePoint(str, offset) {\n const charCode = str.charCodeAt(offset - 1);\n if (isLowSurrogate(charCode) && offset > 1) {\n const prevCharCode = str.charCodeAt(offset - 2);\n if (isHighSurrogate(prevCharCode)) {\n return computeCodePoint(prevCharCode, charCode);\n }\n }\n return charCode;\n}\nexport class CodePointIterator {\n constructor(str, offset = 0) {\n this._str = str;\n this._len = str.length;\n this._offset = offset;\n }\n get offset() {\n return this._offset;\n }\n setOffset(offset) {\n this._offset = offset;\n }\n prevCodePoint() {\n const codePoint = getPrevCodePoint(this._str, this._offset);\n this._offset -= (codePoint >= 65536 /* Constants.UNICODE_SUPPLEMENTARY_PLANE_BEGIN */ ? 2 : 1);\n return codePoint;\n }\n nextCodePoint() {\n const codePoint = getNextCodePoint(this._str, this._len, this._offset);\n this._offset += (codePoint >= 65536 /* Constants.UNICODE_SUPPLEMENTARY_PLANE_BEGIN */ ? 2 : 1);\n return codePoint;\n }\n eol() {\n return (this._offset >= this._len);\n }\n}\nexport class GraphemeIterator {\n constructor(str, offset = 0) {\n this._iterator = new CodePointIterator(str, offset);\n }\n get offset() {\n return this._iterator.offset;\n }\n nextGraphemeLength() {\n const graphemeBreakTree = GraphemeBreakTree.getInstance();\n const iterator = this._iterator;\n const initialOffset = iterator.offset;\n let graphemeBreakType = graphemeBreakTree.getGraphemeBreakType(iterator.nextCodePoint());\n while (!iterator.eol()) {\n const offset = iterator.offset;\n const nextGraphemeBreakType = graphemeBreakTree.getGraphemeBreakType(iterator.nextCodePoint());\n if (breakBetweenGraphemeBreakType(graphemeBreakType, nextGraphemeBreakType)) {\n // move iterator back\n iterator.setOffset(offset);\n break;\n }\n graphemeBreakType = nextGraphemeBreakType;\n }\n return (iterator.offset - initialOffset);\n }\n prevGraphemeLength() {\n const graphemeBreakTree = GraphemeBreakTree.getInstance();\n const iterator = this._iterator;\n const initialOffset = iterator.offset;\n let graphemeBreakType = graphemeBreakTree.getGraphemeBreakType(iterator.prevCodePoint());\n while (iterator.offset > 0) {\n const offset = iterator.offset;\n const prevGraphemeBreakType = graphemeBreakTree.getGraphemeBreakType(iterator.prevCodePoint());\n if (breakBetweenGraphemeBreakType(prevGraphemeBreakType, graphemeBreakType)) {\n // move iterator back\n iterator.setOffset(offset);\n break;\n }\n graphemeBreakType = prevGraphemeBreakType;\n }\n return (initialOffset - iterator.offset);\n }\n eol() {\n return this._iterator.eol();\n }\n}\nexport function nextCharLength(str, initialOffset) {\n const iterator = new GraphemeIterator(str, initialOffset);\n return iterator.nextGraphemeLength();\n}\nexport function prevCharLength(str, initialOffset) {\n const iterator = new GraphemeIterator(str, initialOffset);\n return iterator.prevGraphemeLength();\n}\nexport function getCharContainingOffset(str, offset) {\n if (offset > 0 && isLowSurrogate(str.charCodeAt(offset))) {\n offset--;\n }\n const endOffset = offset + nextCharLength(str, offset);\n const startOffset = endOffset - prevCharLength(str, endOffset);\n return [startOffset, endOffset];\n}\n/**\n * Generated using https://github.com/alexdima/unicode-utils/blob/main/rtl-test.js\n */\nconst CONTAINS_RTL = /(?:[\\u05BE\\u05C0\\u05C3\\u05C6\\u05D0-\\u05F4\\u0608\\u060B\\u060D\\u061B-\\u064A\\u066D-\\u066F\\u0671-\\u06D5\\u06E5\\u06E6\\u06EE\\u06EF\\u06FA-\\u0710\\u0712-\\u072F\\u074D-\\u07A5\\u07B1-\\u07EA\\u07F4\\u07F5\\u07FA\\u07FE-\\u0815\\u081A\\u0824\\u0828\\u0830-\\u0858\\u085E-\\u088E\\u08A0-\\u08C9\\u200F\\uFB1D\\uFB1F-\\uFB28\\uFB2A-\\uFD3D\\uFD50-\\uFDC7\\uFDF0-\\uFDFC\\uFE70-\\uFEFC]|\\uD802[\\uDC00-\\uDD1B\\uDD20-\\uDE00\\uDE10-\\uDE35\\uDE40-\\uDEE4\\uDEEB-\\uDF35\\uDF40-\\uDFFF]|\\uD803[\\uDC00-\\uDD23\\uDE80-\\uDEA9\\uDEAD-\\uDF45\\uDF51-\\uDF81\\uDF86-\\uDFF6]|\\uD83A[\\uDC00-\\uDCCF\\uDD00-\\uDD43\\uDD4B-\\uDFFF]|\\uD83B[\\uDC00-\\uDEBB])/;\n/**\n * Returns true if `str` contains any Unicode character that is classified as \"R\" or \"AL\".\n */\nexport function containsRTL(str) {\n return CONTAINS_RTL.test(str);\n}\nconst IS_BASIC_ASCII = /^[\\t\\n\\r\\x20-\\x7E]*$/;\n/**\n * Returns true if `str` contains only basic ASCII characters in the range 32 - 126 (including 32 and 126) or \\n, \\r, \\t\n */\nexport function isBasicASCII(str) {\n return IS_BASIC_ASCII.test(str);\n}\nexport const UNUSUAL_LINE_TERMINATORS = /[\\u2028\\u2029]/; // LINE SEPARATOR (LS) or PARAGRAPH SEPARATOR (PS)\n/**\n * Returns true if `str` contains unusual line terminators, like LS or PS\n */\nexport function containsUnusualLineTerminators(str) {\n return UNUSUAL_LINE_TERMINATORS.test(str);\n}\nexport function isFullWidthCharacter(charCode) {\n // Do a cheap trick to better support wrapping of wide characters, treat them as 2 columns\n // http://jrgraphix.net/research/unicode_blocks.php\n // 2E80 - 2EFF CJK Radicals Supplement\n // 2F00 - 2FDF Kangxi Radicals\n // 2FF0 - 2FFF Ideographic Description Characters\n // 3000 - 303F CJK Symbols and Punctuation\n // 3040 - 309F Hiragana\n // 30A0 - 30FF Katakana\n // 3100 - 312F Bopomofo\n // 3130 - 318F Hangul Compatibility Jamo\n // 3190 - 319F Kanbun\n // 31A0 - 31BF Bopomofo Extended\n // 31F0 - 31FF Katakana Phonetic Extensions\n // 3200 - 32FF Enclosed CJK Letters and Months\n // 3300 - 33FF CJK Compatibility\n // 3400 - 4DBF CJK Unified Ideographs Extension A\n // 4DC0 - 4DFF Yijing Hexagram Symbols\n // 4E00 - 9FFF CJK Unified Ideographs\n // A000 - A48F Yi Syllables\n // A490 - A4CF Yi Radicals\n // AC00 - D7AF Hangul Syllables\n // [IGNORE] D800 - DB7F High Surrogates\n // [IGNORE] DB80 - DBFF High Private Use Surrogates\n // [IGNORE] DC00 - DFFF Low Surrogates\n // [IGNORE] E000 - F8FF Private Use Area\n // F900 - FAFF CJK Compatibility Ideographs\n // [IGNORE] FB00 - FB4F Alphabetic Presentation Forms\n // [IGNORE] FB50 - FDFF Arabic Presentation Forms-A\n // [IGNORE] FE00 - FE0F Variation Selectors\n // [IGNORE] FE20 - FE2F Combining Half Marks\n // [IGNORE] FE30 - FE4F CJK Compatibility Forms\n // [IGNORE] FE50 - FE6F Small Form Variants\n // [IGNORE] FE70 - FEFF Arabic Presentation Forms-B\n // FF00 - FFEF Halfwidth and Fullwidth Forms\n // [https://en.wikipedia.org/wiki/Halfwidth_and_fullwidth_forms]\n // of which FF01 - FF5E fullwidth ASCII of 21 to 7E\n // [IGNORE] and FF65 - FFDC halfwidth of Katakana and Hangul\n // [IGNORE] FFF0 - FFFF Specials\n return ((charCode >= 0x2E80 && charCode <= 0xD7AF)\n || (charCode >= 0xF900 && charCode <= 0xFAFF)\n || (charCode >= 0xFF01 && charCode <= 0xFF5E));\n}\n/**\n * A fast function (therefore imprecise) to check if code points are emojis.\n * Generated using https://github.com/alexdima/unicode-utils/blob/main/emoji-test.js\n */\nexport function isEmojiImprecise(x) {\n return ((x >= 0x1F1E6 && x <= 0x1F1FF) || (x === 8986) || (x === 8987) || (x === 9200)\n || (x === 9203) || (x >= 9728 && x <= 10175) || (x === 11088) || (x === 11093)\n || (x >= 127744 && x <= 128591) || (x >= 128640 && x <= 128764)\n || (x >= 128992 && x <= 129008) || (x >= 129280 && x <= 129535)\n || (x >= 129648 && x <= 129782));\n}\n// -- UTF-8 BOM\nexport const UTF8_BOM_CHARACTER = String.fromCharCode(65279 /* CharCode.UTF8_BOM */);\nexport function startsWithUTF8BOM(str) {\n return !!(str && str.length > 0 && str.charCodeAt(0) === 65279 /* CharCode.UTF8_BOM */);\n}\nexport function containsUppercaseCharacter(target, ignoreEscapedChars = false) {\n if (!target) {\n return false;\n }\n if (ignoreEscapedChars) {\n target = target.replace(/\\\\./g, '');\n }\n return target.toLowerCase() !== target;\n}\n/**\n * Produces 'a'-'z', followed by 'A'-'Z'... followed by 'a'-'z', etc.\n */\nexport function singleLetterHash(n) {\n const LETTERS_CNT = (90 /* CharCode.Z */ - 65 /* CharCode.A */ + 1);\n n = n % (2 * LETTERS_CNT);\n if (n < LETTERS_CNT) {\n return String.fromCharCode(97 /* CharCode.a */ + n);\n }\n return String.fromCharCode(65 /* CharCode.A */ + n - LETTERS_CNT);\n}\nfunction breakBetweenGraphemeBreakType(breakTypeA, breakTypeB) {\n // http://www.unicode.org/reports/tr29/#Grapheme_Cluster_Boundary_Rules\n // !!! Let's make the common case a bit faster\n if (breakTypeA === 0 /* GraphemeBreakType.Other */) {\n // see https://www.unicode.org/Public/13.0.0/ucd/auxiliary/GraphemeBreakTest-13.0.0d10.html#table\n return (breakTypeB !== 5 /* GraphemeBreakType.Extend */ && breakTypeB !== 7 /* GraphemeBreakType.SpacingMark */);\n }\n // Do not break between a CR and LF. Otherwise, break before and after controls.\n // GB3 CR × LF\n // GB4 (Control | CR | LF) ÷\n // GB5 ÷ (Control | CR | LF)\n if (breakTypeA === 2 /* GraphemeBreakType.CR */) {\n if (breakTypeB === 3 /* GraphemeBreakType.LF */) {\n return false; // GB3\n }\n }\n if (breakTypeA === 4 /* GraphemeBreakType.Control */ || breakTypeA === 2 /* GraphemeBreakType.CR */ || breakTypeA === 3 /* GraphemeBreakType.LF */) {\n return true; // GB4\n }\n if (breakTypeB === 4 /* GraphemeBreakType.Control */ || breakTypeB === 2 /* GraphemeBreakType.CR */ || breakTypeB === 3 /* GraphemeBreakType.LF */) {\n return true; // GB5\n }\n // Do not break Hangul syllable sequences.\n // GB6 L × (L | V | LV | LVT)\n // GB7 (LV | V) × (V | T)\n // GB8 (LVT | T) × T\n if (breakTypeA === 8 /* GraphemeBreakType.L */) {\n if (breakTypeB === 8 /* GraphemeBreakType.L */ || breakTypeB === 9 /* GraphemeBreakType.V */ || breakTypeB === 11 /* GraphemeBreakType.LV */ || breakTypeB === 12 /* GraphemeBreakType.LVT */) {\n return false; // GB6\n }\n }\n if (breakTypeA === 11 /* GraphemeBreakType.LV */ || breakTypeA === 9 /* GraphemeBreakType.V */) {\n if (breakTypeB === 9 /* GraphemeBreakType.V */ || breakTypeB === 10 /* GraphemeBreakType.T */) {\n return false; // GB7\n }\n }\n if (breakTypeA === 12 /* GraphemeBreakType.LVT */ || breakTypeA === 10 /* GraphemeBreakType.T */) {\n if (breakTypeB === 10 /* GraphemeBreakType.T */) {\n return false; // GB8\n }\n }\n // Do not break before extending characters or ZWJ.\n // GB9 × (Extend | ZWJ)\n if (breakTypeB === 5 /* GraphemeBreakType.Extend */ || breakTypeB === 13 /* GraphemeBreakType.ZWJ */) {\n return false; // GB9\n }\n // The GB9a and GB9b rules only apply to extended grapheme clusters:\n // Do not break before SpacingMarks, or after Prepend characters.\n // GB9a × SpacingMark\n // GB9b Prepend ×\n if (breakTypeB === 7 /* GraphemeBreakType.SpacingMark */) {\n return false; // GB9a\n }\n if (breakTypeA === 1 /* GraphemeBreakType.Prepend */) {\n return false; // GB9b\n }\n // Do not break within emoji modifier sequences or emoji zwj sequences.\n // GB11 \\p{Extended_Pictographic} Extend* ZWJ × \\p{Extended_Pictographic}\n if (breakTypeA === 13 /* GraphemeBreakType.ZWJ */ && breakTypeB === 14 /* GraphemeBreakType.Extended_Pictographic */) {\n // Note: we are not implementing the rule entirely here to avoid introducing states\n return false; // GB11\n }\n // GB12 sot (RI RI)* RI × RI\n // GB13 [^RI] (RI RI)* RI × RI\n if (breakTypeA === 6 /* GraphemeBreakType.Regional_Indicator */ && breakTypeB === 6 /* GraphemeBreakType.Regional_Indicator */) {\n // Note: we are not implementing the rule entirely here to avoid introducing states\n return false; // GB12 & GB13\n }\n // GB999 Any ÷ Any\n return true;\n}\nclass GraphemeBreakTree {\n constructor() {\n this._data = getGraphemeBreakRawData();\n }\n static getInstance() {\n if (!GraphemeBreakTree._INSTANCE) {\n GraphemeBreakTree._INSTANCE = new GraphemeBreakTree();\n }\n return GraphemeBreakTree._INSTANCE;\n }\n getGraphemeBreakType(codePoint) {\n // !!! Let's make 7bit ASCII a bit faster: 0..31\n if (codePoint < 32) {\n if (codePoint === 10 /* CharCode.LineFeed */) {\n return 3 /* GraphemeBreakType.LF */;\n }\n if (codePoint === 13 /* CharCode.CarriageReturn */) {\n return 2 /* GraphemeBreakType.CR */;\n }\n return 4 /* GraphemeBreakType.Control */;\n }\n // !!! Let's make 7bit ASCII a bit faster: 32..126\n if (codePoint < 127) {\n return 0 /* GraphemeBreakType.Other */;\n }\n const data = this._data;\n const nodeCount = data.length / 3;\n let nodeIndex = 1;\n while (nodeIndex <= nodeCount) {\n if (codePoint < data[3 * nodeIndex]) {\n // go left\n nodeIndex = 2 * nodeIndex;\n }\n else if (codePoint > data[3 * nodeIndex + 1]) {\n // go right\n nodeIndex = 2 * nodeIndex + 1;\n }\n else {\n // hit\n return data[3 * nodeIndex + 2];\n }\n }\n return 0 /* GraphemeBreakType.Other */;\n }\n}\nGraphemeBreakTree._INSTANCE = null;\nfunction getGraphemeBreakRawData() {\n // generated using https://github.com/alexdima/unicode-utils/blob/main/grapheme-break.js\n return JSON.parse('[0,0,0,51229,51255,12,44061,44087,12,127462,127487,6,7083,7085,5,47645,47671,12,54813,54839,12,128678,128678,14,3270,3270,5,9919,9923,14,45853,45879,12,49437,49463,12,53021,53047,12,71216,71218,7,128398,128399,14,129360,129374,14,2519,2519,5,4448,4519,9,9742,9742,14,12336,12336,14,44957,44983,12,46749,46775,12,48541,48567,12,50333,50359,12,52125,52151,12,53917,53943,12,69888,69890,5,73018,73018,5,127990,127990,14,128558,128559,14,128759,128760,14,129653,129655,14,2027,2035,5,2891,2892,7,3761,3761,5,6683,6683,5,8293,8293,4,9825,9826,14,9999,9999,14,43452,43453,5,44509,44535,12,45405,45431,12,46301,46327,12,47197,47223,12,48093,48119,12,48989,49015,12,49885,49911,12,50781,50807,12,51677,51703,12,52573,52599,12,53469,53495,12,54365,54391,12,65279,65279,4,70471,70472,7,72145,72147,7,119173,119179,5,127799,127818,14,128240,128244,14,128512,128512,14,128652,128652,14,128721,128722,14,129292,129292,14,129445,129450,14,129734,129743,14,1476,1477,5,2366,2368,7,2750,2752,7,3076,3076,5,3415,3415,5,4141,4144,5,6109,6109,5,6964,6964,5,7394,7400,5,9197,9198,14,9770,9770,14,9877,9877,14,9968,9969,14,10084,10084,14,43052,43052,5,43713,43713,5,44285,44311,12,44733,44759,12,45181,45207,12,45629,45655,12,46077,46103,12,46525,46551,12,46973,46999,12,47421,47447,12,47869,47895,12,48317,48343,12,48765,48791,12,49213,49239,12,49661,49687,12,50109,50135,12,50557,50583,12,51005,51031,12,51453,51479,12,51901,51927,12,52349,52375,12,52797,52823,12,53245,53271,12,53693,53719,12,54141,54167,12,54589,54615,12,55037,55063,12,69506,69509,5,70191,70193,5,70841,70841,7,71463,71467,5,72330,72342,5,94031,94031,5,123628,123631,5,127763,127765,14,127941,127941,14,128043,128062,14,128302,128317,14,128465,128467,14,128539,128539,14,128640,128640,14,128662,128662,14,128703,128703,14,128745,128745,14,129004,129007,14,129329,129330,14,129402,129402,14,129483,129483,14,129686,129704,14,130048,131069,14,173,173,4,1757,1757,1,2200,2207,5,2434,2435,7,2631,2632,5,2817,2817,5,3008,3008,5,3201,3201,5,3387,3388,5,3542,3542,5,3902,3903,7,4190,4192,5,6002,6003,5,6439,6440,5,6765,6770,7,7019,7027,5,7154,7155,7,8205,8205,13,8505,8505,14,9654,9654,14,9757,9757,14,9792,9792,14,9852,9853,14,9890,9894,14,9937,9937,14,9981,9981,14,10035,10036,14,11035,11036,14,42654,42655,5,43346,43347,7,43587,43587,5,44006,44007,7,44173,44199,12,44397,44423,12,44621,44647,12,44845,44871,12,45069,45095,12,45293,45319,12,45517,45543,12,45741,45767,12,45965,45991,12,46189,46215,12,46413,46439,12,46637,46663,12,46861,46887,12,47085,47111,12,47309,47335,12,47533,47559,12,47757,47783,12,47981,48007,12,48205,48231,12,48429,48455,12,48653,48679,12,48877,48903,12,49101,49127,12,49325,49351,12,49549,49575,12,49773,49799,12,49997,50023,12,50221,50247,12,50445,50471,12,50669,50695,12,50893,50919,12,51117,51143,12,51341,51367,12,51565,51591,12,51789,51815,12,52013,52039,12,52237,52263,12,52461,52487,12,52685,52711,12,52909,52935,12,53133,53159,12,53357,53383,12,53581,53607,12,53805,53831,12,54029,54055,12,54253,54279,12,54477,54503,12,54701,54727,12,54925,54951,12,55149,55175,12,68101,68102,5,69762,69762,7,70067,70069,7,70371,70378,5,70720,70721,7,71087,71087,5,71341,71341,5,71995,71996,5,72249,72249,7,72850,72871,5,73109,73109,5,118576,118598,5,121505,121519,5,127245,127247,14,127568,127569,14,127777,127777,14,127872,127891,14,127956,127967,14,128015,128016,14,128110,128172,14,128259,128259,14,128367,128368,14,128424,128424,14,128488,128488,14,128530,128532,14,128550,128551,14,128566,128566,14,128647,128647,14,128656,128656,14,128667,128673,14,128691,128693,14,128715,128715,14,128728,128732,14,128752,128752,14,128765,128767,14,129096,129103,14,129311,129311,14,129344,129349,14,129394,129394,14,129413,129425,14,129466,129471,14,129511,129535,14,129664,129666,14,129719,129722,14,129760,129767,14,917536,917631,5,13,13,2,1160,1161,5,1564,1564,4,1807,1807,1,2085,2087,5,2307,2307,7,2382,2383,7,2497,2500,5,2563,2563,7,2677,2677,5,2763,2764,7,2879,2879,5,2914,2915,5,3021,3021,5,3142,3144,5,3263,3263,5,3285,3286,5,3398,3400,7,3530,3530,5,3633,3633,5,3864,3865,5,3974,3975,5,4155,4156,7,4229,4230,5,5909,5909,7,6078,6085,7,6277,6278,5,6451,6456,7,6744,6750,5,6846,6846,5,6972,6972,5,7074,7077,5,7146,7148,7,7222,7223,5,7416,7417,5,8234,8238,4,8417,8417,5,9000,9000,14,9203,9203,14,9730,9731,14,9748,9749,14,9762,9763,14,9776,9783,14,9800,9811,14,9831,9831,14,9872,9873,14,9882,9882,14,9900,9903,14,9929,9933,14,9941,9960,14,9974,9974,14,9989,9989,14,10006,10006,14,10062,10062,14,10160,10160,14,11647,11647,5,12953,12953,14,43019,43019,5,43232,43249,5,43443,43443,5,43567,43568,7,43696,43696,5,43765,43765,7,44013,44013,5,44117,44143,12,44229,44255,12,44341,44367,12,44453,44479,12,44565,44591,12,44677,44703,12,44789,44815,12,44901,44927,12,45013,45039,12,45125,45151,12,45237,45263,12,45349,45375,12,45461,45487,12,45573,45599,12,45685,45711,12,45797,45823,12,45909,45935,12,46021,46047,12,46133,46159,12,46245,46271,12,46357,46383,12,46469,46495,12,46581,46607,12,46693,46719,12,46805,46831,12,46917,46943,12,47029,47055,12,47141,47167,12,47253,47279,12,47365,47391,12,47477,47503,12,47589,47615,12,47701,47727,12,47813,47839,12,47925,47951,12,48037,48063,12,48149,48175,12,48261,48287,12,48373,48399,12,48485,48511,12,48597,48623,12,48709,48735,12,48821,48847,12,48933,48959,12,49045,49071,12,49157,49183,12,49269,49295,12,49381,49407,12,49493,49519,12,49605,49631,12,49717,49743,12,49829,49855,12,49941,49967,12,50053,50079,12,50165,50191,12,50277,50303,12,50389,50415,12,50501,50527,12,50613,50639,12,50725,50751,12,50837,50863,12,50949,50975,12,51061,51087,12,51173,51199,12,51285,51311,12,51397,51423,12,51509,51535,12,51621,51647,12,51733,51759,12,51845,51871,12,51957,51983,12,52069,52095,12,52181,52207,12,52293,52319,12,52405,52431,12,52517,52543,12,52629,52655,12,52741,52767,12,52853,52879,12,52965,52991,12,53077,53103,12,53189,53215,12,53301,53327,12,53413,53439,12,53525,53551,12,53637,53663,12,53749,53775,12,53861,53887,12,53973,53999,12,54085,54111,12,54197,54223,12,54309,54335,12,54421,54447,12,54533,54559,12,54645,54671,12,54757,54783,12,54869,54895,12,54981,55007,12,55093,55119,12,55243,55291,10,66045,66045,5,68325,68326,5,69688,69702,5,69817,69818,5,69957,69958,7,70089,70092,5,70198,70199,5,70462,70462,5,70502,70508,5,70750,70750,5,70846,70846,7,71100,71101,5,71230,71230,7,71351,71351,5,71737,71738,5,72000,72000,7,72160,72160,5,72273,72278,5,72752,72758,5,72882,72883,5,73031,73031,5,73461,73462,7,94192,94193,7,119149,119149,7,121403,121452,5,122915,122916,5,126980,126980,14,127358,127359,14,127535,127535,14,127759,127759,14,127771,127771,14,127792,127793,14,127825,127867,14,127897,127899,14,127945,127945,14,127985,127986,14,128000,128007,14,128021,128021,14,128066,128100,14,128184,128235,14,128249,128252,14,128266,128276,14,128335,128335,14,128379,128390,14,128407,128419,14,128444,128444,14,128481,128481,14,128499,128499,14,128526,128526,14,128536,128536,14,128543,128543,14,128556,128556,14,128564,128564,14,128577,128580,14,128643,128645,14,128649,128649,14,128654,128654,14,128660,128660,14,128664,128664,14,128675,128675,14,128686,128689,14,128695,128696,14,128705,128709,14,128717,128719,14,128725,128725,14,128736,128741,14,128747,128748,14,128755,128755,14,128762,128762,14,128981,128991,14,129009,129023,14,129160,129167,14,129296,129304,14,129320,129327,14,129340,129342,14,129356,129356,14,129388,129392,14,129399,129400,14,129404,129407,14,129432,129442,14,129454,129455,14,129473,129474,14,129485,129487,14,129648,129651,14,129659,129660,14,129671,129679,14,129709,129711,14,129728,129730,14,129751,129753,14,129776,129782,14,917505,917505,4,917760,917999,5,10,10,3,127,159,4,768,879,5,1471,1471,5,1536,1541,1,1648,1648,5,1767,1768,5,1840,1866,5,2070,2073,5,2137,2139,5,2274,2274,1,2363,2363,7,2377,2380,7,2402,2403,5,2494,2494,5,2507,2508,7,2558,2558,5,2622,2624,7,2641,2641,5,2691,2691,7,2759,2760,5,2786,2787,5,2876,2876,5,2881,2884,5,2901,2902,5,3006,3006,5,3014,3016,7,3072,3072,5,3134,3136,5,3157,3158,5,3260,3260,5,3266,3266,5,3274,3275,7,3328,3329,5,3391,3392,7,3405,3405,5,3457,3457,5,3536,3537,7,3551,3551,5,3636,3642,5,3764,3772,5,3895,3895,5,3967,3967,7,3993,4028,5,4146,4151,5,4182,4183,7,4226,4226,5,4253,4253,5,4957,4959,5,5940,5940,7,6070,6070,7,6087,6088,7,6158,6158,4,6432,6434,5,6448,6449,7,6679,6680,5,6742,6742,5,6754,6754,5,6783,6783,5,6912,6915,5,6966,6970,5,6978,6978,5,7042,7042,7,7080,7081,5,7143,7143,7,7150,7150,7,7212,7219,5,7380,7392,5,7412,7412,5,8203,8203,4,8232,8232,4,8265,8265,14,8400,8412,5,8421,8432,5,8617,8618,14,9167,9167,14,9200,9200,14,9410,9410,14,9723,9726,14,9733,9733,14,9745,9745,14,9752,9752,14,9760,9760,14,9766,9766,14,9774,9774,14,9786,9786,14,9794,9794,14,9823,9823,14,9828,9828,14,9833,9850,14,9855,9855,14,9875,9875,14,9880,9880,14,9885,9887,14,9896,9897,14,9906,9916,14,9926,9927,14,9935,9935,14,9939,9939,14,9962,9962,14,9972,9972,14,9978,9978,14,9986,9986,14,9997,9997,14,10002,10002,14,10017,10017,14,10055,10055,14,10071,10071,14,10133,10135,14,10548,10549,14,11093,11093,14,12330,12333,5,12441,12442,5,42608,42610,5,43010,43010,5,43045,43046,5,43188,43203,7,43302,43309,5,43392,43394,5,43446,43449,5,43493,43493,5,43571,43572,7,43597,43597,7,43703,43704,5,43756,43757,5,44003,44004,7,44009,44010,7,44033,44059,12,44089,44115,12,44145,44171,12,44201,44227,12,44257,44283,12,44313,44339,12,44369,44395,12,44425,44451,12,44481,44507,12,44537,44563,12,44593,44619,12,44649,44675,12,44705,44731,12,44761,44787,12,44817,44843,12,44873,44899,12,44929,44955,12,44985,45011,12,45041,45067,12,45097,45123,12,45153,45179,12,45209,45235,12,45265,45291,12,45321,45347,12,45377,45403,12,45433,45459,12,45489,45515,12,45545,45571,12,45601,45627,12,45657,45683,12,45713,45739,12,45769,45795,12,45825,45851,12,45881,45907,12,45937,45963,12,45993,46019,12,46049,46075,12,46105,46131,12,46161,46187,12,46217,46243,12,46273,46299,12,46329,46355,12,46385,46411,12,46441,46467,12,46497,46523,12,46553,46579,12,46609,46635,12,46665,46691,12,46721,46747,12,46777,46803,12,46833,46859,12,46889,46915,12,46945,46971,12,47001,47027,12,47057,47083,12,47113,47139,12,47169,47195,12,47225,47251,12,47281,47307,12,47337,47363,12,47393,47419,12,47449,47475,12,47505,47531,12,47561,47587,12,47617,47643,12,47673,47699,12,47729,47755,12,47785,47811,12,47841,47867,12,47897,47923,12,47953,47979,12,48009,48035,12,48065,48091,12,48121,48147,12,48177,48203,12,48233,48259,12,48289,48315,12,48345,48371,12,48401,48427,12,48457,48483,12,48513,48539,12,48569,48595,12,48625,48651,12,48681,48707,12,48737,48763,12,48793,48819,12,48849,48875,12,48905,48931,12,48961,48987,12,49017,49043,12,49073,49099,12,49129,49155,12,49185,49211,12,49241,49267,12,49297,49323,12,49353,49379,12,49409,49435,12,49465,49491,12,49521,49547,12,49577,49603,12,49633,49659,12,49689,49715,12,49745,49771,12,49801,49827,12,49857,49883,12,49913,49939,12,49969,49995,12,50025,50051,12,50081,50107,12,50137,50163,12,50193,50219,12,50249,50275,12,50305,50331,12,50361,50387,12,50417,50443,12,50473,50499,12,50529,50555,12,50585,50611,12,50641,50667,12,50697,50723,12,50753,50779,12,50809,50835,12,50865,50891,12,50921,50947,12,50977,51003,12,51033,51059,12,51089,51115,12,51145,51171,12,51201,51227,12,51257,51283,12,51313,51339,12,51369,51395,12,51425,51451,12,51481,51507,12,51537,51563,12,51593,51619,12,51649,51675,12,51705,51731,12,51761,51787,12,51817,51843,12,51873,51899,12,51929,51955,12,51985,52011,12,52041,52067,12,52097,52123,12,52153,52179,12,52209,52235,12,52265,52291,12,52321,52347,12,52377,52403,12,52433,52459,12,52489,52515,12,52545,52571,12,52601,52627,12,52657,52683,12,52713,52739,12,52769,52795,12,52825,52851,12,52881,52907,12,52937,52963,12,52993,53019,12,53049,53075,12,53105,53131,12,53161,53187,12,53217,53243,12,53273,53299,12,53329,53355,12,53385,53411,12,53441,53467,12,53497,53523,12,53553,53579,12,53609,53635,12,53665,53691,12,53721,53747,12,53777,53803,12,53833,53859,12,53889,53915,12,53945,53971,12,54001,54027,12,54057,54083,12,54113,54139,12,54169,54195,12,54225,54251,12,54281,54307,12,54337,54363,12,54393,54419,12,54449,54475,12,54505,54531,12,54561,54587,12,54617,54643,12,54673,54699,12,54729,54755,12,54785,54811,12,54841,54867,12,54897,54923,12,54953,54979,12,55009,55035,12,55065,55091,12,55121,55147,12,55177,55203,12,65024,65039,5,65520,65528,4,66422,66426,5,68152,68154,5,69291,69292,5,69633,69633,5,69747,69748,5,69811,69814,5,69826,69826,5,69932,69932,7,70016,70017,5,70079,70080,7,70095,70095,5,70196,70196,5,70367,70367,5,70402,70403,7,70464,70464,5,70487,70487,5,70709,70711,7,70725,70725,7,70833,70834,7,70843,70844,7,70849,70849,7,71090,71093,5,71103,71104,5,71227,71228,7,71339,71339,5,71344,71349,5,71458,71461,5,71727,71735,5,71985,71989,7,71998,71998,5,72002,72002,7,72154,72155,5,72193,72202,5,72251,72254,5,72281,72283,5,72344,72345,5,72766,72766,7,72874,72880,5,72885,72886,5,73023,73029,5,73104,73105,5,73111,73111,5,92912,92916,5,94095,94098,5,113824,113827,4,119142,119142,7,119155,119162,4,119362,119364,5,121476,121476,5,122888,122904,5,123184,123190,5,125252,125258,5,127183,127183,14,127340,127343,14,127377,127386,14,127491,127503,14,127548,127551,14,127744,127756,14,127761,127761,14,127769,127769,14,127773,127774,14,127780,127788,14,127796,127797,14,127820,127823,14,127869,127869,14,127894,127895,14,127902,127903,14,127943,127943,14,127947,127950,14,127972,127972,14,127988,127988,14,127992,127994,14,128009,128011,14,128019,128019,14,128023,128041,14,128064,128064,14,128102,128107,14,128174,128181,14,128238,128238,14,128246,128247,14,128254,128254,14,128264,128264,14,128278,128299,14,128329,128330,14,128348,128359,14,128371,128377,14,128392,128393,14,128401,128404,14,128421,128421,14,128433,128434,14,128450,128452,14,128476,128478,14,128483,128483,14,128495,128495,14,128506,128506,14,128519,128520,14,128528,128528,14,128534,128534,14,128538,128538,14,128540,128542,14,128544,128549,14,128552,128555,14,128557,128557,14,128560,128563,14,128565,128565,14,128567,128576,14,128581,128591,14,128641,128642,14,128646,128646,14,128648,128648,14,128650,128651,14,128653,128653,14,128655,128655,14,128657,128659,14,128661,128661,14,128663,128663,14,128665,128666,14,128674,128674,14,128676,128677,14,128679,128685,14,128690,128690,14,128694,128694,14,128697,128702,14,128704,128704,14,128710,128714,14,128716,128716,14,128720,128720,14,128723,128724,14,128726,128727,14,128733,128735,14,128742,128744,14,128746,128746,14,128749,128751,14,128753,128754,14,128756,128758,14,128761,128761,14,128763,128764,14,128884,128895,14,128992,129003,14,129008,129008,14,129036,129039,14,129114,129119,14,129198,129279,14,129293,129295,14,129305,129310,14,129312,129319,14,129328,129328,14,129331,129338,14,129343,129343,14,129351,129355,14,129357,129359,14,129375,129387,14,129393,129393,14,129395,129398,14,129401,129401,14,129403,129403,14,129408,129412,14,129426,129431,14,129443,129444,14,129451,129453,14,129456,129465,14,129472,129472,14,129475,129482,14,129484,129484,14,129488,129510,14,129536,129647,14,129652,129652,14,129656,129658,14,129661,129663,14,129667,129670,14,129680,129685,14,129705,129708,14,129712,129718,14,129723,129727,14,129731,129733,14,129744,129750,14,129754,129759,14,129768,129775,14,129783,129791,14,917504,917504,4,917506,917535,4,917632,917759,4,918000,921599,4,0,9,4,11,12,4,14,31,4,169,169,14,174,174,14,1155,1159,5,1425,1469,5,1473,1474,5,1479,1479,5,1552,1562,5,1611,1631,5,1750,1756,5,1759,1764,5,1770,1773,5,1809,1809,5,1958,1968,5,2045,2045,5,2075,2083,5,2089,2093,5,2192,2193,1,2250,2273,5,2275,2306,5,2362,2362,5,2364,2364,5,2369,2376,5,2381,2381,5,2385,2391,5,2433,2433,5,2492,2492,5,2495,2496,7,2503,2504,7,2509,2509,5,2530,2531,5,2561,2562,5,2620,2620,5,2625,2626,5,2635,2637,5,2672,2673,5,2689,2690,5,2748,2748,5,2753,2757,5,2761,2761,7,2765,2765,5,2810,2815,5,2818,2819,7,2878,2878,5,2880,2880,7,2887,2888,7,2893,2893,5,2903,2903,5,2946,2946,5,3007,3007,7,3009,3010,7,3018,3020,7,3031,3031,5,3073,3075,7,3132,3132,5,3137,3140,7,3146,3149,5,3170,3171,5,3202,3203,7,3262,3262,7,3264,3265,7,3267,3268,7,3271,3272,7,3276,3277,5,3298,3299,5,3330,3331,7,3390,3390,5,3393,3396,5,3402,3404,7,3406,3406,1,3426,3427,5,3458,3459,7,3535,3535,5,3538,3540,5,3544,3550,7,3570,3571,7,3635,3635,7,3655,3662,5,3763,3763,7,3784,3789,5,3893,3893,5,3897,3897,5,3953,3966,5,3968,3972,5,3981,3991,5,4038,4038,5,4145,4145,7,4153,4154,5,4157,4158,5,4184,4185,5,4209,4212,5,4228,4228,7,4237,4237,5,4352,4447,8,4520,4607,10,5906,5908,5,5938,5939,5,5970,5971,5,6068,6069,5,6071,6077,5,6086,6086,5,6089,6099,5,6155,6157,5,6159,6159,5,6313,6313,5,6435,6438,7,6441,6443,7,6450,6450,5,6457,6459,5,6681,6682,7,6741,6741,7,6743,6743,7,6752,6752,5,6757,6764,5,6771,6780,5,6832,6845,5,6847,6862,5,6916,6916,7,6965,6965,5,6971,6971,7,6973,6977,7,6979,6980,7,7040,7041,5,7073,7073,7,7078,7079,7,7082,7082,7,7142,7142,5,7144,7145,5,7149,7149,5,7151,7153,5,7204,7211,7,7220,7221,7,7376,7378,5,7393,7393,7,7405,7405,5,7415,7415,7,7616,7679,5,8204,8204,5,8206,8207,4,8233,8233,4,8252,8252,14,8288,8292,4,8294,8303,4,8413,8416,5,8418,8420,5,8482,8482,14,8596,8601,14,8986,8987,14,9096,9096,14,9193,9196,14,9199,9199,14,9201,9202,14,9208,9210,14,9642,9643,14,9664,9664,14,9728,9729,14,9732,9732,14,9735,9741,14,9743,9744,14,9746,9746,14,9750,9751,14,9753,9756,14,9758,9759,14,9761,9761,14,9764,9765,14,9767,9769,14,9771,9773,14,9775,9775,14,9784,9785,14,9787,9791,14,9793,9793,14,9795,9799,14,9812,9822,14,9824,9824,14,9827,9827,14,9829,9830,14,9832,9832,14,9851,9851,14,9854,9854,14,9856,9861,14,9874,9874,14,9876,9876,14,9878,9879,14,9881,9881,14,9883,9884,14,9888,9889,14,9895,9895,14,9898,9899,14,9904,9905,14,9917,9918,14,9924,9925,14,9928,9928,14,9934,9934,14,9936,9936,14,9938,9938,14,9940,9940,14,9961,9961,14,9963,9967,14,9970,9971,14,9973,9973,14,9975,9977,14,9979,9980,14,9982,9985,14,9987,9988,14,9992,9996,14,9998,9998,14,10000,10001,14,10004,10004,14,10013,10013,14,10024,10024,14,10052,10052,14,10060,10060,14,10067,10069,14,10083,10083,14,10085,10087,14,10145,10145,14,10175,10175,14,11013,11015,14,11088,11088,14,11503,11505,5,11744,11775,5,12334,12335,5,12349,12349,14,12951,12951,14,42607,42607,5,42612,42621,5,42736,42737,5,43014,43014,5,43043,43044,7,43047,43047,7,43136,43137,7,43204,43205,5,43263,43263,5,43335,43345,5,43360,43388,8,43395,43395,7,43444,43445,7,43450,43451,7,43454,43456,7,43561,43566,5,43569,43570,5,43573,43574,5,43596,43596,5,43644,43644,5,43698,43700,5,43710,43711,5,43755,43755,7,43758,43759,7,43766,43766,5,44005,44005,5,44008,44008,5,44012,44012,7,44032,44032,11,44060,44060,11,44088,44088,11,44116,44116,11,44144,44144,11,44172,44172,11,44200,44200,11,44228,44228,11,44256,44256,11,44284,44284,11,44312,44312,11,44340,44340,11,44368,44368,11,44396,44396,11,44424,44424,11,44452,44452,11,44480,44480,11,44508,44508,11,44536,44536,11,44564,44564,11,44592,44592,11,44620,44620,11,44648,44648,11,44676,44676,11,44704,44704,11,44732,44732,11,44760,44760,11,44788,44788,11,44816,44816,11,44844,44844,11,44872,44872,11,44900,44900,11,44928,44928,11,44956,44956,11,44984,44984,11,45012,45012,11,45040,45040,11,45068,45068,11,45096,45096,11,45124,45124,11,45152,45152,11,45180,45180,11,45208,45208,11,45236,45236,11,45264,45264,11,45292,45292,11,45320,45320,11,45348,45348,11,45376,45376,11,45404,45404,11,45432,45432,11,45460,45460,11,45488,45488,11,45516,45516,11,45544,45544,11,45572,45572,11,45600,45600,11,45628,45628,11,45656,45656,11,45684,45684,11,45712,45712,11,45740,45740,11,45768,45768,11,45796,45796,11,45824,45824,11,45852,45852,11,45880,45880,11,45908,45908,11,45936,45936,11,45964,45964,11,45992,45992,11,46020,46020,11,46048,46048,11,46076,46076,11,46104,46104,11,46132,46132,11,46160,46160,11,46188,46188,11,46216,46216,11,46244,46244,11,46272,46272,11,46300,46300,11,46328,46328,11,46356,46356,11,46384,46384,11,46412,46412,11,46440,46440,11,46468,46468,11,46496,46496,11,46524,46524,11,46552,46552,11,46580,46580,11,46608,46608,11,46636,46636,11,46664,46664,11,46692,46692,11,46720,46720,11,46748,46748,11,46776,46776,11,46804,46804,11,46832,46832,11,46860,46860,11,46888,46888,11,46916,46916,11,46944,46944,11,46972,46972,11,47000,47000,11,47028,47028,11,47056,47056,11,47084,47084,11,47112,47112,11,47140,47140,11,47168,47168,11,47196,47196,11,47224,47224,11,47252,47252,11,47280,47280,11,47308,47308,11,47336,47336,11,47364,47364,11,47392,47392,11,47420,47420,11,47448,47448,11,47476,47476,11,47504,47504,11,47532,47532,11,47560,47560,11,47588,47588,11,47616,47616,11,47644,47644,11,47672,47672,11,47700,47700,11,47728,47728,11,47756,47756,11,47784,47784,11,47812,47812,11,47840,47840,11,47868,47868,11,47896,47896,11,47924,47924,11,47952,47952,11,47980,47980,11,48008,48008,11,48036,48036,11,48064,48064,11,48092,48092,11,48120,48120,11,48148,48148,11,48176,48176,11,48204,48204,11,48232,48232,11,48260,48260,11,48288,48288,11,48316,48316,11,48344,48344,11,48372,48372,11,48400,48400,11,48428,48428,11,48456,48456,11,48484,48484,11,48512,48512,11,48540,48540,11,48568,48568,11,48596,48596,11,48624,48624,11,48652,48652,11,48680,48680,11,48708,48708,11,48736,48736,11,48764,48764,11,48792,48792,11,48820,48820,11,48848,48848,11,48876,48876,11,48904,48904,11,48932,48932,11,48960,48960,11,48988,48988,11,49016,49016,11,49044,49044,11,49072,49072,11,49100,49100,11,49128,49128,11,49156,49156,11,49184,49184,11,49212,49212,11,49240,49240,11,49268,49268,11,49296,49296,11,49324,49324,11,49352,49352,11,49380,49380,11,49408,49408,11,49436,49436,11,49464,49464,11,49492,49492,11,49520,49520,11,49548,49548,11,49576,49576,11,49604,49604,11,49632,49632,11,49660,49660,11,49688,49688,11,49716,49716,11,49744,49744,11,49772,49772,11,49800,49800,11,49828,49828,11,49856,49856,11,49884,49884,11,49912,49912,11,49940,49940,11,49968,49968,11,49996,49996,11,50024,50024,11,50052,50052,11,50080,50080,11,50108,50108,11,50136,50136,11,50164,50164,11,50192,50192,11,50220,50220,11,50248,50248,11,50276,50276,11,50304,50304,11,50332,50332,11,50360,50360,11,50388,50388,11,50416,50416,11,50444,50444,11,50472,50472,11,50500,50500,11,50528,50528,11,50556,50556,11,50584,50584,11,50612,50612,11,50640,50640,11,50668,50668,11,50696,50696,11,50724,50724,11,50752,50752,11,50780,50780,11,50808,50808,11,50836,50836,11,50864,50864,11,50892,50892,11,50920,50920,11,50948,50948,11,50976,50976,11,51004,51004,11,51032,51032,11,51060,51060,11,51088,51088,11,51116,51116,11,51144,51144,11,51172,51172,11,51200,51200,11,51228,51228,11,51256,51256,11,51284,51284,11,51312,51312,11,51340,51340,11,51368,51368,11,51396,51396,11,51424,51424,11,51452,51452,11,51480,51480,11,51508,51508,11,51536,51536,11,51564,51564,11,51592,51592,11,51620,51620,11,51648,51648,11,51676,51676,11,51704,51704,11,51732,51732,11,51760,51760,11,51788,51788,11,51816,51816,11,51844,51844,11,51872,51872,11,51900,51900,11,51928,51928,11,51956,51956,11,51984,51984,11,52012,52012,11,52040,52040,11,52068,52068,11,52096,52096,11,52124,52124,11,52152,52152,11,52180,52180,11,52208,52208,11,52236,52236,11,52264,52264,11,52292,52292,11,52320,52320,11,52348,52348,11,52376,52376,11,52404,52404,11,52432,52432,11,52460,52460,11,52488,52488,11,52516,52516,11,52544,52544,11,52572,52572,11,52600,52600,11,52628,52628,11,52656,52656,11,52684,52684,11,52712,52712,11,52740,52740,11,52768,52768,11,52796,52796,11,52824,52824,11,52852,52852,11,52880,52880,11,52908,52908,11,52936,52936,11,52964,52964,11,52992,52992,11,53020,53020,11,53048,53048,11,53076,53076,11,53104,53104,11,53132,53132,11,53160,53160,11,53188,53188,11,53216,53216,11,53244,53244,11,53272,53272,11,53300,53300,11,53328,53328,11,53356,53356,11,53384,53384,11,53412,53412,11,53440,53440,11,53468,53468,11,53496,53496,11,53524,53524,11,53552,53552,11,53580,53580,11,53608,53608,11,53636,53636,11,53664,53664,11,53692,53692,11,53720,53720,11,53748,53748,11,53776,53776,11,53804,53804,11,53832,53832,11,53860,53860,11,53888,53888,11,53916,53916,11,53944,53944,11,53972,53972,11,54000,54000,11,54028,54028,11,54056,54056,11,54084,54084,11,54112,54112,11,54140,54140,11,54168,54168,11,54196,54196,11,54224,54224,11,54252,54252,11,54280,54280,11,54308,54308,11,54336,54336,11,54364,54364,11,54392,54392,11,54420,54420,11,54448,54448,11,54476,54476,11,54504,54504,11,54532,54532,11,54560,54560,11,54588,54588,11,54616,54616,11,54644,54644,11,54672,54672,11,54700,54700,11,54728,54728,11,54756,54756,11,54784,54784,11,54812,54812,11,54840,54840,11,54868,54868,11,54896,54896,11,54924,54924,11,54952,54952,11,54980,54980,11,55008,55008,11,55036,55036,11,55064,55064,11,55092,55092,11,55120,55120,11,55148,55148,11,55176,55176,11,55216,55238,9,64286,64286,5,65056,65071,5,65438,65439,5,65529,65531,4,66272,66272,5,68097,68099,5,68108,68111,5,68159,68159,5,68900,68903,5,69446,69456,5,69632,69632,7,69634,69634,7,69744,69744,5,69759,69761,5,69808,69810,7,69815,69816,7,69821,69821,1,69837,69837,1,69927,69931,5,69933,69940,5,70003,70003,5,70018,70018,7,70070,70078,5,70082,70083,1,70094,70094,7,70188,70190,7,70194,70195,7,70197,70197,7,70206,70206,5,70368,70370,7,70400,70401,5,70459,70460,5,70463,70463,7,70465,70468,7,70475,70477,7,70498,70499,7,70512,70516,5,70712,70719,5,70722,70724,5,70726,70726,5,70832,70832,5,70835,70840,5,70842,70842,5,70845,70845,5,70847,70848,5,70850,70851,5,71088,71089,7,71096,71099,7,71102,71102,7,71132,71133,5,71219,71226,5,71229,71229,5,71231,71232,5,71340,71340,7,71342,71343,7,71350,71350,7,71453,71455,5,71462,71462,7,71724,71726,7,71736,71736,7,71984,71984,5,71991,71992,7,71997,71997,7,71999,71999,1,72001,72001,1,72003,72003,5,72148,72151,5,72156,72159,7,72164,72164,7,72243,72248,5,72250,72250,1,72263,72263,5,72279,72280,7,72324,72329,1,72343,72343,7,72751,72751,7,72760,72765,5,72767,72767,5,72873,72873,7,72881,72881,7,72884,72884,7,73009,73014,5,73020,73021,5,73030,73030,1,73098,73102,7,73107,73108,7,73110,73110,7,73459,73460,5,78896,78904,4,92976,92982,5,94033,94087,7,94180,94180,5,113821,113822,5,118528,118573,5,119141,119141,5,119143,119145,5,119150,119154,5,119163,119170,5,119210,119213,5,121344,121398,5,121461,121461,5,121499,121503,5,122880,122886,5,122907,122913,5,122918,122922,5,123566,123566,5,125136,125142,5,126976,126979,14,126981,127182,14,127184,127231,14,127279,127279,14,127344,127345,14,127374,127374,14,127405,127461,14,127489,127490,14,127514,127514,14,127538,127546,14,127561,127567,14,127570,127743,14,127757,127758,14,127760,127760,14,127762,127762,14,127766,127768,14,127770,127770,14,127772,127772,14,127775,127776,14,127778,127779,14,127789,127791,14,127794,127795,14,127798,127798,14,127819,127819,14,127824,127824,14,127868,127868,14,127870,127871,14,127892,127893,14,127896,127896,14,127900,127901,14,127904,127940,14,127942,127942,14,127944,127944,14,127946,127946,14,127951,127955,14,127968,127971,14,127973,127984,14,127987,127987,14,127989,127989,14,127991,127991,14,127995,127999,5,128008,128008,14,128012,128014,14,128017,128018,14,128020,128020,14,128022,128022,14,128042,128042,14,128063,128063,14,128065,128065,14,128101,128101,14,128108,128109,14,128173,128173,14,128182,128183,14,128236,128237,14,128239,128239,14,128245,128245,14,128248,128248,14,128253,128253,14,128255,128258,14,128260,128263,14,128265,128265,14,128277,128277,14,128300,128301,14,128326,128328,14,128331,128334,14,128336,128347,14,128360,128366,14,128369,128370,14,128378,128378,14,128391,128391,14,128394,128397,14,128400,128400,14,128405,128406,14,128420,128420,14,128422,128423,14,128425,128432,14,128435,128443,14,128445,128449,14,128453,128464,14,128468,128475,14,128479,128480,14,128482,128482,14,128484,128487,14,128489,128494,14,128496,128498,14,128500,128505,14,128507,128511,14,128513,128518,14,128521,128525,14,128527,128527,14,128529,128529,14,128533,128533,14,128535,128535,14,128537,128537,14]');\n}\n//#endregion\n/**\n * Computes the offset after performing a left delete on the given string,\n * while considering unicode grapheme/emoji rules.\n*/\nexport function getLeftDeleteOffset(offset, str) {\n if (offset === 0) {\n return 0;\n }\n // Try to delete emoji part.\n const emojiOffset = getOffsetBeforeLastEmojiComponent(offset, str);\n if (emojiOffset !== undefined) {\n return emojiOffset;\n }\n // Otherwise, just skip a single code point.\n const iterator = new CodePointIterator(str, offset);\n iterator.prevCodePoint();\n return iterator.offset;\n}\nfunction getOffsetBeforeLastEmojiComponent(initialOffset, str) {\n // See https://www.unicode.org/reports/tr51/tr51-14.html#EBNF_and_Regex for the\n // structure of emojis.\n const iterator = new CodePointIterator(str, initialOffset);\n let codePoint = iterator.prevCodePoint();\n // Skip modifiers\n while ((isEmojiModifier(codePoint) || codePoint === 65039 /* CodePoint.emojiVariantSelector */ || codePoint === 8419 /* CodePoint.enclosingKeyCap */)) {\n if (iterator.offset === 0) {\n // Cannot skip modifier, no preceding emoji base.\n return undefined;\n }\n codePoint = iterator.prevCodePoint();\n }\n // Expect base emoji\n if (!isEmojiImprecise(codePoint)) {\n // Unexpected code point, not a valid emoji.\n return undefined;\n }\n let resultOffset = iterator.offset;\n if (resultOffset > 0) {\n // Skip optional ZWJ code points that combine multiple emojis.\n // In theory, we should check if that ZWJ actually combines multiple emojis\n // to prevent deleting ZWJs in situations we didn't account for.\n const optionalZwjCodePoint = iterator.prevCodePoint();\n if (optionalZwjCodePoint === 8205 /* CodePoint.zwj */) {\n resultOffset = iterator.offset;\n }\n }\n return resultOffset;\n}\nfunction isEmojiModifier(codePoint) {\n return 0x1F3FB <= codePoint && codePoint <= 0x1F3FF;\n}\nexport const noBreakWhitespace = '\\xa0';\nexport class AmbiguousCharacters {\n constructor(confusableDictionary) {\n this.confusableDictionary = confusableDictionary;\n }\n static getInstance(locales) {\n return AmbiguousCharacters.cache.get(Array.from(locales));\n }\n static getLocales() {\n return AmbiguousCharacters._locales.getValue();\n }\n isAmbiguous(codePoint) {\n return this.confusableDictionary.has(codePoint);\n }\n /**\n * Returns the non basic ASCII code point that the given code point can be confused,\n * or undefined if such code point does note exist.\n */\n getPrimaryConfusable(codePoint) {\n return this.confusableDictionary.get(codePoint);\n }\n getConfusableCodePoints() {\n return new Set(this.confusableDictionary.keys());\n }\n}\n_a = AmbiguousCharacters;\nAmbiguousCharacters.ambiguousCharacterData = new Lazy(() => {\n // Generated using https://github.com/hediet/vscode-unicode-data\n // Stored as key1, value1, key2, value2, ...\n return JSON.parse('{\\\"_common\\\":[8232,32,8233,32,5760,32,8192,32,8193,32,8194,32,8195,32,8196,32,8197,32,8198,32,8200,32,8201,32,8202,32,8287,32,8199,32,8239,32,2042,95,65101,95,65102,95,65103,95,8208,45,8209,45,8210,45,65112,45,1748,45,8259,45,727,45,8722,45,10134,45,11450,45,1549,44,1643,44,8218,44,184,44,42233,44,894,59,2307,58,2691,58,1417,58,1795,58,1796,58,5868,58,65072,58,6147,58,6153,58,8282,58,1475,58,760,58,42889,58,8758,58,720,58,42237,58,451,33,11601,33,660,63,577,63,2429,63,5038,63,42731,63,119149,46,8228,46,1793,46,1794,46,42510,46,68176,46,1632,46,1776,46,42232,46,1373,96,65287,96,8219,96,8242,96,1370,96,1523,96,8175,96,65344,96,900,96,8189,96,8125,96,8127,96,8190,96,697,96,884,96,712,96,714,96,715,96,756,96,699,96,701,96,700,96,702,96,42892,96,1497,96,2036,96,2037,96,5194,96,5836,96,94033,96,94034,96,65339,91,10088,40,10098,40,12308,40,64830,40,65341,93,10089,41,10099,41,12309,41,64831,41,10100,123,119060,123,10101,125,65342,94,8270,42,1645,42,8727,42,66335,42,5941,47,8257,47,8725,47,8260,47,9585,47,10187,47,10744,47,119354,47,12755,47,12339,47,11462,47,20031,47,12035,47,65340,92,65128,92,8726,92,10189,92,10741,92,10745,92,119311,92,119355,92,12756,92,20022,92,12034,92,42872,38,708,94,710,94,5869,43,10133,43,66203,43,8249,60,10094,60,706,60,119350,60,5176,60,5810,60,5120,61,11840,61,12448,61,42239,61,8250,62,10095,62,707,62,119351,62,5171,62,94015,62,8275,126,732,126,8128,126,8764,126,65372,124,65293,45,120784,50,120794,50,120804,50,120814,50,120824,50,130034,50,42842,50,423,50,1000,50,42564,50,5311,50,42735,50,119302,51,120785,51,120795,51,120805,51,120815,51,120825,51,130035,51,42923,51,540,51,439,51,42858,51,11468,51,1248,51,94011,51,71882,51,120786,52,120796,52,120806,52,120816,52,120826,52,130036,52,5070,52,71855,52,120787,53,120797,53,120807,53,120817,53,120827,53,130037,53,444,53,71867,53,120788,54,120798,54,120808,54,120818,54,120828,54,130038,54,11474,54,5102,54,71893,54,119314,55,120789,55,120799,55,120809,55,120819,55,120829,55,130039,55,66770,55,71878,55,2819,56,2538,56,2666,56,125131,56,120790,56,120800,56,120810,56,120820,56,120830,56,130040,56,547,56,546,56,66330,56,2663,57,2920,57,2541,57,3437,57,120791,57,120801,57,120811,57,120821,57,120831,57,130041,57,42862,57,11466,57,71884,57,71852,57,71894,57,9082,97,65345,97,119834,97,119886,97,119938,97,119990,97,120042,97,120094,97,120146,97,120198,97,120250,97,120302,97,120354,97,120406,97,120458,97,593,97,945,97,120514,97,120572,97,120630,97,120688,97,120746,97,65313,65,119808,65,119860,65,119912,65,119964,65,120016,65,120068,65,120120,65,120172,65,120224,65,120276,65,120328,65,120380,65,120432,65,913,65,120488,65,120546,65,120604,65,120662,65,120720,65,5034,65,5573,65,42222,65,94016,65,66208,65,119835,98,119887,98,119939,98,119991,98,120043,98,120095,98,120147,98,120199,98,120251,98,120303,98,120355,98,120407,98,120459,98,388,98,5071,98,5234,98,5551,98,65314,66,8492,66,119809,66,119861,66,119913,66,120017,66,120069,66,120121,66,120173,66,120225,66,120277,66,120329,66,120381,66,120433,66,42932,66,914,66,120489,66,120547,66,120605,66,120663,66,120721,66,5108,66,5623,66,42192,66,66178,66,66209,66,66305,66,65347,99,8573,99,119836,99,119888,99,119940,99,119992,99,120044,99,120096,99,120148,99,120200,99,120252,99,120304,99,120356,99,120408,99,120460,99,7428,99,1010,99,11429,99,43951,99,66621,99,128844,67,71922,67,71913,67,65315,67,8557,67,8450,67,8493,67,119810,67,119862,67,119914,67,119966,67,120018,67,120174,67,120226,67,120278,67,120330,67,120382,67,120434,67,1017,67,11428,67,5087,67,42202,67,66210,67,66306,67,66581,67,66844,67,8574,100,8518,100,119837,100,119889,100,119941,100,119993,100,120045,100,120097,100,120149,100,120201,100,120253,100,120305,100,120357,100,120409,100,120461,100,1281,100,5095,100,5231,100,42194,100,8558,68,8517,68,119811,68,119863,68,119915,68,119967,68,120019,68,120071,68,120123,68,120175,68,120227,68,120279,68,120331,68,120383,68,120435,68,5024,68,5598,68,5610,68,42195,68,8494,101,65349,101,8495,101,8519,101,119838,101,119890,101,119942,101,120046,101,120098,101,120150,101,120202,101,120254,101,120306,101,120358,101,120410,101,120462,101,43826,101,1213,101,8959,69,65317,69,8496,69,119812,69,119864,69,119916,69,120020,69,120072,69,120124,69,120176,69,120228,69,120280,69,120332,69,120384,69,120436,69,917,69,120492,69,120550,69,120608,69,120666,69,120724,69,11577,69,5036,69,42224,69,71846,69,71854,69,66182,69,119839,102,119891,102,119943,102,119995,102,120047,102,120099,102,120151,102,120203,102,120255,102,120307,102,120359,102,120411,102,120463,102,43829,102,42905,102,383,102,7837,102,1412,102,119315,70,8497,70,119813,70,119865,70,119917,70,120021,70,120073,70,120125,70,120177,70,120229,70,120281,70,120333,70,120385,70,120437,70,42904,70,988,70,120778,70,5556,70,42205,70,71874,70,71842,70,66183,70,66213,70,66853,70,65351,103,8458,103,119840,103,119892,103,119944,103,120048,103,120100,103,120152,103,120204,103,120256,103,120308,103,120360,103,120412,103,120464,103,609,103,7555,103,397,103,1409,103,119814,71,119866,71,119918,71,119970,71,120022,71,120074,71,120126,71,120178,71,120230,71,120282,71,120334,71,120386,71,120438,71,1292,71,5056,71,5107,71,42198,71,65352,104,8462,104,119841,104,119945,104,119997,104,120049,104,120101,104,120153,104,120205,104,120257,104,120309,104,120361,104,120413,104,120465,104,1211,104,1392,104,5058,104,65320,72,8459,72,8460,72,8461,72,119815,72,119867,72,119919,72,120023,72,120179,72,120231,72,120283,72,120335,72,120387,72,120439,72,919,72,120494,72,120552,72,120610,72,120668,72,120726,72,11406,72,5051,72,5500,72,42215,72,66255,72,731,105,9075,105,65353,105,8560,105,8505,105,8520,105,119842,105,119894,105,119946,105,119998,105,120050,105,120102,105,120154,105,120206,105,120258,105,120310,105,120362,105,120414,105,120466,105,120484,105,618,105,617,105,953,105,8126,105,890,105,120522,105,120580,105,120638,105,120696,105,120754,105,1110,105,42567,105,1231,105,43893,105,5029,105,71875,105,65354,106,8521,106,119843,106,119895,106,119947,106,119999,106,120051,106,120103,106,120155,106,120207,106,120259,106,120311,106,120363,106,120415,106,120467,106,1011,106,1112,106,65322,74,119817,74,119869,74,119921,74,119973,74,120025,74,120077,74,120129,74,120181,74,120233,74,120285,74,120337,74,120389,74,120441,74,42930,74,895,74,1032,74,5035,74,5261,74,42201,74,119844,107,119896,107,119948,107,120000,107,120052,107,120104,107,120156,107,120208,107,120260,107,120312,107,120364,107,120416,107,120468,107,8490,75,65323,75,119818,75,119870,75,119922,75,119974,75,120026,75,120078,75,120130,75,120182,75,120234,75,120286,75,120338,75,120390,75,120442,75,922,75,120497,75,120555,75,120613,75,120671,75,120729,75,11412,75,5094,75,5845,75,42199,75,66840,75,1472,108,8739,73,9213,73,65512,73,1633,108,1777,73,66336,108,125127,108,120783,73,120793,73,120803,73,120813,73,120823,73,130033,73,65321,73,8544,73,8464,73,8465,73,119816,73,119868,73,119920,73,120024,73,120128,73,120180,73,120232,73,120284,73,120336,73,120388,73,120440,73,65356,108,8572,73,8467,108,119845,108,119897,108,119949,108,120001,108,120053,108,120105,73,120157,73,120209,73,120261,73,120313,73,120365,73,120417,73,120469,73,448,73,120496,73,120554,73,120612,73,120670,73,120728,73,11410,73,1030,73,1216,73,1493,108,1503,108,1575,108,126464,108,126592,108,65166,108,65165,108,1994,108,11599,73,5825,73,42226,73,93992,73,66186,124,66313,124,119338,76,8556,76,8466,76,119819,76,119871,76,119923,76,120027,76,120079,76,120131,76,120183,76,120235,76,120287,76,120339,76,120391,76,120443,76,11472,76,5086,76,5290,76,42209,76,93974,76,71843,76,71858,76,66587,76,66854,76,65325,77,8559,77,8499,77,119820,77,119872,77,119924,77,120028,77,120080,77,120132,77,120184,77,120236,77,120288,77,120340,77,120392,77,120444,77,924,77,120499,77,120557,77,120615,77,120673,77,120731,77,1018,77,11416,77,5047,77,5616,77,5846,77,42207,77,66224,77,66321,77,119847,110,119899,110,119951,110,120003,110,120055,110,120107,110,120159,110,120211,110,120263,110,120315,110,120367,110,120419,110,120471,110,1400,110,1404,110,65326,78,8469,78,119821,78,119873,78,119925,78,119977,78,120029,78,120081,78,120185,78,120237,78,120289,78,120341,78,120393,78,120445,78,925,78,120500,78,120558,78,120616,78,120674,78,120732,78,11418,78,42208,78,66835,78,3074,111,3202,111,3330,111,3458,111,2406,111,2662,111,2790,111,3046,111,3174,111,3302,111,3430,111,3664,111,3792,111,4160,111,1637,111,1781,111,65359,111,8500,111,119848,111,119900,111,119952,111,120056,111,120108,111,120160,111,120212,111,120264,111,120316,111,120368,111,120420,111,120472,111,7439,111,7441,111,43837,111,959,111,120528,111,120586,111,120644,111,120702,111,120760,111,963,111,120532,111,120590,111,120648,111,120706,111,120764,111,11423,111,4351,111,1413,111,1505,111,1607,111,126500,111,126564,111,126596,111,65259,111,65260,111,65258,111,65257,111,1726,111,64428,111,64429,111,64427,111,64426,111,1729,111,64424,111,64425,111,64423,111,64422,111,1749,111,3360,111,4125,111,66794,111,71880,111,71895,111,66604,111,1984,79,2534,79,2918,79,12295,79,70864,79,71904,79,120782,79,120792,79,120802,79,120812,79,120822,79,130032,79,65327,79,119822,79,119874,79,119926,79,119978,79,120030,79,120082,79,120134,79,120186,79,120238,79,120290,79,120342,79,120394,79,120446,79,927,79,120502,79,120560,79,120618,79,120676,79,120734,79,11422,79,1365,79,11604,79,4816,79,2848,79,66754,79,42227,79,71861,79,66194,79,66219,79,66564,79,66838,79,9076,112,65360,112,119849,112,119901,112,119953,112,120005,112,120057,112,120109,112,120161,112,120213,112,120265,112,120317,112,120369,112,120421,112,120473,112,961,112,120530,112,120544,112,120588,112,120602,112,120646,112,120660,112,120704,112,120718,112,120762,112,120776,112,11427,112,65328,80,8473,80,119823,80,119875,80,119927,80,119979,80,120031,80,120083,80,120187,80,120239,80,120291,80,120343,80,120395,80,120447,80,929,80,120504,80,120562,80,120620,80,120678,80,120736,80,11426,80,5090,80,5229,80,42193,80,66197,80,119850,113,119902,113,119954,113,120006,113,120058,113,120110,113,120162,113,120214,113,120266,113,120318,113,120370,113,120422,113,120474,113,1307,113,1379,113,1382,113,8474,81,119824,81,119876,81,119928,81,119980,81,120032,81,120084,81,120188,81,120240,81,120292,81,120344,81,120396,81,120448,81,11605,81,119851,114,119903,114,119955,114,120007,114,120059,114,120111,114,120163,114,120215,114,120267,114,120319,114,120371,114,120423,114,120475,114,43847,114,43848,114,7462,114,11397,114,43905,114,119318,82,8475,82,8476,82,8477,82,119825,82,119877,82,119929,82,120033,82,120189,82,120241,82,120293,82,120345,82,120397,82,120449,82,422,82,5025,82,5074,82,66740,82,5511,82,42211,82,94005,82,65363,115,119852,115,119904,115,119956,115,120008,115,120060,115,120112,115,120164,115,120216,115,120268,115,120320,115,120372,115,120424,115,120476,115,42801,115,445,115,1109,115,43946,115,71873,115,66632,115,65331,83,119826,83,119878,83,119930,83,119982,83,120034,83,120086,83,120138,83,120190,83,120242,83,120294,83,120346,83,120398,83,120450,83,1029,83,1359,83,5077,83,5082,83,42210,83,94010,83,66198,83,66592,83,119853,116,119905,116,119957,116,120009,116,120061,116,120113,116,120165,116,120217,116,120269,116,120321,116,120373,116,120425,116,120477,116,8868,84,10201,84,128872,84,65332,84,119827,84,119879,84,119931,84,119983,84,120035,84,120087,84,120139,84,120191,84,120243,84,120295,84,120347,84,120399,84,120451,84,932,84,120507,84,120565,84,120623,84,120681,84,120739,84,11430,84,5026,84,42196,84,93962,84,71868,84,66199,84,66225,84,66325,84,119854,117,119906,117,119958,117,120010,117,120062,117,120114,117,120166,117,120218,117,120270,117,120322,117,120374,117,120426,117,120478,117,42911,117,7452,117,43854,117,43858,117,651,117,965,117,120534,117,120592,117,120650,117,120708,117,120766,117,1405,117,66806,117,71896,117,8746,85,8899,85,119828,85,119880,85,119932,85,119984,85,120036,85,120088,85,120140,85,120192,85,120244,85,120296,85,120348,85,120400,85,120452,85,1357,85,4608,85,66766,85,5196,85,42228,85,94018,85,71864,85,8744,118,8897,118,65366,118,8564,118,119855,118,119907,118,119959,118,120011,118,120063,118,120115,118,120167,118,120219,118,120271,118,120323,118,120375,118,120427,118,120479,118,7456,118,957,118,120526,118,120584,118,120642,118,120700,118,120758,118,1141,118,1496,118,71430,118,43945,118,71872,118,119309,86,1639,86,1783,86,8548,86,119829,86,119881,86,119933,86,119985,86,120037,86,120089,86,120141,86,120193,86,120245,86,120297,86,120349,86,120401,86,120453,86,1140,86,11576,86,5081,86,5167,86,42719,86,42214,86,93960,86,71840,86,66845,86,623,119,119856,119,119908,119,119960,119,120012,119,120064,119,120116,119,120168,119,120220,119,120272,119,120324,119,120376,119,120428,119,120480,119,7457,119,1121,119,1309,119,1377,119,71434,119,71438,119,71439,119,43907,119,71919,87,71910,87,119830,87,119882,87,119934,87,119986,87,120038,87,120090,87,120142,87,120194,87,120246,87,120298,87,120350,87,120402,87,120454,87,1308,87,5043,87,5076,87,42218,87,5742,120,10539,120,10540,120,10799,120,65368,120,8569,120,119857,120,119909,120,119961,120,120013,120,120065,120,120117,120,120169,120,120221,120,120273,120,120325,120,120377,120,120429,120,120481,120,5441,120,5501,120,5741,88,9587,88,66338,88,71916,88,65336,88,8553,88,119831,88,119883,88,119935,88,119987,88,120039,88,120091,88,120143,88,120195,88,120247,88,120299,88,120351,88,120403,88,120455,88,42931,88,935,88,120510,88,120568,88,120626,88,120684,88,120742,88,11436,88,11613,88,5815,88,42219,88,66192,88,66228,88,66327,88,66855,88,611,121,7564,121,65369,121,119858,121,119910,121,119962,121,120014,121,120066,121,120118,121,120170,121,120222,121,120274,121,120326,121,120378,121,120430,121,120482,121,655,121,7935,121,43866,121,947,121,8509,121,120516,121,120574,121,120632,121,120690,121,120748,121,1199,121,4327,121,71900,121,65337,89,119832,89,119884,89,119936,89,119988,89,120040,89,120092,89,120144,89,120196,89,120248,89,120300,89,120352,89,120404,89,120456,89,933,89,978,89,120508,89,120566,89,120624,89,120682,89,120740,89,11432,89,1198,89,5033,89,5053,89,42220,89,94019,89,71844,89,66226,89,119859,122,119911,122,119963,122,120015,122,120067,122,120119,122,120171,122,120223,122,120275,122,120327,122,120379,122,120431,122,120483,122,7458,122,43923,122,71876,122,66293,90,71909,90,65338,90,8484,90,8488,90,119833,90,119885,90,119937,90,119989,90,120041,90,120197,90,120249,90,120301,90,120353,90,120405,90,120457,90,918,90,120493,90,120551,90,120609,90,120667,90,120725,90,5059,90,42204,90,71849,90,65282,34,65284,36,65285,37,65286,38,65290,42,65291,43,65294,46,65295,47,65296,48,65297,49,65298,50,65299,51,65300,52,65301,53,65302,54,65303,55,65304,56,65305,57,65308,60,65309,61,65310,62,65312,64,65316,68,65318,70,65319,71,65324,76,65329,81,65330,82,65333,85,65334,86,65335,87,65343,95,65346,98,65348,100,65350,102,65355,107,65357,109,65358,110,65361,113,65362,114,65364,116,65365,117,65367,119,65370,122,65371,123,65373,125],\\\"_default\\\":[160,32,8211,45,65374,126,65306,58,65281,33,8216,96,8217,96,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"cs\\\":[65374,126,65306,58,65281,33,8216,96,8217,96,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"de\\\":[65374,126,65306,58,65281,33,8216,96,8217,96,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"es\\\":[8211,45,65374,126,65306,58,65281,33,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"fr\\\":[65374,126,65306,58,65281,33,8216,96,8245,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"it\\\":[160,32,8211,45,65374,126,65306,58,65281,33,8216,96,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"ja\\\":[8211,45,65306,58,65281,33,8216,96,8217,96,8245,96,180,96,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65292,44,65307,59],\\\"ko\\\":[8211,45,65374,126,65306,58,65281,33,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"pl\\\":[65374,126,65306,58,65281,33,8216,96,8217,96,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"pt-BR\\\":[65374,126,65306,58,65281,33,8216,96,8217,96,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"qps-ploc\\\":[160,32,8211,45,65374,126,65306,58,65281,33,8216,96,8217,96,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"ru\\\":[65374,126,65306,58,65281,33,8216,96,8217,96,8245,96,180,96,12494,47,305,105,921,73,1009,112,215,120,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"tr\\\":[160,32,8211,45,65374,126,65306,58,65281,33,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65288,40,65289,41,65292,44,65307,59,65311,63],\\\"zh-hans\\\":[65374,126,65306,58,65281,33,8245,96,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65288,40,65289,41],\\\"zh-hant\\\":[8211,45,65374,126,180,96,12494,47,1047,51,1073,54,1072,97,1040,65,1068,98,1042,66,1089,99,1057,67,1077,101,1045,69,1053,72,305,105,1050,75,921,73,1052,77,1086,111,1054,79,1009,112,1088,112,1056,80,1075,114,1058,84,215,120,1093,120,1061,88,1091,121,1059,89,65283,35,65307,59]}');\n});\nAmbiguousCharacters.cache = new LRUCachedFunction((locales) => {\n function arrayToMap(arr) {\n const result = new Map();\n for (let i = 0; i < arr.length; i += 2) {\n result.set(arr[i], arr[i + 1]);\n }\n return result;\n }\n function mergeMaps(map1, map2) {\n const result = new Map(map1);\n for (const [key, value] of map2) {\n result.set(key, value);\n }\n return result;\n }\n function intersectMaps(map1, map2) {\n if (!map1) {\n return map2;\n }\n const result = new Map();\n for (const [key, value] of map1) {\n if (map2.has(key)) {\n result.set(key, value);\n }\n }\n return result;\n }\n const data = _a.ambiguousCharacterData.getValue();\n let filteredLocales = locales.filter((l) => !l.startsWith('_') && l in data);\n if (filteredLocales.length === 0) {\n filteredLocales = ['_default'];\n }\n let languageSpecificMap = undefined;\n for (const locale of filteredLocales) {\n const map = arrayToMap(data[locale]);\n languageSpecificMap = intersectMaps(languageSpecificMap, map);\n }\n const commonMap = arrayToMap(data['_common']);\n const map = mergeMaps(commonMap, languageSpecificMap);\n return new AmbiguousCharacters(map);\n});\nAmbiguousCharacters._locales = new Lazy(() => Object.keys(AmbiguousCharacters.ambiguousCharacterData.getValue()).filter((k) => !k.startsWith('_')));\nexport class InvisibleCharacters {\n static getRawData() {\n // Generated using https://github.com/hediet/vscode-unicode-data\n return JSON.parse('[9,10,11,12,13,32,127,160,173,847,1564,4447,4448,6068,6069,6155,6156,6157,6158,7355,7356,8192,8193,8194,8195,8196,8197,8198,8199,8200,8201,8202,8203,8204,8205,8206,8207,8234,8235,8236,8237,8238,8239,8287,8288,8289,8290,8291,8292,8293,8294,8295,8296,8297,8298,8299,8300,8301,8302,8303,10240,12288,12644,65024,65025,65026,65027,65028,65029,65030,65031,65032,65033,65034,65035,65036,65037,65038,65039,65279,65440,65520,65521,65522,65523,65524,65525,65526,65527,65528,65532,78844,119155,119156,119157,119158,119159,119160,119161,119162,917504,917505,917506,917507,917508,917509,917510,917511,917512,917513,917514,917515,917516,917517,917518,917519,917520,917521,917522,917523,917524,917525,917526,917527,917528,917529,917530,917531,917532,917533,917534,917535,917536,917537,917538,917539,917540,917541,917542,917543,917544,917545,917546,917547,917548,917549,917550,917551,917552,917553,917554,917555,917556,917557,917558,917559,917560,917561,917562,917563,917564,917565,917566,917567,917568,917569,917570,917571,917572,917573,917574,917575,917576,917577,917578,917579,917580,917581,917582,917583,917584,917585,917586,917587,917588,917589,917590,917591,917592,917593,917594,917595,917596,917597,917598,917599,917600,917601,917602,917603,917604,917605,917606,917607,917608,917609,917610,917611,917612,917613,917614,917615,917616,917617,917618,917619,917620,917621,917622,917623,917624,917625,917626,917627,917628,917629,917630,917631,917760,917761,917762,917763,917764,917765,917766,917767,917768,917769,917770,917771,917772,917773,917774,917775,917776,917777,917778,917779,917780,917781,917782,917783,917784,917785,917786,917787,917788,917789,917790,917791,917792,917793,917794,917795,917796,917797,917798,917799,917800,917801,917802,917803,917804,917805,917806,917807,917808,917809,917810,917811,917812,917813,917814,917815,917816,917817,917818,917819,917820,917821,917822,917823,917824,917825,917826,917827,917828,917829,917830,917831,917832,917833,917834,917835,917836,917837,917838,917839,917840,917841,917842,917843,917844,917845,917846,917847,917848,917849,917850,917851,917852,917853,917854,917855,917856,917857,917858,917859,917860,917861,917862,917863,917864,917865,917866,917867,917868,917869,917870,917871,917872,917873,917874,917875,917876,917877,917878,917879,917880,917881,917882,917883,917884,917885,917886,917887,917888,917889,917890,917891,917892,917893,917894,917895,917896,917897,917898,917899,917900,917901,917902,917903,917904,917905,917906,917907,917908,917909,917910,917911,917912,917913,917914,917915,917916,917917,917918,917919,917920,917921,917922,917923,917924,917925,917926,917927,917928,917929,917930,917931,917932,917933,917934,917935,917936,917937,917938,917939,917940,917941,917942,917943,917944,917945,917946,917947,917948,917949,917950,917951,917952,917953,917954,917955,917956,917957,917958,917959,917960,917961,917962,917963,917964,917965,917966,917967,917968,917969,917970,917971,917972,917973,917974,917975,917976,917977,917978,917979,917980,917981,917982,917983,917984,917985,917986,917987,917988,917989,917990,917991,917992,917993,917994,917995,917996,917997,917998,917999]');\n }\n static getData() {\n if (!this._data) {\n this._data = new Set(InvisibleCharacters.getRawData());\n }\n return this._data;\n }\n static isInvisibleCharacter(codePoint) {\n return InvisibleCharacters.getData().has(codePoint);\n }\n static get codePoints() {\n return InvisibleCharacters.getData();\n }\n}\nInvisibleCharacters._data = undefined;\n","/**\n * Uses a LRU cache to make a given parametrized function cached.\n * Caches just the last value.\n * The key must be JSON serializable.\n*/\nexport class LRUCachedFunction {\n constructor(fn) {\n this.fn = fn;\n this.lastCache = undefined;\n this.lastArgKey = undefined;\n }\n get(arg) {\n const key = JSON.stringify(arg);\n if (this.lastArgKey !== key) {\n this.lastArgKey = key;\n this.lastCache = this.fn(arg);\n }\n return this.lastCache;\n }\n}\n/**\n * Uses an unbounded cache (referential equality) to memoize the results of the given function.\n*/\nexport class CachedFunction {\n constructor(fn) {\n this.fn = fn;\n this._map = new Map();\n }\n get cachedValues() {\n return this._map;\n }\n get(arg) {\n if (this._map.has(arg)) {\n return this._map.get(arg);\n }\n const value = this.fn(arg);\n this._map.set(arg, value);\n return value;\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { transformErrorForSerialization } from '../errors.js';\nimport { Emitter } from '../event.js';\nimport { Disposable } from '../lifecycle.js';\nimport { globals, isWeb } from '../platform.js';\nimport * as types from '../types.js';\nimport * as strings from '../strings.js';\nconst INITIALIZE = '$initialize';\nlet webWorkerWarningLogged = false;\nexport function logOnceWebWorkerWarning(err) {\n if (!isWeb) {\n // running tests\n return;\n }\n if (!webWorkerWarningLogged) {\n webWorkerWarningLogged = true;\n console.warn('Could not create web worker(s). Falling back to loading web worker code in main thread, which might cause UI freezes. Please see https://github.com/microsoft/monaco-editor#faq');\n }\n console.warn(err.message);\n}\nclass RequestMessage {\n constructor(vsWorker, req, method, args) {\n this.vsWorker = vsWorker;\n this.req = req;\n this.method = method;\n this.args = args;\n this.type = 0 /* MessageType.Request */;\n }\n}\nclass ReplyMessage {\n constructor(vsWorker, seq, res, err) {\n this.vsWorker = vsWorker;\n this.seq = seq;\n this.res = res;\n this.err = err;\n this.type = 1 /* MessageType.Reply */;\n }\n}\nclass SubscribeEventMessage {\n constructor(vsWorker, req, eventName, arg) {\n this.vsWorker = vsWorker;\n this.req = req;\n this.eventName = eventName;\n this.arg = arg;\n this.type = 2 /* MessageType.SubscribeEvent */;\n }\n}\nclass EventMessage {\n constructor(vsWorker, req, event) {\n this.vsWorker = vsWorker;\n this.req = req;\n this.event = event;\n this.type = 3 /* MessageType.Event */;\n }\n}\nclass UnsubscribeEventMessage {\n constructor(vsWorker, req) {\n this.vsWorker = vsWorker;\n this.req = req;\n this.type = 4 /* MessageType.UnsubscribeEvent */;\n }\n}\nclass SimpleWorkerProtocol {\n constructor(handler) {\n this._workerId = -1;\n this._handler = handler;\n this._lastSentReq = 0;\n this._pendingReplies = Object.create(null);\n this._pendingEmitters = new Map();\n this._pendingEvents = new Map();\n }\n setWorkerId(workerId) {\n this._workerId = workerId;\n }\n sendMessage(method, args) {\n const req = String(++this._lastSentReq);\n return new Promise((resolve, reject) => {\n this._pendingReplies[req] = {\n resolve: resolve,\n reject: reject\n };\n this._send(new RequestMessage(this._workerId, req, method, args));\n });\n }\n listen(eventName, arg) {\n let req = null;\n const emitter = new Emitter({\n onFirstListenerAdd: () => {\n req = String(++this._lastSentReq);\n this._pendingEmitters.set(req, emitter);\n this._send(new SubscribeEventMessage(this._workerId, req, eventName, arg));\n },\n onLastListenerRemove: () => {\n this._pendingEmitters.delete(req);\n this._send(new UnsubscribeEventMessage(this._workerId, req));\n req = null;\n }\n });\n return emitter.event;\n }\n handleMessage(message) {\n if (!message || !message.vsWorker) {\n return;\n }\n if (this._workerId !== -1 && message.vsWorker !== this._workerId) {\n return;\n }\n this._handleMessage(message);\n }\n _handleMessage(msg) {\n switch (msg.type) {\n case 1 /* MessageType.Reply */:\n return this._handleReplyMessage(msg);\n case 0 /* MessageType.Request */:\n return this._handleRequestMessage(msg);\n case 2 /* MessageType.SubscribeEvent */:\n return this._handleSubscribeEventMessage(msg);\n case 3 /* MessageType.Event */:\n return this._handleEventMessage(msg);\n case 4 /* MessageType.UnsubscribeEvent */:\n return this._handleUnsubscribeEventMessage(msg);\n }\n }\n _handleReplyMessage(replyMessage) {\n if (!this._pendingReplies[replyMessage.seq]) {\n console.warn('Got reply to unknown seq');\n return;\n }\n const reply = this._pendingReplies[replyMessage.seq];\n delete this._pendingReplies[replyMessage.seq];\n if (replyMessage.err) {\n let err = replyMessage.err;\n if (replyMessage.err.$isError) {\n err = new Error();\n err.name = replyMessage.err.name;\n err.message = replyMessage.err.message;\n err.stack = replyMessage.err.stack;\n }\n reply.reject(err);\n return;\n }\n reply.resolve(replyMessage.res);\n }\n _handleRequestMessage(requestMessage) {\n const req = requestMessage.req;\n const result = this._handler.handleMessage(requestMessage.method, requestMessage.args);\n result.then((r) => {\n this._send(new ReplyMessage(this._workerId, req, r, undefined));\n }, (e) => {\n if (e.detail instanceof Error) {\n // Loading errors have a detail property that points to the actual error\n e.detail = transformErrorForSerialization(e.detail);\n }\n this._send(new ReplyMessage(this._workerId, req, undefined, transformErrorForSerialization(e)));\n });\n }\n _handleSubscribeEventMessage(msg) {\n const req = msg.req;\n const disposable = this._handler.handleEvent(msg.eventName, msg.arg)((event) => {\n this._send(new EventMessage(this._workerId, req, event));\n });\n this._pendingEvents.set(req, disposable);\n }\n _handleEventMessage(msg) {\n if (!this._pendingEmitters.has(msg.req)) {\n console.warn('Got event for unknown req');\n return;\n }\n this._pendingEmitters.get(msg.req).fire(msg.event);\n }\n _handleUnsubscribeEventMessage(msg) {\n if (!this._pendingEvents.has(msg.req)) {\n console.warn('Got unsubscribe for unknown req');\n return;\n }\n this._pendingEvents.get(msg.req).dispose();\n this._pendingEvents.delete(msg.req);\n }\n _send(msg) {\n const transfer = [];\n if (msg.type === 0 /* MessageType.Request */) {\n for (let i = 0; i < msg.args.length; i++) {\n if (msg.args[i] instanceof ArrayBuffer) {\n transfer.push(msg.args[i]);\n }\n }\n }\n else if (msg.type === 1 /* MessageType.Reply */) {\n if (msg.res instanceof ArrayBuffer) {\n transfer.push(msg.res);\n }\n }\n this._handler.sendMessage(msg, transfer);\n }\n}\n/**\n * Main thread side\n */\nexport class SimpleWorkerClient extends Disposable {\n constructor(workerFactory, moduleId, host) {\n super();\n let lazyProxyReject = null;\n this._worker = this._register(workerFactory.create('vs/base/common/worker/simpleWorker', (msg) => {\n this._protocol.handleMessage(msg);\n }, (err) => {\n // in Firefox, web workers fail lazily :(\n // we will reject the proxy\n lazyProxyReject === null || lazyProxyReject === void 0 ? void 0 : lazyProxyReject(err);\n }));\n this._protocol = new SimpleWorkerProtocol({\n sendMessage: (msg, transfer) => {\n this._worker.postMessage(msg, transfer);\n },\n handleMessage: (method, args) => {\n if (typeof host[method] !== 'function') {\n return Promise.reject(new Error('Missing method ' + method + ' on main thread host.'));\n }\n try {\n return Promise.resolve(host[method].apply(host, args));\n }\n catch (e) {\n return Promise.reject(e);\n }\n },\n handleEvent: (eventName, arg) => {\n if (propertyIsDynamicEvent(eventName)) {\n const event = host[eventName].call(host, arg);\n if (typeof event !== 'function') {\n throw new Error(`Missing dynamic event ${eventName} on main thread host.`);\n }\n return event;\n }\n if (propertyIsEvent(eventName)) {\n const event = host[eventName];\n if (typeof event !== 'function') {\n throw new Error(`Missing event ${eventName} on main thread host.`);\n }\n return event;\n }\n throw new Error(`Malformed event name ${eventName}`);\n }\n });\n this._protocol.setWorkerId(this._worker.getId());\n // Gather loader configuration\n let loaderConfiguration = null;\n if (typeof globals.require !== 'undefined' && typeof globals.require.getConfig === 'function') {\n // Get the configuration from the Monaco AMD Loader\n loaderConfiguration = globals.require.getConfig();\n }\n else if (typeof globals.requirejs !== 'undefined') {\n // Get the configuration from requirejs\n loaderConfiguration = globals.requirejs.s.contexts._.config;\n }\n const hostMethods = types.getAllMethodNames(host);\n // Send initialize message\n this._onModuleLoaded = this._protocol.sendMessage(INITIALIZE, [\n this._worker.getId(),\n JSON.parse(JSON.stringify(loaderConfiguration)),\n moduleId,\n hostMethods,\n ]);\n // Create proxy to loaded code\n const proxyMethodRequest = (method, args) => {\n return this._request(method, args);\n };\n const proxyListen = (eventName, arg) => {\n return this._protocol.listen(eventName, arg);\n };\n this._lazyProxy = new Promise((resolve, reject) => {\n lazyProxyReject = reject;\n this._onModuleLoaded.then((availableMethods) => {\n resolve(createProxyObject(availableMethods, proxyMethodRequest, proxyListen));\n }, (e) => {\n reject(e);\n this._onError('Worker failed to load ' + moduleId, e);\n });\n });\n }\n getProxyObject() {\n return this._lazyProxy;\n }\n _request(method, args) {\n return new Promise((resolve, reject) => {\n this._onModuleLoaded.then(() => {\n this._protocol.sendMessage(method, args).then(resolve, reject);\n }, reject);\n });\n }\n _onError(message, error) {\n console.error(message);\n console.info(error);\n }\n}\nfunction propertyIsEvent(name) {\n // Assume a property is an event if it has a form of \"onSomething\"\n return name[0] === 'o' && name[1] === 'n' && strings.isUpperAsciiLetter(name.charCodeAt(2));\n}\nfunction propertyIsDynamicEvent(name) {\n // Assume a property is a dynamic event (a method that returns an event) if it has a form of \"onDynamicSomething\"\n return /^onDynamic/.test(name) && strings.isUpperAsciiLetter(name.charCodeAt(9));\n}\nfunction createProxyObject(methodNames, invoke, proxyListen) {\n const createProxyMethod = (method) => {\n return function () {\n const args = Array.prototype.slice.call(arguments, 0);\n return invoke(method, args);\n };\n };\n const createProxyDynamicEvent = (eventName) => {\n return function (arg) {\n return proxyListen(eventName, arg);\n };\n };\n const result = {};\n for (const methodName of methodNames) {\n if (propertyIsDynamicEvent(methodName)) {\n result[methodName] = createProxyDynamicEvent(methodName);\n continue;\n }\n if (propertyIsEvent(methodName)) {\n result[methodName] = proxyListen(methodName, undefined);\n continue;\n }\n result[methodName] = createProxyMethod(methodName);\n }\n return result;\n}\n/**\n * Worker side\n */\nexport class SimpleWorkerServer {\n constructor(postMessage, requestHandlerFactory) {\n this._requestHandlerFactory = requestHandlerFactory;\n this._requestHandler = null;\n this._protocol = new SimpleWorkerProtocol({\n sendMessage: (msg, transfer) => {\n postMessage(msg, transfer);\n },\n handleMessage: (method, args) => this._handleMessage(method, args),\n handleEvent: (eventName, arg) => this._handleEvent(eventName, arg)\n });\n }\n onmessage(msg) {\n this._protocol.handleMessage(msg);\n }\n _handleMessage(method, args) {\n if (method === INITIALIZE) {\n return this.initialize(args[0], args[1], args[2], args[3]);\n }\n if (!this._requestHandler || typeof this._requestHandler[method] !== 'function') {\n return Promise.reject(new Error('Missing requestHandler or method: ' + method));\n }\n try {\n return Promise.resolve(this._requestHandler[method].apply(this._requestHandler, args));\n }\n catch (e) {\n return Promise.reject(e);\n }\n }\n _handleEvent(eventName, arg) {\n if (!this._requestHandler) {\n throw new Error(`Missing requestHandler`);\n }\n if (propertyIsDynamicEvent(eventName)) {\n const event = this._requestHandler[eventName].call(this._requestHandler, arg);\n if (typeof event !== 'function') {\n throw new Error(`Missing dynamic event ${eventName} on request handler.`);\n }\n return event;\n }\n if (propertyIsEvent(eventName)) {\n const event = this._requestHandler[eventName];\n if (typeof event !== 'function') {\n throw new Error(`Missing event ${eventName} on request handler.`);\n }\n return event;\n }\n throw new Error(`Malformed event name ${eventName}`);\n }\n initialize(workerId, loaderConfig, moduleId, hostMethods) {\n this._protocol.setWorkerId(workerId);\n const proxyMethodRequest = (method, args) => {\n return this._protocol.sendMessage(method, args);\n };\n const proxyListen = (eventName, arg) => {\n return this._protocol.listen(eventName, arg);\n };\n const hostProxy = createProxyObject(hostMethods, proxyMethodRequest, proxyListen);\n if (this._requestHandlerFactory) {\n // static request handler\n this._requestHandler = this._requestHandlerFactory(hostProxy);\n return Promise.resolve(types.getAllMethodNames(this._requestHandler));\n }\n if (loaderConfig) {\n // Remove 'baseUrl', handling it is beyond scope for now\n if (typeof loaderConfig.baseUrl !== 'undefined') {\n delete loaderConfig['baseUrl'];\n }\n if (typeof loaderConfig.paths !== 'undefined') {\n if (typeof loaderConfig.paths.vs !== 'undefined') {\n delete loaderConfig.paths['vs'];\n }\n }\n if (typeof loaderConfig.trustedTypesPolicy !== undefined) {\n // don't use, it has been destroyed during serialize\n delete loaderConfig['trustedTypesPolicy'];\n }\n // Since this is in a web worker, enable catching errors\n loaderConfig.catchError = true;\n globals.require.config(loaderConfig);\n }\n return new Promise((resolve, reject) => {\n // Use the global require to be sure to get the global config\n // ESM-comment-begin\n // \t\t\tconst req = (globals.require || require);\n // ESM-comment-end\n // ESM-uncomment-begin\n const req = globals.require;\n // ESM-uncomment-end\n req([moduleId], (module) => {\n this._requestHandler = module.create(hostProxy);\n if (!this._requestHandler) {\n reject(new Error(`No RequestHandler!`));\n return;\n }\n resolve(types.getAllMethodNames(this._requestHandler));\n }, reject);\n });\n }\n}\n/**\n * Called on the worker side\n */\nexport function create(postMessage) {\n return new SimpleWorkerServer(postMessage, null);\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { globals, isMacintosh, isWindows } from './platform.js';\nlet safeProcess;\n// Native sandbox environment\nif (typeof globals.vscode !== 'undefined' && typeof globals.vscode.process !== 'undefined') {\n const sandboxProcess = globals.vscode.process;\n safeProcess = {\n get platform() { return sandboxProcess.platform; },\n get arch() { return sandboxProcess.arch; },\n get env() { return sandboxProcess.env; },\n cwd() { return sandboxProcess.cwd(); }\n };\n}\n// Native node.js environment\nelse if (typeof process !== 'undefined') {\n safeProcess = {\n get platform() { return process.platform; },\n get arch() { return process.arch; },\n get env() { return process.env; },\n cwd() { return process.env['VSCODE_CWD'] || process.cwd(); }\n };\n}\n// Web environment\nelse {\n safeProcess = {\n // Supported\n get platform() { return isWindows ? 'win32' : isMacintosh ? 'darwin' : 'linux'; },\n get arch() { return undefined; /* arch is undefined in web */ },\n // Unsupported\n get env() { return {}; },\n cwd() { return '/'; }\n };\n}\n/**\n * Provides safe access to the `cwd` property in node.js, sandboxed or web\n * environments.\n *\n * Note: in web, this property is hardcoded to be `/`.\n */\nexport const cwd = safeProcess.cwd;\n/**\n * Provides safe access to the `env` property in node.js, sandboxed or web\n * environments.\n *\n * Note: in web, this property is hardcoded to be `{}`.\n */\nexport const env = safeProcess.env;\n/**\n * Provides safe access to the `platform` property in node.js, sandboxed or web\n * environments.\n */\nexport const platform = safeProcess.platform;\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n/**\n * Represents information about a specific difference between two sequences.\n */\nexport class DiffChange {\n /**\n * Constructs a new DiffChange with the given sequence information\n * and content.\n */\n constructor(originalStart, originalLength, modifiedStart, modifiedLength) {\n //Debug.Assert(originalLength > 0 || modifiedLength > 0, \"originalLength and modifiedLength cannot both be <= 0\");\n this.originalStart = originalStart;\n this.originalLength = originalLength;\n this.modifiedStart = modifiedStart;\n this.modifiedLength = modifiedLength;\n }\n /**\n * The end point (exclusive) of the change in the original sequence.\n */\n getOriginalEnd() {\n return this.originalStart + this.originalLength;\n }\n /**\n * The end point (exclusive) of the change in the modified sequence.\n */\n getModifiedEnd() {\n return this.modifiedStart + this.modifiedLength;\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport * as strings from './strings.js';\n/**\n * Return a hash value for an object.\n */\nexport function hash(obj) {\n return doHash(obj, 0);\n}\nexport function doHash(obj, hashVal) {\n switch (typeof obj) {\n case 'object':\n if (obj === null) {\n return numberHash(349, hashVal);\n }\n else if (Array.isArray(obj)) {\n return arrayHash(obj, hashVal);\n }\n return objectHash(obj, hashVal);\n case 'string':\n return stringHash(obj, hashVal);\n case 'boolean':\n return booleanHash(obj, hashVal);\n case 'number':\n return numberHash(obj, hashVal);\n case 'undefined':\n return numberHash(937, hashVal);\n default:\n return numberHash(617, hashVal);\n }\n}\nexport function numberHash(val, initialHashVal) {\n return (((initialHashVal << 5) - initialHashVal) + val) | 0; // hashVal * 31 + ch, keep as int32\n}\nfunction booleanHash(b, initialHashVal) {\n return numberHash(b ? 433 : 863, initialHashVal);\n}\nexport function stringHash(s, hashVal) {\n hashVal = numberHash(149417, hashVal);\n for (let i = 0, length = s.length; i < length; i++) {\n hashVal = numberHash(s.charCodeAt(i), hashVal);\n }\n return hashVal;\n}\nfunction arrayHash(arr, initialHashVal) {\n initialHashVal = numberHash(104579, initialHashVal);\n return arr.reduce((hashVal, item) => doHash(item, hashVal), initialHashVal);\n}\nfunction objectHash(obj, initialHashVal) {\n initialHashVal = numberHash(181387, initialHashVal);\n return Object.keys(obj).sort().reduce((hashVal, key) => {\n hashVal = stringHash(key, hashVal);\n return doHash(obj[key], hashVal);\n }, initialHashVal);\n}\nfunction leftRotate(value, bits, totalBits = 32) {\n // delta + bits = totalBits\n const delta = totalBits - bits;\n // All ones, expect `delta` zeros aligned to the right\n const mask = ~((1 << delta) - 1);\n // Join (value left-shifted `bits` bits) with (masked value right-shifted `delta` bits)\n return ((value << bits) | ((mask & value) >>> delta)) >>> 0;\n}\nfunction fill(dest, index = 0, count = dest.byteLength, value = 0) {\n for (let i = 0; i < count; i++) {\n dest[index + i] = value;\n }\n}\nfunction leftPad(value, length, char = '0') {\n while (value.length < length) {\n value = char + value;\n }\n return value;\n}\nexport function toHexString(bufferOrValue, bitsize = 32) {\n if (bufferOrValue instanceof ArrayBuffer) {\n return Array.from(new Uint8Array(bufferOrValue)).map(b => b.toString(16).padStart(2, '0')).join('');\n }\n return leftPad((bufferOrValue >>> 0).toString(16), bitsize / 4);\n}\n/**\n * A SHA1 implementation that works with strings and does not allocate.\n */\nexport class StringSHA1 {\n constructor() {\n this._h0 = 0x67452301;\n this._h1 = 0xEFCDAB89;\n this._h2 = 0x98BADCFE;\n this._h3 = 0x10325476;\n this._h4 = 0xC3D2E1F0;\n this._buff = new Uint8Array(64 /* SHA1Constant.BLOCK_SIZE */ + 3 /* to fit any utf-8 */);\n this._buffDV = new DataView(this._buff.buffer);\n this._buffLen = 0;\n this._totalLen = 0;\n this._leftoverHighSurrogate = 0;\n this._finished = false;\n }\n update(str) {\n const strLen = str.length;\n if (strLen === 0) {\n return;\n }\n const buff = this._buff;\n let buffLen = this._buffLen;\n let leftoverHighSurrogate = this._leftoverHighSurrogate;\n let charCode;\n let offset;\n if (leftoverHighSurrogate !== 0) {\n charCode = leftoverHighSurrogate;\n offset = -1;\n leftoverHighSurrogate = 0;\n }\n else {\n charCode = str.charCodeAt(0);\n offset = 0;\n }\n while (true) {\n let codePoint = charCode;\n if (strings.isHighSurrogate(charCode)) {\n if (offset + 1 < strLen) {\n const nextCharCode = str.charCodeAt(offset + 1);\n if (strings.isLowSurrogate(nextCharCode)) {\n offset++;\n codePoint = strings.computeCodePoint(charCode, nextCharCode);\n }\n else {\n // illegal => unicode replacement character\n codePoint = 65533 /* SHA1Constant.UNICODE_REPLACEMENT */;\n }\n }\n else {\n // last character is a surrogate pair\n leftoverHighSurrogate = charCode;\n break;\n }\n }\n else if (strings.isLowSurrogate(charCode)) {\n // illegal => unicode replacement character\n codePoint = 65533 /* SHA1Constant.UNICODE_REPLACEMENT */;\n }\n buffLen = this._push(buff, buffLen, codePoint);\n offset++;\n if (offset < strLen) {\n charCode = str.charCodeAt(offset);\n }\n else {\n break;\n }\n }\n this._buffLen = buffLen;\n this._leftoverHighSurrogate = leftoverHighSurrogate;\n }\n _push(buff, buffLen, codePoint) {\n if (codePoint < 0x0080) {\n buff[buffLen++] = codePoint;\n }\n else if (codePoint < 0x0800) {\n buff[buffLen++] = 0b11000000 | ((codePoint & 0b00000000000000000000011111000000) >>> 6);\n buff[buffLen++] = 0b10000000 | ((codePoint & 0b00000000000000000000000000111111) >>> 0);\n }\n else if (codePoint < 0x10000) {\n buff[buffLen++] = 0b11100000 | ((codePoint & 0b00000000000000001111000000000000) >>> 12);\n buff[buffLen++] = 0b10000000 | ((codePoint & 0b00000000000000000000111111000000) >>> 6);\n buff[buffLen++] = 0b10000000 | ((codePoint & 0b00000000000000000000000000111111) >>> 0);\n }\n else {\n buff[buffLen++] = 0b11110000 | ((codePoint & 0b00000000000111000000000000000000) >>> 18);\n buff[buffLen++] = 0b10000000 | ((codePoint & 0b00000000000000111111000000000000) >>> 12);\n buff[buffLen++] = 0b10000000 | ((codePoint & 0b00000000000000000000111111000000) >>> 6);\n buff[buffLen++] = 0b10000000 | ((codePoint & 0b00000000000000000000000000111111) >>> 0);\n }\n if (buffLen >= 64 /* SHA1Constant.BLOCK_SIZE */) {\n this._step();\n buffLen -= 64 /* SHA1Constant.BLOCK_SIZE */;\n this._totalLen += 64 /* SHA1Constant.BLOCK_SIZE */;\n // take last 3 in case of UTF8 overflow\n buff[0] = buff[64 /* SHA1Constant.BLOCK_SIZE */ + 0];\n buff[1] = buff[64 /* SHA1Constant.BLOCK_SIZE */ + 1];\n buff[2] = buff[64 /* SHA1Constant.BLOCK_SIZE */ + 2];\n }\n return buffLen;\n }\n digest() {\n if (!this._finished) {\n this._finished = true;\n if (this._leftoverHighSurrogate) {\n // illegal => unicode replacement character\n this._leftoverHighSurrogate = 0;\n this._buffLen = this._push(this._buff, this._buffLen, 65533 /* SHA1Constant.UNICODE_REPLACEMENT */);\n }\n this._totalLen += this._buffLen;\n this._wrapUp();\n }\n return toHexString(this._h0) + toHexString(this._h1) + toHexString(this._h2) + toHexString(this._h3) + toHexString(this._h4);\n }\n _wrapUp() {\n this._buff[this._buffLen++] = 0x80;\n fill(this._buff, this._buffLen);\n if (this._buffLen > 56) {\n this._step();\n fill(this._buff);\n }\n // this will fit because the mantissa can cover up to 52 bits\n const ml = 8 * this._totalLen;\n this._buffDV.setUint32(56, Math.floor(ml / 4294967296), false);\n this._buffDV.setUint32(60, ml % 4294967296, false);\n this._step();\n }\n _step() {\n const bigBlock32 = StringSHA1._bigBlock32;\n const data = this._buffDV;\n for (let j = 0; j < 64 /* 16*4 */; j += 4) {\n bigBlock32.setUint32(j, data.getUint32(j, false), false);\n }\n for (let j = 64; j < 320 /* 80*4 */; j += 4) {\n bigBlock32.setUint32(j, leftRotate((bigBlock32.getUint32(j - 12, false) ^ bigBlock32.getUint32(j - 32, false) ^ bigBlock32.getUint32(j - 56, false) ^ bigBlock32.getUint32(j - 64, false)), 1), false);\n }\n let a = this._h0;\n let b = this._h1;\n let c = this._h2;\n let d = this._h3;\n let e = this._h4;\n let f, k;\n let temp;\n for (let j = 0; j < 80; j++) {\n if (j < 20) {\n f = (b & c) | ((~b) & d);\n k = 0x5A827999;\n }\n else if (j < 40) {\n f = b ^ c ^ d;\n k = 0x6ED9EBA1;\n }\n else if (j < 60) {\n f = (b & c) | (b & d) | (c & d);\n k = 0x8F1BBCDC;\n }\n else {\n f = b ^ c ^ d;\n k = 0xCA62C1D6;\n }\n temp = (leftRotate(a, 5) + f + e + k + bigBlock32.getUint32(j * 4, false)) & 0xffffffff;\n e = d;\n d = c;\n c = leftRotate(b, 30);\n b = a;\n a = temp;\n }\n this._h0 = (this._h0 + a) & 0xffffffff;\n this._h1 = (this._h1 + b) & 0xffffffff;\n this._h2 = (this._h2 + c) & 0xffffffff;\n this._h3 = (this._h3 + d) & 0xffffffff;\n this._h4 = (this._h4 + e) & 0xffffffff;\n }\n}\nStringSHA1._bigBlock32 = new DataView(new ArrayBuffer(320)); // 80 * 4 = 320\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { DiffChange } from './diffChange.js';\nimport { stringHash } from '../hash.js';\nexport class StringDiffSequence {\n constructor(source) {\n this.source = source;\n }\n getElements() {\n const source = this.source;\n const characters = new Int32Array(source.length);\n for (let i = 0, len = source.length; i < len; i++) {\n characters[i] = source.charCodeAt(i);\n }\n return characters;\n }\n}\nexport function stringDiff(original, modified, pretty) {\n return new LcsDiff(new StringDiffSequence(original), new StringDiffSequence(modified)).ComputeDiff(pretty).changes;\n}\n//\n// The code below has been ported from a C# implementation in VS\n//\nexport class Debug {\n static Assert(condition, message) {\n if (!condition) {\n throw new Error(message);\n }\n }\n}\nexport class MyArray {\n /**\n * Copies a range of elements from an Array starting at the specified source index and pastes\n * them to another Array starting at the specified destination index. The length and the indexes\n * are specified as 64-bit integers.\n * sourceArray:\n *\t\tThe Array that contains the data to copy.\n * sourceIndex:\n *\t\tA 64-bit integer that represents the index in the sourceArray at which copying begins.\n * destinationArray:\n *\t\tThe Array that receives the data.\n * destinationIndex:\n *\t\tA 64-bit integer that represents the index in the destinationArray at which storing begins.\n * length:\n *\t\tA 64-bit integer that represents the number of elements to copy.\n */\n static Copy(sourceArray, sourceIndex, destinationArray, destinationIndex, length) {\n for (let i = 0; i < length; i++) {\n destinationArray[destinationIndex + i] = sourceArray[sourceIndex + i];\n }\n }\n static Copy2(sourceArray, sourceIndex, destinationArray, destinationIndex, length) {\n for (let i = 0; i < length; i++) {\n destinationArray[destinationIndex + i] = sourceArray[sourceIndex + i];\n }\n }\n}\n/**\n * A utility class which helps to create the set of DiffChanges from\n * a difference operation. This class accepts original DiffElements and\n * modified DiffElements that are involved in a particular change. The\n * MarkNextChange() method can be called to mark the separation between\n * distinct changes. At the end, the Changes property can be called to retrieve\n * the constructed changes.\n */\nclass DiffChangeHelper {\n /**\n * Constructs a new DiffChangeHelper for the given DiffSequences.\n */\n constructor() {\n this.m_changes = [];\n this.m_originalStart = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;\n this.m_modifiedStart = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;\n this.m_originalCount = 0;\n this.m_modifiedCount = 0;\n }\n /**\n * Marks the beginning of the next change in the set of differences.\n */\n MarkNextChange() {\n // Only add to the list if there is something to add\n if (this.m_originalCount > 0 || this.m_modifiedCount > 0) {\n // Add the new change to our list\n this.m_changes.push(new DiffChange(this.m_originalStart, this.m_originalCount, this.m_modifiedStart, this.m_modifiedCount));\n }\n // Reset for the next change\n this.m_originalCount = 0;\n this.m_modifiedCount = 0;\n this.m_originalStart = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;\n this.m_modifiedStart = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;\n }\n /**\n * Adds the original element at the given position to the elements\n * affected by the current change. The modified index gives context\n * to the change position with respect to the original sequence.\n * @param originalIndex The index of the original element to add.\n * @param modifiedIndex The index of the modified element that provides corresponding position in the modified sequence.\n */\n AddOriginalElement(originalIndex, modifiedIndex) {\n // The 'true' start index is the smallest of the ones we've seen\n this.m_originalStart = Math.min(this.m_originalStart, originalIndex);\n this.m_modifiedStart = Math.min(this.m_modifiedStart, modifiedIndex);\n this.m_originalCount++;\n }\n /**\n * Adds the modified element at the given position to the elements\n * affected by the current change. The original index gives context\n * to the change position with respect to the modified sequence.\n * @param originalIndex The index of the original element that provides corresponding position in the original sequence.\n * @param modifiedIndex The index of the modified element to add.\n */\n AddModifiedElement(originalIndex, modifiedIndex) {\n // The 'true' start index is the smallest of the ones we've seen\n this.m_originalStart = Math.min(this.m_originalStart, originalIndex);\n this.m_modifiedStart = Math.min(this.m_modifiedStart, modifiedIndex);\n this.m_modifiedCount++;\n }\n /**\n * Retrieves all of the changes marked by the class.\n */\n getChanges() {\n if (this.m_originalCount > 0 || this.m_modifiedCount > 0) {\n // Finish up on whatever is left\n this.MarkNextChange();\n }\n return this.m_changes;\n }\n /**\n * Retrieves all of the changes marked by the class in the reverse order\n */\n getReverseChanges() {\n if (this.m_originalCount > 0 || this.m_modifiedCount > 0) {\n // Finish up on whatever is left\n this.MarkNextChange();\n }\n this.m_changes.reverse();\n return this.m_changes;\n }\n}\n/**\n * An implementation of the difference algorithm described in\n * \"An O(ND) Difference Algorithm and its variations\" by Eugene W. Myers\n */\nexport class LcsDiff {\n /**\n * Constructs the DiffFinder\n */\n constructor(originalSequence, modifiedSequence, continueProcessingPredicate = null) {\n this.ContinueProcessingPredicate = continueProcessingPredicate;\n this._originalSequence = originalSequence;\n this._modifiedSequence = modifiedSequence;\n const [originalStringElements, originalElementsOrHash, originalHasStrings] = LcsDiff._getElements(originalSequence);\n const [modifiedStringElements, modifiedElementsOrHash, modifiedHasStrings] = LcsDiff._getElements(modifiedSequence);\n this._hasStrings = (originalHasStrings && modifiedHasStrings);\n this._originalStringElements = originalStringElements;\n this._originalElementsOrHash = originalElementsOrHash;\n this._modifiedStringElements = modifiedStringElements;\n this._modifiedElementsOrHash = modifiedElementsOrHash;\n this.m_forwardHistory = [];\n this.m_reverseHistory = [];\n }\n static _isStringArray(arr) {\n return (arr.length > 0 && typeof arr[0] === 'string');\n }\n static _getElements(sequence) {\n const elements = sequence.getElements();\n if (LcsDiff._isStringArray(elements)) {\n const hashes = new Int32Array(elements.length);\n for (let i = 0, len = elements.length; i < len; i++) {\n hashes[i] = stringHash(elements[i], 0);\n }\n return [elements, hashes, true];\n }\n if (elements instanceof Int32Array) {\n return [[], elements, false];\n }\n return [[], new Int32Array(elements), false];\n }\n ElementsAreEqual(originalIndex, newIndex) {\n if (this._originalElementsOrHash[originalIndex] !== this._modifiedElementsOrHash[newIndex]) {\n return false;\n }\n return (this._hasStrings ? this._originalStringElements[originalIndex] === this._modifiedStringElements[newIndex] : true);\n }\n ElementsAreStrictEqual(originalIndex, newIndex) {\n if (!this.ElementsAreEqual(originalIndex, newIndex)) {\n return false;\n }\n const originalElement = LcsDiff._getStrictElement(this._originalSequence, originalIndex);\n const modifiedElement = LcsDiff._getStrictElement(this._modifiedSequence, newIndex);\n return (originalElement === modifiedElement);\n }\n static _getStrictElement(sequence, index) {\n if (typeof sequence.getStrictElement === 'function') {\n return sequence.getStrictElement(index);\n }\n return null;\n }\n OriginalElementsAreEqual(index1, index2) {\n if (this._originalElementsOrHash[index1] !== this._originalElementsOrHash[index2]) {\n return false;\n }\n return (this._hasStrings ? this._originalStringElements[index1] === this._originalStringElements[index2] : true);\n }\n ModifiedElementsAreEqual(index1, index2) {\n if (this._modifiedElementsOrHash[index1] !== this._modifiedElementsOrHash[index2]) {\n return false;\n }\n return (this._hasStrings ? this._modifiedStringElements[index1] === this._modifiedStringElements[index2] : true);\n }\n ComputeDiff(pretty) {\n return this._ComputeDiff(0, this._originalElementsOrHash.length - 1, 0, this._modifiedElementsOrHash.length - 1, pretty);\n }\n /**\n * Computes the differences between the original and modified input\n * sequences on the bounded range.\n * @returns An array of the differences between the two input sequences.\n */\n _ComputeDiff(originalStart, originalEnd, modifiedStart, modifiedEnd, pretty) {\n const quitEarlyArr = [false];\n let changes = this.ComputeDiffRecursive(originalStart, originalEnd, modifiedStart, modifiedEnd, quitEarlyArr);\n if (pretty) {\n // We have to clean up the computed diff to be more intuitive\n // but it turns out this cannot be done correctly until the entire set\n // of diffs have been computed\n changes = this.PrettifyChanges(changes);\n }\n return {\n quitEarly: quitEarlyArr[0],\n changes: changes\n };\n }\n /**\n * Private helper method which computes the differences on the bounded range\n * recursively.\n * @returns An array of the differences between the two input sequences.\n */\n ComputeDiffRecursive(originalStart, originalEnd, modifiedStart, modifiedEnd, quitEarlyArr) {\n quitEarlyArr[0] = false;\n // Find the start of the differences\n while (originalStart <= originalEnd && modifiedStart <= modifiedEnd && this.ElementsAreEqual(originalStart, modifiedStart)) {\n originalStart++;\n modifiedStart++;\n }\n // Find the end of the differences\n while (originalEnd >= originalStart && modifiedEnd >= modifiedStart && this.ElementsAreEqual(originalEnd, modifiedEnd)) {\n originalEnd--;\n modifiedEnd--;\n }\n // In the special case where we either have all insertions or all deletions or the sequences are identical\n if (originalStart > originalEnd || modifiedStart > modifiedEnd) {\n let changes;\n if (modifiedStart <= modifiedEnd) {\n Debug.Assert(originalStart === originalEnd + 1, 'originalStart should only be one more than originalEnd');\n // All insertions\n changes = [\n new DiffChange(originalStart, 0, modifiedStart, modifiedEnd - modifiedStart + 1)\n ];\n }\n else if (originalStart <= originalEnd) {\n Debug.Assert(modifiedStart === modifiedEnd + 1, 'modifiedStart should only be one more than modifiedEnd');\n // All deletions\n changes = [\n new DiffChange(originalStart, originalEnd - originalStart + 1, modifiedStart, 0)\n ];\n }\n else {\n Debug.Assert(originalStart === originalEnd + 1, 'originalStart should only be one more than originalEnd');\n Debug.Assert(modifiedStart === modifiedEnd + 1, 'modifiedStart should only be one more than modifiedEnd');\n // Identical sequences - No differences\n changes = [];\n }\n return changes;\n }\n // This problem can be solved using the Divide-And-Conquer technique.\n const midOriginalArr = [0];\n const midModifiedArr = [0];\n const result = this.ComputeRecursionPoint(originalStart, originalEnd, modifiedStart, modifiedEnd, midOriginalArr, midModifiedArr, quitEarlyArr);\n const midOriginal = midOriginalArr[0];\n const midModified = midModifiedArr[0];\n if (result !== null) {\n // Result is not-null when there was enough memory to compute the changes while\n // searching for the recursion point\n return result;\n }\n else if (!quitEarlyArr[0]) {\n // We can break the problem down recursively by finding the changes in the\n // First Half: (originalStart, modifiedStart) to (midOriginal, midModified)\n // Second Half: (midOriginal + 1, minModified + 1) to (originalEnd, modifiedEnd)\n // NOTE: ComputeDiff() is inclusive, therefore the second range starts on the next point\n const leftChanges = this.ComputeDiffRecursive(originalStart, midOriginal, modifiedStart, midModified, quitEarlyArr);\n let rightChanges = [];\n if (!quitEarlyArr[0]) {\n rightChanges = this.ComputeDiffRecursive(midOriginal + 1, originalEnd, midModified + 1, modifiedEnd, quitEarlyArr);\n }\n else {\n // We didn't have time to finish the first half, so we don't have time to compute this half.\n // Consider the entire rest of the sequence different.\n rightChanges = [\n new DiffChange(midOriginal + 1, originalEnd - (midOriginal + 1) + 1, midModified + 1, modifiedEnd - (midModified + 1) + 1)\n ];\n }\n return this.ConcatenateChanges(leftChanges, rightChanges);\n }\n // If we hit here, we quit early, and so can't return anything meaningful\n return [\n new DiffChange(originalStart, originalEnd - originalStart + 1, modifiedStart, modifiedEnd - modifiedStart + 1)\n ];\n }\n WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr) {\n let forwardChanges = null;\n let reverseChanges = null;\n // First, walk backward through the forward diagonals history\n let changeHelper = new DiffChangeHelper();\n let diagonalMin = diagonalForwardStart;\n let diagonalMax = diagonalForwardEnd;\n let diagonalRelative = (midOriginalArr[0] - midModifiedArr[0]) - diagonalForwardOffset;\n let lastOriginalIndex = -1073741824 /* Constants.MIN_SAFE_SMALL_INTEGER */;\n let historyIndex = this.m_forwardHistory.length - 1;\n do {\n // Get the diagonal index from the relative diagonal number\n const diagonal = diagonalRelative + diagonalForwardBase;\n // Figure out where we came from\n if (diagonal === diagonalMin || (diagonal < diagonalMax && forwardPoints[diagonal - 1] < forwardPoints[diagonal + 1])) {\n // Vertical line (the element is an insert)\n originalIndex = forwardPoints[diagonal + 1];\n modifiedIndex = originalIndex - diagonalRelative - diagonalForwardOffset;\n if (originalIndex < lastOriginalIndex) {\n changeHelper.MarkNextChange();\n }\n lastOriginalIndex = originalIndex;\n changeHelper.AddModifiedElement(originalIndex + 1, modifiedIndex);\n diagonalRelative = (diagonal + 1) - diagonalForwardBase; //Setup for the next iteration\n }\n else {\n // Horizontal line (the element is a deletion)\n originalIndex = forwardPoints[diagonal - 1] + 1;\n modifiedIndex = originalIndex - diagonalRelative - diagonalForwardOffset;\n if (originalIndex < lastOriginalIndex) {\n changeHelper.MarkNextChange();\n }\n lastOriginalIndex = originalIndex - 1;\n changeHelper.AddOriginalElement(originalIndex, modifiedIndex + 1);\n diagonalRelative = (diagonal - 1) - diagonalForwardBase; //Setup for the next iteration\n }\n if (historyIndex >= 0) {\n forwardPoints = this.m_forwardHistory[historyIndex];\n diagonalForwardBase = forwardPoints[0]; //We stored this in the first spot\n diagonalMin = 1;\n diagonalMax = forwardPoints.length - 1;\n }\n } while (--historyIndex >= -1);\n // Ironically, we get the forward changes as the reverse of the\n // order we added them since we technically added them backwards\n forwardChanges = changeHelper.getReverseChanges();\n if (quitEarlyArr[0]) {\n // TODO: Calculate a partial from the reverse diagonals.\n // For now, just assume everything after the midOriginal/midModified point is a diff\n let originalStartPoint = midOriginalArr[0] + 1;\n let modifiedStartPoint = midModifiedArr[0] + 1;\n if (forwardChanges !== null && forwardChanges.length > 0) {\n const lastForwardChange = forwardChanges[forwardChanges.length - 1];\n originalStartPoint = Math.max(originalStartPoint, lastForwardChange.getOriginalEnd());\n modifiedStartPoint = Math.max(modifiedStartPoint, lastForwardChange.getModifiedEnd());\n }\n reverseChanges = [\n new DiffChange(originalStartPoint, originalEnd - originalStartPoint + 1, modifiedStartPoint, modifiedEnd - modifiedStartPoint + 1)\n ];\n }\n else {\n // Now walk backward through the reverse diagonals history\n changeHelper = new DiffChangeHelper();\n diagonalMin = diagonalReverseStart;\n diagonalMax = diagonalReverseEnd;\n diagonalRelative = (midOriginalArr[0] - midModifiedArr[0]) - diagonalReverseOffset;\n lastOriginalIndex = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;\n historyIndex = (deltaIsEven) ? this.m_reverseHistory.length - 1 : this.m_reverseHistory.length - 2;\n do {\n // Get the diagonal index from the relative diagonal number\n const diagonal = diagonalRelative + diagonalReverseBase;\n // Figure out where we came from\n if (diagonal === diagonalMin || (diagonal < diagonalMax && reversePoints[diagonal - 1] >= reversePoints[diagonal + 1])) {\n // Horizontal line (the element is a deletion))\n originalIndex = reversePoints[diagonal + 1] - 1;\n modifiedIndex = originalIndex - diagonalRelative - diagonalReverseOffset;\n if (originalIndex > lastOriginalIndex) {\n changeHelper.MarkNextChange();\n }\n lastOriginalIndex = originalIndex + 1;\n changeHelper.AddOriginalElement(originalIndex + 1, modifiedIndex + 1);\n diagonalRelative = (diagonal + 1) - diagonalReverseBase; //Setup for the next iteration\n }\n else {\n // Vertical line (the element is an insertion)\n originalIndex = reversePoints[diagonal - 1];\n modifiedIndex = originalIndex - diagonalRelative - diagonalReverseOffset;\n if (originalIndex > lastOriginalIndex) {\n changeHelper.MarkNextChange();\n }\n lastOriginalIndex = originalIndex;\n changeHelper.AddModifiedElement(originalIndex + 1, modifiedIndex + 1);\n diagonalRelative = (diagonal - 1) - diagonalReverseBase; //Setup for the next iteration\n }\n if (historyIndex >= 0) {\n reversePoints = this.m_reverseHistory[historyIndex];\n diagonalReverseBase = reversePoints[0]; //We stored this in the first spot\n diagonalMin = 1;\n diagonalMax = reversePoints.length - 1;\n }\n } while (--historyIndex >= -1);\n // There are cases where the reverse history will find diffs that\n // are correct, but not intuitive, so we need shift them.\n reverseChanges = changeHelper.getChanges();\n }\n return this.ConcatenateChanges(forwardChanges, reverseChanges);\n }\n /**\n * Given the range to compute the diff on, this method finds the point:\n * (midOriginal, midModified)\n * that exists in the middle of the LCS of the two sequences and\n * is the point at which the LCS problem may be broken down recursively.\n * This method will try to keep the LCS trace in memory. If the LCS recursion\n * point is calculated and the full trace is available in memory, then this method\n * will return the change list.\n * @param originalStart The start bound of the original sequence range\n * @param originalEnd The end bound of the original sequence range\n * @param modifiedStart The start bound of the modified sequence range\n * @param modifiedEnd The end bound of the modified sequence range\n * @param midOriginal The middle point of the original sequence range\n * @param midModified The middle point of the modified sequence range\n * @returns The diff changes, if available, otherwise null\n */\n ComputeRecursionPoint(originalStart, originalEnd, modifiedStart, modifiedEnd, midOriginalArr, midModifiedArr, quitEarlyArr) {\n let originalIndex = 0, modifiedIndex = 0;\n let diagonalForwardStart = 0, diagonalForwardEnd = 0;\n let diagonalReverseStart = 0, diagonalReverseEnd = 0;\n // To traverse the edit graph and produce the proper LCS, our actual\n // start position is just outside the given boundary\n originalStart--;\n modifiedStart--;\n // We set these up to make the compiler happy, but they will\n // be replaced before we return with the actual recursion point\n midOriginalArr[0] = 0;\n midModifiedArr[0] = 0;\n // Clear out the history\n this.m_forwardHistory = [];\n this.m_reverseHistory = [];\n // Each cell in the two arrays corresponds to a diagonal in the edit graph.\n // The integer value in the cell represents the originalIndex of the furthest\n // reaching point found so far that ends in that diagonal.\n // The modifiedIndex can be computed mathematically from the originalIndex and the diagonal number.\n const maxDifferences = (originalEnd - originalStart) + (modifiedEnd - modifiedStart);\n const numDiagonals = maxDifferences + 1;\n const forwardPoints = new Int32Array(numDiagonals);\n const reversePoints = new Int32Array(numDiagonals);\n // diagonalForwardBase: Index into forwardPoints of the diagonal which passes through (originalStart, modifiedStart)\n // diagonalReverseBase: Index into reversePoints of the diagonal which passes through (originalEnd, modifiedEnd)\n const diagonalForwardBase = (modifiedEnd - modifiedStart);\n const diagonalReverseBase = (originalEnd - originalStart);\n // diagonalForwardOffset: Geometric offset which allows modifiedIndex to be computed from originalIndex and the\n // diagonal number (relative to diagonalForwardBase)\n // diagonalReverseOffset: Geometric offset which allows modifiedIndex to be computed from originalIndex and the\n // diagonal number (relative to diagonalReverseBase)\n const diagonalForwardOffset = (originalStart - modifiedStart);\n const diagonalReverseOffset = (originalEnd - modifiedEnd);\n // delta: The difference between the end diagonal and the start diagonal. This is used to relate diagonal numbers\n // relative to the start diagonal with diagonal numbers relative to the end diagonal.\n // The Even/Oddn-ness of this delta is important for determining when we should check for overlap\n const delta = diagonalReverseBase - diagonalForwardBase;\n const deltaIsEven = (delta % 2 === 0);\n // Here we set up the start and end points as the furthest points found so far\n // in both the forward and reverse directions, respectively\n forwardPoints[diagonalForwardBase] = originalStart;\n reversePoints[diagonalReverseBase] = originalEnd;\n // Remember if we quit early, and thus need to do a best-effort result instead of a real result.\n quitEarlyArr[0] = false;\n // A couple of points:\n // --With this method, we iterate on the number of differences between the two sequences.\n // The more differences there actually are, the longer this will take.\n // --Also, as the number of differences increases, we have to search on diagonals further\n // away from the reference diagonal (which is diagonalForwardBase for forward, diagonalReverseBase for reverse).\n // --We extend on even diagonals (relative to the reference diagonal) only when numDifferences\n // is even and odd diagonals only when numDifferences is odd.\n for (let numDifferences = 1; numDifferences <= (maxDifferences / 2) + 1; numDifferences++) {\n let furthestOriginalIndex = 0;\n let furthestModifiedIndex = 0;\n // Run the algorithm in the forward direction\n diagonalForwardStart = this.ClipDiagonalBound(diagonalForwardBase - numDifferences, numDifferences, diagonalForwardBase, numDiagonals);\n diagonalForwardEnd = this.ClipDiagonalBound(diagonalForwardBase + numDifferences, numDifferences, diagonalForwardBase, numDiagonals);\n for (let diagonal = diagonalForwardStart; diagonal <= diagonalForwardEnd; diagonal += 2) {\n // STEP 1: We extend the furthest reaching point in the present diagonal\n // by looking at the diagonals above and below and picking the one whose point\n // is further away from the start point (originalStart, modifiedStart)\n if (diagonal === diagonalForwardStart || (diagonal < diagonalForwardEnd && forwardPoints[diagonal - 1] < forwardPoints[diagonal + 1])) {\n originalIndex = forwardPoints[diagonal + 1];\n }\n else {\n originalIndex = forwardPoints[diagonal - 1] + 1;\n }\n modifiedIndex = originalIndex - (diagonal - diagonalForwardBase) - diagonalForwardOffset;\n // Save the current originalIndex so we can test for false overlap in step 3\n const tempOriginalIndex = originalIndex;\n // STEP 2: We can continue to extend the furthest reaching point in the present diagonal\n // so long as the elements are equal.\n while (originalIndex < originalEnd && modifiedIndex < modifiedEnd && this.ElementsAreEqual(originalIndex + 1, modifiedIndex + 1)) {\n originalIndex++;\n modifiedIndex++;\n }\n forwardPoints[diagonal] = originalIndex;\n if (originalIndex + modifiedIndex > furthestOriginalIndex + furthestModifiedIndex) {\n furthestOriginalIndex = originalIndex;\n furthestModifiedIndex = modifiedIndex;\n }\n // STEP 3: If delta is odd (overlap first happens on forward when delta is odd)\n // and diagonal is in the range of reverse diagonals computed for numDifferences-1\n // (the previous iteration; we haven't computed reverse diagonals for numDifferences yet)\n // then check for overlap.\n if (!deltaIsEven && Math.abs(diagonal - diagonalReverseBase) <= (numDifferences - 1)) {\n if (originalIndex >= reversePoints[diagonal]) {\n midOriginalArr[0] = originalIndex;\n midModifiedArr[0] = modifiedIndex;\n if (tempOriginalIndex <= reversePoints[diagonal] && 1447 /* LocalConstants.MaxDifferencesHistory */ > 0 && numDifferences <= (1447 /* LocalConstants.MaxDifferencesHistory */ + 1)) {\n // BINGO! We overlapped, and we have the full trace in memory!\n return this.WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr);\n }\n else {\n // Either false overlap, or we didn't have enough memory for the full trace\n // Just return the recursion point\n return null;\n }\n }\n }\n }\n // Check to see if we should be quitting early, before moving on to the next iteration.\n const matchLengthOfLongest = ((furthestOriginalIndex - originalStart) + (furthestModifiedIndex - modifiedStart) - numDifferences) / 2;\n if (this.ContinueProcessingPredicate !== null && !this.ContinueProcessingPredicate(furthestOriginalIndex, matchLengthOfLongest)) {\n // We can't finish, so skip ahead to generating a result from what we have.\n quitEarlyArr[0] = true;\n // Use the furthest distance we got in the forward direction.\n midOriginalArr[0] = furthestOriginalIndex;\n midModifiedArr[0] = furthestModifiedIndex;\n if (matchLengthOfLongest > 0 && 1447 /* LocalConstants.MaxDifferencesHistory */ > 0 && numDifferences <= (1447 /* LocalConstants.MaxDifferencesHistory */ + 1)) {\n // Enough of the history is in memory to walk it backwards\n return this.WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr);\n }\n else {\n // We didn't actually remember enough of the history.\n //Since we are quitting the diff early, we need to shift back the originalStart and modified start\n //back into the boundary limits since we decremented their value above beyond the boundary limit.\n originalStart++;\n modifiedStart++;\n return [\n new DiffChange(originalStart, originalEnd - originalStart + 1, modifiedStart, modifiedEnd - modifiedStart + 1)\n ];\n }\n }\n // Run the algorithm in the reverse direction\n diagonalReverseStart = this.ClipDiagonalBound(diagonalReverseBase - numDifferences, numDifferences, diagonalReverseBase, numDiagonals);\n diagonalReverseEnd = this.ClipDiagonalBound(diagonalReverseBase + numDifferences, numDifferences, diagonalReverseBase, numDiagonals);\n for (let diagonal = diagonalReverseStart; diagonal <= diagonalReverseEnd; diagonal += 2) {\n // STEP 1: We extend the furthest reaching point in the present diagonal\n // by looking at the diagonals above and below and picking the one whose point\n // is further away from the start point (originalEnd, modifiedEnd)\n if (diagonal === diagonalReverseStart || (diagonal < diagonalReverseEnd && reversePoints[diagonal - 1] >= reversePoints[diagonal + 1])) {\n originalIndex = reversePoints[diagonal + 1] - 1;\n }\n else {\n originalIndex = reversePoints[diagonal - 1];\n }\n modifiedIndex = originalIndex - (diagonal - diagonalReverseBase) - diagonalReverseOffset;\n // Save the current originalIndex so we can test for false overlap\n const tempOriginalIndex = originalIndex;\n // STEP 2: We can continue to extend the furthest reaching point in the present diagonal\n // as long as the elements are equal.\n while (originalIndex > originalStart && modifiedIndex > modifiedStart && this.ElementsAreEqual(originalIndex, modifiedIndex)) {\n originalIndex--;\n modifiedIndex--;\n }\n reversePoints[diagonal] = originalIndex;\n // STEP 4: If delta is even (overlap first happens on reverse when delta is even)\n // and diagonal is in the range of forward diagonals computed for numDifferences\n // then check for overlap.\n if (deltaIsEven && Math.abs(diagonal - diagonalForwardBase) <= numDifferences) {\n if (originalIndex <= forwardPoints[diagonal]) {\n midOriginalArr[0] = originalIndex;\n midModifiedArr[0] = modifiedIndex;\n if (tempOriginalIndex >= forwardPoints[diagonal] && 1447 /* LocalConstants.MaxDifferencesHistory */ > 0 && numDifferences <= (1447 /* LocalConstants.MaxDifferencesHistory */ + 1)) {\n // BINGO! We overlapped, and we have the full trace in memory!\n return this.WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr);\n }\n else {\n // Either false overlap, or we didn't have enough memory for the full trace\n // Just return the recursion point\n return null;\n }\n }\n }\n }\n // Save current vectors to history before the next iteration\n if (numDifferences <= 1447 /* LocalConstants.MaxDifferencesHistory */) {\n // We are allocating space for one extra int, which we fill with\n // the index of the diagonal base index\n let temp = new Int32Array(diagonalForwardEnd - diagonalForwardStart + 2);\n temp[0] = diagonalForwardBase - diagonalForwardStart + 1;\n MyArray.Copy2(forwardPoints, diagonalForwardStart, temp, 1, diagonalForwardEnd - diagonalForwardStart + 1);\n this.m_forwardHistory.push(temp);\n temp = new Int32Array(diagonalReverseEnd - diagonalReverseStart + 2);\n temp[0] = diagonalReverseBase - diagonalReverseStart + 1;\n MyArray.Copy2(reversePoints, diagonalReverseStart, temp, 1, diagonalReverseEnd - diagonalReverseStart + 1);\n this.m_reverseHistory.push(temp);\n }\n }\n // If we got here, then we have the full trace in history. We just have to convert it to a change list\n // NOTE: This part is a bit messy\n return this.WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr);\n }\n /**\n * Shifts the given changes to provide a more intuitive diff.\n * While the first element in a diff matches the first element after the diff,\n * we shift the diff down.\n *\n * @param changes The list of changes to shift\n * @returns The shifted changes\n */\n PrettifyChanges(changes) {\n // Shift all the changes down first\n for (let i = 0; i < changes.length; i++) {\n const change = changes[i];\n const originalStop = (i < changes.length - 1) ? changes[i + 1].originalStart : this._originalElementsOrHash.length;\n const modifiedStop = (i < changes.length - 1) ? changes[i + 1].modifiedStart : this._modifiedElementsOrHash.length;\n const checkOriginal = change.originalLength > 0;\n const checkModified = change.modifiedLength > 0;\n while (change.originalStart + change.originalLength < originalStop\n && change.modifiedStart + change.modifiedLength < modifiedStop\n && (!checkOriginal || this.OriginalElementsAreEqual(change.originalStart, change.originalStart + change.originalLength))\n && (!checkModified || this.ModifiedElementsAreEqual(change.modifiedStart, change.modifiedStart + change.modifiedLength))) {\n const startStrictEqual = this.ElementsAreStrictEqual(change.originalStart, change.modifiedStart);\n const endStrictEqual = this.ElementsAreStrictEqual(change.originalStart + change.originalLength, change.modifiedStart + change.modifiedLength);\n if (endStrictEqual && !startStrictEqual) {\n // moving the change down would create an equal change, but the elements are not strict equal\n break;\n }\n change.originalStart++;\n change.modifiedStart++;\n }\n const mergedChangeArr = [null];\n if (i < changes.length - 1 && this.ChangesOverlap(changes[i], changes[i + 1], mergedChangeArr)) {\n changes[i] = mergedChangeArr[0];\n changes.splice(i + 1, 1);\n i--;\n continue;\n }\n }\n // Shift changes back up until we hit empty or whitespace-only lines\n for (let i = changes.length - 1; i >= 0; i--) {\n const change = changes[i];\n let originalStop = 0;\n let modifiedStop = 0;\n if (i > 0) {\n const prevChange = changes[i - 1];\n originalStop = prevChange.originalStart + prevChange.originalLength;\n modifiedStop = prevChange.modifiedStart + prevChange.modifiedLength;\n }\n const checkOriginal = change.originalLength > 0;\n const checkModified = change.modifiedLength > 0;\n let bestDelta = 0;\n let bestScore = this._boundaryScore(change.originalStart, change.originalLength, change.modifiedStart, change.modifiedLength);\n for (let delta = 1;; delta++) {\n const originalStart = change.originalStart - delta;\n const modifiedStart = change.modifiedStart - delta;\n if (originalStart < originalStop || modifiedStart < modifiedStop) {\n break;\n }\n if (checkOriginal && !this.OriginalElementsAreEqual(originalStart, originalStart + change.originalLength)) {\n break;\n }\n if (checkModified && !this.ModifiedElementsAreEqual(modifiedStart, modifiedStart + change.modifiedLength)) {\n break;\n }\n const touchingPreviousChange = (originalStart === originalStop && modifiedStart === modifiedStop);\n const score = ((touchingPreviousChange ? 5 : 0)\n + this._boundaryScore(originalStart, change.originalLength, modifiedStart, change.modifiedLength));\n if (score > bestScore) {\n bestScore = score;\n bestDelta = delta;\n }\n }\n change.originalStart -= bestDelta;\n change.modifiedStart -= bestDelta;\n const mergedChangeArr = [null];\n if (i > 0 && this.ChangesOverlap(changes[i - 1], changes[i], mergedChangeArr)) {\n changes[i - 1] = mergedChangeArr[0];\n changes.splice(i, 1);\n i++;\n continue;\n }\n }\n // There could be multiple longest common substrings.\n // Give preference to the ones containing longer lines\n if (this._hasStrings) {\n for (let i = 1, len = changes.length; i < len; i++) {\n const aChange = changes[i - 1];\n const bChange = changes[i];\n const matchedLength = bChange.originalStart - aChange.originalStart - aChange.originalLength;\n const aOriginalStart = aChange.originalStart;\n const bOriginalEnd = bChange.originalStart + bChange.originalLength;\n const abOriginalLength = bOriginalEnd - aOriginalStart;\n const aModifiedStart = aChange.modifiedStart;\n const bModifiedEnd = bChange.modifiedStart + bChange.modifiedLength;\n const abModifiedLength = bModifiedEnd - aModifiedStart;\n // Avoid wasting a lot of time with these searches\n if (matchedLength < 5 && abOriginalLength < 20 && abModifiedLength < 20) {\n const t = this._findBetterContiguousSequence(aOriginalStart, abOriginalLength, aModifiedStart, abModifiedLength, matchedLength);\n if (t) {\n const [originalMatchStart, modifiedMatchStart] = t;\n if (originalMatchStart !== aChange.originalStart + aChange.originalLength || modifiedMatchStart !== aChange.modifiedStart + aChange.modifiedLength) {\n // switch to another sequence that has a better score\n aChange.originalLength = originalMatchStart - aChange.originalStart;\n aChange.modifiedLength = modifiedMatchStart - aChange.modifiedStart;\n bChange.originalStart = originalMatchStart + matchedLength;\n bChange.modifiedStart = modifiedMatchStart + matchedLength;\n bChange.originalLength = bOriginalEnd - bChange.originalStart;\n bChange.modifiedLength = bModifiedEnd - bChange.modifiedStart;\n }\n }\n }\n }\n }\n return changes;\n }\n _findBetterContiguousSequence(originalStart, originalLength, modifiedStart, modifiedLength, desiredLength) {\n if (originalLength < desiredLength || modifiedLength < desiredLength) {\n return null;\n }\n const originalMax = originalStart + originalLength - desiredLength + 1;\n const modifiedMax = modifiedStart + modifiedLength - desiredLength + 1;\n let bestScore = 0;\n let bestOriginalStart = 0;\n let bestModifiedStart = 0;\n for (let i = originalStart; i < originalMax; i++) {\n for (let j = modifiedStart; j < modifiedMax; j++) {\n const score = this._contiguousSequenceScore(i, j, desiredLength);\n if (score > 0 && score > bestScore) {\n bestScore = score;\n bestOriginalStart = i;\n bestModifiedStart = j;\n }\n }\n }\n if (bestScore > 0) {\n return [bestOriginalStart, bestModifiedStart];\n }\n return null;\n }\n _contiguousSequenceScore(originalStart, modifiedStart, length) {\n let score = 0;\n for (let l = 0; l < length; l++) {\n if (!this.ElementsAreEqual(originalStart + l, modifiedStart + l)) {\n return 0;\n }\n score += this._originalStringElements[originalStart + l].length;\n }\n return score;\n }\n _OriginalIsBoundary(index) {\n if (index <= 0 || index >= this._originalElementsOrHash.length - 1) {\n return true;\n }\n return (this._hasStrings && /^\\s*$/.test(this._originalStringElements[index]));\n }\n _OriginalRegionIsBoundary(originalStart, originalLength) {\n if (this._OriginalIsBoundary(originalStart) || this._OriginalIsBoundary(originalStart - 1)) {\n return true;\n }\n if (originalLength > 0) {\n const originalEnd = originalStart + originalLength;\n if (this._OriginalIsBoundary(originalEnd - 1) || this._OriginalIsBoundary(originalEnd)) {\n return true;\n }\n }\n return false;\n }\n _ModifiedIsBoundary(index) {\n if (index <= 0 || index >= this._modifiedElementsOrHash.length - 1) {\n return true;\n }\n return (this._hasStrings && /^\\s*$/.test(this._modifiedStringElements[index]));\n }\n _ModifiedRegionIsBoundary(modifiedStart, modifiedLength) {\n if (this._ModifiedIsBoundary(modifiedStart) || this._ModifiedIsBoundary(modifiedStart - 1)) {\n return true;\n }\n if (modifiedLength > 0) {\n const modifiedEnd = modifiedStart + modifiedLength;\n if (this._ModifiedIsBoundary(modifiedEnd - 1) || this._ModifiedIsBoundary(modifiedEnd)) {\n return true;\n }\n }\n return false;\n }\n _boundaryScore(originalStart, originalLength, modifiedStart, modifiedLength) {\n const originalScore = (this._OriginalRegionIsBoundary(originalStart, originalLength) ? 1 : 0);\n const modifiedScore = (this._ModifiedRegionIsBoundary(modifiedStart, modifiedLength) ? 1 : 0);\n return (originalScore + modifiedScore);\n }\n /**\n * Concatenates the two input DiffChange lists and returns the resulting\n * list.\n * @param The left changes\n * @param The right changes\n * @returns The concatenated list\n */\n ConcatenateChanges(left, right) {\n const mergedChangeArr = [];\n if (left.length === 0 || right.length === 0) {\n return (right.length > 0) ? right : left;\n }\n else if (this.ChangesOverlap(left[left.length - 1], right[0], mergedChangeArr)) {\n // Since we break the problem down recursively, it is possible that we\n // might recurse in the middle of a change thereby splitting it into\n // two changes. Here in the combining stage, we detect and fuse those\n // changes back together\n const result = new Array(left.length + right.length - 1);\n MyArray.Copy(left, 0, result, 0, left.length - 1);\n result[left.length - 1] = mergedChangeArr[0];\n MyArray.Copy(right, 1, result, left.length, right.length - 1);\n return result;\n }\n else {\n const result = new Array(left.length + right.length);\n MyArray.Copy(left, 0, result, 0, left.length);\n MyArray.Copy(right, 0, result, left.length, right.length);\n return result;\n }\n }\n /**\n * Returns true if the two changes overlap and can be merged into a single\n * change\n * @param left The left change\n * @param right The right change\n * @param mergedChange The merged change if the two overlap, null otherwise\n * @returns True if the two changes overlap\n */\n ChangesOverlap(left, right, mergedChangeArr) {\n Debug.Assert(left.originalStart <= right.originalStart, 'Left change is not less than or equal to right change');\n Debug.Assert(left.modifiedStart <= right.modifiedStart, 'Left change is not less than or equal to right change');\n if (left.originalStart + left.originalLength >= right.originalStart || left.modifiedStart + left.modifiedLength >= right.modifiedStart) {\n const originalStart = left.originalStart;\n let originalLength = left.originalLength;\n const modifiedStart = left.modifiedStart;\n let modifiedLength = left.modifiedLength;\n if (left.originalStart + left.originalLength >= right.originalStart) {\n originalLength = right.originalStart + right.originalLength - left.originalStart;\n }\n if (left.modifiedStart + left.modifiedLength >= right.modifiedStart) {\n modifiedLength = right.modifiedStart + right.modifiedLength - left.modifiedStart;\n }\n mergedChangeArr[0] = new DiffChange(originalStart, originalLength, modifiedStart, modifiedLength);\n return true;\n }\n else {\n mergedChangeArr[0] = null;\n return false;\n }\n }\n /**\n * Helper method used to clip a diagonal index to the range of valid\n * diagonals. This also decides whether or not the diagonal index,\n * if it exceeds the boundary, should be clipped to the boundary or clipped\n * one inside the boundary depending on the Even/Odd status of the boundary\n * and numDifferences.\n * @param diagonal The index of the diagonal to clip.\n * @param numDifferences The current number of differences being iterated upon.\n * @param diagonalBaseIndex The base reference diagonal.\n * @param numDiagonals The total number of diagonals.\n * @returns The clipped diagonal index.\n */\n ClipDiagonalBound(diagonal, numDifferences, diagonalBaseIndex, numDiagonals) {\n if (diagonal >= 0 && diagonal < numDiagonals) {\n // Nothing to clip, its in range\n return diagonal;\n }\n // diagonalsBelow: The number of diagonals below the reference diagonal\n // diagonalsAbove: The number of diagonals above the reference diagonal\n const diagonalsBelow = diagonalBaseIndex;\n const diagonalsAbove = numDiagonals - diagonalBaseIndex - 1;\n const diffEven = (numDifferences % 2 === 0);\n if (diagonal < 0) {\n const lowerBoundEven = (diagonalsBelow % 2 === 0);\n return (diffEven === lowerBoundEven) ? 0 : 1;\n }\n else {\n const upperBoundEven = (diagonalsAbove % 2 === 0);\n return (diffEven === upperBoundEven) ? numDiagonals - 1 : numDiagonals - 2;\n }\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n// NOTE: VSCode's copy of nodejs path library to be usable in common (non-node) namespace\n// Copied from: https://github.com/nodejs/node/blob/v14.16.0/lib/path.js\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 */\nimport * as process from './process.js';\nconst CHAR_UPPERCASE_A = 65; /* A */\nconst CHAR_LOWERCASE_A = 97; /* a */\nconst CHAR_UPPERCASE_Z = 90; /* Z */\nconst CHAR_LOWERCASE_Z = 122; /* z */\nconst CHAR_DOT = 46; /* . */\nconst CHAR_FORWARD_SLASH = 47; /* / */\nconst CHAR_BACKWARD_SLASH = 92; /* \\ */\nconst CHAR_COLON = 58; /* : */\nconst CHAR_QUESTION_MARK = 63; /* ? */\nclass ErrorInvalidArgType extends Error {\n constructor(name, expected, actual) {\n // determiner: 'must be' or 'must not be'\n let determiner;\n if (typeof expected === 'string' && expected.indexOf('not ') === 0) {\n determiner = 'must not be';\n expected = expected.replace(/^not /, '');\n }\n else {\n determiner = 'must be';\n }\n const type = name.indexOf('.') !== -1 ? 'property' : 'argument';\n let msg = `The \"${name}\" ${type} ${determiner} of type ${expected}`;\n msg += `. Received type ${typeof actual}`;\n super(msg);\n this.code = 'ERR_INVALID_ARG_TYPE';\n }\n}\nfunction validateString(value, name) {\n if (typeof value !== 'string') {\n throw new ErrorInvalidArgType(name, 'string', value);\n }\n}\nfunction isPathSeparator(code) {\n return code === CHAR_FORWARD_SLASH || code === CHAR_BACKWARD_SLASH;\n}\nfunction isPosixPathSeparator(code) {\n return code === CHAR_FORWARD_SLASH;\n}\nfunction isWindowsDeviceRoot(code) {\n return (code >= CHAR_UPPERCASE_A && code <= CHAR_UPPERCASE_Z) ||\n (code >= CHAR_LOWERCASE_A && code <= CHAR_LOWERCASE_Z);\n}\n// Resolves . and .. elements in a path with directory names\nfunction normalizeString(path, allowAboveRoot, separator, isPathSeparator) {\n let res = '';\n let lastSegmentLength = 0;\n let lastSlash = -1;\n let dots = 0;\n let code = 0;\n for (let i = 0; i <= path.length; ++i) {\n if (i < path.length) {\n code = path.charCodeAt(i);\n }\n else if (isPathSeparator(code)) {\n break;\n }\n else {\n code = CHAR_FORWARD_SLASH;\n }\n if (isPathSeparator(code)) {\n if (lastSlash === i - 1 || dots === 1) {\n // NOOP\n }\n else if (dots === 2) {\n if (res.length < 2 || lastSegmentLength !== 2 ||\n res.charCodeAt(res.length - 1) !== CHAR_DOT ||\n res.charCodeAt(res.length - 2) !== CHAR_DOT) {\n if (res.length > 2) {\n const lastSlashIndex = res.lastIndexOf(separator);\n if (lastSlashIndex === -1) {\n res = '';\n lastSegmentLength = 0;\n }\n else {\n res = res.slice(0, lastSlashIndex);\n lastSegmentLength = res.length - 1 - res.lastIndexOf(separator);\n }\n lastSlash = i;\n dots = 0;\n continue;\n }\n else if (res.length !== 0) {\n res = '';\n lastSegmentLength = 0;\n lastSlash = i;\n dots = 0;\n continue;\n }\n }\n if (allowAboveRoot) {\n res += res.length > 0 ? `${separator}..` : '..';\n lastSegmentLength = 2;\n }\n }\n else {\n if (res.length > 0) {\n res += `${separator}${path.slice(lastSlash + 1, i)}`;\n }\n else {\n res = path.slice(lastSlash + 1, i);\n }\n lastSegmentLength = i - lastSlash - 1;\n }\n lastSlash = i;\n dots = 0;\n }\n else if (code === CHAR_DOT && dots !== -1) {\n ++dots;\n }\n else {\n dots = -1;\n }\n }\n return res;\n}\nfunction _format(sep, pathObject) {\n if (pathObject === null || typeof pathObject !== 'object') {\n throw new ErrorInvalidArgType('pathObject', 'Object', pathObject);\n }\n const dir = pathObject.dir || pathObject.root;\n const base = pathObject.base ||\n `${pathObject.name || ''}${pathObject.ext || ''}`;\n if (!dir) {\n return base;\n }\n return dir === pathObject.root ? `${dir}${base}` : `${dir}${sep}${base}`;\n}\nexport const win32 = {\n // path.resolve([from ...], to)\n resolve(...pathSegments) {\n let resolvedDevice = '';\n let resolvedTail = '';\n let resolvedAbsolute = false;\n for (let i = pathSegments.length - 1; i >= -1; i--) {\n let path;\n if (i >= 0) {\n path = pathSegments[i];\n validateString(path, 'path');\n // Skip empty entries\n if (path.length === 0) {\n continue;\n }\n }\n else if (resolvedDevice.length === 0) {\n path = process.cwd();\n }\n else {\n // Windows has the concept of drive-specific current working\n // directories. If we've resolved a drive letter but not yet an\n // absolute path, get cwd for that drive, or the process cwd if\n // the drive cwd is not available. We're sure the device is not\n // a UNC path at this points, because UNC paths are always absolute.\n path = process.env[`=${resolvedDevice}`] || process.cwd();\n // Verify that a cwd was found and that it actually points\n // to our drive. If not, default to the drive's root.\n if (path === undefined ||\n (path.slice(0, 2).toLowerCase() !== resolvedDevice.toLowerCase() &&\n path.charCodeAt(2) === CHAR_BACKWARD_SLASH)) {\n path = `${resolvedDevice}\\\\`;\n }\n }\n const len = path.length;\n let rootEnd = 0;\n let device = '';\n let isAbsolute = false;\n const code = path.charCodeAt(0);\n // Try to match a root\n if (len === 1) {\n if (isPathSeparator(code)) {\n // `path` contains just a path separator\n rootEnd = 1;\n isAbsolute = true;\n }\n }\n else if (isPathSeparator(code)) {\n // Possible UNC root\n // If we started with a separator, we know we at least have an\n // absolute path of some kind (UNC or otherwise)\n isAbsolute = true;\n if (isPathSeparator(path.charCodeAt(1))) {\n // Matched double path separator at beginning\n let j = 2;\n let last = j;\n // Match 1 or more non-path separators\n while (j < len && !isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j < len && j !== last) {\n const firstPart = path.slice(last, j);\n // Matched!\n last = j;\n // Match 1 or more path separators\n while (j < len && isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j < len && j !== last) {\n // Matched!\n last = j;\n // Match 1 or more non-path separators\n while (j < len && !isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j === len || j !== last) {\n // We matched a UNC root\n device = `\\\\\\\\${firstPart}\\\\${path.slice(last, j)}`;\n rootEnd = j;\n }\n }\n }\n }\n else {\n rootEnd = 1;\n }\n }\n else if (isWindowsDeviceRoot(code) &&\n path.charCodeAt(1) === CHAR_COLON) {\n // Possible device root\n device = path.slice(0, 2);\n rootEnd = 2;\n if (len > 2 && isPathSeparator(path.charCodeAt(2))) {\n // Treat separator following drive name as an absolute path\n // indicator\n isAbsolute = true;\n rootEnd = 3;\n }\n }\n if (device.length > 0) {\n if (resolvedDevice.length > 0) {\n if (device.toLowerCase() !== resolvedDevice.toLowerCase()) {\n // This path points to another device so it is not applicable\n continue;\n }\n }\n else {\n resolvedDevice = device;\n }\n }\n if (resolvedAbsolute) {\n if (resolvedDevice.length > 0) {\n break;\n }\n }\n else {\n resolvedTail = `${path.slice(rootEnd)}\\\\${resolvedTail}`;\n resolvedAbsolute = isAbsolute;\n if (isAbsolute && resolvedDevice.length > 0) {\n break;\n }\n }\n }\n // At this point the path should be resolved to a full absolute path,\n // but handle relative paths to be safe (might happen when process.cwd()\n // fails)\n // Normalize the tail path\n resolvedTail = normalizeString(resolvedTail, !resolvedAbsolute, '\\\\', isPathSeparator);\n return resolvedAbsolute ?\n `${resolvedDevice}\\\\${resolvedTail}` :\n `${resolvedDevice}${resolvedTail}` || '.';\n },\n normalize(path) {\n validateString(path, 'path');\n const len = path.length;\n if (len === 0) {\n return '.';\n }\n let rootEnd = 0;\n let device;\n let isAbsolute = false;\n const code = path.charCodeAt(0);\n // Try to match a root\n if (len === 1) {\n // `path` contains just a single char, exit early to avoid\n // unnecessary work\n return isPosixPathSeparator(code) ? '\\\\' : path;\n }\n if (isPathSeparator(code)) {\n // Possible UNC root\n // If we started with a separator, we know we at least have an absolute\n // path of some kind (UNC or otherwise)\n isAbsolute = true;\n if (isPathSeparator(path.charCodeAt(1))) {\n // Matched double path separator at beginning\n let j = 2;\n let last = j;\n // Match 1 or more non-path separators\n while (j < len && !isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j < len && j !== last) {\n const firstPart = path.slice(last, j);\n // Matched!\n last = j;\n // Match 1 or more path separators\n while (j < len && isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j < len && j !== last) {\n // Matched!\n last = j;\n // Match 1 or more non-path separators\n while (j < len && !isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j === len) {\n // We matched a UNC root only\n // Return the normalized version of the UNC root since there\n // is nothing left to process\n return `\\\\\\\\${firstPart}\\\\${path.slice(last)}\\\\`;\n }\n if (j !== last) {\n // We matched a UNC root with leftovers\n device = `\\\\\\\\${firstPart}\\\\${path.slice(last, j)}`;\n rootEnd = j;\n }\n }\n }\n }\n else {\n rootEnd = 1;\n }\n }\n else if (isWindowsDeviceRoot(code) && path.charCodeAt(1) === CHAR_COLON) {\n // Possible device root\n device = path.slice(0, 2);\n rootEnd = 2;\n if (len > 2 && isPathSeparator(path.charCodeAt(2))) {\n // Treat separator following drive name as an absolute path\n // indicator\n isAbsolute = true;\n rootEnd = 3;\n }\n }\n let tail = rootEnd < len ?\n normalizeString(path.slice(rootEnd), !isAbsolute, '\\\\', isPathSeparator) :\n '';\n if (tail.length === 0 && !isAbsolute) {\n tail = '.';\n }\n if (tail.length > 0 && isPathSeparator(path.charCodeAt(len - 1))) {\n tail += '\\\\';\n }\n if (device === undefined) {\n return isAbsolute ? `\\\\${tail}` : tail;\n }\n return isAbsolute ? `${device}\\\\${tail}` : `${device}${tail}`;\n },\n isAbsolute(path) {\n validateString(path, 'path');\n const len = path.length;\n if (len === 0) {\n return false;\n }\n const code = path.charCodeAt(0);\n return isPathSeparator(code) ||\n // Possible device root\n (len > 2 &&\n isWindowsDeviceRoot(code) &&\n path.charCodeAt(1) === CHAR_COLON &&\n isPathSeparator(path.charCodeAt(2)));\n },\n join(...paths) {\n if (paths.length === 0) {\n return '.';\n }\n let joined;\n let firstPart;\n for (let i = 0; i < paths.length; ++i) {\n const arg = paths[i];\n validateString(arg, 'path');\n if (arg.length > 0) {\n if (joined === undefined) {\n joined = firstPart = arg;\n }\n else {\n joined += `\\\\${arg}`;\n }\n }\n }\n if (joined === undefined) {\n return '.';\n }\n // Make sure that the joined path doesn't start with two slashes, because\n // normalize() will mistake it for a UNC path then.\n //\n // This step is skipped when it is very clear that the user actually\n // intended to point at a UNC path. This is assumed when the first\n // non-empty string arguments starts with exactly two slashes followed by\n // at least one more non-slash character.\n //\n // Note that for normalize() to treat a path as a UNC path it needs to\n // have at least 2 components, so we don't filter for that here.\n // This means that the user can use join to construct UNC paths from\n // a server name and a share name; for example:\n // path.join('//server', 'share') -> '\\\\\\\\server\\\\share\\\\')\n let needsReplace = true;\n let slashCount = 0;\n if (typeof firstPart === 'string' && isPathSeparator(firstPart.charCodeAt(0))) {\n ++slashCount;\n const firstLen = firstPart.length;\n if (firstLen > 1 && isPathSeparator(firstPart.charCodeAt(1))) {\n ++slashCount;\n if (firstLen > 2) {\n if (isPathSeparator(firstPart.charCodeAt(2))) {\n ++slashCount;\n }\n else {\n // We matched a UNC path in the first part\n needsReplace = false;\n }\n }\n }\n }\n if (needsReplace) {\n // Find any more consecutive slashes we need to replace\n while (slashCount < joined.length &&\n isPathSeparator(joined.charCodeAt(slashCount))) {\n slashCount++;\n }\n // Replace the slashes if needed\n if (slashCount >= 2) {\n joined = `\\\\${joined.slice(slashCount)}`;\n }\n }\n return win32.normalize(joined);\n },\n // It will solve the relative path from `from` to `to`, for instance:\n // from = 'C:\\\\orandea\\\\test\\\\aaa'\n // to = 'C:\\\\orandea\\\\impl\\\\bbb'\n // The output of the function should be: '..\\\\..\\\\impl\\\\bbb'\n relative(from, to) {\n validateString(from, 'from');\n validateString(to, 'to');\n if (from === to) {\n return '';\n }\n const fromOrig = win32.resolve(from);\n const toOrig = win32.resolve(to);\n if (fromOrig === toOrig) {\n return '';\n }\n from = fromOrig.toLowerCase();\n to = toOrig.toLowerCase();\n if (from === to) {\n return '';\n }\n // Trim any leading backslashes\n let fromStart = 0;\n while (fromStart < from.length &&\n from.charCodeAt(fromStart) === CHAR_BACKWARD_SLASH) {\n fromStart++;\n }\n // Trim trailing backslashes (applicable to UNC paths only)\n let fromEnd = from.length;\n while (fromEnd - 1 > fromStart &&\n from.charCodeAt(fromEnd - 1) === CHAR_BACKWARD_SLASH) {\n fromEnd--;\n }\n const fromLen = fromEnd - fromStart;\n // Trim any leading backslashes\n let toStart = 0;\n while (toStart < to.length &&\n to.charCodeAt(toStart) === CHAR_BACKWARD_SLASH) {\n toStart++;\n }\n // Trim trailing backslashes (applicable to UNC paths only)\n let toEnd = to.length;\n while (toEnd - 1 > toStart &&\n to.charCodeAt(toEnd - 1) === CHAR_BACKWARD_SLASH) {\n toEnd--;\n }\n const toLen = toEnd - toStart;\n // Compare paths to find the longest common path from root\n const length = fromLen < toLen ? fromLen : toLen;\n let lastCommonSep = -1;\n let i = 0;\n for (; i < length; i++) {\n const fromCode = from.charCodeAt(fromStart + i);\n if (fromCode !== to.charCodeAt(toStart + i)) {\n break;\n }\n else if (fromCode === CHAR_BACKWARD_SLASH) {\n lastCommonSep = i;\n }\n }\n // We found a mismatch before the first common path separator was seen, so\n // return the original `to`.\n if (i !== length) {\n if (lastCommonSep === -1) {\n return toOrig;\n }\n }\n else {\n if (toLen > length) {\n if (to.charCodeAt(toStart + i) === CHAR_BACKWARD_SLASH) {\n // We get here if `from` is the exact base path for `to`.\n // For example: from='C:\\\\foo\\\\bar'; to='C:\\\\foo\\\\bar\\\\baz'\n return toOrig.slice(toStart + i + 1);\n }\n if (i === 2) {\n // We get here if `from` is the device root.\n // For example: from='C:\\\\'; to='C:\\\\foo'\n return toOrig.slice(toStart + i);\n }\n }\n if (fromLen > length) {\n if (from.charCodeAt(fromStart + i) === CHAR_BACKWARD_SLASH) {\n // We get here if `to` is the exact base path for `from`.\n // For example: from='C:\\\\foo\\\\bar'; to='C:\\\\foo'\n lastCommonSep = i;\n }\n else if (i === 2) {\n // We get here if `to` is the device root.\n // For example: from='C:\\\\foo\\\\bar'; to='C:\\\\'\n lastCommonSep = 3;\n }\n }\n if (lastCommonSep === -1) {\n lastCommonSep = 0;\n }\n }\n let out = '';\n // Generate the relative path based on the path difference between `to` and\n // `from`\n for (i = fromStart + lastCommonSep + 1; i <= fromEnd; ++i) {\n if (i === fromEnd || from.charCodeAt(i) === CHAR_BACKWARD_SLASH) {\n out += out.length === 0 ? '..' : '\\\\..';\n }\n }\n toStart += lastCommonSep;\n // Lastly, append the rest of the destination (`to`) path that comes after\n // the common path parts\n if (out.length > 0) {\n return `${out}${toOrig.slice(toStart, toEnd)}`;\n }\n if (toOrig.charCodeAt(toStart) === CHAR_BACKWARD_SLASH) {\n ++toStart;\n }\n return toOrig.slice(toStart, toEnd);\n },\n toNamespacedPath(path) {\n // Note: this will *probably* throw somewhere.\n if (typeof path !== 'string') {\n return path;\n }\n if (path.length === 0) {\n return '';\n }\n const resolvedPath = win32.resolve(path);\n if (resolvedPath.length <= 2) {\n return path;\n }\n if (resolvedPath.charCodeAt(0) === CHAR_BACKWARD_SLASH) {\n // Possible UNC root\n if (resolvedPath.charCodeAt(1) === CHAR_BACKWARD_SLASH) {\n const code = resolvedPath.charCodeAt(2);\n if (code !== CHAR_QUESTION_MARK && code !== CHAR_DOT) {\n // Matched non-long UNC root, convert the path to a long UNC path\n return `\\\\\\\\?\\\\UNC\\\\${resolvedPath.slice(2)}`;\n }\n }\n }\n else if (isWindowsDeviceRoot(resolvedPath.charCodeAt(0)) &&\n resolvedPath.charCodeAt(1) === CHAR_COLON &&\n resolvedPath.charCodeAt(2) === CHAR_BACKWARD_SLASH) {\n // Matched device root, convert the path to a long UNC path\n return `\\\\\\\\?\\\\${resolvedPath}`;\n }\n return path;\n },\n dirname(path) {\n validateString(path, 'path');\n const len = path.length;\n if (len === 0) {\n return '.';\n }\n let rootEnd = -1;\n let offset = 0;\n const code = path.charCodeAt(0);\n if (len === 1) {\n // `path` contains just a path separator, exit early to avoid\n // unnecessary work or a dot.\n return isPathSeparator(code) ? path : '.';\n }\n // Try to match a root\n if (isPathSeparator(code)) {\n // Possible UNC root\n rootEnd = offset = 1;\n if (isPathSeparator(path.charCodeAt(1))) {\n // Matched double path separator at beginning\n let j = 2;\n let last = j;\n // Match 1 or more non-path separators\n while (j < len && !isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j < len && j !== last) {\n // Matched!\n last = j;\n // Match 1 or more path separators\n while (j < len && isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j < len && j !== last) {\n // Matched!\n last = j;\n // Match 1 or more non-path separators\n while (j < len && !isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j === len) {\n // We matched a UNC root only\n return path;\n }\n if (j !== last) {\n // We matched a UNC root with leftovers\n // Offset by 1 to include the separator after the UNC root to\n // treat it as a \"normal root\" on top of a (UNC) root\n rootEnd = offset = j + 1;\n }\n }\n }\n }\n // Possible device root\n }\n else if (isWindowsDeviceRoot(code) && path.charCodeAt(1) === CHAR_COLON) {\n rootEnd = len > 2 && isPathSeparator(path.charCodeAt(2)) ? 3 : 2;\n offset = rootEnd;\n }\n let end = -1;\n let matchedSlash = true;\n for (let i = len - 1; i >= offset; --i) {\n if (isPathSeparator(path.charCodeAt(i))) {\n if (!matchedSlash) {\n end = i;\n break;\n }\n }\n else {\n // We saw the first non-path separator\n matchedSlash = false;\n }\n }\n if (end === -1) {\n if (rootEnd === -1) {\n return '.';\n }\n end = rootEnd;\n }\n return path.slice(0, end);\n },\n basename(path, ext) {\n if (ext !== undefined) {\n validateString(ext, 'ext');\n }\n validateString(path, 'path');\n let start = 0;\n let end = -1;\n let matchedSlash = true;\n let i;\n // Check for a drive letter prefix so as not to mistake the following\n // path separator as an extra separator at the end of the path that can be\n // disregarded\n if (path.length >= 2 &&\n isWindowsDeviceRoot(path.charCodeAt(0)) &&\n path.charCodeAt(1) === CHAR_COLON) {\n start = 2;\n }\n if (ext !== undefined && ext.length > 0 && ext.length <= path.length) {\n if (ext === path) {\n return '';\n }\n let extIdx = ext.length - 1;\n let firstNonSlashEnd = -1;\n for (i = path.length - 1; i >= start; --i) {\n const code = path.charCodeAt(i);\n if (isPathSeparator(code)) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n }\n else {\n if (firstNonSlashEnd === -1) {\n // We saw the first non-path separator, remember this index in case\n // we need it if the extension ends up not matching\n matchedSlash = false;\n firstNonSlashEnd = i + 1;\n }\n if (extIdx >= 0) {\n // Try to match the explicit extension\n if (code === ext.charCodeAt(extIdx)) {\n if (--extIdx === -1) {\n // We matched the extension, so mark this as the end of our path\n // component\n end = i;\n }\n }\n else {\n // Extension does not match, so our result is the entire path\n // component\n extIdx = -1;\n end = firstNonSlashEnd;\n }\n }\n }\n }\n if (start === end) {\n end = firstNonSlashEnd;\n }\n else if (end === -1) {\n end = path.length;\n }\n return path.slice(start, end);\n }\n for (i = path.length - 1; i >= start; --i) {\n if (isPathSeparator(path.charCodeAt(i))) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n }\n else if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // path component\n matchedSlash = false;\n end = i + 1;\n }\n }\n if (end === -1) {\n return '';\n }\n return path.slice(start, end);\n },\n extname(path) {\n validateString(path, 'path');\n let start = 0;\n let startDot = -1;\n let startPart = 0;\n let end = -1;\n let matchedSlash = true;\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n let preDotState = 0;\n // Check for a drive letter prefix so as not to mistake the following\n // path separator as an extra separator at the end of the path that can be\n // disregarded\n if (path.length >= 2 &&\n path.charCodeAt(1) === CHAR_COLON &&\n isWindowsDeviceRoot(path.charCodeAt(0))) {\n start = startPart = 2;\n }\n for (let i = path.length - 1; i >= start; --i) {\n const code = path.charCodeAt(i);\n if (isPathSeparator(code)) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === CHAR_DOT) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1) {\n startDot = i;\n }\n else if (preDotState !== 1) {\n preDotState = 1;\n }\n }\n else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n if (startDot === -1 ||\n end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n (preDotState === 1 &&\n startDot === end - 1 &&\n startDot === startPart + 1)) {\n return '';\n }\n return path.slice(startDot, end);\n },\n format: _format.bind(null, '\\\\'),\n parse(path) {\n validateString(path, 'path');\n const ret = { root: '', dir: '', base: '', ext: '', name: '' };\n if (path.length === 0) {\n return ret;\n }\n const len = path.length;\n let rootEnd = 0;\n let code = path.charCodeAt(0);\n if (len === 1) {\n if (isPathSeparator(code)) {\n // `path` contains just a path separator, exit early to avoid\n // unnecessary work\n ret.root = ret.dir = path;\n return ret;\n }\n ret.base = ret.name = path;\n return ret;\n }\n // Try to match a root\n if (isPathSeparator(code)) {\n // Possible UNC root\n rootEnd = 1;\n if (isPathSeparator(path.charCodeAt(1))) {\n // Matched double path separator at beginning\n let j = 2;\n let last = j;\n // Match 1 or more non-path separators\n while (j < len && !isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j < len && j !== last) {\n // Matched!\n last = j;\n // Match 1 or more path separators\n while (j < len && isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j < len && j !== last) {\n // Matched!\n last = j;\n // Match 1 or more non-path separators\n while (j < len && !isPathSeparator(path.charCodeAt(j))) {\n j++;\n }\n if (j === len) {\n // We matched a UNC root only\n rootEnd = j;\n }\n else if (j !== last) {\n // We matched a UNC root with leftovers\n rootEnd = j + 1;\n }\n }\n }\n }\n }\n else if (isWindowsDeviceRoot(code) && path.charCodeAt(1) === CHAR_COLON) {\n // Possible device root\n if (len <= 2) {\n // `path` contains just a drive root, exit early to avoid\n // unnecessary work\n ret.root = ret.dir = path;\n return ret;\n }\n rootEnd = 2;\n if (isPathSeparator(path.charCodeAt(2))) {\n if (len === 3) {\n // `path` contains just a drive root, exit early to avoid\n // unnecessary work\n ret.root = ret.dir = path;\n return ret;\n }\n rootEnd = 3;\n }\n }\n if (rootEnd > 0) {\n ret.root = path.slice(0, rootEnd);\n }\n let startDot = -1;\n let startPart = rootEnd;\n let end = -1;\n let matchedSlash = true;\n let i = path.length - 1;\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n let preDotState = 0;\n // Get non-dir info\n for (; i >= rootEnd; --i) {\n code = path.charCodeAt(i);\n if (isPathSeparator(code)) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === CHAR_DOT) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1) {\n startDot = i;\n }\n else if (preDotState !== 1) {\n preDotState = 1;\n }\n }\n else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n if (end !== -1) {\n if (startDot === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n (preDotState === 1 &&\n startDot === end - 1 &&\n startDot === startPart + 1)) {\n ret.base = ret.name = path.slice(startPart, end);\n }\n else {\n ret.name = path.slice(startPart, startDot);\n ret.base = path.slice(startPart, end);\n ret.ext = path.slice(startDot, end);\n }\n }\n // If the directory is the root, use the entire root as the `dir` including\n // the trailing slash if any (`C:\\abc` -> `C:\\`). Otherwise, strip out the\n // trailing slash (`C:\\abc\\def` -> `C:\\abc`).\n if (startPart > 0 && startPart !== rootEnd) {\n ret.dir = path.slice(0, startPart - 1);\n }\n else {\n ret.dir = ret.root;\n }\n return ret;\n },\n sep: '\\\\',\n delimiter: ';',\n win32: null,\n posix: null\n};\nexport const posix = {\n // path.resolve([from ...], to)\n resolve(...pathSegments) {\n let resolvedPath = '';\n let resolvedAbsolute = false;\n for (let i = pathSegments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n const path = i >= 0 ? pathSegments[i] : process.cwd();\n validateString(path, 'path');\n // Skip empty entries\n if (path.length === 0) {\n continue;\n }\n resolvedPath = `${path}/${resolvedPath}`;\n resolvedAbsolute = path.charCodeAt(0) === CHAR_FORWARD_SLASH;\n }\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n // Normalize the path\n resolvedPath = normalizeString(resolvedPath, !resolvedAbsolute, '/', isPosixPathSeparator);\n if (resolvedAbsolute) {\n return `/${resolvedPath}`;\n }\n return resolvedPath.length > 0 ? resolvedPath : '.';\n },\n normalize(path) {\n validateString(path, 'path');\n if (path.length === 0) {\n return '.';\n }\n const isAbsolute = path.charCodeAt(0) === CHAR_FORWARD_SLASH;\n const trailingSeparator = path.charCodeAt(path.length - 1) === CHAR_FORWARD_SLASH;\n // Normalize the path\n path = normalizeString(path, !isAbsolute, '/', isPosixPathSeparator);\n if (path.length === 0) {\n if (isAbsolute) {\n return '/';\n }\n return trailingSeparator ? './' : '.';\n }\n if (trailingSeparator) {\n path += '/';\n }\n return isAbsolute ? `/${path}` : path;\n },\n isAbsolute(path) {\n validateString(path, 'path');\n return path.length > 0 && path.charCodeAt(0) === CHAR_FORWARD_SLASH;\n },\n join(...paths) {\n if (paths.length === 0) {\n return '.';\n }\n let joined;\n for (let i = 0; i < paths.length; ++i) {\n const arg = paths[i];\n validateString(arg, 'path');\n if (arg.length > 0) {\n if (joined === undefined) {\n joined = arg;\n }\n else {\n joined += `/${arg}`;\n }\n }\n }\n if (joined === undefined) {\n return '.';\n }\n return posix.normalize(joined);\n },\n relative(from, to) {\n validateString(from, 'from');\n validateString(to, 'to');\n if (from === to) {\n return '';\n }\n // Trim leading forward slashes.\n from = posix.resolve(from);\n to = posix.resolve(to);\n if (from === to) {\n return '';\n }\n const fromStart = 1;\n const fromEnd = from.length;\n const fromLen = fromEnd - fromStart;\n const toStart = 1;\n const toLen = to.length - toStart;\n // Compare paths to find the longest common path from root\n const length = (fromLen < toLen ? fromLen : toLen);\n let lastCommonSep = -1;\n let i = 0;\n for (; i < length; i++) {\n const fromCode = from.charCodeAt(fromStart + i);\n if (fromCode !== to.charCodeAt(toStart + i)) {\n break;\n }\n else if (fromCode === CHAR_FORWARD_SLASH) {\n lastCommonSep = i;\n }\n }\n if (i === length) {\n if (toLen > length) {\n if (to.charCodeAt(toStart + i) === CHAR_FORWARD_SLASH) {\n // We get here if `from` is the exact base path for `to`.\n // For example: from='/foo/bar'; to='/foo/bar/baz'\n return to.slice(toStart + i + 1);\n }\n if (i === 0) {\n // We get here if `from` is the root\n // For example: from='/'; to='/foo'\n return to.slice(toStart + i);\n }\n }\n else if (fromLen > length) {\n if (from.charCodeAt(fromStart + i) === CHAR_FORWARD_SLASH) {\n // We get here if `to` is the exact base path for `from`.\n // For example: from='/foo/bar/baz'; to='/foo/bar'\n lastCommonSep = i;\n }\n else if (i === 0) {\n // We get here if `to` is the root.\n // For example: from='/foo/bar'; to='/'\n lastCommonSep = 0;\n }\n }\n }\n let out = '';\n // Generate the relative path based on the path difference between `to`\n // and `from`.\n for (i = fromStart + lastCommonSep + 1; i <= fromEnd; ++i) {\n if (i === fromEnd || from.charCodeAt(i) === CHAR_FORWARD_SLASH) {\n out += out.length === 0 ? '..' : '/..';\n }\n }\n // Lastly, append the rest of the destination (`to`) path that comes after\n // the common path parts.\n return `${out}${to.slice(toStart + lastCommonSep)}`;\n },\n toNamespacedPath(path) {\n // Non-op on posix systems\n return path;\n },\n dirname(path) {\n validateString(path, 'path');\n if (path.length === 0) {\n return '.';\n }\n const hasRoot = path.charCodeAt(0) === CHAR_FORWARD_SLASH;\n let end = -1;\n let matchedSlash = true;\n for (let i = path.length - 1; i >= 1; --i) {\n if (path.charCodeAt(i) === CHAR_FORWARD_SLASH) {\n if (!matchedSlash) {\n end = i;\n break;\n }\n }\n else {\n // We saw the first non-path separator\n matchedSlash = false;\n }\n }\n if (end === -1) {\n return hasRoot ? '/' : '.';\n }\n if (hasRoot && end === 1) {\n return '//';\n }\n return path.slice(0, end);\n },\n basename(path, ext) {\n if (ext !== undefined) {\n validateString(ext, 'ext');\n }\n validateString(path, 'path');\n let start = 0;\n let end = -1;\n let matchedSlash = true;\n let i;\n if (ext !== undefined && ext.length > 0 && ext.length <= path.length) {\n if (ext === path) {\n return '';\n }\n let extIdx = ext.length - 1;\n let firstNonSlashEnd = -1;\n for (i = path.length - 1; i >= 0; --i) {\n const code = path.charCodeAt(i);\n if (code === CHAR_FORWARD_SLASH) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n }\n else {\n if (firstNonSlashEnd === -1) {\n // We saw the first non-path separator, remember this index in case\n // we need it if the extension ends up not matching\n matchedSlash = false;\n firstNonSlashEnd = i + 1;\n }\n if (extIdx >= 0) {\n // Try to match the explicit extension\n if (code === ext.charCodeAt(extIdx)) {\n if (--extIdx === -1) {\n // We matched the extension, so mark this as the end of our path\n // component\n end = i;\n }\n }\n else {\n // Extension does not match, so our result is the entire path\n // component\n extIdx = -1;\n end = firstNonSlashEnd;\n }\n }\n }\n }\n if (start === end) {\n end = firstNonSlashEnd;\n }\n else if (end === -1) {\n end = path.length;\n }\n return path.slice(start, end);\n }\n for (i = path.length - 1; i >= 0; --i) {\n if (path.charCodeAt(i) === CHAR_FORWARD_SLASH) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n }\n else if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // path component\n matchedSlash = false;\n end = i + 1;\n }\n }\n if (end === -1) {\n return '';\n }\n return path.slice(start, end);\n },\n extname(path) {\n validateString(path, 'path');\n let startDot = -1;\n let startPart = 0;\n let end = -1;\n let matchedSlash = true;\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n let preDotState = 0;\n for (let i = path.length - 1; i >= 0; --i) {\n const code = path.charCodeAt(i);\n if (code === CHAR_FORWARD_SLASH) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === CHAR_DOT) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1) {\n startDot = i;\n }\n else if (preDotState !== 1) {\n preDotState = 1;\n }\n }\n else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n if (startDot === -1 ||\n end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n (preDotState === 1 &&\n startDot === end - 1 &&\n startDot === startPart + 1)) {\n return '';\n }\n return path.slice(startDot, end);\n },\n format: _format.bind(null, '/'),\n parse(path) {\n validateString(path, 'path');\n const ret = { root: '', dir: '', base: '', ext: '', name: '' };\n if (path.length === 0) {\n return ret;\n }\n const isAbsolute = path.charCodeAt(0) === CHAR_FORWARD_SLASH;\n let start;\n if (isAbsolute) {\n ret.root = '/';\n start = 1;\n }\n else {\n start = 0;\n }\n let startDot = -1;\n let startPart = 0;\n let end = -1;\n let matchedSlash = true;\n let i = path.length - 1;\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n let preDotState = 0;\n // Get non-dir info\n for (; i >= start; --i) {\n const code = path.charCodeAt(i);\n if (code === CHAR_FORWARD_SLASH) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === CHAR_DOT) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1) {\n startDot = i;\n }\n else if (preDotState !== 1) {\n preDotState = 1;\n }\n }\n else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n if (end !== -1) {\n const start = startPart === 0 && isAbsolute ? 1 : startPart;\n if (startDot === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n (preDotState === 1 &&\n startDot === end - 1 &&\n startDot === startPart + 1)) {\n ret.base = ret.name = path.slice(start, end);\n }\n else {\n ret.name = path.slice(start, startDot);\n ret.base = path.slice(start, end);\n ret.ext = path.slice(startDot, end);\n }\n }\n if (startPart > 0) {\n ret.dir = path.slice(0, startPart - 1);\n }\n else if (isAbsolute) {\n ret.dir = '/';\n }\n return ret;\n },\n sep: '/',\n delimiter: ':',\n win32: null,\n posix: null\n};\nposix.win32 = win32.win32 = win32;\nposix.posix = win32.posix = posix;\nexport const normalize = (process.platform === 'win32' ? win32.normalize : posix.normalize);\nexport const resolve = (process.platform === 'win32' ? win32.resolve : posix.resolve);\nexport const relative = (process.platform === 'win32' ? win32.relative : posix.relative);\nexport const dirname = (process.platform === 'win32' ? win32.dirname : posix.dirname);\nexport const basename = (process.platform === 'win32' ? win32.basename : posix.basename);\nexport const extname = (process.platform === 'win32' ? win32.extname : posix.extname);\nexport const sep = (process.platform === 'win32' ? win32.sep : posix.sep);\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport * as paths from './path.js';\nimport { isWindows } from './platform.js';\nconst _schemePattern = /^\\w[\\w\\d+.-]*$/;\nconst _singleSlashStart = /^\\//;\nconst _doubleSlashStart = /^\\/\\//;\nfunction _validateUri(ret, _strict) {\n // scheme, must be set\n if (!ret.scheme && _strict) {\n throw new Error(`[UriError]: Scheme is missing: {scheme: \"\", authority: \"${ret.authority}\", path: \"${ret.path}\", query: \"${ret.query}\", fragment: \"${ret.fragment}\"}`);\n }\n // scheme, https://tools.ietf.org/html/rfc3986#section-3.1\n // ALPHA *( ALPHA / DIGIT / \"+\" / \"-\" / \".\" )\n if (ret.scheme && !_schemePattern.test(ret.scheme)) {\n throw new Error('[UriError]: Scheme contains illegal characters.');\n }\n // path, http://tools.ietf.org/html/rfc3986#section-3.3\n // If a URI contains an authority component, then the path component\n // must either be empty or begin with a slash (\"/\") character. If a URI\n // does not contain an authority component, then the path cannot begin\n // with two slash characters (\"//\").\n if (ret.path) {\n if (ret.authority) {\n if (!_singleSlashStart.test(ret.path)) {\n throw new Error('[UriError]: If a URI contains an authority component, then the path component must either be empty or begin with a slash (\"/\") character');\n }\n }\n else {\n if (_doubleSlashStart.test(ret.path)) {\n throw new Error('[UriError]: If a URI does not contain an authority component, then the path cannot begin with two slash characters (\"//\")');\n }\n }\n }\n}\n// for a while we allowed uris *without* schemes and this is the migration\n// for them, e.g. an uri without scheme and without strict-mode warns and falls\n// back to the file-scheme. that should cause the least carnage and still be a\n// clear warning\nfunction _schemeFix(scheme, _strict) {\n if (!scheme && !_strict) {\n return 'file';\n }\n return scheme;\n}\n// implements a bit of https://tools.ietf.org/html/rfc3986#section-5\nfunction _referenceResolution(scheme, path) {\n // the slash-character is our 'default base' as we don't\n // support constructing URIs relative to other URIs. This\n // also means that we alter and potentially break paths.\n // see https://tools.ietf.org/html/rfc3986#section-5.1.4\n switch (scheme) {\n case 'https':\n case 'http':\n case 'file':\n if (!path) {\n path = _slash;\n }\n else if (path[0] !== _slash) {\n path = _slash + path;\n }\n break;\n }\n return path;\n}\nconst _empty = '';\nconst _slash = '/';\nconst _regexp = /^(([^:/?#]+?):)?(\\/\\/([^/?#]*))?([^?#]*)(\\?([^#]*))?(#(.*))?/;\n/**\n * Uniform Resource Identifier (URI) http://tools.ietf.org/html/rfc3986.\n * This class is a simple parser which creates the basic component parts\n * (http://tools.ietf.org/html/rfc3986#section-3) with minimal validation\n * and encoding.\n *\n * ```txt\n * foo://example.com:8042/over/there?name=ferret#nose\n * \\_/ \\______________/\\_________/ \\_________/ \\__/\n * | | | | |\n * scheme authority path query fragment\n * | _____________________|__\n * / \\ / \\\n * urn:example:animal:ferret:nose\n * ```\n */\nexport class URI {\n /**\n * @internal\n */\n constructor(schemeOrData, authority, path, query, fragment, _strict = false) {\n if (typeof schemeOrData === 'object') {\n this.scheme = schemeOrData.scheme || _empty;\n this.authority = schemeOrData.authority || _empty;\n this.path = schemeOrData.path || _empty;\n this.query = schemeOrData.query || _empty;\n this.fragment = schemeOrData.fragment || _empty;\n // no validation because it's this URI\n // that creates uri components.\n // _validateUri(this);\n }\n else {\n this.scheme = _schemeFix(schemeOrData, _strict);\n this.authority = authority || _empty;\n this.path = _referenceResolution(this.scheme, path || _empty);\n this.query = query || _empty;\n this.fragment = fragment || _empty;\n _validateUri(this, _strict);\n }\n }\n static isUri(thing) {\n if (thing instanceof URI) {\n return true;\n }\n if (!thing) {\n return false;\n }\n return typeof thing.authority === 'string'\n && typeof thing.fragment === 'string'\n && typeof thing.path === 'string'\n && typeof thing.query === 'string'\n && typeof thing.scheme === 'string'\n && typeof thing.fsPath === 'string'\n && typeof thing.with === 'function'\n && typeof thing.toString === 'function';\n }\n // ---- filesystem path -----------------------\n /**\n * Returns a string representing the corresponding file system path of this URI.\n * Will handle UNC paths, normalizes windows drive letters to lower-case, and uses the\n * platform specific path separator.\n *\n * * Will *not* validate the path for invalid characters and semantics.\n * * Will *not* look at the scheme of this URI.\n * * The result shall *not* be used for display purposes but for accessing a file on disk.\n *\n *\n * The *difference* to `URI#path` is the use of the platform specific separator and the handling\n * of UNC paths. See the below sample of a file-uri with an authority (UNC path).\n *\n * ```ts\n const u = URI.parse('file://server/c$/folder/file.txt')\n u.authority === 'server'\n u.path === '/shares/c$/file.txt'\n u.fsPath === '\\\\server\\c$\\folder\\file.txt'\n ```\n *\n * Using `URI#path` to read a file (using fs-apis) would not be enough because parts of the path,\n * namely the server name, would be missing. Therefore `URI#fsPath` exists - it's sugar to ease working\n * with URIs that represent files on disk (`file` scheme).\n */\n get fsPath() {\n // if (this.scheme !== 'file') {\n // \tconsole.warn(`[UriError] calling fsPath with scheme ${this.scheme}`);\n // }\n return uriToFsPath(this, false);\n }\n // ---- modify to new -------------------------\n with(change) {\n if (!change) {\n return this;\n }\n let { scheme, authority, path, query, fragment } = change;\n if (scheme === undefined) {\n scheme = this.scheme;\n }\n else if (scheme === null) {\n scheme = _empty;\n }\n if (authority === undefined) {\n authority = this.authority;\n }\n else if (authority === null) {\n authority = _empty;\n }\n if (path === undefined) {\n path = this.path;\n }\n else if (path === null) {\n path = _empty;\n }\n if (query === undefined) {\n query = this.query;\n }\n else if (query === null) {\n query = _empty;\n }\n if (fragment === undefined) {\n fragment = this.fragment;\n }\n else if (fragment === null) {\n fragment = _empty;\n }\n if (scheme === this.scheme\n && authority === this.authority\n && path === this.path\n && query === this.query\n && fragment === this.fragment) {\n return this;\n }\n return new Uri(scheme, authority, path, query, fragment);\n }\n // ---- parse & validate ------------------------\n /**\n * Creates a new URI from a string, e.g. `http://www.example.com/some/path`,\n * `file:///usr/home`, or `scheme:with/path`.\n *\n * @param value A string which represents an URI (see `URI#toString`).\n */\n static parse(value, _strict = false) {\n const match = _regexp.exec(value);\n if (!match) {\n return new Uri(_empty, _empty, _empty, _empty, _empty);\n }\n return new Uri(match[2] || _empty, percentDecode(match[4] || _empty), percentDecode(match[5] || _empty), percentDecode(match[7] || _empty), percentDecode(match[9] || _empty), _strict);\n }\n /**\n * Creates a new URI from a file system path, e.g. `c:\\my\\files`,\n * `/usr/home`, or `\\\\server\\share\\some\\path`.\n *\n * The *difference* between `URI#parse` and `URI#file` is that the latter treats the argument\n * as path, not as stringified-uri. E.g. `URI.file(path)` is **not the same as**\n * `URI.parse('file://' + path)` because the path might contain characters that are\n * interpreted (# and ?). See the following sample:\n * ```ts\n const good = URI.file('/coding/c#/project1');\n good.scheme === 'file';\n good.path === '/coding/c#/project1';\n good.fragment === '';\n const bad = URI.parse('file://' + '/coding/c#/project1');\n bad.scheme === 'file';\n bad.path === '/coding/c'; // path is now broken\n bad.fragment === '/project1';\n ```\n *\n * @param path A file system path (see `URI#fsPath`)\n */\n static file(path) {\n let authority = _empty;\n // normalize to fwd-slashes on windows,\n // on other systems bwd-slashes are valid\n // filename character, eg /f\\oo/ba\\r.txt\n if (isWindows) {\n path = path.replace(/\\\\/g, _slash);\n }\n // check for authority as used in UNC shares\n // or use the path as given\n if (path[0] === _slash && path[1] === _slash) {\n const idx = path.indexOf(_slash, 2);\n if (idx === -1) {\n authority = path.substring(2);\n path = _slash;\n }\n else {\n authority = path.substring(2, idx);\n path = path.substring(idx) || _slash;\n }\n }\n return new Uri('file', authority, path, _empty, _empty);\n }\n static from(components) {\n const result = new Uri(components.scheme, components.authority, components.path, components.query, components.fragment);\n _validateUri(result, true);\n return result;\n }\n /**\n * Join a URI path with path fragments and normalizes the resulting path.\n *\n * @param uri The input URI.\n * @param pathFragment The path fragment to add to the URI path.\n * @returns The resulting URI.\n */\n static joinPath(uri, ...pathFragment) {\n if (!uri.path) {\n throw new Error(`[UriError]: cannot call joinPath on URI without path`);\n }\n let newPath;\n if (isWindows && uri.scheme === 'file') {\n newPath = URI.file(paths.win32.join(uriToFsPath(uri, true), ...pathFragment)).path;\n }\n else {\n newPath = paths.posix.join(uri.path, ...pathFragment);\n }\n return uri.with({ path: newPath });\n }\n // ---- printing/externalize ---------------------------\n /**\n * Creates a string representation for this URI. It's guaranteed that calling\n * `URI.parse` with the result of this function creates an URI which is equal\n * to this URI.\n *\n * * The result shall *not* be used for display purposes but for externalization or transport.\n * * The result will be encoded using the percentage encoding and encoding happens mostly\n * ignore the scheme-specific encoding rules.\n *\n * @param skipEncoding Do not encode the result, default is `false`\n */\n toString(skipEncoding = false) {\n return _asFormatted(this, skipEncoding);\n }\n toJSON() {\n return this;\n }\n static revive(data) {\n if (!data) {\n return data;\n }\n else if (data instanceof URI) {\n return data;\n }\n else {\n const result = new Uri(data);\n result._formatted = data.external;\n result._fsPath = data._sep === _pathSepMarker ? data.fsPath : null;\n return result;\n }\n }\n}\nconst _pathSepMarker = isWindows ? 1 : undefined;\n// This class exists so that URI is compatible with vscode.Uri (API).\nclass Uri extends URI {\n constructor() {\n super(...arguments);\n this._formatted = null;\n this._fsPath = null;\n }\n get fsPath() {\n if (!this._fsPath) {\n this._fsPath = uriToFsPath(this, false);\n }\n return this._fsPath;\n }\n toString(skipEncoding = false) {\n if (!skipEncoding) {\n if (!this._formatted) {\n this._formatted = _asFormatted(this, false);\n }\n return this._formatted;\n }\n else {\n // we don't cache that\n return _asFormatted(this, true);\n }\n }\n toJSON() {\n const res = {\n $mid: 1 /* MarshalledId.Uri */\n };\n // cached state\n if (this._fsPath) {\n res.fsPath = this._fsPath;\n res._sep = _pathSepMarker;\n }\n if (this._formatted) {\n res.external = this._formatted;\n }\n // uri components\n if (this.path) {\n res.path = this.path;\n }\n if (this.scheme) {\n res.scheme = this.scheme;\n }\n if (this.authority) {\n res.authority = this.authority;\n }\n if (this.query) {\n res.query = this.query;\n }\n if (this.fragment) {\n res.fragment = this.fragment;\n }\n return res;\n }\n}\n// reserved characters: https://tools.ietf.org/html/rfc3986#section-2.2\nconst encodeTable = {\n [58 /* CharCode.Colon */]: '%3A',\n [47 /* CharCode.Slash */]: '%2F',\n [63 /* CharCode.QuestionMark */]: '%3F',\n [35 /* CharCode.Hash */]: '%23',\n [91 /* CharCode.OpenSquareBracket */]: '%5B',\n [93 /* CharCode.CloseSquareBracket */]: '%5D',\n [64 /* CharCode.AtSign */]: '%40',\n [33 /* CharCode.ExclamationMark */]: '%21',\n [36 /* CharCode.DollarSign */]: '%24',\n [38 /* CharCode.Ampersand */]: '%26',\n [39 /* CharCode.SingleQuote */]: '%27',\n [40 /* CharCode.OpenParen */]: '%28',\n [41 /* CharCode.CloseParen */]: '%29',\n [42 /* CharCode.Asterisk */]: '%2A',\n [43 /* CharCode.Plus */]: '%2B',\n [44 /* CharCode.Comma */]: '%2C',\n [59 /* CharCode.Semicolon */]: '%3B',\n [61 /* CharCode.Equals */]: '%3D',\n [32 /* CharCode.Space */]: '%20',\n};\nfunction encodeURIComponentFast(uriComponent, allowSlash) {\n let res = undefined;\n let nativeEncodePos = -1;\n for (let pos = 0; pos < uriComponent.length; pos++) {\n const code = uriComponent.charCodeAt(pos);\n // unreserved characters: https://tools.ietf.org/html/rfc3986#section-2.3\n if ((code >= 97 /* CharCode.a */ && code <= 122 /* CharCode.z */)\n || (code >= 65 /* CharCode.A */ && code <= 90 /* CharCode.Z */)\n || (code >= 48 /* CharCode.Digit0 */ && code <= 57 /* CharCode.Digit9 */)\n || code === 45 /* CharCode.Dash */\n || code === 46 /* CharCode.Period */\n || code === 95 /* CharCode.Underline */\n || code === 126 /* CharCode.Tilde */\n || (allowSlash && code === 47 /* CharCode.Slash */)) {\n // check if we are delaying native encode\n if (nativeEncodePos !== -1) {\n res += encodeURIComponent(uriComponent.substring(nativeEncodePos, pos));\n nativeEncodePos = -1;\n }\n // check if we write into a new string (by default we try to return the param)\n if (res !== undefined) {\n res += uriComponent.charAt(pos);\n }\n }\n else {\n // encoding needed, we need to allocate a new string\n if (res === undefined) {\n res = uriComponent.substr(0, pos);\n }\n // check with default table first\n const escaped = encodeTable[code];\n if (escaped !== undefined) {\n // check if we are delaying native encode\n if (nativeEncodePos !== -1) {\n res += encodeURIComponent(uriComponent.substring(nativeEncodePos, pos));\n nativeEncodePos = -1;\n }\n // append escaped variant to result\n res += escaped;\n }\n else if (nativeEncodePos === -1) {\n // use native encode only when needed\n nativeEncodePos = pos;\n }\n }\n }\n if (nativeEncodePos !== -1) {\n res += encodeURIComponent(uriComponent.substring(nativeEncodePos));\n }\n return res !== undefined ? res : uriComponent;\n}\nfunction encodeURIComponentMinimal(path) {\n let res = undefined;\n for (let pos = 0; pos < path.length; pos++) {\n const code = path.charCodeAt(pos);\n if (code === 35 /* CharCode.Hash */ || code === 63 /* CharCode.QuestionMark */) {\n if (res === undefined) {\n res = path.substr(0, pos);\n }\n res += encodeTable[code];\n }\n else {\n if (res !== undefined) {\n res += path[pos];\n }\n }\n }\n return res !== undefined ? res : path;\n}\n/**\n * Compute `fsPath` for the given uri\n */\nexport function uriToFsPath(uri, keepDriveLetterCasing) {\n let value;\n if (uri.authority && uri.path.length > 1 && uri.scheme === 'file') {\n // unc path: file://shares/c$/far/boo\n value = `//${uri.authority}${uri.path}`;\n }\n else if (uri.path.charCodeAt(0) === 47 /* CharCode.Slash */\n && (uri.path.charCodeAt(1) >= 65 /* CharCode.A */ && uri.path.charCodeAt(1) <= 90 /* CharCode.Z */ || uri.path.charCodeAt(1) >= 97 /* CharCode.a */ && uri.path.charCodeAt(1) <= 122 /* CharCode.z */)\n && uri.path.charCodeAt(2) === 58 /* CharCode.Colon */) {\n if (!keepDriveLetterCasing) {\n // windows drive letter: file:///c:/far/boo\n value = uri.path[1].toLowerCase() + uri.path.substr(2);\n }\n else {\n value = uri.path.substr(1);\n }\n }\n else {\n // other path\n value = uri.path;\n }\n if (isWindows) {\n value = value.replace(/\\//g, '\\\\');\n }\n return value;\n}\n/**\n * Create the external version of a uri\n */\nfunction _asFormatted(uri, skipEncoding) {\n const encoder = !skipEncoding\n ? encodeURIComponentFast\n : encodeURIComponentMinimal;\n let res = '';\n let { scheme, authority, path, query, fragment } = uri;\n if (scheme) {\n res += scheme;\n res += ':';\n }\n if (authority || scheme === 'file') {\n res += _slash;\n res += _slash;\n }\n if (authority) {\n let idx = authority.indexOf('@');\n if (idx !== -1) {\n // <user>@<auth>\n const userinfo = authority.substr(0, idx);\n authority = authority.substr(idx + 1);\n idx = userinfo.indexOf(':');\n if (idx === -1) {\n res += encoder(userinfo, false);\n }\n else {\n // <user>:<pass>@<auth>\n res += encoder(userinfo.substr(0, idx), false);\n res += ':';\n res += encoder(userinfo.substr(idx + 1), false);\n }\n res += '@';\n }\n authority = authority.toLowerCase();\n idx = authority.indexOf(':');\n if (idx === -1) {\n res += encoder(authority, false);\n }\n else {\n // <auth>:<port>\n res += encoder(authority.substr(0, idx), false);\n res += authority.substr(idx);\n }\n }\n if (path) {\n // lower-case windows drive letters in /C:/fff or C:/fff\n if (path.length >= 3 && path.charCodeAt(0) === 47 /* CharCode.Slash */ && path.charCodeAt(2) === 58 /* CharCode.Colon */) {\n const code = path.charCodeAt(1);\n if (code >= 65 /* CharCode.A */ && code <= 90 /* CharCode.Z */) {\n path = `/${String.fromCharCode(code + 32)}:${path.substr(3)}`; // \"/c:\".length === 3\n }\n }\n else if (path.length >= 2 && path.charCodeAt(1) === 58 /* CharCode.Colon */) {\n const code = path.charCodeAt(0);\n if (code >= 65 /* CharCode.A */ && code <= 90 /* CharCode.Z */) {\n path = `${String.fromCharCode(code + 32)}:${path.substr(2)}`; // \"/c:\".length === 3\n }\n }\n // encode the rest of the path\n res += encoder(path, true);\n }\n if (query) {\n res += '?';\n res += encoder(query, false);\n }\n if (fragment) {\n res += '#';\n res += !skipEncoding ? encodeURIComponentFast(fragment, false) : fragment;\n }\n return res;\n}\n// --- decode\nfunction decodeURIComponentGraceful(str) {\n try {\n return decodeURIComponent(str);\n }\n catch (_a) {\n if (str.length > 3) {\n return str.substr(0, 3) + decodeURIComponentGraceful(str.substr(3));\n }\n else {\n return str;\n }\n }\n}\nconst _rEncodedAsHex = /(%[0-9A-Za-z][0-9A-Za-z])+/g;\nfunction percentDecode(str) {\n if (!str.match(_rEncodedAsHex)) {\n return str;\n }\n return str.replace(_rEncodedAsHex, (match) => decodeURIComponentGraceful(match));\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n/**\n * A position in the editor.\n */\nexport class Position {\n constructor(lineNumber, column) {\n this.lineNumber = lineNumber;\n this.column = column;\n }\n /**\n * Create a new position from this position.\n *\n * @param newLineNumber new line number\n * @param newColumn new column\n */\n with(newLineNumber = this.lineNumber, newColumn = this.column) {\n if (newLineNumber === this.lineNumber && newColumn === this.column) {\n return this;\n }\n else {\n return new Position(newLineNumber, newColumn);\n }\n }\n /**\n * Derive a new position from this position.\n *\n * @param deltaLineNumber line number delta\n * @param deltaColumn column delta\n */\n delta(deltaLineNumber = 0, deltaColumn = 0) {\n return this.with(this.lineNumber + deltaLineNumber, this.column + deltaColumn);\n }\n /**\n * Test if this position equals other position\n */\n equals(other) {\n return Position.equals(this, other);\n }\n /**\n * Test if position `a` equals position `b`\n */\n static equals(a, b) {\n if (!a && !b) {\n return true;\n }\n return (!!a &&\n !!b &&\n a.lineNumber === b.lineNumber &&\n a.column === b.column);\n }\n /**\n * Test if this position is before other position.\n * If the two positions are equal, the result will be false.\n */\n isBefore(other) {\n return Position.isBefore(this, other);\n }\n /**\n * Test if position `a` is before position `b`.\n * If the two positions are equal, the result will be false.\n */\n static isBefore(a, b) {\n if (a.lineNumber < b.lineNumber) {\n return true;\n }\n if (b.lineNumber < a.lineNumber) {\n return false;\n }\n return a.column < b.column;\n }\n /**\n * Test if this position is before other position.\n * If the two positions are equal, the result will be true.\n */\n isBeforeOrEqual(other) {\n return Position.isBeforeOrEqual(this, other);\n }\n /**\n * Test if position `a` is before position `b`.\n * If the two positions are equal, the result will be true.\n */\n static isBeforeOrEqual(a, b) {\n if (a.lineNumber < b.lineNumber) {\n return true;\n }\n if (b.lineNumber < a.lineNumber) {\n return false;\n }\n return a.column <= b.column;\n }\n /**\n * A function that compares positions, useful for sorting\n */\n static compare(a, b) {\n const aLineNumber = a.lineNumber | 0;\n const bLineNumber = b.lineNumber | 0;\n if (aLineNumber === bLineNumber) {\n const aColumn = a.column | 0;\n const bColumn = b.column | 0;\n return aColumn - bColumn;\n }\n return aLineNumber - bLineNumber;\n }\n /**\n * Clone this position.\n */\n clone() {\n return new Position(this.lineNumber, this.column);\n }\n /**\n * Convert to a human-readable representation.\n */\n toString() {\n return '(' + this.lineNumber + ',' + this.column + ')';\n }\n // ---\n /**\n * Create a `Position` from an `IPosition`.\n */\n static lift(pos) {\n return new Position(pos.lineNumber, pos.column);\n }\n /**\n * Test if `obj` is an `IPosition`.\n */\n static isIPosition(obj) {\n return (obj\n && (typeof obj.lineNumber === 'number')\n && (typeof obj.column === 'number'));\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { Position } from './position.js';\n/**\n * A range in the editor. (startLineNumber,startColumn) is <= (endLineNumber,endColumn)\n */\nexport class Range {\n constructor(startLineNumber, startColumn, endLineNumber, endColumn) {\n if ((startLineNumber > endLineNumber) || (startLineNumber === endLineNumber && startColumn > endColumn)) {\n this.startLineNumber = endLineNumber;\n this.startColumn = endColumn;\n this.endLineNumber = startLineNumber;\n this.endColumn = startColumn;\n }\n else {\n this.startLineNumber = startLineNumber;\n this.startColumn = startColumn;\n this.endLineNumber = endLineNumber;\n this.endColumn = endColumn;\n }\n }\n /**\n * Test if this range is empty.\n */\n isEmpty() {\n return Range.isEmpty(this);\n }\n /**\n * Test if `range` is empty.\n */\n static isEmpty(range) {\n return (range.startLineNumber === range.endLineNumber && range.startColumn === range.endColumn);\n }\n /**\n * Test if position is in this range. If the position is at the edges, will return true.\n */\n containsPosition(position) {\n return Range.containsPosition(this, position);\n }\n /**\n * Test if `position` is in `range`. If the position is at the edges, will return true.\n */\n static containsPosition(range, position) {\n if (position.lineNumber < range.startLineNumber || position.lineNumber > range.endLineNumber) {\n return false;\n }\n if (position.lineNumber === range.startLineNumber && position.column < range.startColumn) {\n return false;\n }\n if (position.lineNumber === range.endLineNumber && position.column > range.endColumn) {\n return false;\n }\n return true;\n }\n /**\n * Test if `position` is in `range`. If the position is at the edges, will return false.\n * @internal\n */\n static strictContainsPosition(range, position) {\n if (position.lineNumber < range.startLineNumber || position.lineNumber > range.endLineNumber) {\n return false;\n }\n if (position.lineNumber === range.startLineNumber && position.column <= range.startColumn) {\n return false;\n }\n if (position.lineNumber === range.endLineNumber && position.column >= range.endColumn) {\n return false;\n }\n return true;\n }\n /**\n * Test if range is in this range. If the range is equal to this range, will return true.\n */\n containsRange(range) {\n return Range.containsRange(this, range);\n }\n /**\n * Test if `otherRange` is in `range`. If the ranges are equal, will return true.\n */\n static containsRange(range, otherRange) {\n if (otherRange.startLineNumber < range.startLineNumber || otherRange.endLineNumber < range.startLineNumber) {\n return false;\n }\n if (otherRange.startLineNumber > range.endLineNumber || otherRange.endLineNumber > range.endLineNumber) {\n return false;\n }\n if (otherRange.startLineNumber === range.startLineNumber && otherRange.startColumn < range.startColumn) {\n return false;\n }\n if (otherRange.endLineNumber === range.endLineNumber && otherRange.endColumn > range.endColumn) {\n return false;\n }\n return true;\n }\n /**\n * Test if `range` is strictly in this range. `range` must start after and end before this range for the result to be true.\n */\n strictContainsRange(range) {\n return Range.strictContainsRange(this, range);\n }\n /**\n * Test if `otherRange` is strictly in `range` (must start after, and end before). If the ranges are equal, will return false.\n */\n static strictContainsRange(range, otherRange) {\n if (otherRange.startLineNumber < range.startLineNumber || otherRange.endLineNumber < range.startLineNumber) {\n return false;\n }\n if (otherRange.startLineNumber > range.endLineNumber || otherRange.endLineNumber > range.endLineNumber) {\n return false;\n }\n if (otherRange.startLineNumber === range.startLineNumber && otherRange.startColumn <= range.startColumn) {\n return false;\n }\n if (otherRange.endLineNumber === range.endLineNumber && otherRange.endColumn >= range.endColumn) {\n return false;\n }\n return true;\n }\n /**\n * A reunion of the two ranges.\n * The smallest position will be used as the start point, and the largest one as the end point.\n */\n plusRange(range) {\n return Range.plusRange(this, range);\n }\n /**\n * A reunion of the two ranges.\n * The smallest position will be used as the start point, and the largest one as the end point.\n */\n static plusRange(a, b) {\n let startLineNumber;\n let startColumn;\n let endLineNumber;\n let endColumn;\n if (b.startLineNumber < a.startLineNumber) {\n startLineNumber = b.startLineNumber;\n startColumn = b.startColumn;\n }\n else if (b.startLineNumber === a.startLineNumber) {\n startLineNumber = b.startLineNumber;\n startColumn = Math.min(b.startColumn, a.startColumn);\n }\n else {\n startLineNumber = a.startLineNumber;\n startColumn = a.startColumn;\n }\n if (b.endLineNumber > a.endLineNumber) {\n endLineNumber = b.endLineNumber;\n endColumn = b.endColumn;\n }\n else if (b.endLineNumber === a.endLineNumber) {\n endLineNumber = b.endLineNumber;\n endColumn = Math.max(b.endColumn, a.endColumn);\n }\n else {\n endLineNumber = a.endLineNumber;\n endColumn = a.endColumn;\n }\n return new Range(startLineNumber, startColumn, endLineNumber, endColumn);\n }\n /**\n * A intersection of the two ranges.\n */\n intersectRanges(range) {\n return Range.intersectRanges(this, range);\n }\n /**\n * A intersection of the two ranges.\n */\n static intersectRanges(a, b) {\n let resultStartLineNumber = a.startLineNumber;\n let resultStartColumn = a.startColumn;\n let resultEndLineNumber = a.endLineNumber;\n let resultEndColumn = a.endColumn;\n const otherStartLineNumber = b.startLineNumber;\n const otherStartColumn = b.startColumn;\n const otherEndLineNumber = b.endLineNumber;\n const otherEndColumn = b.endColumn;\n if (resultStartLineNumber < otherStartLineNumber) {\n resultStartLineNumber = otherStartLineNumber;\n resultStartColumn = otherStartColumn;\n }\n else if (resultStartLineNumber === otherStartLineNumber) {\n resultStartColumn = Math.max(resultStartColumn, otherStartColumn);\n }\n if (resultEndLineNumber > otherEndLineNumber) {\n resultEndLineNumber = otherEndLineNumber;\n resultEndColumn = otherEndColumn;\n }\n else if (resultEndLineNumber === otherEndLineNumber) {\n resultEndColumn = Math.min(resultEndColumn, otherEndColumn);\n }\n // Check if selection is now empty\n if (resultStartLineNumber > resultEndLineNumber) {\n return null;\n }\n if (resultStartLineNumber === resultEndLineNumber && resultStartColumn > resultEndColumn) {\n return null;\n }\n return new Range(resultStartLineNumber, resultStartColumn, resultEndLineNumber, resultEndColumn);\n }\n /**\n * Test if this range equals other.\n */\n equalsRange(other) {\n return Range.equalsRange(this, other);\n }\n /**\n * Test if range `a` equals `b`.\n */\n static equalsRange(a, b) {\n return (!!a &&\n !!b &&\n a.startLineNumber === b.startLineNumber &&\n a.startColumn === b.startColumn &&\n a.endLineNumber === b.endLineNumber &&\n a.endColumn === b.endColumn);\n }\n /**\n * Return the end position (which will be after or equal to the start position)\n */\n getEndPosition() {\n return Range.getEndPosition(this);\n }\n /**\n * Return the end position (which will be after or equal to the start position)\n */\n static getEndPosition(range) {\n return new Position(range.endLineNumber, range.endColumn);\n }\n /**\n * Return the start position (which will be before or equal to the end position)\n */\n getStartPosition() {\n return Range.getStartPosition(this);\n }\n /**\n * Return the start position (which will be before or equal to the end position)\n */\n static getStartPosition(range) {\n return new Position(range.startLineNumber, range.startColumn);\n }\n /**\n * Transform to a user presentable string representation.\n */\n toString() {\n return '[' + this.startLineNumber + ',' + this.startColumn + ' -> ' + this.endLineNumber + ',' + this.endColumn + ']';\n }\n /**\n * Create a new range using this range's start position, and using endLineNumber and endColumn as the end position.\n */\n setEndPosition(endLineNumber, endColumn) {\n return new Range(this.startLineNumber, this.startColumn, endLineNumber, endColumn);\n }\n /**\n * Create a new range using this range's end position, and using startLineNumber and startColumn as the start position.\n */\n setStartPosition(startLineNumber, startColumn) {\n return new Range(startLineNumber, startColumn, this.endLineNumber, this.endColumn);\n }\n /**\n * Create a new empty range using this range's start position.\n */\n collapseToStart() {\n return Range.collapseToStart(this);\n }\n /**\n * Create a new empty range using this range's start position.\n */\n static collapseToStart(range) {\n return new Range(range.startLineNumber, range.startColumn, range.startLineNumber, range.startColumn);\n }\n // ---\n static fromPositions(start, end = start) {\n return new Range(start.lineNumber, start.column, end.lineNumber, end.column);\n }\n static lift(range) {\n if (!range) {\n return null;\n }\n return new Range(range.startLineNumber, range.startColumn, range.endLineNumber, range.endColumn);\n }\n /**\n * Test if `obj` is an `IRange`.\n */\n static isIRange(obj) {\n return (obj\n && (typeof obj.startLineNumber === 'number')\n && (typeof obj.startColumn === 'number')\n && (typeof obj.endLineNumber === 'number')\n && (typeof obj.endColumn === 'number'));\n }\n /**\n * Test if the two ranges are touching in any way.\n */\n static areIntersectingOrTouching(a, b) {\n // Check if `a` is before `b`\n if (a.endLineNumber < b.startLineNumber || (a.endLineNumber === b.startLineNumber && a.endColumn < b.startColumn)) {\n return false;\n }\n // Check if `b` is before `a`\n if (b.endLineNumber < a.startLineNumber || (b.endLineNumber === a.startLineNumber && b.endColumn < a.startColumn)) {\n return false;\n }\n // These ranges must intersect\n return true;\n }\n /**\n * Test if the two ranges are intersecting. If the ranges are touching it returns true.\n */\n static areIntersecting(a, b) {\n // Check if `a` is before `b`\n if (a.endLineNumber < b.startLineNumber || (a.endLineNumber === b.startLineNumber && a.endColumn <= b.startColumn)) {\n return false;\n }\n // Check if `b` is before `a`\n if (b.endLineNumber < a.startLineNumber || (b.endLineNumber === a.startLineNumber && b.endColumn <= a.startColumn)) {\n return false;\n }\n // These ranges must intersect\n return true;\n }\n /**\n * A function that compares ranges, useful for sorting ranges\n * It will first compare ranges on the startPosition and then on the endPosition\n */\n static compareRangesUsingStarts(a, b) {\n if (a && b) {\n const aStartLineNumber = a.startLineNumber | 0;\n const bStartLineNumber = b.startLineNumber | 0;\n if (aStartLineNumber === bStartLineNumber) {\n const aStartColumn = a.startColumn | 0;\n const bStartColumn = b.startColumn | 0;\n if (aStartColumn === bStartColumn) {\n const aEndLineNumber = a.endLineNumber | 0;\n const bEndLineNumber = b.endLineNumber | 0;\n if (aEndLineNumber === bEndLineNumber) {\n const aEndColumn = a.endColumn | 0;\n const bEndColumn = b.endColumn | 0;\n return aEndColumn - bEndColumn;\n }\n return aEndLineNumber - bEndLineNumber;\n }\n return aStartColumn - bStartColumn;\n }\n return aStartLineNumber - bStartLineNumber;\n }\n const aExists = (a ? 1 : 0);\n const bExists = (b ? 1 : 0);\n return aExists - bExists;\n }\n /**\n * A function that compares ranges, useful for sorting ranges\n * It will first compare ranges on the endPosition and then on the startPosition\n */\n static compareRangesUsingEnds(a, b) {\n if (a.endLineNumber === b.endLineNumber) {\n if (a.endColumn === b.endColumn) {\n if (a.startLineNumber === b.startLineNumber) {\n return a.startColumn - b.startColumn;\n }\n return a.startLineNumber - b.startLineNumber;\n }\n return a.endColumn - b.endColumn;\n }\n return a.endLineNumber - b.endLineNumber;\n }\n /**\n * Test if the range spans multiple lines.\n */\n static spansMultipleLines(range) {\n return range.endLineNumber > range.startLineNumber;\n }\n toJSON() {\n return this;\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { LcsDiff } from '../../../base/common/diff/diff.js';\nimport * as strings from '../../../base/common/strings.js';\nconst MINIMUM_MATCHING_CHARACTER_LENGTH = 3;\nfunction computeDiff(originalSequence, modifiedSequence, continueProcessingPredicate, pretty) {\n const diffAlgo = new LcsDiff(originalSequence, modifiedSequence, continueProcessingPredicate);\n return diffAlgo.ComputeDiff(pretty);\n}\nclass LineSequence {\n constructor(lines) {\n const startColumns = [];\n const endColumns = [];\n for (let i = 0, length = lines.length; i < length; i++) {\n startColumns[i] = getFirstNonBlankColumn(lines[i], 1);\n endColumns[i] = getLastNonBlankColumn(lines[i], 1);\n }\n this.lines = lines;\n this._startColumns = startColumns;\n this._endColumns = endColumns;\n }\n getElements() {\n const elements = [];\n for (let i = 0, len = this.lines.length; i < len; i++) {\n elements[i] = this.lines[i].substring(this._startColumns[i] - 1, this._endColumns[i] - 1);\n }\n return elements;\n }\n getStrictElement(index) {\n return this.lines[index];\n }\n getStartLineNumber(i) {\n return i + 1;\n }\n getEndLineNumber(i) {\n return i + 1;\n }\n createCharSequence(shouldIgnoreTrimWhitespace, startIndex, endIndex) {\n const charCodes = [];\n const lineNumbers = [];\n const columns = [];\n let len = 0;\n for (let index = startIndex; index <= endIndex; index++) {\n const lineContent = this.lines[index];\n const startColumn = (shouldIgnoreTrimWhitespace ? this._startColumns[index] : 1);\n const endColumn = (shouldIgnoreTrimWhitespace ? this._endColumns[index] : lineContent.length + 1);\n for (let col = startColumn; col < endColumn; col++) {\n charCodes[len] = lineContent.charCodeAt(col - 1);\n lineNumbers[len] = index + 1;\n columns[len] = col;\n len++;\n }\n if (!shouldIgnoreTrimWhitespace && index < endIndex) {\n // Add \\n if trim whitespace is not ignored\n charCodes[len] = 10 /* CharCode.LineFeed */;\n lineNumbers[len] = index + 1;\n columns[len] = lineContent.length + 1;\n len++;\n }\n }\n return new CharSequence(charCodes, lineNumbers, columns);\n }\n}\nclass CharSequence {\n constructor(charCodes, lineNumbers, columns) {\n this._charCodes = charCodes;\n this._lineNumbers = lineNumbers;\n this._columns = columns;\n }\n toString() {\n return ('[' + this._charCodes.map((s, idx) => (s === 10 /* CharCode.LineFeed */ ? '\\\\n' : String.fromCharCode(s)) + `-(${this._lineNumbers[idx]},${this._columns[idx]})`).join(', ') + ']');\n }\n _assertIndex(index, arr) {\n if (index < 0 || index >= arr.length) {\n throw new Error(`Illegal index`);\n }\n }\n getElements() {\n return this._charCodes;\n }\n getStartLineNumber(i) {\n if (i > 0 && i === this._lineNumbers.length) {\n // the start line number of the element after the last element\n // is the end line number of the last element\n return this.getEndLineNumber(i - 1);\n }\n this._assertIndex(i, this._lineNumbers);\n return this._lineNumbers[i];\n }\n getEndLineNumber(i) {\n if (i === -1) {\n // the end line number of the element before the first element\n // is the start line number of the first element\n return this.getStartLineNumber(i + 1);\n }\n this._assertIndex(i, this._lineNumbers);\n if (this._charCodes[i] === 10 /* CharCode.LineFeed */) {\n return this._lineNumbers[i] + 1;\n }\n return this._lineNumbers[i];\n }\n getStartColumn(i) {\n if (i > 0 && i === this._columns.length) {\n // the start column of the element after the last element\n // is the end column of the last element\n return this.getEndColumn(i - 1);\n }\n this._assertIndex(i, this._columns);\n return this._columns[i];\n }\n getEndColumn(i) {\n if (i === -1) {\n // the end column of the element before the first element\n // is the start column of the first element\n return this.getStartColumn(i + 1);\n }\n this._assertIndex(i, this._columns);\n if (this._charCodes[i] === 10 /* CharCode.LineFeed */) {\n return 1;\n }\n return this._columns[i] + 1;\n }\n}\nclass CharChange {\n constructor(originalStartLineNumber, originalStartColumn, originalEndLineNumber, originalEndColumn, modifiedStartLineNumber, modifiedStartColumn, modifiedEndLineNumber, modifiedEndColumn) {\n this.originalStartLineNumber = originalStartLineNumber;\n this.originalStartColumn = originalStartColumn;\n this.originalEndLineNumber = originalEndLineNumber;\n this.originalEndColumn = originalEndColumn;\n this.modifiedStartLineNumber = modifiedStartLineNumber;\n this.modifiedStartColumn = modifiedStartColumn;\n this.modifiedEndLineNumber = modifiedEndLineNumber;\n this.modifiedEndColumn = modifiedEndColumn;\n }\n static createFromDiffChange(diffChange, originalCharSequence, modifiedCharSequence) {\n const originalStartLineNumber = originalCharSequence.getStartLineNumber(diffChange.originalStart);\n const originalStartColumn = originalCharSequence.getStartColumn(diffChange.originalStart);\n const originalEndLineNumber = originalCharSequence.getEndLineNumber(diffChange.originalStart + diffChange.originalLength - 1);\n const originalEndColumn = originalCharSequence.getEndColumn(diffChange.originalStart + diffChange.originalLength - 1);\n const modifiedStartLineNumber = modifiedCharSequence.getStartLineNumber(diffChange.modifiedStart);\n const modifiedStartColumn = modifiedCharSequence.getStartColumn(diffChange.modifiedStart);\n const modifiedEndLineNumber = modifiedCharSequence.getEndLineNumber(diffChange.modifiedStart + diffChange.modifiedLength - 1);\n const modifiedEndColumn = modifiedCharSequence.getEndColumn(diffChange.modifiedStart + diffChange.modifiedLength - 1);\n return new CharChange(originalStartLineNumber, originalStartColumn, originalEndLineNumber, originalEndColumn, modifiedStartLineNumber, modifiedStartColumn, modifiedEndLineNumber, modifiedEndColumn);\n }\n}\nfunction postProcessCharChanges(rawChanges) {\n if (rawChanges.length <= 1) {\n return rawChanges;\n }\n const result = [rawChanges[0]];\n let prevChange = result[0];\n for (let i = 1, len = rawChanges.length; i < len; i++) {\n const currChange = rawChanges[i];\n const originalMatchingLength = currChange.originalStart - (prevChange.originalStart + prevChange.originalLength);\n const modifiedMatchingLength = currChange.modifiedStart - (prevChange.modifiedStart + prevChange.modifiedLength);\n // Both of the above should be equal, but the continueProcessingPredicate may prevent this from being true\n const matchingLength = Math.min(originalMatchingLength, modifiedMatchingLength);\n if (matchingLength < MINIMUM_MATCHING_CHARACTER_LENGTH) {\n // Merge the current change into the previous one\n prevChange.originalLength = (currChange.originalStart + currChange.originalLength) - prevChange.originalStart;\n prevChange.modifiedLength = (currChange.modifiedStart + currChange.modifiedLength) - prevChange.modifiedStart;\n }\n else {\n // Add the current change\n result.push(currChange);\n prevChange = currChange;\n }\n }\n return result;\n}\nclass LineChange {\n constructor(originalStartLineNumber, originalEndLineNumber, modifiedStartLineNumber, modifiedEndLineNumber, charChanges) {\n this.originalStartLineNumber = originalStartLineNumber;\n this.originalEndLineNumber = originalEndLineNumber;\n this.modifiedStartLineNumber = modifiedStartLineNumber;\n this.modifiedEndLineNumber = modifiedEndLineNumber;\n this.charChanges = charChanges;\n }\n static createFromDiffResult(shouldIgnoreTrimWhitespace, diffChange, originalLineSequence, modifiedLineSequence, continueCharDiff, shouldComputeCharChanges, shouldPostProcessCharChanges) {\n let originalStartLineNumber;\n let originalEndLineNumber;\n let modifiedStartLineNumber;\n let modifiedEndLineNumber;\n let charChanges = undefined;\n if (diffChange.originalLength === 0) {\n originalStartLineNumber = originalLineSequence.getStartLineNumber(diffChange.originalStart) - 1;\n originalEndLineNumber = 0;\n }\n else {\n originalStartLineNumber = originalLineSequence.getStartLineNumber(diffChange.originalStart);\n originalEndLineNumber = originalLineSequence.getEndLineNumber(diffChange.originalStart + diffChange.originalLength - 1);\n }\n if (diffChange.modifiedLength === 0) {\n modifiedStartLineNumber = modifiedLineSequence.getStartLineNumber(diffChange.modifiedStart) - 1;\n modifiedEndLineNumber = 0;\n }\n else {\n modifiedStartLineNumber = modifiedLineSequence.getStartLineNumber(diffChange.modifiedStart);\n modifiedEndLineNumber = modifiedLineSequence.getEndLineNumber(diffChange.modifiedStart + diffChange.modifiedLength - 1);\n }\n if (shouldComputeCharChanges && diffChange.originalLength > 0 && diffChange.originalLength < 20 && diffChange.modifiedLength > 0 && diffChange.modifiedLength < 20 && continueCharDiff()) {\n // Compute character changes for diff chunks of at most 20 lines...\n const originalCharSequence = originalLineSequence.createCharSequence(shouldIgnoreTrimWhitespace, diffChange.originalStart, diffChange.originalStart + diffChange.originalLength - 1);\n const modifiedCharSequence = modifiedLineSequence.createCharSequence(shouldIgnoreTrimWhitespace, diffChange.modifiedStart, diffChange.modifiedStart + diffChange.modifiedLength - 1);\n if (originalCharSequence.getElements().length > 0 && modifiedCharSequence.getElements().length > 0) {\n let rawChanges = computeDiff(originalCharSequence, modifiedCharSequence, continueCharDiff, true).changes;\n if (shouldPostProcessCharChanges) {\n rawChanges = postProcessCharChanges(rawChanges);\n }\n charChanges = [];\n for (let i = 0, length = rawChanges.length; i < length; i++) {\n charChanges.push(CharChange.createFromDiffChange(rawChanges[i], originalCharSequence, modifiedCharSequence));\n }\n }\n }\n return new LineChange(originalStartLineNumber, originalEndLineNumber, modifiedStartLineNumber, modifiedEndLineNumber, charChanges);\n }\n}\nexport class DiffComputer {\n constructor(originalLines, modifiedLines, opts) {\n this.shouldComputeCharChanges = opts.shouldComputeCharChanges;\n this.shouldPostProcessCharChanges = opts.shouldPostProcessCharChanges;\n this.shouldIgnoreTrimWhitespace = opts.shouldIgnoreTrimWhitespace;\n this.shouldMakePrettyDiff = opts.shouldMakePrettyDiff;\n this.originalLines = originalLines;\n this.modifiedLines = modifiedLines;\n this.original = new LineSequence(originalLines);\n this.modified = new LineSequence(modifiedLines);\n this.continueLineDiff = createContinueProcessingPredicate(opts.maxComputationTime);\n this.continueCharDiff = createContinueProcessingPredicate(opts.maxComputationTime === 0 ? 0 : Math.min(opts.maxComputationTime, 5000)); // never run after 5s for character changes...\n }\n computeDiff() {\n if (this.original.lines.length === 1 && this.original.lines[0].length === 0) {\n // empty original => fast path\n if (this.modified.lines.length === 1 && this.modified.lines[0].length === 0) {\n return {\n quitEarly: false,\n changes: []\n };\n }\n return {\n quitEarly: false,\n changes: [{\n originalStartLineNumber: 1,\n originalEndLineNumber: 1,\n modifiedStartLineNumber: 1,\n modifiedEndLineNumber: this.modified.lines.length,\n charChanges: [{\n modifiedEndColumn: 0,\n modifiedEndLineNumber: 0,\n modifiedStartColumn: 0,\n modifiedStartLineNumber: 0,\n originalEndColumn: 0,\n originalEndLineNumber: 0,\n originalStartColumn: 0,\n originalStartLineNumber: 0\n }]\n }]\n };\n }\n if (this.modified.lines.length === 1 && this.modified.lines[0].length === 0) {\n // empty modified => fast path\n return {\n quitEarly: false,\n changes: [{\n originalStartLineNumber: 1,\n originalEndLineNumber: this.original.lines.length,\n modifiedStartLineNumber: 1,\n modifiedEndLineNumber: 1,\n charChanges: [{\n modifiedEndColumn: 0,\n modifiedEndLineNumber: 0,\n modifiedStartColumn: 0,\n modifiedStartLineNumber: 0,\n originalEndColumn: 0,\n originalEndLineNumber: 0,\n originalStartColumn: 0,\n originalStartLineNumber: 0\n }]\n }]\n };\n }\n const diffResult = computeDiff(this.original, this.modified, this.continueLineDiff, this.shouldMakePrettyDiff);\n const rawChanges = diffResult.changes;\n const quitEarly = diffResult.quitEarly;\n // The diff is always computed with ignoring trim whitespace\n // This ensures we get the prettiest diff\n if (this.shouldIgnoreTrimWhitespace) {\n const lineChanges = [];\n for (let i = 0, length = rawChanges.length; i < length; i++) {\n lineChanges.push(LineChange.createFromDiffResult(this.shouldIgnoreTrimWhitespace, rawChanges[i], this.original, this.modified, this.continueCharDiff, this.shouldComputeCharChanges, this.shouldPostProcessCharChanges));\n }\n return {\n quitEarly: quitEarly,\n changes: lineChanges\n };\n }\n // Need to post-process and introduce changes where the trim whitespace is different\n // Note that we are looping starting at -1 to also cover the lines before the first change\n const result = [];\n let originalLineIndex = 0;\n let modifiedLineIndex = 0;\n for (let i = -1 /* !!!! */, len = rawChanges.length; i < len; i++) {\n const nextChange = (i + 1 < len ? rawChanges[i + 1] : null);\n const originalStop = (nextChange ? nextChange.originalStart : this.originalLines.length);\n const modifiedStop = (nextChange ? nextChange.modifiedStart : this.modifiedLines.length);\n while (originalLineIndex < originalStop && modifiedLineIndex < modifiedStop) {\n const originalLine = this.originalLines[originalLineIndex];\n const modifiedLine = this.modifiedLines[modifiedLineIndex];\n if (originalLine !== modifiedLine) {\n // These lines differ only in trim whitespace\n // Check the leading whitespace\n {\n let originalStartColumn = getFirstNonBlankColumn(originalLine, 1);\n let modifiedStartColumn = getFirstNonBlankColumn(modifiedLine, 1);\n while (originalStartColumn > 1 && modifiedStartColumn > 1) {\n const originalChar = originalLine.charCodeAt(originalStartColumn - 2);\n const modifiedChar = modifiedLine.charCodeAt(modifiedStartColumn - 2);\n if (originalChar !== modifiedChar) {\n break;\n }\n originalStartColumn--;\n modifiedStartColumn--;\n }\n if (originalStartColumn > 1 || modifiedStartColumn > 1) {\n this._pushTrimWhitespaceCharChange(result, originalLineIndex + 1, 1, originalStartColumn, modifiedLineIndex + 1, 1, modifiedStartColumn);\n }\n }\n // Check the trailing whitespace\n {\n let originalEndColumn = getLastNonBlankColumn(originalLine, 1);\n let modifiedEndColumn = getLastNonBlankColumn(modifiedLine, 1);\n const originalMaxColumn = originalLine.length + 1;\n const modifiedMaxColumn = modifiedLine.length + 1;\n while (originalEndColumn < originalMaxColumn && modifiedEndColumn < modifiedMaxColumn) {\n const originalChar = originalLine.charCodeAt(originalEndColumn - 1);\n const modifiedChar = originalLine.charCodeAt(modifiedEndColumn - 1);\n if (originalChar !== modifiedChar) {\n break;\n }\n originalEndColumn++;\n modifiedEndColumn++;\n }\n if (originalEndColumn < originalMaxColumn || modifiedEndColumn < modifiedMaxColumn) {\n this._pushTrimWhitespaceCharChange(result, originalLineIndex + 1, originalEndColumn, originalMaxColumn, modifiedLineIndex + 1, modifiedEndColumn, modifiedMaxColumn);\n }\n }\n }\n originalLineIndex++;\n modifiedLineIndex++;\n }\n if (nextChange) {\n // Emit the actual change\n result.push(LineChange.createFromDiffResult(this.shouldIgnoreTrimWhitespace, nextChange, this.original, this.modified, this.continueCharDiff, this.shouldComputeCharChanges, this.shouldPostProcessCharChanges));\n originalLineIndex += nextChange.originalLength;\n modifiedLineIndex += nextChange.modifiedLength;\n }\n }\n return {\n quitEarly: quitEarly,\n changes: result\n };\n }\n _pushTrimWhitespaceCharChange(result, originalLineNumber, originalStartColumn, originalEndColumn, modifiedLineNumber, modifiedStartColumn, modifiedEndColumn) {\n if (this._mergeTrimWhitespaceCharChange(result, originalLineNumber, originalStartColumn, originalEndColumn, modifiedLineNumber, modifiedStartColumn, modifiedEndColumn)) {\n // Merged into previous\n return;\n }\n let charChanges = undefined;\n if (this.shouldComputeCharChanges) {\n charChanges = [new CharChange(originalLineNumber, originalStartColumn, originalLineNumber, originalEndColumn, modifiedLineNumber, modifiedStartColumn, modifiedLineNumber, modifiedEndColumn)];\n }\n result.push(new LineChange(originalLineNumber, originalLineNumber, modifiedLineNumber, modifiedLineNumber, charChanges));\n }\n _mergeTrimWhitespaceCharChange(result, originalLineNumber, originalStartColumn, originalEndColumn, modifiedLineNumber, modifiedStartColumn, modifiedEndColumn) {\n const len = result.length;\n if (len === 0) {\n return false;\n }\n const prevChange = result[len - 1];\n if (prevChange.originalEndLineNumber === 0 || prevChange.modifiedEndLineNumber === 0) {\n // Don't merge with inserts/deletes\n return false;\n }\n if (prevChange.originalEndLineNumber + 1 === originalLineNumber && prevChange.modifiedEndLineNumber + 1 === modifiedLineNumber) {\n prevChange.originalEndLineNumber = originalLineNumber;\n prevChange.modifiedEndLineNumber = modifiedLineNumber;\n if (this.shouldComputeCharChanges && prevChange.charChanges) {\n prevChange.charChanges.push(new CharChange(originalLineNumber, originalStartColumn, originalLineNumber, originalEndColumn, modifiedLineNumber, modifiedStartColumn, modifiedLineNumber, modifiedEndColumn));\n }\n return true;\n }\n return false;\n }\n}\nfunction getFirstNonBlankColumn(txt, defaultValue) {\n const r = strings.firstNonWhitespaceIndex(txt);\n if (r === -1) {\n return defaultValue;\n }\n return r + 1;\n}\nfunction getLastNonBlankColumn(txt, defaultValue) {\n const r = strings.lastNonWhitespaceIndex(txt);\n if (r === -1) {\n return defaultValue;\n }\n return r + 2;\n}\nfunction createContinueProcessingPredicate(maximumRuntime) {\n if (maximumRuntime === 0) {\n return () => true;\n }\n const startTime = Date.now();\n return () => {\n return Date.now() - startTime < maximumRuntime;\n };\n}\n","/**\n * Returns the last element of an array.\n * @param array The array.\n * @param n Which element from the end (default is zero).\n */\nexport function tail(array, n = 0) {\n return array[array.length - (1 + n)];\n}\nexport function tail2(arr) {\n if (arr.length === 0) {\n throw new Error('Invalid tail call');\n }\n return [arr.slice(0, arr.length - 1), arr[arr.length - 1]];\n}\nexport function equals(one, other, itemEquals = (a, b) => a === b) {\n if (one === other) {\n return true;\n }\n if (!one || !other) {\n return false;\n }\n if (one.length !== other.length) {\n return false;\n }\n for (let i = 0, len = one.length; i < len; i++) {\n if (!itemEquals(one[i], other[i])) {\n return false;\n }\n }\n return true;\n}\n/**\n * Remove the element at `index` by replacing it with the last element. This is faster than `splice`\n * but changes the order of the array\n */\nexport function removeFastWithoutKeepingOrder(array, index) {\n const last = array.length - 1;\n if (index < last) {\n array[index] = array[last];\n }\n array.pop();\n}\n/**\n * Performs a binary search algorithm over a sorted array.\n *\n * @param array The array being searched.\n * @param key The value we search for.\n * @param comparator A function that takes two array elements and returns zero\n * if they are equal, a negative number if the first element precedes the\n * second one in the sorting order, or a positive number if the second element\n * precedes the first one.\n * @return See {@link binarySearch2}\n */\nexport function binarySearch(array, key, comparator) {\n return binarySearch2(array.length, i => comparator(array[i], key));\n}\n/**\n * Performs a binary search algorithm over a sorted collection. Useful for cases\n * when we need to perform a binary search over something that isn't actually an\n * array, and converting data to an array would defeat the use of binary search\n * in the first place.\n *\n * @param length The collection length.\n * @param compareToKey A function that takes an index of an element in the\n * collection and returns zero if the value at this index is equal to the\n * search key, a negative number if the value precedes the search key in the\n * sorting order, or a positive number if the search key precedes the value.\n * @return A non-negative index of an element, if found. If not found, the\n * result is -(n+1) (or ~n, using bitwise notation), where n is the index\n * where the key should be inserted to maintain the sorting order.\n */\nexport function binarySearch2(length, compareToKey) {\n let low = 0, high = length - 1;\n while (low <= high) {\n const mid = ((low + high) / 2) | 0;\n const comp = compareToKey(mid);\n if (comp < 0) {\n low = mid + 1;\n }\n else if (comp > 0) {\n high = mid - 1;\n }\n else {\n return mid;\n }\n }\n return -(low + 1);\n}\n/**\n * Takes a sorted array and a function p. The array is sorted in such a way that all elements where p(x) is false\n * are located before all elements where p(x) is true.\n * @returns the least x for which p(x) is true or array.length if no element fullfills the given function.\n */\nexport function findFirstInSorted(array, p) {\n let low = 0, high = array.length;\n if (high === 0) {\n return 0; // no children\n }\n while (low < high) {\n const mid = Math.floor((low + high) / 2);\n if (p(array[mid])) {\n high = mid;\n }\n else {\n low = mid + 1;\n }\n }\n return low;\n}\nexport function quickSelect(nth, data, compare) {\n nth = nth | 0;\n if (nth >= data.length) {\n throw new TypeError('invalid index');\n }\n const pivotValue = data[Math.floor(data.length * Math.random())];\n const lower = [];\n const higher = [];\n const pivots = [];\n for (const value of data) {\n const val = compare(value, pivotValue);\n if (val < 0) {\n lower.push(value);\n }\n else if (val > 0) {\n higher.push(value);\n }\n else {\n pivots.push(value);\n }\n }\n if (nth < lower.length) {\n return quickSelect(nth, lower, compare);\n }\n else if (nth < lower.length + pivots.length) {\n return pivots[0];\n }\n else {\n return quickSelect(nth - (lower.length + pivots.length), higher, compare);\n }\n}\nexport function groupBy(data, compare) {\n const result = [];\n let currentGroup = undefined;\n for (const element of data.slice(0).sort(compare)) {\n if (!currentGroup || compare(currentGroup[0], element) !== 0) {\n currentGroup = [element];\n result.push(currentGroup);\n }\n else {\n currentGroup.push(element);\n }\n }\n return result;\n}\n/**\n * @returns New array with all falsy values removed. The original array IS NOT modified.\n */\nexport function coalesce(array) {\n return array.filter(e => !!e);\n}\n/**\n * @returns false if the provided object is an array and not empty.\n */\nexport function isFalsyOrEmpty(obj) {\n return !Array.isArray(obj) || obj.length === 0;\n}\nexport function isNonEmptyArray(obj) {\n return Array.isArray(obj) && obj.length > 0;\n}\n/**\n * Removes duplicates from the given array. The optional keyFn allows to specify\n * how elements are checked for equality by returning an alternate value for each.\n */\nexport function distinct(array, keyFn = value => value) {\n const seen = new Set();\n return array.filter(element => {\n const key = keyFn(element);\n if (seen.has(key)) {\n return false;\n }\n seen.add(key);\n return true;\n });\n}\nexport function findLast(arr, predicate) {\n const idx = lastIndex(arr, predicate);\n if (idx === -1) {\n return undefined;\n }\n return arr[idx];\n}\nexport function lastIndex(array, fn) {\n for (let i = array.length - 1; i >= 0; i--) {\n const element = array[i];\n if (fn(element)) {\n return i;\n }\n }\n return -1;\n}\nexport function firstOrDefault(array, notFoundValue) {\n return array.length > 0 ? array[0] : notFoundValue;\n}\nexport function range(arg, to) {\n let from = typeof to === 'number' ? arg : 0;\n if (typeof to === 'number') {\n from = arg;\n }\n else {\n from = 0;\n to = arg;\n }\n const result = [];\n if (from <= to) {\n for (let i = from; i < to; i++) {\n result.push(i);\n }\n }\n else {\n for (let i = from; i > to; i--) {\n result.push(i);\n }\n }\n return result;\n}\n/**\n * Insert `insertArr` inside `target` at `insertIndex`.\n * Please don't touch unless you understand https://jsperf.com/inserting-an-array-within-an-array\n */\nexport function arrayInsert(target, insertIndex, insertArr) {\n const before = target.slice(0, insertIndex);\n const after = target.slice(insertIndex);\n return before.concat(insertArr, after);\n}\n/**\n * Pushes an element to the start of the array, if found.\n */\nexport function pushToStart(arr, value) {\n const index = arr.indexOf(value);\n if (index > -1) {\n arr.splice(index, 1);\n arr.unshift(value);\n }\n}\n/**\n * Pushes an element to the end of the array, if found.\n */\nexport function pushToEnd(arr, value) {\n const index = arr.indexOf(value);\n if (index > -1) {\n arr.splice(index, 1);\n arr.push(value);\n }\n}\nexport function pushMany(arr, items) {\n for (const item of items) {\n arr.push(item);\n }\n}\nexport function asArray(x) {\n return Array.isArray(x) ? x : [x];\n}\n/**\n * Insert the new items in the array.\n * @param array The original array.\n * @param start The zero-based location in the array from which to start inserting elements.\n * @param newItems The items to be inserted\n */\nexport function insertInto(array, start, newItems) {\n const startIdx = getActualStartIndex(array, start);\n const originalLength = array.length;\n const newItemsLength = newItems.length;\n array.length = originalLength + newItemsLength;\n // Move the items after the start index, start from the end so that we don't overwrite any value.\n for (let i = originalLength - 1; i >= startIdx; i--) {\n array[i + newItemsLength] = array[i];\n }\n for (let i = 0; i < newItemsLength; i++) {\n array[i + startIdx] = newItems[i];\n }\n}\n/**\n * Removes elements from an array and inserts new elements in their place, returning the deleted elements. Alternative to the native Array.splice method, it\n * can only support limited number of items due to the maximum call stack size limit.\n * @param array The original array.\n * @param start The zero-based location in the array from which to start removing elements.\n * @param deleteCount The number of elements to remove.\n * @returns An array containing the elements that were deleted.\n */\nexport function splice(array, start, deleteCount, newItems) {\n const index = getActualStartIndex(array, start);\n const result = array.splice(index, deleteCount);\n insertInto(array, index, newItems);\n return result;\n}\n/**\n * Determine the actual start index (same logic as the native splice() or slice())\n * If greater than the length of the array, start will be set to the length of the array. In this case, no element will be deleted but the method will behave as an adding function, adding as many element as item[n*] provided.\n * If negative, it will begin that many elements from the end of the array. (In this case, the origin -1, meaning -n is the index of the nth last element, and is therefore equivalent to the index of array.length - n.) If array.length + start is less than 0, it will begin from index 0.\n * @param array The target array.\n * @param start The operation index.\n */\nfunction getActualStartIndex(array, start) {\n return start < 0 ? Math.max(start + array.length, 0) : Math.min(start, array.length);\n}\nexport var CompareResult;\n(function (CompareResult) {\n function isLessThan(result) {\n return result < 0;\n }\n CompareResult.isLessThan = isLessThan;\n function isGreaterThan(result) {\n return result > 0;\n }\n CompareResult.isGreaterThan = isGreaterThan;\n function isNeitherLessOrGreaterThan(result) {\n return result === 0;\n }\n CompareResult.isNeitherLessOrGreaterThan = isNeitherLessOrGreaterThan;\n CompareResult.greaterThan = 1;\n CompareResult.lessThan = -1;\n CompareResult.neitherLessOrGreaterThan = 0;\n})(CompareResult || (CompareResult = {}));\nexport function compareBy(selector, comparator) {\n return (a, b) => comparator(selector(a), selector(b));\n}\n/**\n * The natural order on numbers.\n*/\nexport const numberComparator = (a, b) => a - b;\n/**\n * Returns the first item that is equal to or greater than every other item.\n*/\nexport function findMaxBy(items, comparator) {\n if (items.length === 0) {\n return undefined;\n }\n let max = items[0];\n for (let i = 1; i < items.length; i++) {\n const item = items[i];\n if (comparator(item, max) > 0) {\n max = item;\n }\n }\n return max;\n}\n/**\n * Returns the last item that is equal to or greater than every other item.\n*/\nexport function findLastMaxBy(items, comparator) {\n if (items.length === 0) {\n return undefined;\n }\n let max = items[0];\n for (let i = 1; i < items.length; i++) {\n const item = items[i];\n if (comparator(item, max) >= 0) {\n max = item;\n }\n }\n return max;\n}\n/**\n * Returns the first item that is equal to or less than every other item.\n*/\nexport function findMinBy(items, comparator) {\n return findMaxBy(items, (a, b) => -comparator(a, b));\n}\nexport class ArrayQueue {\n /**\n * Constructs a queue that is backed by the given array. Runtime is O(1).\n */\n constructor(items) {\n this.items = items;\n this.firstIdx = 0;\n this.lastIdx = this.items.length - 1;\n }\n get length() {\n return this.lastIdx - this.firstIdx + 1;\n }\n /**\n * Consumes elements from the beginning of the queue as long as the predicate returns true.\n * If no elements were consumed, `null` is returned. Has a runtime of O(result.length).\n */\n takeWhile(predicate) {\n // P(k) := k <= this.lastIdx && predicate(this.items[k])\n // Find s := min { k | k >= this.firstIdx && !P(k) } and return this.data[this.firstIdx...s)\n let startIdx = this.firstIdx;\n while (startIdx < this.items.length && predicate(this.items[startIdx])) {\n startIdx++;\n }\n const result = startIdx === this.firstIdx ? null : this.items.slice(this.firstIdx, startIdx);\n this.firstIdx = startIdx;\n return result;\n }\n /**\n * Consumes elements from the end of the queue as long as the predicate returns true.\n * If no elements were consumed, `null` is returned.\n * The result has the same order as the underlying array!\n */\n takeFromEndWhile(predicate) {\n // P(k) := this.firstIdx >= k && predicate(this.items[k])\n // Find s := max { k | k <= this.lastIdx && !P(k) } and return this.data(s...this.lastIdx]\n let endIdx = this.lastIdx;\n while (endIdx >= 0 && predicate(this.items[endIdx])) {\n endIdx--;\n }\n const result = endIdx === this.lastIdx ? null : this.items.slice(endIdx + 1, this.lastIdx + 1);\n this.lastIdx = endIdx;\n return result;\n }\n peek() {\n if (this.length === 0) {\n return undefined;\n }\n return this.items[this.firstIdx];\n }\n dequeue() {\n const result = this.items[this.firstIdx];\n this.firstIdx++;\n return result;\n }\n takeCount(count) {\n const result = this.items.slice(this.firstIdx, this.firstIdx + count);\n this.firstIdx += count;\n return result;\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nexport function toUint8(v) {\n if (v < 0) {\n return 0;\n }\n if (v > 255 /* Constants.MAX_UINT_8 */) {\n return 255 /* Constants.MAX_UINT_8 */;\n }\n return v | 0;\n}\nexport function toUint32(v) {\n if (v < 0) {\n return 0;\n }\n if (v > 4294967295 /* Constants.MAX_UINT_32 */) {\n return 4294967295 /* Constants.MAX_UINT_32 */;\n }\n return v | 0;\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { arrayInsert } from '../../../base/common/arrays.js';\nimport { toUint32 } from '../../../base/common/uint.js';\nexport class PrefixSumComputer {\n constructor(values) {\n this.values = values;\n this.prefixSum = new Uint32Array(values.length);\n this.prefixSumValidIndex = new Int32Array(1);\n this.prefixSumValidIndex[0] = -1;\n }\n insertValues(insertIndex, insertValues) {\n insertIndex = toUint32(insertIndex);\n const oldValues = this.values;\n const oldPrefixSum = this.prefixSum;\n const insertValuesLen = insertValues.length;\n if (insertValuesLen === 0) {\n return false;\n }\n this.values = new Uint32Array(oldValues.length + insertValuesLen);\n this.values.set(oldValues.subarray(0, insertIndex), 0);\n this.values.set(oldValues.subarray(insertIndex), insertIndex + insertValuesLen);\n this.values.set(insertValues, insertIndex);\n if (insertIndex - 1 < this.prefixSumValidIndex[0]) {\n this.prefixSumValidIndex[0] = insertIndex - 1;\n }\n this.prefixSum = new Uint32Array(this.values.length);\n if (this.prefixSumValidIndex[0] >= 0) {\n this.prefixSum.set(oldPrefixSum.subarray(0, this.prefixSumValidIndex[0] + 1));\n }\n return true;\n }\n setValue(index, value) {\n index = toUint32(index);\n value = toUint32(value);\n if (this.values[index] === value) {\n return false;\n }\n this.values[index] = value;\n if (index - 1 < this.prefixSumValidIndex[0]) {\n this.prefixSumValidIndex[0] = index - 1;\n }\n return true;\n }\n removeValues(startIndex, count) {\n startIndex = toUint32(startIndex);\n count = toUint32(count);\n const oldValues = this.values;\n const oldPrefixSum = this.prefixSum;\n if (startIndex >= oldValues.length) {\n return false;\n }\n const maxCount = oldValues.length - startIndex;\n if (count >= maxCount) {\n count = maxCount;\n }\n if (count === 0) {\n return false;\n }\n this.values = new Uint32Array(oldValues.length - count);\n this.values.set(oldValues.subarray(0, startIndex), 0);\n this.values.set(oldValues.subarray(startIndex + count), startIndex);\n this.prefixSum = new Uint32Array(this.values.length);\n if (startIndex - 1 < this.prefixSumValidIndex[0]) {\n this.prefixSumValidIndex[0] = startIndex - 1;\n }\n if (this.prefixSumValidIndex[0] >= 0) {\n this.prefixSum.set(oldPrefixSum.subarray(0, this.prefixSumValidIndex[0] + 1));\n }\n return true;\n }\n getTotalSum() {\n if (this.values.length === 0) {\n return 0;\n }\n return this._getPrefixSum(this.values.length - 1);\n }\n /**\n * Returns the sum of the first `index + 1` many items.\n * @returns `SUM(0 <= j <= index, values[j])`.\n */\n getPrefixSum(index) {\n if (index < 0) {\n return 0;\n }\n index = toUint32(index);\n return this._getPrefixSum(index);\n }\n _getPrefixSum(index) {\n if (index <= this.prefixSumValidIndex[0]) {\n return this.prefixSum[index];\n }\n let startIndex = this.prefixSumValidIndex[0] + 1;\n if (startIndex === 0) {\n this.prefixSum[0] = this.values[0];\n startIndex++;\n }\n if (index >= this.values.length) {\n index = this.values.length - 1;\n }\n for (let i = startIndex; i <= index; i++) {\n this.prefixSum[i] = this.prefixSum[i - 1] + this.values[i];\n }\n this.prefixSumValidIndex[0] = Math.max(this.prefixSumValidIndex[0], index);\n return this.prefixSum[index];\n }\n getIndexOf(sum) {\n sum = Math.floor(sum);\n // Compute all sums (to get a fully valid prefixSum)\n this.getTotalSum();\n let low = 0;\n let high = this.values.length - 1;\n let mid = 0;\n let midStop = 0;\n let midStart = 0;\n while (low <= high) {\n mid = low + ((high - low) / 2) | 0;\n midStop = this.prefixSum[mid];\n midStart = midStop - this.values[mid];\n if (sum < midStart) {\n high = mid - 1;\n }\n else if (sum >= midStop) {\n low = mid + 1;\n }\n else {\n break;\n }\n }\n return new PrefixSumIndexOfResult(mid, sum - midStart);\n }\n}\n/**\n * {@link getIndexOf} has an amortized runtime complexity of O(1).\n *\n * ({@link PrefixSumComputer.getIndexOf} is just O(log n))\n*/\nexport class ConstantTimePrefixSumComputer {\n constructor(values) {\n this._values = values;\n this._isValid = false;\n this._validEndIndex = -1;\n this._prefixSum = [];\n this._indexBySum = [];\n }\n /**\n * @returns SUM(0 <= j < values.length, values[j])\n */\n getTotalSum() {\n this._ensureValid();\n return this._indexBySum.length;\n }\n /**\n * Returns the sum of the first `count` many items.\n * @returns `SUM(0 <= j < count, values[j])`.\n */\n getPrefixSum(count) {\n this._ensureValid();\n if (count === 0) {\n return 0;\n }\n return this._prefixSum[count - 1];\n }\n /**\n * @returns `result`, such that `getPrefixSum(result.index) + result.remainder = sum`\n */\n getIndexOf(sum) {\n this._ensureValid();\n const idx = this._indexBySum[sum];\n const viewLinesAbove = idx > 0 ? this._prefixSum[idx - 1] : 0;\n return new PrefixSumIndexOfResult(idx, sum - viewLinesAbove);\n }\n removeValues(start, deleteCount) {\n this._values.splice(start, deleteCount);\n this._invalidate(start);\n }\n insertValues(insertIndex, insertArr) {\n this._values = arrayInsert(this._values, insertIndex, insertArr);\n this._invalidate(insertIndex);\n }\n _invalidate(index) {\n this._isValid = false;\n this._validEndIndex = Math.min(this._validEndIndex, index - 1);\n }\n _ensureValid() {\n if (this._isValid) {\n return;\n }\n for (let i = this._validEndIndex + 1, len = this._values.length; i < len; i++) {\n const value = this._values[i];\n const sumAbove = i > 0 ? this._prefixSum[i - 1] : 0;\n this._prefixSum[i] = sumAbove + value;\n for (let j = 0; j < value; j++) {\n this._indexBySum[sumAbove + j] = i;\n }\n }\n // trim things\n this._prefixSum.length = this._values.length;\n this._indexBySum.length = this._prefixSum[this._prefixSum.length - 1];\n // mark as valid\n this._isValid = true;\n this._validEndIndex = this._values.length - 1;\n }\n setValue(index, value) {\n if (this._values[index] === value) {\n // no change\n return;\n }\n this._values[index] = value;\n this._invalidate(index);\n }\n}\nexport class PrefixSumIndexOfResult {\n constructor(index, remainder) {\n this.index = index;\n this.remainder = remainder;\n this._prefixSumIndexOfResultBrand = undefined;\n this.index = index;\n this.remainder = remainder;\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { Iterable } from '../../../base/common/iterator.js';\nimport { LinkedList } from '../../../base/common/linkedList.js';\nexport const USUAL_WORD_SEPARATORS = '`~!@#$%^&*()-=+[{]}\\\\|;:\\'\",.<>/?';\n/**\n * Create a word definition regular expression based on default word separators.\n * Optionally provide allowed separators that should be included in words.\n *\n * The default would look like this:\n * /(-?\\d*\\.\\d\\w*)|([^\\`\\~\\!\\@\\#\\$\\%\\^\\&\\*\\(\\)\\-\\=\\+\\[\\{\\]\\}\\\\\\|\\;\\:\\'\\\"\\,\\.\\<\\>\\/\\?\\s]+)/g\n */\nfunction createWordRegExp(allowInWords = '') {\n let source = '(-?\\\\d*\\\\.\\\\d\\\\w*)|([^';\n for (const sep of USUAL_WORD_SEPARATORS) {\n if (allowInWords.indexOf(sep) >= 0) {\n continue;\n }\n source += '\\\\' + sep;\n }\n source += '\\\\s]+)';\n return new RegExp(source, 'g');\n}\n// catches numbers (including floating numbers) in the first group, and alphanum in the second\nexport const DEFAULT_WORD_REGEXP = createWordRegExp();\nexport function ensureValidWordDefinition(wordDefinition) {\n let result = DEFAULT_WORD_REGEXP;\n if (wordDefinition && (wordDefinition instanceof RegExp)) {\n if (!wordDefinition.global) {\n let flags = 'g';\n if (wordDefinition.ignoreCase) {\n flags += 'i';\n }\n if (wordDefinition.multiline) {\n flags += 'm';\n }\n if (wordDefinition.unicode) {\n flags += 'u';\n }\n result = new RegExp(wordDefinition.source, flags);\n }\n else {\n result = wordDefinition;\n }\n }\n result.lastIndex = 0;\n return result;\n}\nconst _defaultConfig = new LinkedList();\n_defaultConfig.unshift({\n maxLen: 1000,\n windowSize: 15,\n timeBudget: 150\n});\nexport function getWordAtText(column, wordDefinition, text, textOffset, config) {\n if (!config) {\n config = Iterable.first(_defaultConfig);\n }\n if (text.length > config.maxLen) {\n // don't throw strings that long at the regexp\n // but use a sub-string in which a word must occur\n let start = column - config.maxLen / 2;\n if (start < 0) {\n start = 0;\n }\n else {\n textOffset += start;\n }\n text = text.substring(start, column + config.maxLen / 2);\n return getWordAtText(column, wordDefinition, text, textOffset, config);\n }\n const t1 = Date.now();\n const pos = column - 1 - textOffset;\n let prevRegexIndex = -1;\n let match = null;\n for (let i = 1;; i++) {\n // check time budget\n if (Date.now() - t1 >= config.timeBudget) {\n break;\n }\n // reset the index at which the regexp should start matching, also know where it\n // should stop so that subsequent search don't repeat previous searches\n const regexIndex = pos - config.windowSize * i;\n wordDefinition.lastIndex = Math.max(0, regexIndex);\n const thisMatch = _findRegexMatchEnclosingPosition(wordDefinition, text, pos, prevRegexIndex);\n if (!thisMatch && match) {\n // stop: we have something\n break;\n }\n match = thisMatch;\n // stop: searched at start\n if (regexIndex <= 0) {\n break;\n }\n prevRegexIndex = regexIndex;\n }\n if (match) {\n const result = {\n word: match[0],\n startColumn: textOffset + 1 + match.index,\n endColumn: textOffset + 1 + match.index + match[0].length\n };\n wordDefinition.lastIndex = 0;\n return result;\n }\n return null;\n}\nfunction _findRegexMatchEnclosingPosition(wordDefinition, text, pos, stopPos) {\n let match;\n while (match = wordDefinition.exec(text)) {\n const matchIndex = match.index || 0;\n if (matchIndex <= pos && wordDefinition.lastIndex >= pos) {\n return match;\n }\n else if (stopPos > 0 && matchIndex > stopPos) {\n return null;\n }\n }\n return null;\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { toUint8 } from '../../../base/common/uint.js';\n/**\n * A fast character classifier that uses a compact array for ASCII values.\n */\nexport class CharacterClassifier {\n constructor(_defaultValue) {\n const defaultValue = toUint8(_defaultValue);\n this._defaultValue = defaultValue;\n this._asciiMap = CharacterClassifier._createAsciiMap(defaultValue);\n this._map = new Map();\n }\n static _createAsciiMap(defaultValue) {\n const asciiMap = new Uint8Array(256);\n for (let i = 0; i < 256; i++) {\n asciiMap[i] = defaultValue;\n }\n return asciiMap;\n }\n set(charCode, _value) {\n const value = toUint8(_value);\n if (charCode >= 0 && charCode < 256) {\n this._asciiMap[charCode] = value;\n }\n else {\n this._map.set(charCode, value);\n }\n }\n get(charCode) {\n if (charCode >= 0 && charCode < 256) {\n return this._asciiMap[charCode];\n }\n else {\n return (this._map.get(charCode) || this._defaultValue);\n }\n }\n}\nexport class CharacterSet {\n constructor() {\n this._actual = new CharacterClassifier(0 /* Boolean.False */);\n }\n add(charCode) {\n this._actual.set(charCode, 1 /* Boolean.True */);\n }\n has(charCode) {\n return (this._actual.get(charCode) === 1 /* Boolean.True */);\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { CharacterClassifier } from '../core/characterClassifier.js';\nexport class Uint8Matrix {\n constructor(rows, cols, defaultValue) {\n const data = new Uint8Array(rows * cols);\n for (let i = 0, len = rows * cols; i < len; i++) {\n data[i] = defaultValue;\n }\n this._data = data;\n this.rows = rows;\n this.cols = cols;\n }\n get(row, col) {\n return this._data[row * this.cols + col];\n }\n set(row, col, value) {\n this._data[row * this.cols + col] = value;\n }\n}\nexport class StateMachine {\n constructor(edges) {\n let maxCharCode = 0;\n let maxState = 0 /* State.Invalid */;\n for (let i = 0, len = edges.length; i < len; i++) {\n const [from, chCode, to] = edges[i];\n if (chCode > maxCharCode) {\n maxCharCode = chCode;\n }\n if (from > maxState) {\n maxState = from;\n }\n if (to > maxState) {\n maxState = to;\n }\n }\n maxCharCode++;\n maxState++;\n const states = new Uint8Matrix(maxState, maxCharCode, 0 /* State.Invalid */);\n for (let i = 0, len = edges.length; i < len; i++) {\n const [from, chCode, to] = edges[i];\n states.set(from, chCode, to);\n }\n this._states = states;\n this._maxCharCode = maxCharCode;\n }\n nextState(currentState, chCode) {\n if (chCode < 0 || chCode >= this._maxCharCode) {\n return 0 /* State.Invalid */;\n }\n return this._states.get(currentState, chCode);\n }\n}\n// State machine for http:// or https:// or file://\nlet _stateMachine = null;\nfunction getStateMachine() {\n if (_stateMachine === null) {\n _stateMachine = new StateMachine([\n [1 /* State.Start */, 104 /* CharCode.h */, 2 /* State.H */],\n [1 /* State.Start */, 72 /* CharCode.H */, 2 /* State.H */],\n [1 /* State.Start */, 102 /* CharCode.f */, 6 /* State.F */],\n [1 /* State.Start */, 70 /* CharCode.F */, 6 /* State.F */],\n [2 /* State.H */, 116 /* CharCode.t */, 3 /* State.HT */],\n [2 /* State.H */, 84 /* CharCode.T */, 3 /* State.HT */],\n [3 /* State.HT */, 116 /* CharCode.t */, 4 /* State.HTT */],\n [3 /* State.HT */, 84 /* CharCode.T */, 4 /* State.HTT */],\n [4 /* State.HTT */, 112 /* CharCode.p */, 5 /* State.HTTP */],\n [4 /* State.HTT */, 80 /* CharCode.P */, 5 /* State.HTTP */],\n [5 /* State.HTTP */, 115 /* CharCode.s */, 9 /* State.BeforeColon */],\n [5 /* State.HTTP */, 83 /* CharCode.S */, 9 /* State.BeforeColon */],\n [5 /* State.HTTP */, 58 /* CharCode.Colon */, 10 /* State.AfterColon */],\n [6 /* State.F */, 105 /* CharCode.i */, 7 /* State.FI */],\n [6 /* State.F */, 73 /* CharCode.I */, 7 /* State.FI */],\n [7 /* State.FI */, 108 /* CharCode.l */, 8 /* State.FIL */],\n [7 /* State.FI */, 76 /* CharCode.L */, 8 /* State.FIL */],\n [8 /* State.FIL */, 101 /* CharCode.e */, 9 /* State.BeforeColon */],\n [8 /* State.FIL */, 69 /* CharCode.E */, 9 /* State.BeforeColon */],\n [9 /* State.BeforeColon */, 58 /* CharCode.Colon */, 10 /* State.AfterColon */],\n [10 /* State.AfterColon */, 47 /* CharCode.Slash */, 11 /* State.AlmostThere */],\n [11 /* State.AlmostThere */, 47 /* CharCode.Slash */, 12 /* State.End */],\n ]);\n }\n return _stateMachine;\n}\nlet _classifier = null;\nfunction getClassifier() {\n if (_classifier === null) {\n _classifier = new CharacterClassifier(0 /* CharacterClass.None */);\n // allow-any-unicode-next-line\n const FORCE_TERMINATION_CHARACTERS = ' \\t<>\\'\\\"、。。、,.:;‘〈「『〔([{「」}])〕』」〉’`~…';\n for (let i = 0; i < FORCE_TERMINATION_CHARACTERS.length; i++) {\n _classifier.set(FORCE_TERMINATION_CHARACTERS.charCodeAt(i), 1 /* CharacterClass.ForceTermination */);\n }\n const CANNOT_END_WITH_CHARACTERS = '.,;:';\n for (let i = 0; i < CANNOT_END_WITH_CHARACTERS.length; i++) {\n _classifier.set(CANNOT_END_WITH_CHARACTERS.charCodeAt(i), 2 /* CharacterClass.CannotEndIn */);\n }\n }\n return _classifier;\n}\nexport class LinkComputer {\n static _createLink(classifier, line, lineNumber, linkBeginIndex, linkEndIndex) {\n // Do not allow to end link in certain characters...\n let lastIncludedCharIndex = linkEndIndex - 1;\n do {\n const chCode = line.charCodeAt(lastIncludedCharIndex);\n const chClass = classifier.get(chCode);\n if (chClass !== 2 /* CharacterClass.CannotEndIn */) {\n break;\n }\n lastIncludedCharIndex--;\n } while (lastIncludedCharIndex > linkBeginIndex);\n // Handle links enclosed in parens, square brackets and curlys.\n if (linkBeginIndex > 0) {\n const charCodeBeforeLink = line.charCodeAt(linkBeginIndex - 1);\n const lastCharCodeInLink = line.charCodeAt(lastIncludedCharIndex);\n if ((charCodeBeforeLink === 40 /* CharCode.OpenParen */ && lastCharCodeInLink === 41 /* CharCode.CloseParen */)\n || (charCodeBeforeLink === 91 /* CharCode.OpenSquareBracket */ && lastCharCodeInLink === 93 /* CharCode.CloseSquareBracket */)\n || (charCodeBeforeLink === 123 /* CharCode.OpenCurlyBrace */ && lastCharCodeInLink === 125 /* CharCode.CloseCurlyBrace */)) {\n // Do not end in ) if ( is before the link start\n // Do not end in ] if [ is before the link start\n // Do not end in } if { is before the link start\n lastIncludedCharIndex--;\n }\n }\n return {\n range: {\n startLineNumber: lineNumber,\n startColumn: linkBeginIndex + 1,\n endLineNumber: lineNumber,\n endColumn: lastIncludedCharIndex + 2\n },\n url: line.substring(linkBeginIndex, lastIncludedCharIndex + 1)\n };\n }\n static computeLinks(model, stateMachine = getStateMachine()) {\n const classifier = getClassifier();\n const result = [];\n for (let i = 1, lineCount = model.getLineCount(); i <= lineCount; i++) {\n const line = model.getLineContent(i);\n const len = line.length;\n let j = 0;\n let linkBeginIndex = 0;\n let linkBeginChCode = 0;\n let state = 1 /* State.Start */;\n let hasOpenParens = false;\n let hasOpenSquareBracket = false;\n let inSquareBrackets = false;\n let hasOpenCurlyBracket = false;\n while (j < len) {\n let resetStateMachine = false;\n const chCode = line.charCodeAt(j);\n if (state === 13 /* State.Accept */) {\n let chClass;\n switch (chCode) {\n case 40 /* CharCode.OpenParen */:\n hasOpenParens = true;\n chClass = 0 /* CharacterClass.None */;\n break;\n case 41 /* CharCode.CloseParen */:\n chClass = (hasOpenParens ? 0 /* CharacterClass.None */ : 1 /* CharacterClass.ForceTermination */);\n break;\n case 91 /* CharCode.OpenSquareBracket */:\n inSquareBrackets = true;\n hasOpenSquareBracket = true;\n chClass = 0 /* CharacterClass.None */;\n break;\n case 93 /* CharCode.CloseSquareBracket */:\n inSquareBrackets = false;\n chClass = (hasOpenSquareBracket ? 0 /* CharacterClass.None */ : 1 /* CharacterClass.ForceTermination */);\n break;\n case 123 /* CharCode.OpenCurlyBrace */:\n hasOpenCurlyBracket = true;\n chClass = 0 /* CharacterClass.None */;\n break;\n case 125 /* CharCode.CloseCurlyBrace */:\n chClass = (hasOpenCurlyBracket ? 0 /* CharacterClass.None */ : 1 /* CharacterClass.ForceTermination */);\n break;\n /* The following three rules make it that ' or \" or ` are allowed inside links if the link didn't begin with them */\n case 39 /* CharCode.SingleQuote */:\n chClass = (linkBeginChCode === 39 /* CharCode.SingleQuote */ ? 1 /* CharacterClass.ForceTermination */ : 0 /* CharacterClass.None */);\n break;\n case 34 /* CharCode.DoubleQuote */:\n chClass = (linkBeginChCode === 34 /* CharCode.DoubleQuote */ ? 1 /* CharacterClass.ForceTermination */ : 0 /* CharacterClass.None */);\n break;\n case 96 /* CharCode.BackTick */:\n chClass = (linkBeginChCode === 96 /* CharCode.BackTick */ ? 1 /* CharacterClass.ForceTermination */ : 0 /* CharacterClass.None */);\n break;\n case 42 /* CharCode.Asterisk */:\n // `*` terminates a link if the link began with `*`\n chClass = (linkBeginChCode === 42 /* CharCode.Asterisk */) ? 1 /* CharacterClass.ForceTermination */ : 0 /* CharacterClass.None */;\n break;\n case 124 /* CharCode.Pipe */:\n // `|` terminates a link if the link began with `|`\n chClass = (linkBeginChCode === 124 /* CharCode.Pipe */) ? 1 /* CharacterClass.ForceTermination */ : 0 /* CharacterClass.None */;\n break;\n case 32 /* CharCode.Space */:\n // ` ` allow space in between [ and ]\n chClass = (inSquareBrackets ? 0 /* CharacterClass.None */ : 1 /* CharacterClass.ForceTermination */);\n break;\n default:\n chClass = classifier.get(chCode);\n }\n // Check if character terminates link\n if (chClass === 1 /* CharacterClass.ForceTermination */) {\n result.push(LinkComputer._createLink(classifier, line, i, linkBeginIndex, j));\n resetStateMachine = true;\n }\n }\n else if (state === 12 /* State.End */) {\n let chClass;\n if (chCode === 91 /* CharCode.OpenSquareBracket */) {\n // Allow for the authority part to contain ipv6 addresses which contain [ and ]\n hasOpenSquareBracket = true;\n chClass = 0 /* CharacterClass.None */;\n }\n else {\n chClass = classifier.get(chCode);\n }\n // Check if character terminates link\n if (chClass === 1 /* CharacterClass.ForceTermination */) {\n resetStateMachine = true;\n }\n else {\n state = 13 /* State.Accept */;\n }\n }\n else {\n state = stateMachine.nextState(state, chCode);\n if (state === 0 /* State.Invalid */) {\n resetStateMachine = true;\n }\n }\n if (resetStateMachine) {\n state = 1 /* State.Start */;\n hasOpenParens = false;\n hasOpenSquareBracket = false;\n hasOpenCurlyBracket = false;\n // Record where the link started\n linkBeginIndex = j + 1;\n linkBeginChCode = chCode;\n }\n j++;\n }\n if (state === 13 /* State.Accept */) {\n result.push(LinkComputer._createLink(classifier, line, i, linkBeginIndex, len));\n }\n }\n return result;\n }\n}\n/**\n * Returns an array of all links contains in the provided\n * document. *Note* that this operation is computational\n * expensive and should not run in the UI thread.\n */\nexport function computeLinks(model) {\n if (!model || typeof model.getLineCount !== 'function' || typeof model.getLineContent !== 'function') {\n // Unknown caller!\n return [];\n }\n return LinkComputer.computeLinks(model);\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nexport class BasicInplaceReplace {\n constructor() {\n this._defaultValueSet = [\n ['true', 'false'],\n ['True', 'False'],\n ['Private', 'Public', 'Friend', 'ReadOnly', 'Partial', 'Protected', 'WriteOnly'],\n ['public', 'protected', 'private'],\n ];\n }\n navigateValueSet(range1, text1, range2, text2, up) {\n if (range1 && text1) {\n const result = this.doNavigateValueSet(text1, up);\n if (result) {\n return {\n range: range1,\n value: result\n };\n }\n }\n if (range2 && text2) {\n const result = this.doNavigateValueSet(text2, up);\n if (result) {\n return {\n range: range2,\n value: result\n };\n }\n }\n return null;\n }\n doNavigateValueSet(text, up) {\n const numberResult = this.numberReplace(text, up);\n if (numberResult !== null) {\n return numberResult;\n }\n return this.textReplace(text, up);\n }\n numberReplace(value, up) {\n const precision = Math.pow(10, value.length - (value.lastIndexOf('.') + 1));\n let n1 = Number(value);\n const n2 = parseFloat(value);\n if (!isNaN(n1) && !isNaN(n2) && n1 === n2) {\n if (n1 === 0 && !up) {\n return null; // don't do negative\n //\t\t\t} else if(n1 === 9 && up) {\n //\t\t\t\treturn null; // don't insert 10 into a number\n }\n else {\n n1 = Math.floor(n1 * precision);\n n1 += up ? precision : -precision;\n return String(n1 / precision);\n }\n }\n return null;\n }\n textReplace(value, up) {\n return this.valueSetsReplace(this._defaultValueSet, value, up);\n }\n valueSetsReplace(valueSets, value, up) {\n let result = null;\n for (let i = 0, len = valueSets.length; result === null && i < len; i++) {\n result = this.valueSetReplace(valueSets[i], value, up);\n }\n return result;\n }\n valueSetReplace(valueSet, value, up) {\n let idx = valueSet.indexOf(value);\n if (idx >= 0) {\n idx += up ? +1 : -1;\n if (idx < 0) {\n idx = valueSet.length - 1;\n }\n else {\n idx %= valueSet.length;\n }\n return valueSet[idx];\n }\n return null;\n }\n}\nBasicInplaceReplace.INSTANCE = new BasicInplaceReplace();\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { Emitter, Event } from './event.js';\nconst shortcutEvent = Object.freeze(function (callback, context) {\n const handle = setTimeout(callback.bind(context), 0);\n return { dispose() { clearTimeout(handle); } };\n});\nexport var CancellationToken;\n(function (CancellationToken) {\n function isCancellationToken(thing) {\n if (thing === CancellationToken.None || thing === CancellationToken.Cancelled) {\n return true;\n }\n if (thing instanceof MutableToken) {\n return true;\n }\n if (!thing || typeof thing !== 'object') {\n return false;\n }\n return typeof thing.isCancellationRequested === 'boolean'\n && typeof thing.onCancellationRequested === 'function';\n }\n CancellationToken.isCancellationToken = isCancellationToken;\n CancellationToken.None = Object.freeze({\n isCancellationRequested: false,\n onCancellationRequested: Event.None\n });\n CancellationToken.Cancelled = Object.freeze({\n isCancellationRequested: true,\n onCancellationRequested: shortcutEvent\n });\n})(CancellationToken || (CancellationToken = {}));\nclass MutableToken {\n constructor() {\n this._isCancelled = false;\n this._emitter = null;\n }\n cancel() {\n if (!this._isCancelled) {\n this._isCancelled = true;\n if (this._emitter) {\n this._emitter.fire(undefined);\n this.dispose();\n }\n }\n }\n get isCancellationRequested() {\n return this._isCancelled;\n }\n get onCancellationRequested() {\n if (this._isCancelled) {\n return shortcutEvent;\n }\n if (!this._emitter) {\n this._emitter = new Emitter();\n }\n return this._emitter.event;\n }\n dispose() {\n if (this._emitter) {\n this._emitter.dispose();\n this._emitter = null;\n }\n }\n}\nexport class CancellationTokenSource {\n constructor(parent) {\n this._token = undefined;\n this._parentListener = undefined;\n this._parentListener = parent && parent.onCancellationRequested(this.cancel, this);\n }\n get token() {\n if (!this._token) {\n // be lazy and create the token only when\n // actually needed\n this._token = new MutableToken();\n }\n return this._token;\n }\n cancel() {\n if (!this._token) {\n // save an object by returning the default\n // cancelled token when cancellation happens\n // before someone asks for the token\n this._token = CancellationToken.Cancelled;\n }\n else if (this._token instanceof MutableToken) {\n // actually cancel\n this._token.cancel();\n }\n }\n dispose(cancel = false) {\n if (cancel) {\n this.cancel();\n }\n if (this._parentListener) {\n this._parentListener.dispose();\n }\n if (!this._token) {\n // ensure to initialize with an empty token if we had none\n this._token = CancellationToken.None;\n }\n else if (this._token instanceof MutableToken) {\n // actually dispose\n this._token.dispose();\n }\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nclass KeyCodeStrMap {\n constructor() {\n this._keyCodeToStr = [];\n this._strToKeyCode = Object.create(null);\n }\n define(keyCode, str) {\n this._keyCodeToStr[keyCode] = str;\n this._strToKeyCode[str.toLowerCase()] = keyCode;\n }\n keyCodeToStr(keyCode) {\n return this._keyCodeToStr[keyCode];\n }\n strToKeyCode(str) {\n return this._strToKeyCode[str.toLowerCase()] || 0 /* KeyCode.Unknown */;\n }\n}\nconst uiMap = new KeyCodeStrMap();\nconst userSettingsUSMap = new KeyCodeStrMap();\nconst userSettingsGeneralMap = new KeyCodeStrMap();\nexport const EVENT_KEY_CODE_MAP = new Array(230);\nexport const NATIVE_WINDOWS_KEY_CODE_TO_KEY_CODE = {};\nconst scanCodeIntToStr = [];\nconst scanCodeStrToInt = Object.create(null);\nconst scanCodeLowerCaseStrToInt = Object.create(null);\n/**\n * -1 if a ScanCode => KeyCode mapping depends on kb layout.\n */\nexport const IMMUTABLE_CODE_TO_KEY_CODE = [];\n/**\n * -1 if a KeyCode => ScanCode mapping depends on kb layout.\n */\nexport const IMMUTABLE_KEY_CODE_TO_CODE = [];\nfor (let i = 0; i <= 193 /* ScanCode.MAX_VALUE */; i++) {\n IMMUTABLE_CODE_TO_KEY_CODE[i] = -1 /* KeyCode.DependsOnKbLayout */;\n}\nfor (let i = 0; i <= 127 /* KeyCode.MAX_VALUE */; i++) {\n IMMUTABLE_KEY_CODE_TO_CODE[i] = -1 /* ScanCode.DependsOnKbLayout */;\n}\n(function () {\n // See https://msdn.microsoft.com/en-us/library/windows/desktop/dd375731(v=vs.85).aspx\n // See https://github.com/microsoft/node-native-keymap/blob/master/deps/chromium/keyboard_codes_win.h\n const empty = '';\n const mappings = [\n // keyCodeOrd, immutable, scanCode, scanCodeStr, keyCode, keyCodeStr, eventKeyCode, vkey, usUserSettingsLabel, generalUserSettingsLabel\n [0, 1, 0 /* ScanCode.None */, 'None', 0 /* KeyCode.Unknown */, 'unknown', 0, 'VK_UNKNOWN', empty, empty],\n [0, 1, 1 /* ScanCode.Hyper */, 'Hyper', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 2 /* ScanCode.Super */, 'Super', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 3 /* ScanCode.Fn */, 'Fn', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 4 /* ScanCode.FnLock */, 'FnLock', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 5 /* ScanCode.Suspend */, 'Suspend', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 6 /* ScanCode.Resume */, 'Resume', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 7 /* ScanCode.Turbo */, 'Turbo', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 8 /* ScanCode.Sleep */, 'Sleep', 0 /* KeyCode.Unknown */, empty, 0, 'VK_SLEEP', empty, empty],\n [0, 1, 9 /* ScanCode.WakeUp */, 'WakeUp', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [31, 0, 10 /* ScanCode.KeyA */, 'KeyA', 31 /* KeyCode.KeyA */, 'A', 65, 'VK_A', empty, empty],\n [32, 0, 11 /* ScanCode.KeyB */, 'KeyB', 32 /* KeyCode.KeyB */, 'B', 66, 'VK_B', empty, empty],\n [33, 0, 12 /* ScanCode.KeyC */, 'KeyC', 33 /* KeyCode.KeyC */, 'C', 67, 'VK_C', empty, empty],\n [34, 0, 13 /* ScanCode.KeyD */, 'KeyD', 34 /* KeyCode.KeyD */, 'D', 68, 'VK_D', empty, empty],\n [35, 0, 14 /* ScanCode.KeyE */, 'KeyE', 35 /* KeyCode.KeyE */, 'E', 69, 'VK_E', empty, empty],\n [36, 0, 15 /* ScanCode.KeyF */, 'KeyF', 36 /* KeyCode.KeyF */, 'F', 70, 'VK_F', empty, empty],\n [37, 0, 16 /* ScanCode.KeyG */, 'KeyG', 37 /* KeyCode.KeyG */, 'G', 71, 'VK_G', empty, empty],\n [38, 0, 17 /* ScanCode.KeyH */, 'KeyH', 38 /* KeyCode.KeyH */, 'H', 72, 'VK_H', empty, empty],\n [39, 0, 18 /* ScanCode.KeyI */, 'KeyI', 39 /* KeyCode.KeyI */, 'I', 73, 'VK_I', empty, empty],\n [40, 0, 19 /* ScanCode.KeyJ */, 'KeyJ', 40 /* KeyCode.KeyJ */, 'J', 74, 'VK_J', empty, empty],\n [41, 0, 20 /* ScanCode.KeyK */, 'KeyK', 41 /* KeyCode.KeyK */, 'K', 75, 'VK_K', empty, empty],\n [42, 0, 21 /* ScanCode.KeyL */, 'KeyL', 42 /* KeyCode.KeyL */, 'L', 76, 'VK_L', empty, empty],\n [43, 0, 22 /* ScanCode.KeyM */, 'KeyM', 43 /* KeyCode.KeyM */, 'M', 77, 'VK_M', empty, empty],\n [44, 0, 23 /* ScanCode.KeyN */, 'KeyN', 44 /* KeyCode.KeyN */, 'N', 78, 'VK_N', empty, empty],\n [45, 0, 24 /* ScanCode.KeyO */, 'KeyO', 45 /* KeyCode.KeyO */, 'O', 79, 'VK_O', empty, empty],\n [46, 0, 25 /* ScanCode.KeyP */, 'KeyP', 46 /* KeyCode.KeyP */, 'P', 80, 'VK_P', empty, empty],\n [47, 0, 26 /* ScanCode.KeyQ */, 'KeyQ', 47 /* KeyCode.KeyQ */, 'Q', 81, 'VK_Q', empty, empty],\n [48, 0, 27 /* ScanCode.KeyR */, 'KeyR', 48 /* KeyCode.KeyR */, 'R', 82, 'VK_R', empty, empty],\n [49, 0, 28 /* ScanCode.KeyS */, 'KeyS', 49 /* KeyCode.KeyS */, 'S', 83, 'VK_S', empty, empty],\n [50, 0, 29 /* ScanCode.KeyT */, 'KeyT', 50 /* KeyCode.KeyT */, 'T', 84, 'VK_T', empty, empty],\n [51, 0, 30 /* ScanCode.KeyU */, 'KeyU', 51 /* KeyCode.KeyU */, 'U', 85, 'VK_U', empty, empty],\n [52, 0, 31 /* ScanCode.KeyV */, 'KeyV', 52 /* KeyCode.KeyV */, 'V', 86, 'VK_V', empty, empty],\n [53, 0, 32 /* ScanCode.KeyW */, 'KeyW', 53 /* KeyCode.KeyW */, 'W', 87, 'VK_W', empty, empty],\n [54, 0, 33 /* ScanCode.KeyX */, 'KeyX', 54 /* KeyCode.KeyX */, 'X', 88, 'VK_X', empty, empty],\n [55, 0, 34 /* ScanCode.KeyY */, 'KeyY', 55 /* KeyCode.KeyY */, 'Y', 89, 'VK_Y', empty, empty],\n [56, 0, 35 /* ScanCode.KeyZ */, 'KeyZ', 56 /* KeyCode.KeyZ */, 'Z', 90, 'VK_Z', empty, empty],\n [22, 0, 36 /* ScanCode.Digit1 */, 'Digit1', 22 /* KeyCode.Digit1 */, '1', 49, 'VK_1', empty, empty],\n [23, 0, 37 /* ScanCode.Digit2 */, 'Digit2', 23 /* KeyCode.Digit2 */, '2', 50, 'VK_2', empty, empty],\n [24, 0, 38 /* ScanCode.Digit3 */, 'Digit3', 24 /* KeyCode.Digit3 */, '3', 51, 'VK_3', empty, empty],\n [25, 0, 39 /* ScanCode.Digit4 */, 'Digit4', 25 /* KeyCode.Digit4 */, '4', 52, 'VK_4', empty, empty],\n [26, 0, 40 /* ScanCode.Digit5 */, 'Digit5', 26 /* KeyCode.Digit5 */, '5', 53, 'VK_5', empty, empty],\n [27, 0, 41 /* ScanCode.Digit6 */, 'Digit6', 27 /* KeyCode.Digit6 */, '6', 54, 'VK_6', empty, empty],\n [28, 0, 42 /* ScanCode.Digit7 */, 'Digit7', 28 /* KeyCode.Digit7 */, '7', 55, 'VK_7', empty, empty],\n [29, 0, 43 /* ScanCode.Digit8 */, 'Digit8', 29 /* KeyCode.Digit8 */, '8', 56, 'VK_8', empty, empty],\n [30, 0, 44 /* ScanCode.Digit9 */, 'Digit9', 30 /* KeyCode.Digit9 */, '9', 57, 'VK_9', empty, empty],\n [21, 0, 45 /* ScanCode.Digit0 */, 'Digit0', 21 /* KeyCode.Digit0 */, '0', 48, 'VK_0', empty, empty],\n [3, 1, 46 /* ScanCode.Enter */, 'Enter', 3 /* KeyCode.Enter */, 'Enter', 13, 'VK_RETURN', empty, empty],\n [9, 1, 47 /* ScanCode.Escape */, 'Escape', 9 /* KeyCode.Escape */, 'Escape', 27, 'VK_ESCAPE', empty, empty],\n [1, 1, 48 /* ScanCode.Backspace */, 'Backspace', 1 /* KeyCode.Backspace */, 'Backspace', 8, 'VK_BACK', empty, empty],\n [2, 1, 49 /* ScanCode.Tab */, 'Tab', 2 /* KeyCode.Tab */, 'Tab', 9, 'VK_TAB', empty, empty],\n [10, 1, 50 /* ScanCode.Space */, 'Space', 10 /* KeyCode.Space */, 'Space', 32, 'VK_SPACE', empty, empty],\n [83, 0, 51 /* ScanCode.Minus */, 'Minus', 83 /* KeyCode.Minus */, '-', 189, 'VK_OEM_MINUS', '-', 'OEM_MINUS'],\n [81, 0, 52 /* ScanCode.Equal */, 'Equal', 81 /* KeyCode.Equal */, '=', 187, 'VK_OEM_PLUS', '=', 'OEM_PLUS'],\n [87, 0, 53 /* ScanCode.BracketLeft */, 'BracketLeft', 87 /* KeyCode.BracketLeft */, '[', 219, 'VK_OEM_4', '[', 'OEM_4'],\n [89, 0, 54 /* ScanCode.BracketRight */, 'BracketRight', 89 /* KeyCode.BracketRight */, ']', 221, 'VK_OEM_6', ']', 'OEM_6'],\n [88, 0, 55 /* ScanCode.Backslash */, 'Backslash', 88 /* KeyCode.Backslash */, '\\\\', 220, 'VK_OEM_5', '\\\\', 'OEM_5'],\n [0, 0, 56 /* ScanCode.IntlHash */, 'IntlHash', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [80, 0, 57 /* ScanCode.Semicolon */, 'Semicolon', 80 /* KeyCode.Semicolon */, ';', 186, 'VK_OEM_1', ';', 'OEM_1'],\n [90, 0, 58 /* ScanCode.Quote */, 'Quote', 90 /* KeyCode.Quote */, '\\'', 222, 'VK_OEM_7', '\\'', 'OEM_7'],\n [86, 0, 59 /* ScanCode.Backquote */, 'Backquote', 86 /* KeyCode.Backquote */, '`', 192, 'VK_OEM_3', '`', 'OEM_3'],\n [82, 0, 60 /* ScanCode.Comma */, 'Comma', 82 /* KeyCode.Comma */, ',', 188, 'VK_OEM_COMMA', ',', 'OEM_COMMA'],\n [84, 0, 61 /* ScanCode.Period */, 'Period', 84 /* KeyCode.Period */, '.', 190, 'VK_OEM_PERIOD', '.', 'OEM_PERIOD'],\n [85, 0, 62 /* ScanCode.Slash */, 'Slash', 85 /* KeyCode.Slash */, '/', 191, 'VK_OEM_2', '/', 'OEM_2'],\n [8, 1, 63 /* ScanCode.CapsLock */, 'CapsLock', 8 /* KeyCode.CapsLock */, 'CapsLock', 20, 'VK_CAPITAL', empty, empty],\n [59, 1, 64 /* ScanCode.F1 */, 'F1', 59 /* KeyCode.F1 */, 'F1', 112, 'VK_F1', empty, empty],\n [60, 1, 65 /* ScanCode.F2 */, 'F2', 60 /* KeyCode.F2 */, 'F2', 113, 'VK_F2', empty, empty],\n [61, 1, 66 /* ScanCode.F3 */, 'F3', 61 /* KeyCode.F3 */, 'F3', 114, 'VK_F3', empty, empty],\n [62, 1, 67 /* ScanCode.F4 */, 'F4', 62 /* KeyCode.F4 */, 'F4', 115, 'VK_F4', empty, empty],\n [63, 1, 68 /* ScanCode.F5 */, 'F5', 63 /* KeyCode.F5 */, 'F5', 116, 'VK_F5', empty, empty],\n [64, 1, 69 /* ScanCode.F6 */, 'F6', 64 /* KeyCode.F6 */, 'F6', 117, 'VK_F6', empty, empty],\n [65, 1, 70 /* ScanCode.F7 */, 'F7', 65 /* KeyCode.F7 */, 'F7', 118, 'VK_F7', empty, empty],\n [66, 1, 71 /* ScanCode.F8 */, 'F8', 66 /* KeyCode.F8 */, 'F8', 119, 'VK_F8', empty, empty],\n [67, 1, 72 /* ScanCode.F9 */, 'F9', 67 /* KeyCode.F9 */, 'F9', 120, 'VK_F9', empty, empty],\n [68, 1, 73 /* ScanCode.F10 */, 'F10', 68 /* KeyCode.F10 */, 'F10', 121, 'VK_F10', empty, empty],\n [69, 1, 74 /* ScanCode.F11 */, 'F11', 69 /* KeyCode.F11 */, 'F11', 122, 'VK_F11', empty, empty],\n [70, 1, 75 /* ScanCode.F12 */, 'F12', 70 /* KeyCode.F12 */, 'F12', 123, 'VK_F12', empty, empty],\n [0, 1, 76 /* ScanCode.PrintScreen */, 'PrintScreen', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [79, 1, 77 /* ScanCode.ScrollLock */, 'ScrollLock', 79 /* KeyCode.ScrollLock */, 'ScrollLock', 145, 'VK_SCROLL', empty, empty],\n [7, 1, 78 /* ScanCode.Pause */, 'Pause', 7 /* KeyCode.PauseBreak */, 'PauseBreak', 19, 'VK_PAUSE', empty, empty],\n [19, 1, 79 /* ScanCode.Insert */, 'Insert', 19 /* KeyCode.Insert */, 'Insert', 45, 'VK_INSERT', empty, empty],\n [14, 1, 80 /* ScanCode.Home */, 'Home', 14 /* KeyCode.Home */, 'Home', 36, 'VK_HOME', empty, empty],\n [11, 1, 81 /* ScanCode.PageUp */, 'PageUp', 11 /* KeyCode.PageUp */, 'PageUp', 33, 'VK_PRIOR', empty, empty],\n [20, 1, 82 /* ScanCode.Delete */, 'Delete', 20 /* KeyCode.Delete */, 'Delete', 46, 'VK_DELETE', empty, empty],\n [13, 1, 83 /* ScanCode.End */, 'End', 13 /* KeyCode.End */, 'End', 35, 'VK_END', empty, empty],\n [12, 1, 84 /* ScanCode.PageDown */, 'PageDown', 12 /* KeyCode.PageDown */, 'PageDown', 34, 'VK_NEXT', empty, empty],\n [17, 1, 85 /* ScanCode.ArrowRight */, 'ArrowRight', 17 /* KeyCode.RightArrow */, 'RightArrow', 39, 'VK_RIGHT', 'Right', empty],\n [15, 1, 86 /* ScanCode.ArrowLeft */, 'ArrowLeft', 15 /* KeyCode.LeftArrow */, 'LeftArrow', 37, 'VK_LEFT', 'Left', empty],\n [18, 1, 87 /* ScanCode.ArrowDown */, 'ArrowDown', 18 /* KeyCode.DownArrow */, 'DownArrow', 40, 'VK_DOWN', 'Down', empty],\n [16, 1, 88 /* ScanCode.ArrowUp */, 'ArrowUp', 16 /* KeyCode.UpArrow */, 'UpArrow', 38, 'VK_UP', 'Up', empty],\n [78, 1, 89 /* ScanCode.NumLock */, 'NumLock', 78 /* KeyCode.NumLock */, 'NumLock', 144, 'VK_NUMLOCK', empty, empty],\n [108, 1, 90 /* ScanCode.NumpadDivide */, 'NumpadDivide', 108 /* KeyCode.NumpadDivide */, 'NumPad_Divide', 111, 'VK_DIVIDE', empty, empty],\n [103, 1, 91 /* ScanCode.NumpadMultiply */, 'NumpadMultiply', 103 /* KeyCode.NumpadMultiply */, 'NumPad_Multiply', 106, 'VK_MULTIPLY', empty, empty],\n [106, 1, 92 /* ScanCode.NumpadSubtract */, 'NumpadSubtract', 106 /* KeyCode.NumpadSubtract */, 'NumPad_Subtract', 109, 'VK_SUBTRACT', empty, empty],\n [104, 1, 93 /* ScanCode.NumpadAdd */, 'NumpadAdd', 104 /* KeyCode.NumpadAdd */, 'NumPad_Add', 107, 'VK_ADD', empty, empty],\n [3, 1, 94 /* ScanCode.NumpadEnter */, 'NumpadEnter', 3 /* KeyCode.Enter */, empty, 0, empty, empty, empty],\n [94, 1, 95 /* ScanCode.Numpad1 */, 'Numpad1', 94 /* KeyCode.Numpad1 */, 'NumPad1', 97, 'VK_NUMPAD1', empty, empty],\n [95, 1, 96 /* ScanCode.Numpad2 */, 'Numpad2', 95 /* KeyCode.Numpad2 */, 'NumPad2', 98, 'VK_NUMPAD2', empty, empty],\n [96, 1, 97 /* ScanCode.Numpad3 */, 'Numpad3', 96 /* KeyCode.Numpad3 */, 'NumPad3', 99, 'VK_NUMPAD3', empty, empty],\n [97, 1, 98 /* ScanCode.Numpad4 */, 'Numpad4', 97 /* KeyCode.Numpad4 */, 'NumPad4', 100, 'VK_NUMPAD4', empty, empty],\n [98, 1, 99 /* ScanCode.Numpad5 */, 'Numpad5', 98 /* KeyCode.Numpad5 */, 'NumPad5', 101, 'VK_NUMPAD5', empty, empty],\n [99, 1, 100 /* ScanCode.Numpad6 */, 'Numpad6', 99 /* KeyCode.Numpad6 */, 'NumPad6', 102, 'VK_NUMPAD6', empty, empty],\n [100, 1, 101 /* ScanCode.Numpad7 */, 'Numpad7', 100 /* KeyCode.Numpad7 */, 'NumPad7', 103, 'VK_NUMPAD7', empty, empty],\n [101, 1, 102 /* ScanCode.Numpad8 */, 'Numpad8', 101 /* KeyCode.Numpad8 */, 'NumPad8', 104, 'VK_NUMPAD8', empty, empty],\n [102, 1, 103 /* ScanCode.Numpad9 */, 'Numpad9', 102 /* KeyCode.Numpad9 */, 'NumPad9', 105, 'VK_NUMPAD9', empty, empty],\n [93, 1, 104 /* ScanCode.Numpad0 */, 'Numpad0', 93 /* KeyCode.Numpad0 */, 'NumPad0', 96, 'VK_NUMPAD0', empty, empty],\n [107, 1, 105 /* ScanCode.NumpadDecimal */, 'NumpadDecimal', 107 /* KeyCode.NumpadDecimal */, 'NumPad_Decimal', 110, 'VK_DECIMAL', empty, empty],\n [92, 0, 106 /* ScanCode.IntlBackslash */, 'IntlBackslash', 92 /* KeyCode.IntlBackslash */, 'OEM_102', 226, 'VK_OEM_102', empty, empty],\n [58, 1, 107 /* ScanCode.ContextMenu */, 'ContextMenu', 58 /* KeyCode.ContextMenu */, 'ContextMenu', 93, empty, empty, empty],\n [0, 1, 108 /* ScanCode.Power */, 'Power', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 109 /* ScanCode.NumpadEqual */, 'NumpadEqual', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [71, 1, 110 /* ScanCode.F13 */, 'F13', 71 /* KeyCode.F13 */, 'F13', 124, 'VK_F13', empty, empty],\n [72, 1, 111 /* ScanCode.F14 */, 'F14', 72 /* KeyCode.F14 */, 'F14', 125, 'VK_F14', empty, empty],\n [73, 1, 112 /* ScanCode.F15 */, 'F15', 73 /* KeyCode.F15 */, 'F15', 126, 'VK_F15', empty, empty],\n [74, 1, 113 /* ScanCode.F16 */, 'F16', 74 /* KeyCode.F16 */, 'F16', 127, 'VK_F16', empty, empty],\n [75, 1, 114 /* ScanCode.F17 */, 'F17', 75 /* KeyCode.F17 */, 'F17', 128, 'VK_F17', empty, empty],\n [76, 1, 115 /* ScanCode.F18 */, 'F18', 76 /* KeyCode.F18 */, 'F18', 129, 'VK_F18', empty, empty],\n [77, 1, 116 /* ScanCode.F19 */, 'F19', 77 /* KeyCode.F19 */, 'F19', 130, 'VK_F19', empty, empty],\n [0, 1, 117 /* ScanCode.F20 */, 'F20', 0 /* KeyCode.Unknown */, empty, 0, 'VK_F20', empty, empty],\n [0, 1, 118 /* ScanCode.F21 */, 'F21', 0 /* KeyCode.Unknown */, empty, 0, 'VK_F21', empty, empty],\n [0, 1, 119 /* ScanCode.F22 */, 'F22', 0 /* KeyCode.Unknown */, empty, 0, 'VK_F22', empty, empty],\n [0, 1, 120 /* ScanCode.F23 */, 'F23', 0 /* KeyCode.Unknown */, empty, 0, 'VK_F23', empty, empty],\n [0, 1, 121 /* ScanCode.F24 */, 'F24', 0 /* KeyCode.Unknown */, empty, 0, 'VK_F24', empty, empty],\n [0, 1, 122 /* ScanCode.Open */, 'Open', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 123 /* ScanCode.Help */, 'Help', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 124 /* ScanCode.Select */, 'Select', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 125 /* ScanCode.Again */, 'Again', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 126 /* ScanCode.Undo */, 'Undo', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 127 /* ScanCode.Cut */, 'Cut', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 128 /* ScanCode.Copy */, 'Copy', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 129 /* ScanCode.Paste */, 'Paste', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 130 /* ScanCode.Find */, 'Find', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 131 /* ScanCode.AudioVolumeMute */, 'AudioVolumeMute', 112 /* KeyCode.AudioVolumeMute */, 'AudioVolumeMute', 173, 'VK_VOLUME_MUTE', empty, empty],\n [0, 1, 132 /* ScanCode.AudioVolumeUp */, 'AudioVolumeUp', 113 /* KeyCode.AudioVolumeUp */, 'AudioVolumeUp', 175, 'VK_VOLUME_UP', empty, empty],\n [0, 1, 133 /* ScanCode.AudioVolumeDown */, 'AudioVolumeDown', 114 /* KeyCode.AudioVolumeDown */, 'AudioVolumeDown', 174, 'VK_VOLUME_DOWN', empty, empty],\n [105, 1, 134 /* ScanCode.NumpadComma */, 'NumpadComma', 105 /* KeyCode.NUMPAD_SEPARATOR */, 'NumPad_Separator', 108, 'VK_SEPARATOR', empty, empty],\n [110, 0, 135 /* ScanCode.IntlRo */, 'IntlRo', 110 /* KeyCode.ABNT_C1 */, 'ABNT_C1', 193, 'VK_ABNT_C1', empty, empty],\n [0, 1, 136 /* ScanCode.KanaMode */, 'KanaMode', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 0, 137 /* ScanCode.IntlYen */, 'IntlYen', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 138 /* ScanCode.Convert */, 'Convert', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 139 /* ScanCode.NonConvert */, 'NonConvert', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 140 /* ScanCode.Lang1 */, 'Lang1', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 141 /* ScanCode.Lang2 */, 'Lang2', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 142 /* ScanCode.Lang3 */, 'Lang3', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 143 /* ScanCode.Lang4 */, 'Lang4', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 144 /* ScanCode.Lang5 */, 'Lang5', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 145 /* ScanCode.Abort */, 'Abort', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 146 /* ScanCode.Props */, 'Props', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 147 /* ScanCode.NumpadParenLeft */, 'NumpadParenLeft', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 148 /* ScanCode.NumpadParenRight */, 'NumpadParenRight', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 149 /* ScanCode.NumpadBackspace */, 'NumpadBackspace', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 150 /* ScanCode.NumpadMemoryStore */, 'NumpadMemoryStore', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 151 /* ScanCode.NumpadMemoryRecall */, 'NumpadMemoryRecall', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 152 /* ScanCode.NumpadMemoryClear */, 'NumpadMemoryClear', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 153 /* ScanCode.NumpadMemoryAdd */, 'NumpadMemoryAdd', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 154 /* ScanCode.NumpadMemorySubtract */, 'NumpadMemorySubtract', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 155 /* ScanCode.NumpadClear */, 'NumpadClear', 126 /* KeyCode.Clear */, 'Clear', 12, 'VK_CLEAR', empty, empty],\n [0, 1, 156 /* ScanCode.NumpadClearEntry */, 'NumpadClearEntry', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [5, 1, 0 /* ScanCode.None */, empty, 5 /* KeyCode.Ctrl */, 'Ctrl', 17, 'VK_CONTROL', empty, empty],\n [4, 1, 0 /* ScanCode.None */, empty, 4 /* KeyCode.Shift */, 'Shift', 16, 'VK_SHIFT', empty, empty],\n [6, 1, 0 /* ScanCode.None */, empty, 6 /* KeyCode.Alt */, 'Alt', 18, 'VK_MENU', empty, empty],\n [57, 1, 0 /* ScanCode.None */, empty, 57 /* KeyCode.Meta */, 'Meta', 0, 'VK_COMMAND', empty, empty],\n [5, 1, 157 /* ScanCode.ControlLeft */, 'ControlLeft', 5 /* KeyCode.Ctrl */, empty, 0, 'VK_LCONTROL', empty, empty],\n [4, 1, 158 /* ScanCode.ShiftLeft */, 'ShiftLeft', 4 /* KeyCode.Shift */, empty, 0, 'VK_LSHIFT', empty, empty],\n [6, 1, 159 /* ScanCode.AltLeft */, 'AltLeft', 6 /* KeyCode.Alt */, empty, 0, 'VK_LMENU', empty, empty],\n [57, 1, 160 /* ScanCode.MetaLeft */, 'MetaLeft', 57 /* KeyCode.Meta */, empty, 0, 'VK_LWIN', empty, empty],\n [5, 1, 161 /* ScanCode.ControlRight */, 'ControlRight', 5 /* KeyCode.Ctrl */, empty, 0, 'VK_RCONTROL', empty, empty],\n [4, 1, 162 /* ScanCode.ShiftRight */, 'ShiftRight', 4 /* KeyCode.Shift */, empty, 0, 'VK_RSHIFT', empty, empty],\n [6, 1, 163 /* ScanCode.AltRight */, 'AltRight', 6 /* KeyCode.Alt */, empty, 0, 'VK_RMENU', empty, empty],\n [57, 1, 164 /* ScanCode.MetaRight */, 'MetaRight', 57 /* KeyCode.Meta */, empty, 0, 'VK_RWIN', empty, empty],\n [0, 1, 165 /* ScanCode.BrightnessUp */, 'BrightnessUp', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 166 /* ScanCode.BrightnessDown */, 'BrightnessDown', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 167 /* ScanCode.MediaPlay */, 'MediaPlay', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 168 /* ScanCode.MediaRecord */, 'MediaRecord', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 169 /* ScanCode.MediaFastForward */, 'MediaFastForward', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 170 /* ScanCode.MediaRewind */, 'MediaRewind', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [114, 1, 171 /* ScanCode.MediaTrackNext */, 'MediaTrackNext', 119 /* KeyCode.MediaTrackNext */, 'MediaTrackNext', 176, 'VK_MEDIA_NEXT_TRACK', empty, empty],\n [115, 1, 172 /* ScanCode.MediaTrackPrevious */, 'MediaTrackPrevious', 120 /* KeyCode.MediaTrackPrevious */, 'MediaTrackPrevious', 177, 'VK_MEDIA_PREV_TRACK', empty, empty],\n [116, 1, 173 /* ScanCode.MediaStop */, 'MediaStop', 121 /* KeyCode.MediaStop */, 'MediaStop', 178, 'VK_MEDIA_STOP', empty, empty],\n [0, 1, 174 /* ScanCode.Eject */, 'Eject', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [117, 1, 175 /* ScanCode.MediaPlayPause */, 'MediaPlayPause', 122 /* KeyCode.MediaPlayPause */, 'MediaPlayPause', 179, 'VK_MEDIA_PLAY_PAUSE', empty, empty],\n [0, 1, 176 /* ScanCode.MediaSelect */, 'MediaSelect', 123 /* KeyCode.LaunchMediaPlayer */, 'LaunchMediaPlayer', 181, 'VK_MEDIA_LAUNCH_MEDIA_SELECT', empty, empty],\n [0, 1, 177 /* ScanCode.LaunchMail */, 'LaunchMail', 124 /* KeyCode.LaunchMail */, 'LaunchMail', 180, 'VK_MEDIA_LAUNCH_MAIL', empty, empty],\n [0, 1, 178 /* ScanCode.LaunchApp2 */, 'LaunchApp2', 125 /* KeyCode.LaunchApp2 */, 'LaunchApp2', 183, 'VK_MEDIA_LAUNCH_APP2', empty, empty],\n [0, 1, 179 /* ScanCode.LaunchApp1 */, 'LaunchApp1', 0 /* KeyCode.Unknown */, empty, 0, 'VK_MEDIA_LAUNCH_APP1', empty, empty],\n [0, 1, 180 /* ScanCode.SelectTask */, 'SelectTask', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 181 /* ScanCode.LaunchScreenSaver */, 'LaunchScreenSaver', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 182 /* ScanCode.BrowserSearch */, 'BrowserSearch', 115 /* KeyCode.BrowserSearch */, 'BrowserSearch', 170, 'VK_BROWSER_SEARCH', empty, empty],\n [0, 1, 183 /* ScanCode.BrowserHome */, 'BrowserHome', 116 /* KeyCode.BrowserHome */, 'BrowserHome', 172, 'VK_BROWSER_HOME', empty, empty],\n [112, 1, 184 /* ScanCode.BrowserBack */, 'BrowserBack', 117 /* KeyCode.BrowserBack */, 'BrowserBack', 166, 'VK_BROWSER_BACK', empty, empty],\n [113, 1, 185 /* ScanCode.BrowserForward */, 'BrowserForward', 118 /* KeyCode.BrowserForward */, 'BrowserForward', 167, 'VK_BROWSER_FORWARD', empty, empty],\n [0, 1, 186 /* ScanCode.BrowserStop */, 'BrowserStop', 0 /* KeyCode.Unknown */, empty, 0, 'VK_BROWSER_STOP', empty, empty],\n [0, 1, 187 /* ScanCode.BrowserRefresh */, 'BrowserRefresh', 0 /* KeyCode.Unknown */, empty, 0, 'VK_BROWSER_REFRESH', empty, empty],\n [0, 1, 188 /* ScanCode.BrowserFavorites */, 'BrowserFavorites', 0 /* KeyCode.Unknown */, empty, 0, 'VK_BROWSER_FAVORITES', empty, empty],\n [0, 1, 189 /* ScanCode.ZoomToggle */, 'ZoomToggle', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 190 /* ScanCode.MailReply */, 'MailReply', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 191 /* ScanCode.MailForward */, 'MailForward', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n [0, 1, 192 /* ScanCode.MailSend */, 'MailSend', 0 /* KeyCode.Unknown */, empty, 0, empty, empty, empty],\n // See https://lists.w3.org/Archives/Public/www-dom/2010JulSep/att-0182/keyCode-spec.html\n // If an Input Method Editor is processing key input and the event is keydown, return 229.\n [109, 1, 0 /* ScanCode.None */, empty, 109 /* KeyCode.KEY_IN_COMPOSITION */, 'KeyInComposition', 229, empty, empty, empty],\n [111, 1, 0 /* ScanCode.None */, empty, 111 /* KeyCode.ABNT_C2 */, 'ABNT_C2', 194, 'VK_ABNT_C2', empty, empty],\n [91, 1, 0 /* ScanCode.None */, empty, 91 /* KeyCode.OEM_8 */, 'OEM_8', 223, 'VK_OEM_8', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_KANA', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_HANGUL', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_JUNJA', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_FINAL', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_HANJA', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_KANJI', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_CONVERT', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_NONCONVERT', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_ACCEPT', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_MODECHANGE', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_SELECT', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_PRINT', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_EXECUTE', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_SNAPSHOT', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_HELP', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_APPS', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_PROCESSKEY', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_PACKET', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_DBE_SBCSCHAR', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_DBE_DBCSCHAR', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_ATTN', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_CRSEL', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_EXSEL', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_EREOF', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_PLAY', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_ZOOM', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_NONAME', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_PA1', empty, empty],\n [0, 1, 0 /* ScanCode.None */, empty, 0 /* KeyCode.Unknown */, empty, 0, 'VK_OEM_CLEAR', empty, empty],\n ];\n const seenKeyCode = [];\n const seenScanCode = [];\n for (const mapping of mappings) {\n const [_keyCodeOrd, immutable, scanCode, scanCodeStr, keyCode, keyCodeStr, eventKeyCode, vkey, usUserSettingsLabel, generalUserSettingsLabel] = mapping;\n if (!seenScanCode[scanCode]) {\n seenScanCode[scanCode] = true;\n scanCodeIntToStr[scanCode] = scanCodeStr;\n scanCodeStrToInt[scanCodeStr] = scanCode;\n scanCodeLowerCaseStrToInt[scanCodeStr.toLowerCase()] = scanCode;\n if (immutable) {\n IMMUTABLE_CODE_TO_KEY_CODE[scanCode] = keyCode;\n if ((keyCode !== 0 /* KeyCode.Unknown */)\n && (keyCode !== 3 /* KeyCode.Enter */)\n && (keyCode !== 5 /* KeyCode.Ctrl */)\n && (keyCode !== 4 /* KeyCode.Shift */)\n && (keyCode !== 6 /* KeyCode.Alt */)\n && (keyCode !== 57 /* KeyCode.Meta */)) {\n IMMUTABLE_KEY_CODE_TO_CODE[keyCode] = scanCode;\n }\n }\n }\n if (!seenKeyCode[keyCode]) {\n seenKeyCode[keyCode] = true;\n if (!keyCodeStr) {\n throw new Error(`String representation missing for key code ${keyCode} around scan code ${scanCodeStr}`);\n }\n uiMap.define(keyCode, keyCodeStr);\n userSettingsUSMap.define(keyCode, usUserSettingsLabel || keyCodeStr);\n userSettingsGeneralMap.define(keyCode, generalUserSettingsLabel || usUserSettingsLabel || keyCodeStr);\n }\n if (eventKeyCode) {\n EVENT_KEY_CODE_MAP[eventKeyCode] = keyCode;\n }\n if (vkey) {\n NATIVE_WINDOWS_KEY_CODE_TO_KEY_CODE[vkey] = keyCode;\n }\n }\n // Manually added due to the exclusion above (due to duplication with NumpadEnter)\n IMMUTABLE_KEY_CODE_TO_CODE[3 /* KeyCode.Enter */] = 46 /* ScanCode.Enter */;\n})();\nexport var KeyCodeUtils;\n(function (KeyCodeUtils) {\n function toString(keyCode) {\n return uiMap.keyCodeToStr(keyCode);\n }\n KeyCodeUtils.toString = toString;\n function fromString(key) {\n return uiMap.strToKeyCode(key);\n }\n KeyCodeUtils.fromString = fromString;\n function toUserSettingsUS(keyCode) {\n return userSettingsUSMap.keyCodeToStr(keyCode);\n }\n KeyCodeUtils.toUserSettingsUS = toUserSettingsUS;\n function toUserSettingsGeneral(keyCode) {\n return userSettingsGeneralMap.keyCodeToStr(keyCode);\n }\n KeyCodeUtils.toUserSettingsGeneral = toUserSettingsGeneral;\n function fromUserSettings(key) {\n return userSettingsUSMap.strToKeyCode(key) || userSettingsGeneralMap.strToKeyCode(key);\n }\n KeyCodeUtils.fromUserSettings = fromUserSettings;\n function toElectronAccelerator(keyCode) {\n if (keyCode >= 93 /* KeyCode.Numpad0 */ && keyCode <= 108 /* KeyCode.NumpadDivide */) {\n // [Electron Accelerators] Electron is able to parse numpad keys, but unfortunately it\n // renders them just as regular keys in menus. For example, num0 is rendered as \"0\",\n // numdiv is rendered as \"/\", numsub is rendered as \"-\".\n //\n // This can lead to incredible confusion, as it makes numpad based keybindings indistinguishable\n // from keybindings based on regular keys.\n //\n // We therefore need to fall back to custom rendering for numpad keys.\n return null;\n }\n switch (keyCode) {\n case 16 /* KeyCode.UpArrow */:\n return 'Up';\n case 18 /* KeyCode.DownArrow */:\n return 'Down';\n case 15 /* KeyCode.LeftArrow */:\n return 'Left';\n case 17 /* KeyCode.RightArrow */:\n return 'Right';\n }\n return uiMap.keyCodeToStr(keyCode);\n }\n KeyCodeUtils.toElectronAccelerator = toElectronAccelerator;\n})(KeyCodeUtils || (KeyCodeUtils = {}));\nexport function KeyChord(firstPart, secondPart) {\n const chordPart = ((secondPart & 0x0000FFFF) << 16) >>> 0;\n return (firstPart | chordPart) >>> 0;\n}\n","// Selects all codicon names encapsulated in the `$()` syntax and wraps the\n// results with spaces so that screen readers can read the text better.\nexport function getCodiconAriaLabel(text) {\n if (!text) {\n return '';\n }\n return text.replace(/\\$\\((.*?)\\)/g, (_match, codiconName) => ` ${codiconName} `).trim();\n}\n/**\n * The Codicon library is a set of default icons that are built-in in VS Code.\n *\n * In the product (outside of base) Codicons should only be used as defaults. In order to have all icons in VS Code\n * themeable, component should define new, UI component specific icons using `iconRegistry.registerIcon`.\n * In that call a Codicon can be named as default.\n */\nexport class Codicon {\n constructor(id, definition, description) {\n this.id = id;\n this.definition = definition;\n this.description = description;\n Codicon._allCodicons.push(this);\n }\n get classNames() { return 'codicon codicon-' + this.id; }\n // classNamesArray is useful for migrating to ES6 classlist\n get classNamesArray() { return ['codicon', 'codicon-' + this.id]; }\n get cssSelector() { return '.codicon.codicon-' + this.id; }\n /**\n * @returns Returns all default icons covered by the codicon font. Only to be used by the icon registry in platform.\n */\n static getAll() {\n return Codicon._allCodicons;\n }\n}\n// registry\nCodicon._allCodicons = [];\n// built-in icons, with image name\nCodicon.add = new Codicon('add', { fontCharacter: '\\\\ea60' });\nCodicon.plus = new Codicon('plus', Codicon.add.definition);\nCodicon.gistNew = new Codicon('gist-new', Codicon.add.definition);\nCodicon.repoCreate = new Codicon('repo-create', Codicon.add.definition);\nCodicon.lightbulb = new Codicon('lightbulb', { fontCharacter: '\\\\ea61' });\nCodicon.lightBulb = new Codicon('light-bulb', { fontCharacter: '\\\\ea61' });\nCodicon.repo = new Codicon('repo', { fontCharacter: '\\\\ea62' });\nCodicon.repoDelete = new Codicon('repo-delete', { fontCharacter: '\\\\ea62' });\nCodicon.gistFork = new Codicon('gist-fork', { fontCharacter: '\\\\ea63' });\nCodicon.repoForked = new Codicon('repo-forked', { fontCharacter: '\\\\ea63' });\nCodicon.gitPullRequest = new Codicon('git-pull-request', { fontCharacter: '\\\\ea64' });\nCodicon.gitPullRequestAbandoned = new Codicon('git-pull-request-abandoned', { fontCharacter: '\\\\ea64' });\nCodicon.recordKeys = new Codicon('record-keys', { fontCharacter: '\\\\ea65' });\nCodicon.keyboard = new Codicon('keyboard', { fontCharacter: '\\\\ea65' });\nCodicon.tag = new Codicon('tag', { fontCharacter: '\\\\ea66' });\nCodicon.tagAdd = new Codicon('tag-add', { fontCharacter: '\\\\ea66' });\nCodicon.tagRemove = new Codicon('tag-remove', { fontCharacter: '\\\\ea66' });\nCodicon.person = new Codicon('person', { fontCharacter: '\\\\ea67' });\nCodicon.personFollow = new Codicon('person-follow', { fontCharacter: '\\\\ea67' });\nCodicon.personOutline = new Codicon('person-outline', { fontCharacter: '\\\\ea67' });\nCodicon.personFilled = new Codicon('person-filled', { fontCharacter: '\\\\ea67' });\nCodicon.gitBranch = new Codicon('git-branch', { fontCharacter: '\\\\ea68' });\nCodicon.gitBranchCreate = new Codicon('git-branch-create', { fontCharacter: '\\\\ea68' });\nCodicon.gitBranchDelete = new Codicon('git-branch-delete', { fontCharacter: '\\\\ea68' });\nCodicon.sourceControl = new Codicon('source-control', { fontCharacter: '\\\\ea68' });\nCodicon.mirror = new Codicon('mirror', { fontCharacter: '\\\\ea69' });\nCodicon.mirrorPublic = new Codicon('mirror-public', { fontCharacter: '\\\\ea69' });\nCodicon.star = new Codicon('star', { fontCharacter: '\\\\ea6a' });\nCodicon.starAdd = new Codicon('star-add', { fontCharacter: '\\\\ea6a' });\nCodicon.starDelete = new Codicon('star-delete', { fontCharacter: '\\\\ea6a' });\nCodicon.starEmpty = new Codicon('star-empty', { fontCharacter: '\\\\ea6a' });\nCodicon.comment = new Codicon('comment', { fontCharacter: '\\\\ea6b' });\nCodicon.commentAdd = new Codicon('comment-add', { fontCharacter: '\\\\ea6b' });\nCodicon.alert = new Codicon('alert', { fontCharacter: '\\\\ea6c' });\nCodicon.warning = new Codicon('warning', { fontCharacter: '\\\\ea6c' });\nCodicon.search = new Codicon('search', { fontCharacter: '\\\\ea6d' });\nCodicon.searchSave = new Codicon('search-save', { fontCharacter: '\\\\ea6d' });\nCodicon.logOut = new Codicon('log-out', { fontCharacter: '\\\\ea6e' });\nCodicon.signOut = new Codicon('sign-out', { fontCharacter: '\\\\ea6e' });\nCodicon.logIn = new Codicon('log-in', { fontCharacter: '\\\\ea6f' });\nCodicon.signIn = new Codicon('sign-in', { fontCharacter: '\\\\ea6f' });\nCodicon.eye = new Codicon('eye', { fontCharacter: '\\\\ea70' });\nCodicon.eyeUnwatch = new Codicon('eye-unwatch', { fontCharacter: '\\\\ea70' });\nCodicon.eyeWatch = new Codicon('eye-watch', { fontCharacter: '\\\\ea70' });\nCodicon.circleFilled = new Codicon('circle-filled', { fontCharacter: '\\\\ea71' });\nCodicon.primitiveDot = new Codicon('primitive-dot', { fontCharacter: '\\\\ea71' });\nCodicon.closeDirty = new Codicon('close-dirty', { fontCharacter: '\\\\ea71' });\nCodicon.debugBreakpoint = new Codicon('debug-breakpoint', { fontCharacter: '\\\\ea71' });\nCodicon.debugBreakpointDisabled = new Codicon('debug-breakpoint-disabled', { fontCharacter: '\\\\ea71' });\nCodicon.debugHint = new Codicon('debug-hint', { fontCharacter: '\\\\ea71' });\nCodicon.primitiveSquare = new Codicon('primitive-square', { fontCharacter: '\\\\ea72' });\nCodicon.edit = new Codicon('edit', { fontCharacter: '\\\\ea73' });\nCodicon.pencil = new Codicon('pencil', { fontCharacter: '\\\\ea73' });\nCodicon.info = new Codicon('info', { fontCharacter: '\\\\ea74' });\nCodicon.issueOpened = new Codicon('issue-opened', { fontCharacter: '\\\\ea74' });\nCodicon.gistPrivate = new Codicon('gist-private', { fontCharacter: '\\\\ea75' });\nCodicon.gitForkPrivate = new Codicon('git-fork-private', { fontCharacter: '\\\\ea75' });\nCodicon.lock = new Codicon('lock', { fontCharacter: '\\\\ea75' });\nCodicon.mirrorPrivate = new Codicon('mirror-private', { fontCharacter: '\\\\ea75' });\nCodicon.close = new Codicon('close', { fontCharacter: '\\\\ea76' });\nCodicon.removeClose = new Codicon('remove-close', { fontCharacter: '\\\\ea76' });\nCodicon.x = new Codicon('x', { fontCharacter: '\\\\ea76' });\nCodicon.repoSync = new Codicon('repo-sync', { fontCharacter: '\\\\ea77' });\nCodicon.sync = new Codicon('sync', { fontCharacter: '\\\\ea77' });\nCodicon.clone = new Codicon('clone', { fontCharacter: '\\\\ea78' });\nCodicon.desktopDownload = new Codicon('desktop-download', { fontCharacter: '\\\\ea78' });\nCodicon.beaker = new Codicon('beaker', { fontCharacter: '\\\\ea79' });\nCodicon.microscope = new Codicon('microscope', { fontCharacter: '\\\\ea79' });\nCodicon.vm = new Codicon('vm', { fontCharacter: '\\\\ea7a' });\nCodicon.deviceDesktop = new Codicon('device-desktop', { fontCharacter: '\\\\ea7a' });\nCodicon.file = new Codicon('file', { fontCharacter: '\\\\ea7b' });\nCodicon.fileText = new Codicon('file-text', { fontCharacter: '\\\\ea7b' });\nCodicon.more = new Codicon('more', { fontCharacter: '\\\\ea7c' });\nCodicon.ellipsis = new Codicon('ellipsis', { fontCharacter: '\\\\ea7c' });\nCodicon.kebabHorizontal = new Codicon('kebab-horizontal', { fontCharacter: '\\\\ea7c' });\nCodicon.mailReply = new Codicon('mail-reply', { fontCharacter: '\\\\ea7d' });\nCodicon.reply = new Codicon('reply', { fontCharacter: '\\\\ea7d' });\nCodicon.organization = new Codicon('organization', { fontCharacter: '\\\\ea7e' });\nCodicon.organizationFilled = new Codicon('organization-filled', { fontCharacter: '\\\\ea7e' });\nCodicon.organizationOutline = new Codicon('organization-outline', { fontCharacter: '\\\\ea7e' });\nCodicon.newFile = new Codicon('new-file', { fontCharacter: '\\\\ea7f' });\nCodicon.fileAdd = new Codicon('file-add', { fontCharacter: '\\\\ea7f' });\nCodicon.newFolder = new Codicon('new-folder', { fontCharacter: '\\\\ea80' });\nCodicon.fileDirectoryCreate = new Codicon('file-directory-create', { fontCharacter: '\\\\ea80' });\nCodicon.trash = new Codicon('trash', { fontCharacter: '\\\\ea81' });\nCodicon.trashcan = new Codicon('trashcan', { fontCharacter: '\\\\ea81' });\nCodicon.history = new Codicon('history', { fontCharacter: '\\\\ea82' });\nCodicon.clock = new Codicon('clock', { fontCharacter: '\\\\ea82' });\nCodicon.folder = new Codicon('folder', { fontCharacter: '\\\\ea83' });\nCodicon.fileDirectory = new Codicon('file-directory', { fontCharacter: '\\\\ea83' });\nCodicon.symbolFolder = new Codicon('symbol-folder', { fontCharacter: '\\\\ea83' });\nCodicon.logoGithub = new Codicon('logo-github', { fontCharacter: '\\\\ea84' });\nCodicon.markGithub = new Codicon('mark-github', { fontCharacter: '\\\\ea84' });\nCodicon.github = new Codicon('github', { fontCharacter: '\\\\ea84' });\nCodicon.terminal = new Codicon('terminal', { fontCharacter: '\\\\ea85' });\nCodicon.console = new Codicon('console', { fontCharacter: '\\\\ea85' });\nCodicon.repl = new Codicon('repl', { fontCharacter: '\\\\ea85' });\nCodicon.zap = new Codicon('zap', { fontCharacter: '\\\\ea86' });\nCodicon.symbolEvent = new Codicon('symbol-event', { fontCharacter: '\\\\ea86' });\nCodicon.error = new Codicon('error', { fontCharacter: '\\\\ea87' });\nCodicon.stop = new Codicon('stop', { fontCharacter: '\\\\ea87' });\nCodicon.variable = new Codicon('variable', { fontCharacter: '\\\\ea88' });\nCodicon.symbolVariable = new Codicon('symbol-variable', { fontCharacter: '\\\\ea88' });\nCodicon.array = new Codicon('array', { fontCharacter: '\\\\ea8a' });\nCodicon.symbolArray = new Codicon('symbol-array', { fontCharacter: '\\\\ea8a' });\nCodicon.symbolModule = new Codicon('symbol-module', { fontCharacter: '\\\\ea8b' });\nCodicon.symbolPackage = new Codicon('symbol-package', { fontCharacter: '\\\\ea8b' });\nCodicon.symbolNamespace = new Codicon('symbol-namespace', { fontCharacter: '\\\\ea8b' });\nCodicon.symbolObject = new Codicon('symbol-object', { fontCharacter: '\\\\ea8b' });\nCodicon.symbolMethod = new Codicon('symbol-method', { fontCharacter: '\\\\ea8c' });\nCodicon.symbolFunction = new Codicon('symbol-function', { fontCharacter: '\\\\ea8c' });\nCodicon.symbolConstructor = new Codicon('symbol-constructor', { fontCharacter: '\\\\ea8c' });\nCodicon.symbolBoolean = new Codicon('symbol-boolean', { fontCharacter: '\\\\ea8f' });\nCodicon.symbolNull = new Codicon('symbol-null', { fontCharacter: '\\\\ea8f' });\nCodicon.symbolNumeric = new Codicon('symbol-numeric', { fontCharacter: '\\\\ea90' });\nCodicon.symbolNumber = new Codicon('symbol-number', { fontCharacter: '\\\\ea90' });\nCodicon.symbolStructure = new Codicon('symbol-structure', { fontCharacter: '\\\\ea91' });\nCodicon.symbolStruct = new Codicon('symbol-struct', { fontCharacter: '\\\\ea91' });\nCodicon.symbolParameter = new Codicon('symbol-parameter', { fontCharacter: '\\\\ea92' });\nCodicon.symbolTypeParameter = new Codicon('symbol-type-parameter', { fontCharacter: '\\\\ea92' });\nCodicon.symbolKey = new Codicon('symbol-key', { fontCharacter: '\\\\ea93' });\nCodicon.symbolText = new Codicon('symbol-text', { fontCharacter: '\\\\ea93' });\nCodicon.symbolReference = new Codicon('symbol-reference', { fontCharacter: '\\\\ea94' });\nCodicon.goToFile = new Codicon('go-to-file', { fontCharacter: '\\\\ea94' });\nCodicon.symbolEnum = new Codicon('symbol-enum', { fontCharacter: '\\\\ea95' });\nCodicon.symbolValue = new Codicon('symbol-value', { fontCharacter: '\\\\ea95' });\nCodicon.symbolRuler = new Codicon('symbol-ruler', { fontCharacter: '\\\\ea96' });\nCodicon.symbolUnit = new Codicon('symbol-unit', { fontCharacter: '\\\\ea96' });\nCodicon.activateBreakpoints = new Codicon('activate-breakpoints', { fontCharacter: '\\\\ea97' });\nCodicon.archive = new Codicon('archive', { fontCharacter: '\\\\ea98' });\nCodicon.arrowBoth = new Codicon('arrow-both', { fontCharacter: '\\\\ea99' });\nCodicon.arrowDown = new Codicon('arrow-down', { fontCharacter: '\\\\ea9a' });\nCodicon.arrowLeft = new Codicon('arrow-left', { fontCharacter: '\\\\ea9b' });\nCodicon.arrowRight = new Codicon('arrow-right', { fontCharacter: '\\\\ea9c' });\nCodicon.arrowSmallDown = new Codicon('arrow-small-down', { fontCharacter: '\\\\ea9d' });\nCodicon.arrowSmallLeft = new Codicon('arrow-small-left', { fontCharacter: '\\\\ea9e' });\nCodicon.arrowSmallRight = new Codicon('arrow-small-right', { fontCharacter: '\\\\ea9f' });\nCodicon.arrowSmallUp = new Codicon('arrow-small-up', { fontCharacter: '\\\\eaa0' });\nCodicon.arrowUp = new Codicon('arrow-up', { fontCharacter: '\\\\eaa1' });\nCodicon.bell = new Codicon('bell', { fontCharacter: '\\\\eaa2' });\nCodicon.bold = new Codicon('bold', { fontCharacter: '\\\\eaa3' });\nCodicon.book = new Codicon('book', { fontCharacter: '\\\\eaa4' });\nCodicon.bookmark = new Codicon('bookmark', { fontCharacter: '\\\\eaa5' });\nCodicon.debugBreakpointConditionalUnverified = new Codicon('debug-breakpoint-conditional-unverified', { fontCharacter: '\\\\eaa6' });\nCodicon.debugBreakpointConditional = new Codicon('debug-breakpoint-conditional', { fontCharacter: '\\\\eaa7' });\nCodicon.debugBreakpointConditionalDisabled = new Codicon('debug-breakpoint-conditional-disabled', { fontCharacter: '\\\\eaa7' });\nCodicon.debugBreakpointDataUnverified = new Codicon('debug-breakpoint-data-unverified', { fontCharacter: '\\\\eaa8' });\nCodicon.debugBreakpointData = new Codicon('debug-breakpoint-data', { fontCharacter: '\\\\eaa9' });\nCodicon.debugBreakpointDataDisabled = new Codicon('debug-breakpoint-data-disabled', { fontCharacter: '\\\\eaa9' });\nCodicon.debugBreakpointLogUnverified = new Codicon('debug-breakpoint-log-unverified', { fontCharacter: '\\\\eaaa' });\nCodicon.debugBreakpointLog = new Codicon('debug-breakpoint-log', { fontCharacter: '\\\\eaab' });\nCodicon.debugBreakpointLogDisabled = new Codicon('debug-breakpoint-log-disabled', { fontCharacter: '\\\\eaab' });\nCodicon.briefcase = new Codicon('briefcase', { fontCharacter: '\\\\eaac' });\nCodicon.broadcast = new Codicon('broadcast', { fontCharacter: '\\\\eaad' });\nCodicon.browser = new Codicon('browser', { fontCharacter: '\\\\eaae' });\nCodicon.bug = new Codicon('bug', { fontCharacter: '\\\\eaaf' });\nCodicon.calendar = new Codicon('calendar', { fontCharacter: '\\\\eab0' });\nCodicon.caseSensitive = new Codicon('case-sensitive', { fontCharacter: '\\\\eab1' });\nCodicon.check = new Codicon('check', { fontCharacter: '\\\\eab2' });\nCodicon.checklist = new Codicon('checklist', { fontCharacter: '\\\\eab3' });\nCodicon.chevronDown = new Codicon('chevron-down', { fontCharacter: '\\\\eab4' });\nCodicon.dropDownButton = new Codicon('drop-down-button', Codicon.chevronDown.definition);\nCodicon.chevronLeft = new Codicon('chevron-left', { fontCharacter: '\\\\eab5' });\nCodicon.chevronRight = new Codicon('chevron-right', { fontCharacter: '\\\\eab6' });\nCodicon.chevronUp = new Codicon('chevron-up', { fontCharacter: '\\\\eab7' });\nCodicon.chromeClose = new Codicon('chrome-close', { fontCharacter: '\\\\eab8' });\nCodicon.chromeMaximize = new Codicon('chrome-maximize', { fontCharacter: '\\\\eab9' });\nCodicon.chromeMinimize = new Codicon('chrome-minimize', { fontCharacter: '\\\\eaba' });\nCodicon.chromeRestore = new Codicon('chrome-restore', { fontCharacter: '\\\\eabb' });\nCodicon.circleOutline = new Codicon('circle-outline', { fontCharacter: '\\\\eabc' });\nCodicon.debugBreakpointUnverified = new Codicon('debug-breakpoint-unverified', { fontCharacter: '\\\\eabc' });\nCodicon.circleSlash = new Codicon('circle-slash', { fontCharacter: '\\\\eabd' });\nCodicon.circuitBoard = new Codicon('circuit-board', { fontCharacter: '\\\\eabe' });\nCodicon.clearAll = new Codicon('clear-all', { fontCharacter: '\\\\eabf' });\nCodicon.clippy = new Codicon('clippy', { fontCharacter: '\\\\eac0' });\nCodicon.closeAll = new Codicon('close-all', { fontCharacter: '\\\\eac1' });\nCodicon.cloudDownload = new Codicon('cloud-download', { fontCharacter: '\\\\eac2' });\nCodicon.cloudUpload = new Codicon('cloud-upload', { fontCharacter: '\\\\eac3' });\nCodicon.code = new Codicon('code', { fontCharacter: '\\\\eac4' });\nCodicon.collapseAll = new Codicon('collapse-all', { fontCharacter: '\\\\eac5' });\nCodicon.colorMode = new Codicon('color-mode', { fontCharacter: '\\\\eac6' });\nCodicon.commentDiscussion = new Codicon('comment-discussion', { fontCharacter: '\\\\eac7' });\nCodicon.compareChanges = new Codicon('compare-changes', { fontCharacter: '\\\\eafd' });\nCodicon.creditCard = new Codicon('credit-card', { fontCharacter: '\\\\eac9' });\nCodicon.dash = new Codicon('dash', { fontCharacter: '\\\\eacc' });\nCodicon.dashboard = new Codicon('dashboard', { fontCharacter: '\\\\eacd' });\nCodicon.database = new Codicon('database', { fontCharacter: '\\\\eace' });\nCodicon.debugContinue = new Codicon('debug-continue', { fontCharacter: '\\\\eacf' });\nCodicon.debugDisconnect = new Codicon('debug-disconnect', { fontCharacter: '\\\\ead0' });\nCodicon.debugPause = new Codicon('debug-pause', { fontCharacter: '\\\\ead1' });\nCodicon.debugRestart = new Codicon('debug-restart', { fontCharacter: '\\\\ead2' });\nCodicon.debugStart = new Codicon('debug-start', { fontCharacter: '\\\\ead3' });\nCodicon.debugStepInto = new Codicon('debug-step-into', { fontCharacter: '\\\\ead4' });\nCodicon.debugStepOut = new Codicon('debug-step-out', { fontCharacter: '\\\\ead5' });\nCodicon.debugStepOver = new Codicon('debug-step-over', { fontCharacter: '\\\\ead6' });\nCodicon.debugStop = new Codicon('debug-stop', { fontCharacter: '\\\\ead7' });\nCodicon.debug = new Codicon('debug', { fontCharacter: '\\\\ead8' });\nCodicon.deviceCameraVideo = new Codicon('device-camera-video', { fontCharacter: '\\\\ead9' });\nCodicon.deviceCamera = new Codicon('device-camera', { fontCharacter: '\\\\eada' });\nCodicon.deviceMobile = new Codicon('device-mobile', { fontCharacter: '\\\\eadb' });\nCodicon.diffAdded = new Codicon('diff-added', { fontCharacter: '\\\\eadc' });\nCodicon.diffIgnored = new Codicon('diff-ignored', { fontCharacter: '\\\\eadd' });\nCodicon.diffModified = new Codicon('diff-modified', { fontCharacter: '\\\\eade' });\nCodicon.diffRemoved = new Codicon('diff-removed', { fontCharacter: '\\\\eadf' });\nCodicon.diffRenamed = new Codicon('diff-renamed', { fontCharacter: '\\\\eae0' });\nCodicon.diff = new Codicon('diff', { fontCharacter: '\\\\eae1' });\nCodicon.discard = new Codicon('discard', { fontCharacter: '\\\\eae2' });\nCodicon.editorLayout = new Codicon('editor-layout', { fontCharacter: '\\\\eae3' });\nCodicon.emptyWindow = new Codicon('empty-window', { fontCharacter: '\\\\eae4' });\nCodicon.exclude = new Codicon('exclude', { fontCharacter: '\\\\eae5' });\nCodicon.extensions = new Codicon('extensions', { fontCharacter: '\\\\eae6' });\nCodicon.eyeClosed = new Codicon('eye-closed', { fontCharacter: '\\\\eae7' });\nCodicon.fileBinary = new Codicon('file-binary', { fontCharacter: '\\\\eae8' });\nCodicon.fileCode = new Codicon('file-code', { fontCharacter: '\\\\eae9' });\nCodicon.fileMedia = new Codicon('file-media', { fontCharacter: '\\\\eaea' });\nCodicon.filePdf = new Codicon('file-pdf', { fontCharacter: '\\\\eaeb' });\nCodicon.fileSubmodule = new Codicon('file-submodule', { fontCharacter: '\\\\eaec' });\nCodicon.fileSymlinkDirectory = new Codicon('file-symlink-directory', { fontCharacter: '\\\\eaed' });\nCodicon.fileSymlinkFile = new Codicon('file-symlink-file', { fontCharacter: '\\\\eaee' });\nCodicon.fileZip = new Codicon('file-zip', { fontCharacter: '\\\\eaef' });\nCodicon.files = new Codicon('files', { fontCharacter: '\\\\eaf0' });\nCodicon.filter = new Codicon('filter', { fontCharacter: '\\\\eaf1' });\nCodicon.flame = new Codicon('flame', { fontCharacter: '\\\\eaf2' });\nCodicon.foldDown = new Codicon('fold-down', { fontCharacter: '\\\\eaf3' });\nCodicon.foldUp = new Codicon('fold-up', { fontCharacter: '\\\\eaf4' });\nCodicon.fold = new Codicon('fold', { fontCharacter: '\\\\eaf5' });\nCodicon.folderActive = new Codicon('folder-active', { fontCharacter: '\\\\eaf6' });\nCodicon.folderOpened = new Codicon('folder-opened', { fontCharacter: '\\\\eaf7' });\nCodicon.gear = new Codicon('gear', { fontCharacter: '\\\\eaf8' });\nCodicon.gift = new Codicon('gift', { fontCharacter: '\\\\eaf9' });\nCodicon.gistSecret = new Codicon('gist-secret', { fontCharacter: '\\\\eafa' });\nCodicon.gist = new Codicon('gist', { fontCharacter: '\\\\eafb' });\nCodicon.gitCommit = new Codicon('git-commit', { fontCharacter: '\\\\eafc' });\nCodicon.gitCompare = new Codicon('git-compare', { fontCharacter: '\\\\eafd' });\nCodicon.gitMerge = new Codicon('git-merge', { fontCharacter: '\\\\eafe' });\nCodicon.githubAction = new Codicon('github-action', { fontCharacter: '\\\\eaff' });\nCodicon.githubAlt = new Codicon('github-alt', { fontCharacter: '\\\\eb00' });\nCodicon.globe = new Codicon('globe', { fontCharacter: '\\\\eb01' });\nCodicon.grabber = new Codicon('grabber', { fontCharacter: '\\\\eb02' });\nCodicon.graph = new Codicon('graph', { fontCharacter: '\\\\eb03' });\nCodicon.gripper = new Codicon('gripper', { fontCharacter: '\\\\eb04' });\nCodicon.heart = new Codicon('heart', { fontCharacter: '\\\\eb05' });\nCodicon.home = new Codicon('home', { fontCharacter: '\\\\eb06' });\nCodicon.horizontalRule = new Codicon('horizontal-rule', { fontCharacter: '\\\\eb07' });\nCodicon.hubot = new Codicon('hubot', { fontCharacter: '\\\\eb08' });\nCodicon.inbox = new Codicon('inbox', { fontCharacter: '\\\\eb09' });\nCodicon.issueClosed = new Codicon('issue-closed', { fontCharacter: '\\\\eba4' });\nCodicon.issueReopened = new Codicon('issue-reopened', { fontCharacter: '\\\\eb0b' });\nCodicon.issues = new Codicon('issues', { fontCharacter: '\\\\eb0c' });\nCodicon.italic = new Codicon('italic', { fontCharacter: '\\\\eb0d' });\nCodicon.jersey = new Codicon('jersey', { fontCharacter: '\\\\eb0e' });\nCodicon.json = new Codicon('json', { fontCharacter: '\\\\eb0f' });\nCodicon.kebabVertical = new Codicon('kebab-vertical', { fontCharacter: '\\\\eb10' });\nCodicon.key = new Codicon('key', { fontCharacter: '\\\\eb11' });\nCodicon.law = new Codicon('law', { fontCharacter: '\\\\eb12' });\nCodicon.lightbulbAutofix = new Codicon('lightbulb-autofix', { fontCharacter: '\\\\eb13' });\nCodicon.linkExternal = new Codicon('link-external', { fontCharacter: '\\\\eb14' });\nCodicon.link = new Codicon('link', { fontCharacter: '\\\\eb15' });\nCodicon.listOrdered = new Codicon('list-ordered', { fontCharacter: '\\\\eb16' });\nCodicon.listUnordered = new Codicon('list-unordered', { fontCharacter: '\\\\eb17' });\nCodicon.liveShare = new Codicon('live-share', { fontCharacter: '\\\\eb18' });\nCodicon.loading = new Codicon('loading', { fontCharacter: '\\\\eb19' });\nCodicon.location = new Codicon('location', { fontCharacter: '\\\\eb1a' });\nCodicon.mailRead = new Codicon('mail-read', { fontCharacter: '\\\\eb1b' });\nCodicon.mail = new Codicon('mail', { fontCharacter: '\\\\eb1c' });\nCodicon.markdown = new Codicon('markdown', { fontCharacter: '\\\\eb1d' });\nCodicon.megaphone = new Codicon('megaphone', { fontCharacter: '\\\\eb1e' });\nCodicon.mention = new Codicon('mention', { fontCharacter: '\\\\eb1f' });\nCodicon.milestone = new Codicon('milestone', { fontCharacter: '\\\\eb20' });\nCodicon.mortarBoard = new Codicon('mortar-board', { fontCharacter: '\\\\eb21' });\nCodicon.move = new Codicon('move', { fontCharacter: '\\\\eb22' });\nCodicon.multipleWindows = new Codicon('multiple-windows', { fontCharacter: '\\\\eb23' });\nCodicon.mute = new Codicon('mute', { fontCharacter: '\\\\eb24' });\nCodicon.noNewline = new Codicon('no-newline', { fontCharacter: '\\\\eb25' });\nCodicon.note = new Codicon('note', { fontCharacter: '\\\\eb26' });\nCodicon.octoface = new Codicon('octoface', { fontCharacter: '\\\\eb27' });\nCodicon.openPreview = new Codicon('open-preview', { fontCharacter: '\\\\eb28' });\nCodicon.package_ = new Codicon('package', { fontCharacter: '\\\\eb29' });\nCodicon.paintcan = new Codicon('paintcan', { fontCharacter: '\\\\eb2a' });\nCodicon.pin = new Codicon('pin', { fontCharacter: '\\\\eb2b' });\nCodicon.play = new Codicon('play', { fontCharacter: '\\\\eb2c' });\nCodicon.run = new Codicon('run', { fontCharacter: '\\\\eb2c' });\nCodicon.plug = new Codicon('plug', { fontCharacter: '\\\\eb2d' });\nCodicon.preserveCase = new Codicon('preserve-case', { fontCharacter: '\\\\eb2e' });\nCodicon.preview = new Codicon('preview', { fontCharacter: '\\\\eb2f' });\nCodicon.project = new Codicon('project', { fontCharacter: '\\\\eb30' });\nCodicon.pulse = new Codicon('pulse', { fontCharacter: '\\\\eb31' });\nCodicon.question = new Codicon('question', { fontCharacter: '\\\\eb32' });\nCodicon.quote = new Codicon('quote', { fontCharacter: '\\\\eb33' });\nCodicon.radioTower = new Codicon('radio-tower', { fontCharacter: '\\\\eb34' });\nCodicon.reactions = new Codicon('reactions', { fontCharacter: '\\\\eb35' });\nCodicon.references = new Codicon('references', { fontCharacter: '\\\\eb36' });\nCodicon.refresh = new Codicon('refresh', { fontCharacter: '\\\\eb37' });\nCodicon.regex = new Codicon('regex', { fontCharacter: '\\\\eb38' });\nCodicon.remoteExplorer = new Codicon('remote-explorer', { fontCharacter: '\\\\eb39' });\nCodicon.remote = new Codicon('remote', { fontCharacter: '\\\\eb3a' });\nCodicon.remove = new Codicon('remove', { fontCharacter: '\\\\eb3b' });\nCodicon.replaceAll = new Codicon('replace-all', { fontCharacter: '\\\\eb3c' });\nCodicon.replace = new Codicon('replace', { fontCharacter: '\\\\eb3d' });\nCodicon.repoClone = new Codicon('repo-clone', { fontCharacter: '\\\\eb3e' });\nCodicon.repoForcePush = new Codicon('repo-force-push', { fontCharacter: '\\\\eb3f' });\nCodicon.repoPull = new Codicon('repo-pull', { fontCharacter: '\\\\eb40' });\nCodicon.repoPush = new Codicon('repo-push', { fontCharacter: '\\\\eb41' });\nCodicon.report = new Codicon('report', { fontCharacter: '\\\\eb42' });\nCodicon.requestChanges = new Codicon('request-changes', { fontCharacter: '\\\\eb43' });\nCodicon.rocket = new Codicon('rocket', { fontCharacter: '\\\\eb44' });\nCodicon.rootFolderOpened = new Codicon('root-folder-opened', { fontCharacter: '\\\\eb45' });\nCodicon.rootFolder = new Codicon('root-folder', { fontCharacter: '\\\\eb46' });\nCodicon.rss = new Codicon('rss', { fontCharacter: '\\\\eb47' });\nCodicon.ruby = new Codicon('ruby', { fontCharacter: '\\\\eb48' });\nCodicon.saveAll = new Codicon('save-all', { fontCharacter: '\\\\eb49' });\nCodicon.saveAs = new Codicon('save-as', { fontCharacter: '\\\\eb4a' });\nCodicon.save = new Codicon('save', { fontCharacter: '\\\\eb4b' });\nCodicon.screenFull = new Codicon('screen-full', { fontCharacter: '\\\\eb4c' });\nCodicon.screenNormal = new Codicon('screen-normal', { fontCharacter: '\\\\eb4d' });\nCodicon.searchStop = new Codicon('search-stop', { fontCharacter: '\\\\eb4e' });\nCodicon.server = new Codicon('server', { fontCharacter: '\\\\eb50' });\nCodicon.settingsGear = new Codicon('settings-gear', { fontCharacter: '\\\\eb51' });\nCodicon.settings = new Codicon('settings', { fontCharacter: '\\\\eb52' });\nCodicon.shield = new Codicon('shield', { fontCharacter: '\\\\eb53' });\nCodicon.smiley = new Codicon('smiley', { fontCharacter: '\\\\eb54' });\nCodicon.sortPrecedence = new Codicon('sort-precedence', { fontCharacter: '\\\\eb55' });\nCodicon.splitHorizontal = new Codicon('split-horizontal', { fontCharacter: '\\\\eb56' });\nCodicon.splitVertical = new Codicon('split-vertical', { fontCharacter: '\\\\eb57' });\nCodicon.squirrel = new Codicon('squirrel', { fontCharacter: '\\\\eb58' });\nCodicon.starFull = new Codicon('star-full', { fontCharacter: '\\\\eb59' });\nCodicon.starHalf = new Codicon('star-half', { fontCharacter: '\\\\eb5a' });\nCodicon.symbolClass = new Codicon('symbol-class', { fontCharacter: '\\\\eb5b' });\nCodicon.symbolColor = new Codicon('symbol-color', { fontCharacter: '\\\\eb5c' });\nCodicon.symbolCustomColor = new Codicon('symbol-customcolor', { fontCharacter: '\\\\eb5c' });\nCodicon.symbolConstant = new Codicon('symbol-constant', { fontCharacter: '\\\\eb5d' });\nCodicon.symbolEnumMember = new Codicon('symbol-enum-member', { fontCharacter: '\\\\eb5e' });\nCodicon.symbolField = new Codicon('symbol-field', { fontCharacter: '\\\\eb5f' });\nCodicon.symbolFile = new Codicon('symbol-file', { fontCharacter: '\\\\eb60' });\nCodicon.symbolInterface = new Codicon('symbol-interface', { fontCharacter: '\\\\eb61' });\nCodicon.symbolKeyword = new Codicon('symbol-keyword', { fontCharacter: '\\\\eb62' });\nCodicon.symbolMisc = new Codicon('symbol-misc', { fontCharacter: '\\\\eb63' });\nCodicon.symbolOperator = new Codicon('symbol-operator', { fontCharacter: '\\\\eb64' });\nCodicon.symbolProperty = new Codicon('symbol-property', { fontCharacter: '\\\\eb65' });\nCodicon.wrench = new Codicon('wrench', { fontCharacter: '\\\\eb65' });\nCodicon.wrenchSubaction = new Codicon('wrench-subaction', { fontCharacter: '\\\\eb65' });\nCodicon.symbolSnippet = new Codicon('symbol-snippet', { fontCharacter: '\\\\eb66' });\nCodicon.tasklist = new Codicon('tasklist', { fontCharacter: '\\\\eb67' });\nCodicon.telescope = new Codicon('telescope', { fontCharacter: '\\\\eb68' });\nCodicon.textSize = new Codicon('text-size', { fontCharacter: '\\\\eb69' });\nCodicon.threeBars = new Codicon('three-bars', { fontCharacter: '\\\\eb6a' });\nCodicon.thumbsdown = new Codicon('thumbsdown', { fontCharacter: '\\\\eb6b' });\nCodicon.thumbsup = new Codicon('thumbsup', { fontCharacter: '\\\\eb6c' });\nCodicon.tools = new Codicon('tools', { fontCharacter: '\\\\eb6d' });\nCodicon.triangleDown = new Codicon('triangle-down', { fontCharacter: '\\\\eb6e' });\nCodicon.triangleLeft = new Codicon('triangle-left', { fontCharacter: '\\\\eb6f' });\nCodicon.triangleRight = new Codicon('triangle-right', { fontCharacter: '\\\\eb70' });\nCodicon.triangleUp = new Codicon('triangle-up', { fontCharacter: '\\\\eb71' });\nCodicon.twitter = new Codicon('twitter', { fontCharacter: '\\\\eb72' });\nCodicon.unfold = new Codicon('unfold', { fontCharacter: '\\\\eb73' });\nCodicon.unlock = new Codicon('unlock', { fontCharacter: '\\\\eb74' });\nCodicon.unmute = new Codicon('unmute', { fontCharacter: '\\\\eb75' });\nCodicon.unverified = new Codicon('unverified', { fontCharacter: '\\\\eb76' });\nCodicon.verified = new Codicon('verified', { fontCharacter: '\\\\eb77' });\nCodicon.versions = new Codicon('versions', { fontCharacter: '\\\\eb78' });\nCodicon.vmActive = new Codicon('vm-active', { fontCharacter: '\\\\eb79' });\nCodicon.vmOutline = new Codicon('vm-outline', { fontCharacter: '\\\\eb7a' });\nCodicon.vmRunning = new Codicon('vm-running', { fontCharacter: '\\\\eb7b' });\nCodicon.watch = new Codicon('watch', { fontCharacter: '\\\\eb7c' });\nCodicon.whitespace = new Codicon('whitespace', { fontCharacter: '\\\\eb7d' });\nCodicon.wholeWord = new Codicon('whole-word', { fontCharacter: '\\\\eb7e' });\nCodicon.window = new Codicon('window', { fontCharacter: '\\\\eb7f' });\nCodicon.wordWrap = new Codicon('word-wrap', { fontCharacter: '\\\\eb80' });\nCodicon.zoomIn = new Codicon('zoom-in', { fontCharacter: '\\\\eb81' });\nCodicon.zoomOut = new Codicon('zoom-out', { fontCharacter: '\\\\eb82' });\nCodicon.listFilter = new Codicon('list-filter', { fontCharacter: '\\\\eb83' });\nCodicon.listFlat = new Codicon('list-flat', { fontCharacter: '\\\\eb84' });\nCodicon.listSelection = new Codicon('list-selection', { fontCharacter: '\\\\eb85' });\nCodicon.selection = new Codicon('selection', { fontCharacter: '\\\\eb85' });\nCodicon.listTree = new Codicon('list-tree', { fontCharacter: '\\\\eb86' });\nCodicon.debugBreakpointFunctionUnverified = new Codicon('debug-breakpoint-function-unverified', { fontCharacter: '\\\\eb87' });\nCodicon.debugBreakpointFunction = new Codicon('debug-breakpoint-function', { fontCharacter: '\\\\eb88' });\nCodicon.debugBreakpointFunctionDisabled = new Codicon('debug-breakpoint-function-disabled', { fontCharacter: '\\\\eb88' });\nCodicon.debugStackframeActive = new Codicon('debug-stackframe-active', { fontCharacter: '\\\\eb89' });\nCodicon.circleSmallFilled = new Codicon('circle-small-filled', { fontCharacter: '\\\\eb8a' });\nCodicon.debugStackframeDot = new Codicon('debug-stackframe-dot', Codicon.circleSmallFilled.definition);\nCodicon.debugStackframe = new Codicon('debug-stackframe', { fontCharacter: '\\\\eb8b' });\nCodicon.debugStackframeFocused = new Codicon('debug-stackframe-focused', { fontCharacter: '\\\\eb8b' });\nCodicon.debugBreakpointUnsupported = new Codicon('debug-breakpoint-unsupported', { fontCharacter: '\\\\eb8c' });\nCodicon.symbolString = new Codicon('symbol-string', { fontCharacter: '\\\\eb8d' });\nCodicon.debugReverseContinue = new Codicon('debug-reverse-continue', { fontCharacter: '\\\\eb8e' });\nCodicon.debugStepBack = new Codicon('debug-step-back', { fontCharacter: '\\\\eb8f' });\nCodicon.debugRestartFrame = new Codicon('debug-restart-frame', { fontCharacter: '\\\\eb90' });\nCodicon.callIncoming = new Codicon('call-incoming', { fontCharacter: '\\\\eb92' });\nCodicon.callOutgoing = new Codicon('call-outgoing', { fontCharacter: '\\\\eb93' });\nCodicon.menu = new Codicon('menu', { fontCharacter: '\\\\eb94' });\nCodicon.expandAll = new Codicon('expand-all', { fontCharacter: '\\\\eb95' });\nCodicon.feedback = new Codicon('feedback', { fontCharacter: '\\\\eb96' });\nCodicon.groupByRefType = new Codicon('group-by-ref-type', { fontCharacter: '\\\\eb97' });\nCodicon.ungroupByRefType = new Codicon('ungroup-by-ref-type', { fontCharacter: '\\\\eb98' });\nCodicon.account = new Codicon('account', { fontCharacter: '\\\\eb99' });\nCodicon.bellDot = new Codicon('bell-dot', { fontCharacter: '\\\\eb9a' });\nCodicon.debugConsole = new Codicon('debug-console', { fontCharacter: '\\\\eb9b' });\nCodicon.library = new Codicon('library', { fontCharacter: '\\\\eb9c' });\nCodicon.output = new Codicon('output', { fontCharacter: '\\\\eb9d' });\nCodicon.runAll = new Codicon('run-all', { fontCharacter: '\\\\eb9e' });\nCodicon.syncIgnored = new Codicon('sync-ignored', { fontCharacter: '\\\\eb9f' });\nCodicon.pinned = new Codicon('pinned', { fontCharacter: '\\\\eba0' });\nCodicon.githubInverted = new Codicon('github-inverted', { fontCharacter: '\\\\eba1' });\nCodicon.debugAlt = new Codicon('debug-alt', { fontCharacter: '\\\\eb91' });\nCodicon.serverProcess = new Codicon('server-process', { fontCharacter: '\\\\eba2' });\nCodicon.serverEnvironment = new Codicon('server-environment', { fontCharacter: '\\\\eba3' });\nCodicon.pass = new Codicon('pass', { fontCharacter: '\\\\eba4' });\nCodicon.stopCircle = new Codicon('stop-circle', { fontCharacter: '\\\\eba5' });\nCodicon.playCircle = new Codicon('play-circle', { fontCharacter: '\\\\eba6' });\nCodicon.record = new Codicon('record', { fontCharacter: '\\\\eba7' });\nCodicon.debugAltSmall = new Codicon('debug-alt-small', { fontCharacter: '\\\\eba8' });\nCodicon.vmConnect = new Codicon('vm-connect', { fontCharacter: '\\\\eba9' });\nCodicon.cloud = new Codicon('cloud', { fontCharacter: '\\\\ebaa' });\nCodicon.merge = new Codicon('merge', { fontCharacter: '\\\\ebab' });\nCodicon.exportIcon = new Codicon('export', { fontCharacter: '\\\\ebac' });\nCodicon.graphLeft = new Codicon('graph-left', { fontCharacter: '\\\\ebad' });\nCodicon.magnet = new Codicon('magnet', { fontCharacter: '\\\\ebae' });\nCodicon.notebook = new Codicon('notebook', { fontCharacter: '\\\\ebaf' });\nCodicon.redo = new Codicon('redo', { fontCharacter: '\\\\ebb0' });\nCodicon.checkAll = new Codicon('check-all', { fontCharacter: '\\\\ebb1' });\nCodicon.pinnedDirty = new Codicon('pinned-dirty', { fontCharacter: '\\\\ebb2' });\nCodicon.passFilled = new Codicon('pass-filled', { fontCharacter: '\\\\ebb3' });\nCodicon.circleLargeFilled = new Codicon('circle-large-filled', { fontCharacter: '\\\\ebb4' });\nCodicon.circleLargeOutline = new Codicon('circle-large-outline', { fontCharacter: '\\\\ebb5' });\nCodicon.combine = new Codicon('combine', { fontCharacter: '\\\\ebb6' });\nCodicon.gather = new Codicon('gather', { fontCharacter: '\\\\ebb6' });\nCodicon.table = new Codicon('table', { fontCharacter: '\\\\ebb7' });\nCodicon.variableGroup = new Codicon('variable-group', { fontCharacter: '\\\\ebb8' });\nCodicon.typeHierarchy = new Codicon('type-hierarchy', { fontCharacter: '\\\\ebb9' });\nCodicon.typeHierarchySub = new Codicon('type-hierarchy-sub', { fontCharacter: '\\\\ebba' });\nCodicon.typeHierarchySuper = new Codicon('type-hierarchy-super', { fontCharacter: '\\\\ebbb' });\nCodicon.gitPullRequestCreate = new Codicon('git-pull-request-create', { fontCharacter: '\\\\ebbc' });\nCodicon.runAbove = new Codicon('run-above', { fontCharacter: '\\\\ebbd' });\nCodicon.runBelow = new Codicon('run-below', { fontCharacter: '\\\\ebbe' });\nCodicon.notebookTemplate = new Codicon('notebook-template', { fontCharacter: '\\\\ebbf' });\nCodicon.debugRerun = new Codicon('debug-rerun', { fontCharacter: '\\\\ebc0' });\nCodicon.workspaceTrusted = new Codicon('workspace-trusted', { fontCharacter: '\\\\ebc1' });\nCodicon.workspaceUntrusted = new Codicon('workspace-untrusted', { fontCharacter: '\\\\ebc2' });\nCodicon.workspaceUnspecified = new Codicon('workspace-unspecified', { fontCharacter: '\\\\ebc3' });\nCodicon.terminalCmd = new Codicon('terminal-cmd', { fontCharacter: '\\\\ebc4' });\nCodicon.terminalDebian = new Codicon('terminal-debian', { fontCharacter: '\\\\ebc5' });\nCodicon.terminalLinux = new Codicon('terminal-linux', { fontCharacter: '\\\\ebc6' });\nCodicon.terminalPowershell = new Codicon('terminal-powershell', { fontCharacter: '\\\\ebc7' });\nCodicon.terminalTmux = new Codicon('terminal-tmux', { fontCharacter: '\\\\ebc8' });\nCodicon.terminalUbuntu = new Codicon('terminal-ubuntu', { fontCharacter: '\\\\ebc9' });\nCodicon.terminalBash = new Codicon('terminal-bash', { fontCharacter: '\\\\ebca' });\nCodicon.arrowSwap = new Codicon('arrow-swap', { fontCharacter: '\\\\ebcb' });\nCodicon.copy = new Codicon('copy', { fontCharacter: '\\\\ebcc' });\nCodicon.personAdd = new Codicon('person-add', { fontCharacter: '\\\\ebcd' });\nCodicon.filterFilled = new Codicon('filter-filled', { fontCharacter: '\\\\ebce' });\nCodicon.wand = new Codicon('wand', { fontCharacter: '\\\\ebcf' });\nCodicon.debugLineByLine = new Codicon('debug-line-by-line', { fontCharacter: '\\\\ebd0' });\nCodicon.inspect = new Codicon('inspect', { fontCharacter: '\\\\ebd1' });\nCodicon.layers = new Codicon('layers', { fontCharacter: '\\\\ebd2' });\nCodicon.layersDot = new Codicon('layers-dot', { fontCharacter: '\\\\ebd3' });\nCodicon.layersActive = new Codicon('layers-active', { fontCharacter: '\\\\ebd4' });\nCodicon.compass = new Codicon('compass', { fontCharacter: '\\\\ebd5' });\nCodicon.compassDot = new Codicon('compass-dot', { fontCharacter: '\\\\ebd6' });\nCodicon.compassActive = new Codicon('compass-active', { fontCharacter: '\\\\ebd7' });\nCodicon.azure = new Codicon('azure', { fontCharacter: '\\\\ebd8' });\nCodicon.issueDraft = new Codicon('issue-draft', { fontCharacter: '\\\\ebd9' });\nCodicon.gitPullRequestClosed = new Codicon('git-pull-request-closed', { fontCharacter: '\\\\ebda' });\nCodicon.gitPullRequestDraft = new Codicon('git-pull-request-draft', { fontCharacter: '\\\\ebdb' });\nCodicon.debugAll = new Codicon('debug-all', { fontCharacter: '\\\\ebdc' });\nCodicon.debugCoverage = new Codicon('debug-coverage', { fontCharacter: '\\\\ebdd' });\nCodicon.runErrors = new Codicon('run-errors', { fontCharacter: '\\\\ebde' });\nCodicon.folderLibrary = new Codicon('folder-library', { fontCharacter: '\\\\ebdf' });\nCodicon.debugContinueSmall = new Codicon('debug-continue-small', { fontCharacter: '\\\\ebe0' });\nCodicon.beakerStop = new Codicon('beaker-stop', { fontCharacter: '\\\\ebe1' });\nCodicon.graphLine = new Codicon('graph-line', { fontCharacter: '\\\\ebe2' });\nCodicon.graphScatter = new Codicon('graph-scatter', { fontCharacter: '\\\\ebe3' });\nCodicon.pieChart = new Codicon('pie-chart', { fontCharacter: '\\\\ebe4' });\nCodicon.bracket = new Codicon('bracket', Codicon.json.definition);\nCodicon.bracketDot = new Codicon('bracket-dot', { fontCharacter: '\\\\ebe5' });\nCodicon.bracketError = new Codicon('bracket-error', { fontCharacter: '\\\\ebe6' });\nCodicon.lockSmall = new Codicon('lock-small', { fontCharacter: '\\\\ebe7' });\nCodicon.azureDevops = new Codicon('azure-devops', { fontCharacter: '\\\\ebe8' });\nCodicon.verifiedFilled = new Codicon('verified-filled', { fontCharacter: '\\\\ebe9' });\nCodicon.newLine = new Codicon('newline', { fontCharacter: '\\\\ebea' });\nCodicon.layout = new Codicon('layout', { fontCharacter: '\\\\ebeb' });\nCodicon.layoutActivitybarLeft = new Codicon('layout-activitybar-left', { fontCharacter: '\\\\ebec' });\nCodicon.layoutActivitybarRight = new Codicon('layout-activitybar-right', { fontCharacter: '\\\\ebed' });\nCodicon.layoutPanelLeft = new Codicon('layout-panel-left', { fontCharacter: '\\\\ebee' });\nCodicon.layoutPanelCenter = new Codicon('layout-panel-center', { fontCharacter: '\\\\ebef' });\nCodicon.layoutPanelJustify = new Codicon('layout-panel-justify', { fontCharacter: '\\\\ebf0' });\nCodicon.layoutPanelRight = new Codicon('layout-panel-right', { fontCharacter: '\\\\ebf1' });\nCodicon.layoutPanel = new Codicon('layout-panel', { fontCharacter: '\\\\ebf2' });\nCodicon.layoutSidebarLeft = new Codicon('layout-sidebar-left', { fontCharacter: '\\\\ebf3' });\nCodicon.layoutSidebarRight = new Codicon('layout-sidebar-right', { fontCharacter: '\\\\ebf4' });\nCodicon.layoutStatusbar = new Codicon('layout-statusbar', { fontCharacter: '\\\\ebf5' });\nCodicon.layoutMenubar = new Codicon('layout-menubar', { fontCharacter: '\\\\ebf6' });\nCodicon.layoutCentered = new Codicon('layout-centered', { fontCharacter: '\\\\ebf7' });\nCodicon.layoutSidebarRightOff = new Codicon('layout-sidebar-right-off', { fontCharacter: '\\\\ec00' });\nCodicon.layoutPanelOff = new Codicon('layout-panel-off', { fontCharacter: '\\\\ec01' });\nCodicon.layoutSidebarLeftOff = new Codicon('layout-sidebar-left-off', { fontCharacter: '\\\\ec02' });\nCodicon.target = new Codicon('target', { fontCharacter: '\\\\ebf8' });\nCodicon.indent = new Codicon('indent', { fontCharacter: '\\\\ebf9' });\nCodicon.recordSmall = new Codicon('record-small', { fontCharacter: '\\\\ebfa' });\nCodicon.errorSmall = new Codicon('error-small', { fontCharacter: '\\\\ebfb' });\nCodicon.arrowCircleDown = new Codicon('arrow-circle-down', { fontCharacter: '\\\\ebfc' });\nCodicon.arrowCircleLeft = new Codicon('arrow-circle-left', { fontCharacter: '\\\\ebfd' });\nCodicon.arrowCircleRight = new Codicon('arrow-circle-right', { fontCharacter: '\\\\ebfe' });\nCodicon.arrowCircleUp = new Codicon('arrow-circle-up', { fontCharacter: '\\\\ebff' });\nCodicon.heartFilled = new Codicon('heart-filled', { fontCharacter: '\\\\ec04' });\nCodicon.map = new Codicon('map', { fontCharacter: '\\\\ec05' });\nCodicon.mapFilled = new Codicon('map-filled', { fontCharacter: '\\\\ec06' });\nCodicon.circleSmall = new Codicon('circle-small', { fontCharacter: '\\\\ec07' });\nCodicon.bellSlash = new Codicon('bell-slash', { fontCharacter: '\\\\ec08' });\nCodicon.bellSlashDot = new Codicon('bell-slash-dot', { fontCharacter: '\\\\ec09' });\nCodicon.commentUnresolved = new Codicon('comment-unresolved', { fontCharacter: '\\\\ec0a' });\nCodicon.gitPullRequestGoToChanges = new Codicon('git-pull-request-go-to-changes', { fontCharacter: '\\\\ec0b' });\nCodicon.gitPullRequestNewChanges = new Codicon('git-pull-request-new-changes', { fontCharacter: '\\\\ec0c' });\n// derived icons, that could become separate icons\nCodicon.dialogError = new Codicon('dialog-error', Codicon.error.definition);\nCodicon.dialogWarning = new Codicon('dialog-warning', Codicon.warning.definition);\nCodicon.dialogInfo = new Codicon('dialog-info', Codicon.info.definition);\nCodicon.dialogClose = new Codicon('dialog-close', Codicon.close.definition);\nCodicon.treeItemExpanded = new Codicon('tree-item-expanded', Codicon.chevronDown.definition); // collapsed is done with rotation\nCodicon.treeFilterOnTypeOn = new Codicon('tree-filter-on-type-on', Codicon.listFilter.definition);\nCodicon.treeFilterOnTypeOff = new Codicon('tree-filter-on-type-off', Codicon.listSelection.definition);\nCodicon.treeFilterClear = new Codicon('tree-filter-clear', Codicon.close.definition);\nCodicon.treeItemLoading = new Codicon('tree-item-loading', Codicon.loading.definition);\nCodicon.menuSelection = new Codicon('menu-selection', Codicon.check.definition);\nCodicon.menuSubmenu = new Codicon('menu-submenu', Codicon.chevronRight.definition);\nCodicon.menuBarMore = new Codicon('menubar-more', Codicon.more.definition);\nCodicon.scrollbarButtonLeft = new Codicon('scrollbar-button-left', Codicon.triangleLeft.definition);\nCodicon.scrollbarButtonRight = new Codicon('scrollbar-button-right', Codicon.triangleRight.definition);\nCodicon.scrollbarButtonUp = new Codicon('scrollbar-button-up', Codicon.triangleUp.definition);\nCodicon.scrollbarButtonDown = new Codicon('scrollbar-button-down', Codicon.triangleDown.definition);\nCodicon.toolBarMore = new Codicon('toolbar-more', Codicon.more.definition);\nCodicon.quickInputBack = new Codicon('quick-input-back', Codicon.arrowLeft.definition);\nexport var CSSIcon;\n(function (CSSIcon) {\n CSSIcon.iconNameSegment = '[A-Za-z0-9]+';\n CSSIcon.iconNameExpression = '[A-Za-z0-9-]+';\n CSSIcon.iconModifierExpression = '~[A-Za-z]+';\n CSSIcon.iconNameCharacter = '[A-Za-z0-9~-]';\n const cssIconIdRegex = new RegExp(`^(${CSSIcon.iconNameExpression})(${CSSIcon.iconModifierExpression})?$`);\n function asClassNameArray(icon) {\n if (icon instanceof Codicon) {\n return ['codicon', 'codicon-' + icon.id];\n }\n const match = cssIconIdRegex.exec(icon.id);\n if (!match) {\n return asClassNameArray(Codicon.error);\n }\n const [, id, modifier] = match;\n const classNames = ['codicon', 'codicon-' + id];\n if (modifier) {\n classNames.push('codicon-modifier-' + modifier.substr(1));\n }\n return classNames;\n }\n CSSIcon.asClassNameArray = asClassNameArray;\n function asClassName(icon) {\n return asClassNameArray(icon).join(' ');\n }\n CSSIcon.asClassName = asClassName;\n function asCSSSelector(icon) {\n return '.' + asClassNameArray(icon).join('.');\n }\n CSSIcon.asCSSSelector = asCSSSelector;\n})(CSSIcon || (CSSIcon = {}));\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { Position } from './position.js';\nimport { Range } from './range.js';\n/**\n * A selection in the editor.\n * The selection is a range that has an orientation.\n */\nexport class Selection extends Range {\n constructor(selectionStartLineNumber, selectionStartColumn, positionLineNumber, positionColumn) {\n super(selectionStartLineNumber, selectionStartColumn, positionLineNumber, positionColumn);\n this.selectionStartLineNumber = selectionStartLineNumber;\n this.selectionStartColumn = selectionStartColumn;\n this.positionLineNumber = positionLineNumber;\n this.positionColumn = positionColumn;\n }\n /**\n * Transform to a human-readable representation.\n */\n toString() {\n return '[' + this.selectionStartLineNumber + ',' + this.selectionStartColumn + ' -> ' + this.positionLineNumber + ',' + this.positionColumn + ']';\n }\n /**\n * Test if equals other selection.\n */\n equalsSelection(other) {\n return (Selection.selectionsEqual(this, other));\n }\n /**\n * Test if the two selections are equal.\n */\n static selectionsEqual(a, b) {\n return (a.selectionStartLineNumber === b.selectionStartLineNumber &&\n a.selectionStartColumn === b.selectionStartColumn &&\n a.positionLineNumber === b.positionLineNumber &&\n a.positionColumn === b.positionColumn);\n }\n /**\n * Get directions (LTR or RTL).\n */\n getDirection() {\n if (this.selectionStartLineNumber === this.startLineNumber && this.selectionStartColumn === this.startColumn) {\n return 0 /* SelectionDirection.LTR */;\n }\n return 1 /* SelectionDirection.RTL */;\n }\n /**\n * Create a new selection with a different `positionLineNumber` and `positionColumn`.\n */\n setEndPosition(endLineNumber, endColumn) {\n if (this.getDirection() === 0 /* SelectionDirection.LTR */) {\n return new Selection(this.startLineNumber, this.startColumn, endLineNumber, endColumn);\n }\n return new Selection(endLineNumber, endColumn, this.startLineNumber, this.startColumn);\n }\n /**\n * Get the position at `positionLineNumber` and `positionColumn`.\n */\n getPosition() {\n return new Position(this.positionLineNumber, this.positionColumn);\n }\n /**\n * Get the position at the start of the selection.\n */\n getSelectionStart() {\n return new Position(this.selectionStartLineNumber, this.selectionStartColumn);\n }\n /**\n * Create a new selection with a different `selectionStartLineNumber` and `selectionStartColumn`.\n */\n setStartPosition(startLineNumber, startColumn) {\n if (this.getDirection() === 0 /* SelectionDirection.LTR */) {\n return new Selection(startLineNumber, startColumn, this.endLineNumber, this.endColumn);\n }\n return new Selection(this.endLineNumber, this.endColumn, startLineNumber, startColumn);\n }\n // ----\n /**\n * Create a `Selection` from one or two positions\n */\n static fromPositions(start, end = start) {\n return new Selection(start.lineNumber, start.column, end.lineNumber, end.column);\n }\n /**\n * Creates a `Selection` from a range, given a direction.\n */\n static fromRange(range, direction) {\n if (direction === 0 /* SelectionDirection.LTR */) {\n return new Selection(range.startLineNumber, range.startColumn, range.endLineNumber, range.endColumn);\n }\n else {\n return new Selection(range.endLineNumber, range.endColumn, range.startLineNumber, range.startColumn);\n }\n }\n /**\n * Create a `Selection` from an `ISelection`.\n */\n static liftSelection(sel) {\n return new Selection(sel.selectionStartLineNumber, sel.selectionStartColumn, sel.positionLineNumber, sel.positionColumn);\n }\n /**\n * `a` equals `b`.\n */\n static selectionsArrEqual(a, b) {\n if (a && !b || !a && b) {\n return false;\n }\n if (!a && !b) {\n return true;\n }\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0, len = a.length; i < len; i++) {\n if (!this.selectionsEqual(a[i], b[i])) {\n return false;\n }\n }\n return true;\n }\n /**\n * Test if `obj` is an `ISelection`.\n */\n static isISelection(obj) {\n return (obj\n && (typeof obj.selectionStartLineNumber === 'number')\n && (typeof obj.selectionStartColumn === 'number')\n && (typeof obj.positionLineNumber === 'number')\n && (typeof obj.positionColumn === 'number'));\n }\n /**\n * Create with a direction.\n */\n static createWithDirection(startLineNumber, startColumn, endLineNumber, endColumn, direction) {\n if (direction === 0 /* SelectionDirection.LTR */) {\n return new Selection(startLineNumber, startColumn, endLineNumber, endColumn);\n }\n return new Selection(endLineNumber, endColumn, startLineNumber, startColumn);\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { Emitter } from '../../base/common/event.js';\nimport { Disposable, toDisposable } from '../../base/common/lifecycle.js';\nexport class TokenizationRegistry {\n constructor() {\n this._map = new Map();\n this._factories = new Map();\n this._onDidChange = new Emitter();\n this.onDidChange = this._onDidChange.event;\n this._colorMap = null;\n }\n fire(languages) {\n this._onDidChange.fire({\n changedLanguages: languages,\n changedColorMap: false\n });\n }\n register(language, support) {\n this._map.set(language, support);\n this.fire([language]);\n return toDisposable(() => {\n if (this._map.get(language) !== support) {\n return;\n }\n this._map.delete(language);\n this.fire([language]);\n });\n }\n registerFactory(languageId, factory) {\n var _a;\n (_a = this._factories.get(languageId)) === null || _a === void 0 ? void 0 : _a.dispose();\n const myData = new TokenizationSupportFactoryData(this, languageId, factory);\n this._factories.set(languageId, myData);\n return toDisposable(() => {\n const v = this._factories.get(languageId);\n if (!v || v !== myData) {\n return;\n }\n this._factories.delete(languageId);\n v.dispose();\n });\n }\n getOrCreate(languageId) {\n return __awaiter(this, void 0, void 0, function* () {\n // check first if the support is already set\n const tokenizationSupport = this.get(languageId);\n if (tokenizationSupport) {\n return tokenizationSupport;\n }\n const factory = this._factories.get(languageId);\n if (!factory || factory.isResolved) {\n // no factory or factory.resolve already finished\n return null;\n }\n yield factory.resolve();\n return this.get(languageId);\n });\n }\n get(language) {\n return (this._map.get(language) || null);\n }\n isResolved(languageId) {\n const tokenizationSupport = this.get(languageId);\n if (tokenizationSupport) {\n return true;\n }\n const factory = this._factories.get(languageId);\n if (!factory || factory.isResolved) {\n return true;\n }\n return false;\n }\n setColorMap(colorMap) {\n this._colorMap = colorMap;\n this._onDidChange.fire({\n changedLanguages: Array.from(this._map.keys()),\n changedColorMap: true\n });\n }\n getColorMap() {\n return this._colorMap;\n }\n getDefaultBackground() {\n if (this._colorMap && this._colorMap.length > 2 /* ColorId.DefaultBackground */) {\n return this._colorMap[2 /* ColorId.DefaultBackground */];\n }\n return null;\n }\n}\nclass TokenizationSupportFactoryData extends Disposable {\n constructor(_registry, _languageId, _factory) {\n super();\n this._registry = _registry;\n this._languageId = _languageId;\n this._factory = _factory;\n this._isDisposed = false;\n this._resolvePromise = null;\n this._isResolved = false;\n }\n get isResolved() {\n return this._isResolved;\n }\n dispose() {\n this._isDisposed = true;\n super.dispose();\n }\n resolve() {\n return __awaiter(this, void 0, void 0, function* () {\n if (!this._resolvePromise) {\n this._resolvePromise = this._create();\n }\n return this._resolvePromise;\n });\n }\n _create() {\n return __awaiter(this, void 0, void 0, function* () {\n const value = yield Promise.resolve(this._factory.createTokenizationSupport());\n this._isResolved = true;\n if (value && !this._isDisposed) {\n this._register(this._registry.register(this._languageId, value));\n }\n });\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { Codicon } from '../../base/common/codicons.js';\nimport { URI } from '../../base/common/uri.js';\nimport { Range } from './core/range.js';\nimport { TokenizationRegistry as TokenizationRegistryImpl } from './tokenizationRegistry.js';\nexport class Token {\n constructor(offset, type, language) {\n this._tokenBrand = undefined;\n this.offset = offset;\n this.type = type;\n this.language = language;\n }\n toString() {\n return '(' + this.offset + ', ' + this.type + ')';\n }\n}\n/**\n * @internal\n */\nexport class TokenizationResult {\n constructor(tokens, endState) {\n this._tokenizationResultBrand = undefined;\n this.tokens = tokens;\n this.endState = endState;\n }\n}\n/**\n * @internal\n */\nexport class EncodedTokenizationResult {\n constructor(tokens, endState) {\n this._encodedTokenizationResultBrand = undefined;\n this.tokens = tokens;\n this.endState = endState;\n }\n}\n/**\n * @internal\n */\nexport var CompletionItemKinds;\n(function (CompletionItemKinds) {\n const byKind = new Map();\n byKind.set(0 /* CompletionItemKind.Method */, Codicon.symbolMethod);\n byKind.set(1 /* CompletionItemKind.Function */, Codicon.symbolFunction);\n byKind.set(2 /* CompletionItemKind.Constructor */, Codicon.symbolConstructor);\n byKind.set(3 /* CompletionItemKind.Field */, Codicon.symbolField);\n byKind.set(4 /* CompletionItemKind.Variable */, Codicon.symbolVariable);\n byKind.set(5 /* CompletionItemKind.Class */, Codicon.symbolClass);\n byKind.set(6 /* CompletionItemKind.Struct */, Codicon.symbolStruct);\n byKind.set(7 /* CompletionItemKind.Interface */, Codicon.symbolInterface);\n byKind.set(8 /* CompletionItemKind.Module */, Codicon.symbolModule);\n byKind.set(9 /* CompletionItemKind.Property */, Codicon.symbolProperty);\n byKind.set(10 /* CompletionItemKind.Event */, Codicon.symbolEvent);\n byKind.set(11 /* CompletionItemKind.Operator */, Codicon.symbolOperator);\n byKind.set(12 /* CompletionItemKind.Unit */, Codicon.symbolUnit);\n byKind.set(13 /* CompletionItemKind.Value */, Codicon.symbolValue);\n byKind.set(15 /* CompletionItemKind.Enum */, Codicon.symbolEnum);\n byKind.set(14 /* CompletionItemKind.Constant */, Codicon.symbolConstant);\n byKind.set(15 /* CompletionItemKind.Enum */, Codicon.symbolEnum);\n byKind.set(16 /* CompletionItemKind.EnumMember */, Codicon.symbolEnumMember);\n byKind.set(17 /* CompletionItemKind.Keyword */, Codicon.symbolKeyword);\n byKind.set(27 /* CompletionItemKind.Snippet */, Codicon.symbolSnippet);\n byKind.set(18 /* CompletionItemKind.Text */, Codicon.symbolText);\n byKind.set(19 /* CompletionItemKind.Color */, Codicon.symbolColor);\n byKind.set(20 /* CompletionItemKind.File */, Codicon.symbolFile);\n byKind.set(21 /* CompletionItemKind.Reference */, Codicon.symbolReference);\n byKind.set(22 /* CompletionItemKind.Customcolor */, Codicon.symbolCustomColor);\n byKind.set(23 /* CompletionItemKind.Folder */, Codicon.symbolFolder);\n byKind.set(24 /* CompletionItemKind.TypeParameter */, Codicon.symbolTypeParameter);\n byKind.set(25 /* CompletionItemKind.User */, Codicon.account);\n byKind.set(26 /* CompletionItemKind.Issue */, Codicon.issues);\n /**\n * @internal\n */\n function toIcon(kind) {\n let codicon = byKind.get(kind);\n if (!codicon) {\n console.info('No codicon found for CompletionItemKind ' + kind);\n codicon = Codicon.symbolProperty;\n }\n return codicon;\n }\n CompletionItemKinds.toIcon = toIcon;\n const data = new Map();\n data.set('method', 0 /* CompletionItemKind.Method */);\n data.set('function', 1 /* CompletionItemKind.Function */);\n data.set('constructor', 2 /* CompletionItemKind.Constructor */);\n data.set('field', 3 /* CompletionItemKind.Field */);\n data.set('variable', 4 /* CompletionItemKind.Variable */);\n data.set('class', 5 /* CompletionItemKind.Class */);\n data.set('struct', 6 /* CompletionItemKind.Struct */);\n data.set('interface', 7 /* CompletionItemKind.Interface */);\n data.set('module', 8 /* CompletionItemKind.Module */);\n data.set('property', 9 /* CompletionItemKind.Property */);\n data.set('event', 10 /* CompletionItemKind.Event */);\n data.set('operator', 11 /* CompletionItemKind.Operator */);\n data.set('unit', 12 /* CompletionItemKind.Unit */);\n data.set('value', 13 /* CompletionItemKind.Value */);\n data.set('constant', 14 /* CompletionItemKind.Constant */);\n data.set('enum', 15 /* CompletionItemKind.Enum */);\n data.set('enum-member', 16 /* CompletionItemKind.EnumMember */);\n data.set('enumMember', 16 /* CompletionItemKind.EnumMember */);\n data.set('keyword', 17 /* CompletionItemKind.Keyword */);\n data.set('snippet', 27 /* CompletionItemKind.Snippet */);\n data.set('text', 18 /* CompletionItemKind.Text */);\n data.set('color', 19 /* CompletionItemKind.Color */);\n data.set('file', 20 /* CompletionItemKind.File */);\n data.set('reference', 21 /* CompletionItemKind.Reference */);\n data.set('customcolor', 22 /* CompletionItemKind.Customcolor */);\n data.set('folder', 23 /* CompletionItemKind.Folder */);\n data.set('type-parameter', 24 /* CompletionItemKind.TypeParameter */);\n data.set('typeParameter', 24 /* CompletionItemKind.TypeParameter */);\n data.set('account', 25 /* CompletionItemKind.User */);\n data.set('issue', 26 /* CompletionItemKind.Issue */);\n /**\n * @internal\n */\n function fromString(value, strict) {\n let res = data.get(value);\n if (typeof res === 'undefined' && !strict) {\n res = 9 /* CompletionItemKind.Property */;\n }\n return res;\n }\n CompletionItemKinds.fromString = fromString;\n})(CompletionItemKinds || (CompletionItemKinds = {}));\n/**\n * How an {@link InlineCompletionsProvider inline completion provider} was triggered.\n */\nexport var InlineCompletionTriggerKind;\n(function (InlineCompletionTriggerKind) {\n /**\n * Completion was triggered automatically while editing.\n * It is sufficient to return a single completion item in this case.\n */\n InlineCompletionTriggerKind[InlineCompletionTriggerKind[\"Automatic\"] = 0] = \"Automatic\";\n /**\n * Completion was triggered explicitly by a user gesture.\n * Return multiple completion items to enable cycling through them.\n */\n InlineCompletionTriggerKind[InlineCompletionTriggerKind[\"Explicit\"] = 1] = \"Explicit\";\n})(InlineCompletionTriggerKind || (InlineCompletionTriggerKind = {}));\nexport var SignatureHelpTriggerKind;\n(function (SignatureHelpTriggerKind) {\n SignatureHelpTriggerKind[SignatureHelpTriggerKind[\"Invoke\"] = 1] = \"Invoke\";\n SignatureHelpTriggerKind[SignatureHelpTriggerKind[\"TriggerCharacter\"] = 2] = \"TriggerCharacter\";\n SignatureHelpTriggerKind[SignatureHelpTriggerKind[\"ContentChange\"] = 3] = \"ContentChange\";\n})(SignatureHelpTriggerKind || (SignatureHelpTriggerKind = {}));\n/**\n * A document highlight kind.\n */\nexport var DocumentHighlightKind;\n(function (DocumentHighlightKind) {\n /**\n * A textual occurrence.\n */\n DocumentHighlightKind[DocumentHighlightKind[\"Text\"] = 0] = \"Text\";\n /**\n * Read-access of a symbol, like reading a variable.\n */\n DocumentHighlightKind[DocumentHighlightKind[\"Read\"] = 1] = \"Read\";\n /**\n * Write-access of a symbol, like writing to a variable.\n */\n DocumentHighlightKind[DocumentHighlightKind[\"Write\"] = 2] = \"Write\";\n})(DocumentHighlightKind || (DocumentHighlightKind = {}));\n/**\n * @internal\n */\nexport function isLocationLink(thing) {\n return thing\n && URI.isUri(thing.uri)\n && Range.isIRange(thing.range)\n && (Range.isIRange(thing.originSelectionRange) || Range.isIRange(thing.targetSelectionRange));\n}\n/**\n * @internal\n */\nexport var SymbolKinds;\n(function (SymbolKinds) {\n const byKind = new Map();\n byKind.set(0 /* SymbolKind.File */, Codicon.symbolFile);\n byKind.set(1 /* SymbolKind.Module */, Codicon.symbolModule);\n byKind.set(2 /* SymbolKind.Namespace */, Codicon.symbolNamespace);\n byKind.set(3 /* SymbolKind.Package */, Codicon.symbolPackage);\n byKind.set(4 /* SymbolKind.Class */, Codicon.symbolClass);\n byKind.set(5 /* SymbolKind.Method */, Codicon.symbolMethod);\n byKind.set(6 /* SymbolKind.Property */, Codicon.symbolProperty);\n byKind.set(7 /* SymbolKind.Field */, Codicon.symbolField);\n byKind.set(8 /* SymbolKind.Constructor */, Codicon.symbolConstructor);\n byKind.set(9 /* SymbolKind.Enum */, Codicon.symbolEnum);\n byKind.set(10 /* SymbolKind.Interface */, Codicon.symbolInterface);\n byKind.set(11 /* SymbolKind.Function */, Codicon.symbolFunction);\n byKind.set(12 /* SymbolKind.Variable */, Codicon.symbolVariable);\n byKind.set(13 /* SymbolKind.Constant */, Codicon.symbolConstant);\n byKind.set(14 /* SymbolKind.String */, Codicon.symbolString);\n byKind.set(15 /* SymbolKind.Number */, Codicon.symbolNumber);\n byKind.set(16 /* SymbolKind.Boolean */, Codicon.symbolBoolean);\n byKind.set(17 /* SymbolKind.Array */, Codicon.symbolArray);\n byKind.set(18 /* SymbolKind.Object */, Codicon.symbolObject);\n byKind.set(19 /* SymbolKind.Key */, Codicon.symbolKey);\n byKind.set(20 /* SymbolKind.Null */, Codicon.symbolNull);\n byKind.set(21 /* SymbolKind.EnumMember */, Codicon.symbolEnumMember);\n byKind.set(22 /* SymbolKind.Struct */, Codicon.symbolStruct);\n byKind.set(23 /* SymbolKind.Event */, Codicon.symbolEvent);\n byKind.set(24 /* SymbolKind.Operator */, Codicon.symbolOperator);\n byKind.set(25 /* SymbolKind.TypeParameter */, Codicon.symbolTypeParameter);\n /**\n * @internal\n */\n function toIcon(kind) {\n let icon = byKind.get(kind);\n if (!icon) {\n console.info('No codicon found for SymbolKind ' + kind);\n icon = Codicon.symbolProperty;\n }\n return icon;\n }\n SymbolKinds.toIcon = toIcon;\n})(SymbolKinds || (SymbolKinds = {}));\nexport class FoldingRangeKind {\n /**\n * Creates a new {@link FoldingRangeKind}.\n *\n * @param value of the kind.\n */\n constructor(value) {\n this.value = value;\n }\n}\n/**\n * Kind for folding range representing a comment. The value of the kind is 'comment'.\n */\nFoldingRangeKind.Comment = new FoldingRangeKind('comment');\n/**\n * Kind for folding range representing a import. The value of the kind is 'imports'.\n */\nFoldingRangeKind.Imports = new FoldingRangeKind('imports');\n/**\n * Kind for folding range representing regions (for example marked by `#region`, `#endregion`).\n * The value of the kind is 'region'.\n */\nFoldingRangeKind.Region = new FoldingRangeKind('region');\n/**\n * @internal\n */\nexport var Command;\n(function (Command) {\n /**\n * @internal\n */\n function is(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n return typeof obj.id === 'string' &&\n typeof obj.title === 'string';\n }\n Command.is = is;\n})(Command || (Command = {}));\nexport var InlayHintKind;\n(function (InlayHintKind) {\n InlayHintKind[InlayHintKind[\"Type\"] = 1] = \"Type\";\n InlayHintKind[InlayHintKind[\"Parameter\"] = 2] = \"Parameter\";\n})(InlayHintKind || (InlayHintKind = {}));\n/**\n * @internal\n */\nexport const TokenizationRegistry = new TokenizationRegistryImpl();\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n// THIS IS A GENERATED FILE. DO NOT EDIT DIRECTLY.\nexport var AccessibilitySupport;\n(function (AccessibilitySupport) {\n /**\n * This should be the browser case where it is not known if a screen reader is attached or no.\n */\n AccessibilitySupport[AccessibilitySupport[\"Unknown\"] = 0] = \"Unknown\";\n AccessibilitySupport[AccessibilitySupport[\"Disabled\"] = 1] = \"Disabled\";\n AccessibilitySupport[AccessibilitySupport[\"Enabled\"] = 2] = \"Enabled\";\n})(AccessibilitySupport || (AccessibilitySupport = {}));\nexport var CodeActionTriggerType;\n(function (CodeActionTriggerType) {\n CodeActionTriggerType[CodeActionTriggerType[\"Invoke\"] = 1] = \"Invoke\";\n CodeActionTriggerType[CodeActionTriggerType[\"Auto\"] = 2] = \"Auto\";\n})(CodeActionTriggerType || (CodeActionTriggerType = {}));\nexport var CompletionItemInsertTextRule;\n(function (CompletionItemInsertTextRule) {\n /**\n * Adjust whitespace/indentation of multiline insert texts to\n * match the current line indentation.\n */\n CompletionItemInsertTextRule[CompletionItemInsertTextRule[\"KeepWhitespace\"] = 1] = \"KeepWhitespace\";\n /**\n * `insertText` is a snippet.\n */\n CompletionItemInsertTextRule[CompletionItemInsertTextRule[\"InsertAsSnippet\"] = 4] = \"InsertAsSnippet\";\n})(CompletionItemInsertTextRule || (CompletionItemInsertTextRule = {}));\nexport var CompletionItemKind;\n(function (CompletionItemKind) {\n CompletionItemKind[CompletionItemKind[\"Method\"] = 0] = \"Method\";\n CompletionItemKind[CompletionItemKind[\"Function\"] = 1] = \"Function\";\n CompletionItemKind[CompletionItemKind[\"Constructor\"] = 2] = \"Constructor\";\n CompletionItemKind[CompletionItemKind[\"Field\"] = 3] = \"Field\";\n CompletionItemKind[CompletionItemKind[\"Variable\"] = 4] = \"Variable\";\n CompletionItemKind[CompletionItemKind[\"Class\"] = 5] = \"Class\";\n CompletionItemKind[CompletionItemKind[\"Struct\"] = 6] = \"Struct\";\n CompletionItemKind[CompletionItemKind[\"Interface\"] = 7] = \"Interface\";\n CompletionItemKind[CompletionItemKind[\"Module\"] = 8] = \"Module\";\n CompletionItemKind[CompletionItemKind[\"Property\"] = 9] = \"Property\";\n CompletionItemKind[CompletionItemKind[\"Event\"] = 10] = \"Event\";\n CompletionItemKind[CompletionItemKind[\"Operator\"] = 11] = \"Operator\";\n CompletionItemKind[CompletionItemKind[\"Unit\"] = 12] = \"Unit\";\n CompletionItemKind[CompletionItemKind[\"Value\"] = 13] = \"Value\";\n CompletionItemKind[CompletionItemKind[\"Constant\"] = 14] = \"Constant\";\n CompletionItemKind[CompletionItemKind[\"Enum\"] = 15] = \"Enum\";\n CompletionItemKind[CompletionItemKind[\"EnumMember\"] = 16] = \"EnumMember\";\n CompletionItemKind[CompletionItemKind[\"Keyword\"] = 17] = \"Keyword\";\n CompletionItemKind[CompletionItemKind[\"Text\"] = 18] = \"Text\";\n CompletionItemKind[CompletionItemKind[\"Color\"] = 19] = \"Color\";\n CompletionItemKind[CompletionItemKind[\"File\"] = 20] = \"File\";\n CompletionItemKind[CompletionItemKind[\"Reference\"] = 21] = \"Reference\";\n CompletionItemKind[CompletionItemKind[\"Customcolor\"] = 22] = \"Customcolor\";\n CompletionItemKind[CompletionItemKind[\"Folder\"] = 23] = \"Folder\";\n CompletionItemKind[CompletionItemKind[\"TypeParameter\"] = 24] = \"TypeParameter\";\n CompletionItemKind[CompletionItemKind[\"User\"] = 25] = \"User\";\n CompletionItemKind[CompletionItemKind[\"Issue\"] = 26] = \"Issue\";\n CompletionItemKind[CompletionItemKind[\"Snippet\"] = 27] = \"Snippet\";\n})(CompletionItemKind || (CompletionItemKind = {}));\nexport var CompletionItemTag;\n(function (CompletionItemTag) {\n CompletionItemTag[CompletionItemTag[\"Deprecated\"] = 1] = \"Deprecated\";\n})(CompletionItemTag || (CompletionItemTag = {}));\n/**\n * How a suggest provider was triggered.\n */\nexport var CompletionTriggerKind;\n(function (CompletionTriggerKind) {\n CompletionTriggerKind[CompletionTriggerKind[\"Invoke\"] = 0] = \"Invoke\";\n CompletionTriggerKind[CompletionTriggerKind[\"TriggerCharacter\"] = 1] = \"TriggerCharacter\";\n CompletionTriggerKind[CompletionTriggerKind[\"TriggerForIncompleteCompletions\"] = 2] = \"TriggerForIncompleteCompletions\";\n})(CompletionTriggerKind || (CompletionTriggerKind = {}));\n/**\n * A positioning preference for rendering content widgets.\n */\nexport var ContentWidgetPositionPreference;\n(function (ContentWidgetPositionPreference) {\n /**\n * Place the content widget exactly at a position\n */\n ContentWidgetPositionPreference[ContentWidgetPositionPreference[\"EXACT\"] = 0] = \"EXACT\";\n /**\n * Place the content widget above a position\n */\n ContentWidgetPositionPreference[ContentWidgetPositionPreference[\"ABOVE\"] = 1] = \"ABOVE\";\n /**\n * Place the content widget below a position\n */\n ContentWidgetPositionPreference[ContentWidgetPositionPreference[\"BELOW\"] = 2] = \"BELOW\";\n})(ContentWidgetPositionPreference || (ContentWidgetPositionPreference = {}));\n/**\n * Describes the reason the cursor has changed its position.\n */\nexport var CursorChangeReason;\n(function (CursorChangeReason) {\n /**\n * Unknown or not set.\n */\n CursorChangeReason[CursorChangeReason[\"NotSet\"] = 0] = \"NotSet\";\n /**\n * A `model.setValue()` was called.\n */\n CursorChangeReason[CursorChangeReason[\"ContentFlush\"] = 1] = \"ContentFlush\";\n /**\n * The `model` has been changed outside of this cursor and the cursor recovers its position from associated markers.\n */\n CursorChangeReason[CursorChangeReason[\"RecoverFromMarkers\"] = 2] = \"RecoverFromMarkers\";\n /**\n * There was an explicit user gesture.\n */\n CursorChangeReason[CursorChangeReason[\"Explicit\"] = 3] = \"Explicit\";\n /**\n * There was a Paste.\n */\n CursorChangeReason[CursorChangeReason[\"Paste\"] = 4] = \"Paste\";\n /**\n * There was an Undo.\n */\n CursorChangeReason[CursorChangeReason[\"Undo\"] = 5] = \"Undo\";\n /**\n * There was a Redo.\n */\n CursorChangeReason[CursorChangeReason[\"Redo\"] = 6] = \"Redo\";\n})(CursorChangeReason || (CursorChangeReason = {}));\n/**\n * The default end of line to use when instantiating models.\n */\nexport var DefaultEndOfLine;\n(function (DefaultEndOfLine) {\n /**\n * Use line feed (\\n) as the end of line character.\n */\n DefaultEndOfLine[DefaultEndOfLine[\"LF\"] = 1] = \"LF\";\n /**\n * Use carriage return and line feed (\\r\\n) as the end of line character.\n */\n DefaultEndOfLine[DefaultEndOfLine[\"CRLF\"] = 2] = \"CRLF\";\n})(DefaultEndOfLine || (DefaultEndOfLine = {}));\n/**\n * A document highlight kind.\n */\nexport var DocumentHighlightKind;\n(function (DocumentHighlightKind) {\n /**\n * A textual occurrence.\n */\n DocumentHighlightKind[DocumentHighlightKind[\"Text\"] = 0] = \"Text\";\n /**\n * Read-access of a symbol, like reading a variable.\n */\n DocumentHighlightKind[DocumentHighlightKind[\"Read\"] = 1] = \"Read\";\n /**\n * Write-access of a symbol, like writing to a variable.\n */\n DocumentHighlightKind[DocumentHighlightKind[\"Write\"] = 2] = \"Write\";\n})(DocumentHighlightKind || (DocumentHighlightKind = {}));\n/**\n * Configuration options for auto indentation in the editor\n */\nexport var EditorAutoIndentStrategy;\n(function (EditorAutoIndentStrategy) {\n EditorAutoIndentStrategy[EditorAutoIndentStrategy[\"None\"] = 0] = \"None\";\n EditorAutoIndentStrategy[EditorAutoIndentStrategy[\"Keep\"] = 1] = \"Keep\";\n EditorAutoIndentStrategy[EditorAutoIndentStrategy[\"Brackets\"] = 2] = \"Brackets\";\n EditorAutoIndentStrategy[EditorAutoIndentStrategy[\"Advanced\"] = 3] = \"Advanced\";\n EditorAutoIndentStrategy[EditorAutoIndentStrategy[\"Full\"] = 4] = \"Full\";\n})(EditorAutoIndentStrategy || (EditorAutoIndentStrategy = {}));\nexport var EditorOption;\n(function (EditorOption) {\n EditorOption[EditorOption[\"acceptSuggestionOnCommitCharacter\"] = 0] = \"acceptSuggestionOnCommitCharacter\";\n EditorOption[EditorOption[\"acceptSuggestionOnEnter\"] = 1] = \"acceptSuggestionOnEnter\";\n EditorOption[EditorOption[\"accessibilitySupport\"] = 2] = \"accessibilitySupport\";\n EditorOption[EditorOption[\"accessibilityPageSize\"] = 3] = \"accessibilityPageSize\";\n EditorOption[EditorOption[\"ariaLabel\"] = 4] = \"ariaLabel\";\n EditorOption[EditorOption[\"autoClosingBrackets\"] = 5] = \"autoClosingBrackets\";\n EditorOption[EditorOption[\"autoClosingDelete\"] = 6] = \"autoClosingDelete\";\n EditorOption[EditorOption[\"autoClosingOvertype\"] = 7] = \"autoClosingOvertype\";\n EditorOption[EditorOption[\"autoClosingQuotes\"] = 8] = \"autoClosingQuotes\";\n EditorOption[EditorOption[\"autoIndent\"] = 9] = \"autoIndent\";\n EditorOption[EditorOption[\"automaticLayout\"] = 10] = \"automaticLayout\";\n EditorOption[EditorOption[\"autoSurround\"] = 11] = \"autoSurround\";\n EditorOption[EditorOption[\"bracketPairColorization\"] = 12] = \"bracketPairColorization\";\n EditorOption[EditorOption[\"guides\"] = 13] = \"guides\";\n EditorOption[EditorOption[\"codeLens\"] = 14] = \"codeLens\";\n EditorOption[EditorOption[\"codeLensFontFamily\"] = 15] = \"codeLensFontFamily\";\n EditorOption[EditorOption[\"codeLensFontSize\"] = 16] = \"codeLensFontSize\";\n EditorOption[EditorOption[\"colorDecorators\"] = 17] = \"colorDecorators\";\n EditorOption[EditorOption[\"columnSelection\"] = 18] = \"columnSelection\";\n EditorOption[EditorOption[\"comments\"] = 19] = \"comments\";\n EditorOption[EditorOption[\"contextmenu\"] = 20] = \"contextmenu\";\n EditorOption[EditorOption[\"copyWithSyntaxHighlighting\"] = 21] = \"copyWithSyntaxHighlighting\";\n EditorOption[EditorOption[\"cursorBlinking\"] = 22] = \"cursorBlinking\";\n EditorOption[EditorOption[\"cursorSmoothCaretAnimation\"] = 23] = \"cursorSmoothCaretAnimation\";\n EditorOption[EditorOption[\"cursorStyle\"] = 24] = \"cursorStyle\";\n EditorOption[EditorOption[\"cursorSurroundingLines\"] = 25] = \"cursorSurroundingLines\";\n EditorOption[EditorOption[\"cursorSurroundingLinesStyle\"] = 26] = \"cursorSurroundingLinesStyle\";\n EditorOption[EditorOption[\"cursorWidth\"] = 27] = \"cursorWidth\";\n EditorOption[EditorOption[\"disableLayerHinting\"] = 28] = \"disableLayerHinting\";\n EditorOption[EditorOption[\"disableMonospaceOptimizations\"] = 29] = \"disableMonospaceOptimizations\";\n EditorOption[EditorOption[\"domReadOnly\"] = 30] = \"domReadOnly\";\n EditorOption[EditorOption[\"dragAndDrop\"] = 31] = \"dragAndDrop\";\n EditorOption[EditorOption[\"dropIntoEditor\"] = 32] = \"dropIntoEditor\";\n EditorOption[EditorOption[\"emptySelectionClipboard\"] = 33] = \"emptySelectionClipboard\";\n EditorOption[EditorOption[\"experimental\"] = 34] = \"experimental\";\n EditorOption[EditorOption[\"extraEditorClassName\"] = 35] = \"extraEditorClassName\";\n EditorOption[EditorOption[\"fastScrollSensitivity\"] = 36] = \"fastScrollSensitivity\";\n EditorOption[EditorOption[\"find\"] = 37] = \"find\";\n EditorOption[EditorOption[\"fixedOverflowWidgets\"] = 38] = \"fixedOverflowWidgets\";\n EditorOption[EditorOption[\"folding\"] = 39] = \"folding\";\n EditorOption[EditorOption[\"foldingStrategy\"] = 40] = \"foldingStrategy\";\n EditorOption[EditorOption[\"foldingHighlight\"] = 41] = \"foldingHighlight\";\n EditorOption[EditorOption[\"foldingImportsByDefault\"] = 42] = \"foldingImportsByDefault\";\n EditorOption[EditorOption[\"foldingMaximumRegions\"] = 43] = \"foldingMaximumRegions\";\n EditorOption[EditorOption[\"unfoldOnClickAfterEndOfLine\"] = 44] = \"unfoldOnClickAfterEndOfLine\";\n EditorOption[EditorOption[\"fontFamily\"] = 45] = \"fontFamily\";\n EditorOption[EditorOption[\"fontInfo\"] = 46] = \"fontInfo\";\n EditorOption[EditorOption[\"fontLigatures\"] = 47] = \"fontLigatures\";\n EditorOption[EditorOption[\"fontSize\"] = 48] = \"fontSize\";\n EditorOption[EditorOption[\"fontWeight\"] = 49] = \"fontWeight\";\n EditorOption[EditorOption[\"formatOnPaste\"] = 50] = \"formatOnPaste\";\n EditorOption[EditorOption[\"formatOnType\"] = 51] = \"formatOnType\";\n EditorOption[EditorOption[\"glyphMargin\"] = 52] = \"glyphMargin\";\n EditorOption[EditorOption[\"gotoLocation\"] = 53] = \"gotoLocation\";\n EditorOption[EditorOption[\"hideCursorInOverviewRuler\"] = 54] = \"hideCursorInOverviewRuler\";\n EditorOption[EditorOption[\"hover\"] = 55] = \"hover\";\n EditorOption[EditorOption[\"inDiffEditor\"] = 56] = \"inDiffEditor\";\n EditorOption[EditorOption[\"inlineSuggest\"] = 57] = \"inlineSuggest\";\n EditorOption[EditorOption[\"letterSpacing\"] = 58] = \"letterSpacing\";\n EditorOption[EditorOption[\"lightbulb\"] = 59] = \"lightbulb\";\n EditorOption[EditorOption[\"lineDecorationsWidth\"] = 60] = \"lineDecorationsWidth\";\n EditorOption[EditorOption[\"lineHeight\"] = 61] = \"lineHeight\";\n EditorOption[EditorOption[\"lineNumbers\"] = 62] = \"lineNumbers\";\n EditorOption[EditorOption[\"lineNumbersMinChars\"] = 63] = \"lineNumbersMinChars\";\n EditorOption[EditorOption[\"linkedEditing\"] = 64] = \"linkedEditing\";\n EditorOption[EditorOption[\"links\"] = 65] = \"links\";\n EditorOption[EditorOption[\"matchBrackets\"] = 66] = \"matchBrackets\";\n EditorOption[EditorOption[\"minimap\"] = 67] = \"minimap\";\n EditorOption[EditorOption[\"mouseStyle\"] = 68] = \"mouseStyle\";\n EditorOption[EditorOption[\"mouseWheelScrollSensitivity\"] = 69] = \"mouseWheelScrollSensitivity\";\n EditorOption[EditorOption[\"mouseWheelZoom\"] = 70] = \"mouseWheelZoom\";\n EditorOption[EditorOption[\"multiCursorMergeOverlapping\"] = 71] = \"multiCursorMergeOverlapping\";\n EditorOption[EditorOption[\"multiCursorModifier\"] = 72] = \"multiCursorModifier\";\n EditorOption[EditorOption[\"multiCursorPaste\"] = 73] = \"multiCursorPaste\";\n EditorOption[EditorOption[\"occurrencesHighlight\"] = 74] = \"occurrencesHighlight\";\n EditorOption[EditorOption[\"overviewRulerBorder\"] = 75] = \"overviewRulerBorder\";\n EditorOption[EditorOption[\"overviewRulerLanes\"] = 76] = \"overviewRulerLanes\";\n EditorOption[EditorOption[\"padding\"] = 77] = \"padding\";\n EditorOption[EditorOption[\"parameterHints\"] = 78] = \"parameterHints\";\n EditorOption[EditorOption[\"peekWidgetDefaultFocus\"] = 79] = \"peekWidgetDefaultFocus\";\n EditorOption[EditorOption[\"definitionLinkOpensInPeek\"] = 80] = \"definitionLinkOpensInPeek\";\n EditorOption[EditorOption[\"quickSuggestions\"] = 81] = \"quickSuggestions\";\n EditorOption[EditorOption[\"quickSuggestionsDelay\"] = 82] = \"quickSuggestionsDelay\";\n EditorOption[EditorOption[\"readOnly\"] = 83] = \"readOnly\";\n EditorOption[EditorOption[\"renameOnType\"] = 84] = \"renameOnType\";\n EditorOption[EditorOption[\"renderControlCharacters\"] = 85] = \"renderControlCharacters\";\n EditorOption[EditorOption[\"renderFinalNewline\"] = 86] = \"renderFinalNewline\";\n EditorOption[EditorOption[\"renderLineHighlight\"] = 87] = \"renderLineHighlight\";\n EditorOption[EditorOption[\"renderLineHighlightOnlyWhenFocus\"] = 88] = \"renderLineHighlightOnlyWhenFocus\";\n EditorOption[EditorOption[\"renderValidationDecorations\"] = 89] = \"renderValidationDecorations\";\n EditorOption[EditorOption[\"renderWhitespace\"] = 90] = \"renderWhitespace\";\n EditorOption[EditorOption[\"revealHorizontalRightPadding\"] = 91] = \"revealHorizontalRightPadding\";\n EditorOption[EditorOption[\"roundedSelection\"] = 92] = \"roundedSelection\";\n EditorOption[EditorOption[\"rulers\"] = 93] = \"rulers\";\n EditorOption[EditorOption[\"scrollbar\"] = 94] = \"scrollbar\";\n EditorOption[EditorOption[\"scrollBeyondLastColumn\"] = 95] = \"scrollBeyondLastColumn\";\n EditorOption[EditorOption[\"scrollBeyondLastLine\"] = 96] = \"scrollBeyondLastLine\";\n EditorOption[EditorOption[\"scrollPredominantAxis\"] = 97] = \"scrollPredominantAxis\";\n EditorOption[EditorOption[\"selectionClipboard\"] = 98] = \"selectionClipboard\";\n EditorOption[EditorOption[\"selectionHighlight\"] = 99] = \"selectionHighlight\";\n EditorOption[EditorOption[\"selectOnLineNumbers\"] = 100] = \"selectOnLineNumbers\";\n EditorOption[EditorOption[\"showFoldingControls\"] = 101] = \"showFoldingControls\";\n EditorOption[EditorOption[\"showUnused\"] = 102] = \"showUnused\";\n EditorOption[EditorOption[\"snippetSuggestions\"] = 103] = \"snippetSuggestions\";\n EditorOption[EditorOption[\"smartSelect\"] = 104] = \"smartSelect\";\n EditorOption[EditorOption[\"smoothScrolling\"] = 105] = \"smoothScrolling\";\n EditorOption[EditorOption[\"stickyTabStops\"] = 106] = \"stickyTabStops\";\n EditorOption[EditorOption[\"stopRenderingLineAfter\"] = 107] = \"stopRenderingLineAfter\";\n EditorOption[EditorOption[\"suggest\"] = 108] = \"suggest\";\n EditorOption[EditorOption[\"suggestFontSize\"] = 109] = \"suggestFontSize\";\n EditorOption[EditorOption[\"suggestLineHeight\"] = 110] = \"suggestLineHeight\";\n EditorOption[EditorOption[\"suggestOnTriggerCharacters\"] = 111] = \"suggestOnTriggerCharacters\";\n EditorOption[EditorOption[\"suggestSelection\"] = 112] = \"suggestSelection\";\n EditorOption[EditorOption[\"tabCompletion\"] = 113] = \"tabCompletion\";\n EditorOption[EditorOption[\"tabIndex\"] = 114] = \"tabIndex\";\n EditorOption[EditorOption[\"unicodeHighlighting\"] = 115] = \"unicodeHighlighting\";\n EditorOption[EditorOption[\"unusualLineTerminators\"] = 116] = \"unusualLineTerminators\";\n EditorOption[EditorOption[\"useShadowDOM\"] = 117] = \"useShadowDOM\";\n EditorOption[EditorOption[\"useTabStops\"] = 118] = \"useTabStops\";\n EditorOption[EditorOption[\"wordSeparators\"] = 119] = \"wordSeparators\";\n EditorOption[EditorOption[\"wordWrap\"] = 120] = \"wordWrap\";\n EditorOption[EditorOption[\"wordWrapBreakAfterCharacters\"] = 121] = \"wordWrapBreakAfterCharacters\";\n EditorOption[EditorOption[\"wordWrapBreakBeforeCharacters\"] = 122] = \"wordWrapBreakBeforeCharacters\";\n EditorOption[EditorOption[\"wordWrapColumn\"] = 123] = \"wordWrapColumn\";\n EditorOption[EditorOption[\"wordWrapOverride1\"] = 124] = \"wordWrapOverride1\";\n EditorOption[EditorOption[\"wordWrapOverride2\"] = 125] = \"wordWrapOverride2\";\n EditorOption[EditorOption[\"wrappingIndent\"] = 126] = \"wrappingIndent\";\n EditorOption[EditorOption[\"wrappingStrategy\"] = 127] = \"wrappingStrategy\";\n EditorOption[EditorOption[\"showDeprecated\"] = 128] = \"showDeprecated\";\n EditorOption[EditorOption[\"inlayHints\"] = 129] = \"inlayHints\";\n EditorOption[EditorOption[\"editorClassName\"] = 130] = \"editorClassName\";\n EditorOption[EditorOption[\"pixelRatio\"] = 131] = \"pixelRatio\";\n EditorOption[EditorOption[\"tabFocusMode\"] = 132] = \"tabFocusMode\";\n EditorOption[EditorOption[\"layoutInfo\"] = 133] = \"layoutInfo\";\n EditorOption[EditorOption[\"wrappingInfo\"] = 134] = \"wrappingInfo\";\n})(EditorOption || (EditorOption = {}));\n/**\n * End of line character preference.\n */\nexport var EndOfLinePreference;\n(function (EndOfLinePreference) {\n /**\n * Use the end of line character identified in the text buffer.\n */\n EndOfLinePreference[EndOfLinePreference[\"TextDefined\"] = 0] = \"TextDefined\";\n /**\n * Use line feed (\\n) as the end of line character.\n */\n EndOfLinePreference[EndOfLinePreference[\"LF\"] = 1] = \"LF\";\n /**\n * Use carriage return and line feed (\\r\\n) as the end of line character.\n */\n EndOfLinePreference[EndOfLinePreference[\"CRLF\"] = 2] = \"CRLF\";\n})(EndOfLinePreference || (EndOfLinePreference = {}));\n/**\n * End of line character preference.\n */\nexport var EndOfLineSequence;\n(function (EndOfLineSequence) {\n /**\n * Use line feed (\\n) as the end of line character.\n */\n EndOfLineSequence[EndOfLineSequence[\"LF\"] = 0] = \"LF\";\n /**\n * Use carriage return and line feed (\\r\\n) as the end of line character.\n */\n EndOfLineSequence[EndOfLineSequence[\"CRLF\"] = 1] = \"CRLF\";\n})(EndOfLineSequence || (EndOfLineSequence = {}));\n/**\n * Describes what to do with the indentation when pressing Enter.\n */\nexport var IndentAction;\n(function (IndentAction) {\n /**\n * Insert new line and copy the previous line's indentation.\n */\n IndentAction[IndentAction[\"None\"] = 0] = \"None\";\n /**\n * Insert new line and indent once (relative to the previous line's indentation).\n */\n IndentAction[IndentAction[\"Indent\"] = 1] = \"Indent\";\n /**\n * Insert two new lines:\n * - the first one indented which will hold the cursor\n * - the second one at the same indentation level\n */\n IndentAction[IndentAction[\"IndentOutdent\"] = 2] = \"IndentOutdent\";\n /**\n * Insert new line and outdent once (relative to the previous line's indentation).\n */\n IndentAction[IndentAction[\"Outdent\"] = 3] = \"Outdent\";\n})(IndentAction || (IndentAction = {}));\nexport var InjectedTextCursorStops;\n(function (InjectedTextCursorStops) {\n InjectedTextCursorStops[InjectedTextCursorStops[\"Both\"] = 0] = \"Both\";\n InjectedTextCursorStops[InjectedTextCursorStops[\"Right\"] = 1] = \"Right\";\n InjectedTextCursorStops[InjectedTextCursorStops[\"Left\"] = 2] = \"Left\";\n InjectedTextCursorStops[InjectedTextCursorStops[\"None\"] = 3] = \"None\";\n})(InjectedTextCursorStops || (InjectedTextCursorStops = {}));\nexport var InlayHintKind;\n(function (InlayHintKind) {\n InlayHintKind[InlayHintKind[\"Type\"] = 1] = \"Type\";\n InlayHintKind[InlayHintKind[\"Parameter\"] = 2] = \"Parameter\";\n})(InlayHintKind || (InlayHintKind = {}));\n/**\n * How an {@link InlineCompletionsProvider inline completion provider} was triggered.\n */\nexport var InlineCompletionTriggerKind;\n(function (InlineCompletionTriggerKind) {\n /**\n * Completion was triggered automatically while editing.\n * It is sufficient to return a single completion item in this case.\n */\n InlineCompletionTriggerKind[InlineCompletionTriggerKind[\"Automatic\"] = 0] = \"Automatic\";\n /**\n * Completion was triggered explicitly by a user gesture.\n * Return multiple completion items to enable cycling through them.\n */\n InlineCompletionTriggerKind[InlineCompletionTriggerKind[\"Explicit\"] = 1] = \"Explicit\";\n})(InlineCompletionTriggerKind || (InlineCompletionTriggerKind = {}));\n/**\n * Virtual Key Codes, the value does not hold any inherent meaning.\n * Inspired somewhat from https://msdn.microsoft.com/en-us/library/windows/desktop/dd375731(v=vs.85).aspx\n * But these are \"more general\", as they should work across browsers & OS`s.\n */\nexport var KeyCode;\n(function (KeyCode) {\n KeyCode[KeyCode[\"DependsOnKbLayout\"] = -1] = \"DependsOnKbLayout\";\n /**\n * Placed first to cover the 0 value of the enum.\n */\n KeyCode[KeyCode[\"Unknown\"] = 0] = \"Unknown\";\n KeyCode[KeyCode[\"Backspace\"] = 1] = \"Backspace\";\n KeyCode[KeyCode[\"Tab\"] = 2] = \"Tab\";\n KeyCode[KeyCode[\"Enter\"] = 3] = \"Enter\";\n KeyCode[KeyCode[\"Shift\"] = 4] = \"Shift\";\n KeyCode[KeyCode[\"Ctrl\"] = 5] = \"Ctrl\";\n KeyCode[KeyCode[\"Alt\"] = 6] = \"Alt\";\n KeyCode[KeyCode[\"PauseBreak\"] = 7] = \"PauseBreak\";\n KeyCode[KeyCode[\"CapsLock\"] = 8] = \"CapsLock\";\n KeyCode[KeyCode[\"Escape\"] = 9] = \"Escape\";\n KeyCode[KeyCode[\"Space\"] = 10] = \"Space\";\n KeyCode[KeyCode[\"PageUp\"] = 11] = \"PageUp\";\n KeyCode[KeyCode[\"PageDown\"] = 12] = \"PageDown\";\n KeyCode[KeyCode[\"End\"] = 13] = \"End\";\n KeyCode[KeyCode[\"Home\"] = 14] = \"Home\";\n KeyCode[KeyCode[\"LeftArrow\"] = 15] = \"LeftArrow\";\n KeyCode[KeyCode[\"UpArrow\"] = 16] = \"UpArrow\";\n KeyCode[KeyCode[\"RightArrow\"] = 17] = \"RightArrow\";\n KeyCode[KeyCode[\"DownArrow\"] = 18] = \"DownArrow\";\n KeyCode[KeyCode[\"Insert\"] = 19] = \"Insert\";\n KeyCode[KeyCode[\"Delete\"] = 20] = \"Delete\";\n KeyCode[KeyCode[\"Digit0\"] = 21] = \"Digit0\";\n KeyCode[KeyCode[\"Digit1\"] = 22] = \"Digit1\";\n KeyCode[KeyCode[\"Digit2\"] = 23] = \"Digit2\";\n KeyCode[KeyCode[\"Digit3\"] = 24] = \"Digit3\";\n KeyCode[KeyCode[\"Digit4\"] = 25] = \"Digit4\";\n KeyCode[KeyCode[\"Digit5\"] = 26] = \"Digit5\";\n KeyCode[KeyCode[\"Digit6\"] = 27] = \"Digit6\";\n KeyCode[KeyCode[\"Digit7\"] = 28] = \"Digit7\";\n KeyCode[KeyCode[\"Digit8\"] = 29] = \"Digit8\";\n KeyCode[KeyCode[\"Digit9\"] = 30] = \"Digit9\";\n KeyCode[KeyCode[\"KeyA\"] = 31] = \"KeyA\";\n KeyCode[KeyCode[\"KeyB\"] = 32] = \"KeyB\";\n KeyCode[KeyCode[\"KeyC\"] = 33] = \"KeyC\";\n KeyCode[KeyCode[\"KeyD\"] = 34] = \"KeyD\";\n KeyCode[KeyCode[\"KeyE\"] = 35] = \"KeyE\";\n KeyCode[KeyCode[\"KeyF\"] = 36] = \"KeyF\";\n KeyCode[KeyCode[\"KeyG\"] = 37] = \"KeyG\";\n KeyCode[KeyCode[\"KeyH\"] = 38] = \"KeyH\";\n KeyCode[KeyCode[\"KeyI\"] = 39] = \"KeyI\";\n KeyCode[KeyCode[\"KeyJ\"] = 40] = \"KeyJ\";\n KeyCode[KeyCode[\"KeyK\"] = 41] = \"KeyK\";\n KeyCode[KeyCode[\"KeyL\"] = 42] = \"KeyL\";\n KeyCode[KeyCode[\"KeyM\"] = 43] = \"KeyM\";\n KeyCode[KeyCode[\"KeyN\"] = 44] = \"KeyN\";\n KeyCode[KeyCode[\"KeyO\"] = 45] = \"KeyO\";\n KeyCode[KeyCode[\"KeyP\"] = 46] = \"KeyP\";\n KeyCode[KeyCode[\"KeyQ\"] = 47] = \"KeyQ\";\n KeyCode[KeyCode[\"KeyR\"] = 48] = \"KeyR\";\n KeyCode[KeyCode[\"KeyS\"] = 49] = \"KeyS\";\n KeyCode[KeyCode[\"KeyT\"] = 50] = \"KeyT\";\n KeyCode[KeyCode[\"KeyU\"] = 51] = \"KeyU\";\n KeyCode[KeyCode[\"KeyV\"] = 52] = \"KeyV\";\n KeyCode[KeyCode[\"KeyW\"] = 53] = \"KeyW\";\n KeyCode[KeyCode[\"KeyX\"] = 54] = \"KeyX\";\n KeyCode[KeyCode[\"KeyY\"] = 55] = \"KeyY\";\n KeyCode[KeyCode[\"KeyZ\"] = 56] = \"KeyZ\";\n KeyCode[KeyCode[\"Meta\"] = 57] = \"Meta\";\n KeyCode[KeyCode[\"ContextMenu\"] = 58] = \"ContextMenu\";\n KeyCode[KeyCode[\"F1\"] = 59] = \"F1\";\n KeyCode[KeyCode[\"F2\"] = 60] = \"F2\";\n KeyCode[KeyCode[\"F3\"] = 61] = \"F3\";\n KeyCode[KeyCode[\"F4\"] = 62] = \"F4\";\n KeyCode[KeyCode[\"F5\"] = 63] = \"F5\";\n KeyCode[KeyCode[\"F6\"] = 64] = \"F6\";\n KeyCode[KeyCode[\"F7\"] = 65] = \"F7\";\n KeyCode[KeyCode[\"F8\"] = 66] = \"F8\";\n KeyCode[KeyCode[\"F9\"] = 67] = \"F9\";\n KeyCode[KeyCode[\"F10\"] = 68] = \"F10\";\n KeyCode[KeyCode[\"F11\"] = 69] = \"F11\";\n KeyCode[KeyCode[\"F12\"] = 70] = \"F12\";\n KeyCode[KeyCode[\"F13\"] = 71] = \"F13\";\n KeyCode[KeyCode[\"F14\"] = 72] = \"F14\";\n KeyCode[KeyCode[\"F15\"] = 73] = \"F15\";\n KeyCode[KeyCode[\"F16\"] = 74] = \"F16\";\n KeyCode[KeyCode[\"F17\"] = 75] = \"F17\";\n KeyCode[KeyCode[\"F18\"] = 76] = \"F18\";\n KeyCode[KeyCode[\"F19\"] = 77] = \"F19\";\n KeyCode[KeyCode[\"NumLock\"] = 78] = \"NumLock\";\n KeyCode[KeyCode[\"ScrollLock\"] = 79] = \"ScrollLock\";\n /**\n * Used for miscellaneous characters; it can vary by keyboard.\n * For the US standard keyboard, the ';:' key\n */\n KeyCode[KeyCode[\"Semicolon\"] = 80] = \"Semicolon\";\n /**\n * For any country/region, the '+' key\n * For the US standard keyboard, the '=+' key\n */\n KeyCode[KeyCode[\"Equal\"] = 81] = \"Equal\";\n /**\n * For any country/region, the ',' key\n * For the US standard keyboard, the ',<' key\n */\n KeyCode[KeyCode[\"Comma\"] = 82] = \"Comma\";\n /**\n * For any country/region, the '-' key\n * For the US standard keyboard, the '-_' key\n */\n KeyCode[KeyCode[\"Minus\"] = 83] = \"Minus\";\n /**\n * For any country/region, the '.' key\n * For the US standard keyboard, the '.>' key\n */\n KeyCode[KeyCode[\"Period\"] = 84] = \"Period\";\n /**\n * Used for miscellaneous characters; it can vary by keyboard.\n * For the US standard keyboard, the '/?' key\n */\n KeyCode[KeyCode[\"Slash\"] = 85] = \"Slash\";\n /**\n * Used for miscellaneous characters; it can vary by keyboard.\n * For the US standard keyboard, the '`~' key\n */\n KeyCode[KeyCode[\"Backquote\"] = 86] = \"Backquote\";\n /**\n * Used for miscellaneous characters; it can vary by keyboard.\n * For the US standard keyboard, the '[{' key\n */\n KeyCode[KeyCode[\"BracketLeft\"] = 87] = \"BracketLeft\";\n /**\n * Used for miscellaneous characters; it can vary by keyboard.\n * For the US standard keyboard, the '\\|' key\n */\n KeyCode[KeyCode[\"Backslash\"] = 88] = \"Backslash\";\n /**\n * Used for miscellaneous characters; it can vary by keyboard.\n * For the US standard keyboard, the ']}' key\n */\n KeyCode[KeyCode[\"BracketRight\"] = 89] = \"BracketRight\";\n /**\n * Used for miscellaneous characters; it can vary by keyboard.\n * For the US standard keyboard, the ''\"' key\n */\n KeyCode[KeyCode[\"Quote\"] = 90] = \"Quote\";\n /**\n * Used for miscellaneous characters; it can vary by keyboard.\n */\n KeyCode[KeyCode[\"OEM_8\"] = 91] = \"OEM_8\";\n /**\n * Either the angle bracket key or the backslash key on the RT 102-key keyboard.\n */\n KeyCode[KeyCode[\"IntlBackslash\"] = 92] = \"IntlBackslash\";\n KeyCode[KeyCode[\"Numpad0\"] = 93] = \"Numpad0\";\n KeyCode[KeyCode[\"Numpad1\"] = 94] = \"Numpad1\";\n KeyCode[KeyCode[\"Numpad2\"] = 95] = \"Numpad2\";\n KeyCode[KeyCode[\"Numpad3\"] = 96] = \"Numpad3\";\n KeyCode[KeyCode[\"Numpad4\"] = 97] = \"Numpad4\";\n KeyCode[KeyCode[\"Numpad5\"] = 98] = \"Numpad5\";\n KeyCode[KeyCode[\"Numpad6\"] = 99] = \"Numpad6\";\n KeyCode[KeyCode[\"Numpad7\"] = 100] = \"Numpad7\";\n KeyCode[KeyCode[\"Numpad8\"] = 101] = \"Numpad8\";\n KeyCode[KeyCode[\"Numpad9\"] = 102] = \"Numpad9\";\n KeyCode[KeyCode[\"NumpadMultiply\"] = 103] = \"NumpadMultiply\";\n KeyCode[KeyCode[\"NumpadAdd\"] = 104] = \"NumpadAdd\";\n KeyCode[KeyCode[\"NUMPAD_SEPARATOR\"] = 105] = \"NUMPAD_SEPARATOR\";\n KeyCode[KeyCode[\"NumpadSubtract\"] = 106] = \"NumpadSubtract\";\n KeyCode[KeyCode[\"NumpadDecimal\"] = 107] = \"NumpadDecimal\";\n KeyCode[KeyCode[\"NumpadDivide\"] = 108] = \"NumpadDivide\";\n /**\n * Cover all key codes when IME is processing input.\n */\n KeyCode[KeyCode[\"KEY_IN_COMPOSITION\"] = 109] = \"KEY_IN_COMPOSITION\";\n KeyCode[KeyCode[\"ABNT_C1\"] = 110] = \"ABNT_C1\";\n KeyCode[KeyCode[\"ABNT_C2\"] = 111] = \"ABNT_C2\";\n KeyCode[KeyCode[\"AudioVolumeMute\"] = 112] = \"AudioVolumeMute\";\n KeyCode[KeyCode[\"AudioVolumeUp\"] = 113] = \"AudioVolumeUp\";\n KeyCode[KeyCode[\"AudioVolumeDown\"] = 114] = \"AudioVolumeDown\";\n KeyCode[KeyCode[\"BrowserSearch\"] = 115] = \"BrowserSearch\";\n KeyCode[KeyCode[\"BrowserHome\"] = 116] = \"BrowserHome\";\n KeyCode[KeyCode[\"BrowserBack\"] = 117] = \"BrowserBack\";\n KeyCode[KeyCode[\"BrowserForward\"] = 118] = \"BrowserForward\";\n KeyCode[KeyCode[\"MediaTrackNext\"] = 119] = \"MediaTrackNext\";\n KeyCode[KeyCode[\"MediaTrackPrevious\"] = 120] = \"MediaTrackPrevious\";\n KeyCode[KeyCode[\"MediaStop\"] = 121] = \"MediaStop\";\n KeyCode[KeyCode[\"MediaPlayPause\"] = 122] = \"MediaPlayPause\";\n KeyCode[KeyCode[\"LaunchMediaPlayer\"] = 123] = \"LaunchMediaPlayer\";\n KeyCode[KeyCode[\"LaunchMail\"] = 124] = \"LaunchMail\";\n KeyCode[KeyCode[\"LaunchApp2\"] = 125] = \"LaunchApp2\";\n /**\n * VK_CLEAR, 0x0C, CLEAR key\n */\n KeyCode[KeyCode[\"Clear\"] = 126] = \"Clear\";\n /**\n * Placed last to cover the length of the enum.\n * Please do not depend on this value!\n */\n KeyCode[KeyCode[\"MAX_VALUE\"] = 127] = \"MAX_VALUE\";\n})(KeyCode || (KeyCode = {}));\nexport var MarkerSeverity;\n(function (MarkerSeverity) {\n MarkerSeverity[MarkerSeverity[\"Hint\"] = 1] = \"Hint\";\n MarkerSeverity[MarkerSeverity[\"Info\"] = 2] = \"Info\";\n MarkerSeverity[MarkerSeverity[\"Warning\"] = 4] = \"Warning\";\n MarkerSeverity[MarkerSeverity[\"Error\"] = 8] = \"Error\";\n})(MarkerSeverity || (MarkerSeverity = {}));\nexport var MarkerTag;\n(function (MarkerTag) {\n MarkerTag[MarkerTag[\"Unnecessary\"] = 1] = \"Unnecessary\";\n MarkerTag[MarkerTag[\"Deprecated\"] = 2] = \"Deprecated\";\n})(MarkerTag || (MarkerTag = {}));\n/**\n * Position in the minimap to render the decoration.\n */\nexport var MinimapPosition;\n(function (MinimapPosition) {\n MinimapPosition[MinimapPosition[\"Inline\"] = 1] = \"Inline\";\n MinimapPosition[MinimapPosition[\"Gutter\"] = 2] = \"Gutter\";\n})(MinimapPosition || (MinimapPosition = {}));\n/**\n * Type of hit element with the mouse in the editor.\n */\nexport var MouseTargetType;\n(function (MouseTargetType) {\n /**\n * Mouse is on top of an unknown element.\n */\n MouseTargetType[MouseTargetType[\"UNKNOWN\"] = 0] = \"UNKNOWN\";\n /**\n * Mouse is on top of the textarea used for input.\n */\n MouseTargetType[MouseTargetType[\"TEXTAREA\"] = 1] = \"TEXTAREA\";\n /**\n * Mouse is on top of the glyph margin\n */\n MouseTargetType[MouseTargetType[\"GUTTER_GLYPH_MARGIN\"] = 2] = \"GUTTER_GLYPH_MARGIN\";\n /**\n * Mouse is on top of the line numbers\n */\n MouseTargetType[MouseTargetType[\"GUTTER_LINE_NUMBERS\"] = 3] = \"GUTTER_LINE_NUMBERS\";\n /**\n * Mouse is on top of the line decorations\n */\n MouseTargetType[MouseTargetType[\"GUTTER_LINE_DECORATIONS\"] = 4] = \"GUTTER_LINE_DECORATIONS\";\n /**\n * Mouse is on top of the whitespace left in the gutter by a view zone.\n */\n MouseTargetType[MouseTargetType[\"GUTTER_VIEW_ZONE\"] = 5] = \"GUTTER_VIEW_ZONE\";\n /**\n * Mouse is on top of text in the content.\n */\n MouseTargetType[MouseTargetType[\"CONTENT_TEXT\"] = 6] = \"CONTENT_TEXT\";\n /**\n * Mouse is on top of empty space in the content (e.g. after line text or below last line)\n */\n MouseTargetType[MouseTargetType[\"CONTENT_EMPTY\"] = 7] = \"CONTENT_EMPTY\";\n /**\n * Mouse is on top of a view zone in the content.\n */\n MouseTargetType[MouseTargetType[\"CONTENT_VIEW_ZONE\"] = 8] = \"CONTENT_VIEW_ZONE\";\n /**\n * Mouse is on top of a content widget.\n */\n MouseTargetType[MouseTargetType[\"CONTENT_WIDGET\"] = 9] = \"CONTENT_WIDGET\";\n /**\n * Mouse is on top of the decorations overview ruler.\n */\n MouseTargetType[MouseTargetType[\"OVERVIEW_RULER\"] = 10] = \"OVERVIEW_RULER\";\n /**\n * Mouse is on top of a scrollbar.\n */\n MouseTargetType[MouseTargetType[\"SCROLLBAR\"] = 11] = \"SCROLLBAR\";\n /**\n * Mouse is on top of an overlay widget.\n */\n MouseTargetType[MouseTargetType[\"OVERLAY_WIDGET\"] = 12] = \"OVERLAY_WIDGET\";\n /**\n * Mouse is outside of the editor.\n */\n MouseTargetType[MouseTargetType[\"OUTSIDE_EDITOR\"] = 13] = \"OUTSIDE_EDITOR\";\n})(MouseTargetType || (MouseTargetType = {}));\n/**\n * A positioning preference for rendering overlay widgets.\n */\nexport var OverlayWidgetPositionPreference;\n(function (OverlayWidgetPositionPreference) {\n /**\n * Position the overlay widget in the top right corner\n */\n OverlayWidgetPositionPreference[OverlayWidgetPositionPreference[\"TOP_RIGHT_CORNER\"] = 0] = \"TOP_RIGHT_CORNER\";\n /**\n * Position the overlay widget in the bottom right corner\n */\n OverlayWidgetPositionPreference[OverlayWidgetPositionPreference[\"BOTTOM_RIGHT_CORNER\"] = 1] = \"BOTTOM_RIGHT_CORNER\";\n /**\n * Position the overlay widget in the top center\n */\n OverlayWidgetPositionPreference[OverlayWidgetPositionPreference[\"TOP_CENTER\"] = 2] = \"TOP_CENTER\";\n})(OverlayWidgetPositionPreference || (OverlayWidgetPositionPreference = {}));\n/**\n * Vertical Lane in the overview ruler of the editor.\n */\nexport var OverviewRulerLane;\n(function (OverviewRulerLane) {\n OverviewRulerLane[OverviewRulerLane[\"Left\"] = 1] = \"Left\";\n OverviewRulerLane[OverviewRulerLane[\"Center\"] = 2] = \"Center\";\n OverviewRulerLane[OverviewRulerLane[\"Right\"] = 4] = \"Right\";\n OverviewRulerLane[OverviewRulerLane[\"Full\"] = 7] = \"Full\";\n})(OverviewRulerLane || (OverviewRulerLane = {}));\nexport var PositionAffinity;\n(function (PositionAffinity) {\n /**\n * Prefers the left most position.\n */\n PositionAffinity[PositionAffinity[\"Left\"] = 0] = \"Left\";\n /**\n * Prefers the right most position.\n */\n PositionAffinity[PositionAffinity[\"Right\"] = 1] = \"Right\";\n /**\n * No preference.\n */\n PositionAffinity[PositionAffinity[\"None\"] = 2] = \"None\";\n /**\n * If the given position is on injected text, prefers the position left of it.\n */\n PositionAffinity[PositionAffinity[\"LeftOfInjectedText\"] = 3] = \"LeftOfInjectedText\";\n /**\n * If the given position is on injected text, prefers the position right of it.\n */\n PositionAffinity[PositionAffinity[\"RightOfInjectedText\"] = 4] = \"RightOfInjectedText\";\n})(PositionAffinity || (PositionAffinity = {}));\nexport var RenderLineNumbersType;\n(function (RenderLineNumbersType) {\n RenderLineNumbersType[RenderLineNumbersType[\"Off\"] = 0] = \"Off\";\n RenderLineNumbersType[RenderLineNumbersType[\"On\"] = 1] = \"On\";\n RenderLineNumbersType[RenderLineNumbersType[\"Relative\"] = 2] = \"Relative\";\n RenderLineNumbersType[RenderLineNumbersType[\"Interval\"] = 3] = \"Interval\";\n RenderLineNumbersType[RenderLineNumbersType[\"Custom\"] = 4] = \"Custom\";\n})(RenderLineNumbersType || (RenderLineNumbersType = {}));\nexport var RenderMinimap;\n(function (RenderMinimap) {\n RenderMinimap[RenderMinimap[\"None\"] = 0] = \"None\";\n RenderMinimap[RenderMinimap[\"Text\"] = 1] = \"Text\";\n RenderMinimap[RenderMinimap[\"Blocks\"] = 2] = \"Blocks\";\n})(RenderMinimap || (RenderMinimap = {}));\nexport var ScrollType;\n(function (ScrollType) {\n ScrollType[ScrollType[\"Smooth\"] = 0] = \"Smooth\";\n ScrollType[ScrollType[\"Immediate\"] = 1] = \"Immediate\";\n})(ScrollType || (ScrollType = {}));\nexport var ScrollbarVisibility;\n(function (ScrollbarVisibility) {\n ScrollbarVisibility[ScrollbarVisibility[\"Auto\"] = 1] = \"Auto\";\n ScrollbarVisibility[ScrollbarVisibility[\"Hidden\"] = 2] = \"Hidden\";\n ScrollbarVisibility[ScrollbarVisibility[\"Visible\"] = 3] = \"Visible\";\n})(ScrollbarVisibility || (ScrollbarVisibility = {}));\n/**\n * The direction of a selection.\n */\nexport var SelectionDirection;\n(function (SelectionDirection) {\n /**\n * The selection starts above where it ends.\n */\n SelectionDirection[SelectionDirection[\"LTR\"] = 0] = \"LTR\";\n /**\n * The selection starts below where it ends.\n */\n SelectionDirection[SelectionDirection[\"RTL\"] = 1] = \"RTL\";\n})(SelectionDirection || (SelectionDirection = {}));\nexport var SignatureHelpTriggerKind;\n(function (SignatureHelpTriggerKind) {\n SignatureHelpTriggerKind[SignatureHelpTriggerKind[\"Invoke\"] = 1] = \"Invoke\";\n SignatureHelpTriggerKind[SignatureHelpTriggerKind[\"TriggerCharacter\"] = 2] = \"TriggerCharacter\";\n SignatureHelpTriggerKind[SignatureHelpTriggerKind[\"ContentChange\"] = 3] = \"ContentChange\";\n})(SignatureHelpTriggerKind || (SignatureHelpTriggerKind = {}));\n/**\n * A symbol kind.\n */\nexport var SymbolKind;\n(function (SymbolKind) {\n SymbolKind[SymbolKind[\"File\"] = 0] = \"File\";\n SymbolKind[SymbolKind[\"Module\"] = 1] = \"Module\";\n SymbolKind[SymbolKind[\"Namespace\"] = 2] = \"Namespace\";\n SymbolKind[SymbolKind[\"Package\"] = 3] = \"Package\";\n SymbolKind[SymbolKind[\"Class\"] = 4] = \"Class\";\n SymbolKind[SymbolKind[\"Method\"] = 5] = \"Method\";\n SymbolKind[SymbolKind[\"Property\"] = 6] = \"Property\";\n SymbolKind[SymbolKind[\"Field\"] = 7] = \"Field\";\n SymbolKind[SymbolKind[\"Constructor\"] = 8] = \"Constructor\";\n SymbolKind[SymbolKind[\"Enum\"] = 9] = \"Enum\";\n SymbolKind[SymbolKind[\"Interface\"] = 10] = \"Interface\";\n SymbolKind[SymbolKind[\"Function\"] = 11] = \"Function\";\n SymbolKind[SymbolKind[\"Variable\"] = 12] = \"Variable\";\n SymbolKind[SymbolKind[\"Constant\"] = 13] = \"Constant\";\n SymbolKind[SymbolKind[\"String\"] = 14] = \"String\";\n SymbolKind[SymbolKind[\"Number\"] = 15] = \"Number\";\n SymbolKind[SymbolKind[\"Boolean\"] = 16] = \"Boolean\";\n SymbolKind[SymbolKind[\"Array\"] = 17] = \"Array\";\n SymbolKind[SymbolKind[\"Object\"] = 18] = \"Object\";\n SymbolKind[SymbolKind[\"Key\"] = 19] = \"Key\";\n SymbolKind[SymbolKind[\"Null\"] = 20] = \"Null\";\n SymbolKind[SymbolKind[\"EnumMember\"] = 21] = \"EnumMember\";\n SymbolKind[SymbolKind[\"Struct\"] = 22] = \"Struct\";\n SymbolKind[SymbolKind[\"Event\"] = 23] = \"Event\";\n SymbolKind[SymbolKind[\"Operator\"] = 24] = \"Operator\";\n SymbolKind[SymbolKind[\"TypeParameter\"] = 25] = \"TypeParameter\";\n})(SymbolKind || (SymbolKind = {}));\nexport var SymbolTag;\n(function (SymbolTag) {\n SymbolTag[SymbolTag[\"Deprecated\"] = 1] = \"Deprecated\";\n})(SymbolTag || (SymbolTag = {}));\n/**\n * The kind of animation in which the editor's cursor should be rendered.\n */\nexport var TextEditorCursorBlinkingStyle;\n(function (TextEditorCursorBlinkingStyle) {\n /**\n * Hidden\n */\n TextEditorCursorBlinkingStyle[TextEditorCursorBlinkingStyle[\"Hidden\"] = 0] = \"Hidden\";\n /**\n * Blinking\n */\n TextEditorCursorBlinkingStyle[TextEditorCursorBlinkingStyle[\"Blink\"] = 1] = \"Blink\";\n /**\n * Blinking with smooth fading\n */\n TextEditorCursorBlinkingStyle[TextEditorCursorBlinkingStyle[\"Smooth\"] = 2] = \"Smooth\";\n /**\n * Blinking with prolonged filled state and smooth fading\n */\n TextEditorCursorBlinkingStyle[TextEditorCursorBlinkingStyle[\"Phase\"] = 3] = \"Phase\";\n /**\n * Expand collapse animation on the y axis\n */\n TextEditorCursorBlinkingStyle[TextEditorCursorBlinkingStyle[\"Expand\"] = 4] = \"Expand\";\n /**\n * No-Blinking\n */\n TextEditorCursorBlinkingStyle[TextEditorCursorBlinkingStyle[\"Solid\"] = 5] = \"Solid\";\n})(TextEditorCursorBlinkingStyle || (TextEditorCursorBlinkingStyle = {}));\n/**\n * The style in which the editor's cursor should be rendered.\n */\nexport var TextEditorCursorStyle;\n(function (TextEditorCursorStyle) {\n /**\n * As a vertical line (sitting between two characters).\n */\n TextEditorCursorStyle[TextEditorCursorStyle[\"Line\"] = 1] = \"Line\";\n /**\n * As a block (sitting on top of a character).\n */\n TextEditorCursorStyle[TextEditorCursorStyle[\"Block\"] = 2] = \"Block\";\n /**\n * As a horizontal line (sitting under a character).\n */\n TextEditorCursorStyle[TextEditorCursorStyle[\"Underline\"] = 3] = \"Underline\";\n /**\n * As a thin vertical line (sitting between two characters).\n */\n TextEditorCursorStyle[TextEditorCursorStyle[\"LineThin\"] = 4] = \"LineThin\";\n /**\n * As an outlined block (sitting on top of a character).\n */\n TextEditorCursorStyle[TextEditorCursorStyle[\"BlockOutline\"] = 5] = \"BlockOutline\";\n /**\n * As a thin horizontal line (sitting under a character).\n */\n TextEditorCursorStyle[TextEditorCursorStyle[\"UnderlineThin\"] = 6] = \"UnderlineThin\";\n})(TextEditorCursorStyle || (TextEditorCursorStyle = {}));\n/**\n * Describes the behavior of decorations when typing/editing near their edges.\n * Note: Please do not edit the values, as they very carefully match `DecorationRangeBehavior`\n */\nexport var TrackedRangeStickiness;\n(function (TrackedRangeStickiness) {\n TrackedRangeStickiness[TrackedRangeStickiness[\"AlwaysGrowsWhenTypingAtEdges\"] = 0] = \"AlwaysGrowsWhenTypingAtEdges\";\n TrackedRangeStickiness[TrackedRangeStickiness[\"NeverGrowsWhenTypingAtEdges\"] = 1] = \"NeverGrowsWhenTypingAtEdges\";\n TrackedRangeStickiness[TrackedRangeStickiness[\"GrowsOnlyWhenTypingBefore\"] = 2] = \"GrowsOnlyWhenTypingBefore\";\n TrackedRangeStickiness[TrackedRangeStickiness[\"GrowsOnlyWhenTypingAfter\"] = 3] = \"GrowsOnlyWhenTypingAfter\";\n})(TrackedRangeStickiness || (TrackedRangeStickiness = {}));\n/**\n * Describes how to indent wrapped lines.\n */\nexport var WrappingIndent;\n(function (WrappingIndent) {\n /**\n * No indentation => wrapped lines begin at column 1.\n */\n WrappingIndent[WrappingIndent[\"None\"] = 0] = \"None\";\n /**\n * Same => wrapped lines get the same indentation as the parent.\n */\n WrappingIndent[WrappingIndent[\"Same\"] = 1] = \"Same\";\n /**\n * Indent => wrapped lines get +1 indentation toward the parent.\n */\n WrappingIndent[WrappingIndent[\"Indent\"] = 2] = \"Indent\";\n /**\n * DeepIndent => wrapped lines get +2 indentation toward the parent.\n */\n WrappingIndent[WrappingIndent[\"DeepIndent\"] = 3] = \"DeepIndent\";\n})(WrappingIndent || (WrappingIndent = {}));\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { CancellationTokenSource } from '../../../base/common/cancellation.js';\nimport { Emitter } from '../../../base/common/event.js';\nimport { KeyChord } from '../../../base/common/keyCodes.js';\nimport { URI } from '../../../base/common/uri.js';\nimport { Position } from '../core/position.js';\nimport { Range } from '../core/range.js';\nimport { Selection } from '../core/selection.js';\nimport { Token } from '../languages.js';\nimport * as standaloneEnums from '../standalone/standaloneEnums.js';\nexport class KeyMod {\n static chord(firstPart, secondPart) {\n return KeyChord(firstPart, secondPart);\n }\n}\nKeyMod.CtrlCmd = 2048 /* ConstKeyMod.CtrlCmd */;\nKeyMod.Shift = 1024 /* ConstKeyMod.Shift */;\nKeyMod.Alt = 512 /* ConstKeyMod.Alt */;\nKeyMod.WinCtrl = 256 /* ConstKeyMod.WinCtrl */;\nexport function createMonacoBaseAPI() {\n return {\n editor: undefined,\n languages: undefined,\n CancellationTokenSource: CancellationTokenSource,\n Emitter: Emitter,\n KeyCode: standaloneEnums.KeyCode,\n KeyMod: KeyMod,\n Position: Position,\n Range: Range,\n Selection: Selection,\n SelectionDirection: standaloneEnums.SelectionDirection,\n MarkerSeverity: standaloneEnums.MarkerSeverity,\n MarkerTag: standaloneEnums.MarkerTag,\n Uri: URI,\n Token: Token\n };\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { CharacterClassifier } from './characterClassifier.js';\nexport class WordCharacterClassifier extends CharacterClassifier {\n constructor(wordSeparators) {\n super(0 /* WordCharacterClass.Regular */);\n for (let i = 0, len = wordSeparators.length; i < len; i++) {\n this.set(wordSeparators.charCodeAt(i), 2 /* WordCharacterClass.WordSeparator */);\n }\n this.set(32 /* CharCode.Space */, 1 /* WordCharacterClass.Whitespace */);\n this.set(9 /* CharCode.Tab */, 1 /* WordCharacterClass.Whitespace */);\n }\n}\nfunction once(computeFn) {\n const cache = {}; // TODO@Alex unbounded cache\n return (input) => {\n if (!cache.hasOwnProperty(input)) {\n cache[input] = computeFn(input);\n }\n return cache[input];\n };\n}\nexport const getMapForWordSeparators = once((input) => new WordCharacterClassifier(input));\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { isArray, isTypedArray, isObject, isUndefinedOrNull } from './types.js';\nexport function deepClone(obj) {\n if (!obj || typeof obj !== 'object') {\n return obj;\n }\n if (obj instanceof RegExp) {\n // See https://github.com/microsoft/TypeScript/issues/10990\n return obj;\n }\n const result = Array.isArray(obj) ? [] : {};\n Object.keys(obj).forEach((key) => {\n if (obj[key] && typeof obj[key] === 'object') {\n result[key] = deepClone(obj[key]);\n }\n else {\n result[key] = obj[key];\n }\n });\n return result;\n}\nexport function deepFreeze(obj) {\n if (!obj || typeof obj !== 'object') {\n return obj;\n }\n const stack = [obj];\n while (stack.length > 0) {\n const obj = stack.shift();\n Object.freeze(obj);\n for (const key in obj) {\n if (_hasOwnProperty.call(obj, key)) {\n const prop = obj[key];\n if (typeof prop === 'object' && !Object.isFrozen(prop) && !isTypedArray(prop)) {\n stack.push(prop);\n }\n }\n }\n }\n return obj;\n}\nconst _hasOwnProperty = Object.prototype.hasOwnProperty;\nexport function cloneAndChange(obj, changer) {\n return _cloneAndChange(obj, changer, new Set());\n}\nfunction _cloneAndChange(obj, changer, seen) {\n if (isUndefinedOrNull(obj)) {\n return obj;\n }\n const changed = changer(obj);\n if (typeof changed !== 'undefined') {\n return changed;\n }\n if (isArray(obj)) {\n const r1 = [];\n for (const e of obj) {\n r1.push(_cloneAndChange(e, changer, seen));\n }\n return r1;\n }\n if (isObject(obj)) {\n if (seen.has(obj)) {\n throw new Error('Cannot clone recursive data-structure');\n }\n seen.add(obj);\n const r2 = {};\n for (const i2 in obj) {\n if (_hasOwnProperty.call(obj, i2)) {\n r2[i2] = _cloneAndChange(obj[i2], changer, seen);\n }\n }\n seen.delete(obj);\n return r2;\n }\n return obj;\n}\n/**\n * Copies all properties of source into destination. The optional parameter \"overwrite\" allows to control\n * if existing properties on the destination should be overwritten or not. Defaults to true (overwrite).\n */\nexport function mixin(destination, source, overwrite = true) {\n if (!isObject(destination)) {\n return source;\n }\n if (isObject(source)) {\n Object.keys(source).forEach(key => {\n if (key in destination) {\n if (overwrite) {\n if (isObject(destination[key]) && isObject(source[key])) {\n mixin(destination[key], source[key], overwrite);\n }\n else {\n destination[key] = source[key];\n }\n }\n }\n else {\n destination[key] = source[key];\n }\n });\n }\n return destination;\n}\nexport function equals(one, other) {\n if (one === other) {\n return true;\n }\n if (one === null || one === undefined || other === null || other === undefined) {\n return false;\n }\n if (typeof one !== typeof other) {\n return false;\n }\n if (typeof one !== 'object') {\n return false;\n }\n if ((Array.isArray(one)) !== (Array.isArray(other))) {\n return false;\n }\n let i;\n let key;\n if (Array.isArray(one)) {\n if (one.length !== other.length) {\n return false;\n }\n for (i = 0; i < one.length; i++) {\n if (!equals(one[i], other[i])) {\n return false;\n }\n }\n }\n else {\n const oneKeys = [];\n for (key in one) {\n oneKeys.push(key);\n }\n oneKeys.sort();\n const otherKeys = [];\n for (key in other) {\n otherKeys.push(key);\n }\n otherKeys.sort();\n if (!equals(oneKeys, otherKeys)) {\n return false;\n }\n for (i = 0; i < oneKeys.length; i++) {\n if (!equals(one[oneKeys[i]], other[oneKeys[i]])) {\n return false;\n }\n }\n }\n return true;\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { equals } from '../../base/common/objects.js';\n/**\n * Vertical Lane in the overview ruler of the editor.\n */\nexport var OverviewRulerLane;\n(function (OverviewRulerLane) {\n OverviewRulerLane[OverviewRulerLane[\"Left\"] = 1] = \"Left\";\n OverviewRulerLane[OverviewRulerLane[\"Center\"] = 2] = \"Center\";\n OverviewRulerLane[OverviewRulerLane[\"Right\"] = 4] = \"Right\";\n OverviewRulerLane[OverviewRulerLane[\"Full\"] = 7] = \"Full\";\n})(OverviewRulerLane || (OverviewRulerLane = {}));\n/**\n * Position in the minimap to render the decoration.\n */\nexport var MinimapPosition;\n(function (MinimapPosition) {\n MinimapPosition[MinimapPosition[\"Inline\"] = 1] = \"Inline\";\n MinimapPosition[MinimapPosition[\"Gutter\"] = 2] = \"Gutter\";\n})(MinimapPosition || (MinimapPosition = {}));\nexport var InjectedTextCursorStops;\n(function (InjectedTextCursorStops) {\n InjectedTextCursorStops[InjectedTextCursorStops[\"Both\"] = 0] = \"Both\";\n InjectedTextCursorStops[InjectedTextCursorStops[\"Right\"] = 1] = \"Right\";\n InjectedTextCursorStops[InjectedTextCursorStops[\"Left\"] = 2] = \"Left\";\n InjectedTextCursorStops[InjectedTextCursorStops[\"None\"] = 3] = \"None\";\n})(InjectedTextCursorStops || (InjectedTextCursorStops = {}));\nexport class TextModelResolvedOptions {\n /**\n * @internal\n */\n constructor(src) {\n this._textModelResolvedOptionsBrand = undefined;\n this.tabSize = Math.max(1, src.tabSize | 0);\n this.indentSize = src.tabSize | 0;\n this.insertSpaces = Boolean(src.insertSpaces);\n this.defaultEOL = src.defaultEOL | 0;\n this.trimAutoWhitespace = Boolean(src.trimAutoWhitespace);\n this.bracketPairColorizationOptions = src.bracketPairColorizationOptions;\n }\n /**\n * @internal\n */\n equals(other) {\n return (this.tabSize === other.tabSize\n && this.indentSize === other.indentSize\n && this.insertSpaces === other.insertSpaces\n && this.defaultEOL === other.defaultEOL\n && this.trimAutoWhitespace === other.trimAutoWhitespace\n && equals(this.bracketPairColorizationOptions, other.bracketPairColorizationOptions));\n }\n /**\n * @internal\n */\n createChangeEvent(newOpts) {\n return {\n tabSize: this.tabSize !== newOpts.tabSize,\n indentSize: this.indentSize !== newOpts.indentSize,\n insertSpaces: this.insertSpaces !== newOpts.insertSpaces,\n trimAutoWhitespace: this.trimAutoWhitespace !== newOpts.trimAutoWhitespace,\n };\n }\n}\nexport class FindMatch {\n /**\n * @internal\n */\n constructor(range, matches) {\n this._findMatchBrand = undefined;\n this.range = range;\n this.matches = matches;\n }\n}\n/**\n * @internal\n */\nexport function isITextSnapshot(obj) {\n return (obj && typeof obj.read === 'function');\n}\n/**\n * @internal\n */\nexport class ValidAnnotatedEditOperation {\n constructor(identifier, range, text, forceMoveMarkers, isAutoWhitespaceEdit, _isTracked) {\n this.identifier = identifier;\n this.range = range;\n this.text = text;\n this.forceMoveMarkers = forceMoveMarkers;\n this.isAutoWhitespaceEdit = isAutoWhitespaceEdit;\n this._isTracked = _isTracked;\n }\n}\n/**\n * @internal\n */\nexport class SearchData {\n constructor(regex, wordSeparators, simpleSearch) {\n this.regex = regex;\n this.wordSeparators = wordSeparators;\n this.simpleSearch = simpleSearch;\n }\n}\n/**\n * @internal\n */\nexport class ApplyEditsResult {\n constructor(reverseEdits, changes, trimAutoWhitespaceLineNumbers) {\n this.reverseEdits = reverseEdits;\n this.changes = changes;\n this.trimAutoWhitespaceLineNumbers = trimAutoWhitespaceLineNumbers;\n }\n}\n/**\n * @internal\n */\nexport function shouldSynchronizeModel(model) {\n return (!model.isTooLargeForSyncing() && !model.isForSimpleWidget);\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport * as strings from '../../../base/common/strings.js';\nimport { getMapForWordSeparators } from '../core/wordCharacterClassifier.js';\nimport { Position } from '../core/position.js';\nimport { Range } from '../core/range.js';\nimport { FindMatch, SearchData } from '../model.js';\nconst LIMIT_FIND_COUNT = 999;\nexport class SearchParams {\n constructor(searchString, isRegex, matchCase, wordSeparators) {\n this.searchString = searchString;\n this.isRegex = isRegex;\n this.matchCase = matchCase;\n this.wordSeparators = wordSeparators;\n }\n parseSearchRequest() {\n if (this.searchString === '') {\n return null;\n }\n // Try to create a RegExp out of the params\n let multiline;\n if (this.isRegex) {\n multiline = isMultilineRegexSource(this.searchString);\n }\n else {\n multiline = (this.searchString.indexOf('\\n') >= 0);\n }\n let regex = null;\n try {\n regex = strings.createRegExp(this.searchString, this.isRegex, {\n matchCase: this.matchCase,\n wholeWord: false,\n multiline: multiline,\n global: true,\n unicode: true\n });\n }\n catch (err) {\n return null;\n }\n if (!regex) {\n return null;\n }\n let canUseSimpleSearch = (!this.isRegex && !multiline);\n if (canUseSimpleSearch && this.searchString.toLowerCase() !== this.searchString.toUpperCase()) {\n // casing might make a difference\n canUseSimpleSearch = this.matchCase;\n }\n return new SearchData(regex, this.wordSeparators ? getMapForWordSeparators(this.wordSeparators) : null, canUseSimpleSearch ? this.searchString : null);\n }\n}\nexport function isMultilineRegexSource(searchString) {\n if (!searchString || searchString.length === 0) {\n return false;\n }\n for (let i = 0, len = searchString.length; i < len; i++) {\n const chCode = searchString.charCodeAt(i);\n if (chCode === 10 /* CharCode.LineFeed */) {\n return true;\n }\n if (chCode === 92 /* CharCode.Backslash */) {\n // move to next char\n i++;\n if (i >= len) {\n // string ends with a \\\n break;\n }\n const nextChCode = searchString.charCodeAt(i);\n if (nextChCode === 110 /* CharCode.n */ || nextChCode === 114 /* CharCode.r */ || nextChCode === 87 /* CharCode.W */) {\n return true;\n }\n }\n }\n return false;\n}\nexport function createFindMatch(range, rawMatches, captureMatches) {\n if (!captureMatches) {\n return new FindMatch(range, null);\n }\n const matches = [];\n for (let i = 0, len = rawMatches.length; i < len; i++) {\n matches[i] = rawMatches[i];\n }\n return new FindMatch(range, matches);\n}\nclass LineFeedCounter {\n constructor(text) {\n const lineFeedsOffsets = [];\n let lineFeedsOffsetsLen = 0;\n for (let i = 0, textLen = text.length; i < textLen; i++) {\n if (text.charCodeAt(i) === 10 /* CharCode.LineFeed */) {\n lineFeedsOffsets[lineFeedsOffsetsLen++] = i;\n }\n }\n this._lineFeedsOffsets = lineFeedsOffsets;\n }\n findLineFeedCountBeforeOffset(offset) {\n const lineFeedsOffsets = this._lineFeedsOffsets;\n let min = 0;\n let max = lineFeedsOffsets.length - 1;\n if (max === -1) {\n // no line feeds\n return 0;\n }\n if (offset <= lineFeedsOffsets[0]) {\n // before first line feed\n return 0;\n }\n while (min < max) {\n const mid = min + ((max - min) / 2 >> 0);\n if (lineFeedsOffsets[mid] >= offset) {\n max = mid - 1;\n }\n else {\n if (lineFeedsOffsets[mid + 1] >= offset) {\n // bingo!\n min = mid;\n max = mid;\n }\n else {\n min = mid + 1;\n }\n }\n }\n return min + 1;\n }\n}\nexport class TextModelSearch {\n static findMatches(model, searchParams, searchRange, captureMatches, limitResultCount) {\n const searchData = searchParams.parseSearchRequest();\n if (!searchData) {\n return [];\n }\n if (searchData.regex.multiline) {\n return this._doFindMatchesMultiline(model, searchRange, new Searcher(searchData.wordSeparators, searchData.regex), captureMatches, limitResultCount);\n }\n return this._doFindMatchesLineByLine(model, searchRange, searchData, captureMatches, limitResultCount);\n }\n /**\n * Multiline search always executes on the lines concatenated with \\n.\n * We must therefore compensate for the count of \\n in case the model is CRLF\n */\n static _getMultilineMatchRange(model, deltaOffset, text, lfCounter, matchIndex, match0) {\n let startOffset;\n let lineFeedCountBeforeMatch = 0;\n if (lfCounter) {\n lineFeedCountBeforeMatch = lfCounter.findLineFeedCountBeforeOffset(matchIndex);\n startOffset = deltaOffset + matchIndex + lineFeedCountBeforeMatch /* add as many \\r as there were \\n */;\n }\n else {\n startOffset = deltaOffset + matchIndex;\n }\n let endOffset;\n if (lfCounter) {\n const lineFeedCountBeforeEndOfMatch = lfCounter.findLineFeedCountBeforeOffset(matchIndex + match0.length);\n const lineFeedCountInMatch = lineFeedCountBeforeEndOfMatch - lineFeedCountBeforeMatch;\n endOffset = startOffset + match0.length + lineFeedCountInMatch /* add as many \\r as there were \\n */;\n }\n else {\n endOffset = startOffset + match0.length;\n }\n const startPosition = model.getPositionAt(startOffset);\n const endPosition = model.getPositionAt(endOffset);\n return new Range(startPosition.lineNumber, startPosition.column, endPosition.lineNumber, endPosition.column);\n }\n static _doFindMatchesMultiline(model, searchRange, searcher, captureMatches, limitResultCount) {\n const deltaOffset = model.getOffsetAt(searchRange.getStartPosition());\n // We always execute multiline search over the lines joined with \\n\n // This makes it that \\n will match the EOL for both CRLF and LF models\n // We compensate for offset errors in `_getMultilineMatchRange`\n const text = model.getValueInRange(searchRange, 1 /* EndOfLinePreference.LF */);\n const lfCounter = (model.getEOL() === '\\r\\n' ? new LineFeedCounter(text) : null);\n const result = [];\n let counter = 0;\n let m;\n searcher.reset(0);\n while ((m = searcher.next(text))) {\n result[counter++] = createFindMatch(this._getMultilineMatchRange(model, deltaOffset, text, lfCounter, m.index, m[0]), m, captureMatches);\n if (counter >= limitResultCount) {\n return result;\n }\n }\n return result;\n }\n static _doFindMatchesLineByLine(model, searchRange, searchData, captureMatches, limitResultCount) {\n const result = [];\n let resultLen = 0;\n // Early case for a search range that starts & stops on the same line number\n if (searchRange.startLineNumber === searchRange.endLineNumber) {\n const text = model.getLineContent(searchRange.startLineNumber).substring(searchRange.startColumn - 1, searchRange.endColumn - 1);\n resultLen = this._findMatchesInLine(searchData, text, searchRange.startLineNumber, searchRange.startColumn - 1, resultLen, result, captureMatches, limitResultCount);\n return result;\n }\n // Collect results from first line\n const text = model.getLineContent(searchRange.startLineNumber).substring(searchRange.startColumn - 1);\n resultLen = this._findMatchesInLine(searchData, text, searchRange.startLineNumber, searchRange.startColumn - 1, resultLen, result, captureMatches, limitResultCount);\n // Collect results from middle lines\n for (let lineNumber = searchRange.startLineNumber + 1; lineNumber < searchRange.endLineNumber && resultLen < limitResultCount; lineNumber++) {\n resultLen = this._findMatchesInLine(searchData, model.getLineContent(lineNumber), lineNumber, 0, resultLen, result, captureMatches, limitResultCount);\n }\n // Collect results from last line\n if (resultLen < limitResultCount) {\n const text = model.getLineContent(searchRange.endLineNumber).substring(0, searchRange.endColumn - 1);\n resultLen = this._findMatchesInLine(searchData, text, searchRange.endLineNumber, 0, resultLen, result, captureMatches, limitResultCount);\n }\n return result;\n }\n static _findMatchesInLine(searchData, text, lineNumber, deltaOffset, resultLen, result, captureMatches, limitResultCount) {\n const wordSeparators = searchData.wordSeparators;\n if (!captureMatches && searchData.simpleSearch) {\n const searchString = searchData.simpleSearch;\n const searchStringLen = searchString.length;\n const textLength = text.length;\n let lastMatchIndex = -searchStringLen;\n while ((lastMatchIndex = text.indexOf(searchString, lastMatchIndex + searchStringLen)) !== -1) {\n if (!wordSeparators || isValidMatch(wordSeparators, text, textLength, lastMatchIndex, searchStringLen)) {\n result[resultLen++] = new FindMatch(new Range(lineNumber, lastMatchIndex + 1 + deltaOffset, lineNumber, lastMatchIndex + 1 + searchStringLen + deltaOffset), null);\n if (resultLen >= limitResultCount) {\n return resultLen;\n }\n }\n }\n return resultLen;\n }\n const searcher = new Searcher(searchData.wordSeparators, searchData.regex);\n let m;\n // Reset regex to search from the beginning\n searcher.reset(0);\n do {\n m = searcher.next(text);\n if (m) {\n result[resultLen++] = createFindMatch(new Range(lineNumber, m.index + 1 + deltaOffset, lineNumber, m.index + 1 + m[0].length + deltaOffset), m, captureMatches);\n if (resultLen >= limitResultCount) {\n return resultLen;\n }\n }\n } while (m);\n return resultLen;\n }\n static findNextMatch(model, searchParams, searchStart, captureMatches) {\n const searchData = searchParams.parseSearchRequest();\n if (!searchData) {\n return null;\n }\n const searcher = new Searcher(searchData.wordSeparators, searchData.regex);\n if (searchData.regex.multiline) {\n return this._doFindNextMatchMultiline(model, searchStart, searcher, captureMatches);\n }\n return this._doFindNextMatchLineByLine(model, searchStart, searcher, captureMatches);\n }\n static _doFindNextMatchMultiline(model, searchStart, searcher, captureMatches) {\n const searchTextStart = new Position(searchStart.lineNumber, 1);\n const deltaOffset = model.getOffsetAt(searchTextStart);\n const lineCount = model.getLineCount();\n // We always execute multiline search over the lines joined with \\n\n // This makes it that \\n will match the EOL for both CRLF and LF models\n // We compensate for offset errors in `_getMultilineMatchRange`\n const text = model.getValueInRange(new Range(searchTextStart.lineNumber, searchTextStart.column, lineCount, model.getLineMaxColumn(lineCount)), 1 /* EndOfLinePreference.LF */);\n const lfCounter = (model.getEOL() === '\\r\\n' ? new LineFeedCounter(text) : null);\n searcher.reset(searchStart.column - 1);\n const m = searcher.next(text);\n if (m) {\n return createFindMatch(this._getMultilineMatchRange(model, deltaOffset, text, lfCounter, m.index, m[0]), m, captureMatches);\n }\n if (searchStart.lineNumber !== 1 || searchStart.column !== 1) {\n // Try again from the top\n return this._doFindNextMatchMultiline(model, new Position(1, 1), searcher, captureMatches);\n }\n return null;\n }\n static _doFindNextMatchLineByLine(model, searchStart, searcher, captureMatches) {\n const lineCount = model.getLineCount();\n const startLineNumber = searchStart.lineNumber;\n // Look in first line\n const text = model.getLineContent(startLineNumber);\n const r = this._findFirstMatchInLine(searcher, text, startLineNumber, searchStart.column, captureMatches);\n if (r) {\n return r;\n }\n for (let i = 1; i <= lineCount; i++) {\n const lineIndex = (startLineNumber + i - 1) % lineCount;\n const text = model.getLineContent(lineIndex + 1);\n const r = this._findFirstMatchInLine(searcher, text, lineIndex + 1, 1, captureMatches);\n if (r) {\n return r;\n }\n }\n return null;\n }\n static _findFirstMatchInLine(searcher, text, lineNumber, fromColumn, captureMatches) {\n // Set regex to search from column\n searcher.reset(fromColumn - 1);\n const m = searcher.next(text);\n if (m) {\n return createFindMatch(new Range(lineNumber, m.index + 1, lineNumber, m.index + 1 + m[0].length), m, captureMatches);\n }\n return null;\n }\n static findPreviousMatch(model, searchParams, searchStart, captureMatches) {\n const searchData = searchParams.parseSearchRequest();\n if (!searchData) {\n return null;\n }\n const searcher = new Searcher(searchData.wordSeparators, searchData.regex);\n if (searchData.regex.multiline) {\n return this._doFindPreviousMatchMultiline(model, searchStart, searcher, captureMatches);\n }\n return this._doFindPreviousMatchLineByLine(model, searchStart, searcher, captureMatches);\n }\n static _doFindPreviousMatchMultiline(model, searchStart, searcher, captureMatches) {\n const matches = this._doFindMatchesMultiline(model, new Range(1, 1, searchStart.lineNumber, searchStart.column), searcher, captureMatches, 10 * LIMIT_FIND_COUNT);\n if (matches.length > 0) {\n return matches[matches.length - 1];\n }\n const lineCount = model.getLineCount();\n if (searchStart.lineNumber !== lineCount || searchStart.column !== model.getLineMaxColumn(lineCount)) {\n // Try again with all content\n return this._doFindPreviousMatchMultiline(model, new Position(lineCount, model.getLineMaxColumn(lineCount)), searcher, captureMatches);\n }\n return null;\n }\n static _doFindPreviousMatchLineByLine(model, searchStart, searcher, captureMatches) {\n const lineCount = model.getLineCount();\n const startLineNumber = searchStart.lineNumber;\n // Look in first line\n const text = model.getLineContent(startLineNumber).substring(0, searchStart.column - 1);\n const r = this._findLastMatchInLine(searcher, text, startLineNumber, captureMatches);\n if (r) {\n return r;\n }\n for (let i = 1; i <= lineCount; i++) {\n const lineIndex = (lineCount + startLineNumber - i - 1) % lineCount;\n const text = model.getLineContent(lineIndex + 1);\n const r = this._findLastMatchInLine(searcher, text, lineIndex + 1, captureMatches);\n if (r) {\n return r;\n }\n }\n return null;\n }\n static _findLastMatchInLine(searcher, text, lineNumber, captureMatches) {\n let bestResult = null;\n let m;\n searcher.reset(0);\n while ((m = searcher.next(text))) {\n bestResult = createFindMatch(new Range(lineNumber, m.index + 1, lineNumber, m.index + 1 + m[0].length), m, captureMatches);\n }\n return bestResult;\n }\n}\nfunction leftIsWordBounday(wordSeparators, text, textLength, matchStartIndex, matchLength) {\n if (matchStartIndex === 0) {\n // Match starts at start of string\n return true;\n }\n const charBefore = text.charCodeAt(matchStartIndex - 1);\n if (wordSeparators.get(charBefore) !== 0 /* WordCharacterClass.Regular */) {\n // The character before the match is a word separator\n return true;\n }\n if (charBefore === 13 /* CharCode.CarriageReturn */ || charBefore === 10 /* CharCode.LineFeed */) {\n // The character before the match is line break or carriage return.\n return true;\n }\n if (matchLength > 0) {\n const firstCharInMatch = text.charCodeAt(matchStartIndex);\n if (wordSeparators.get(firstCharInMatch) !== 0 /* WordCharacterClass.Regular */) {\n // The first character inside the match is a word separator\n return true;\n }\n }\n return false;\n}\nfunction rightIsWordBounday(wordSeparators, text, textLength, matchStartIndex, matchLength) {\n if (matchStartIndex + matchLength === textLength) {\n // Match ends at end of string\n return true;\n }\n const charAfter = text.charCodeAt(matchStartIndex + matchLength);\n if (wordSeparators.get(charAfter) !== 0 /* WordCharacterClass.Regular */) {\n // The character after the match is a word separator\n return true;\n }\n if (charAfter === 13 /* CharCode.CarriageReturn */ || charAfter === 10 /* CharCode.LineFeed */) {\n // The character after the match is line break or carriage return.\n return true;\n }\n if (matchLength > 0) {\n const lastCharInMatch = text.charCodeAt(matchStartIndex + matchLength - 1);\n if (wordSeparators.get(lastCharInMatch) !== 0 /* WordCharacterClass.Regular */) {\n // The last character in the match is a word separator\n return true;\n }\n }\n return false;\n}\nexport function isValidMatch(wordSeparators, text, textLength, matchStartIndex, matchLength) {\n return (leftIsWordBounday(wordSeparators, text, textLength, matchStartIndex, matchLength)\n && rightIsWordBounday(wordSeparators, text, textLength, matchStartIndex, matchLength));\n}\nexport class Searcher {\n constructor(wordSeparators, searchRegex) {\n this._wordSeparators = wordSeparators;\n this._searchRegex = searchRegex;\n this._prevMatchStartIndex = -1;\n this._prevMatchLength = 0;\n }\n reset(lastIndex) {\n this._searchRegex.lastIndex = lastIndex;\n this._prevMatchStartIndex = -1;\n this._prevMatchLength = 0;\n }\n next(text) {\n const textLength = text.length;\n let m;\n do {\n if (this._prevMatchStartIndex + this._prevMatchLength === textLength) {\n // Reached the end of the line\n return null;\n }\n m = this._searchRegex.exec(text);\n if (!m) {\n return null;\n }\n const matchStartIndex = m.index;\n const matchLength = m[0].length;\n if (matchStartIndex === this._prevMatchStartIndex && matchLength === this._prevMatchLength) {\n if (matchLength === 0) {\n // the search result is an empty string and won't advance `regex.lastIndex`, so `regex.exec` will stuck here\n // we attempt to recover from that by advancing by two if surrogate pair found and by one otherwise\n if (strings.getNextCodePoint(text, textLength, this._searchRegex.lastIndex) > 0xFFFF) {\n this._searchRegex.lastIndex += 2;\n }\n else {\n this._searchRegex.lastIndex += 1;\n }\n continue;\n }\n // Exit early if the regex matches the same range twice\n return null;\n }\n this._prevMatchStartIndex = matchStartIndex;\n this._prevMatchLength = matchLength;\n if (!this._wordSeparators || isValidMatch(this._wordSeparators, text, textLength, matchStartIndex, matchLength)) {\n return m;\n }\n } while (m);\n return null;\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { Range } from '../core/range.js';\nimport { Searcher } from '../model/textModelSearch.js';\nimport * as strings from '../../../base/common/strings.js';\nimport { assertNever } from '../../../base/common/types.js';\nimport { DEFAULT_WORD_REGEXP, getWordAtText } from '../core/wordHelper.js';\nexport class UnicodeTextModelHighlighter {\n static computeUnicodeHighlights(model, options, range) {\n const startLine = range ? range.startLineNumber : 1;\n const endLine = range ? range.endLineNumber : model.getLineCount();\n const codePointHighlighter = new CodePointHighlighter(options);\n const candidates = codePointHighlighter.getCandidateCodePoints();\n let regex;\n if (candidates === 'allNonBasicAscii') {\n regex = new RegExp('[^\\\\t\\\\n\\\\r\\\\x20-\\\\x7E]', 'g');\n }\n else {\n regex = new RegExp(`${buildRegExpCharClassExpr(Array.from(candidates))}`, 'g');\n }\n const searcher = new Searcher(null, regex);\n const ranges = [];\n let hasMore = false;\n let m;\n let ambiguousCharacterCount = 0;\n let invisibleCharacterCount = 0;\n let nonBasicAsciiCharacterCount = 0;\n forLoop: for (let lineNumber = startLine, lineCount = endLine; lineNumber <= lineCount; lineNumber++) {\n const lineContent = model.getLineContent(lineNumber);\n const lineLength = lineContent.length;\n // Reset regex to search from the beginning\n searcher.reset(0);\n do {\n m = searcher.next(lineContent);\n if (m) {\n let startIndex = m.index;\n let endIndex = m.index + m[0].length;\n // Extend range to entire code point\n if (startIndex > 0) {\n const charCodeBefore = lineContent.charCodeAt(startIndex - 1);\n if (strings.isHighSurrogate(charCodeBefore)) {\n startIndex--;\n }\n }\n if (endIndex + 1 < lineLength) {\n const charCodeBefore = lineContent.charCodeAt(endIndex - 1);\n if (strings.isHighSurrogate(charCodeBefore)) {\n endIndex++;\n }\n }\n const str = lineContent.substring(startIndex, endIndex);\n const word = getWordAtText(startIndex + 1, DEFAULT_WORD_REGEXP, lineContent, 0);\n const highlightReason = codePointHighlighter.shouldHighlightNonBasicASCII(str, word ? word.word : null);\n if (highlightReason !== 0 /* SimpleHighlightReason.None */) {\n if (highlightReason === 3 /* SimpleHighlightReason.Ambiguous */) {\n ambiguousCharacterCount++;\n }\n else if (highlightReason === 2 /* SimpleHighlightReason.Invisible */) {\n invisibleCharacterCount++;\n }\n else if (highlightReason === 1 /* SimpleHighlightReason.NonBasicASCII */) {\n nonBasicAsciiCharacterCount++;\n }\n else {\n assertNever(highlightReason);\n }\n const MAX_RESULT_LENGTH = 1000;\n if (ranges.length >= MAX_RESULT_LENGTH) {\n hasMore = true;\n break forLoop;\n }\n ranges.push(new Range(lineNumber, startIndex + 1, lineNumber, endIndex + 1));\n }\n }\n } while (m);\n }\n return {\n ranges,\n hasMore,\n ambiguousCharacterCount,\n invisibleCharacterCount,\n nonBasicAsciiCharacterCount\n };\n }\n static computeUnicodeHighlightReason(char, options) {\n const codePointHighlighter = new CodePointHighlighter(options);\n const reason = codePointHighlighter.shouldHighlightNonBasicASCII(char, null);\n switch (reason) {\n case 0 /* SimpleHighlightReason.None */:\n return null;\n case 2 /* SimpleHighlightReason.Invisible */:\n return { kind: 1 /* UnicodeHighlighterReasonKind.Invisible */ };\n case 3 /* SimpleHighlightReason.Ambiguous */: {\n const codePoint = char.codePointAt(0);\n const primaryConfusable = codePointHighlighter.ambiguousCharacters.getPrimaryConfusable(codePoint);\n const notAmbiguousInLocales = strings.AmbiguousCharacters.getLocales().filter((l) => !strings.AmbiguousCharacters.getInstance(new Set([...options.allowedLocales, l])).isAmbiguous(codePoint));\n return { kind: 0 /* UnicodeHighlighterReasonKind.Ambiguous */, confusableWith: String.fromCodePoint(primaryConfusable), notAmbiguousInLocales };\n }\n case 1 /* SimpleHighlightReason.NonBasicASCII */:\n return { kind: 2 /* UnicodeHighlighterReasonKind.NonBasicAscii */ };\n }\n }\n}\nfunction buildRegExpCharClassExpr(codePoints, flags) {\n const src = `[${strings.escapeRegExpCharacters(codePoints.map((i) => String.fromCodePoint(i)).join(''))}]`;\n return src;\n}\nclass CodePointHighlighter {\n constructor(options) {\n this.options = options;\n this.allowedCodePoints = new Set(options.allowedCodePoints);\n this.ambiguousCharacters = strings.AmbiguousCharacters.getInstance(new Set(options.allowedLocales));\n }\n getCandidateCodePoints() {\n if (this.options.nonBasicASCII) {\n return 'allNonBasicAscii';\n }\n const set = new Set();\n if (this.options.invisibleCharacters) {\n for (const cp of strings.InvisibleCharacters.codePoints) {\n if (!isAllowedInvisibleCharacter(String.fromCodePoint(cp))) {\n set.add(cp);\n }\n }\n }\n if (this.options.ambiguousCharacters) {\n for (const cp of this.ambiguousCharacters.getConfusableCodePoints()) {\n set.add(cp);\n }\n }\n for (const cp of this.allowedCodePoints) {\n set.delete(cp);\n }\n return set;\n }\n shouldHighlightNonBasicASCII(character, wordContext) {\n const codePoint = character.codePointAt(0);\n if (this.allowedCodePoints.has(codePoint)) {\n return 0 /* SimpleHighlightReason.None */;\n }\n if (this.options.nonBasicASCII) {\n return 1 /* SimpleHighlightReason.NonBasicASCII */;\n }\n let hasBasicASCIICharacters = false;\n let hasNonConfusableNonBasicAsciiCharacter = false;\n if (wordContext) {\n for (const char of wordContext) {\n const codePoint = char.codePointAt(0);\n const isBasicASCII = strings.isBasicASCII(char);\n hasBasicASCIICharacters = hasBasicASCIICharacters || isBasicASCII;\n if (!isBasicASCII &&\n !this.ambiguousCharacters.isAmbiguous(codePoint) &&\n !strings.InvisibleCharacters.isInvisibleCharacter(codePoint)) {\n hasNonConfusableNonBasicAsciiCharacter = true;\n }\n }\n }\n if (\n /* Don't allow mixing weird looking characters with ASCII */ !hasBasicASCIICharacters &&\n /* Is there an obviously weird looking character? */ hasNonConfusableNonBasicAsciiCharacter) {\n return 0 /* SimpleHighlightReason.None */;\n }\n if (this.options.invisibleCharacters) {\n // TODO check for emojis\n if (!isAllowedInvisibleCharacter(character) && strings.InvisibleCharacters.isInvisibleCharacter(codePoint)) {\n return 2 /* SimpleHighlightReason.Invisible */;\n }\n }\n if (this.options.ambiguousCharacters) {\n if (this.ambiguousCharacters.isAmbiguous(codePoint)) {\n return 3 /* SimpleHighlightReason.Ambiguous */;\n }\n }\n return 0 /* SimpleHighlightReason.None */;\n }\n}\nfunction isAllowedInvisibleCharacter(character) {\n return character === ' ' || character === '\\n' || character === '\\t';\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport { stringDiff } from '../../../base/common/diff/diff.js';\nimport { globals } from '../../../base/common/platform.js';\nimport { URI } from '../../../base/common/uri.js';\nimport { Position } from '../core/position.js';\nimport { Range } from '../core/range.js';\nimport { DiffComputer } from '../diff/diffComputer.js';\nimport { MirrorTextModel as BaseMirrorModel } from '../model/mirrorTextModel.js';\nimport { ensureValidWordDefinition, getWordAtText } from '../core/wordHelper.js';\nimport { computeLinks } from '../languages/linkComputer.js';\nimport { BasicInplaceReplace } from '../languages/supports/inplaceReplaceSupport.js';\nimport { createMonacoBaseAPI } from './editorBaseApi.js';\nimport * as types from '../../../base/common/types.js';\nimport { StopWatch } from '../../../base/common/stopwatch.js';\nimport { UnicodeTextModelHighlighter } from './unicodeTextModelHighlighter.js';\n/**\n * @internal\n */\nexport class MirrorModel extends BaseMirrorModel {\n get uri() {\n return this._uri;\n }\n get eol() {\n return this._eol;\n }\n getValue() {\n return this.getText();\n }\n getLinesContent() {\n return this._lines.slice(0);\n }\n getLineCount() {\n return this._lines.length;\n }\n getLineContent(lineNumber) {\n return this._lines[lineNumber - 1];\n }\n getWordAtPosition(position, wordDefinition) {\n const wordAtText = getWordAtText(position.column, ensureValidWordDefinition(wordDefinition), this._lines[position.lineNumber - 1], 0);\n if (wordAtText) {\n return new Range(position.lineNumber, wordAtText.startColumn, position.lineNumber, wordAtText.endColumn);\n }\n return null;\n }\n words(wordDefinition) {\n const lines = this._lines;\n const wordenize = this._wordenize.bind(this);\n let lineNumber = 0;\n let lineText = '';\n let wordRangesIdx = 0;\n let wordRanges = [];\n return {\n *[Symbol.iterator]() {\n while (true) {\n if (wordRangesIdx < wordRanges.length) {\n const value = lineText.substring(wordRanges[wordRangesIdx].start, wordRanges[wordRangesIdx].end);\n wordRangesIdx += 1;\n yield value;\n }\n else {\n if (lineNumber < lines.length) {\n lineText = lines[lineNumber];\n wordRanges = wordenize(lineText, wordDefinition);\n wordRangesIdx = 0;\n lineNumber += 1;\n }\n else {\n break;\n }\n }\n }\n }\n };\n }\n getLineWords(lineNumber, wordDefinition) {\n const content = this._lines[lineNumber - 1];\n const ranges = this._wordenize(content, wordDefinition);\n const words = [];\n for (const range of ranges) {\n words.push({\n word: content.substring(range.start, range.end),\n startColumn: range.start + 1,\n endColumn: range.end + 1\n });\n }\n return words;\n }\n _wordenize(content, wordDefinition) {\n const result = [];\n let match;\n wordDefinition.lastIndex = 0; // reset lastIndex just to be sure\n while (match = wordDefinition.exec(content)) {\n if (match[0].length === 0) {\n // it did match the empty string\n break;\n }\n result.push({ start: match.index, end: match.index + match[0].length });\n }\n return result;\n }\n getValueInRange(range) {\n range = this._validateRange(range);\n if (range.startLineNumber === range.endLineNumber) {\n return this._lines[range.startLineNumber - 1].substring(range.startColumn - 1, range.endColumn - 1);\n }\n const lineEnding = this._eol;\n const startLineIndex = range.startLineNumber - 1;\n const endLineIndex = range.endLineNumber - 1;\n const resultLines = [];\n resultLines.push(this._lines[startLineIndex].substring(range.startColumn - 1));\n for (let i = startLineIndex + 1; i < endLineIndex; i++) {\n resultLines.push(this._lines[i]);\n }\n resultLines.push(this._lines[endLineIndex].substring(0, range.endColumn - 1));\n return resultLines.join(lineEnding);\n }\n offsetAt(position) {\n position = this._validatePosition(position);\n this._ensureLineStarts();\n return this._lineStarts.getPrefixSum(position.lineNumber - 2) + (position.column - 1);\n }\n positionAt(offset) {\n offset = Math.floor(offset);\n offset = Math.max(0, offset);\n this._ensureLineStarts();\n const out = this._lineStarts.getIndexOf(offset);\n const lineLength = this._lines[out.index].length;\n // Ensure we return a valid position\n return {\n lineNumber: 1 + out.index,\n column: 1 + Math.min(out.remainder, lineLength)\n };\n }\n _validateRange(range) {\n const start = this._validatePosition({ lineNumber: range.startLineNumber, column: range.startColumn });\n const end = this._validatePosition({ lineNumber: range.endLineNumber, column: range.endColumn });\n if (start.lineNumber !== range.startLineNumber\n || start.column !== range.startColumn\n || end.lineNumber !== range.endLineNumber\n || end.column !== range.endColumn) {\n return {\n startLineNumber: start.lineNumber,\n startColumn: start.column,\n endLineNumber: end.lineNumber,\n endColumn: end.column\n };\n }\n return range;\n }\n _validatePosition(position) {\n if (!Position.isIPosition(position)) {\n throw new Error('bad position');\n }\n let { lineNumber, column } = position;\n let hasChanged = false;\n if (lineNumber < 1) {\n lineNumber = 1;\n column = 1;\n hasChanged = true;\n }\n else if (lineNumber > this._lines.length) {\n lineNumber = this._lines.length;\n column = this._lines[lineNumber - 1].length + 1;\n hasChanged = true;\n }\n else {\n const maxCharacter = this._lines[lineNumber - 1].length + 1;\n if (column < 1) {\n column = 1;\n hasChanged = true;\n }\n else if (column > maxCharacter) {\n column = maxCharacter;\n hasChanged = true;\n }\n }\n if (!hasChanged) {\n return position;\n }\n else {\n return { lineNumber, column };\n }\n }\n}\n/**\n * @internal\n */\nexport class EditorSimpleWorker {\n constructor(host, foreignModuleFactory) {\n this._host = host;\n this._models = Object.create(null);\n this._foreignModuleFactory = foreignModuleFactory;\n this._foreignModule = null;\n }\n dispose() {\n this._models = Object.create(null);\n }\n _getModel(uri) {\n return this._models[uri];\n }\n _getModels() {\n const all = [];\n Object.keys(this._models).forEach((key) => all.push(this._models[key]));\n return all;\n }\n acceptNewModel(data) {\n this._models[data.url] = new MirrorModel(URI.parse(data.url), data.lines, data.EOL, data.versionId);\n }\n acceptModelChanged(strURL, e) {\n if (!this._models[strURL]) {\n return;\n }\n const model = this._models[strURL];\n model.onEvents(e);\n }\n acceptRemovedModel(strURL) {\n if (!this._models[strURL]) {\n return;\n }\n delete this._models[strURL];\n }\n computeUnicodeHighlights(url, options, range) {\n return __awaiter(this, void 0, void 0, function* () {\n const model = this._getModel(url);\n if (!model) {\n return { ranges: [], hasMore: false, ambiguousCharacterCount: 0, invisibleCharacterCount: 0, nonBasicAsciiCharacterCount: 0 };\n }\n return UnicodeTextModelHighlighter.computeUnicodeHighlights(model, options, range);\n });\n }\n // ---- BEGIN diff --------------------------------------------------------------------------\n computeDiff(originalUrl, modifiedUrl, ignoreTrimWhitespace, maxComputationTime) {\n return __awaiter(this, void 0, void 0, function* () {\n const original = this._getModel(originalUrl);\n const modified = this._getModel(modifiedUrl);\n if (!original || !modified) {\n return null;\n }\n return EditorSimpleWorker.computeDiff(original, modified, ignoreTrimWhitespace, maxComputationTime);\n });\n }\n static computeDiff(originalTextModel, modifiedTextModel, ignoreTrimWhitespace, maxComputationTime) {\n const originalLines = originalTextModel.getLinesContent();\n const modifiedLines = modifiedTextModel.getLinesContent();\n const diffComputer = new DiffComputer(originalLines, modifiedLines, {\n shouldComputeCharChanges: true,\n shouldPostProcessCharChanges: true,\n shouldIgnoreTrimWhitespace: ignoreTrimWhitespace,\n shouldMakePrettyDiff: true,\n maxComputationTime: maxComputationTime\n });\n const diffResult = diffComputer.computeDiff();\n const identical = (diffResult.changes.length > 0 ? false : this._modelsAreIdentical(originalTextModel, modifiedTextModel));\n return {\n quitEarly: diffResult.quitEarly,\n identical: identical,\n changes: diffResult.changes\n };\n }\n static _modelsAreIdentical(original, modified) {\n const originalLineCount = original.getLineCount();\n const modifiedLineCount = modified.getLineCount();\n if (originalLineCount !== modifiedLineCount) {\n return false;\n }\n for (let line = 1; line <= originalLineCount; line++) {\n const originalLine = original.getLineContent(line);\n const modifiedLine = modified.getLineContent(line);\n if (originalLine !== modifiedLine) {\n return false;\n }\n }\n return true;\n }\n computeMoreMinimalEdits(modelUrl, edits) {\n return __awaiter(this, void 0, void 0, function* () {\n const model = this._getModel(modelUrl);\n if (!model) {\n return edits;\n }\n const result = [];\n let lastEol = undefined;\n edits = edits.slice(0).sort((a, b) => {\n if (a.range && b.range) {\n return Range.compareRangesUsingStarts(a.range, b.range);\n }\n // eol only changes should go to the end\n const aRng = a.range ? 0 : 1;\n const bRng = b.range ? 0 : 1;\n return aRng - bRng;\n });\n for (let { range, text, eol } of edits) {\n if (typeof eol === 'number') {\n lastEol = eol;\n }\n if (Range.isEmpty(range) && !text) {\n // empty change\n continue;\n }\n const original = model.getValueInRange(range);\n text = text.replace(/\\r\\n|\\n|\\r/g, model.eol);\n if (original === text) {\n // noop\n continue;\n }\n // make sure diff won't take too long\n if (Math.max(text.length, original.length) > EditorSimpleWorker._diffLimit) {\n result.push({ range, text });\n continue;\n }\n // compute diff between original and edit.text\n const changes = stringDiff(original, text, false);\n const editOffset = model.offsetAt(Range.lift(range).getStartPosition());\n for (const change of changes) {\n const start = model.positionAt(editOffset + change.originalStart);\n const end = model.positionAt(editOffset + change.originalStart + change.originalLength);\n const newEdit = {\n text: text.substr(change.modifiedStart, change.modifiedLength),\n range: { startLineNumber: start.lineNumber, startColumn: start.column, endLineNumber: end.lineNumber, endColumn: end.column }\n };\n if (model.getValueInRange(newEdit.range) !== newEdit.text) {\n result.push(newEdit);\n }\n }\n }\n if (typeof lastEol === 'number') {\n result.push({ eol: lastEol, text: '', range: { startLineNumber: 0, startColumn: 0, endLineNumber: 0, endColumn: 0 } });\n }\n return result;\n });\n }\n // ---- END minimal edits ---------------------------------------------------------------\n computeLinks(modelUrl) {\n return __awaiter(this, void 0, void 0, function* () {\n const model = this._getModel(modelUrl);\n if (!model) {\n return null;\n }\n return computeLinks(model);\n });\n }\n textualSuggest(modelUrls, leadingWord, wordDef, wordDefFlags) {\n return __awaiter(this, void 0, void 0, function* () {\n const sw = new StopWatch(true);\n const wordDefRegExp = new RegExp(wordDef, wordDefFlags);\n const seen = new Set();\n outer: for (const url of modelUrls) {\n const model = this._getModel(url);\n if (!model) {\n continue;\n }\n for (const word of model.words(wordDefRegExp)) {\n if (word === leadingWord || !isNaN(Number(word))) {\n continue;\n }\n seen.add(word);\n if (seen.size > EditorSimpleWorker._suggestionsLimit) {\n break outer;\n }\n }\n }\n return { words: Array.from(seen), duration: sw.elapsed() };\n });\n }\n // ---- END suggest --------------------------------------------------------------------------\n //#region -- word ranges --\n computeWordRanges(modelUrl, range, wordDef, wordDefFlags) {\n return __awaiter(this, void 0, void 0, function* () {\n const model = this._getModel(modelUrl);\n if (!model) {\n return Object.create(null);\n }\n const wordDefRegExp = new RegExp(wordDef, wordDefFlags);\n const result = Object.create(null);\n for (let line = range.startLineNumber; line < range.endLineNumber; line++) {\n const words = model.getLineWords(line, wordDefRegExp);\n for (const word of words) {\n if (!isNaN(Number(word.word))) {\n continue;\n }\n let array = result[word.word];\n if (!array) {\n array = [];\n result[word.word] = array;\n }\n array.push({\n startLineNumber: line,\n startColumn: word.startColumn,\n endLineNumber: line,\n endColumn: word.endColumn\n });\n }\n }\n return result;\n });\n }\n //#endregion\n navigateValueSet(modelUrl, range, up, wordDef, wordDefFlags) {\n return __awaiter(this, void 0, void 0, function* () {\n const model = this._getModel(modelUrl);\n if (!model) {\n return null;\n }\n const wordDefRegExp = new RegExp(wordDef, wordDefFlags);\n if (range.startColumn === range.endColumn) {\n range = {\n startLineNumber: range.startLineNumber,\n startColumn: range.startColumn,\n endLineNumber: range.endLineNumber,\n endColumn: range.endColumn + 1\n };\n }\n const selectionText = model.getValueInRange(range);\n const wordRange = model.getWordAtPosition({ lineNumber: range.startLineNumber, column: range.startColumn }, wordDefRegExp);\n if (!wordRange) {\n return null;\n }\n const word = model.getValueInRange(wordRange);\n const result = BasicInplaceReplace.INSTANCE.navigateValueSet(range, selectionText, wordRange, word, up);\n return result;\n });\n }\n // ---- BEGIN foreign module support --------------------------------------------------------------------------\n loadForeignModule(moduleId, createData, foreignHostMethods) {\n const proxyMethodRequest = (method, args) => {\n return this._host.fhr(method, args);\n };\n const foreignHost = types.createProxyObject(foreignHostMethods, proxyMethodRequest);\n const ctx = {\n host: foreignHost,\n getMirrorModels: () => {\n return this._getModels();\n }\n };\n if (this._foreignModuleFactory) {\n this._foreignModule = this._foreignModuleFactory(ctx, createData);\n // static foreing module\n return Promise.resolve(types.getAllMethodNames(this._foreignModule));\n }\n // ESM-comment-begin\n // \t\treturn new Promise<any>((resolve, reject) => {\n // \t\t\trequire([moduleId], (foreignModule: { create: IForeignModuleFactory }) => {\n // \t\t\t\tthis._foreignModule = foreignModule.create(ctx, createData);\n // \n // \t\t\t\tresolve(types.getAllMethodNames(this._foreignModule));\n // \n // \t\t\t}, reject);\n // \t\t});\n // ESM-comment-end\n // ESM-uncomment-begin\n return Promise.reject(new Error(`Unexpected usage`));\n // ESM-uncomment-end\n }\n // foreign method request\n fmr(method, args) {\n if (!this._foreignModule || typeof this._foreignModule[method] !== 'function') {\n return Promise.reject(new Error('Missing requestHandler or method: ' + method));\n }\n try {\n return Promise.resolve(this._foreignModule[method].apply(this._foreignModule, args));\n }\n catch (e) {\n return Promise.reject(e);\n }\n }\n}\n// ---- END diff --------------------------------------------------------------------------\n// ---- BEGIN minimal edits ---------------------------------------------------------------\nEditorSimpleWorker._diffLimit = 100000;\n// ---- BEGIN suggest --------------------------------------------------------------------------\nEditorSimpleWorker._suggestionsLimit = 10000;\n/**\n * Called on the worker side\n * @internal\n */\nexport function create(host) {\n return new EditorSimpleWorker(host, null);\n}\nif (typeof importScripts === 'function') {\n // Running in a web worker\n globals.monaco = createMonacoBaseAPI();\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { splitLines } from '../../../base/common/strings.js';\nimport { Position } from '../core/position.js';\nimport { PrefixSumComputer } from './prefixSumComputer.js';\nexport class MirrorTextModel {\n constructor(uri, lines, eol, versionId) {\n this._uri = uri;\n this._lines = lines;\n this._eol = eol;\n this._versionId = versionId;\n this._lineStarts = null;\n this._cachedTextValue = null;\n }\n dispose() {\n this._lines.length = 0;\n }\n get version() {\n return this._versionId;\n }\n getText() {\n if (this._cachedTextValue === null) {\n this._cachedTextValue = this._lines.join(this._eol);\n }\n return this._cachedTextValue;\n }\n onEvents(e) {\n if (e.eol && e.eol !== this._eol) {\n this._eol = e.eol;\n this._lineStarts = null;\n }\n // Update my lines\n const changes = e.changes;\n for (const change of changes) {\n this._acceptDeleteRange(change.range);\n this._acceptInsertText(new Position(change.range.startLineNumber, change.range.startColumn), change.text);\n }\n this._versionId = e.versionId;\n this._cachedTextValue = null;\n }\n _ensureLineStarts() {\n if (!this._lineStarts) {\n const eolLength = this._eol.length;\n const linesLength = this._lines.length;\n const lineStartValues = new Uint32Array(linesLength);\n for (let i = 0; i < linesLength; i++) {\n lineStartValues[i] = this._lines[i].length + eolLength;\n }\n this._lineStarts = new PrefixSumComputer(lineStartValues);\n }\n }\n /**\n * All changes to a line's text go through this method\n */\n _setLineText(lineIndex, newValue) {\n this._lines[lineIndex] = newValue;\n if (this._lineStarts) {\n // update prefix sum\n this._lineStarts.setValue(lineIndex, this._lines[lineIndex].length + this._eol.length);\n }\n }\n _acceptDeleteRange(range) {\n if (range.startLineNumber === range.endLineNumber) {\n if (range.startColumn === range.endColumn) {\n // Nothing to delete\n return;\n }\n // Delete text on the affected line\n this._setLineText(range.startLineNumber - 1, this._lines[range.startLineNumber - 1].substring(0, range.startColumn - 1)\n + this._lines[range.startLineNumber - 1].substring(range.endColumn - 1));\n return;\n }\n // Take remaining text on last line and append it to remaining text on first line\n this._setLineText(range.startLineNumber - 1, this._lines[range.startLineNumber - 1].substring(0, range.startColumn - 1)\n + this._lines[range.endLineNumber - 1].substring(range.endColumn - 1));\n // Delete middle lines\n this._lines.splice(range.startLineNumber, range.endLineNumber - range.startLineNumber);\n if (this._lineStarts) {\n // update prefix sum\n this._lineStarts.removeValues(range.startLineNumber, range.endLineNumber - range.startLineNumber);\n }\n }\n _acceptInsertText(position, insertText) {\n if (insertText.length === 0) {\n // Nothing to insert\n return;\n }\n const insertLines = splitLines(insertText);\n if (insertLines.length === 1) {\n // Inserting text on one line\n this._setLineText(position.lineNumber - 1, this._lines[position.lineNumber - 1].substring(0, position.column - 1)\n + insertLines[0]\n + this._lines[position.lineNumber - 1].substring(position.column - 1));\n return;\n }\n // Append overflowing text from first line to the end of text to insert\n insertLines[insertLines.length - 1] += this._lines[position.lineNumber - 1].substring(position.column - 1);\n // Delete overflowing text from first line and insert text on first line\n this._setLineText(position.lineNumber - 1, this._lines[position.lineNumber - 1].substring(0, position.column - 1)\n + insertLines[0]);\n // Insert new lines & store lengths\n const newLengths = new Uint32Array(insertLines.length - 1);\n for (let i = 1; i < insertLines.length; i++) {\n this._lines.splice(position.lineNumber + i - 1, 0, insertLines[i]);\n newLengths[i - 1] = insertLines[i].length + this._eol.length;\n }\n if (this._lineStarts) {\n // update prefix sum\n this._lineStarts.insertValues(position.lineNumber, newLengths);\n }\n }\n}\n","/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\nimport { SimpleWorkerServer } from '../base/common/worker/simpleWorker.js';\nimport { EditorSimpleWorker } from './common/services/editorSimpleWorker.js';\nlet initialized = false;\nexport function initialize(foreignModule) {\n if (initialized) {\n return;\n }\n initialized = true;\n const simpleWorker = new SimpleWorkerServer((msg) => {\n self.postMessage(msg);\n }, (host) => new EditorSimpleWorker(host, foreignModule));\n self.onmessage = (e) => {\n simpleWorker.onmessage(e.data);\n };\n}\nself.onmessage = (e) => {\n // Ignore first message in this case and initialize if not yet initialized\n if (!initialized) {\n initialize(null);\n }\n};\n"],"names":["__webpack_require__","g","globalThis","this","Function","e","window","errorHandler","constructor","listeners","unexpectedErrorHandler","setTimeout","stack","ErrorNoTelemetry","isErrorNoTelemetry","message","Error","emit","forEach","listener","onUnexpectedError","onUnexpectedExternalError","isCancellationError","transformErrorForSerialization","error","name","$isError","stacktrace","noTelemetry","canceledName","CancellationError","super","msg","static","err","result","once","fn","_this","didCall","apply","arguments","Iterable","is","thing","Symbol","iterator","_empty","Object","freeze","consume","iterable","atMost","Number","POSITIVE_INFINITY","consumed","i","next","done","empty","push","value","single","element","from","isEmpty","first","some","predicate","find","filter","map","index","concat","iterables","concatNested","reduce","reducer","initialValue","slice","arr","to","length","collect","equals","a","b","comparator","at","bt","ai","bi","an","bn","disposableTracker","trackDisposable","x","markAsDisposed","disposable","setParentOfDisposable","child","parent","setParent","MultiDisposeError","errors","join","dispose","arg","d","Array","isArray","combinedDisposable","disposables","toDisposable","children","setParentOfDisposables","self","DisposableStore","_toDispose","Set","_isDisposed","clear","isDisposed","values","add","o","DISABLE_DISPOSED_WARNING","console","warn","_store","_register","None","SafeDisposable","unset","isset","set","callback","undefined","Node","Undefined","prev","_first","_last","_size","size","node","unshift","_insert","atTheEnd","newNode","oldLast","oldFirst","didRemove","_remove","shift","res","pop","anchor","isPseudo","document","location","hash","indexOf","_format","args","replace","match","rest","String","localize","data","_a","LANGUAGE_DEFAULT","_locale","_userAgent","_isWindows","_isMacintosh","_isLinux","_isLinuxSnap","_isNative","_isWeb","_isElectron","_isIOS","_isCI","_language","_translationsConfigFile","nodeProcess","vscode","process","isElectronProcess","versions","electron","isElectronRenderer","type","navigator","platform","env","rawNlsConfig","nlsConfig","JSON","parse","resolved","availableLanguages","locale","userAgent","maxTouchPoints","_platform","isWindows","isMacintosh","importScripts","setTimeout0IsFaster","postMessage","pending","addEventListener","vscodeScheduleAsyncWork","len","candidate","id","splice","lastId","myId","isChrome","hasPerformanceNow","StopWatch","highResolution","_highResolution","_startTime","_now","_stopTime","stop","elapsed","Date","now","Event","_addLeakageTraceLogic","options","event","thisArgs","didFire","call","snapshot","each","merge","initial","output","onFirstListenerAdd","emitter","fire","onLastListenerRemove","Emitter","debounce","delay","leading","leakWarningThreshold","subscription","handle","numDebouncedCalls","cur","clearTimeout","_output","latch","cache","firstCall","shouldEmit","signal","any","events","split","isT","buffer","flushAfterTimeout","_buffer","flush","onFirstListenerDidAdd","ChainableEvent","on","chain","fromNodeEventEmitter","eventName","removeListener","fromDOMEventEmitter","removeEventListener","toPromise","Promise","resolve","runAndSubscribe","handler","runAndSubscribeWithStore","store","run","EmitterObserver","obs","_counter","_hasChanged","addObserver","removeObserver","beginUpdate","_observable","handleChange","_change","endUpdate","get","fromObservable","EventProfiling","_listenerCount","_invocationCount","_elapsedOverall","_name","_idPool","start","listenerCount","_stopWatch","info","toFixed","Stacktrace","print","Listener","callbackThis","invoke","_b","_disposed","_options","_leakageMon","_perfMon","_profName","_deliveryQueue","deliveryQueue","_c","_d","_listeners","_event","firstListener","removeMonitor","create","check","onListenerDidAdd","PrivateEventDeliveryQueue","deliver","_queue","EventDeliveryQueueElement","newQueue","getAllMethodNames","obj","methods","prop","proto","getPrototypeOf","prototype","getOwnPropertyNames","getAllPropertyNames","assertNever","Lazy","executor","_didRun","hasValue","getValue","_value","_error","rawValue","escapeRegExpCharacters","isUpperAsciiLetter","code","isHighSurrogate","charCode","isLowSurrogate","computeCodePoint","highSurrogate","lowSurrogate","getNextCodePoint","str","offset","charCodeAt","nextCharCode","IS_BASIC_ASCII","fromCharCode","GraphemeBreakTree","_data","_INSTANCE","getGraphemeBreakType","codePoint","nodeCount","nodeIndex","AmbiguousCharacters","confusableDictionary","locales","_locales","isAmbiguous","has","getPrimaryConfusable","getConfusableCodePoints","keys","ambiguousCharacterData","lastCache","lastArgKey","key","stringify","arrayToMap","Map","intersectMaps","map1","map2","languageSpecificMap","filteredLocales","l","startsWith","mergeMaps","k","InvisibleCharacters","getRawData","getData","codePoints","INITIALIZE","safeProcess","RequestMessage","vsWorker","req","method","ReplyMessage","seq","SubscribeEventMessage","EventMessage","UnsubscribeEventMessage","SimpleWorkerProtocol","_workerId","_handler","_lastSentReq","_pendingReplies","_pendingEmitters","_pendingEvents","setWorkerId","workerId","sendMessage","reject","_send","listen","delete","handleMessage","_handleMessage","_handleReplyMessage","_handleRequestMessage","_handleSubscribeEventMessage","_handleEventMessage","_handleUnsubscribeEventMessage","replyMessage","reply","requestMessage","then","r","detail","handleEvent","transfer","ArrayBuffer","propertyIsEvent","propertyIsDynamicEvent","test","methodNames","proxyListen","createProxyMethod","createProxyDynamicEvent","methodName","SimpleWorkerServer","requestHandlerFactory","_requestHandlerFactory","_requestHandler","_protocol","_handleEvent","onmessage","initialize","loaderConfig","moduleId","hostMethods","hostProxy","baseUrl","paths","vs","trustedTypesPolicy","catchError","module","DiffChange","originalStart","originalLength","modifiedStart","modifiedLength","getOriginalEnd","getModifiedEnd","numberHash","val","initialHashVal","stringHash","s","hashVal","leftRotate","bits","totalBits","delta","fill","dest","count","byteLength","toHexString","bufferOrValue","bitsize","Uint8Array","toString","padStart","char","leftPad","StringSHA1","_h0","_h1","_h2","_h3","_h4","_buff","_buffDV","DataView","_buffLen","_totalLen","_leftoverHighSurrogate","_finished","update","strLen","buff","buffLen","leftoverHighSurrogate","_push","_step","digest","_wrapUp","ml","setUint32","Math","floor","bigBlock32","_bigBlock32","j","getUint32","f","temp","c","StringDiffSequence","source","getElements","characters","Int32Array","stringDiff","original","modified","pretty","LcsDiff","ComputeDiff","changes","Debug","condition","MyArray","sourceArray","sourceIndex","destinationArray","destinationIndex","DiffChangeHelper","m_changes","m_originalStart","m_modifiedStart","m_originalCount","m_modifiedCount","MarkNextChange","AddOriginalElement","originalIndex","modifiedIndex","min","AddModifiedElement","getChanges","getReverseChanges","reverse","originalSequence","modifiedSequence","continueProcessingPredicate","ContinueProcessingPredicate","_originalSequence","_modifiedSequence","originalStringElements","originalElementsOrHash","originalHasStrings","_getElements","modifiedStringElements","modifiedElementsOrHash","modifiedHasStrings","_hasStrings","_originalStringElements","_originalElementsOrHash","_modifiedStringElements","_modifiedElementsOrHash","m_forwardHistory","m_reverseHistory","sequence","elements","_isStringArray","hashes","ElementsAreEqual","newIndex","ElementsAreStrictEqual","_getStrictElement","getStrictElement","OriginalElementsAreEqual","index1","index2","ModifiedElementsAreEqual","_ComputeDiff","originalEnd","modifiedEnd","quitEarlyArr","ComputeDiffRecursive","PrettifyChanges","quitEarly","Assert","midOriginalArr","midModifiedArr","ComputeRecursionPoint","midOriginal","midModified","leftChanges","rightChanges","ConcatenateChanges","WALKTRACE","diagonalForwardBase","diagonalForwardStart","diagonalForwardEnd","diagonalForwardOffset","diagonalReverseBase","diagonalReverseStart","diagonalReverseEnd","diagonalReverseOffset","forwardPoints","reversePoints","deltaIsEven","forwardChanges","reverseChanges","changeHelper","diagonalMin","diagonalMax","diagonalRelative","lastOriginalIndex","historyIndex","diagonal","originalStartPoint","modifiedStartPoint","lastForwardChange","max","maxDifferences","numDiagonals","numDifferences","furthestOriginalIndex","furthestModifiedIndex","ClipDiagonalBound","tempOriginalIndex","abs","matchLengthOfLongest","Copy2","change","originalStop","modifiedStop","checkOriginal","checkModified","startStrictEqual","mergedChangeArr","ChangesOverlap","prevChange","bestDelta","bestScore","_boundaryScore","score","aChange","bChange","matchedLength","aOriginalStart","bOriginalEnd","abOriginalLength","aModifiedStart","bModifiedEnd","abModifiedLength","t","_findBetterContiguousSequence","originalMatchStart","modifiedMatchStart","desiredLength","originalMax","modifiedMax","bestOriginalStart","bestModifiedStart","_contiguousSequenceScore","_OriginalIsBoundary","_OriginalRegionIsBoundary","_ModifiedIsBoundary","_ModifiedRegionIsBoundary","left","right","Copy","diagonalBaseIndex","diffEven","sandboxProcess","arch","cwd","CHAR_DOT","CHAR_FORWARD_SLASH","CHAR_BACKWARD_SLASH","CHAR_COLON","ErrorInvalidArgType","expected","actual","determiner","validateString","isPathSeparator","isPosixPathSeparator","isWindowsDeviceRoot","normalizeString","path","allowAboveRoot","separator","lastSegmentLength","lastSlash","dots","lastSlashIndex","lastIndexOf","sep","pathObject","dir","root","base","ext","win32","pathSegments","resolvedDevice","resolvedTail","resolvedAbsolute","toLowerCase","rootEnd","device","isAbsolute","last","firstPart","normalize","tail","joined","needsReplace","slashCount","firstLen","relative","fromOrig","toOrig","fromStart","fromEnd","fromLen","toStart","toEnd","toLen","lastCommonSep","fromCode","out","toNamespacedPath","resolvedPath","dirname","end","matchedSlash","basename","extIdx","firstNonSlashEnd","extname","startDot","startPart","preDotState","format","bind","ret","delimiter","posix","trailingSeparator","hasRoot","_schemePattern","_singleSlashStart","_doubleSlashStart","_validateUri","_strict","scheme","authority","query","fragment","_slash","_regexp","schemeOrData","_schemeFix","_referenceResolution","fsPath","with","uriToFsPath","Uri","exec","percentDecode","idx","substring","components","uri","pathFragment","newPath","file","skipEncoding","_asFormatted","toJSON","_formatted","external","_fsPath","_sep","_pathSepMarker","$mid","encodeTable","encodeURIComponentFast","uriComponent","allowSlash","nativeEncodePos","pos","encodeURIComponent","charAt","substr","escaped","encodeURIComponentMinimal","keepDriveLetterCasing","encoder","userinfo","decodeURIComponentGraceful","decodeURIComponent","_rEncodedAsHex","lineNumber","column","newLineNumber","newColumn","deltaLineNumber","deltaColumn","other","isBefore","isBeforeOrEqual","aLineNumber","bLineNumber","clone","startLineNumber","startColumn","endLineNumber","endColumn","range","containsPosition","position","containsRange","otherRange","strictContainsRange","plusRange","intersectRanges","resultStartLineNumber","resultStartColumn","resultEndLineNumber","resultEndColumn","otherStartLineNumber","otherStartColumn","otherEndLineNumber","otherEndColumn","equalsRange","getEndPosition","getStartPosition","setEndPosition","setStartPosition","collapseToStart","aStartLineNumber","bStartLineNumber","aStartColumn","bStartColumn","aEndLineNumber","bEndLineNumber","computeDiff","LineSequence","lines","startColumns","endColumns","getFirstNonBlankColumn","getLastNonBlankColumn","_startColumns","_endColumns","getStartLineNumber","getEndLineNumber","createCharSequence","shouldIgnoreTrimWhitespace","startIndex","endIndex","charCodes","lineNumbers","columns","lineContent","col","CharSequence","_charCodes","_lineNumbers","_columns","_assertIndex","getStartColumn","getEndColumn","CharChange","originalStartLineNumber","originalStartColumn","originalEndLineNumber","originalEndColumn","modifiedStartLineNumber","modifiedStartColumn","modifiedEndLineNumber","modifiedEndColumn","diffChange","originalCharSequence","modifiedCharSequence","LineChange","charChanges","originalLineSequence","modifiedLineSequence","continueCharDiff","shouldComputeCharChanges","shouldPostProcessCharChanges","rawChanges","currChange","originalMatchingLength","modifiedMatchingLength","postProcessCharChanges","createFromDiffChange","DiffComputer","originalLines","modifiedLines","opts","shouldMakePrettyDiff","continueLineDiff","createContinueProcessingPredicate","maxComputationTime","diffResult","lineChanges","createFromDiffResult","originalLineIndex","modifiedLineIndex","nextChange","originalLine","modifiedLine","_pushTrimWhitespaceCharChange","originalMaxColumn","modifiedMaxColumn","originalLineNumber","modifiedLineNumber","_mergeTrimWhitespaceCharChange","txt","defaultValue","chCode","maximumRuntime","startTime","CompareResult","isLessThan","isGreaterThan","isNeitherLessOrGreaterThan","greaterThan","lessThan","neitherLessOrGreaterThan","toUint8","v","toUint32","PrefixSumComputer","prefixSum","Uint32Array","prefixSumValidIndex","insertValues","insertIndex","oldValues","oldPrefixSum","insertValuesLen","subarray","setValue","removeValues","maxCount","getTotalSum","_getPrefixSum","getPrefixSum","getIndexOf","sum","low","high","mid","midStop","midStart","PrefixSumIndexOfResult","remainder","_prefixSumIndexOfResultBrand","DEFAULT_WORD_REGEXP","allowInWords","RegExp","createWordRegExp","_defaultConfig","getWordAtText","wordDefinition","text","textOffset","config","maxLen","t1","prevRegexIndex","timeBudget","regexIndex","windowSize","lastIndex","thisMatch","_findRegexMatchEnclosingPosition","word","stopPos","matchIndex","CharacterClassifier","_defaultValue","_asciiMap","_createAsciiMap","_map","asciiMap","Uint8Matrix","rows","cols","row","StateMachine","edges","maxCharCode","maxState","states","_states","_maxCharCode","nextState","currentState","_stateMachine","_classifier","LinkComputer","classifier","line","linkBeginIndex","linkEndIndex","lastIncludedCharIndex","charCodeBeforeLink","lastCharCodeInLink","url","model","stateMachine","getStateMachine","FORCE_TERMINATION_CHARACTERS","CANNOT_END_WITH_CHARACTERS","getClassifier","lineCount","getLineCount","getLineContent","linkBeginChCode","state","hasOpenParens","hasOpenSquareBracket","inSquareBrackets","hasOpenCurlyBracket","resetStateMachine","chClass","_createLink","BasicInplaceReplace","_defaultValueSet","navigateValueSet","range1","text1","range2","text2","up","doNavigateValueSet","numberResult","numberReplace","textReplace","precision","pow","n1","n2","parseFloat","isNaN","valueSetsReplace","valueSets","valueSetReplace","valueSet","INSTANCE","shortcutEvent","context","CancellationToken","isCancellationToken","Cancelled","MutableToken","isCancellationRequested","onCancellationRequested","_isCancelled","_emitter","cancel","CancellationTokenSource","_token","_parentListener","token","KeyCodeStrMap","_keyCodeToStr","_strToKeyCode","define","keyCode","keyCodeToStr","strToKeyCode","uiMap","userSettingsUSMap","userSettingsGeneralMap","EVENT_KEY_CODE_MAP","NATIVE_WINDOWS_KEY_CODE_TO_KEY_CODE","scanCodeIntToStr","scanCodeStrToInt","scanCodeLowerCaseStrToInt","IMMUTABLE_CODE_TO_KEY_CODE","IMMUTABLE_KEY_CODE_TO_CODE","KeyCodeUtils","CSSIcon","mappings","seenKeyCode","seenScanCode","mapping","_keyCodeOrd","immutable","scanCode","scanCodeStr","keyCodeStr","eventKeyCode","vkey","usUserSettingsLabel","generalUserSettingsLabel","fromString","toUserSettingsUS","toUserSettingsGeneral","fromUserSettings","toElectronAccelerator","Selection","selectionStartLineNumber","selectionStartColumn","positionLineNumber","positionColumn","equalsSelection","selectionsEqual","getDirection","getPosition","getSelectionStart","direction","sel","Codicon","definition","description","_allCodicons","classNames","classNamesArray","cssSelector","fontCharacter","plus","gistNew","repoCreate","lightbulb","lightBulb","repo","repoDelete","gistFork","repoForked","gitPullRequest","gitPullRequestAbandoned","recordKeys","keyboard","tag","tagAdd","tagRemove","person","personFollow","personOutline","personFilled","gitBranch","gitBranchCreate","gitBranchDelete","sourceControl","mirror","mirrorPublic","star","starAdd","starDelete","starEmpty","comment","commentAdd","alert","warning","search","searchSave","logOut","signOut","logIn","signIn","eye","eyeUnwatch","eyeWatch","circleFilled","primitiveDot","closeDirty","debugBreakpoint","debugBreakpointDisabled","debugHint","primitiveSquare","edit","pencil","issueOpened","gistPrivate","gitForkPrivate","lock","mirrorPrivate","close","removeClose","repoSync","sync","desktopDownload","beaker","microscope","vm","deviceDesktop","fileText","more","ellipsis","kebabHorizontal","mailReply","organization","organizationFilled","organizationOutline","newFile","fileAdd","newFolder","fileDirectoryCreate","trash","trashcan","history","clock","folder","fileDirectory","symbolFolder","logoGithub","markGithub","github","terminal","repl","zap","symbolEvent","variable","symbolVariable","array","symbolArray","symbolModule","symbolPackage","symbolNamespace","symbolObject","symbolMethod","symbolFunction","symbolConstructor","symbolBoolean","symbolNull","symbolNumeric","symbolNumber","symbolStructure","symbolStruct","symbolParameter","symbolTypeParameter","symbolKey","symbolText","symbolReference","goToFile","symbolEnum","symbolValue","symbolRuler","symbolUnit","activateBreakpoints","archive","arrowBoth","arrowDown","arrowLeft","arrowRight","arrowSmallDown","arrowSmallLeft","arrowSmallRight","arrowSmallUp","arrowUp","bell","bold","book","bookmark","debugBreakpointConditionalUnverified","debugBreakpointConditional","debugBreakpointConditionalDisabled","debugBreakpointDataUnverified","debugBreakpointData","debugBreakpointDataDisabled","debugBreakpointLogUnverified","debugBreakpointLog","debugBreakpointLogDisabled","briefcase","broadcast","browser","bug","calendar","caseSensitive","checklist","chevronDown","dropDownButton","chevronLeft","chevronRight","chevronUp","chromeClose","chromeMaximize","chromeMinimize","chromeRestore","circleOutline","debugBreakpointUnverified","circleSlash","circuitBoard","clearAll","clippy","closeAll","cloudDownload","cloudUpload","collapseAll","colorMode","commentDiscussion","compareChanges","creditCard","dash","dashboard","database","debugContinue","debugDisconnect","debugPause","debugRestart","debugStart","debugStepInto","debugStepOut","debugStepOver","debugStop","debug","deviceCameraVideo","deviceCamera","deviceMobile","diffAdded","diffIgnored","diffModified","diffRemoved","diffRenamed","diff","discard","editorLayout","emptyWindow","exclude","extensions","eyeClosed","fileBinary","fileCode","fileMedia","filePdf","fileSubmodule","fileSymlinkDirectory","fileSymlinkFile","fileZip","files","flame","foldDown","foldUp","fold","folderActive","folderOpened","gear","gift","gistSecret","gist","gitCommit","gitCompare","gitMerge","githubAction","githubAlt","globe","grabber","graph","gripper","heart","home","horizontalRule","hubot","inbox","issueClosed","issueReopened","issues","italic","jersey","json","kebabVertical","law","lightbulbAutofix","linkExternal","link","listOrdered","listUnordered","liveShare","loading","mailRead","mail","markdown","megaphone","mention","milestone","mortarBoard","move","multipleWindows","mute","noNewline","note","octoface","openPreview","package_","paintcan","pin","play","plug","preserveCase","preview","project","pulse","question","quote","radioTower","reactions","references","refresh","regex","remoteExplorer","remote","remove","replaceAll","repoClone","repoForcePush","repoPull","repoPush","report","requestChanges","rocket","rootFolderOpened","rootFolder","rss","ruby","saveAll","saveAs","save","screenFull","screenNormal","searchStop","server","settingsGear","settings","shield","smiley","sortPrecedence","splitHorizontal","splitVertical","squirrel","starFull","starHalf","symbolClass","symbolColor","symbolCustomColor","symbolConstant","symbolEnumMember","symbolField","symbolFile","symbolInterface","symbolKeyword","symbolMisc","symbolOperator","symbolProperty","wrench","wrenchSubaction","symbolSnippet","tasklist","telescope","textSize","threeBars","thumbsdown","thumbsup","tools","triangleDown","triangleLeft","triangleRight","triangleUp","twitter","unfold","unlock","unmute","unverified","verified","vmActive","vmOutline","vmRunning","watch","whitespace","wholeWord","wordWrap","zoomIn","zoomOut","listFilter","listFlat","listSelection","selection","listTree","debugBreakpointFunctionUnverified","debugBreakpointFunction","debugBreakpointFunctionDisabled","debugStackframeActive","circleSmallFilled","debugStackframeDot","debugStackframe","debugStackframeFocused","debugBreakpointUnsupported","symbolString","debugReverseContinue","debugStepBack","debugRestartFrame","callIncoming","callOutgoing","menu","expandAll","feedback","groupByRefType","ungroupByRefType","account","bellDot","debugConsole","library","runAll","syncIgnored","pinned","githubInverted","debugAlt","serverProcess","serverEnvironment","pass","stopCircle","playCircle","record","debugAltSmall","vmConnect","cloud","exportIcon","graphLeft","magnet","notebook","redo","checkAll","pinnedDirty","passFilled","circleLargeFilled","circleLargeOutline","combine","gather","table","variableGroup","typeHierarchy","typeHierarchySub","typeHierarchySuper","gitPullRequestCreate","runAbove","runBelow","notebookTemplate","debugRerun","workspaceTrusted","workspaceUntrusted","workspaceUnspecified","terminalCmd","terminalDebian","terminalLinux","terminalPowershell","terminalTmux","terminalUbuntu","terminalBash","arrowSwap","copy","personAdd","filterFilled","wand","debugLineByLine","inspect","layers","layersDot","layersActive","compass","compassDot","compassActive","azure","issueDraft","gitPullRequestClosed","gitPullRequestDraft","debugAll","debugCoverage","runErrors","folderLibrary","debugContinueSmall","beakerStop","graphLine","graphScatter","pieChart","bracket","bracketDot","bracketError","lockSmall","azureDevops","verifiedFilled","newLine","layout","layoutActivitybarLeft","layoutActivitybarRight","layoutPanelLeft","layoutPanelCenter","layoutPanelJustify","layoutPanelRight","layoutPanel","layoutSidebarLeft","layoutSidebarRight","layoutStatusbar","layoutMenubar","layoutCentered","layoutSidebarRightOff","layoutPanelOff","layoutSidebarLeftOff","target","indent","recordSmall","errorSmall","arrowCircleDown","arrowCircleLeft","arrowCircleRight","arrowCircleUp","heartFilled","mapFilled","circleSmall","bellSlash","bellSlashDot","commentUnresolved","gitPullRequestGoToChanges","gitPullRequestNewChanges","dialogError","dialogWarning","dialogInfo","dialogClose","treeItemExpanded","treeFilterOnTypeOn","treeFilterOnTypeOff","treeFilterClear","treeItemLoading","menuSelection","menuSubmenu","menuBarMore","scrollbarButtonLeft","scrollbarButtonRight","scrollbarButtonUp","scrollbarButtonDown","toolBarMore","quickInputBack","iconNameSegment","iconNameExpression","iconModifierExpression","iconNameCharacter","cssIconIdRegex","asClassNameArray","icon","modifier","asClassName","asCSSSelector","CompletionItemKinds","InlineCompletionTriggerKind","SignatureHelpTriggerKind","DocumentHighlightKind","SymbolKinds","Command","InlayHintKind","thisArg","_arguments","P","generator","fulfilled","step","rejected","TokenizationSupportFactoryData","_registry","_languageId","_factory","_resolvePromise","_isResolved","isResolved","_create","createTokenizationSupport","register","Token","language","_tokenBrand","byKind","toIcon","kind","codicon","strict","FoldingRangeKind","Comment","Imports","Region","title","_factories","_onDidChange","onDidChange","_colorMap","languages","changedLanguages","changedColorMap","support","registerFactory","languageId","factory","myData","getOrCreate","tokenizationSupport","setColorMap","colorMap","getColorMap","getDefaultBackground","AccessibilitySupport","CodeActionTriggerType","CompletionItemInsertTextRule","CompletionItemKind","CompletionItemTag","CompletionTriggerKind","ContentWidgetPositionPreference","CursorChangeReason","DefaultEndOfLine","EditorAutoIndentStrategy","EditorOption","EndOfLinePreference","EndOfLineSequence","IndentAction","InjectedTextCursorStops","KeyCode","MarkerSeverity","MarkerTag","MinimapPosition","MouseTargetType","OverlayWidgetPositionPreference","OverviewRulerLane","PositionAffinity","RenderLineNumbersType","RenderMinimap","ScrollType","ScrollbarVisibility","SelectionDirection","SymbolKind","SymbolTag","TextEditorCursorBlinkingStyle","TextEditorCursorStyle","TrackedRangeStickiness","WrappingIndent","KeyMod","secondPart","KeyChord","CtrlCmd","Shift","Alt","WinCtrl","WordCharacterClassifier","wordSeparators","computeFn","input","hasOwnProperty","isValidMatch","textLength","matchStartIndex","matchLength","charBefore","firstCharInMatch","leftIsWordBounday","charAfter","lastCharInMatch","rightIsWordBounday","Searcher","searchRegex","_wordSeparators","_searchRegex","_prevMatchStartIndex","_prevMatchLength","reset","m","CodePointHighlighter","allowedCodePoints","ambiguousCharacters","allowedLocales","getCandidateCodePoints","nonBasicASCII","invisibleCharacters","cp","isAllowedInvisibleCharacter","fromCodePoint","shouldHighlightNonBasicASCII","character","wordContext","codePointAt","hasBasicASCIICharacters","hasNonConfusableNonBasicAsciiCharacter","isBasicASCII","MirrorModel","eol","versionId","_uri","_lines","_eol","_versionId","_lineStarts","_cachedTextValue","version","getText","onEvents","_acceptDeleteRange","_acceptInsertText","_ensureLineStarts","eolLength","linesLength","lineStartValues","_setLineText","lineIndex","newValue","insertText","insertLines","newLengths","getLinesContent","getWordAtPosition","wordAtText","global","flags","ignoreCase","multiline","unicode","ensureValidWordDefinition","words","wordenize","_wordenize","lineText","wordRangesIdx","wordRanges","getLineWords","content","ranges","getValueInRange","_validateRange","lineEnding","startLineIndex","endLineIndex","resultLines","offsetAt","_validatePosition","positionAt","lineLength","hasChanged","maxCharacter","EditorSimpleWorker","host","foreignModuleFactory","_host","_models","_foreignModuleFactory","_foreignModule","_getModel","_getModels","all","acceptNewModel","EOL","acceptModelChanged","strURL","acceptRemovedModel","computeUnicodeHighlights","startLine","endLine","codePointHighlighter","candidates","searcher","hasMore","ambiguousCharacterCount","invisibleCharacterCount","nonBasicAsciiCharacterCount","forLoop","highlightReason","MAX_RESULT_LENGTH","primaryConfusable","notAmbiguousInLocales","confusableWith","originalUrl","modifiedUrl","ignoreTrimWhitespace","originalTextModel","modifiedTextModel","identical","_modelsAreIdentical","originalLineCount","computeMoreMinimalEdits","modelUrl","edits","lastEol","sort","_diffLimit","editOffset","newEdit","computeLinks","textualSuggest","modelUrls","leadingWord","wordDef","wordDefFlags","sw","wordDefRegExp","seen","outer","_suggestionsLimit","duration","computeWordRanges","selectionText","wordRange","loadForeignModule","createData","foreignHostMethods","foreignHost","fhr","ctx","getMirrorModels","fmr","editor","Position","Range","initialized","foreignModule","simpleWorker"],"sourceRoot":""}