;(function () {
function o(n) {
var i = e
n && (e[n] || (e[n] = {}), (i = e[n]))
if (!i.define || !i.define.packaged)
(t.original = i.define), (i.define = t), (i.define.packaged = !0)
if (!i.require || !i.require.packaged)
(r.original = i.require), (i.require = r), (i.require.packaged = !0)
}
var ACE_NAMESPACE = 'ace',
e = (function () {
return this
})()
!e && typeof window != 'undefined' && (e = window)
if (!ACE_NAMESPACE && typeof requirejs != 'undefined') return
var t = function (e, n, r) {
if (typeof e != 'string') {
t.original
? t.original.apply(this, arguments)
: (console.error("dropping module because define wasn't a string."), console.trace())
return
}
arguments.length == 2 && (r = n), t.modules[e] || ((t.payloads[e] = r), (t.modules[e] = null))
}
;(t.modules = {}), (t.payloads = {})
var n = function (e, t, n) {
if (typeof t == 'string') {
var i = s(e, t)
if (i != undefined) return n && n(), i
} else if (Object.prototype.toString.call(t) === '[object Array]') {
var o = []
for (var u = 0, a = t.length; u < a; ++u) {
var f = s(e, t[u])
if (f == undefined && r.original) return
o.push(f)
}
return (n && n.apply(null, o)) || !0
}
},
r = function (e, t) {
var i = n('', e, t)
return i == undefined && r.original ? r.original.apply(this, arguments) : i
},
i = function (e, t) {
if (t.indexOf('!') !== -1) {
var n = t.split('!')
return i(e, n[0]) + '!' + i(e, n[1])
}
if (t.charAt(0) == '.') {
var r = e.split('/').slice(0, -1).join('/')
t = r + '/' + t
while (t.indexOf('.') !== -1 && s != t) {
var s = t
t = t.replace(/\/\.\//, '/').replace(/[^\/]+\/\.\.\//, '')
}
}
return t
},
s = function (e, r) {
r = i(e, r)
var s = t.modules[r]
if (!s) {
s = t.payloads[r]
if (typeof s == 'function') {
var o = {},
u = { id: r, uri: '', exports: o, packaged: !0 },
a = function (e, t) {
return n(r, e, t)
},
f = s(a, o, u)
;(o = f || u.exports), (t.modules[r] = o), delete t.payloads[r]
}
s = t.modules[r] = o || s
}
return s
}
o(ACE_NAMESPACE)
})(),
ace.define('ace/lib/fixoldbrowsers', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
typeof Element != 'undefined' &&
!Element.prototype.remove &&
Object.defineProperty(Element.prototype, 'remove', {
enumerable: !1,
writable: !0,
configurable: !0,
value: function () {
this.parentNode && this.parentNode.removeChild(this)
},
})
}),
ace.define('ace/lib/useragent', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
;(t.OS = { LINUX: 'LINUX', MAC: 'MAC', WINDOWS: 'WINDOWS' }),
(t.getOS = function () {
return t.isMac ? t.OS.MAC : t.isLinux ? t.OS.LINUX : t.OS.WINDOWS
})
var r = typeof navigator == 'object' ? navigator : {},
i = (/mac|win|linux/i.exec(r.platform) || ['other'])[0].toLowerCase(),
s = r.userAgent || '',
o = r.appName || ''
;(t.isWin = i == 'win'),
(t.isMac = i == 'mac'),
(t.isLinux = i == 'linux'),
(t.isIE =
o == 'Microsoft Internet Explorer' || o.indexOf('MSAppHost') >= 0
? parseFloat(
(s.match(/(?:MSIE |Trident\/[0-9]+[\.0-9]+;.*rv:)([0-9]+[\.0-9]+)/) || [])[1]
)
: parseFloat((s.match(/(?:Trident\/[0-9]+[\.0-9]+;.*rv:)([0-9]+[\.0-9]+)/) || [])[1])),
(t.isOldIE = t.isIE && t.isIE < 9),
(t.isGecko = t.isMozilla = s.match(/ Gecko\/\d+/)),
(t.isOpera =
typeof opera == 'object' &&
Object.prototype.toString.call(window.opera) == '[object Opera]'),
(t.isWebKit = parseFloat(s.split('WebKit/')[1]) || undefined),
(t.isChrome = parseFloat(s.split(' Chrome/')[1]) || undefined),
(t.isEdge = parseFloat(s.split(' Edge/')[1]) || undefined),
(t.isAIR = s.indexOf('AdobeAIR') >= 0),
(t.isAndroid = s.indexOf('Android') >= 0),
(t.isChromeOS = s.indexOf(' CrOS ') >= 0),
(t.isIOS = /iPad|iPhone|iPod/.test(s) && !window.MSStream),
t.isIOS && (t.isMac = !0),
(t.isMobile = t.isIOS || t.isAndroid)
}),
ace.define(
'ace/lib/dom',
['require', 'exports', 'module', 'ace/lib/useragent'],
function (e, t, n) {
'use strict'
var r = e('./useragent'),
i = 'http://www.w3.org/1999/xhtml'
;(t.buildDom = function o(e, t, n) {
if (typeof e == 'string' && e) {
var r = document.createTextNode(e)
return t && t.appendChild(r), r
}
if (!Array.isArray(e)) return e && e.appendChild && t && t.appendChild(e), e
if (typeof e[0] != 'string' || !e[0]) {
var i = []
for (var s = 0; s < e.length; s++) {
var u = o(e[s], t, n)
u && i.push(u)
}
return i
}
var a = document.createElement(e[0]),
f = e[1],
l = 1
f && typeof f == 'object' && !Array.isArray(f) && (l = 2)
for (var s = l; s < e.length; s++) o(e[s], a, n)
return (
l == 2 &&
Object.keys(f).forEach(function (e) {
var t = f[e]
e === 'class'
? (a.className = Array.isArray(t) ? t.join(' ') : t)
: typeof t == 'function' || e == 'value' || e[0] == '$'
? (a[e] = t)
: e === 'ref'
? n && (n[t] = a)
: t != null && a.setAttribute(e, t)
}),
t && t.appendChild(a),
a
)
}),
(t.getDocumentHead = function (e) {
return (
e || (e = document), e.head || e.getElementsByTagName('head')[0] || e.documentElement
)
}),
(t.createElement = function (e, t) {
return document.createElementNS
? document.createElementNS(t || i, e)
: document.createElement(e)
}),
(t.removeChildren = function (e) {
e.innerHTML = ''
}),
(t.createTextNode = function (e, t) {
var n = t ? t.ownerDocument : document
return n.createTextNode(e)
}),
(t.createFragment = function (e) {
var t = e ? e.ownerDocument : document
return t.createDocumentFragment()
}),
(t.hasCssClass = function (e, t) {
var n = (e.className + '').split(/\s+/g)
return n.indexOf(t) !== -1
}),
(t.addCssClass = function (e, n) {
t.hasCssClass(e, n) || (e.className += ' ' + n)
}),
(t.removeCssClass = function (e, t) {
var n = e.className.split(/\s+/g)
for (;;) {
var r = n.indexOf(t)
if (r == -1) break
n.splice(r, 1)
}
e.className = n.join(' ')
}),
(t.toggleCssClass = function (e, t) {
var n = e.className.split(/\s+/g),
r = !0
for (;;) {
var i = n.indexOf(t)
if (i == -1) break
;(r = !1), n.splice(i, 1)
}
return r && n.push(t), (e.className = n.join(' ')), r
}),
(t.setCssClass = function (e, n, r) {
r ? t.addCssClass(e, n) : t.removeCssClass(e, n)
}),
(t.hasCssString = function (e, t) {
var n = 0,
r
t = t || document
if ((r = t.querySelectorAll('style'))) while (n < r.length) if (r[n++].id === e) return !0
}),
(t.importCssString = function (n, r, i) {
var s = i
if (!i || !i.getRootNode) s = document
else {
s = i.getRootNode()
if (!s || s == i) s = document
}
var o = s.ownerDocument || s
if (r && t.hasCssString(r, s)) return null
r && (n += '\n/*# sourceURL=ace/css/' + r + ' */')
var u = t.createElement('style')
u.appendChild(o.createTextNode(n)),
r && (u.id = r),
s == o && (s = t.getDocumentHead(o)),
s.insertBefore(u, s.firstChild)
}),
(t.importCssStylsheet = function (e, n) {
t.buildDom(['link', { rel: 'stylesheet', href: e }], t.getDocumentHead(n))
}),
(t.scrollbarWidth = function (e) {
var n = t.createElement('ace_inner')
;(n.style.width = '100%'),
(n.style.minWidth = '0px'),
(n.style.height = '200px'),
(n.style.display = 'block')
var r = t.createElement('ace_outer'),
i = r.style
;(i.position = 'absolute'),
(i.left = '-10000px'),
(i.overflow = 'hidden'),
(i.width = '200px'),
(i.minWidth = '0px'),
(i.height = '150px'),
(i.display = 'block'),
r.appendChild(n)
var s = e.documentElement
s.appendChild(r)
var o = n.offsetWidth
i.overflow = 'scroll'
var u = n.offsetWidth
return o == u && (u = r.clientWidth), s.removeChild(r), o - u
}),
typeof document == 'undefined' && (t.importCssString = function () {}),
(t.computedStyle = function (e, t) {
return window.getComputedStyle(e, '') || {}
}),
(t.setStyle = function (e, t, n) {
e[t] !== n && (e[t] = n)
}),
(t.HAS_CSS_ANIMATION = !1),
(t.HAS_CSS_TRANSFORMS = !1),
(t.HI_DPI = r.isWin ? typeof window != 'undefined' && window.devicePixelRatio >= 1.5 : !0)
if (typeof document != 'undefined') {
var s = document.createElement('div')
t.HI_DPI && s.style.transform !== undefined && (t.HAS_CSS_TRANSFORMS = !0),
!r.isEdge && typeof s.style.animationName != 'undefined' && (t.HAS_CSS_ANIMATION = !0),
(s = null)
}
t.HAS_CSS_TRANSFORMS
? (t.translate = function (e, t, n) {
e.style.transform = 'translate(' + Math.round(t) + 'px, ' + Math.round(n) + 'px)'
})
: (t.translate = function (e, t, n) {
;(e.style.top = Math.round(n) + 'px'), (e.style.left = Math.round(t) + 'px')
})
}
),
ace.define('ace/lib/oop', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
;(t.inherits = function (e, t) {
;(e.super_ = t),
(e.prototype = Object.create(t.prototype, {
constructor: { value: e, enumerable: !1, writable: !0, configurable: !0 },
}))
}),
(t.mixin = function (e, t) {
for (var n in t) e[n] = t[n]
return e
}),
(t.implement = function (e, n) {
t.mixin(e, n)
})
}),
ace.define('ace/lib/keys', ['require', 'exports', 'module', 'ace/lib/oop'], function (e, t, n) {
'use strict'
var r = e('./oop'),
i = (function () {
var e = {
MODIFIER_KEYS: {
16: 'Shift',
17: 'Ctrl',
18: 'Alt',
224: 'Meta',
91: 'MetaLeft',
92: 'MetaRight',
93: 'ContextMenu',
},
KEY_MODS: {
ctrl: 1,
alt: 2,
option: 2,
shift: 4,
super: 8,
meta: 8,
command: 8,
cmd: 8,
control: 1,
},
FUNCTION_KEYS: {
8: 'Backspace',
9: 'Tab',
13: 'Return',
19: 'Pause',
27: 'Esc',
32: 'Space',
33: 'PageUp',
34: 'PageDown',
35: 'End',
36: 'Home',
37: 'Left',
38: 'Up',
39: 'Right',
40: 'Down',
44: 'Print',
45: 'Insert',
46: 'Delete',
96: 'Numpad0',
97: 'Numpad1',
98: 'Numpad2',
99: 'Numpad3',
100: 'Numpad4',
101: 'Numpad5',
102: 'Numpad6',
103: 'Numpad7',
104: 'Numpad8',
105: 'Numpad9',
'-13': 'NumpadEnter',
112: 'F1',
113: 'F2',
114: 'F3',
115: 'F4',
116: 'F5',
117: 'F6',
118: 'F7',
119: 'F8',
120: 'F9',
121: 'F10',
122: 'F11',
123: 'F12',
144: 'Numlock',
145: 'Scrolllock',
},
PRINTABLE_KEYS: {
32: ' ',
48: '0',
49: '1',
50: '2',
51: '3',
52: '4',
53: '5',
54: '6',
55: '7',
56: '8',
57: '9',
59: ';',
61: '=',
65: 'a',
66: 'b',
67: 'c',
68: 'd',
69: 'e',
70: 'f',
71: 'g',
72: 'h',
73: 'i',
74: 'j',
75: 'k',
76: 'l',
77: 'm',
78: 'n',
79: 'o',
80: 'p',
81: 'q',
82: 'r',
83: 's',
84: 't',
85: 'u',
86: 'v',
87: 'w',
88: 'x',
89: 'y',
90: 'z',
107: '+',
109: '-',
110: '.',
186: ';',
187: '=',
188: ',',
189: '-',
190: '.',
191: '/',
192: '`',
219: '[',
220: '\\',
221: ']',
222: "'",
111: '/',
106: '*',
},
},
t,
n
for (n in e.FUNCTION_KEYS) (t = e.FUNCTION_KEYS[n].toLowerCase()), (e[t] = parseInt(n, 10))
for (n in e.PRINTABLE_KEYS)
(t = e.PRINTABLE_KEYS[n].toLowerCase()), (e[t] = parseInt(n, 10))
return (
r.mixin(e, e.MODIFIER_KEYS),
r.mixin(e, e.PRINTABLE_KEYS),
r.mixin(e, e.FUNCTION_KEYS),
(e.enter = e['return']),
(e.escape = e.esc),
(e.del = e['delete']),
(e[173] = '-'),
(function () {
var t = ['cmd', 'ctrl', 'alt', 'shift']
for (var n = Math.pow(2, t.length); n--; )
e.KEY_MODS[n] =
t
.filter(function (t) {
return n & e.KEY_MODS[t]
})
.join('-') + '-'
})(),
(e.KEY_MODS[0] = ''),
(e.KEY_MODS[-1] = 'input-'),
e
)
})()
r.mixin(t, i),
(t.keyCodeToString = function (e) {
var t = i[e]
return typeof t != 'string' && (t = String.fromCharCode(e)), t.toLowerCase()
})
}),
ace.define(
'ace/lib/event',
['require', 'exports', 'module', 'ace/lib/keys', 'ace/lib/useragent'],
function (e, t, n) {
'use strict'
function a() {
u = !1
try {
document.createComment('').addEventListener('test', function () {}, {
get passive() {
u = { passive: !1 }
},
})
} catch (e) {}
}
function f() {
return u == undefined && a(), u
}
function l(e, t, n) {
;(this.elem = e), (this.type = t), (this.callback = n)
}
function d(e, t, n) {
var u = p(t)
if (!i.isMac && s) {
t.getModifierState && (t.getModifierState('OS') || t.getModifierState('Win')) && (u |= 8)
if (s.altGr) {
if ((3 & u) == 3) return
s.altGr = 0
}
if (n === 18 || n === 17) {
var a = 'location' in t ? t.location : t.keyLocation
if (n === 17 && a === 1) s[n] == 1 && (o = t.timeStamp)
else if (n === 18 && u === 3 && a === 2) {
var f = t.timeStamp - o
f < 50 && (s.altGr = !0)
}
}
}
n in r.MODIFIER_KEYS && (n = -1)
if (!u && n === 13) {
var a = 'location' in t ? t.location : t.keyLocation
if (a === 3) {
e(t, u, -n)
if (t.defaultPrevented) return
}
}
if (i.isChromeOS && u & 8) {
e(t, u, n)
if (t.defaultPrevented) return
u &= -9
}
return !!u || n in r.FUNCTION_KEYS || n in r.PRINTABLE_KEYS ? e(t, u, n) : !1
}
function v() {
s = Object.create(null)
}
var r = e('./keys'),
i = e('./useragent'),
s = null,
o = 0,
u
l.prototype.destroy = function () {
h(this.elem, this.type, this.callback), (this.elem = this.type = this.callback = undefined)
}
var c = (t.addListener = function (e, t, n, r) {
e.addEventListener(t, n, f()), r && r.$toDestroy.push(new l(e, t, n))
}),
h = (t.removeListener = function (e, t, n) {
e.removeEventListener(t, n, f())
})
;(t.stopEvent = function (e) {
return t.stopPropagation(e), t.preventDefault(e), !1
}),
(t.stopPropagation = function (e) {
e.stopPropagation && e.stopPropagation()
}),
(t.preventDefault = function (e) {
e.preventDefault && e.preventDefault()
}),
(t.getButton = function (e) {
return e.type == 'dblclick'
? 0
: e.type == 'contextmenu' || (i.isMac && e.ctrlKey && !e.altKey && !e.shiftKey)
? 2
: e.button
}),
(t.capture = function (e, t, n) {
function i(e) {
t && t(e), n && n(e), h(r, 'mousemove', t), h(r, 'mouseup', i), h(r, 'dragstart', i)
}
var r = (e && e.ownerDocument) || document
return c(r, 'mousemove', t), c(r, 'mouseup', i), c(r, 'dragstart', i), i
}),
(t.addMouseWheelListener = function (e, t, n) {
'onmousewheel' in e
? c(
e,
'mousewheel',
function (e) {
var n = 8
e.wheelDeltaX !== undefined
? ((e.wheelX = -e.wheelDeltaX / n), (e.wheelY = -e.wheelDeltaY / n))
: ((e.wheelX = 0), (e.wheelY = -e.wheelDelta / n)),
t(e)
},
n
)
: 'onwheel' in e
? c(
e,
'wheel',
function (e) {
var n = 0.35
switch (e.deltaMode) {
case e.DOM_DELTA_PIXEL:
;(e.wheelX = e.deltaX * n || 0), (e.wheelY = e.deltaY * n || 0)
break
case e.DOM_DELTA_LINE:
case e.DOM_DELTA_PAGE:
;(e.wheelX = (e.deltaX || 0) * 5), (e.wheelY = (e.deltaY || 0) * 5)
}
t(e)
},
n
)
: c(
e,
'DOMMouseScroll',
function (e) {
e.axis && e.axis == e.HORIZONTAL_AXIS
? ((e.wheelX = (e.detail || 0) * 5), (e.wheelY = 0))
: ((e.wheelX = 0), (e.wheelY = (e.detail || 0) * 5)),
t(e)
},
n
)
}),
(t.addMultiMouseDownListener = function (e, n, r, s, o) {
function p(e) {
t.getButton(e) !== 0 ? (u = 0) : e.detail > 1 ? (u++, u > 4 && (u = 1)) : (u = 1)
if (i.isIE) {
var o = Math.abs(e.clientX - a) > 5 || Math.abs(e.clientY - f) > 5
if (!l || o) u = 1
l && clearTimeout(l),
(l = setTimeout(
function () {
l = null
},
n[u - 1] || 600
)),
u == 1 && ((a = e.clientX), (f = e.clientY))
}
;(e._clicks = u), r[s]('mousedown', e)
if (u > 4) u = 0
else if (u > 1) return r[s](h[u], e)
}
var u = 0,
a,
f,
l,
h = { 2: 'dblclick', 3: 'tripleclick', 4: 'quadclick' }
Array.isArray(e) || (e = [e]),
e.forEach(function (e) {
c(e, 'mousedown', p, o)
})
})
var p = function (e) {
return (
0 | (e.ctrlKey ? 1 : 0) | (e.altKey ? 2 : 0) | (e.shiftKey ? 4 : 0) | (e.metaKey ? 8 : 0)
)
}
;(t.getModifierString = function (e) {
return r.KEY_MODS[p(e)]
}),
(t.addCommandKeyListener = function (e, n, r) {
if (i.isOldGecko || (i.isOpera && !('KeyboardEvent' in window))) {
var o = null
c(
e,
'keydown',
function (e) {
o = e.keyCode
},
r
),
c(
e,
'keypress',
function (e) {
return d(n, e, o)
},
r
)
} else {
var u = null
c(
e,
'keydown',
function (e) {
s[e.keyCode] = (s[e.keyCode] || 0) + 1
var t = d(n, e, e.keyCode)
return (u = e.defaultPrevented), t
},
r
),
c(
e,
'keypress',
function (e) {
u &&
(e.ctrlKey || e.altKey || e.shiftKey || e.metaKey) &&
(t.stopEvent(e), (u = null))
},
r
),
c(
e,
'keyup',
function (e) {
s[e.keyCode] = null
},
r
),
s || (v(), c(window, 'focus', v))
}
})
if (typeof window == 'object' && window.postMessage && !i.isOldIE) {
var m = 1
t.nextTick = function (e, n) {
n = n || window
var r = 'zero-timeout-message-' + m++,
i = function (s) {
s.data == r && (t.stopPropagation(s), h(n, 'message', i), e())
}
c(n, 'message', i), n.postMessage(r, '*')
}
}
;(t.$idleBlocked = !1),
(t.onIdle = function (e, n) {
return setTimeout(function r() {
t.$idleBlocked ? setTimeout(r, 100) : e()
}, n)
}),
(t.$idleBlockId = null),
(t.blockIdle = function (e) {
t.$idleBlockId && clearTimeout(t.$idleBlockId),
(t.$idleBlocked = !0),
(t.$idleBlockId = setTimeout(function () {
t.$idleBlocked = !1
}, e || 100))
}),
(t.nextFrame =
typeof window == 'object' &&
(window.requestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.msRequestAnimationFrame ||
window.oRequestAnimationFrame)),
t.nextFrame
? (t.nextFrame = t.nextFrame.bind(window))
: (t.nextFrame = function (e) {
setTimeout(e, 17)
})
}
),
ace.define('ace/range', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
var r = function (e, t) {
return e.row - t.row || e.column - t.column
},
i = function (e, t, n, r) {
;(this.start = { row: e, column: t }), (this.end = { row: n, column: r })
}
;(function () {
;(this.isEqual = function (e) {
return (
this.start.row === e.start.row &&
this.end.row === e.end.row &&
this.start.column === e.start.column &&
this.end.column === e.end.column
)
}),
(this.toString = function () {
return (
'Range: [' +
this.start.row +
'/' +
this.start.column +
'] -> [' +
this.end.row +
'/' +
this.end.column +
']'
)
}),
(this.contains = function (e, t) {
return this.compare(e, t) == 0
}),
(this.compareRange = function (e) {
var t,
n = e.end,
r = e.start
return (
(t = this.compare(n.row, n.column)),
t == 1
? ((t = this.compare(r.row, r.column)), t == 1 ? 2 : t == 0 ? 1 : 0)
: t == -1
? -2
: ((t = this.compare(r.row, r.column)), t == -1 ? -1 : t == 1 ? 42 : 0)
)
}),
(this.comparePoint = function (e) {
return this.compare(e.row, e.column)
}),
(this.containsRange = function (e) {
return this.comparePoint(e.start) == 0 && this.comparePoint(e.end) == 0
}),
(this.intersects = function (e) {
var t = this.compareRange(e)
return t == -1 || t == 0 || t == 1
}),
(this.isEnd = function (e, t) {
return this.end.row == e && this.end.column == t
}),
(this.isStart = function (e, t) {
return this.start.row == e && this.start.column == t
}),
(this.setStart = function (e, t) {
typeof e == 'object'
? ((this.start.column = e.column), (this.start.row = e.row))
: ((this.start.row = e), (this.start.column = t))
}),
(this.setEnd = function (e, t) {
typeof e == 'object'
? ((this.end.column = e.column), (this.end.row = e.row))
: ((this.end.row = e), (this.end.column = t))
}),
(this.inside = function (e, t) {
return this.compare(e, t) == 0 ? (this.isEnd(e, t) || this.isStart(e, t) ? !1 : !0) : !1
}),
(this.insideStart = function (e, t) {
return this.compare(e, t) == 0 ? (this.isEnd(e, t) ? !1 : !0) : !1
}),
(this.insideEnd = function (e, t) {
return this.compare(e, t) == 0 ? (this.isStart(e, t) ? !1 : !0) : !1
}),
(this.compare = function (e, t) {
return !this.isMultiLine() && e === this.start.row
? t < this.start.column
? -1
: t > this.end.column
? 1
: 0
: e < this.start.row
? -1
: e > this.end.row
? 1
: this.start.row === e
? t >= this.start.column
? 0
: -1
: this.end.row === e
? t <= this.end.column
? 0
: 1
: 0
}),
(this.compareStart = function (e, t) {
return this.start.row == e && this.start.column == t ? -1 : this.compare(e, t)
}),
(this.compareEnd = function (e, t) {
return this.end.row == e && this.end.column == t ? 1 : this.compare(e, t)
}),
(this.compareInside = function (e, t) {
return this.end.row == e && this.end.column == t
? 1
: this.start.row == e && this.start.column == t
? -1
: this.compare(e, t)
}),
(this.clipRows = function (e, t) {
if (this.end.row > t) var n = { row: t + 1, column: 0 }
else if (this.end.row < e) var n = { row: e, column: 0 }
if (this.start.row > t) var r = { row: t + 1, column: 0 }
else if (this.start.row < e) var r = { row: e, column: 0 }
return i.fromPoints(r || this.start, n || this.end)
}),
(this.extend = function (e, t) {
var n = this.compare(e, t)
if (n == 0) return this
if (n == -1) var r = { row: e, column: t }
else var s = { row: e, column: t }
return i.fromPoints(r || this.start, s || this.end)
}),
(this.isEmpty = function () {
return this.start.row === this.end.row && this.start.column === this.end.column
}),
(this.isMultiLine = function () {
return this.start.row !== this.end.row
}),
(this.clone = function () {
return i.fromPoints(this.start, this.end)
}),
(this.collapseRows = function () {
return this.end.column == 0
? new i(this.start.row, 0, Math.max(this.start.row, this.end.row - 1), 0)
: new i(this.start.row, 0, this.end.row, 0)
}),
(this.toScreenRange = function (e) {
var t = e.documentToScreenPosition(this.start),
n = e.documentToScreenPosition(this.end)
return new i(t.row, t.column, n.row, n.column)
}),
(this.moveBy = function (e, t) {
;(this.start.row += e),
(this.start.column += t),
(this.end.row += e),
(this.end.column += t)
})
}).call(i.prototype),
(i.fromPoints = function (e, t) {
return new i(e.row, e.column, t.row, t.column)
}),
(i.comparePoints = r),
(i.comparePoints = function (e, t) {
return e.row - t.row || e.column - t.column
}),
(t.Range = i)
}),
ace.define('ace/lib/lang', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
;(t.last = function (e) {
return e[e.length - 1]
}),
(t.stringReverse = function (e) {
return e.split('').reverse().join('')
}),
(t.stringRepeat = function (e, t) {
var n = ''
while (t > 0) {
t & 1 && (n += e)
if ((t >>= 1)) e += e
}
return n
})
var r = /^\s\s*/,
i = /\s\s*$/
;(t.stringTrimLeft = function (e) {
return e.replace(r, '')
}),
(t.stringTrimRight = function (e) {
return e.replace(i, '')
}),
(t.copyObject = function (e) {
var t = {}
for (var n in e) t[n] = e[n]
return t
}),
(t.copyArray = function (e) {
var t = []
for (var n = 0, r = e.length; n < r; n++)
e[n] && typeof e[n] == 'object' ? (t[n] = this.copyObject(e[n])) : (t[n] = e[n])
return t
}),
(t.deepCopy = function s(e) {
if (typeof e != 'object' || !e) return e
var t
if (Array.isArray(e)) {
t = []
for (var n = 0; n < e.length; n++) t[n] = s(e[n])
return t
}
if (Object.prototype.toString.call(e) !== '[object Object]') return e
t = {}
for (var n in e) t[n] = s(e[n])
return t
}),
(t.arrayToMap = function (e) {
var t = {}
for (var n = 0; n < e.length; n++) t[e[n]] = 1
return t
}),
(t.createMap = function (e) {
var t = Object.create(null)
for (var n in e) t[n] = e[n]
return t
}),
(t.arrayRemove = function (e, t) {
for (var n = 0; n <= e.length; n++) t === e[n] && e.splice(n, 1)
}),
(t.escapeRegExp = function (e) {
return e.replace(/([.*+?^${}()|[\]\/\\])/g, '\\$1')
}),
(t.escapeHTML = function (e) {
return ('' + e)
.replace(/&/g, '&')
.replace(/"/g, '"')
.replace(/'/g, ''')
.replace(/ Date.now() - 50 ? !0 : (r = !1)
},
cancel: function () {
r = Date.now()
},
}
}),
ace.define(
'ace/keyboard/textinput',
[
'require',
'exports',
'module',
'ace/lib/event',
'ace/lib/useragent',
'ace/lib/dom',
'ace/lib/lang',
'ace/clipboard',
'ace/lib/keys',
],
function (e, t, n) {
'use strict'
var r = e('../lib/event'),
i = e('../lib/useragent'),
s = e('../lib/dom'),
o = e('../lib/lang'),
u = e('../clipboard'),
a = i.isChrome < 18,
f = i.isIE,
l = i.isChrome > 63,
c = 400,
h = e('../lib/keys'),
p = h.KEY_MODS,
d = i.isIOS,
v = d ? /\s/ : /\n/,
m = i.isMobile,
g = function (e, t) {
function X() {
;(x = !0), n.blur(), n.focus(), (x = !1)
}
function $(e) {
e.keyCode == 27 &&
n.value.length < n.selectionStart &&
(b || (T = n.value), (N = C = -1), O()),
V()
}
function K() {
clearTimeout(J),
(J = setTimeout(function () {
E && ((n.style.cssText = E), (E = '')),
(t.renderer.$isMousePressed = !1),
t.renderer.$keepTextAreaAtCursor && t.renderer.$moveTextAreaToCursor()
}, 0))
}
function G(e, t, n) {
var r = null,
i = !1
n.addEventListener(
'keydown',
function (e) {
r && clearTimeout(r), (i = !0)
},
!0
),
n.addEventListener(
'keyup',
function (e) {
r = setTimeout(function () {
i = !1
}, 100)
},
!0
)
var s = function (e) {
if (document.activeElement !== n) return
if (i || b || t.$mouseHandler.isMousePressed) return
if (g) return
var r = n.selectionStart,
s = n.selectionEnd,
o = null,
u = 0
if (r == 0) o = h.up
else if (r == 1) o = h.home
else if (s > C && T[s] == '\n') o = h.end
else if (r < N && T[r - 1] == ' ') (o = h.left), (u = p.option)
else if (r < N || (r == N && C != N && r == s)) o = h.left
else if (s > C && T.slice(0, s).split('\n').length > 2) o = h.down
else if (s > C && T[s - 1] == ' ') (o = h.right), (u = p.option)
else if (s > C || (s == C && C != N && r == s)) o = h.right
r !== s && (u |= p.shift)
if (o) {
var a = t.onCommandKey({}, u, o)
if (!a && t.commands) {
o = h.keyCodeToString(o)
var f = t.commands.findKeyCommand(u, o)
f && t.execCommand(f)
}
;(N = r), (C = s), O('')
}
}
document.addEventListener('selectionchange', s),
t.on('destroy', function () {
document.removeEventListener('selectionchange', s)
})
}
var n = s.createElement('textarea')
;(n.className = 'ace_text-input'),
n.setAttribute('wrap', 'off'),
n.setAttribute('autocorrect', 'off'),
n.setAttribute('autocapitalize', 'off'),
n.setAttribute('spellcheck', !1),
(n.style.opacity = '0'),
e.insertBefore(n, e.firstChild)
var g = !1,
y = !1,
b = !1,
w = !1,
E = ''
m || (n.style.fontSize = '1px')
var S = !1,
x = !1,
T = '',
N = 0,
C = 0,
k = 0
try {
var L = document.activeElement === n
} catch (A) {}
r.addListener(
n,
'blur',
function (e) {
if (x) return
t.onBlur(e), (L = !1)
},
t
),
r.addListener(
n,
'focus',
function (e) {
if (x) return
L = !0
if (i.isEdge)
try {
if (!document.hasFocus()) return
} catch (e) {}
t.onFocus(e), i.isEdge ? setTimeout(O) : O()
},
t
),
(this.$focusScroll = !1),
(this.focus = function () {
if (E || l || this.$focusScroll == 'browser') return n.focus({ preventScroll: !0 })
var e = n.style.top
;(n.style.position = 'fixed'), (n.style.top = '0px')
try {
var t = n.getBoundingClientRect().top != 0
} catch (r) {
return
}
var i = []
if (t) {
var s = n.parentElement
while (s && s.nodeType == 1)
i.push(s),
s.setAttribute('ace_nocontext', !0),
!s.parentElement && s.getRootNode
? (s = s.getRootNode().host)
: (s = s.parentElement)
}
n.focus({ preventScroll: !0 }),
t &&
i.forEach(function (e) {
e.removeAttribute('ace_nocontext')
}),
setTimeout(function () {
;(n.style.position = ''), n.style.top == '0px' && (n.style.top = e)
}, 0)
}),
(this.blur = function () {
n.blur()
}),
(this.isFocused = function () {
return L
}),
t.on('beforeEndOperation', function () {
var e = t.curOp,
r = e && e.command && e.command.name
if (r == 'insertstring') return
var i = r && (e.docChanged || e.selectionChanged)
b && i && ((T = n.value = ''), W()), O()
})
var O = d
? function (e) {
if (!L || (g && !e) || w) return
e || (e = '')
var r = '\n ab' + e + 'cde fg\n'
r != n.value && (n.value = T = r)
var i = 4,
s = 4 + (e.length || (t.selection.isEmpty() ? 0 : 1))
;(N != i || C != s) && n.setSelectionRange(i, s), (N = i), (C = s)
}
: function () {
if (b || w) return
if (!L && !P) return
b = !0
var e = 0,
r = 0,
i = ''
if (t.session) {
var s = t.selection,
o = s.getRange(),
u = s.cursor.row
;(e = o.start.column), (r = o.end.column), (i = t.session.getLine(u))
if (o.start.row != u) {
var a = t.session.getLine(u - 1)
;(e = o.start.row < u - 1 ? 0 : e), (r += a.length + 1), (i = a + '\n' + i)
} else if (o.end.row != u) {
var f = t.session.getLine(u + 1)
;(r = o.end.row > u + 1 ? f.length : r), (r += i.length + 1), (i = i + '\n' + f)
} else m && u > 0 && ((i = '\n' + i), (r += 1), (e += 1))
i.length > c &&
(e < c && r < c
? (i = i.slice(0, c))
: ((i = '\n'), e == r ? (e = r = 0) : ((e = 0), (r = 1))))
}
var l = i + '\n\n'
l != T && ((n.value = T = l), (N = C = l.length)),
P && ((N = n.selectionStart), (C = n.selectionEnd))
if (C != r || N != e || n.selectionEnd != C)
try {
n.setSelectionRange(e, r), (N = e), (C = r)
} catch (h) {}
b = !1
}
;(this.resetSelection = O), L && t.onFocus()
var M = function (e) {
return (
e.selectionStart === 0 &&
e.selectionEnd >= T.length &&
e.value === T &&
T &&
e.selectionEnd !== C
)
},
_ = function (e) {
if (b) return
g ? (g = !1) : M(n) ? (t.selectAll(), O()) : m && n.selectionStart != N && O()
},
D = null
;(this.setInputHandler = function (e) {
D = e
}),
(this.getInputHandler = function () {
return D
})
var P = !1,
H = function (e, r) {
P && (P = !1)
if (y) return O(), e && t.onPaste(e), (y = !1), ''
var s = n.selectionStart,
o = n.selectionEnd,
u = N,
a = T.length - C,
f = e,
l = e.length - s,
c = e.length - o,
h = 0
while (u > 0 && T[h] == e[h]) h++, u--
;(f = f.slice(h)), (h = 1)
while (a > 0 && T.length - h > N - 1 && T[T.length - h] == e[e.length - h]) h++, a--
;(l -= h - 1), (c -= h - 1)
var p = f.length - h + 1
p < 0 && ((u = -p), (p = 0)), (f = f.slice(0, p))
if (!r && !f && !l && !u && !a && !c) return ''
w = !0
var d = !1
return (
i.isAndroid && f == '. ' && ((f = ' '), (d = !0)),
(f && !u && !a && !l && !c) || S
? t.onTextInput(f)
: t.onTextInput(f, {
extendLeft: u,
extendRight: a,
restoreStart: l,
restoreEnd: c,
}),
(w = !1),
(T = e),
(N = s),
(C = o),
(k = c),
d ? '\n' : f
)
},
B = function (e) {
if (b) return z()
if (e && e.inputType) {
if (e.inputType == 'historyUndo') return t.execCommand('undo')
if (e.inputType == 'historyRedo') return t.execCommand('redo')
}
var r = n.value,
i = H(r, !0)
;(r.length > c + 100 || v.test(i) || (m && N < 1 && N == C)) && O()
},
j = function (e, t, n) {
var r = e.clipboardData || window.clipboardData
if (!r || a) return
var i = f || n ? 'Text' : 'text/plain'
try {
return t ? r.setData(i, t) !== !1 : r.getData(i)
} catch (e) {
if (!n) return j(e, t, !0)
}
},
F = function (e, i) {
var s = t.getCopyText()
if (!s) return r.preventDefault(e)
j(e, s)
? (d &&
(O(s),
(g = s),
setTimeout(function () {
g = !1
}, 10)),
i ? t.onCut() : t.onCopy(),
r.preventDefault(e))
: ((g = !0),
(n.value = s),
n.select(),
setTimeout(function () {
;(g = !1), O(), i ? t.onCut() : t.onCopy()
}))
},
I = function (e) {
F(e, !0)
},
q = function (e) {
F(e, !1)
},
R = function (e) {
var s = j(e)
if (u.pasteCancelled()) return
typeof s == 'string'
? (s && t.onPaste(s, e), i.isIE && setTimeout(O), r.preventDefault(e))
: ((n.value = ''), (y = !0))
}
r.addCommandKeyListener(n, t.onCommandKey.bind(t), t),
r.addListener(n, 'select', _, t),
r.addListener(n, 'input', B, t),
r.addListener(n, 'cut', I, t),
r.addListener(n, 'copy', q, t),
r.addListener(n, 'paste', R, t),
(!('oncut' in n) || !('oncopy' in n) || !('onpaste' in n)) &&
r.addListener(
e,
'keydown',
function (e) {
if ((i.isMac && !e.metaKey) || !e.ctrlKey) return
switch (e.keyCode) {
case 67:
q(e)
break
case 86:
R(e)
break
case 88:
I(e)
}
},
t
)
var U = function (e) {
if (b || !t.onCompositionStart || t.$readOnly) return
b = {}
if (S) return
e.data && (b.useTextareaForIME = !1),
setTimeout(z, 0),
t._signal('compositionStart'),
t.on('mousedown', X)
var r = t.getSelectionRange()
;(r.end.row = r.start.row),
(r.end.column = r.start.column),
(b.markerRange = r),
(b.selectionStart = N),
t.onCompositionStart(b),
b.useTextareaForIME
? ((T = n.value = ''), (N = 0), (C = 0))
: (n.msGetInputContext && (b.context = n.msGetInputContext()),
n.getInputContext && (b.context = n.getInputContext()))
},
z = function () {
if (!b || !t.onCompositionUpdate || t.$readOnly) return
if (S) return X()
if (b.useTextareaForIME) t.onCompositionUpdate(n.value)
else {
var e = n.value
H(e),
b.markerRange &&
(b.context &&
(b.markerRange.start.column = b.selectionStart =
b.context.compositionStartOffset),
(b.markerRange.end.column =
b.markerRange.start.column + C - b.selectionStart + k))
}
},
W = function (e) {
if (!t.onCompositionEnd || t.$readOnly) return
;(b = !1), t.onCompositionEnd(), t.off('mousedown', X), e && B()
},
V = o.delayedCall(z, 50).schedule.bind(null, null)
r.addListener(n, 'compositionstart', U, t),
r.addListener(n, 'compositionupdate', z, t),
r.addListener(n, 'keyup', $, t),
r.addListener(n, 'keydown', V, t),
r.addListener(n, 'compositionend', W, t),
(this.getElement = function () {
return n
}),
(this.setCommandMode = function (e) {
;(S = e), (n.readOnly = !1)
}),
(this.setReadOnly = function (e) {
S || (n.readOnly = e)
}),
(this.setCopyWithEmptySelection = function (e) {}),
(this.onContextMenu = function (e) {
;(P = !0),
O(),
t._emit('nativecontextmenu', { target: t, domEvent: e }),
this.moveToMouse(e, !0)
}),
(this.moveToMouse = function (e, o) {
E || (E = n.style.cssText),
(n.style.cssText =
(o ? 'z-index:100000;' : '') +
(i.isIE ? 'opacity:0.1;' : '') +
'text-indent: -' +
(N + C) * t.renderer.characterWidth * 0.5 +
'px;')
var u = t.container.getBoundingClientRect(),
a = s.computedStyle(t.container),
f = u.top + (parseInt(a.borderTopWidth) || 0),
l = u.left + (parseInt(u.borderLeftWidth) || 0),
c = u.bottom - f - n.clientHeight - 2,
h = function (e) {
s.translate(n, e.clientX - l - 2, Math.min(e.clientY - f - 2, c))
}
h(e)
if (e.type != 'mousedown') return
;(t.renderer.$isMousePressed = !0),
clearTimeout(J),
i.isWin && r.capture(t.container, h, K)
}),
(this.onContextMenuClose = K)
var J,
Q = function (e) {
t.textInput.onContextMenu(e), K()
}
r.addListener(n, 'mouseup', Q, t),
r.addListener(
n,
'mousedown',
function (e) {
e.preventDefault(), K()
},
t
),
r.addListener(t.renderer.scroller, 'contextmenu', Q, t),
r.addListener(n, 'contextmenu', Q, t),
d && G(e, t, n)
}
;(t.TextInput = g),
(t.$setUserAgentForTests = function (e, t) {
;(m = e), (d = t)
})
}
),
ace.define(
'ace/mouse/default_handlers',
['require', 'exports', 'module', 'ace/lib/useragent'],
function (e, t, n) {
'use strict'
function o(e) {
e.$clickSelection = null
var t = e.editor
t.setDefaultHandler('mousedown', this.onMouseDown.bind(e)),
t.setDefaultHandler('dblclick', this.onDoubleClick.bind(e)),
t.setDefaultHandler('tripleclick', this.onTripleClick.bind(e)),
t.setDefaultHandler('quadclick', this.onQuadClick.bind(e)),
t.setDefaultHandler('mousewheel', this.onMouseWheel.bind(e))
var n = [
'select',
'startSelect',
'selectEnd',
'selectAllEnd',
'selectByWordsEnd',
'selectByLinesEnd',
'dragWait',
'dragWaitEnd',
'focusWait',
]
n.forEach(function (t) {
e[t] = this[t]
}, this),
(e.selectByLines = this.extendSelectionBy.bind(e, 'getLineRange')),
(e.selectByWords = this.extendSelectionBy.bind(e, 'getWordRange'))
}
function u(e, t, n, r) {
return Math.sqrt(Math.pow(n - e, 2) + Math.pow(r - t, 2))
}
function a(e, t) {
if (e.start.row == e.end.row) var n = 2 * t.column - e.start.column - e.end.column
else if (e.start.row == e.end.row - 1 && !e.start.column && !e.end.column)
var n = t.column - 4
else var n = 2 * t.row - e.start.row - e.end.row
return n < 0 ? { cursor: e.start, anchor: e.end } : { cursor: e.end, anchor: e.start }
}
var r = e('../lib/useragent'),
i = 0,
s = 550
;(function () {
;(this.onMouseDown = function (e) {
var t = e.inSelection(),
n = e.getDocumentPosition()
this.mousedownEvent = e
var i = this.editor,
s = e.getButton()
if (s !== 0) {
var o = i.getSelectionRange(),
u = o.isEmpty()
;(u || s == 1) && i.selection.moveToPosition(n),
s == 2 && (i.textInput.onContextMenu(e.domEvent), r.isMozilla || e.preventDefault())
return
}
this.mousedownEvent.time = Date.now()
if (t && !i.isFocused()) {
i.focus()
if (this.$focusTimeout && !this.$clickSelection && !i.inMultiSelectMode) {
this.setState('focusWait'), this.captureMouse(e)
return
}
}
return (
this.captureMouse(e), this.startSelect(n, e.domEvent._clicks > 1), e.preventDefault()
)
}),
(this.startSelect = function (e, t) {
e = e || this.editor.renderer.screenToTextCoordinates(this.x, this.y)
var n = this.editor
if (!this.mousedownEvent) return
this.mousedownEvent.getShiftKey()
? n.selection.selectToPosition(e)
: t || n.selection.moveToPosition(e),
t || this.select(),
n.renderer.scroller.setCapture && n.renderer.scroller.setCapture(),
n.setStyle('ace_selecting'),
this.setState('select')
}),
(this.select = function () {
var e,
t = this.editor,
n = t.renderer.screenToTextCoordinates(this.x, this.y)
if (this.$clickSelection) {
var r = this.$clickSelection.comparePoint(n)
if (r == -1) e = this.$clickSelection.end
else if (r == 1) e = this.$clickSelection.start
else {
var i = a(this.$clickSelection, n)
;(n = i.cursor), (e = i.anchor)
}
t.selection.setSelectionAnchor(e.row, e.column)
}
t.selection.selectToPosition(n), t.renderer.scrollCursorIntoView()
}),
(this.extendSelectionBy = function (e) {
var t,
n = this.editor,
r = n.renderer.screenToTextCoordinates(this.x, this.y),
i = n.selection[e](r.row, r.column)
if (this.$clickSelection) {
var s = this.$clickSelection.comparePoint(i.start),
o = this.$clickSelection.comparePoint(i.end)
if (s == -1 && o <= 0) {
t = this.$clickSelection.end
if (i.end.row != r.row || i.end.column != r.column) r = i.start
} else if (o == 1 && s >= 0) {
t = this.$clickSelection.start
if (i.start.row != r.row || i.start.column != r.column) r = i.end
} else if (s == -1 && o == 1) (r = i.end), (t = i.start)
else {
var u = a(this.$clickSelection, r)
;(r = u.cursor), (t = u.anchor)
}
n.selection.setSelectionAnchor(t.row, t.column)
}
n.selection.selectToPosition(r), n.renderer.scrollCursorIntoView()
}),
(this.selectEnd =
this.selectAllEnd =
this.selectByWordsEnd =
this.selectByLinesEnd =
function () {
;(this.$clickSelection = null),
this.editor.unsetStyle('ace_selecting'),
this.editor.renderer.scroller.releaseCapture &&
this.editor.renderer.scroller.releaseCapture()
}),
(this.focusWait = function () {
var e = u(this.mousedownEvent.x, this.mousedownEvent.y, this.x, this.y),
t = Date.now()
;(e > i || t - this.mousedownEvent.time > this.$focusTimeout) &&
this.startSelect(this.mousedownEvent.getDocumentPosition())
}),
(this.onDoubleClick = function (e) {
var t = e.getDocumentPosition(),
n = this.editor,
r = n.session,
i = r.getBracketRange(t)
i
? (i.isEmpty() && (i.start.column--, i.end.column++), this.setState('select'))
: ((i = n.selection.getWordRange(t.row, t.column)), this.setState('selectByWords')),
(this.$clickSelection = i),
this.select()
}),
(this.onTripleClick = function (e) {
var t = e.getDocumentPosition(),
n = this.editor
this.setState('selectByLines')
var r = n.getSelectionRange()
r.isMultiLine() && r.contains(t.row, t.column)
? ((this.$clickSelection = n.selection.getLineRange(r.start.row)),
(this.$clickSelection.end = n.selection.getLineRange(r.end.row).end))
: (this.$clickSelection = n.selection.getLineRange(t.row)),
this.select()
}),
(this.onQuadClick = function (e) {
var t = this.editor
t.selectAll(),
(this.$clickSelection = t.getSelectionRange()),
this.setState('selectAll')
}),
(this.onMouseWheel = function (e) {
if (e.getAccelKey()) return
e.getShiftKey() && e.wheelY && !e.wheelX && ((e.wheelX = e.wheelY), (e.wheelY = 0))
var t = this.editor
this.$lastScroll || (this.$lastScroll = { t: 0, vx: 0, vy: 0, allowed: 0 })
var n = this.$lastScroll,
r = e.domEvent.timeStamp,
i = r - n.t,
o = i ? e.wheelX / i : n.vx,
u = i ? e.wheelY / i : n.vy
i < s && ((o = (o + n.vx) / 2), (u = (u + n.vy) / 2))
var a = Math.abs(o / u),
f = !1
a >= 1 && t.renderer.isScrollableBy(e.wheelX * e.speed, 0) && (f = !0),
a <= 1 && t.renderer.isScrollableBy(0, e.wheelY * e.speed) && (f = !0)
if (f) n.allowed = r
else if (r - n.allowed < s) {
var l = Math.abs(o) <= 1.5 * Math.abs(n.vx) && Math.abs(u) <= 1.5 * Math.abs(n.vy)
l ? ((f = !0), (n.allowed = r)) : (n.allowed = 0)
}
;(n.t = r), (n.vx = o), (n.vy = u)
if (f) return t.renderer.scrollBy(e.wheelX * e.speed, e.wheelY * e.speed), e.stop()
})
}).call(o.prototype),
(t.DefaultHandlers = o)
}
),
ace.define(
'ace/tooltip',
['require', 'exports', 'module', 'ace/lib/oop', 'ace/lib/dom'],
function (e, t, n) {
'use strict'
function s(e) {
;(this.isOpen = !1), (this.$element = null), (this.$parentNode = e)
}
var r = e('./lib/oop'),
i = e('./lib/dom')
;(function () {
;(this.$init = function () {
return (
(this.$element = i.createElement('div')),
(this.$element.className = 'ace_tooltip'),
(this.$element.style.display = 'none'),
this.$parentNode.appendChild(this.$element),
this.$element
)
}),
(this.getElement = function () {
return this.$element || this.$init()
}),
(this.setText = function (e) {
this.getElement().textContent = e
}),
(this.setHtml = function (e) {
this.getElement().innerHTML = e
}),
(this.setPosition = function (e, t) {
;(this.getElement().style.left = e + 'px'), (this.getElement().style.top = t + 'px')
}),
(this.setClassName = function (e) {
i.addCssClass(this.getElement(), e)
}),
(this.show = function (e, t, n) {
e != null && this.setText(e),
t != null && n != null && this.setPosition(t, n),
this.isOpen || ((this.getElement().style.display = 'block'), (this.isOpen = !0))
}),
(this.hide = function () {
this.isOpen && ((this.getElement().style.display = 'none'), (this.isOpen = !1))
}),
(this.getHeight = function () {
return this.getElement().offsetHeight
}),
(this.getWidth = function () {
return this.getElement().offsetWidth
}),
(this.destroy = function () {
;(this.isOpen = !1),
this.$element &&
this.$element.parentNode &&
this.$element.parentNode.removeChild(this.$element)
})
}).call(s.prototype),
(t.Tooltip = s)
}
),
ace.define(
'ace/mouse/default_gutter_handler',
['require', 'exports', 'module', 'ace/lib/dom', 'ace/lib/oop', 'ace/lib/event', 'ace/tooltip'],
function (e, t, n) {
'use strict'
function u(e) {
function l() {
var r = u.getDocumentPosition().row,
s = n.$annotations[r]
if (!s) return c()
var o = t.session.getLength()
if (r == o) {
var a = t.renderer.pixelToScreenCoordinates(0, u.y).row,
l = u.$pos
if (a > t.session.documentToScreenRow(l.row, l.column)) return c()
}
if (f == s) return
;(f = s.text.join('
')),
i.setHtml(f),
i.show(),
t._signal('showGutterTooltip', i),
t.on('mousewheel', c)
if (e.$tooltipFollowsMouse) h(u)
else {
var p = u.domEvent.target,
d = p.getBoundingClientRect(),
v = i.getElement().style
;(v.left = d.right + 'px'), (v.top = d.bottom + 'px')
}
}
function c() {
o && (o = clearTimeout(o)),
f && (i.hide(), (f = null), t._signal('hideGutterTooltip', i), t.off('mousewheel', c))
}
function h(e) {
i.setPosition(e.x, e.y)
}
var t = e.editor,
n = t.renderer.$gutterLayer,
i = new a(t.container)
e.editor.setDefaultHandler('guttermousedown', function (r) {
if (!t.isFocused() || r.getButton() != 0) return
var i = n.getRegion(r)
if (i == 'foldWidgets') return
var s = r.getDocumentPosition().row,
o = t.session.selection
if (r.getShiftKey()) o.selectTo(s, 0)
else {
if (r.domEvent.detail == 2) return t.selectAll(), r.preventDefault()
e.$clickSelection = t.selection.getLineRange(s)
}
return e.setState('selectByLines'), e.captureMouse(r), r.preventDefault()
})
var o, u, f
e.editor.setDefaultHandler('guttermousemove', function (t) {
var n = t.domEvent.target || t.domEvent.srcElement
if (r.hasCssClass(n, 'ace_fold-widget')) return c()
f && e.$tooltipFollowsMouse && h(t), (u = t)
if (o) return
o = setTimeout(function () {
;(o = null), u && !e.isMousePressed ? l() : c()
}, 50)
}),
s.addListener(
t.renderer.$gutter,
'mouseout',
function (e) {
u = null
if (!f || o) return
o = setTimeout(function () {
;(o = null), c()
}, 50)
},
t
),
t.on('changeSession', c)
}
function a(e) {
o.call(this, e)
}
var r = e('../lib/dom'),
i = e('../lib/oop'),
s = e('../lib/event'),
o = e('../tooltip').Tooltip
i.inherits(a, o),
function () {
this.setPosition = function (e, t) {
var n = window.innerWidth || document.documentElement.clientWidth,
r = window.innerHeight || document.documentElement.clientHeight,
i = this.getWidth(),
s = this.getHeight()
;(e += 15),
(t += 15),
e + i > n && (e -= e + i - n),
t + s > r && (t -= 20 + s),
o.prototype.setPosition.call(this, e, t)
}
}.call(a.prototype),
(t.GutterHandler = u)
}
),
ace.define(
'ace/mouse/mouse_event',
['require', 'exports', 'module', 'ace/lib/event', 'ace/lib/useragent'],
function (e, t, n) {
'use strict'
var r = e('../lib/event'),
i = e('../lib/useragent'),
s = (t.MouseEvent = function (e, t) {
;(this.domEvent = e),
(this.editor = t),
(this.x = this.clientX = e.clientX),
(this.y = this.clientY = e.clientY),
(this.$pos = null),
(this.$inSelection = null),
(this.propagationStopped = !1),
(this.defaultPrevented = !1)
})
;(function () {
;(this.stopPropagation = function () {
r.stopPropagation(this.domEvent), (this.propagationStopped = !0)
}),
(this.preventDefault = function () {
r.preventDefault(this.domEvent), (this.defaultPrevented = !0)
}),
(this.stop = function () {
this.stopPropagation(), this.preventDefault()
}),
(this.getDocumentPosition = function () {
return this.$pos
? this.$pos
: ((this.$pos = this.editor.renderer.screenToTextCoordinates(
this.clientX,
this.clientY
)),
this.$pos)
}),
(this.inSelection = function () {
if (this.$inSelection !== null) return this.$inSelection
var e = this.editor,
t = e.getSelectionRange()
if (t.isEmpty()) this.$inSelection = !1
else {
var n = this.getDocumentPosition()
this.$inSelection = t.contains(n.row, n.column)
}
return this.$inSelection
}),
(this.getButton = function () {
return r.getButton(this.domEvent)
}),
(this.getShiftKey = function () {
return this.domEvent.shiftKey
}),
(this.getAccelKey = i.isMac
? function () {
return this.domEvent.metaKey
}
: function () {
return this.domEvent.ctrlKey
})
}).call(s.prototype)
}
),
ace.define(
'ace/mouse/dragdrop_handler',
['require', 'exports', 'module', 'ace/lib/dom', 'ace/lib/event', 'ace/lib/useragent'],
function (e, t, n) {
'use strict'
function f(e) {
function T(e, n) {
var r = Date.now(),
i = !n || e.row != n.row,
s = !n || e.column != n.column
if (!S || i || s) t.moveCursorToPosition(e), (S = r), (x = { x: p, y: d })
else {
var o = l(x.x, x.y, p, d)
o > a ? (S = null) : r - S >= u && (t.renderer.scrollCursorIntoView(), (S = null))
}
}
function N(e, n) {
var r = Date.now(),
i = t.renderer.layerConfig.lineHeight,
s = t.renderer.layerConfig.characterWidth,
u = t.renderer.scroller.getBoundingClientRect(),
a = {
x: { left: p - u.left, right: u.right - p },
y: { top: d - u.top, bottom: u.bottom - d },
},
f = Math.min(a.x.left, a.x.right),
l = Math.min(a.y.top, a.y.bottom),
c = { row: e.row, column: e.column }
f / s <= 2 && (c.column += a.x.left < a.x.right ? -3 : 2),
l / i <= 1 && (c.row += a.y.top < a.y.bottom ? -1 : 1)
var h = e.row != c.row,
v = e.column != c.column,
m = !n || e.row != n.row
h || (v && !m)
? E
? r - E >= o && t.renderer.scrollCursorIntoView(c)
: (E = r)
: (E = null)
}
function C() {
var e = g
;(g = t.renderer.screenToTextCoordinates(p, d)), T(g, e), N(g, e)
}
function k() {
;(m = t.selection.toOrientedRange()),
(h = t.session.addMarker(m, 'ace_selection', t.getSelectionStyle())),
t.clearSelection(),
t.isFocused() && t.renderer.$cursorLayer.setBlinking(!1),
clearInterval(v),
C(),
(v = setInterval(C, 20)),
(y = 0),
i.addListener(document, 'mousemove', O)
}
function L() {
clearInterval(v),
t.session.removeMarker(h),
(h = null),
t.selection.fromOrientedRange(m),
t.isFocused() && !w && t.$resetCursorStyle(),
(m = null),
(g = null),
(y = 0),
(E = null),
(S = null),
i.removeListener(document, 'mousemove', O)
}
function O() {
A == null &&
(A = setTimeout(function () {
A != null && h && L()
}, 20))
}
function M(e) {
var t = e.types
return (
!t ||
Array.prototype.some.call(t, function (e) {
return e == 'text/plain' || e == 'Text'
})
)
}
function _(e) {
var t = ['copy', 'copymove', 'all', 'uninitialized'],
n = ['move', 'copymove', 'linkmove', 'all', 'uninitialized'],
r = s.isMac ? e.altKey : e.ctrlKey,
i = 'uninitialized'
try {
i = e.dataTransfer.effectAllowed.toLowerCase()
} catch (e) {}
var o = 'none'
return (
r && t.indexOf(i) >= 0
? (o = 'copy')
: n.indexOf(i) >= 0
? (o = 'move')
: t.indexOf(i) >= 0 && (o = 'copy'),
o
)
}
var t = e.editor,
n = r.createElement('img')
;(n.src = 'data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=='),
s.isOpera &&
(n.style.cssText =
'width:1px;height:1px;position:fixed;top:0;left:0;z-index:2147483647;opacity:0;')
var f = ['dragWait', 'dragWaitEnd', 'startDrag', 'dragReadyEnd', 'onMouseDrag']
f.forEach(function (t) {
e[t] = this[t]
}, this),
t.on('mousedown', this.onMouseDown.bind(e))
var c = t.container,
h,
p,
d,
v,
m,
g,
y = 0,
b,
w,
E,
S,
x
;(this.onDragStart = function (e) {
if (this.cancelDrag || !c.draggable) {
var r = this
return (
setTimeout(function () {
r.startSelect(), r.captureMouse(e)
}, 0),
e.preventDefault()
)
}
m = t.getSelectionRange()
var i = e.dataTransfer
;(i.effectAllowed = t.getReadOnly() ? 'copy' : 'copyMove'),
s.isOpera && (t.container.appendChild(n), (n.scrollTop = 0)),
i.setDragImage && i.setDragImage(n, 0, 0),
s.isOpera && t.container.removeChild(n),
i.clearData(),
i.setData('Text', t.session.getTextRange()),
(w = !0),
this.setState('drag')
}),
(this.onDragEnd = function (e) {
;(c.draggable = !1), (w = !1), this.setState(null)
if (!t.getReadOnly()) {
var n = e.dataTransfer.dropEffect
!b && n == 'move' && t.session.remove(t.getSelectionRange()), t.$resetCursorStyle()
}
this.editor.unsetStyle('ace_dragging'), this.editor.renderer.setCursorStyle('')
}),
(this.onDragEnter = function (e) {
if (t.getReadOnly() || !M(e.dataTransfer)) return
return (
(p = e.clientX),
(d = e.clientY),
h || k(),
y++,
(e.dataTransfer.dropEffect = b = _(e)),
i.preventDefault(e)
)
}),
(this.onDragOver = function (e) {
if (t.getReadOnly() || !M(e.dataTransfer)) return
return (
(p = e.clientX),
(d = e.clientY),
h || (k(), y++),
A !== null && (A = null),
(e.dataTransfer.dropEffect = b = _(e)),
i.preventDefault(e)
)
}),
(this.onDragLeave = function (e) {
y--
if (y <= 0 && h) return L(), (b = null), i.preventDefault(e)
}),
(this.onDrop = function (e) {
if (!g) return
var n = e.dataTransfer
if (w)
switch (b) {
case 'move':
m.contains(g.row, g.column) ? (m = { start: g, end: g }) : (m = t.moveText(m, g))
break
case 'copy':
m = t.moveText(m, g, !0)
}
else {
var r = n.getData('Text')
;(m = { start: g, end: t.session.insert(g, r) }), t.focus(), (b = null)
}
return L(), i.preventDefault(e)
}),
i.addListener(c, 'dragstart', this.onDragStart.bind(e), t),
i.addListener(c, 'dragend', this.onDragEnd.bind(e), t),
i.addListener(c, 'dragenter', this.onDragEnter.bind(e), t),
i.addListener(c, 'dragover', this.onDragOver.bind(e), t),
i.addListener(c, 'dragleave', this.onDragLeave.bind(e), t),
i.addListener(c, 'drop', this.onDrop.bind(e), t)
var A = null
}
function l(e, t, n, r) {
return Math.sqrt(Math.pow(n - e, 2) + Math.pow(r - t, 2))
}
var r = e('../lib/dom'),
i = e('../lib/event'),
s = e('../lib/useragent'),
o = 200,
u = 200,
a = 5
;(function () {
;(this.dragWait = function () {
var e = Date.now() - this.mousedownEvent.time
e > this.editor.getDragDelay() && this.startDrag()
}),
(this.dragWaitEnd = function () {
var e = this.editor.container
;(e.draggable = !1),
this.startSelect(this.mousedownEvent.getDocumentPosition()),
this.selectEnd()
}),
(this.dragReadyEnd = function (e) {
this.editor.$resetCursorStyle(),
this.editor.unsetStyle('ace_dragging'),
this.editor.renderer.setCursorStyle(''),
this.dragWaitEnd()
}),
(this.startDrag = function () {
this.cancelDrag = !1
var e = this.editor,
t = e.container
;(t.draggable = !0), e.renderer.$cursorLayer.setBlinking(!1), e.setStyle('ace_dragging')
var n = s.isWin ? 'default' : 'move'
e.renderer.setCursorStyle(n), this.setState('dragReady')
}),
(this.onMouseDrag = function (e) {
var t = this.editor.container
if (s.isIE && this.state == 'dragReady') {
var n = l(this.mousedownEvent.x, this.mousedownEvent.y, this.x, this.y)
n > 3 && t.dragDrop()
}
if (this.state === 'dragWait') {
var n = l(this.mousedownEvent.x, this.mousedownEvent.y, this.x, this.y)
n > 0 &&
((t.draggable = !1), this.startSelect(this.mousedownEvent.getDocumentPosition()))
}
}),
(this.onMouseDown = function (e) {
if (!this.$dragEnabled) return
this.mousedownEvent = e
var t = this.editor,
n = e.inSelection(),
r = e.getButton(),
i = e.domEvent.detail || 1
if (i === 1 && r === 0 && n) {
if (e.editor.inMultiSelectMode && (e.getAccelKey() || e.getShiftKey())) return
this.mousedownEvent.time = Date.now()
var o = e.domEvent.target || e.domEvent.srcElement
'unselectable' in o && (o.unselectable = 'on')
if (t.getDragDelay()) {
if (s.isWebKit) {
this.cancelDrag = !0
var u = t.container
u.draggable = !0
}
this.setState('dragWait')
} else this.startDrag()
this.captureMouse(e, this.onMouseDrag.bind(this)), (e.defaultPrevented = !0)
}
})
}).call(f.prototype),
(t.DragdropHandler = f)
}
),
ace.define(
'ace/mouse/touch_handler',
['require', 'exports', 'module', 'ace/mouse/mouse_event', 'ace/lib/event', 'ace/lib/dom'],
function (e, t, n) {
'use strict'
var r = e('./mouse_event').MouseEvent,
i = e('../lib/event'),
s = e('../lib/dom')
t.addTouchListeners = function (e, t) {
function b() {
var e = window.navigator && window.navigator.clipboard,
r = !1,
i = function () {
var n = t.getCopyText(),
i = t.session.getUndoManager().hasUndo()
y.replaceChild(
s.buildDom(
r
? [
'span',
!n && [
'span',
{ class: 'ace_mobile-button', action: 'selectall' },
'Select All',
],
n && ['span', { class: 'ace_mobile-button', action: 'copy' }, 'Copy'],
n && ['span', { class: 'ace_mobile-button', action: 'cut' }, 'Cut'],
e && ['span', { class: 'ace_mobile-button', action: 'paste' }, 'Paste'],
i && ['span', { class: 'ace_mobile-button', action: 'undo' }, 'Undo'],
['span', { class: 'ace_mobile-button', action: 'find' }, 'Find'],
[
'span',
{ class: 'ace_mobile-button', action: 'openCommandPallete' },
'Pallete',
],
]
: ['span']
),
y.firstChild
)
},
o = function (n) {
var s = n.target.getAttribute('action')
if (s == 'more' || !r) return (r = !r), i()
if (s == 'paste')
e.readText().then(function (e) {
t.execCommand(s, e)
})
else if (s) {
if (s == 'cut' || s == 'copy')
e ? e.writeText(t.getCopyText()) : document.execCommand('copy')
t.execCommand(s)
}
;(y.firstChild.style.display = 'none'),
(r = !1),
s != 'openCommandPallete' && t.focus()
}
y = s.buildDom(
[
'div',
{
class: 'ace_mobile-menu',
ontouchstart: function (e) {
;(n = 'menu'), e.stopPropagation(), e.preventDefault(), t.textInput.focus()
},
ontouchend: function (e) {
e.stopPropagation(), e.preventDefault(), o(e)
},
onclick: o,
},
['span'],
['span', { class: 'ace_mobile-button', action: 'more' }, '...'],
],
t.container
)
}
function w() {
y || b()
var e = t.selection.cursor,
n = t.renderer.textToScreenCoordinates(e.row, e.column),
r = t.renderer.textToScreenCoordinates(0, 0).pageX,
i = t.renderer.scrollLeft,
s = t.container.getBoundingClientRect()
;(y.style.top = n.pageY - s.top - 3 + 'px'),
n.pageX - s.left < s.width - 70
? ((y.style.left = ''), (y.style.right = '10px'))
: ((y.style.right = ''), (y.style.left = r + i - s.left + 'px')),
(y.style.display = ''),
(y.firstChild.style.display = 'none'),
t.on('input', E)
}
function E(e) {
y && (y.style.display = 'none'), t.off('input', E)
}
function S() {
;(l = null), clearTimeout(l)
var e = t.selection.getRange(),
r = e.contains(p.row, p.column)
if (e.isEmpty() || !r) t.selection.moveToPosition(p), t.selection.selectWord()
;(n = 'wait'), w()
}
function x() {
;(l = null), clearTimeout(l), t.selection.moveToPosition(p)
var e = d >= 2 ? t.selection.getLineRange(p.row) : t.session.getBracketRange(p)
e && !e.isEmpty() ? t.selection.setRange(e) : t.selection.selectWord(), (n = 'wait')
}
function T() {
;(h += 60),
(c = setInterval(function () {
h-- <= 0 && (clearInterval(c), (c = null)),
Math.abs(v) < 0.01 && (v = 0),
Math.abs(m) < 0.01 && (m = 0),
h < 20 && (v = 0.9 * v),
h < 20 && (m = 0.9 * m)
var e = t.session.getScrollTop()
t.renderer.scrollBy(10 * v, 10 * m), e == t.session.getScrollTop() && (h = 0)
}, 10))
}
var n = 'scroll',
o,
u,
a,
f,
l,
c,
h = 0,
p,
d = 0,
v = 0,
m = 0,
g,
y
i.addListener(
e,
'contextmenu',
function (e) {
if (!g) return
var n = t.textInput.getElement()
n.focus()
},
t
),
i.addListener(
e,
'touchstart',
function (e) {
var i = e.touches
if (l || i.length > 1) {
clearTimeout(l), (l = null), (a = -1), (n = 'zoom')
return
}
g = t.$mouseHandler.isMousePressed = !0
var s = t.renderer.layerConfig.lineHeight,
c = t.renderer.layerConfig.lineHeight,
y = e.timeStamp
f = y
var b = i[0],
w = b.clientX,
E = b.clientY
Math.abs(o - w) + Math.abs(u - E) > s && (a = -1),
(o = e.clientX = w),
(u = e.clientY = E),
(v = m = 0)
var T = new r(e, t)
p = T.getDocumentPosition()
if (y - a < 500 && i.length == 1 && !h) d++, e.preventDefault(), (e.button = 0), x()
else {
d = 0
var N = t.selection.cursor,
C = t.selection.isEmpty() ? N : t.selection.anchor,
k = t.renderer.$cursorLayer.getPixelPosition(N, !0),
L = t.renderer.$cursorLayer.getPixelPosition(C, !0),
A = t.renderer.scroller.getBoundingClientRect(),
O = t.renderer.layerConfig.offset,
M = t.renderer.scrollLeft,
_ = function (e, t) {
return (e /= c), (t = t / s - 0.75), e * e + t * t
}
if (e.clientX < A.left) {
n = 'zoom'
return
}
var D = _(e.clientX - A.left - k.left + M, e.clientY - A.top - k.top + O),
P = _(e.clientX - A.left - L.left + M, e.clientY - A.top - L.top + O)
D < 3.5 && P < 3.5 && (n = D > P ? 'cursor' : 'anchor'),
P < 3.5 ? (n = 'anchor') : D < 3.5 ? (n = 'cursor') : (n = 'scroll'),
(l = setTimeout(S, 450))
}
a = y
},
t
),
i.addListener(
e,
'touchend',
function (e) {
;(g = t.$mouseHandler.isMousePressed = !1),
c && clearInterval(c),
n == 'zoom'
? ((n = ''), (h = 0))
: l
? (t.selection.moveToPosition(p), (h = 0), w())
: n == 'scroll'
? (T(), E())
: w(),
clearTimeout(l),
(l = null)
},
t
),
i.addListener(
e,
'touchmove',
function (e) {
l && (clearTimeout(l), (l = null))
var i = e.touches
if (i.length > 1 || n == 'zoom') return
var s = i[0],
a = o - s.clientX,
c = u - s.clientY
if (n == 'wait') {
if (!(a * a + c * c > 4)) return e.preventDefault()
n = 'cursor'
}
;(o = s.clientX), (u = s.clientY), (e.clientX = s.clientX), (e.clientY = s.clientY)
var h = e.timeStamp,
p = h - f
f = h
if (n == 'scroll') {
var d = new r(e, t)
;(d.speed = 1),
(d.wheelX = a),
(d.wheelY = c),
10 * Math.abs(a) < Math.abs(c) && (a = 0),
10 * Math.abs(c) < Math.abs(a) && (c = 0),
p != 0 && ((v = a / p), (m = c / p)),
t._emit('mousewheel', d),
d.propagationStopped || (v = m = 0)
} else {
var g = new r(e, t),
y = g.getDocumentPosition()
n == 'cursor'
? t.selection.moveCursorToPosition(y)
: n == 'anchor' && t.selection.setSelectionAnchor(y.row, y.column),
t.renderer.scrollCursorIntoView(y),
e.preventDefault()
}
},
t
)
}
}
),
ace.define('ace/lib/net', ['require', 'exports', 'module', 'ace/lib/dom'], function (e, t, n) {
'use strict'
var r = e('./dom')
;(t.get = function (e, t) {
var n = new XMLHttpRequest()
n.open('GET', e, !0),
(n.onreadystatechange = function () {
n.readyState === 4 && t(n.responseText)
}),
n.send(null)
}),
(t.loadScript = function (e, t) {
var n = r.getDocumentHead(),
i = document.createElement('script')
;(i.src = e),
n.appendChild(i),
(i.onload = i.onreadystatechange =
function (e, n) {
if (n || !i.readyState || i.readyState == 'loaded' || i.readyState == 'complete')
(i = i.onload = i.onreadystatechange = null), n || t()
})
}),
(t.qualifyURL = function (e) {
var t = document.createElement('a')
return (t.href = e), t.href
})
}),
ace.define('ace/lib/event_emitter', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
var r = {},
i = function () {
this.propagationStopped = !0
},
s = function () {
this.defaultPrevented = !0
}
;(r._emit = r._dispatchEvent =
function (e, t) {
this._eventRegistry || (this._eventRegistry = {}),
this._defaultHandlers || (this._defaultHandlers = {})
var n = this._eventRegistry[e] || [],
r = this._defaultHandlers[e]
if (!n.length && !r) return
if (typeof t != 'object' || !t) t = {}
t.type || (t.type = e),
t.stopPropagation || (t.stopPropagation = i),
t.preventDefault || (t.preventDefault = s),
(n = n.slice())
for (var o = 0; o < n.length; o++) {
n[o](t, this)
if (t.propagationStopped) break
}
if (r && !t.defaultPrevented) return r(t, this)
}),
(r._signal = function (e, t) {
var n = (this._eventRegistry || {})[e]
if (!n) return
n = n.slice()
for (var r = 0; r < n.length; r++) n[r](t, this)
}),
(r.once = function (e, t) {
var n = this
this.on(e, function r() {
n.off(e, r), t.apply(null, arguments)
})
if (!t)
return new Promise(function (e) {
t = e
})
}),
(r.setDefaultHandler = function (e, t) {
var n = this._defaultHandlers
n || (n = this._defaultHandlers = { _disabled_: {} })
if (n[e]) {
var r = n[e],
i = n._disabled_[e]
i || (n._disabled_[e] = i = []), i.push(r)
var s = i.indexOf(t)
s != -1 && i.splice(s, 1)
}
n[e] = t
}),
(r.removeDefaultHandler = function (e, t) {
var n = this._defaultHandlers
if (!n) return
var r = n._disabled_[e]
if (n[e] == t) r && this.setDefaultHandler(e, r.pop())
else if (r) {
var i = r.indexOf(t)
i != -1 && r.splice(i, 1)
}
}),
(r.on = r.addEventListener =
function (e, t, n) {
this._eventRegistry = this._eventRegistry || {}
var r = this._eventRegistry[e]
return (
r || (r = this._eventRegistry[e] = []),
r.indexOf(t) == -1 && r[n ? 'unshift' : 'push'](t),
t
)
}),
(r.off =
r.removeListener =
r.removeEventListener =
function (e, t) {
this._eventRegistry = this._eventRegistry || {}
var n = this._eventRegistry[e]
if (!n) return
var r = n.indexOf(t)
r !== -1 && n.splice(r, 1)
}),
(r.removeAllListeners = function (e) {
e || (this._eventRegistry = this._defaultHandlers = undefined),
this._eventRegistry && (this._eventRegistry[e] = undefined),
this._defaultHandlers && (this._defaultHandlers[e] = undefined)
}),
(t.EventEmitter = r)
}),
ace.define(
'ace/lib/app_config',
['require', 'exports', 'module', 'ace/lib/oop', 'ace/lib/event_emitter'],
function (e, t, n) {
'no use strict'
function o(e) {
typeof console != 'undefined' && console.warn && console.warn.apply(console, arguments)
}
function u(e, t) {
var n = new Error(e)
;(n.data = t),
typeof console == 'object' && console.error && console.error(n),
setTimeout(function () {
throw n
})
}
var r = e('./oop'),
i = e('./event_emitter').EventEmitter,
s = {
setOptions: function (e) {
Object.keys(e).forEach(function (t) {
this.setOption(t, e[t])
}, this)
},
getOptions: function (e) {
var t = {}
if (!e) {
var n = this.$options
e = Object.keys(n).filter(function (e) {
return !n[e].hidden
})
} else Array.isArray(e) || ((t = e), (e = Object.keys(t)))
return (
e.forEach(function (e) {
t[e] = this.getOption(e)
}, this),
t
)
},
setOption: function (e, t) {
if (this['$' + e] === t) return
var n = this.$options[e]
if (!n) return o('misspelled option "' + e + '"')
if (n.forwardTo) return this[n.forwardTo] && this[n.forwardTo].setOption(e, t)
n.handlesSet || (this['$' + e] = t), n && n.set && n.set.call(this, t)
},
getOption: function (e) {
var t = this.$options[e]
return t
? t.forwardTo
? this[t.forwardTo] && this[t.forwardTo].getOption(e)
: t && t.get
? t.get.call(this)
: this['$' + e]
: o('misspelled option "' + e + '"')
},
},
a = function () {
this.$defaultOptions = {}
}
;(function () {
r.implement(this, i),
(this.defineOptions = function (e, t, n) {
return (
e.$options || (this.$defaultOptions[t] = e.$options = {}),
Object.keys(n).forEach(function (t) {
var r = n[t]
typeof r == 'string' && (r = { forwardTo: r }),
r.name || (r.name = t),
(e.$options[r.name] = r),
'initialValue' in r && (e['$' + r.name] = r.initialValue)
}),
r.implement(e, s),
this
)
}),
(this.resetOptions = function (e) {
Object.keys(e.$options).forEach(function (t) {
var n = e.$options[t]
'value' in n && e.setOption(t, n.value)
})
}),
(this.setDefaultValue = function (e, t, n) {
if (!e) {
for (e in this.$defaultOptions) if (this.$defaultOptions[e][t]) break
if (!this.$defaultOptions[e][t]) return !1
}
var r = this.$defaultOptions[e] || (this.$defaultOptions[e] = {})
r[t] && (r.forwardTo ? this.setDefaultValue(r.forwardTo, t, n) : (r[t].value = n))
}),
(this.setDefaultValues = function (e, t) {
Object.keys(t).forEach(function (n) {
this.setDefaultValue(e, n, t[n])
}, this)
}),
(this.warn = o),
(this.reportError = u)
}).call(a.prototype),
(t.AppConfig = a)
}
),
ace.define(
'ace/config',
[
'require',
'exports',
'module',
'ace/lib/lang',
'ace/lib/oop',
'ace/lib/net',
'ace/lib/app_config',
],
function (e, t, n) {
'no use strict'
function l(r) {
if (!u || !u.document) return
a.packaged = r || e.packaged || n.packaged || (u.define && define.packaged)
var i = {},
s = '',
o = document.currentScript || document._currentScript,
f = (o && o.ownerDocument) || document,
l = f.getElementsByTagName('script')
for (var h = 0; h < l.length; h++) {
var p = l[h],
d = p.src || p.getAttribute('src')
if (!d) continue
var v = p.attributes
for (var m = 0, g = v.length; m < g; m++) {
var y = v[m]
y.name.indexOf('data-ace-') === 0 && (i[c(y.name.replace(/^data-ace-/, ''))] = y.value)
}
var b = d.match(/^(.*)\/ace(\-\w+)?\.js(\?|$)/)
b && (s = b[1])
}
s && ((i.base = i.base || s), (i.packaged = !0)),
(i.basePath = i.base),
(i.workerPath = i.workerPath || i.base),
(i.modePath = i.modePath || i.base),
(i.themePath = i.themePath || i.base),
delete i.base
for (var w in i) typeof i[w] != 'undefined' && t.set(w, i[w])
}
function c(e) {
return e.replace(/-(.)/g, function (e, t) {
return t.toUpperCase()
})
}
var r = e('./lib/lang'),
i = e('./lib/oop'),
s = e('./lib/net'),
o = e('./lib/app_config').AppConfig
n.exports = t = new o()
var u = (function () {
return this || (typeof window != 'undefined' && window)
})(),
a = {
packaged: !1,
workerPath: null,
modePath: null,
themePath: null,
basePath: '',
suffix: '.js',
$moduleUrls: {},
loadWorkerFromBlob: !0,
sharedPopups: !1,
}
;(t.get = function (e) {
if (!a.hasOwnProperty(e)) throw new Error('Unknown config key: ' + e)
return a[e]
}),
(t.set = function (e, t) {
if (a.hasOwnProperty(e)) a[e] = t
else if (this.setDefaultValue('', e, t) == 0) throw new Error('Unknown config key: ' + e)
}),
(t.all = function () {
return r.copyObject(a)
}),
(t.$modes = {}),
(t.moduleUrl = function (e, t) {
if (a.$moduleUrls[e]) return a.$moduleUrls[e]
var n = e.split('/')
t = t || n[n.length - 2] || ''
var r = t == 'snippets' ? '/' : '-',
i = n[n.length - 1]
if (t == 'worker' && r == '-') {
var s = new RegExp('^' + t + '[\\-_]|[\\-_]' + t + '$', 'g')
i = i.replace(s, '')
}
;(!i || i == t) && n.length > 1 && (i = n[n.length - 2])
var o = a[t + 'Path']
return (
o == null ? (o = a.basePath) : r == '/' && (t = r = ''),
o && o.slice(-1) != '/' && (o += '/'),
o + t + r + i + this.get('suffix')
)
}),
(t.setModuleUrl = function (e, t) {
return (a.$moduleUrls[e] = t)
}),
(t.$loading = {}),
(t.loadModule = function (n, r) {
var i, o
Array.isArray(n) && ((o = n[0]), (n = n[1]))
try {
i = e(n)
} catch (u) {}
if (i && !t.$loading[n]) return r && r(i)
t.$loading[n] || (t.$loading[n] = []), t.$loading[n].push(r)
if (t.$loading[n].length > 1) return
var a = function () {
e([n], function (e) {
t._emit('load.module', { name: n, module: e })
var r = t.$loading[n]
;(t.$loading[n] = null),
r.forEach(function (t) {
t && t(e)
})
})
}
if (!t.get('packaged')) return a()
s.loadScript(t.moduleUrl(n, o), a), f()
})
var f = function () {
!a.basePath &&
!a.workerPath &&
!a.modePath &&
!a.themePath &&
!Object.keys(a.$moduleUrls).length &&
(console.error(
'Unable to infer path to ace from script src,',
"use ace.config.set('basePath', 'path') to enable dynamic loading of modes and themes",
'or with webpack use ace/webpack-resolver'
),
(f = function () {}))
}
;(t.init = l), (t.version = '1.4.12')
}
),
ace.define(
'ace/mouse/mouse_handler',
[
'require',
'exports',
'module',
'ace/lib/event',
'ace/lib/useragent',
'ace/mouse/default_handlers',
'ace/mouse/default_gutter_handler',
'ace/mouse/mouse_event',
'ace/mouse/dragdrop_handler',
'ace/mouse/touch_handler',
'ace/config',
],
function (e, t, n) {
'use strict'
var r = e('../lib/event'),
i = e('../lib/useragent'),
s = e('./default_handlers').DefaultHandlers,
o = e('./default_gutter_handler').GutterHandler,
u = e('./mouse_event').MouseEvent,
a = e('./dragdrop_handler').DragdropHandler,
f = e('./touch_handler').addTouchListeners,
l = e('../config'),
c = function (e) {
var t = this
;(this.editor = e), new s(this), new o(this), new a(this)
var n = function (t) {
var n =
!document.hasFocus ||
!document.hasFocus() ||
(!e.isFocused() &&
document.activeElement == (e.textInput && e.textInput.getElement()))
n && window.focus(), e.focus()
},
u = e.renderer.getMouseEventTarget()
r.addListener(u, 'click', this.onMouseEvent.bind(this, 'click'), e),
r.addListener(u, 'mousemove', this.onMouseMove.bind(this, 'mousemove'), e),
r.addMultiMouseDownListener(
[
u,
e.renderer.scrollBarV && e.renderer.scrollBarV.inner,
e.renderer.scrollBarH && e.renderer.scrollBarH.inner,
e.textInput && e.textInput.getElement(),
].filter(Boolean),
[400, 300, 250],
this,
'onMouseEvent',
e
),
r.addMouseWheelListener(e.container, this.onMouseWheel.bind(this, 'mousewheel'), e),
f(e.container, e)
var l = e.renderer.$gutter
r.addListener(l, 'mousedown', this.onMouseEvent.bind(this, 'guttermousedown'), e),
r.addListener(l, 'click', this.onMouseEvent.bind(this, 'gutterclick'), e),
r.addListener(l, 'dblclick', this.onMouseEvent.bind(this, 'gutterdblclick'), e),
r.addListener(l, 'mousemove', this.onMouseEvent.bind(this, 'guttermousemove'), e),
r.addListener(u, 'mousedown', n, e),
r.addListener(l, 'mousedown', n, e),
i.isIE &&
e.renderer.scrollBarV &&
(r.addListener(e.renderer.scrollBarV.element, 'mousedown', n, e),
r.addListener(e.renderer.scrollBarH.element, 'mousedown', n, e)),
e.on(
'mousemove',
function (n) {
if (t.state || t.$dragDelay || !t.$dragEnabled) return
var r = e.renderer.screenToTextCoordinates(n.x, n.y),
i = e.session.selection.getRange(),
s = e.renderer
!i.isEmpty() && i.insideStart(r.row, r.column)
? s.setCursorStyle('default')
: s.setCursorStyle('')
},
e
)
}
;(function () {
;(this.onMouseEvent = function (e, t) {
this.editor._emit(e, new u(t, this.editor))
}),
(this.onMouseMove = function (e, t) {
var n = this.editor._eventRegistry && this.editor._eventRegistry.mousemove
if (!n || !n.length) return
this.editor._emit(e, new u(t, this.editor))
}),
(this.onMouseWheel = function (e, t) {
var n = new u(t, this.editor)
;(n.speed = this.$scrollSpeed * 2),
(n.wheelX = t.wheelX),
(n.wheelY = t.wheelY),
this.editor._emit(e, n)
}),
(this.setState = function (e) {
this.state = e
}),
(this.captureMouse = function (e, t) {
;(this.x = e.x), (this.y = e.y), (this.isMousePressed = !0)
var n = this.editor,
s = this.editor.renderer
s.$isMousePressed = !0
var o = this,
a = function (e) {
if (!e) return
if (i.isWebKit && !e.which && o.releaseMouse) return o.releaseMouse()
;(o.x = e.clientX),
(o.y = e.clientY),
t && t(e),
(o.mouseEvent = new u(e, o.editor)),
(o.$mouseMoved = !0)
},
f = function (e) {
n.off('beforeEndOperation', c),
clearInterval(h),
l(),
o[o.state + 'End'] && o[o.state + 'End'](e),
(o.state = ''),
(o.isMousePressed = s.$isMousePressed = !1),
s.$keepTextAreaAtCursor && s.$moveTextAreaToCursor(),
(o.$onCaptureMouseMove = o.releaseMouse = null),
e && o.onMouseEvent('mouseup', e),
n.endOperation()
},
l = function () {
o[o.state] && o[o.state](), (o.$mouseMoved = !1)
}
if (i.isOldIE && e.domEvent.type == 'dblclick')
return setTimeout(function () {
f(e)
})
var c = function (e) {
if (!o.releaseMouse) return
n.curOp.command.name &&
n.curOp.selectionChanged &&
(o[o.state + 'End'] && o[o.state + 'End'](), (o.state = ''), o.releaseMouse())
}
n.on('beforeEndOperation', c),
n.startOperation({ command: { name: 'mouse' } }),
(o.$onCaptureMouseMove = a),
(o.releaseMouse = r.capture(this.editor.container, a, f))
var h = setInterval(l, 20)
}),
(this.releaseMouse = null),
(this.cancelContextMenu = function () {
var e = function (t) {
if (t && t.domEvent && t.domEvent.type != 'contextmenu') return
this.editor.off('nativecontextmenu', e), t && t.domEvent && r.stopEvent(t.domEvent)
}.bind(this)
setTimeout(e, 10), this.editor.on('nativecontextmenu', e)
}),
(this.destroy = function () {
this.releaseMouse && this.releaseMouse()
})
}).call(c.prototype),
l.defineOptions(c.prototype, 'mouseHandler', {
scrollSpeed: { initialValue: 2 },
dragDelay: { initialValue: i.isMac ? 150 : 0 },
dragEnabled: { initialValue: !0 },
focusTimeout: { initialValue: 0 },
tooltipFollowsMouse: { initialValue: !0 },
}),
(t.MouseHandler = c)
}
),
ace.define(
'ace/mouse/fold_handler',
['require', 'exports', 'module', 'ace/lib/dom'],
function (e, t, n) {
'use strict'
function i(e) {
e.on('click', function (t) {
var n = t.getDocumentPosition(),
i = e.session,
s = i.getFoldAt(n.row, n.column, 1)
s && (t.getAccelKey() ? i.removeFold(s) : i.expandFold(s), t.stop())
var o = t.domEvent && t.domEvent.target
o &&
r.hasCssClass(o, 'ace_inline_button') &&
r.hasCssClass(o, 'ace_toggle_wrap') &&
(i.setOption('wrap', !i.getUseWrapMode()), e.renderer.scrollCursorIntoView())
}),
e.on('gutterclick', function (t) {
var n = e.renderer.$gutterLayer.getRegion(t)
if (n == 'foldWidgets') {
var r = t.getDocumentPosition().row,
i = e.session
i.foldWidgets && i.foldWidgets[r] && e.session.onFoldWidgetClick(r, t),
e.isFocused() || e.focus(),
t.stop()
}
}),
e.on('gutterdblclick', function (t) {
var n = e.renderer.$gutterLayer.getRegion(t)
if (n == 'foldWidgets') {
var r = t.getDocumentPosition().row,
i = e.session,
s = i.getParentFoldRangeData(r, !0),
o = s.range || s.firstRange
if (o) {
r = o.start.row
var u = i.getFoldAt(r, i.getLine(r).length, 1)
u
? i.removeFold(u)
: (i.addFold('...', o),
e.renderer.scrollCursorIntoView({ row: o.start.row, column: 0 }))
}
t.stop()
}
})
}
var r = e('../lib/dom')
t.FoldHandler = i
}
),
ace.define(
'ace/keyboard/keybinding',
['require', 'exports', 'module', 'ace/lib/keys', 'ace/lib/event'],
function (e, t, n) {
'use strict'
var r = e('../lib/keys'),
i = e('../lib/event'),
s = function (e) {
;(this.$editor = e),
(this.$data = { editor: e }),
(this.$handlers = []),
this.setDefaultHandler(e.commands)
}
;(function () {
;(this.setDefaultHandler = function (e) {
this.removeKeyboardHandler(this.$defaultHandler),
(this.$defaultHandler = e),
this.addKeyboardHandler(e, 0)
}),
(this.setKeyboardHandler = function (e) {
var t = this.$handlers
if (t[t.length - 1] == e) return
while (t[t.length - 1] && t[t.length - 1] != this.$defaultHandler)
this.removeKeyboardHandler(t[t.length - 1])
this.addKeyboardHandler(e, 1)
}),
(this.addKeyboardHandler = function (e, t) {
if (!e) return
typeof e == 'function' && !e.handleKeyboard && (e.handleKeyboard = e)
var n = this.$handlers.indexOf(e)
n != -1 && this.$handlers.splice(n, 1),
t == undefined ? this.$handlers.push(e) : this.$handlers.splice(t, 0, e),
n == -1 && e.attach && e.attach(this.$editor)
}),
(this.removeKeyboardHandler = function (e) {
var t = this.$handlers.indexOf(e)
return t == -1
? !1
: (this.$handlers.splice(t, 1), e.detach && e.detach(this.$editor), !0)
}),
(this.getKeyboardHandler = function () {
return this.$handlers[this.$handlers.length - 1]
}),
(this.getStatusText = function () {
var e = this.$data,
t = e.editor
return this.$handlers
.map(function (n) {
return (n.getStatusText && n.getStatusText(t, e)) || ''
})
.filter(Boolean)
.join(' ')
}),
(this.$callKeyboardHandlers = function (e, t, n, r) {
var s,
o = !1,
u = this.$editor.commands
for (var a = this.$handlers.length; a--; ) {
s = this.$handlers[a].handleKeyboard(this.$data, e, t, n, r)
if (!s || !s.command) continue
s.command == 'null' ? (o = !0) : (o = u.exec(s.command, this.$editor, s.args, r)),
o && r && e != -1 && s.passEvent != 1 && s.command.passEvent != 1 && i.stopEvent(r)
if (o) break
}
return (
!o &&
e == -1 &&
((s = { command: 'insertstring' }), (o = u.exec('insertstring', this.$editor, t))),
o && this.$editor._signal && this.$editor._signal('keyboardActivity', s),
o
)
}),
(this.onCommandKey = function (e, t, n) {
var i = r.keyCodeToString(n)
return this.$callKeyboardHandlers(t, i, n, e)
}),
(this.onTextInput = function (e) {
return this.$callKeyboardHandlers(-1, e)
})
}).call(s.prototype),
(t.KeyBinding = s)
}
),
ace.define('ace/lib/bidiutil', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
function F(e, t, n, r) {
var i = s ? d : p,
c = null,
h = null,
v = null,
m = 0,
g = null,
y = null,
b = -1,
w = null,
E = null,
T = []
if (!r) for (w = 0, r = []; w < n; w++) r[w] = R(e[w])
;(o = s), (u = !1), (a = !1), (f = !1), (l = !1)
for (E = 0; E < n; E++) {
;(c = m),
(T[E] = h = q(e, r, T, E)),
(m = i[c][h]),
(g = m & 240),
(m &= 15),
(t[E] = v = i[m][5])
if (g > 0)
if (g == 16) {
for (w = b; w < E; w++) t[w] = 1
b = -1
} else b = -1
y = i[m][6]
if (y) b == -1 && (b = E)
else if (b > -1) {
for (w = b; w < E; w++) t[w] = v
b = -1
}
r[E] == S && (t[E] = 0), (o |= v)
}
if (l)
for (w = 0; w < n; w++)
if (r[w] == x) {
t[w] = s
for (var C = w - 1; C >= 0; C--) {
if (r[C] != N) break
t[C] = s
}
}
}
function I(e, t, n) {
if (o < e) return
if (e == 1 && s == m && !f) {
n.reverse()
return
}
var r = n.length,
i = 0,
u,
a,
l,
c
while (i < r) {
if (t[i] >= e) {
u = i + 1
while (u < r && t[u] >= e) u++
for (a = i, l = u - 1; a < l; a++, l--) (c = n[a]), (n[a] = n[l]), (n[l] = c)
i = u
}
i++
}
}
function q(e, t, n, r) {
var i = t[r],
o,
c,
h,
p
switch (i) {
case g:
case y:
u = !1
case E:
case w:
return i
case b:
return u ? w : b
case T:
return (u = !0), (a = !0), y
case N:
return E
case C:
if (
r < 1 ||
r + 1 >= t.length ||
((o = n[r - 1]) != b && o != w) ||
((c = t[r + 1]) != b && c != w)
)
return E
return u && (c = w), c == o ? c : E
case k:
o = r > 0 ? n[r - 1] : S
if (o == b && r + 1 < t.length && t[r + 1] == b) return b
return E
case L:
if (r > 0 && n[r - 1] == b) return b
if (u) return E
;(p = r + 1), (h = t.length)
while (p < h && t[p] == L) p++
if (p < h && t[p] == b) return b
return E
case A:
;(h = t.length), (p = r + 1)
while (p < h && t[p] == A) p++
if (p < h) {
var d = e[r],
v = (d >= 1425 && d <= 2303) || d == 64286
o = t[p]
if (v && (o == y || o == T)) return y
}
if (r < 1 || (o = t[r - 1]) == S) return E
return n[r - 1]
case S:
return (u = !1), (f = !0), s
case x:
return (l = !0), E
case O:
case M:
case D:
case P:
case _:
u = !1
case H:
return E
}
}
function R(e) {
var t = e.charCodeAt(0),
n = t >> 8
return n == 0
? t > 191
? g
: B[t]
: n == 5
? /[\u0591-\u05f4]/.test(e)
? y
: g
: n == 6
? /[\u0610-\u061a\u064b-\u065f\u06d6-\u06e4\u06e7-\u06ed]/.test(e)
? A
: /[\u0660-\u0669\u066b-\u066c]/.test(e)
? w
: t == 1642
? L
: /[\u06f0-\u06f9]/.test(e)
? b
: T
: n == 32 && t <= 8287
? j[t & 255]
: n == 254
? t >= 65136
? T
: E
: E
}
function U(e) {
return e >= '\u064b' && e <= '\u0655'
}
var r = ['\u0621', '\u0641'],
i = ['\u063a', '\u064a'],
s = 0,
o = 0,
u = !1,
a = !1,
f = !1,
l = !1,
c = !1,
h = !1,
p = [
[0, 3, 0, 1, 0, 0, 0],
[0, 3, 0, 1, 2, 2, 0],
[0, 3, 0, 17, 2, 0, 1],
[0, 3, 5, 5, 4, 1, 0],
[0, 3, 21, 21, 4, 0, 1],
[0, 3, 5, 5, 4, 2, 0],
],
d = [
[2, 0, 1, 1, 0, 1, 0],
[2, 0, 1, 1, 0, 2, 0],
[2, 0, 2, 1, 3, 2, 0],
[2, 0, 2, 33, 3, 1, 1],
],
v = 0,
m = 1,
g = 0,
y = 1,
b = 2,
w = 3,
E = 4,
S = 5,
x = 6,
T = 7,
N = 8,
C = 9,
k = 10,
L = 11,
A = 12,
O = 13,
M = 14,
_ = 15,
D = 16,
P = 17,
H = 18,
B = [
H,
H,
H,
H,
H,
H,
H,
H,
H,
x,
S,
x,
N,
S,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
S,
S,
S,
x,
N,
E,
E,
L,
L,
L,
E,
E,
E,
E,
E,
k,
C,
k,
C,
C,
b,
b,
b,
b,
b,
b,
b,
b,
b,
b,
C,
E,
E,
E,
E,
E,
E,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
E,
E,
E,
E,
E,
E,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
g,
E,
E,
E,
E,
H,
H,
H,
H,
H,
H,
S,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
H,
C,
E,
L,
L,
L,
L,
E,
E,
E,
E,
g,
E,
E,
H,
E,
E,
L,
L,
b,
b,
E,
g,
E,
E,
E,
b,
g,
E,
E,
E,
E,
E,
],
j = [
N,
N,
N,
N,
N,
N,
N,
N,
N,
N,
N,
H,
H,
H,
g,
y,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
N,
S,
O,
M,
_,
D,
P,
C,
L,
L,
L,
L,
L,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
C,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
E,
N,
]
;(t.L = g),
(t.R = y),
(t.EN = b),
(t.ON_R = 3),
(t.AN = 4),
(t.R_H = 5),
(t.B = 6),
(t.RLE = 7),
(t.DOT = '\u00b7'),
(t.doBidiReorder = function (e, n, r) {
if (e.length < 2) return {}
var i = e.split(''),
o = new Array(i.length),
u = new Array(i.length),
a = []
;(s = r ? m : v), F(i, a, i.length, n)
for (var f = 0; f < o.length; o[f] = f, f++);
I(2, a, o), I(1, a, o)
for (var f = 0; f < o.length - 1; f++)
n[f] === w
? (a[f] = t.AN)
: a[f] === y && ((n[f] > T && n[f] < O) || n[f] === E || n[f] === H)
? (a[f] = t.ON_R)
: f > 0 &&
i[f - 1] === '\u0644' &&
/\u0622|\u0623|\u0625|\u0627/.test(i[f]) &&
((a[f - 1] = a[f] = t.R_H), f++)
i[i.length - 1] === t.DOT && (a[i.length - 1] = t.B), i[0] === '\u202b' && (a[0] = t.RLE)
for (var f = 0; f < o.length; f++) u[f] = a[o[f]]
return { logicalFromVisual: o, bidiLevels: u }
}),
(t.hasBidiCharacters = function (e, t) {
var n = !1
for (var r = 0; r < e.length; r++)
(t[r] = R(e.charAt(r))), !n && (t[r] == y || t[r] == T || t[r] == w) && (n = !0)
return n
}),
(t.getVisualFromLogicalIdx = function (e, t) {
for (var n = 0; n < t.logicalFromVisual.length; n++)
if (t.logicalFromVisual[n] == e) return n
return 0
})
}),
ace.define(
'ace/bidihandler',
['require', 'exports', 'module', 'ace/lib/bidiutil', 'ace/lib/lang'],
function (e, t, n) {
'use strict'
var r = e('./lib/bidiutil'),
i = e('./lib/lang'),
s = /[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac\u202B]/,
o = function (e) {
;(this.session = e),
(this.bidiMap = {}),
(this.currentRow = null),
(this.bidiUtil = r),
(this.charWidths = []),
(this.EOL = '\u00ac'),
(this.showInvisibles = !0),
(this.isRtlDir = !1),
(this.$isRtl = !1),
(this.line = ''),
(this.wrapIndent = 0),
(this.EOF = '\u00b6'),
(this.RLE = '\u202b'),
(this.contentWidth = 0),
(this.fontMetrics = null),
(this.rtlLineOffset = 0),
(this.wrapOffset = 0),
(this.isMoveLeftOperation = !1),
(this.seenBidi = s.test(e.getValue()))
}
;(function () {
;(this.isBidiRow = function (e, t, n) {
return this.seenBidi
? (e !== this.currentRow &&
((this.currentRow = e), this.updateRowLine(t, n), this.updateBidiMap()),
this.bidiMap.bidiLevels)
: !1
}),
(this.onChange = function (e) {
this.seenBidi
? (this.currentRow = null)
: e.action == 'insert' &&
s.test(e.lines.join('\n')) &&
((this.seenBidi = !0), (this.currentRow = null))
}),
(this.getDocumentRow = function () {
var e = 0,
t = this.session.$screenRowCache
if (t.length) {
var n = this.session.$getRowCacheIndex(t, this.currentRow)
n >= 0 && (e = this.session.$docRowCache[n])
}
return e
}),
(this.getSplitIndex = function () {
var e = 0,
t = this.session.$screenRowCache
if (t.length) {
var n,
r = this.session.$getRowCacheIndex(t, this.currentRow)
while (this.currentRow - e > 0) {
n = this.session.$getRowCacheIndex(t, this.currentRow - e - 1)
if (n !== r) break
;(r = n), e++
}
} else e = this.currentRow
return e
}),
(this.updateRowLine = function (e, t) {
e === undefined && (e = this.getDocumentRow())
var n = e === this.session.getLength() - 1,
s = n ? this.EOF : this.EOL
;(this.wrapIndent = 0),
(this.line = this.session.getLine(e)),
(this.isRtlDir = this.$isRtl || this.line.charAt(0) === this.RLE)
if (this.session.$useWrapMode) {
var o = this.session.$wrapData[e]
o &&
(t === undefined && (t = this.getSplitIndex()),
t > 0 && o.length
? ((this.wrapIndent = o.indent),
(this.wrapOffset = this.wrapIndent * this.charWidths[r.L]),
(this.line =
t < o.length
? this.line.substring(o[t - 1], o[t])
: this.line.substring(o[o.length - 1])))
: (this.line = this.line.substring(0, o[t]))),
t == o.length && (this.line += this.showInvisibles ? s : r.DOT)
} else this.line += this.showInvisibles ? s : r.DOT
var u = this.session,
a = 0,
f
;(this.line = this.line.replace(/\t|[\u1100-\u2029, \u202F-\uFFE6]/g, function (e, t) {
return e === ' ' || u.isFullWidth(e.charCodeAt(0))
? ((f = e === ' ' ? u.getScreenTabSize(t + a) : 2),
(a += f - 1),
i.stringRepeat(r.DOT, f))
: e
})),
this.isRtlDir &&
((this.fontMetrics.$main.textContent =
this.line.charAt(this.line.length - 1) == r.DOT
? this.line.substr(0, this.line.length - 1)
: this.line),
(this.rtlLineOffset =
this.contentWidth - this.fontMetrics.$main.getBoundingClientRect().width))
}),
(this.updateBidiMap = function () {
var e = []
r.hasBidiCharacters(this.line, e) || this.isRtlDir
? (this.bidiMap = r.doBidiReorder(this.line, e, this.isRtlDir))
: (this.bidiMap = {})
}),
(this.markAsDirty = function () {
this.currentRow = null
}),
(this.updateCharacterWidths = function (e) {
if (this.characterWidth === e.$characterSize.width) return
this.fontMetrics = e
var t = (this.characterWidth = e.$characterSize.width),
n = e.$measureCharWidth('\u05d4')
;(this.charWidths[r.L] = this.charWidths[r.EN] = this.charWidths[r.ON_R] = t),
(this.charWidths[r.R] = this.charWidths[r.AN] = n),
(this.charWidths[r.R_H] = n * 0.45),
(this.charWidths[r.B] = this.charWidths[r.RLE] = 0),
(this.currentRow = null)
}),
(this.setShowInvisibles = function (e) {
;(this.showInvisibles = e), (this.currentRow = null)
}),
(this.setEolChar = function (e) {
this.EOL = e
}),
(this.setContentWidth = function (e) {
this.contentWidth = e
}),
(this.isRtlLine = function (e) {
return this.$isRtl
? !0
: e != undefined
? this.session.getLine(e).charAt(0) == this.RLE
: this.isRtlDir
}),
(this.setRtlDirection = function (e, t) {
var n = e.getCursorPosition()
for (var r = e.selection.getSelectionAnchor().row; r <= n.row; r++)
!t && e.session.getLine(r).charAt(0) === e.session.$bidiHandler.RLE
? e.session.doc.removeInLine(r, 0, 1)
: t &&
e.session.getLine(r).charAt(0) !== e.session.$bidiHandler.RLE &&
e.session.doc.insert({ column: 0, row: r }, e.session.$bidiHandler.RLE)
}),
(this.getPosLeft = function (e) {
e -= this.wrapIndent
var t = this.line.charAt(0) === this.RLE ? 1 : 0,
n = e > t ? (this.session.getOverwrite() ? e : e - 1) : t,
i = r.getVisualFromLogicalIdx(n, this.bidiMap),
s = this.bidiMap.bidiLevels,
o = 0
!this.session.getOverwrite() && e <= t && s[i] % 2 !== 0 && i++
for (var u = 0; u < i; u++) o += this.charWidths[s[u]]
return (
!this.session.getOverwrite() &&
e > t &&
s[i] % 2 === 0 &&
(o += this.charWidths[s[i]]),
this.wrapIndent && (o += this.isRtlDir ? -1 * this.wrapOffset : this.wrapOffset),
this.isRtlDir && (o += this.rtlLineOffset),
o
)
}),
(this.getSelections = function (e, t) {
var n = this.bidiMap,
r = n.bidiLevels,
i,
s = [],
o = 0,
u = Math.min(e, t) - this.wrapIndent,
a = Math.max(e, t) - this.wrapIndent,
f = !1,
l = !1,
c = 0
this.wrapIndent && (o += this.isRtlDir ? -1 * this.wrapOffset : this.wrapOffset)
for (var h, p = 0; p < r.length; p++)
(h = n.logicalFromVisual[p]),
(i = r[p]),
(f = h >= u && h < a),
f && !l ? (c = o) : !f && l && s.push({ left: c, width: o - c }),
(o += this.charWidths[i]),
(l = f)
f && p === r.length && s.push({ left: c, width: o - c })
if (this.isRtlDir) for (var d = 0; d < s.length; d++) s[d].left += this.rtlLineOffset
return s
}),
(this.offsetToCol = function (e) {
this.isRtlDir && (e -= this.rtlLineOffset)
var t = 0,
e = Math.max(e, 0),
n = 0,
r = 0,
i = this.bidiMap.bidiLevels,
s = this.charWidths[i[r]]
this.wrapIndent && (e -= this.isRtlDir ? -1 * this.wrapOffset : this.wrapOffset)
while (e > n + s / 2) {
n += s
if (r === i.length - 1) {
s = 0
break
}
s = this.charWidths[i[++r]]
}
return (
r > 0 && i[r - 1] % 2 !== 0 && i[r] % 2 === 0
? (e < n && r--, (t = this.bidiMap.logicalFromVisual[r]))
: r > 0 && i[r - 1] % 2 === 0 && i[r] % 2 !== 0
? (t =
1 +
(e > n
? this.bidiMap.logicalFromVisual[r]
: this.bidiMap.logicalFromVisual[r - 1]))
: (this.isRtlDir && r === i.length - 1 && s === 0 && i[r - 1] % 2 === 0) ||
(!this.isRtlDir && r === 0 && i[r] % 2 !== 0)
? (t = 1 + this.bidiMap.logicalFromVisual[r])
: (r > 0 && i[r - 1] % 2 !== 0 && s !== 0 && r--,
(t = this.bidiMap.logicalFromVisual[r])),
t === 0 && this.isRtlDir && t++,
t + this.wrapIndent
)
})
}).call(o.prototype),
(t.BidiHandler = o)
}
),
ace.define(
'ace/selection',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/lib/lang',
'ace/lib/event_emitter',
'ace/range',
],
function (e, t, n) {
'use strict'
var r = e('./lib/oop'),
i = e('./lib/lang'),
s = e('./lib/event_emitter').EventEmitter,
o = e('./range').Range,
u = function (e) {
;(this.session = e),
(this.doc = e.getDocument()),
this.clearSelection(),
(this.cursor = this.lead = this.doc.createAnchor(0, 0)),
(this.anchor = this.doc.createAnchor(0, 0)),
(this.$silent = !1)
var t = this
this.cursor.on('change', function (e) {
;(t.$cursorChanged = !0),
t.$silent || t._emit('changeCursor'),
!t.$isEmpty && !t.$silent && t._emit('changeSelection'),
!t.$keepDesiredColumnOnChange &&
e.old.column != e.value.column &&
(t.$desiredColumn = null)
}),
this.anchor.on('change', function () {
;(t.$anchorChanged = !0), !t.$isEmpty && !t.$silent && t._emit('changeSelection')
})
}
;(function () {
r.implement(this, s),
(this.isEmpty = function () {
return (
this.$isEmpty ||
(this.anchor.row == this.lead.row && this.anchor.column == this.lead.column)
)
}),
(this.isMultiLine = function () {
return !this.$isEmpty && this.anchor.row != this.cursor.row
}),
(this.getCursor = function () {
return this.lead.getPosition()
}),
(this.setSelectionAnchor = function (e, t) {
;(this.$isEmpty = !1), this.anchor.setPosition(e, t)
}),
(this.getAnchor = this.getSelectionAnchor =
function () {
return this.$isEmpty ? this.getSelectionLead() : this.anchor.getPosition()
}),
(this.getSelectionLead = function () {
return this.lead.getPosition()
}),
(this.isBackwards = function () {
var e = this.anchor,
t = this.lead
return e.row > t.row || (e.row == t.row && e.column > t.column)
}),
(this.getRange = function () {
var e = this.anchor,
t = this.lead
return this.$isEmpty
? o.fromPoints(t, t)
: this.isBackwards()
? o.fromPoints(t, e)
: o.fromPoints(e, t)
}),
(this.clearSelection = function () {
this.$isEmpty || ((this.$isEmpty = !0), this._emit('changeSelection'))
}),
(this.selectAll = function () {
this.$setSelection(0, 0, Number.MAX_VALUE, Number.MAX_VALUE)
}),
(this.setRange = this.setSelectionRange =
function (e, t) {
var n = t ? e.end : e.start,
r = t ? e.start : e.end
this.$setSelection(n.row, n.column, r.row, r.column)
}),
(this.$setSelection = function (e, t, n, r) {
if (this.$silent) return
var i = this.$isEmpty,
s = this.inMultiSelectMode
;(this.$silent = !0),
(this.$cursorChanged = this.$anchorChanged = !1),
this.anchor.setPosition(e, t),
this.cursor.setPosition(n, r),
(this.$isEmpty = !o.comparePoints(this.anchor, this.cursor)),
(this.$silent = !1),
this.$cursorChanged && this._emit('changeCursor'),
(this.$cursorChanged || this.$anchorChanged || i != this.$isEmpty || s) &&
this._emit('changeSelection')
}),
(this.$moveSelection = function (e) {
var t = this.lead
this.$isEmpty && this.setSelectionAnchor(t.row, t.column), e.call(this)
}),
(this.selectTo = function (e, t) {
this.$moveSelection(function () {
this.moveCursorTo(e, t)
})
}),
(this.selectToPosition = function (e) {
this.$moveSelection(function () {
this.moveCursorToPosition(e)
})
}),
(this.moveTo = function (e, t) {
this.clearSelection(), this.moveCursorTo(e, t)
}),
(this.moveToPosition = function (e) {
this.clearSelection(), this.moveCursorToPosition(e)
}),
(this.selectUp = function () {
this.$moveSelection(this.moveCursorUp)
}),
(this.selectDown = function () {
this.$moveSelection(this.moveCursorDown)
}),
(this.selectRight = function () {
this.$moveSelection(this.moveCursorRight)
}),
(this.selectLeft = function () {
this.$moveSelection(this.moveCursorLeft)
}),
(this.selectLineStart = function () {
this.$moveSelection(this.moveCursorLineStart)
}),
(this.selectLineEnd = function () {
this.$moveSelection(this.moveCursorLineEnd)
}),
(this.selectFileEnd = function () {
this.$moveSelection(this.moveCursorFileEnd)
}),
(this.selectFileStart = function () {
this.$moveSelection(this.moveCursorFileStart)
}),
(this.selectWordRight = function () {
this.$moveSelection(this.moveCursorWordRight)
}),
(this.selectWordLeft = function () {
this.$moveSelection(this.moveCursorWordLeft)
}),
(this.getWordRange = function (e, t) {
if (typeof t == 'undefined') {
var n = e || this.lead
;(e = n.row), (t = n.column)
}
return this.session.getWordRange(e, t)
}),
(this.selectWord = function () {
this.setSelectionRange(this.getWordRange())
}),
(this.selectAWord = function () {
var e = this.getCursor(),
t = this.session.getAWordRange(e.row, e.column)
this.setSelectionRange(t)
}),
(this.getLineRange = function (e, t) {
var n = typeof e == 'number' ? e : this.lead.row,
r,
i = this.session.getFoldLine(n)
return (
i ? ((n = i.start.row), (r = i.end.row)) : (r = n),
t === !0 ? new o(n, 0, r, this.session.getLine(r).length) : new o(n, 0, r + 1, 0)
)
}),
(this.selectLine = function () {
this.setSelectionRange(this.getLineRange())
}),
(this.moveCursorUp = function () {
this.moveCursorBy(-1, 0)
}),
(this.moveCursorDown = function () {
this.moveCursorBy(1, 0)
}),
(this.wouldMoveIntoSoftTab = function (e, t, n) {
var r = e.column,
i = e.column + t
return (
n < 0 && ((r = e.column - t), (i = e.column)),
this.session.isTabStop(e) &&
this.doc.getLine(e.row).slice(r, i).split(' ').length - 1 == t
)
}),
(this.moveCursorLeft = function () {
var e = this.lead.getPosition(),
t
if ((t = this.session.getFoldAt(e.row, e.column, -1)))
this.moveCursorTo(t.start.row, t.start.column)
else if (e.column === 0)
e.row > 0 && this.moveCursorTo(e.row - 1, this.doc.getLine(e.row - 1).length)
else {
var n = this.session.getTabSize()
this.wouldMoveIntoSoftTab(e, n, -1) && !this.session.getNavigateWithinSoftTabs()
? this.moveCursorBy(0, -n)
: this.moveCursorBy(0, -1)
}
}),
(this.moveCursorRight = function () {
var e = this.lead.getPosition(),
t
if ((t = this.session.getFoldAt(e.row, e.column, 1)))
this.moveCursorTo(t.end.row, t.end.column)
else if (this.lead.column == this.doc.getLine(this.lead.row).length)
this.lead.row < this.doc.getLength() - 1 && this.moveCursorTo(this.lead.row + 1, 0)
else {
var n = this.session.getTabSize(),
e = this.lead
this.wouldMoveIntoSoftTab(e, n, 1) && !this.session.getNavigateWithinSoftTabs()
? this.moveCursorBy(0, n)
: this.moveCursorBy(0, 1)
}
}),
(this.moveCursorLineStart = function () {
var e = this.lead.row,
t = this.lead.column,
n = this.session.documentToScreenRow(e, t),
r = this.session.screenToDocumentPosition(n, 0),
i = this.session.getDisplayLine(e, null, r.row, r.column),
s = i.match(/^\s*/)
s[0].length != t && !this.session.$useEmacsStyleLineStart && (r.column += s[0].length),
this.moveCursorToPosition(r)
}),
(this.moveCursorLineEnd = function () {
var e = this.lead,
t = this.session.getDocumentLastRowColumnPosition(e.row, e.column)
if (this.lead.column == t.column) {
var n = this.session.getLine(t.row)
if (t.column == n.length) {
var r = n.search(/\s+$/)
r > 0 && (t.column = r)
}
}
this.moveCursorTo(t.row, t.column)
}),
(this.moveCursorFileEnd = function () {
var e = this.doc.getLength() - 1,
t = this.doc.getLine(e).length
this.moveCursorTo(e, t)
}),
(this.moveCursorFileStart = function () {
this.moveCursorTo(0, 0)
}),
(this.moveCursorLongWordRight = function () {
var e = this.lead.row,
t = this.lead.column,
n = this.doc.getLine(e),
r = n.substring(t)
;(this.session.nonTokenRe.lastIndex = 0), (this.session.tokenRe.lastIndex = 0)
var i = this.session.getFoldAt(e, t, 1)
if (i) {
this.moveCursorTo(i.end.row, i.end.column)
return
}
this.session.nonTokenRe.exec(r) &&
((t += this.session.nonTokenRe.lastIndex),
(this.session.nonTokenRe.lastIndex = 0),
(r = n.substring(t)))
if (t >= n.length) {
this.moveCursorTo(e, n.length),
this.moveCursorRight(),
e < this.doc.getLength() - 1 && this.moveCursorWordRight()
return
}
this.session.tokenRe.exec(r) &&
((t += this.session.tokenRe.lastIndex), (this.session.tokenRe.lastIndex = 0)),
this.moveCursorTo(e, t)
}),
(this.moveCursorLongWordLeft = function () {
var e = this.lead.row,
t = this.lead.column,
n
if ((n = this.session.getFoldAt(e, t, -1))) {
this.moveCursorTo(n.start.row, n.start.column)
return
}
var r = this.session.getFoldStringAt(e, t, -1)
r == null && (r = this.doc.getLine(e).substring(0, t))
var s = i.stringReverse(r)
;(this.session.nonTokenRe.lastIndex = 0),
(this.session.tokenRe.lastIndex = 0),
this.session.nonTokenRe.exec(s) &&
((t -= this.session.nonTokenRe.lastIndex),
(s = s.slice(this.session.nonTokenRe.lastIndex)),
(this.session.nonTokenRe.lastIndex = 0))
if (t <= 0) {
this.moveCursorTo(e, 0), this.moveCursorLeft(), e > 0 && this.moveCursorWordLeft()
return
}
this.session.tokenRe.exec(s) &&
((t -= this.session.tokenRe.lastIndex), (this.session.tokenRe.lastIndex = 0)),
this.moveCursorTo(e, t)
}),
(this.$shortWordEndIndex = function (e) {
var t = 0,
n,
r = /\s/,
i = this.session.tokenRe
i.lastIndex = 0
if (this.session.tokenRe.exec(e)) t = this.session.tokenRe.lastIndex
else {
while ((n = e[t]) && r.test(n)) t++
if (t < 1) {
i.lastIndex = 0
while ((n = e[t]) && !i.test(n)) {
;(i.lastIndex = 0), t++
if (r.test(n)) {
if (t > 2) {
t--
break
}
while ((n = e[t]) && r.test(n)) t++
if (t > 2) break
}
}
}
}
return (i.lastIndex = 0), t
}),
(this.moveCursorShortWordRight = function () {
var e = this.lead.row,
t = this.lead.column,
n = this.doc.getLine(e),
r = n.substring(t),
i = this.session.getFoldAt(e, t, 1)
if (i) return this.moveCursorTo(i.end.row, i.end.column)
if (t == n.length) {
var s = this.doc.getLength()
do e++, (r = this.doc.getLine(e))
while (e < s && /^\s*$/.test(r))
;/^\s+/.test(r) || (r = ''), (t = 0)
}
var o = this.$shortWordEndIndex(r)
this.moveCursorTo(e, t + o)
}),
(this.moveCursorShortWordLeft = function () {
var e = this.lead.row,
t = this.lead.column,
n
if ((n = this.session.getFoldAt(e, t, -1)))
return this.moveCursorTo(n.start.row, n.start.column)
var r = this.session.getLine(e).substring(0, t)
if (t === 0) {
do e--, (r = this.doc.getLine(e))
while (e > 0 && /^\s*$/.test(r))
;(t = r.length), /\s+$/.test(r) || (r = '')
}
var s = i.stringReverse(r),
o = this.$shortWordEndIndex(s)
return this.moveCursorTo(e, t - o)
}),
(this.moveCursorWordRight = function () {
this.session.$selectLongWords
? this.moveCursorLongWordRight()
: this.moveCursorShortWordRight()
}),
(this.moveCursorWordLeft = function () {
this.session.$selectLongWords
? this.moveCursorLongWordLeft()
: this.moveCursorShortWordLeft()
}),
(this.moveCursorBy = function (e, t) {
var n = this.session.documentToScreenPosition(this.lead.row, this.lead.column),
r
t === 0 &&
(e !== 0 &&
(this.session.$bidiHandler.isBidiRow(n.row, this.lead.row)
? ((r = this.session.$bidiHandler.getPosLeft(n.column)),
(n.column = Math.round(r / this.session.$bidiHandler.charWidths[0])))
: (r = n.column * this.session.$bidiHandler.charWidths[0])),
this.$desiredColumn
? (n.column = this.$desiredColumn)
: (this.$desiredColumn = n.column))
if (e != 0 && this.session.lineWidgets && this.session.lineWidgets[this.lead.row]) {
var i = this.session.lineWidgets[this.lead.row]
e < 0 ? (e -= i.rowsAbove || 0) : e > 0 && (e += i.rowCount - (i.rowsAbove || 0))
}
var s = this.session.screenToDocumentPosition(n.row + e, n.column, r)
e !== 0 && t === 0 && s.row === this.lead.row && s.column === this.lead.column,
this.moveCursorTo(s.row, s.column + t, t === 0)
}),
(this.moveCursorToPosition = function (e) {
this.moveCursorTo(e.row, e.column)
}),
(this.moveCursorTo = function (e, t, n) {
var r = this.session.getFoldAt(e, t, 1)
r && ((e = r.start.row), (t = r.start.column)), (this.$keepDesiredColumnOnChange = !0)
var i = this.session.getLine(e)
;/[\uDC00-\uDFFF]/.test(i.charAt(t)) &&
i.charAt(t - 1) &&
(this.lead.row == e && this.lead.column == t + 1 ? (t -= 1) : (t += 1)),
this.lead.setPosition(e, t),
(this.$keepDesiredColumnOnChange = !1),
n || (this.$desiredColumn = null)
}),
(this.moveCursorToScreen = function (e, t, n) {
var r = this.session.screenToDocumentPosition(e, t)
this.moveCursorTo(r.row, r.column, n)
}),
(this.detach = function () {
this.lead.detach(), this.anchor.detach(), (this.session = this.doc = null)
}),
(this.fromOrientedRange = function (e) {
this.setSelectionRange(e, e.cursor == e.start),
(this.$desiredColumn = e.desiredColumn || this.$desiredColumn)
}),
(this.toOrientedRange = function (e) {
var t = this.getRange()
return (
e
? ((e.start.column = t.start.column),
(e.start.row = t.start.row),
(e.end.column = t.end.column),
(e.end.row = t.end.row))
: (e = t),
(e.cursor = this.isBackwards() ? e.start : e.end),
(e.desiredColumn = this.$desiredColumn),
e
)
}),
(this.getRangeOfMovements = function (e) {
var t = this.getCursor()
try {
e(this)
var n = this.getCursor()
return o.fromPoints(t, n)
} catch (r) {
return o.fromPoints(t, t)
} finally {
this.moveCursorToPosition(t)
}
}),
(this.toJSON = function () {
if (this.rangeCount)
var e = this.ranges.map(function (e) {
var t = e.clone()
return (t.isBackwards = e.cursor == e.start), t
})
else {
var e = this.getRange()
e.isBackwards = this.isBackwards()
}
return e
}),
(this.fromJSON = function (e) {
if (e.start == undefined) {
if (this.rangeList && e.length > 1) {
this.toSingleRange(e[0])
for (var t = e.length; t--; ) {
var n = o.fromPoints(e[t].start, e[t].end)
e[t].isBackwards && (n.cursor = n.start), this.addRange(n, !0)
}
return
}
e = e[0]
}
this.rangeList && this.toSingleRange(e), this.setSelectionRange(e, e.isBackwards)
}),
(this.isEqual = function (e) {
if ((e.length || this.rangeCount) && e.length != this.rangeCount) return !1
if (!e.length || !this.ranges) return this.getRange().isEqual(e)
for (var t = this.ranges.length; t--; ) if (!this.ranges[t].isEqual(e[t])) return !1
return !0
})
}).call(u.prototype),
(t.Selection = u)
}
),
ace.define('ace/tokenizer', ['require', 'exports', 'module', 'ace/config'], function (e, t, n) {
'use strict'
var r = e('./config'),
i = 2e3,
s = function (e) {
;(this.states = e), (this.regExps = {}), (this.matchMappings = {})
for (var t in this.states) {
var n = this.states[t],
r = [],
i = 0,
s = (this.matchMappings[t] = { defaultToken: 'text' }),
o = 'g',
u = []
for (var a = 0; a < n.length; a++) {
var f = n[a]
f.defaultToken && (s.defaultToken = f.defaultToken), f.caseInsensitive && (o = 'gi')
if (f.regex == null) continue
f.regex instanceof RegExp && (f.regex = f.regex.toString().slice(1, -1))
var l = f.regex,
c = new RegExp('(?:(' + l + ')|(.))').exec('a').length - 2
Array.isArray(f.token)
? f.token.length == 1 || c == 1
? (f.token = f.token[0])
: c - 1 != f.token.length
? (this.reportError("number of classes and regexp groups doesn't match", {
rule: f,
groupCount: c - 1,
}),
(f.token = f.token[0]))
: ((f.tokenArray = f.token), (f.token = null), (f.onMatch = this.$arrayTokens))
: typeof f.token == 'function' &&
!f.onMatch &&
(c > 1 ? (f.onMatch = this.$applyToken) : (f.onMatch = f.token)),
c > 1 &&
(/\\\d/.test(f.regex)
? (l = f.regex.replace(/\\([0-9]+)/g, function (e, t) {
return '\\' + (parseInt(t, 10) + i + 1)
}))
: ((c = 1), (l = this.removeCapturingGroups(f.regex))),
!f.splitRegex && typeof f.token != 'string' && u.push(f)),
(s[i] = a),
(i += c),
r.push(l),
f.onMatch || (f.onMatch = null)
}
r.length || ((s[0] = 0), r.push('$')),
u.forEach(function (e) {
e.splitRegex = this.createSplitterRegexp(e.regex, o)
}, this),
(this.regExps[t] = new RegExp('(' + r.join(')|(') + ')|($)', o))
}
}
;(function () {
;(this.$setMaxTokenCount = function (e) {
i = e | 0
}),
(this.$applyToken = function (e) {
var t = this.splitRegex.exec(e).slice(1),
n = this.token.apply(this, t)
if (typeof n == 'string') return [{ type: n, value: e }]
var r = []
for (var i = 0, s = n.length; i < s; i++)
t[i] && (r[r.length] = { type: n[i], value: t[i] })
return r
}),
(this.$arrayTokens = function (e) {
if (!e) return []
var t = this.splitRegex.exec(e)
if (!t) return 'text'
var n = [],
r = this.tokenArray
for (var i = 0, s = r.length; i < s; i++)
t[i + 1] && (n[n.length] = { type: r[i], value: t[i + 1] })
return n
}),
(this.removeCapturingGroups = function (e) {
var t = e.replace(/\\.|\[(?:\\.|[^\\\]])*|\(\?[:=!]|(\()/g, function (e, t) {
return t ? '(?:' : e
})
return t
}),
(this.createSplitterRegexp = function (e, t) {
if (e.indexOf('(?=') != -1) {
var n = 0,
r = !1,
i = {}
e.replace(/(\\.)|(\((?:\?[=!])?)|(\))|([\[\]])/g, function (e, t, s, o, u, a) {
return (
r
? (r = u != ']')
: u
? (r = !0)
: o
? (n == i.stack && ((i.end = a + 1), (i.stack = -1)), n--)
: s && (n++, s.length != 1 && ((i.stack = n), (i.start = a))),
e
)
}),
i.end != null &&
/^\)*$/.test(e.substr(i.end)) &&
(e = e.substring(0, i.start) + e.substr(i.end))
}
return (
e.charAt(0) != '^' && (e = '^' + e),
e.charAt(e.length - 1) != '$' && (e += '$'),
new RegExp(e, (t || '').replace('g', ''))
)
}),
(this.getLineTokens = function (e, t) {
if (t && typeof t != 'string') {
var n = t.slice(0)
;(t = n[0]), t === '#tmp' && (n.shift(), (t = n.shift()))
} else var n = []
var r = t || 'start',
s = this.states[r]
s || ((r = 'start'), (s = this.states[r]))
var o = this.matchMappings[r],
u = this.regExps[r]
u.lastIndex = 0
var a,
f = [],
l = 0,
c = 0,
h = { type: null, value: '' }
while ((a = u.exec(e))) {
var p = o.defaultToken,
d = null,
v = a[0],
m = u.lastIndex
if (m - v.length > l) {
var g = e.substring(l, m - v.length)
h.type == p ? (h.value += g) : (h.type && f.push(h), (h = { type: p, value: g }))
}
for (var y = 0; y < a.length - 2; y++) {
if (a[y + 1] === undefined) continue
;(d = s[o[y]]),
d.onMatch ? (p = d.onMatch(v, r, n, e)) : (p = d.token),
d.next &&
(typeof d.next == 'string' ? (r = d.next) : (r = d.next(r, n)),
(s = this.states[r]),
s ||
(this.reportError("state doesn't exist", r),
(r = 'start'),
(s = this.states[r])),
(o = this.matchMappings[r]),
(l = m),
(u = this.regExps[r]),
(u.lastIndex = m)),
d.consumeLineEnd && (l = m)
break
}
if (v)
if (typeof p == 'string')
(!!d && d.merge === !1) || h.type !== p
? (h.type && f.push(h), (h = { type: p, value: v }))
: (h.value += v)
else if (p) {
h.type && f.push(h), (h = { type: null, value: '' })
for (var y = 0; y < p.length; y++) f.push(p[y])
}
if (l == e.length) break
l = m
if (c++ > i) {
c > 2 * e.length &&
this.reportError('infinite loop with in ace tokenizer', { startState: t, line: e })
while (l < e.length)
h.type && f.push(h), (h = { value: e.substring(l, (l += 500)), type: 'overflow' })
;(r = 'start'), (n = [])
break
}
}
return (
h.type && f.push(h),
n.length > 1 && n[0] !== r && n.unshift('#tmp', r),
{ tokens: f, state: n.length ? n : r }
)
}),
(this.reportError = r.reportError)
}).call(s.prototype),
(t.Tokenizer = s)
}),
ace.define(
'ace/mode/text_highlight_rules',
['require', 'exports', 'module', 'ace/lib/lang'],
function (e, t, n) {
'use strict'
var r = e('../lib/lang'),
i = function () {
this.$rules = { start: [{ token: 'empty_line', regex: '^$' }, { defaultToken: 'text' }] }
}
;(function () {
;(this.addRules = function (e, t) {
if (!t) {
for (var n in e) this.$rules[n] = e[n]
return
}
for (var n in e) {
var r = e[n]
for (var i = 0; i < r.length; i++) {
var s = r[i]
if (s.next || s.onMatch)
typeof s.next == 'string' && s.next.indexOf(t) !== 0 && (s.next = t + s.next),
s.nextState && s.nextState.indexOf(t) !== 0 && (s.nextState = t + s.nextState)
}
this.$rules[t + n] = r
}
}),
(this.getRules = function () {
return this.$rules
}),
(this.embedRules = function (e, t, n, i, s) {
var o = typeof e == 'function' ? new e().getRules() : e
if (i) for (var u = 0; u < i.length; u++) i[u] = t + i[u]
else {
i = []
for (var a in o) i.push(t + a)
}
this.addRules(o, t)
if (n) {
var f = Array.prototype[s ? 'push' : 'unshift']
for (var u = 0; u < i.length; u++) f.apply(this.$rules[i[u]], r.deepCopy(n))
}
this.$embeds || (this.$embeds = []), this.$embeds.push(t)
}),
(this.getEmbeds = function () {
return this.$embeds
})
var e = function (e, t) {
return (e != 'start' || t.length) && t.unshift(this.nextState, e), this.nextState
},
t = function (e, t) {
return t.shift(), t.shift() || 'start'
}
;(this.normalizeRules = function () {
function i(s) {
var o = r[s]
o.processed = !0
for (var u = 0; u < o.length; u++) {
var a = o[u],
f = null
Array.isArray(a) && ((f = a), (a = {})),
!a.regex &&
a.start &&
((a.regex = a.start),
a.next || (a.next = []),
a.next.push(
{ defaultToken: a.token },
{ token: a.token + '.end', regex: a.end || a.start, next: 'pop' }
),
(a.token = a.token + '.start'),
(a.push = !0))
var l = a.next || a.push
if (l && Array.isArray(l)) {
var c = a.stateName
c || ((c = a.token), typeof c != 'string' && (c = c[0] || ''), r[c] && (c += n++)),
(r[c] = l),
(a.next = c),
i(c)
} else l == 'pop' && (a.next = t)
a.push && ((a.nextState = a.next || a.push), (a.next = e), delete a.push)
if (a.rules)
for (var h in a.rules)
r[h] ? r[h].push && r[h].push.apply(r[h], a.rules[h]) : (r[h] = a.rules[h])
var p = typeof a == 'string' ? a : a.include
p &&
(Array.isArray(p)
? (f = p.map(function (e) {
return r[e]
}))
: (f = r[p]))
if (f) {
var d = [u, 1].concat(f)
a.noEscape &&
(d = d.filter(function (e) {
return !e.next
})),
o.splice.apply(o, d),
u--
}
a.keywordMap &&
((a.token = this.createKeywordMapper(
a.keywordMap,
a.defaultToken || 'text',
a.caseInsensitive
)),
delete a.defaultToken)
}
}
var n = 0,
r = this.$rules
Object.keys(r).forEach(i, this)
}),
(this.createKeywordMapper = function (e, t, n, r) {
var i = Object.create(null)
return (
(this.$keywordList = []),
Object.keys(e).forEach(function (t) {
var s = e[t],
o = s.split(r || '|')
for (var u = o.length; u--; ) {
var a = o[u]
this.$keywordList.push(a), n && (a = a.toLowerCase()), (i[a] = t)
}
}, this),
(e = null),
n
? function (e) {
return i[e.toLowerCase()] || t
}
: function (e) {
return i[e] || t
}
)
}),
(this.getKeywords = function () {
return this.$keywords
})
}).call(i.prototype),
(t.TextHighlightRules = i)
}
),
ace.define('ace/mode/behaviour', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
var r = function () {
this.$behaviours = {}
}
;(function () {
;(this.add = function (e, t, n) {
switch (undefined) {
case this.$behaviours:
this.$behaviours = {}
case this.$behaviours[e]:
this.$behaviours[e] = {}
}
this.$behaviours[e][t] = n
}),
(this.addBehaviours = function (e) {
for (var t in e) for (var n in e[t]) this.add(t, n, e[t][n])
}),
(this.remove = function (e) {
this.$behaviours && this.$behaviours[e] && delete this.$behaviours[e]
}),
(this.inherit = function (e, t) {
if (typeof e == 'function') var n = new e().getBehaviours(t)
else var n = e.getBehaviours(t)
this.addBehaviours(n)
}),
(this.getBehaviours = function (e) {
if (!e) return this.$behaviours
var t = {}
for (var n = 0; n < e.length; n++)
this.$behaviours[e[n]] && (t[e[n]] = this.$behaviours[e[n]])
return t
})
}).call(r.prototype),
(t.Behaviour = r)
}),
ace.define(
'ace/token_iterator',
['require', 'exports', 'module', 'ace/range'],
function (e, t, n) {
'use strict'
var r = e('./range').Range,
i = function (e, t, n) {
;(this.$session = e), (this.$row = t), (this.$rowTokens = e.getTokens(t))
var r = e.getTokenAt(t, n)
this.$tokenIndex = r ? r.index : -1
}
;(function () {
;(this.stepBackward = function () {
this.$tokenIndex -= 1
while (this.$tokenIndex < 0) {
this.$row -= 1
if (this.$row < 0) return (this.$row = 0), null
;(this.$rowTokens = this.$session.getTokens(this.$row)),
(this.$tokenIndex = this.$rowTokens.length - 1)
}
return this.$rowTokens[this.$tokenIndex]
}),
(this.stepForward = function () {
this.$tokenIndex += 1
var e
while (this.$tokenIndex >= this.$rowTokens.length) {
;(this.$row += 1), e || (e = this.$session.getLength())
if (this.$row >= e) return (this.$row = e - 1), null
;(this.$rowTokens = this.$session.getTokens(this.$row)), (this.$tokenIndex = 0)
}
return this.$rowTokens[this.$tokenIndex]
}),
(this.getCurrentToken = function () {
return this.$rowTokens[this.$tokenIndex]
}),
(this.getCurrentTokenRow = function () {
return this.$row
}),
(this.getCurrentTokenColumn = function () {
var e = this.$rowTokens,
t = this.$tokenIndex,
n = e[t].start
if (n !== undefined) return n
n = 0
while (t > 0) (t -= 1), (n += e[t].value.length)
return n
}),
(this.getCurrentTokenPosition = function () {
return { row: this.$row, column: this.getCurrentTokenColumn() }
}),
(this.getCurrentTokenRange = function () {
var e = this.$rowTokens[this.$tokenIndex],
t = this.getCurrentTokenColumn()
return new r(this.$row, t, this.$row, t + e.value.length)
})
}).call(i.prototype),
(t.TokenIterator = i)
}
),
ace.define(
'ace/mode/behaviour/cstyle',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/mode/behaviour',
'ace/token_iterator',
'ace/lib/lang',
],
function (e, t, n) {
'use strict'
var r = e('../../lib/oop'),
i = e('../behaviour').Behaviour,
s = e('../../token_iterator').TokenIterator,
o = e('../../lib/lang'),
u = ['text', 'paren.rparen', 'rparen', 'paren', 'punctuation.operator'],
a = ['text', 'paren.rparen', 'rparen', 'paren', 'punctuation.operator', 'comment'],
f,
l = {},
c = { '"': '"', "'": "'" },
h = function (e) {
var t = -1
e.multiSelect &&
((t = e.selection.index),
l.rangeCount != e.multiSelect.rangeCount &&
(l = { rangeCount: e.multiSelect.rangeCount }))
if (l[t]) return (f = l[t])
f = l[t] = {
autoInsertedBrackets: 0,
autoInsertedRow: -1,
autoInsertedLineEnd: '',
maybeInsertedBrackets: 0,
maybeInsertedRow: -1,
maybeInsertedLineStart: '',
maybeInsertedLineEnd: '',
}
},
p = function (e, t, n, r) {
var i = e.end.row - e.start.row
return {
text: n + t + r,
selection: [0, e.start.column + 1, i, e.end.column + (i ? 0 : 1)],
}
},
d = function (e) {
this.add('braces', 'insertion', function (t, n, r, i, s) {
var u = r.getCursorPosition(),
a = i.doc.getLine(u.row)
if (s == '{') {
h(r)
var l = r.getSelectionRange(),
c = i.doc.getTextRange(l)
if (c !== '' && c !== '{' && r.getWrapBehavioursEnabled()) return p(l, c, '{', '}')
if (d.isSaneInsertion(r, i))
return /[\]\}\)]/.test(a[u.column]) || r.inMultiSelectMode || (e && e.braces)
? (d.recordAutoInsert(r, i, '}'), { text: '{}', selection: [1, 1] })
: (d.recordMaybeInsert(r, i, '{'), { text: '{', selection: [1, 1] })
} else if (s == '}') {
h(r)
var v = a.substring(u.column, u.column + 1)
if (v == '}') {
var m = i.$findOpeningBracket('}', { column: u.column + 1, row: u.row })
if (m !== null && d.isAutoInsertedClosing(u, a, s))
return d.popAutoInsertedClosing(), { text: '', selection: [1, 1] }
}
} else {
if (s == '\n' || s == '\r\n') {
h(r)
var g = ''
d.isMaybeInsertedClosing(u, a) &&
((g = o.stringRepeat('}', f.maybeInsertedBrackets)),
d.clearMaybeInsertedClosing())
var v = a.substring(u.column, u.column + 1)
if (v === '}') {
var y = i.findMatchingBracket({ row: u.row, column: u.column + 1 }, '}')
if (!y) return null
var b = this.$getIndent(i.getLine(y.row))
} else {
if (!g) {
d.clearMaybeInsertedClosing()
return
}
var b = this.$getIndent(a)
}
var w = b + i.getTabString()
return { text: '\n' + w + '\n' + b + g, selection: [1, w.length, 1, w.length] }
}
d.clearMaybeInsertedClosing()
}
}),
this.add('braces', 'deletion', function (e, t, n, r, i) {
var s = r.doc.getTextRange(i)
if (!i.isMultiLine() && s == '{') {
h(n)
var o = r.doc.getLine(i.start.row),
u = o.substring(i.end.column, i.end.column + 1)
if (u == '}') return i.end.column++, i
f.maybeInsertedBrackets--
}
}),
this.add('parens', 'insertion', function (e, t, n, r, i) {
if (i == '(') {
h(n)
var s = n.getSelectionRange(),
o = r.doc.getTextRange(s)
if (o !== '' && n.getWrapBehavioursEnabled()) return p(s, o, '(', ')')
if (d.isSaneInsertion(n, r))
return d.recordAutoInsert(n, r, ')'), { text: '()', selection: [1, 1] }
} else if (i == ')') {
h(n)
var u = n.getCursorPosition(),
a = r.doc.getLine(u.row),
f = a.substring(u.column, u.column + 1)
if (f == ')') {
var l = r.$findOpeningBracket(')', { column: u.column + 1, row: u.row })
if (l !== null && d.isAutoInsertedClosing(u, a, i))
return d.popAutoInsertedClosing(), { text: '', selection: [1, 1] }
}
}
}),
this.add('parens', 'deletion', function (e, t, n, r, i) {
var s = r.doc.getTextRange(i)
if (!i.isMultiLine() && s == '(') {
h(n)
var o = r.doc.getLine(i.start.row),
u = o.substring(i.start.column + 1, i.start.column + 2)
if (u == ')') return i.end.column++, i
}
}),
this.add('brackets', 'insertion', function (e, t, n, r, i) {
if (i == '[') {
h(n)
var s = n.getSelectionRange(),
o = r.doc.getTextRange(s)
if (o !== '' && n.getWrapBehavioursEnabled()) return p(s, o, '[', ']')
if (d.isSaneInsertion(n, r))
return d.recordAutoInsert(n, r, ']'), { text: '[]', selection: [1, 1] }
} else if (i == ']') {
h(n)
var u = n.getCursorPosition(),
a = r.doc.getLine(u.row),
f = a.substring(u.column, u.column + 1)
if (f == ']') {
var l = r.$findOpeningBracket(']', { column: u.column + 1, row: u.row })
if (l !== null && d.isAutoInsertedClosing(u, a, i))
return d.popAutoInsertedClosing(), { text: '', selection: [1, 1] }
}
}
}),
this.add('brackets', 'deletion', function (e, t, n, r, i) {
var s = r.doc.getTextRange(i)
if (!i.isMultiLine() && s == '[') {
h(n)
var o = r.doc.getLine(i.start.row),
u = o.substring(i.start.column + 1, i.start.column + 2)
if (u == ']') return i.end.column++, i
}
}),
this.add('string_dquotes', 'insertion', function (e, t, n, r, i) {
var s = r.$mode.$quotes || c
if (i.length == 1 && s[i]) {
if (this.lineCommentStart && this.lineCommentStart.indexOf(i) != -1) return
h(n)
var o = i,
u = n.getSelectionRange(),
a = r.doc.getTextRange(u)
if (a !== '' && (a.length != 1 || !s[a]) && n.getWrapBehavioursEnabled())
return p(u, a, o, o)
if (!a) {
var f = n.getCursorPosition(),
l = r.doc.getLine(f.row),
d = l.substring(f.column - 1, f.column),
v = l.substring(f.column, f.column + 1),
m = r.getTokenAt(f.row, f.column),
g = r.getTokenAt(f.row, f.column + 1)
if (d == '\\' && m && /escape/.test(m.type)) return null
var y = m && /string|escape/.test(m.type),
b = !g || /string|escape/.test(g.type),
w
if (v == o) (w = y !== b), w && /string\.end/.test(g.type) && (w = !1)
else {
if (y && !b) return null
if (y && b) return null
var E = r.$mode.tokenRe
E.lastIndex = 0
var S = E.test(d)
E.lastIndex = 0
var x = E.test(d)
if (S || x) return null
if (v && !/[\s;,.})\]\\]/.test(v)) return null
var T = l[f.column - 2]
if (!(d != o || (T != o && !E.test(T)))) return null
w = !0
}
return { text: w ? o + o : '', selection: [1, 1] }
}
}
}),
this.add('string_dquotes', 'deletion', function (e, t, n, r, i) {
var s = r.$mode.$quotes || c,
o = r.doc.getTextRange(i)
if (!i.isMultiLine() && s.hasOwnProperty(o)) {
h(n)
var u = r.doc.getLine(i.start.row),
a = u.substring(i.start.column + 1, i.start.column + 2)
if (a == o) return i.end.column++, i
}
})
}
;(d.isSaneInsertion = function (e, t) {
var n = e.getCursorPosition(),
r = new s(t, n.row, n.column)
if (!this.$matchTokenType(r.getCurrentToken() || 'text', u)) {
if (/[)}\]]/.test(e.session.getLine(n.row)[n.column])) return !0
var i = new s(t, n.row, n.column + 1)
if (!this.$matchTokenType(i.getCurrentToken() || 'text', u)) return !1
}
return (
r.stepForward(),
r.getCurrentTokenRow() !== n.row || this.$matchTokenType(r.getCurrentToken() || 'text', a)
)
}),
(d.$matchTokenType = function (e, t) {
return t.indexOf(e.type || e) > -1
}),
(d.recordAutoInsert = function (e, t, n) {
var r = e.getCursorPosition(),
i = t.doc.getLine(r.row)
this.isAutoInsertedClosing(r, i, f.autoInsertedLineEnd[0]) ||
(f.autoInsertedBrackets = 0),
(f.autoInsertedRow = r.row),
(f.autoInsertedLineEnd = n + i.substr(r.column)),
f.autoInsertedBrackets++
}),
(d.recordMaybeInsert = function (e, t, n) {
var r = e.getCursorPosition(),
i = t.doc.getLine(r.row)
this.isMaybeInsertedClosing(r, i) || (f.maybeInsertedBrackets = 0),
(f.maybeInsertedRow = r.row),
(f.maybeInsertedLineStart = i.substr(0, r.column) + n),
(f.maybeInsertedLineEnd = i.substr(r.column)),
f.maybeInsertedBrackets++
}),
(d.isAutoInsertedClosing = function (e, t, n) {
return (
f.autoInsertedBrackets > 0 &&
e.row === f.autoInsertedRow &&
n === f.autoInsertedLineEnd[0] &&
t.substr(e.column) === f.autoInsertedLineEnd
)
}),
(d.isMaybeInsertedClosing = function (e, t) {
return (
f.maybeInsertedBrackets > 0 &&
e.row === f.maybeInsertedRow &&
t.substr(e.column) === f.maybeInsertedLineEnd &&
t.substr(0, e.column) == f.maybeInsertedLineStart
)
}),
(d.popAutoInsertedClosing = function () {
;(f.autoInsertedLineEnd = f.autoInsertedLineEnd.substr(1)), f.autoInsertedBrackets--
}),
(d.clearMaybeInsertedClosing = function () {
f && ((f.maybeInsertedBrackets = 0), (f.maybeInsertedRow = -1))
}),
r.inherits(d, i),
(t.CstyleBehaviour = d)
}
),
ace.define('ace/unicode', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
var r = [
48, 9, 8, 25, 5, 0, 2, 25, 48, 0, 11, 0, 5, 0, 6, 22, 2, 30, 2, 457, 5, 11, 15, 4, 8, 0, 2,
0, 18, 116, 2, 1, 3, 3, 9, 0, 2, 2, 2, 0, 2, 19, 2, 82, 2, 138, 2, 4, 3, 155, 12, 37, 3, 0,
8, 38, 10, 44, 2, 0, 2, 1, 2, 1, 2, 0, 9, 26, 6, 2, 30, 10, 7, 61, 2, 9, 5, 101, 2, 7, 3, 9,
2, 18, 3, 0, 17, 58, 3, 100, 15, 53, 5, 0, 6, 45, 211, 57, 3, 18, 2, 5, 3, 11, 3, 9, 2, 1,
7, 6, 2, 2, 2, 7, 3, 1, 3, 21, 2, 6, 2, 0, 4, 3, 3, 8, 3, 1, 3, 3, 9, 0, 5, 1, 2, 4, 3, 11,
16, 2, 2, 5, 5, 1, 3, 21, 2, 6, 2, 1, 2, 1, 2, 1, 3, 0, 2, 4, 5, 1, 3, 2, 4, 0, 8, 3, 2, 0,
8, 15, 12, 2, 2, 8, 2, 2, 2, 21, 2, 6, 2, 1, 2, 4, 3, 9, 2, 2, 2, 2, 3, 0, 16, 3, 3, 9, 18,
2, 2, 7, 3, 1, 3, 21, 2, 6, 2, 1, 2, 4, 3, 8, 3, 1, 3, 2, 9, 1, 5, 1, 2, 4, 3, 9, 2, 0, 17,
1, 2, 5, 4, 2, 2, 3, 4, 1, 2, 0, 2, 1, 4, 1, 4, 2, 4, 11, 5, 4, 4, 2, 2, 3, 3, 0, 7, 0, 15,
9, 18, 2, 2, 7, 2, 2, 2, 22, 2, 9, 2, 4, 4, 7, 2, 2, 2, 3, 8, 1, 2, 1, 7, 3, 3, 9, 19, 1, 2,
7, 2, 2, 2, 22, 2, 9, 2, 4, 3, 8, 2, 2, 2, 3, 8, 1, 8, 0, 2, 3, 3, 9, 19, 1, 2, 7, 2, 2, 2,
22, 2, 15, 4, 7, 2, 2, 2, 3, 10, 0, 9, 3, 3, 9, 11, 5, 3, 1, 2, 17, 4, 23, 2, 8, 2, 0, 3, 6,
4, 0, 5, 5, 2, 0, 2, 7, 19, 1, 14, 57, 6, 14, 2, 9, 40, 1, 2, 0, 3, 1, 2, 0, 3, 0, 7, 3, 2,
6, 2, 2, 2, 0, 2, 0, 3, 1, 2, 12, 2, 2, 3, 4, 2, 0, 2, 5, 3, 9, 3, 1, 35, 0, 24, 1, 7, 9,
12, 0, 2, 0, 2, 0, 5, 9, 2, 35, 5, 19, 2, 5, 5, 7, 2, 35, 10, 0, 58, 73, 7, 77, 3, 37, 11,
42, 2, 0, 4, 328, 2, 3, 3, 6, 2, 0, 2, 3, 3, 40, 2, 3, 3, 32, 2, 3, 3, 6, 2, 0, 2, 3, 3, 14,
2, 56, 2, 3, 3, 66, 5, 0, 33, 15, 17, 84, 13, 619, 3, 16, 2, 25, 6, 74, 22, 12, 2, 6, 12,
20, 12, 19, 13, 12, 2, 2, 2, 1, 13, 51, 3, 29, 4, 0, 5, 1, 3, 9, 34, 2, 3, 9, 7, 87, 9, 42,
6, 69, 11, 28, 4, 11, 5, 11, 11, 39, 3, 4, 12, 43, 5, 25, 7, 10, 38, 27, 5, 62, 2, 28, 3,
10, 7, 9, 14, 0, 89, 75, 5, 9, 18, 8, 13, 42, 4, 11, 71, 55, 9, 9, 4, 48, 83, 2, 2, 30, 14,
230, 23, 280, 3, 5, 3, 37, 3, 5, 3, 7, 2, 0, 2, 0, 2, 0, 2, 30, 3, 52, 2, 6, 2, 0, 4, 2, 2,
6, 4, 3, 3, 5, 5, 12, 6, 2, 2, 6, 67, 1, 20, 0, 29, 0, 14, 0, 17, 4, 60, 12, 5, 0, 4, 11,
18, 0, 5, 0, 3, 9, 2, 0, 4, 4, 7, 0, 2, 0, 2, 0, 2, 3, 2, 10, 3, 3, 6, 4, 5, 0, 53, 1, 2684,
46, 2, 46, 2, 132, 7, 6, 15, 37, 11, 53, 10, 0, 17, 22, 10, 6, 2, 6, 2, 6, 2, 6, 2, 6, 2, 6,
2, 6, 2, 6, 2, 31, 48, 0, 470, 1, 36, 5, 2, 4, 6, 1, 5, 85, 3, 1, 3, 2, 2, 89, 2, 3, 6, 40,
4, 93, 18, 23, 57, 15, 513, 6581, 75, 20939, 53, 1164, 68, 45, 3, 268, 4, 27, 21, 31, 3, 13,
13, 1, 2, 24, 9, 69, 11, 1, 38, 8, 3, 102, 3, 1, 111, 44, 25, 51, 13, 68, 12, 9, 7, 23, 4,
0, 5, 45, 3, 35, 13, 28, 4, 64, 15, 10, 39, 54, 10, 13, 3, 9, 7, 22, 4, 1, 5, 66, 25, 2,
227, 42, 2, 1, 3, 9, 7, 11171, 13, 22, 5, 48, 8453, 301, 3, 61, 3, 105, 39, 6, 13, 4, 6, 11,
2, 12, 2, 4, 2, 0, 2, 1, 2, 1, 2, 107, 34, 362, 19, 63, 3, 53, 41, 11, 5, 15, 17, 6, 13, 1,
25, 2, 33, 4, 2, 134, 20, 9, 8, 25, 5, 0, 2, 25, 12, 88, 4, 5, 3, 5, 3, 5, 3, 2,
],
i = 0,
s = []
for (var o = 0; o < r.length; o += 2)
s.push((i += r[o])), r[o + 1] && s.push(45, (i += r[o + 1]))
t.wordChars = String.fromCharCode.apply(null, s)
}),
ace.define(
'ace/mode/text',
[
'require',
'exports',
'module',
'ace/config',
'ace/tokenizer',
'ace/mode/text_highlight_rules',
'ace/mode/behaviour/cstyle',
'ace/unicode',
'ace/lib/lang',
'ace/token_iterator',
'ace/range',
],
function (e, t, n) {
'use strict'
var r = e('../config'),
i = e('../tokenizer').Tokenizer,
s = e('./text_highlight_rules').TextHighlightRules,
o = e('./behaviour/cstyle').CstyleBehaviour,
u = e('../unicode'),
a = e('../lib/lang'),
f = e('../token_iterator').TokenIterator,
l = e('../range').Range,
c = function () {
this.HighlightRules = s
}
;(function () {
;(this.$defaultBehaviour = new o()),
(this.tokenRe = new RegExp('^[' + u.wordChars + '\\$_]+', 'g')),
(this.nonTokenRe = new RegExp('^(?:[^' + u.wordChars + '\\$_]|\\s])+', 'g')),
(this.getTokenizer = function () {
return (
this.$tokenizer ||
((this.$highlightRules =
this.$highlightRules || new this.HighlightRules(this.$highlightRuleConfig)),
(this.$tokenizer = new i(this.$highlightRules.getRules()))),
this.$tokenizer
)
}),
(this.lineCommentStart = ''),
(this.blockComment = ''),
(this.toggleCommentLines = function (e, t, n, r) {
function w(e) {
for (var t = n; t <= r; t++) e(i.getLine(t), t)
}
var i = t.doc,
s = !0,
o = !0,
u = Infinity,
f = t.getTabSize(),
l = !1
if (!this.lineCommentStart) {
if (!this.blockComment) return !1
var c = this.blockComment.start,
h = this.blockComment.end,
p = new RegExp('^(\\s*)(?:' + a.escapeRegExp(c) + ')'),
d = new RegExp('(?:' + a.escapeRegExp(h) + ')\\s*$'),
v = function (e, t) {
if (g(e, t)) return
if (!s || /\S/.test(e))
i.insertInLine({ row: t, column: e.length }, h),
i.insertInLine({ row: t, column: u }, c)
},
m = function (e, t) {
var n
;(n = e.match(d)) && i.removeInLine(t, e.length - n[0].length, e.length),
(n = e.match(p)) && i.removeInLine(t, n[1].length, n[0].length)
},
g = function (e, n) {
if (p.test(e)) return !0
var r = t.getTokens(n)
for (var i = 0; i < r.length; i++) if (r[i].type === 'comment') return !0
}
} else {
if (Array.isArray(this.lineCommentStart))
var p = this.lineCommentStart.map(a.escapeRegExp).join('|'),
c = this.lineCommentStart[0]
else
var p = a.escapeRegExp(this.lineCommentStart),
c = this.lineCommentStart
;(p = new RegExp('^(\\s*)(?:' + p + ') ?')), (l = t.getUseSoftTabs())
var m = function (e, t) {
var n = e.match(p)
if (!n) return
var r = n[1].length,
s = n[0].length
!b(e, r, s) && n[0][s - 1] == ' ' && s--, i.removeInLine(t, r, s)
},
y = c + ' ',
v = function (e, t) {
if (!s || /\S/.test(e))
b(e, u, u)
? i.insertInLine({ row: t, column: u }, y)
: i.insertInLine({ row: t, column: u }, c)
},
g = function (e, t) {
return p.test(e)
},
b = function (e, t, n) {
var r = 0
while (t-- && e.charAt(t) == ' ') r++
if (r % f != 0) return !1
var r = 0
while (e.charAt(n++) == ' ') r++
return f > 2 ? r % f != f - 1 : r % f == 0
}
}
var E = Infinity
w(function (e, t) {
var n = e.search(/\S/)
n !== -1
? (n < u && (u = n), o && !g(e, t) && (o = !1))
: E > e.length && (E = e.length)
}),
u == Infinity && ((u = E), (s = !1), (o = !1)),
l && u % f != 0 && (u = Math.floor(u / f) * f),
w(o ? m : v)
}),
(this.toggleBlockComment = function (e, t, n, r) {
var i = this.blockComment
if (!i) return
!i.start && i[0] && (i = i[0])
var s = new f(t, r.row, r.column),
o = s.getCurrentToken(),
u = t.selection,
a = t.selection.toOrientedRange(),
c,
h
if (o && /comment/.test(o.type)) {
var p, d
while (o && /comment/.test(o.type)) {
var v = o.value.indexOf(i.start)
if (v != -1) {
var m = s.getCurrentTokenRow(),
g = s.getCurrentTokenColumn() + v
p = new l(m, g, m, g + i.start.length)
break
}
o = s.stepBackward()
}
var s = new f(t, r.row, r.column),
o = s.getCurrentToken()
while (o && /comment/.test(o.type)) {
var v = o.value.indexOf(i.end)
if (v != -1) {
var m = s.getCurrentTokenRow(),
g = s.getCurrentTokenColumn() + v
d = new l(m, g, m, g + i.end.length)
break
}
o = s.stepForward()
}
d && t.remove(d), p && (t.remove(p), (c = p.start.row), (h = -i.start.length))
} else
(h = i.start.length),
(c = n.start.row),
t.insert(n.end, i.end),
t.insert(n.start, i.start)
a.start.row == c && (a.start.column += h),
a.end.row == c && (a.end.column += h),
t.selection.fromOrientedRange(a)
}),
(this.getNextLineIndent = function (e, t, n) {
return this.$getIndent(t)
}),
(this.checkOutdent = function (e, t, n) {
return !1
}),
(this.autoOutdent = function (e, t, n) {}),
(this.$getIndent = function (e) {
return e.match(/^\s*/)[0]
}),
(this.createWorker = function (e) {
return null
}),
(this.createModeDelegates = function (e) {
;(this.$embeds = []), (this.$modes = {})
for (var t in e)
if (e[t]) {
var n = e[t],
i = n.prototype.$id,
s = r.$modes[i]
s || (r.$modes[i] = s = new n()),
r.$modes[t] || (r.$modes[t] = s),
this.$embeds.push(t),
(this.$modes[t] = s)
}
var o = [
'toggleBlockComment',
'toggleCommentLines',
'getNextLineIndent',
'checkOutdent',
'autoOutdent',
'transformAction',
'getCompletions',
]
for (var t = 0; t < o.length; t++)
(function (e) {
var n = o[t],
r = e[n]
e[o[t]] = function () {
return this.$delegator(n, arguments, r)
}
})(this)
}),
(this.$delegator = function (e, t, n) {
var r = t[0] || 'start'
if (typeof r != 'string') {
if (Array.isArray(r[2])) {
var i = r[2][r[2].length - 1],
s = this.$modes[i]
if (s) return s[e].apply(s, [r[1]].concat([].slice.call(t, 1)))
}
r = r[0] || 'start'
}
for (var o = 0; o < this.$embeds.length; o++) {
if (!this.$modes[this.$embeds[o]]) continue
var u = r.split(this.$embeds[o])
if (!u[0] && u[1]) {
t[0] = u[1]
var s = this.$modes[this.$embeds[o]]
return s[e].apply(s, t)
}
}
var a = n.apply(this, t)
return n ? a : undefined
}),
(this.transformAction = function (e, t, n, r, i) {
if (this.$behaviour) {
var s = this.$behaviour.getBehaviours()
for (var o in s)
if (s[o][t]) {
var u = s[o][t].apply(this, arguments)
if (u) return u
}
}
}),
(this.getKeywords = function (e) {
if (!this.completionKeywords) {
var t = this.$tokenizer.rules,
n = []
for (var r in t) {
var i = t[r]
for (var s = 0, o = i.length; s < o; s++)
if (typeof i[s].token == 'string')
/keyword|support|storage/.test(i[s].token) && n.push(i[s].regex)
else if (typeof i[s].token == 'object')
for (var u = 0, a = i[s].token.length; u < a; u++)
if (/keyword|support|storage/.test(i[s].token[u])) {
var r = i[s].regex.match(/\(.+?\)/g)[u]
n.push(r.substr(1, r.length - 2))
}
}
this.completionKeywords = n
}
return e ? n.concat(this.$keywordList || []) : this.$keywordList
}),
(this.$createKeywordList = function () {
return (
this.$highlightRules || this.getTokenizer(),
(this.$keywordList = this.$highlightRules.$keywordList || [])
)
}),
(this.getCompletions = function (e, t, n, r) {
var i = this.$keywordList || this.$createKeywordList()
return i.map(function (e) {
return { name: e, value: e, score: 0, meta: 'keyword' }
})
}),
(this.$id = 'ace/mode/text')
}).call(c.prototype),
(t.Mode = c)
}
),
ace.define('ace/apply_delta', ['require', 'exports', 'module'], function (e, t, n) {
'use strict'
function r(e, t) {
throw (console.log('Invalid Delta:', e), 'Invalid Delta: ' + t)
}
function i(e, t) {
return t.row >= 0 && t.row < e.length && t.column >= 0 && t.column <= e[t.row].length
}
function s(e, t) {
t.action != 'insert' &&
t.action != 'remove' &&
r(t, "delta.action must be 'insert' or 'remove'"),
t.lines instanceof Array || r(t, 'delta.lines must be an Array'),
(!t.start || !t.end) && r(t, 'delta.start/end must be an present')
var n = t.start
i(e, t.start) || r(t, 'delta.start must be contained in document')
var s = t.end
t.action == 'remove' &&
!i(e, s) &&
r(t, "delta.end must contained in document for 'remove' actions")
var o = s.row - n.row,
u = s.column - (o == 0 ? n.column : 0)
;(o != t.lines.length - 1 || t.lines[o].length != u) &&
r(t, 'delta.range must match delta lines')
}
t.applyDelta = function (e, t, n) {
var r = t.start.row,
i = t.start.column,
s = e[r] || ''
switch (t.action) {
case 'insert':
var o = t.lines
if (o.length === 1) e[r] = s.substring(0, i) + t.lines[0] + s.substring(i)
else {
var u = [r, 1].concat(t.lines)
e.splice.apply(e, u),
(e[r] = s.substring(0, i) + e[r]),
(e[r + t.lines.length - 1] += s.substring(i))
}
break
case 'remove':
var a = t.end.column,
f = t.end.row
r === f
? (e[r] = s.substring(0, i) + s.substring(a))
: e.splice(r, f - r + 1, s.substring(0, i) + e[f].substring(a))
}
}
}),
ace.define(
'ace/anchor',
['require', 'exports', 'module', 'ace/lib/oop', 'ace/lib/event_emitter'],
function (e, t, n) {
'use strict'
var r = e('./lib/oop'),
i = e('./lib/event_emitter').EventEmitter,
s = (t.Anchor = function (e, t, n) {
;(this.$onChange = this.onChange.bind(this)),
this.attach(e),
typeof n == 'undefined' ? this.setPosition(t.row, t.column) : this.setPosition(t, n)
})
;(function () {
function e(e, t, n) {
var r = n ? e.column <= t.column : e.column < t.column
return e.row < t.row || (e.row == t.row && r)
}
function t(t, n, r) {
var i = t.action == 'insert',
s = (i ? 1 : -1) * (t.end.row - t.start.row),
o = (i ? 1 : -1) * (t.end.column - t.start.column),
u = t.start,
a = i ? u : t.end
return e(n, u, r)
? { row: n.row, column: n.column }
: e(a, n, !r)
? { row: n.row + s, column: n.column + (n.row == a.row ? o : 0) }
: { row: u.row, column: u.column }
}
r.implement(this, i),
(this.getPosition = function () {
return this.$clipPositionToDocument(this.row, this.column)
}),
(this.getDocument = function () {
return this.document
}),
(this.$insertRight = !1),
(this.onChange = function (e) {
if (e.start.row == e.end.row && e.start.row != this.row) return
if (e.start.row > this.row) return
var n = t(e, { row: this.row, column: this.column }, this.$insertRight)
this.setPosition(n.row, n.column, !0)
}),
(this.setPosition = function (e, t, n) {
var r
n ? (r = { row: e, column: t }) : (r = this.$clipPositionToDocument(e, t))
if (this.row == r.row && this.column == r.column) return
var i = { row: this.row, column: this.column }
;(this.row = r.row),
(this.column = r.column),
this._signal('change', { old: i, value: r })
}),
(this.detach = function () {
this.document.off('change', this.$onChange)
}),
(this.attach = function (e) {
;(this.document = e || this.document), this.document.on('change', this.$onChange)
}),
(this.$clipPositionToDocument = function (e, t) {
var n = {}
return (
e >= this.document.getLength()
? ((n.row = Math.max(0, this.document.getLength() - 1)),
(n.column = this.document.getLine(n.row).length))
: e < 0
? ((n.row = 0), (n.column = 0))
: ((n.row = e),
(n.column = Math.min(this.document.getLine(n.row).length, Math.max(0, t)))),
t < 0 && (n.column = 0),
n
)
})
}).call(s.prototype)
}
),
ace.define(
'ace/document',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/apply_delta',
'ace/lib/event_emitter',
'ace/range',
'ace/anchor',
],
function (e, t, n) {
'use strict'
var r = e('./lib/oop'),
i = e('./apply_delta').applyDelta,
s = e('./lib/event_emitter').EventEmitter,
o = e('./range').Range,
u = e('./anchor').Anchor,
a = function (e) {
;(this.$lines = ['']),
e.length === 0
? (this.$lines = [''])
: Array.isArray(e)
? this.insertMergedLines({ row: 0, column: 0 }, e)
: this.insert({ row: 0, column: 0 }, e)
}
;(function () {
r.implement(this, s),
(this.setValue = function (e) {
var t = this.getLength() - 1
this.remove(new o(0, 0, t, this.getLine(t).length)),
this.insert({ row: 0, column: 0 }, e)
}),
(this.getValue = function () {
return this.getAllLines().join(this.getNewLineCharacter())
}),
(this.createAnchor = function (e, t) {
return new u(this, e, t)
}),
'aaa'.split(/a/).length === 0
? (this.$split = function (e) {
return e.replace(/\r\n|\r/g, '\n').split('\n')
})
: (this.$split = function (e) {
return e.split(/\r\n|\r|\n/)
}),
(this.$detectNewLine = function (e) {
var t = e.match(/^.*?(\r\n|\r|\n)/m)
;(this.$autoNewLine = t ? t[1] : '\n'), this._signal('changeNewLineMode')
}),
(this.getNewLineCharacter = function () {
switch (this.$newLineMode) {
case 'windows':
return '\r\n'
case 'unix':
return '\n'
default:
return this.$autoNewLine || '\n'
}
}),
(this.$autoNewLine = ''),
(this.$newLineMode = 'auto'),
(this.setNewLineMode = function (e) {
if (this.$newLineMode === e) return
;(this.$newLineMode = e), this._signal('changeNewLineMode')
}),
(this.getNewLineMode = function () {
return this.$newLineMode
}),
(this.isNewLine = function (e) {
return e == '\r\n' || e == '\r' || e == '\n'
}),
(this.getLine = function (e) {
return this.$lines[e] || ''
}),
(this.getLines = function (e, t) {
return this.$lines.slice(e, t + 1)
}),
(this.getAllLines = function () {
return this.getLines(0, this.getLength())
}),
(this.getLength = function () {
return this.$lines.length
}),
(this.getTextRange = function (e) {
return this.getLinesForRange(e).join(this.getNewLineCharacter())
}),
(this.getLinesForRange = function (e) {
var t
if (e.start.row === e.end.row)
t = [this.getLine(e.start.row).substring(e.start.column, e.end.column)]
else {
;(t = this.getLines(e.start.row, e.end.row)),
(t[0] = (t[0] || '').substring(e.start.column))
var n = t.length - 1
e.end.row - e.start.row == n && (t[n] = t[n].substring(0, e.end.column))
}
return t
}),
(this.insertLines = function (e, t) {
return (
console.warn(
'Use of document.insertLines is deprecated. Use the insertFullLines method instead.'
),
this.insertFullLines(e, t)
)
}),
(this.removeLines = function (e, t) {
return (
console.warn(
'Use of document.removeLines is deprecated. Use the removeFullLines method instead.'
),
this.removeFullLines(e, t)
)
}),
(this.insertNewLine = function (e) {
return (
console.warn(
"Use of document.insertNewLine is deprecated. Use insertMergedLines(position, ['', '']) instead."
),
this.insertMergedLines(e, ['', ''])
)
}),
(this.insert = function (e, t) {
return (
this.getLength() <= 1 && this.$detectNewLine(t),
this.insertMergedLines(e, this.$split(t))
)
}),
(this.insertInLine = function (e, t) {
var n = this.clippedPos(e.row, e.column),
r = this.pos(e.row, e.column + t.length)
return (
this.applyDelta({ start: n, end: r, action: 'insert', lines: [t] }, !0),
this.clonePos(r)
)
}),
(this.clippedPos = function (e, t) {
var n = this.getLength()
e === undefined ? (e = n) : e < 0 ? (e = 0) : e >= n && ((e = n - 1), (t = undefined))
var r = this.getLine(e)
return (
t == undefined && (t = r.length),
(t = Math.min(Math.max(t, 0), r.length)),
{ row: e, column: t }
)
}),
(this.clonePos = function (e) {
return { row: e.row, column: e.column }
}),
(this.pos = function (e, t) {
return { row: e, column: t }
}),
(this.$clipPosition = function (e) {
var t = this.getLength()
return (
e.row >= t
? ((e.row = Math.max(0, t - 1)), (e.column = this.getLine(t - 1).length))
: ((e.row = Math.max(0, e.row)),
(e.column = Math.min(Math.max(e.column, 0), this.getLine(e.row).length))),
e
)
}),
(this.insertFullLines = function (e, t) {
e = Math.min(Math.max(e, 0), this.getLength())
var n = 0
e < this.getLength()
? ((t = t.concat([''])), (n = 0))
: ((t = [''].concat(t)), e--, (n = this.$lines[e].length)),
this.insertMergedLines({ row: e, column: n }, t)
}),
(this.insertMergedLines = function (e, t) {
var n = this.clippedPos(e.row, e.column),
r = {
row: n.row + t.length - 1,
column: (t.length == 1 ? n.column : 0) + t[t.length - 1].length,
}
return (
this.applyDelta({ start: n, end: r, action: 'insert', lines: t }), this.clonePos(r)
)
}),
(this.remove = function (e) {
var t = this.clippedPos(e.start.row, e.start.column),
n = this.clippedPos(e.end.row, e.end.column)
return (
this.applyDelta({
start: t,
end: n,
action: 'remove',
lines: this.getLinesForRange({ start: t, end: n }),
}),
this.clonePos(t)
)
}),
(this.removeInLine = function (e, t, n) {
var r = this.clippedPos(e, t),
i = this.clippedPos(e, n)
return (
this.applyDelta(
{
start: r,
end: i,
action: 'remove',
lines: this.getLinesForRange({ start: r, end: i }),
},
!0
),
this.clonePos(r)
)
}),
(this.removeFullLines = function (e, t) {
;(e = Math.min(Math.max(0, e), this.getLength() - 1)),
(t = Math.min(Math.max(0, t), this.getLength() - 1))
var n = t == this.getLength() - 1 && e > 0,
r = t < this.getLength() - 1,
i = n ? e - 1 : e,
s = n ? this.getLine(i).length : 0,
u = r ? t + 1 : t,
a = r ? 0 : this.getLine(u).length,
f = new o(i, s, u, a),
l = this.$lines.slice(e, t + 1)
return (
this.applyDelta({
start: f.start,
end: f.end,
action: 'remove',
lines: this.getLinesForRange(f),
}),
l
)
}),
(this.removeNewLine = function (e) {
e < this.getLength() - 1 &&
e >= 0 &&
this.applyDelta({
start: this.pos(e, this.getLine(e).length),
end: this.pos(e + 1, 0),
action: 'remove',
lines: ['', ''],
})
}),
(this.replace = function (e, t) {
e instanceof o || (e = o.fromPoints(e.start, e.end))
if (t.length === 0 && e.isEmpty()) return e.start
if (t == this.getTextRange(e)) return e.end
this.remove(e)
var n
return t ? (n = this.insert(e.start, t)) : (n = e.start), n
}),
(this.applyDeltas = function (e) {
for (var t = 0; t < e.length; t++) this.applyDelta(e[t])
}),
(this.revertDeltas = function (e) {
for (var t = e.length - 1; t >= 0; t--) this.revertDelta(e[t])
}),
(this.applyDelta = function (e, t) {
var n = e.action == 'insert'
if (n ? e.lines.length <= 1 && !e.lines[0] : !o.comparePoints(e.start, e.end)) return
n && e.lines.length > 2e4
? this.$splitAndapplyLargeDelta(e, 2e4)
: (i(this.$lines, e, t), this._signal('change', e))
}),
(this.$safeApplyDelta = function (e) {
var t = this.$lines.length
;((e.action == 'remove' && e.start.row < t && e.end.row < t) ||
(e.action == 'insert' && e.start.row <= t)) &&
this.applyDelta(e)
}),
(this.$splitAndapplyLargeDelta = function (e, t) {
var n = e.lines,
r = n.length - t + 1,
i = e.start.row,
s = e.start.column
for (var o = 0, u = 0; o < r; o = u) {
u += t - 1
var a = n.slice(o, u)
a.push(''),
this.applyDelta(
{
start: this.pos(i + o, s),
end: this.pos(i + u, (s = 0)),
action: e.action,
lines: a,
},
!0
)
}
;(e.lines = n.slice(o)),
(e.start.row = i + o),
(e.start.column = s),
this.applyDelta(e, !0)
}),
(this.revertDelta = function (e) {
this.$safeApplyDelta({
start: this.clonePos(e.start),
end: this.clonePos(e.end),
action: e.action == 'insert' ? 'remove' : 'insert',
lines: e.lines.slice(),
})
}),
(this.indexToPosition = function (e, t) {
var n = this.$lines || this.getAllLines(),
r = this.getNewLineCharacter().length
for (var i = t || 0, s = n.length; i < s; i++) {
e -= n[i].length + r
if (e < 0) return { row: i, column: e + n[i].length + r }
}
return { row: s - 1, column: e + n[s - 1].length + r }
}),
(this.positionToIndex = function (e, t) {
var n = this.$lines || this.getAllLines(),
r = this.getNewLineCharacter().length,
i = 0,
s = Math.min(e.row, n.length)
for (var o = t || 0; o < s; ++o) i += n[o].length + r
return i + e.column
})
}).call(a.prototype),
(t.Document = a)
}
),
ace.define(
'ace/background_tokenizer',
['require', 'exports', 'module', 'ace/lib/oop', 'ace/lib/event_emitter'],
function (e, t, n) {
'use strict'
var r = e('./lib/oop'),
i = e('./lib/event_emitter').EventEmitter,
s = function (e, t) {
;(this.running = !1),
(this.lines = []),
(this.states = []),
(this.currentLine = 0),
(this.tokenizer = e)
var n = this
this.$worker = function () {
if (!n.running) return
var e = new Date(),
t = n.currentLine,
r = -1,
i = n.doc,
s = t
while (n.lines[t]) t++
var o = i.getLength(),
u = 0
n.running = !1
while (t < o) {
n.$tokenizeRow(t), (r = t)
do t++
while (n.lines[t])
u++
if (u % 5 === 0 && new Date() - e > 20) {
n.running = setTimeout(n.$worker, 20)
break
}
}
;(n.currentLine = t), r == -1 && (r = t), s <= r && n.fireUpdateEvent(s, r)
}
}
;(function () {
r.implement(this, i),
(this.setTokenizer = function (e) {
;(this.tokenizer = e), (this.lines = []), (this.states = []), this.start(0)
}),
(this.setDocument = function (e) {
;(this.doc = e), (this.lines = []), (this.states = []), this.stop()
}),
(this.fireUpdateEvent = function (e, t) {
var n = { first: e, last: t }
this._signal('update', { data: n })
}),
(this.start = function (e) {
;(this.currentLine = Math.min(e || 0, this.currentLine, this.doc.getLength())),
this.lines.splice(this.currentLine, this.lines.length),
this.states.splice(this.currentLine, this.states.length),
this.stop(),
(this.running = setTimeout(this.$worker, 700))
}),
(this.scheduleStart = function () {
this.running || (this.running = setTimeout(this.$worker, 700))
}),
(this.$updateOnChange = function (e) {
var t = e.start.row,
n = e.end.row - t
if (n === 0) this.lines[t] = null
else if (e.action == 'remove')
this.lines.splice(t, n + 1, null), this.states.splice(t, n + 1, null)
else {
var r = Array(n + 1)
r.unshift(t, 1),
this.lines.splice.apply(this.lines, r),
this.states.splice.apply(this.states, r)
}
;(this.currentLine = Math.min(t, this.currentLine, this.doc.getLength())), this.stop()
}),
(this.stop = function () {
this.running && clearTimeout(this.running), (this.running = !1)
}),
(this.getTokens = function (e) {
return this.lines[e] || this.$tokenizeRow(e)
}),
(this.getState = function (e) {
return this.currentLine == e && this.$tokenizeRow(e), this.states[e] || 'start'
}),
(this.$tokenizeRow = function (e) {
var t = this.doc.getLine(e),
n = this.states[e - 1],
r = this.tokenizer.getLineTokens(t, n, e)
return (
this.states[e] + '' != r.state + ''
? ((this.states[e] = r.state),
(this.lines[e + 1] = null),
this.currentLine > e + 1 && (this.currentLine = e + 1))
: this.currentLine == e && (this.currentLine = e + 1),
(this.lines[e] = r.tokens)
)
})
}).call(s.prototype),
(t.BackgroundTokenizer = s)
}
),
ace.define(
'ace/search_highlight',
['require', 'exports', 'module', 'ace/lib/lang', 'ace/lib/oop', 'ace/range'],
function (e, t, n) {
'use strict'
var r = e('./lib/lang'),
i = e('./lib/oop'),
s = e('./range').Range,
o = function (e, t, n) {
this.setRegexp(e), (this.clazz = t), (this.type = n || 'text')
}
;(function () {
;(this.MAX_RANGES = 500),
(this.setRegexp = function (e) {
if (this.regExp + '' == e + '') return
;(this.regExp = e), (this.cache = [])
}),
(this.update = function (e, t, n, i) {
if (!this.regExp) return
var o = i.firstRow,
u = i.lastRow
for (var a = o; a <= u; a++) {
var f = this.cache[a]
f == null &&
((f = r.getMatchOffsets(n.getLine(a), this.regExp)),
f.length > this.MAX_RANGES && (f = f.slice(0, this.MAX_RANGES)),
(f = f.map(function (e) {
return new s(a, e.offset, a, e.offset + e.length)
})),
(this.cache[a] = f.length ? f : ''))
for (var l = f.length; l--; )
t.drawSingleLineMarker(e, f[l].toScreenRange(n), this.clazz, i)
}
})
}).call(o.prototype),
(t.SearchHighlight = o)
}
),
ace.define(
'ace/edit_session/fold_line',
['require', 'exports', 'module', 'ace/range'],
function (e, t, n) {
'use strict'
function i(e, t) {
;(this.foldData = e), Array.isArray(t) ? (this.folds = t) : (t = this.folds = [t])
var n = t[t.length - 1]
;(this.range = new r(t[0].start.row, t[0].start.column, n.end.row, n.end.column)),
(this.start = this.range.start),
(this.end = this.range.end),
this.folds.forEach(function (e) {
e.setFoldLine(this)
}, this)
}
var r = e('../range').Range
;(function () {
;(this.shiftRow = function (e) {
;(this.start.row += e),
(this.end.row += e),
this.folds.forEach(function (t) {
;(t.start.row += e), (t.end.row += e)
})
}),
(this.addFold = function (e) {
if (e.sameRow) {
if (e.start.row < this.startRow || e.endRow > this.endRow)
throw new Error("Can't add a fold to this FoldLine as it has no connection")
this.folds.push(e),
this.folds.sort(function (e, t) {
return -e.range.compareEnd(t.start.row, t.start.column)
}),
this.range.compareEnd(e.start.row, e.start.column) > 0
? ((this.end.row = e.end.row), (this.end.column = e.end.column))
: this.range.compareStart(e.end.row, e.end.column) < 0 &&
((this.start.row = e.start.row), (this.start.column = e.start.column))
} else if (e.start.row == this.end.row)
this.folds.push(e), (this.end.row = e.end.row), (this.end.column = e.end.column)
else {
if (e.end.row != this.start.row)
throw new Error("Trying to add fold to FoldRow that doesn't have a matching row")
this.folds.unshift(e),
(this.start.row = e.start.row),
(this.start.column = e.start.column)
}
e.foldLine = this
}),
(this.containsRow = function (e) {
return e >= this.start.row && e <= this.end.row
}),
(this.walk = function (e, t, n) {
var r = 0,
i = this.folds,
s,
o,
u,
a = !0
t == null && ((t = this.end.row), (n = this.end.column))
for (var f = 0; f < i.length; f++) {
;(s = i[f]), (o = s.range.compareStart(t, n))
if (o == -1) {
e(null, t, n, r, a)
return
}
;(u = e(null, s.start.row, s.start.column, r, a)),
(u = !u && e(s.placeholder, s.start.row, s.start.column, r))
if (u || o === 0) return
;(a = !s.sameRow), (r = s.end.column)
}
e(null, t, n, r, a)
}),
(this.getNextFoldTo = function (e, t) {
var n, r
for (var i = 0; i < this.folds.length; i++) {
;(n = this.folds[i]), (r = n.range.compareEnd(e, t))
if (r == -1) return { fold: n, kind: 'after' }
if (r === 0) return { fold: n, kind: 'inside' }
}
return null
}),
(this.addRemoveChars = function (e, t, n) {
var r = this.getNextFoldTo(e, t),
i,
s
if (r) {
i = r.fold
if (r.kind == 'inside' && i.start.column != t && i.start.row != e)
window.console && window.console.log(e, t, i)
else if (i.start.row == e) {
s = this.folds
var o = s.indexOf(i)
o === 0 && (this.start.column += n)
for (o; o < s.length; o++) {
;(i = s[o]), (i.start.column += n)
if (!i.sameRow) return
i.end.column += n
}
this.end.column += n
}
}
}),
(this.split = function (e, t) {
var n = this.getNextFoldTo(e, t)
if (!n || n.kind == 'inside') return null
var r = n.fold,
s = this.folds,
o = this.foldData,
u = s.indexOf(r),
a = s[u - 1]
;(this.end.row = a.end.row),
(this.end.column = a.end.column),
(s = s.splice(u, s.length - u))
var f = new i(o, s)
return o.splice(o.indexOf(this) + 1, 0, f), f
}),
(this.merge = function (e) {
var t = e.folds
for (var n = 0; n < t.length; n++) this.addFold(t[n])
var r = this.foldData
r.splice(r.indexOf(e), 1)
}),
(this.toString = function () {
var e = [this.range.toString() + ': [']
return (
this.folds.forEach(function (t) {
e.push(' ' + t.toString())
}),
e.push(']'),
e.join('\n')
)
}),
(this.idxToPosition = function (e) {
var t = 0
for (var n = 0; n < this.folds.length; n++) {
var r = this.folds[n]
e -= r.start.column - t
if (e < 0) return { row: r.start.row, column: r.start.column + e }
e -= r.placeholder.length
if (e < 0) return r.start
t = r.end.column
}
return { row: this.end.row, column: this.end.column + e }
})
}).call(i.prototype),
(t.FoldLine = i)
}
),
ace.define('ace/range_list', ['require', 'exports', 'module', 'ace/range'], function (e, t, n) {
'use strict'
var r = e('./range').Range,
i = r.comparePoints,
s = function () {
;(this.ranges = []), (this.$bias = 1)
}
;(function () {
;(this.comparePoints = i),
(this.pointIndex = function (e, t, n) {
var r = this.ranges
for (var s = n || 0; s < r.length; s++) {
var o = r[s],
u = i(e, o.end)
if (u > 0) continue
var a = i(e, o.start)
return u === 0 ? (t && a !== 0 ? -s - 2 : s) : a > 0 || (a === 0 && !t) ? s : -s - 1
}
return -s - 1
}),
(this.add = function (e) {
var t = !e.isEmpty(),
n = this.pointIndex(e.start, t)
n < 0 && (n = -n - 1)
var r = this.pointIndex(e.end, t, n)
return r < 0 ? (r = -r - 1) : r++, this.ranges.splice(n, r - n, e)
}),
(this.addList = function (e) {
var t = []
for (var n = e.length; n--; ) t.push.apply(t, this.add(e[n]))
return t
}),
(this.substractPoint = function (e) {
var t = this.pointIndex(e)
if (t >= 0) return this.ranges.splice(t, 1)
}),
(this.merge = function () {
var e = [],
t = this.ranges
t = t.sort(function (e, t) {
return i(e.start, t.start)
})
var n = t[0],
r
for (var s = 1; s < t.length; s++) {
;(r = n), (n = t[s])
var o = i(r.end, n.start)
if (o < 0) continue
if (o == 0 && !r.isEmpty() && !n.isEmpty()) continue
i(r.end, n.end) < 0 && ((r.end.row = n.end.row), (r.end.column = n.end.column)),
t.splice(s, 1),
e.push(n),
(n = r),
s--
}
return (this.ranges = t), e
}),
(this.contains = function (e, t) {
return this.pointIndex({ row: e, column: t }) >= 0
}),
(this.containsPoint = function (e) {
return this.pointIndex(e) >= 0
}),
(this.rangeAtPoint = function (e) {
var t = this.pointIndex(e)
if (t >= 0) return this.ranges[t]
}),
(this.clipRows = function (e, t) {
var n = this.ranges
if (n[0].start.row > t || n[n.length - 1].start.row < e) return []
var r = this.pointIndex({ row: e, column: 0 })
r < 0 && (r = -r - 1)
var i = this.pointIndex({ row: t, column: 0 }, r)
i < 0 && (i = -i - 1)
var s = []
for (var o = r; o < i; o++) s.push(n[o])
return s
}),
(this.removeAll = function () {
return this.ranges.splice(0, this.ranges.length)
}),
(this.attach = function (e) {
this.session && this.detach(),
(this.session = e),
(this.onChange = this.$onChange.bind(this)),
this.session.on('change', this.onChange)
}),
(this.detach = function () {
if (!this.session) return
this.session.removeListener('change', this.onChange), (this.session = null)
}),
(this.$onChange = function (e) {
var t = e.start,
n = e.end,
r = t.row,
i = n.row,
s = this.ranges
for (var o = 0, u = s.length; o < u; o++) {
var a = s[o]
if (a.end.row >= r) break
}
if (e.action == 'insert') {
var f = i - r,
l = -t.column + n.column
for (; o < u; o++) {
var a = s[o]
if (a.start.row > r) break
a.start.row == r &&
a.start.column >= t.column &&
((a.start.column == t.column && this.$bias <= 0) ||
((a.start.column += l), (a.start.row += f)))
if (a.end.row == r && a.end.column >= t.column) {
if (a.end.column == t.column && this.$bias < 0) continue
a.end.column == t.column &&
l > 0 &&
o < u - 1 &&
a.end.column > a.start.column &&
a.end.column == s[o + 1].start.column &&
(a.end.column -= l),
(a.end.column += l),
(a.end.row += f)
}
}
} else {
var f = r - i,
l = t.column - n.column
for (; o < u; o++) {
var a = s[o]
if (a.start.row > i) break
if (a.end.row < i && (r < a.end.row || (r == a.end.row && t.column < a.end.column)))
(a.end.row = r), (a.end.column = t.column)
else if (a.end.row == i)
if (a.end.column <= n.column) {
if (f || a.end.column > t.column) (a.end.column = t.column), (a.end.row = t.row)
} else (a.end.column += l), (a.end.row += f)
else a.end.row > i && (a.end.row += f)
if (
a.start.row < i &&
(r < a.start.row || (r == a.start.row && t.column < a.start.column))
)
(a.start.row = r), (a.start.column = t.column)
else if (a.start.row == i)
if (a.start.column <= n.column) {
if (f || a.start.column > t.column)
(a.start.column = t.column), (a.start.row = t.row)
} else (a.start.column += l), (a.start.row += f)
else a.start.row > i && (a.start.row += f)
}
}
if (f != 0 && o < u)
for (; o < u; o++) {
var a = s[o]
;(a.start.row += f), (a.end.row += f)
}
})
}).call(s.prototype),
(t.RangeList = s)
}),
ace.define(
'ace/edit_session/fold',
['require', 'exports', 'module', 'ace/range_list', 'ace/lib/oop'],
function (e, t, n) {
'use strict'
function o(e, t) {
;(e.row -= t.row), e.row == 0 && (e.column -= t.column)
}
function u(e, t) {
o(e.start, t), o(e.end, t)
}
function a(e, t) {
e.row == 0 && (e.column += t.column), (e.row += t.row)
}
function f(e, t) {
a(e.start, t), a(e.end, t)
}
var r = e('../range_list').RangeList,
i = e('../lib/oop'),
s = (t.Fold = function (e, t) {
;(this.foldLine = null),
(this.placeholder = t),
(this.range = e),
(this.start = e.start),
(this.end = e.end),
(this.sameRow = e.start.row == e.end.row),
(this.subFolds = this.ranges = [])
})
i.inherits(s, r),
function () {
;(this.toString = function () {
return '"' + this.placeholder + '" ' + this.range.toString()
}),
(this.setFoldLine = function (e) {
;(this.foldLine = e),
this.subFolds.forEach(function (t) {
t.setFoldLine(e)
})
}),
(this.clone = function () {
var e = this.range.clone(),
t = new s(e, this.placeholder)
return (
this.subFolds.forEach(function (e) {
t.subFolds.push(e.clone())
}),
(t.collapseChildren = this.collapseChildren),
t
)
}),
(this.addSubFold = function (e) {
if (this.range.isEqual(e)) return
u(e, this.start)
var t = e.start.row,
n = e.start.column
for (var r = 0, i = -1; r < this.subFolds.length; r++) {
i = this.subFolds[r].range.compare(t, n)
if (i != 1) break
}
var s = this.subFolds[r],
o = 0
if (i == 0) {
if (s.range.containsRange(e)) return s.addSubFold(e)
o = 1
}
var t = e.range.end.row,
n = e.range.end.column
for (var a = r, i = -1; a < this.subFolds.length; a++) {
i = this.subFolds[a].range.compare(t, n)
if (i != 1) break
}
i == 0 && a++
var f = this.subFolds.splice(r, a - r, e),
l = i == 0 ? f.length - 1 : f.length
for (var c = o; c < l; c++) e.addSubFold(f[c])
return e.setFoldLine(this.foldLine), e
}),
(this.restoreRange = function (e) {
return f(e, this.start)
})
}.call(s.prototype)
}
),
ace.define(
'ace/edit_session/folding',
[
'require',
'exports',
'module',
'ace/range',
'ace/edit_session/fold_line',
'ace/edit_session/fold',
'ace/token_iterator',
],
function (e, t, n) {
'use strict'
function u() {
;(this.getFoldAt = function (e, t, n) {
var r = this.getFoldLine(e)
if (!r) return null
var i = r.folds
for (var s = 0; s < i.length; s++) {
var o = i[s].range
if (o.contains(e, t)) {
if (n == 1 && o.isEnd(e, t) && !o.isEmpty()) continue
if (n == -1 && o.isStart(e, t) && !o.isEmpty()) continue
return i[s]
}
}
}),
(this.getFoldsInRange = function (e) {
var t = e.start,
n = e.end,
r = this.$foldData,
i = []
;(t.column += 1), (n.column -= 1)
for (var s = 0; s < r.length; s++) {
var o = r[s].range.compareRange(e)
if (o == 2) continue
if (o == -2) break
var u = r[s].folds
for (var a = 0; a < u.length; a++) {
var f = u[a]
o = f.range.compareRange(e)
if (o == -2) break
if (o == 2) continue
if (o == 42) break
i.push(f)
}
}
return (t.column -= 1), (n.column += 1), i
}),
(this.getFoldsInRangeList = function (e) {
if (Array.isArray(e)) {
var t = []
e.forEach(function (e) {
t = t.concat(this.getFoldsInRange(e))
}, this)
} else var t = this.getFoldsInRange(e)
return t
}),
(this.getAllFolds = function () {
var e = [],
t = this.$foldData
for (var n = 0; n < t.length; n++)
for (var r = 0; r < t[n].folds.length; r++) e.push(t[n].folds[r])
return e
}),
(this.getFoldStringAt = function (e, t, n, r) {
r = r || this.getFoldLine(e)
if (!r) return null
var i = { end: { column: 0 } },
s,
o
for (var u = 0; u < r.folds.length; u++) {
o = r.folds[u]
var a = o.range.compareEnd(e, t)
if (a == -1) {
s = this.getLine(o.start.row).substring(i.end.column, o.start.column)
break
}
if (a === 0) return null
i = o
}
return (
s || (s = this.getLine(o.start.row).substring(i.end.column)),
n == -1
? s.substring(0, t - i.end.column)
: n == 1
? s.substring(t - i.end.column)
: s
)
}),
(this.getFoldLine = function (e, t) {
var n = this.$foldData,
r = 0
t && (r = n.indexOf(t)), r == -1 && (r = 0)
for (r; r < n.length; r++) {
var i = n[r]
if (i.start.row <= e && i.end.row >= e) return i
if (i.end.row > e) return null
}
return null
}),
(this.getNextFoldLine = function (e, t) {
var n = this.$foldData,
r = 0
t && (r = n.indexOf(t)), r == -1 && (r = 0)
for (r; r < n.length; r++) {
var i = n[r]
if (i.end.row >= e) return i
}
return null
}),
(this.getFoldedRowCount = function (e, t) {
var n = this.$foldData,
r = t - e + 1
for (var i = 0; i < n.length; i++) {
var s = n[i],
o = s.end.row,
u = s.start.row
if (o >= t) {
u < t && (u >= e ? (r -= t - u) : (r = 0))
break
}
o >= e && (u >= e ? (r -= o - u) : (r -= o - e + 1))
}
return r
}),
(this.$addFoldLine = function (e) {
return (
this.$foldData.push(e),
this.$foldData.sort(function (e, t) {
return e.start.row - t.start.row
}),
e
)
}),
(this.addFold = function (e, t) {
var n = this.$foldData,
r = !1,
o
e instanceof s
? (o = e)
: ((o = new s(t, e)), (o.collapseChildren = t.collapseChildren)),
this.$clipRangeToDocument(o.range)
var u = o.start.row,
a = o.start.column,
f = o.end.row,
l = o.end.column,
c = this.getFoldAt(u, a, 1),
h = this.getFoldAt(f, l, -1)
if (c && h == c) return c.addSubFold(o)
c && !c.range.isStart(u, a) && this.removeFold(c),
h && !h.range.isEnd(f, l) && this.removeFold(h)
var p = this.getFoldsInRange(o.range)
p.length > 0 &&
(this.removeFolds(p),
o.collapseChildren ||
p.forEach(function (e) {
o.addSubFold(e)
}))
for (var d = 0; d < n.length; d++) {
var v = n[d]
if (f == v.start.row) {
v.addFold(o), (r = !0)
break
}
if (u == v.end.row) {
v.addFold(o), (r = !0)
if (!o.sameRow) {
var m = n[d + 1]
if (m && m.start.row == f) {
v.merge(m)
break
}
}
break
}
if (f <= v.start.row) break
}
return (
r || (v = this.$addFoldLine(new i(this.$foldData, o))),
this.$useWrapMode
? this.$updateWrapData(v.start.row, v.start.row)
: this.$updateRowLengthCache(v.start.row, v.start.row),
(this.$modified = !0),
this._signal('changeFold', { data: o, action: 'add' }),
o
)
}),
(this.addFolds = function (e) {
e.forEach(function (e) {
this.addFold(e)
}, this)
}),
(this.removeFold = function (e) {
var t = e.foldLine,
n = t.start.row,
r = t.end.row,
i = this.$foldData,
s = t.folds
if (s.length == 1) i.splice(i.indexOf(t), 1)
else if (t.range.isEnd(e.end.row, e.end.column))
s.pop(),
(t.end.row = s[s.length - 1].end.row),
(t.end.column = s[s.length - 1].end.column)
else if (t.range.isStart(e.start.row, e.start.column))
s.shift(), (t.start.row = s[0].start.row), (t.start.column = s[0].start.column)
else if (e.sameRow) s.splice(s.indexOf(e), 1)
else {
var o = t.split(e.start.row, e.start.column)
;(s = o.folds),
s.shift(),
(o.start.row = s[0].start.row),
(o.start.column = s[0].start.column)
}
this.$updating ||
(this.$useWrapMode ? this.$updateWrapData(n, r) : this.$updateRowLengthCache(n, r)),
(this.$modified = !0),
this._signal('changeFold', { data: e, action: 'remove' })
}),
(this.removeFolds = function (e) {
var t = []
for (var n = 0; n < e.length; n++) t.push(e[n])
t.forEach(function (e) {
this.removeFold(e)
}, this),
(this.$modified = !0)
}),
(this.expandFold = function (e) {
this.removeFold(e),
e.subFolds.forEach(function (t) {
e.restoreRange(t), this.addFold(t)
}, this),
e.collapseChildren > 0 &&
this.foldAll(e.start.row + 1, e.end.row, e.collapseChildren - 1),
(e.subFolds = [])
}),
(this.expandFolds = function (e) {
e.forEach(function (e) {
this.expandFold(e)
}, this)
}),
(this.unfold = function (e, t) {
var n, i
e == null
? ((n = new r(0, 0, this.getLength(), 0)), t == null && (t = !0))
: typeof e == 'number'
? (n = new r(e, 0, e, this.getLine(e).length))
: 'row' in e
? (n = r.fromPoints(e, e))
: (n = e),
(i = this.getFoldsInRangeList(n)),
t != 0 ? this.removeFolds(i) : this.expandFolds(i)
if (i.length) return i
}),
(this.isRowFolded = function (e, t) {
return !!this.getFoldLine(e, t)
}),
(this.getRowFoldEnd = function (e, t) {
var n = this.getFoldLine(e, t)
return n ? n.end.row : e
}),
(this.getRowFoldStart = function (e, t) {
var n = this.getFoldLine(e, t)
return n ? n.start.row : e
}),
(this.getFoldDisplayLine = function (e, t, n, r, i) {
r == null && (r = e.start.row),
i == null && (i = 0),
t == null && (t = e.end.row),
n == null && (n = this.getLine(t).length)
var s = this.doc,
o = ''
return (
e.walk(
function (e, t, n, u) {
if (t < r) return
if (t == r) {
if (n < i) return
u = Math.max(i, u)
}
e != null ? (o += e) : (o += s.getLine(t).substring(u, n))
},
t,
n
),
o
)
}),
(this.getDisplayLine = function (e, t, n, r) {
var i = this.getFoldLine(e)
if (!i) {
var s
return (s = this.doc.getLine(e)), s.substring(r || 0, t || s.length)
}
return this.getFoldDisplayLine(i, e, t, n, r)
}),
(this.$cloneFoldData = function () {
var e = []
return (
(e = this.$foldData.map(function (t) {
var n = t.folds.map(function (e) {
return e.clone()
})
return new i(e, n)
})),
e
)
}),
(this.toggleFold = function (e) {
var t = this.selection,
n = t.getRange(),
r,
i
if (n.isEmpty()) {
var s = n.start
r = this.getFoldAt(s.row, s.column)
if (r) {
this.expandFold(r)
return
}
;(i = this.findMatchingBracket(s))
? n.comparePoint(i) == 1
? (n.end = i)
: ((n.start = i), n.start.column++, n.end.column--)
: (i = this.findMatchingBracket({ row: s.row, column: s.column + 1 }))
? (n.comparePoint(i) == 1 ? (n.end = i) : (n.start = i), n.start.column++)
: (n = this.getCommentFoldRange(s.row, s.column) || n)
} else {
var o = this.getFoldsInRange(n)
if (e && o.length) {
this.expandFolds(o)
return
}
o.length == 1 && (r = o[0])
}
r || (r = this.getFoldAt(n.start.row, n.start.column))
if (r && r.range.toString() == n.toString()) {
this.expandFold(r)
return
}
var u = '...'
if (!n.isMultiLine()) {
u = this.getTextRange(n)
if (u.length < 4) return
u = u.trim().substring(0, 2) + '..'
}
this.addFold(u, n)
}),
(this.getCommentFoldRange = function (e, t, n) {
var i = new o(this, e, t),
s = i.getCurrentToken(),
u = s && s.type
if (s && /^comment|string/.test(u)) {
;(u = u.match(/comment|string/)[0]), u == 'comment' && (u += '|doc-start')
var a = new RegExp(u),
f = new r()
if (n != 1) {
do s = i.stepBackward()
while (s && a.test(s.type))
i.stepForward()
}
;(f.start.row = i.getCurrentTokenRow()),
(f.start.column = i.getCurrentTokenColumn() + 2),
(i = new o(this, e, t))
if (n != -1) {
var l = -1
do {
s = i.stepForward()
if (l == -1) {
var c = this.getState(i.$row)
a.test(c) || (l = i.$row)
} else if (i.$row > l) break
} while (s && a.test(s.type))
s = i.stepBackward()
} else s = i.getCurrentToken()
return (
(f.end.row = i.getCurrentTokenRow()),
(f.end.column = i.getCurrentTokenColumn() + s.value.length - 2),
f
)
}
}),
(this.foldAll = function (e, t, n, r) {
n == undefined && (n = 1e5)
var i = this.foldWidgets
if (!i) return
;(t = t || this.getLength()), (e = e || 0)
for (var s = e; s < t; s++) {
i[s] == null && (i[s] = this.getFoldWidget(s))
if (i[s] != 'start') continue
if (r && !r(s)) continue
var o = this.getFoldWidgetRange(s)
o &&
o.isMultiLine() &&
o.end.row <= t &&
o.start.row >= e &&
((s = o.end.row), (o.collapseChildren = n), this.addFold('...', o))
}
}),
(this.foldToLevel = function (e) {
this.foldAll()
while (e-- > 0) this.unfold(null, !1)
}),
(this.foldAllComments = function () {
var e = this
this.foldAll(null, null, null, function (t) {
var n = e.getTokens(t)
for (var r = 0; r < n.length; r++) {
var i = n[r]
if (i.type == 'text' && /^\s+$/.test(i.value)) continue
return /comment/.test(i.type) ? !0 : !1
}
})
}),
(this.$foldStyles = { manual: 1, markbegin: 1, markbeginend: 1 }),
(this.$foldStyle = 'markbegin'),
(this.setFoldStyle = function (e) {
if (!this.$foldStyles[e])
throw new Error(
'invalid fold style: ' + e + '[' + Object.keys(this.$foldStyles).join(', ') + ']'
)
if (this.$foldStyle == e) return
;(this.$foldStyle = e), e == 'manual' && this.unfold()
var t = this.$foldMode
this.$setFolding(null), this.$setFolding(t)
}),
(this.$setFolding = function (e) {
if (this.$foldMode == e) return
;(this.$foldMode = e),
this.off('change', this.$updateFoldWidgets),
this.off('tokenizerUpdate', this.$tokenizerUpdateFoldWidgets),
this._signal('changeAnnotation')
if (!e || this.$foldStyle == 'manual') {
this.foldWidgets = null
return
}
;(this.foldWidgets = []),
(this.getFoldWidget = e.getFoldWidget.bind(e, this, this.$foldStyle)),
(this.getFoldWidgetRange = e.getFoldWidgetRange.bind(e, this, this.$foldStyle)),
(this.$updateFoldWidgets = this.updateFoldWidgets.bind(this)),
(this.$tokenizerUpdateFoldWidgets = this.tokenizerUpdateFoldWidgets.bind(this)),
this.on('change', this.$updateFoldWidgets),
this.on('tokenizerUpdate', this.$tokenizerUpdateFoldWidgets)
}),
(this.getParentFoldRangeData = function (e, t) {
var n = this.foldWidgets
if (!n || (t && n[e])) return {}
var r = e - 1,
i
while (r >= 0) {
var s = n[r]
s == null && (s = n[r] = this.getFoldWidget(r))
if (s == 'start') {
var o = this.getFoldWidgetRange(r)
i || (i = o)
if (o && o.end.row >= e) break
}
r--
}
return { range: r !== -1 && o, firstRange: i }
}),
(this.onFoldWidgetClick = function (e, t) {
t = t.domEvent
var n = { children: t.shiftKey, all: t.ctrlKey || t.metaKey, siblings: t.altKey },
r = this.$toggleFoldWidget(e, n)
if (!r) {
var i = t.target || t.srcElement
i && /ace_fold-widget/.test(i.className) && (i.className += ' ace_invalid')
}
}),
(this.$toggleFoldWidget = function (e, t) {
if (!this.getFoldWidget) return
var n = this.getFoldWidget(e),
r = this.getLine(e),
i = n === 'end' ? -1 : 1,
s = this.getFoldAt(e, i === -1 ? 0 : r.length, i)
if (s) return t.children || t.all ? this.removeFold(s) : this.expandFold(s), s
var o = this.getFoldWidgetRange(e, !0)
if (o && !o.isMultiLine()) {
s = this.getFoldAt(o.start.row, o.start.column, 1)
if (s && o.isEqual(s.range)) return this.removeFold(s), s
}
if (t.siblings) {
var u = this.getParentFoldRangeData(e)
if (u.range)
var a = u.range.start.row + 1,
f = u.range.end.row
this.foldAll(a, f, t.all ? 1e4 : 0)
} else
t.children
? ((f = o ? o.end.row : this.getLength()), this.foldAll(e + 1, f, t.all ? 1e4 : 0))
: o && (t.all && (o.collapseChildren = 1e4), this.addFold('...', o))
return o
}),
(this.toggleFoldWidget = function (e) {
var t = this.selection.getCursor().row
t = this.getRowFoldStart(t)
var n = this.$toggleFoldWidget(t, {})
if (n) return
var r = this.getParentFoldRangeData(t, !0)
n = r.range || r.firstRange
if (n) {
t = n.start.row
var i = this.getFoldAt(t, this.getLine(t).length, 1)
i ? this.removeFold(i) : this.addFold('...', n)
}
}),
(this.updateFoldWidgets = function (e) {
var t = e.start.row,
n = e.end.row - t
if (n === 0) this.foldWidgets[t] = null
else if (e.action == 'remove') this.foldWidgets.splice(t, n + 1, null)
else {
var r = Array(n + 1)
r.unshift(t, 1), this.foldWidgets.splice.apply(this.foldWidgets, r)
}
}),
(this.tokenizerUpdateFoldWidgets = function (e) {
var t = e.data
t.first != t.last &&
this.foldWidgets.length > t.first &&
this.foldWidgets.splice(t.first, this.foldWidgets.length)
})
}
var r = e('../range').Range,
i = e('./fold_line').FoldLine,
s = e('./fold').Fold,
o = e('../token_iterator').TokenIterator
t.Folding = u
}
),
ace.define(
'ace/edit_session/bracket_match',
['require', 'exports', 'module', 'ace/token_iterator', 'ace/range'],
function (e, t, n) {
'use strict'
function s() {
;(this.findMatchingBracket = function (e, t) {
if (e.column == 0) return null
var n = t || this.getLine(e.row).charAt(e.column - 1)
if (n == '') return null
var r = n.match(/([\(\[\{])|([\)\]\}])/)
return r
? r[1]
? this.$findClosingBracket(r[1], e)
: this.$findOpeningBracket(r[2], e)
: null
}),
(this.getBracketRange = function (e) {
var t = this.getLine(e.row),
n = !0,
r,
s = t.charAt(e.column - 1),
o = s && s.match(/([\(\[\{])|([\)\]\}])/)
o ||
((s = t.charAt(e.column)),
(e = { row: e.row, column: e.column + 1 }),
(o = s && s.match(/([\(\[\{])|([\)\]\}])/)),
(n = !1))
if (!o) return null
if (o[1]) {
var u = this.$findClosingBracket(o[1], e)
if (!u) return null
;(r = i.fromPoints(e, u)), n || (r.end.column++, r.start.column--), (r.cursor = r.end)
} else {
var u = this.$findOpeningBracket(o[2], e)
if (!u) return null
;(r = i.fromPoints(u, e)),
n || (r.start.column++, r.end.column--),
(r.cursor = r.start)
}
return r
}),
(this.getMatchingBracketRanges = function (e) {
var t = this.getLine(e.row),
n = t.charAt(e.column - 1),
r = n && n.match(/([\(\[\{])|([\)\]\}])/)
r ||
((n = t.charAt(e.column)),
(e = { row: e.row, column: e.column + 1 }),
(r = n && n.match(/([\(\[\{])|([\)\]\}])/)))
if (!r) return null
var s = new i(e.row, e.column - 1, e.row, e.column),
o = r[1] ? this.$findClosingBracket(r[1], e) : this.$findOpeningBracket(r[2], e)
if (!o) return [s]
var u = new i(o.row, o.column, o.row, o.column + 1)
return [s, u]
}),
(this.$brackets = {
')': '(',
'(': ')',
']': '[',
'[': ']',
'{': '}',
'}': '{',
'<': '>',
'>': '<',
}),
(this.$findOpeningBracket = function (e, t, n) {
var i = this.$brackets[e],
s = 1,
o = new r(this, t.row, t.column),
u = o.getCurrentToken()
u || (u = o.stepForward())
if (!u) return
n ||
(n = new RegExp(
'(\\.?' +
u.type
.replace('.', '\\.')
.replace('rparen', '.paren')
.replace(/\b(?:end)\b/, '(?:start|begin|end)') +
')+'
))
var a = t.column - o.getCurrentTokenColumn() - 2,
f = u.value
for (;;) {
while (a >= 0) {
var l = f.charAt(a)
if (l == i) {
s -= 1
if (s == 0)
return { row: o.getCurrentTokenRow(), column: a + o.getCurrentTokenColumn() }
} else l == e && (s += 1)
a -= 1
}
do u = o.stepBackward()
while (u && !n.test(u.type))
if (u == null) break
;(f = u.value), (a = f.length - 1)
}
return null
}),
(this.$findClosingBracket = function (e, t, n) {
var i = this.$brackets[e],
s = 1,
o = new r(this, t.row, t.column),
u = o.getCurrentToken()
u || (u = o.stepForward())
if (!u) return
n ||
(n = new RegExp(
'(\\.?' +
u.type
.replace('.', '\\.')
.replace('lparen', '.paren')
.replace(/\b(?:start|begin)\b/, '(?:start|begin|end)') +
')+'
))
var a = t.column - o.getCurrentTokenColumn()
for (;;) {
var f = u.value,
l = f.length
while (a < l) {
var c = f.charAt(a)
if (c == i) {
s -= 1
if (s == 0)
return { row: o.getCurrentTokenRow(), column: a + o.getCurrentTokenColumn() }
} else c == e && (s += 1)
a += 1
}
do u = o.stepForward()
while (u && !n.test(u.type))
if (u == null) break
a = 0
}
return null
})
}
var r = e('../token_iterator').TokenIterator,
i = e('../range').Range
t.BracketMatch = s
}
),
ace.define(
'ace/edit_session',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/lib/lang',
'ace/bidihandler',
'ace/config',
'ace/lib/event_emitter',
'ace/selection',
'ace/mode/text',
'ace/range',
'ace/document',
'ace/background_tokenizer',
'ace/search_highlight',
'ace/edit_session/folding',
'ace/edit_session/bracket_match',
],
function (e, t, n) {
'use strict'
var r = e('./lib/oop'),
i = e('./lib/lang'),
s = e('./bidihandler').BidiHandler,
o = e('./config'),
u = e('./lib/event_emitter').EventEmitter,
a = e('./selection').Selection,
f = e('./mode/text').Mode,
l = e('./range').Range,
c = e('./document').Document,
h = e('./background_tokenizer').BackgroundTokenizer,
p = e('./search_highlight').SearchHighlight,
d = function (e, t) {
;(this.$breakpoints = []),
(this.$decorations = []),
(this.$frontMarkers = {}),
(this.$backMarkers = {}),
(this.$markerId = 1),
(this.$undoSelect = !0),
(this.$foldData = []),
(this.id = 'session' + ++d.$uid),
(this.$foldData.toString = function () {
return this.join('\n')
}),
this.on('changeFold', this.onChangeFold.bind(this)),
(this.$onChange = this.onChange.bind(this))
if (typeof e != 'object' || !e.getLine) e = new c(e)
this.setDocument(e),
(this.selection = new a(this)),
(this.$bidiHandler = new s(this)),
o.resetOptions(this),
this.setMode(t),
o._signal('session', this)
}
;(d.$uid = 0),
function () {
function m(e) {
return e < 4352
? !1
: (e >= 4352 && e <= 4447) ||
(e >= 4515 && e <= 4519) ||
(e >= 4602 && e <= 4607) ||
(e >= 9001 && e <= 9002) ||
(e >= 11904 && e <= 11929) ||
(e >= 11931 && e <= 12019) ||
(e >= 12032 && e <= 12245) ||
(e >= 12272 && e <= 12283) ||
(e >= 12288 && e <= 12350) ||
(e >= 12353 && e <= 12438) ||
(e >= 12441 && e <= 12543) ||
(e >= 12549 && e <= 12589) ||
(e >= 12593 && e <= 12686) ||
(e >= 12688 && e <= 12730) ||
(e >= 12736 && e <= 12771) ||
(e >= 12784 && e <= 12830) ||
(e >= 12832 && e <= 12871) ||
(e >= 12880 && e <= 13054) ||
(e >= 13056 && e <= 19903) ||
(e >= 19968 && e <= 42124) ||
(e >= 42128 && e <= 42182) ||
(e >= 43360 && e <= 43388) ||
(e >= 44032 && e <= 55203) ||
(e >= 55216 && e <= 55238) ||
(e >= 55243 && e <= 55291) ||
(e >= 63744 && e <= 64255) ||
(e >= 65040 && e <= 65049) ||
(e >= 65072 && e <= 65106) ||
(e >= 65108 && e <= 65126) ||
(e >= 65128 && e <= 65131) ||
(e >= 65281 && e <= 65376) ||
(e >= 65504 && e <= 65510)
}
r.implement(this, u),
(this.setDocument = function (e) {
this.doc && this.doc.removeListener('change', this.$onChange),
(this.doc = e),
e.on('change', this.$onChange),
this.bgTokenizer && this.bgTokenizer.setDocument(this.getDocument()),
this.resetCaches()
}),
(this.getDocument = function () {
return this.doc
}),
(this.$resetRowCache = function (e) {
if (!e) {
;(this.$docRowCache = []), (this.$screenRowCache = [])
return
}
var t = this.$docRowCache.length,
n = this.$getRowCacheIndex(this.$docRowCache, e) + 1
t > n && (this.$docRowCache.splice(n, t), this.$screenRowCache.splice(n, t))
}),
(this.$getRowCacheIndex = function (e, t) {
var n = 0,
r = e.length - 1
while (n <= r) {
var i = (n + r) >> 1,
s = e[i]
if (t > s) n = i + 1
else {
if (!(t < s)) return i
r = i - 1
}
}
return n - 1
}),
(this.resetCaches = function () {
;(this.$modified = !0),
(this.$wrapData = []),
(this.$rowLengthCache = []),
this.$resetRowCache(0),
this.bgTokenizer && this.bgTokenizer.start(0)
}),
(this.onChangeFold = function (e) {
var t = e.data
this.$resetRowCache(t.start.row)
}),
(this.onChange = function (e) {
;(this.$modified = !0),
this.$bidiHandler.onChange(e),
this.$resetRowCache(e.start.row)
var t = this.$updateInternalDataOnChange(e)
!this.$fromUndo &&
this.$undoManager &&
(t &&
t.length &&
(this.$undoManager.add({ action: 'removeFolds', folds: t }, this.mergeUndoDeltas),
(this.mergeUndoDeltas = !0)),
this.$undoManager.add(e, this.mergeUndoDeltas),
(this.mergeUndoDeltas = !0),
this.$informUndoManager.schedule()),
this.bgTokenizer && this.bgTokenizer.$updateOnChange(e),
this._signal('change', e)
}),
(this.setValue = function (e) {
this.doc.setValue(e),
this.selection.moveTo(0, 0),
this.$resetRowCache(0),
this.setUndoManager(this.$undoManager),
this.getUndoManager().reset()
}),
(this.getValue = this.toString =
function () {
return this.doc.getValue()
}),
(this.getSelection = function () {
return this.selection
}),
(this.getState = function (e) {
return this.bgTokenizer.getState(e)
}),
(this.getTokens = function (e) {
return this.bgTokenizer.getTokens(e)
}),
(this.getTokenAt = function (e, t) {
var n = this.bgTokenizer.getTokens(e),
r,
i = 0
if (t == null) {
var s = n.length - 1
i = this.getLine(e).length
} else
for (var s = 0; s < n.length; s++) {
i += n[s].value.length
if (i >= t) break
}
return (r = n[s]), r ? ((r.index = s), (r.start = i - r.value.length), r) : null
}),
(this.setUndoManager = function (e) {
;(this.$undoManager = e), this.$informUndoManager && this.$informUndoManager.cancel()
if (e) {
var t = this
e.addSession(this),
(this.$syncInformUndoManager = function () {
t.$informUndoManager.cancel(), (t.mergeUndoDeltas = !1)
}),
(this.$informUndoManager = i.delayedCall(this.$syncInformUndoManager))
} else this.$syncInformUndoManager = function () {}
}),
(this.markUndoGroup = function () {
this.$syncInformUndoManager && this.$syncInformUndoManager()
}),
(this.$defaultUndoManager = {
undo: function () {},
redo: function () {},
hasUndo: function () {},
hasRedo: function () {},
reset: function () {},
add: function () {},
addSelection: function () {},
startNewGroup: function () {},
addSession: function () {},
}),
(this.getUndoManager = function () {
return this.$undoManager || this.$defaultUndoManager
}),
(this.getTabString = function () {
return this.getUseSoftTabs() ? i.stringRepeat(' ', this.getTabSize()) : ' '
}),
(this.setUseSoftTabs = function (e) {
this.setOption('useSoftTabs', e)
}),
(this.getUseSoftTabs = function () {
return this.$useSoftTabs && !this.$mode.$indentWithTabs
}),
(this.setTabSize = function (e) {
this.setOption('tabSize', e)
}),
(this.getTabSize = function () {
return this.$tabSize
}),
(this.isTabStop = function (e) {
return this.$useSoftTabs && e.column % this.$tabSize === 0
}),
(this.setNavigateWithinSoftTabs = function (e) {
this.setOption('navigateWithinSoftTabs', e)
}),
(this.getNavigateWithinSoftTabs = function () {
return this.$navigateWithinSoftTabs
}),
(this.$overwrite = !1),
(this.setOverwrite = function (e) {
this.setOption('overwrite', e)
}),
(this.getOverwrite = function () {
return this.$overwrite
}),
(this.toggleOverwrite = function () {
this.setOverwrite(!this.$overwrite)
}),
(this.addGutterDecoration = function (e, t) {
this.$decorations[e] || (this.$decorations[e] = ''),
(this.$decorations[e] += ' ' + t),
this._signal('changeBreakpoint', {})
}),
(this.removeGutterDecoration = function (e, t) {
;(this.$decorations[e] = (this.$decorations[e] || '').replace(' ' + t, '')),
this._signal('changeBreakpoint', {})
}),
(this.getBreakpoints = function () {
return this.$breakpoints
}),
(this.setBreakpoints = function (e) {
this.$breakpoints = []
for (var t = 0; t < e.length; t++) this.$breakpoints[e[t]] = 'ace_breakpoint'
this._signal('changeBreakpoint', {})
}),
(this.clearBreakpoints = function () {
;(this.$breakpoints = []), this._signal('changeBreakpoint', {})
}),
(this.setBreakpoint = function (e, t) {
t === undefined && (t = 'ace_breakpoint'),
t ? (this.$breakpoints[e] = t) : delete this.$breakpoints[e],
this._signal('changeBreakpoint', {})
}),
(this.clearBreakpoint = function (e) {
delete this.$breakpoints[e], this._signal('changeBreakpoint', {})
}),
(this.addMarker = function (e, t, n, r) {
var i = this.$markerId++,
s = {
range: e,
type: n || 'line',
renderer: typeof n == 'function' ? n : null,
clazz: t,
inFront: !!r,
id: i,
}
return (
r
? ((this.$frontMarkers[i] = s), this._signal('changeFrontMarker'))
: ((this.$backMarkers[i] = s), this._signal('changeBackMarker')),
i
)
}),
(this.addDynamicMarker = function (e, t) {
if (!e.update) return
var n = this.$markerId++
return (
(e.id = n),
(e.inFront = !!t),
t
? ((this.$frontMarkers[n] = e), this._signal('changeFrontMarker'))
: ((this.$backMarkers[n] = e), this._signal('changeBackMarker')),
e
)
}),
(this.removeMarker = function (e) {
var t = this.$frontMarkers[e] || this.$backMarkers[e]
if (!t) return
var n = t.inFront ? this.$frontMarkers : this.$backMarkers
delete n[e], this._signal(t.inFront ? 'changeFrontMarker' : 'changeBackMarker')
}),
(this.getMarkers = function (e) {
return e ? this.$frontMarkers : this.$backMarkers
}),
(this.highlight = function (e) {
if (!this.$searchHighlight) {
var t = new p(null, 'ace_selected-word', 'text')
this.$searchHighlight = this.addDynamicMarker(t)
}
this.$searchHighlight.setRegexp(e)
}),
(this.highlightLines = function (e, t, n, r) {
typeof t != 'number' && ((n = t), (t = e)), n || (n = 'ace_step')
var i = new l(e, 0, t, Infinity)
return (i.id = this.addMarker(i, n, 'fullLine', r)), i
}),
(this.setAnnotations = function (e) {
;(this.$annotations = e), this._signal('changeAnnotation', {})
}),
(this.getAnnotations = function () {
return this.$annotations || []
}),
(this.clearAnnotations = function () {
this.setAnnotations([])
}),
(this.$detectNewLine = function (e) {
var t = e.match(/^.*?(\r?\n)/m)
t ? (this.$autoNewLine = t[1]) : (this.$autoNewLine = '\n')
}),
(this.getWordRange = function (e, t) {
var n = this.getLine(e),
r = !1
t > 0 && (r = !!n.charAt(t - 1).match(this.tokenRe)),
r || (r = !!n.charAt(t).match(this.tokenRe))
if (r) var i = this.tokenRe
else if (/^\s+$/.test(n.slice(t - 1, t + 1))) var i = /\s/
else var i = this.nonTokenRe
var s = t
if (s > 0) {
do s--
while (s >= 0 && n.charAt(s).match(i))
s++
}
var o = t
while (o < n.length && n.charAt(o).match(i)) o++
return new l(e, s, e, o)
}),
(this.getAWordRange = function (e, t) {
var n = this.getWordRange(e, t),
r = this.getLine(n.end.row)
while (r.charAt(n.end.column).match(/[ \t]/)) n.end.column += 1
return n
}),
(this.setNewLineMode = function (e) {
this.doc.setNewLineMode(e)
}),
(this.getNewLineMode = function () {
return this.doc.getNewLineMode()
}),
(this.setUseWorker = function (e) {
this.setOption('useWorker', e)
}),
(this.getUseWorker = function () {
return this.$useWorker
}),
(this.onReloadTokenizer = function (e) {
var t = e.data
this.bgTokenizer.start(t.first), this._signal('tokenizerUpdate', e)
}),
(this.$modes = o.$modes),
(this.$mode = null),
(this.$modeId = null),
(this.setMode = function (e, t) {
if (e && typeof e == 'object') {
if (e.getTokenizer) return this.$onChangeMode(e)
var n = e,
r = n.path
} else r = e || 'ace/mode/text'
this.$modes['ace/mode/text'] || (this.$modes['ace/mode/text'] = new f())
if (this.$modes[r] && !n) {
this.$onChangeMode(this.$modes[r]), t && t()
return
}
;(this.$modeId = r),
o.loadModule(
['mode', r],
function (e) {
if (this.$modeId !== r) return t && t()
this.$modes[r] && !n
? this.$onChangeMode(this.$modes[r])
: e &&
e.Mode &&
((e = new e.Mode(n)),
n || ((this.$modes[r] = e), (e.$id = r)),
this.$onChangeMode(e)),
t && t()
}.bind(this)
),
this.$mode || this.$onChangeMode(this.$modes['ace/mode/text'], !0)
}),
(this.$onChangeMode = function (e, t) {
t || (this.$modeId = e.$id)
if (this.$mode === e) return
var n = this.$mode
;(this.$mode = e), this.$stopWorker(), this.$useWorker && this.$startWorker()
var r = e.getTokenizer()
if (r.on !== undefined) {
var i = this.onReloadTokenizer.bind(this)
r.on('update', i)
}
if (!this.bgTokenizer) {
this.bgTokenizer = new h(r)
var s = this
this.bgTokenizer.on('update', function (e) {
s._signal('tokenizerUpdate', e)
})
} else this.bgTokenizer.setTokenizer(r)
this.bgTokenizer.setDocument(this.getDocument()),
(this.tokenRe = e.tokenRe),
(this.nonTokenRe = e.nonTokenRe),
t ||
(e.attachToSession && e.attachToSession(this),
this.$options.wrapMethod.set.call(this, this.$wrapMethod),
this.$setFolding(e.foldingRules),
this.bgTokenizer.start(0),
this._emit('changeMode', { oldMode: n, mode: e }))
}),
(this.$stopWorker = function () {
this.$worker && (this.$worker.terminate(), (this.$worker = null))
}),
(this.$startWorker = function () {
try {
this.$worker = this.$mode.createWorker(this)
} catch (e) {
o.warn('Could not load worker', e), (this.$worker = null)
}
}),
(this.getMode = function () {
return this.$mode
}),
(this.$scrollTop = 0),
(this.setScrollTop = function (e) {
if (this.$scrollTop === e || isNaN(e)) return
;(this.$scrollTop = e), this._signal('changeScrollTop', e)
}),
(this.getScrollTop = function () {
return this.$scrollTop
}),
(this.$scrollLeft = 0),
(this.setScrollLeft = function (e) {
if (this.$scrollLeft === e || isNaN(e)) return
;(this.$scrollLeft = e), this._signal('changeScrollLeft', e)
}),
(this.getScrollLeft = function () {
return this.$scrollLeft
}),
(this.getScreenWidth = function () {
return (
this.$computeWidth(),
this.lineWidgets
? Math.max(this.getLineWidgetMaxWidth(), this.screenWidth)
: this.screenWidth
)
}),
(this.getLineWidgetMaxWidth = function () {
if (this.lineWidgetsWidth != null) return this.lineWidgetsWidth
var e = 0
return (
this.lineWidgets.forEach(function (t) {
t && t.screenWidth > e && (e = t.screenWidth)
}),
(this.lineWidgetWidth = e)
)
}),
(this.$computeWidth = function (e) {
if (this.$modified || e) {
this.$modified = !1
if (this.$useWrapMode) return (this.screenWidth = this.$wrapLimit)
var t = this.doc.getAllLines(),
n = this.$rowLengthCache,
r = 0,
i = 0,
s = this.$foldData[i],
o = s ? s.start.row : Infinity,
u = t.length
for (var a = 0; a < u; a++) {
if (a > o) {
a = s.end.row + 1
if (a >= u) break
;(s = this.$foldData[i++]), (o = s ? s.start.row : Infinity)
}
n[a] == null && (n[a] = this.$getStringScreenWidth(t[a])[0]),
n[a] > r && (r = n[a])
}
this.screenWidth = r
}
}),
(this.getLine = function (e) {
return this.doc.getLine(e)
}),
(this.getLines = function (e, t) {
return this.doc.getLines(e, t)
}),
(this.getLength = function () {
return this.doc.getLength()
}),
(this.getTextRange = function (e) {
return this.doc.getTextRange(e || this.selection.getRange())
}),
(this.insert = function (e, t) {
return this.doc.insert(e, t)
}),
(this.remove = function (e) {
return this.doc.remove(e)
}),
(this.removeFullLines = function (e, t) {
return this.doc.removeFullLines(e, t)
}),
(this.undoChanges = function (e, t) {
if (!e.length) return
this.$fromUndo = !0
for (var n = e.length - 1; n != -1; n--) {
var r = e[n]
r.action == 'insert' || r.action == 'remove'
? this.doc.revertDelta(r)
: r.folds && this.addFolds(r.folds)
}
!t &&
this.$undoSelect &&
(e.selectionBefore
? this.selection.fromJSON(e.selectionBefore)
: this.selection.setRange(this.$getUndoSelection(e, !0))),
(this.$fromUndo = !1)
}),
(this.redoChanges = function (e, t) {
if (!e.length) return
this.$fromUndo = !0
for (var n = 0; n < e.length; n++) {
var r = e[n]
;(r.action == 'insert' || r.action == 'remove') && this.doc.$safeApplyDelta(r)
}
!t &&
this.$undoSelect &&
(e.selectionAfter
? this.selection.fromJSON(e.selectionAfter)
: this.selection.setRange(this.$getUndoSelection(e, !1))),
(this.$fromUndo = !1)
}),
(this.setUndoSelect = function (e) {
this.$undoSelect = e
}),
(this.$getUndoSelection = function (e, t) {
function n(e) {
return t ? e.action !== 'insert' : e.action === 'insert'
}
var r, i
for (var s = 0; s < e.length; s++) {
var o = e[s]
if (!o.start) continue
if (!r) {
n(o) ? (r = l.fromPoints(o.start, o.end)) : (r = l.fromPoints(o.start, o.start))
continue
}
n(o)
? ((i = o.start),
r.compare(i.row, i.column) == -1 && r.setStart(i),
(i = o.end),
r.compare(i.row, i.column) == 1 && r.setEnd(i))
: ((i = o.start),
r.compare(i.row, i.column) == -1 && (r = l.fromPoints(o.start, o.start)))
}
return r
}),
(this.replace = function (e, t) {
return this.doc.replace(e, t)
}),
(this.moveText = function (e, t, n) {
var r = this.getTextRange(e),
i = this.getFoldsInRange(e),
s = l.fromPoints(t, t)
if (!n) {
this.remove(e)
var o = e.start.row - e.end.row,
u = o ? -e.end.column : e.start.column - e.end.column
u &&
(s.start.row == e.end.row &&
s.start.column > e.end.column &&
(s.start.column += u),
s.end.row == e.end.row && s.end.column > e.end.column && (s.end.column += u)),
o && s.start.row >= e.end.row && ((s.start.row += o), (s.end.row += o))
}
s.end = this.insert(s.start, r)
if (i.length) {
var a = e.start,
f = s.start,
o = f.row - a.row,
u = f.column - a.column
this.addFolds(
i.map(function (e) {
return (
(e = e.clone()),
e.start.row == a.row && (e.start.column += u),
e.end.row == a.row && (e.end.column += u),
(e.start.row += o),
(e.end.row += o),
e
)
})
)
}
return s
}),
(this.indentRows = function (e, t, n) {
n = n.replace(/\t/g, this.getTabString())
for (var r = e; r <= t; r++) this.doc.insertInLine({ row: r, column: 0 }, n)
}),
(this.outdentRows = function (e) {
var t = e.collapseRows(),
n = new l(0, 0, 0, 0),
r = this.getTabSize()
for (var i = t.start.row; i <= t.end.row; ++i) {
var s = this.getLine(i)
;(n.start.row = i), (n.end.row = i)
for (var o = 0; o < r; ++o) if (s.charAt(o) != ' ') break
o < r && s.charAt(o) == ' '
? ((n.start.column = o), (n.end.column = o + 1))
: ((n.start.column = 0), (n.end.column = o)),
this.remove(n)
}
}),
(this.$moveLines = function (e, t, n) {
;(e = this.getRowFoldStart(e)), (t = this.getRowFoldEnd(t))
if (n < 0) {
var r = this.getRowFoldStart(e + n)
if (r < 0) return 0
var i = r - e
} else if (n > 0) {
var r = this.getRowFoldEnd(t + n)
if (r > this.doc.getLength() - 1) return 0
var i = r - t
} else {
;(e = this.$clipRowToDocument(e)), (t = this.$clipRowToDocument(t))
var i = t - e + 1
}
var s = new l(e, 0, t, Number.MAX_VALUE),
o = this.getFoldsInRange(s).map(function (e) {
return (e = e.clone()), (e.start.row += i), (e.end.row += i), e
}),
u = n == 0 ? this.doc.getLines(e, t) : this.doc.removeFullLines(e, t)
return this.doc.insertFullLines(e + i, u), o.length && this.addFolds(o), i
}),
(this.moveLinesUp = function (e, t) {
return this.$moveLines(e, t, -1)
}),
(this.moveLinesDown = function (e, t) {
return this.$moveLines(e, t, 1)
}),
(this.duplicateLines = function (e, t) {
return this.$moveLines(e, t, 0)
}),
(this.$clipRowToDocument = function (e) {
return Math.max(0, Math.min(e, this.doc.getLength() - 1))
}),
(this.$clipColumnToRow = function (e, t) {
return t < 0 ? 0 : Math.min(this.doc.getLine(e).length, t)
}),
(this.$clipPositionToDocument = function (e, t) {
t = Math.max(0, t)
if (e < 0) (e = 0), (t = 0)
else {
var n = this.doc.getLength()
e >= n
? ((e = n - 1), (t = this.doc.getLine(n - 1).length))
: (t = Math.min(this.doc.getLine(e).length, t))
}
return { row: e, column: t }
}),
(this.$clipRangeToDocument = function (e) {
e.start.row < 0
? ((e.start.row = 0), (e.start.column = 0))
: (e.start.column = this.$clipColumnToRow(e.start.row, e.start.column))
var t = this.doc.getLength() - 1
return (
e.end.row > t
? ((e.end.row = t), (e.end.column = this.doc.getLine(t).length))
: (e.end.column = this.$clipColumnToRow(e.end.row, e.end.column)),
e
)
}),
(this.$wrapLimit = 80),
(this.$useWrapMode = !1),
(this.$wrapLimitRange = { min: null, max: null }),
(this.setUseWrapMode = function (e) {
if (e != this.$useWrapMode) {
;(this.$useWrapMode = e), (this.$modified = !0), this.$resetRowCache(0)
if (e) {
var t = this.getLength()
;(this.$wrapData = Array(t)), this.$updateWrapData(0, t - 1)
}
this._signal('changeWrapMode')
}
}),
(this.getUseWrapMode = function () {
return this.$useWrapMode
}),
(this.setWrapLimitRange = function (e, t) {
if (this.$wrapLimitRange.min !== e || this.$wrapLimitRange.max !== t)
(this.$wrapLimitRange = { min: e, max: t }),
(this.$modified = !0),
this.$bidiHandler.markAsDirty(),
this.$useWrapMode && this._signal('changeWrapMode')
}),
(this.adjustWrapLimit = function (e, t) {
var n = this.$wrapLimitRange
n.max < 0 && (n = { min: t, max: t })
var r = this.$constrainWrapLimit(e, n.min, n.max)
return r != this.$wrapLimit && r > 1
? ((this.$wrapLimit = r),
(this.$modified = !0),
this.$useWrapMode &&
(this.$updateWrapData(0, this.getLength() - 1),
this.$resetRowCache(0),
this._signal('changeWrapLimit')),
!0)
: !1
}),
(this.$constrainWrapLimit = function (e, t, n) {
return t && (e = Math.max(t, e)), n && (e = Math.min(n, e)), e
}),
(this.getWrapLimit = function () {
return this.$wrapLimit
}),
(this.setWrapLimit = function (e) {
this.setWrapLimitRange(e, e)
}),
(this.getWrapLimitRange = function () {
return { min: this.$wrapLimitRange.min, max: this.$wrapLimitRange.max }
}),
(this.$updateInternalDataOnChange = function (e) {
var t = this.$useWrapMode,
n = e.action,
r = e.start,
i = e.end,
s = r.row,
o = i.row,
u = o - s,
a = null
this.$updating = !0
if (u != 0)
if (n === 'remove') {
this[t ? '$wrapData' : '$rowLengthCache'].splice(s, u)
var f = this.$foldData
;(a = this.getFoldsInRange(e)), this.removeFolds(a)
var l = this.getFoldLine(i.row),
c = 0
if (l) {
l.addRemoveChars(i.row, i.column, r.column - i.column), l.shiftRow(-u)
var h = this.getFoldLine(s)
h && h !== l && (h.merge(l), (l = h)), (c = f.indexOf(l) + 1)
}
for (c; c < f.length; c++) {
var l = f[c]
l.start.row >= i.row && l.shiftRow(-u)
}
o = s
} else {
var p = Array(u)
p.unshift(s, 0)
var d = t ? this.$wrapData : this.$rowLengthCache
d.splice.apply(d, p)
var f = this.$foldData,
l = this.getFoldLine(s),
c = 0
if (l) {
var v = l.range.compareInside(r.row, r.column)
v == 0
? ((l = l.split(r.row, r.column)),
l && (l.shiftRow(u), l.addRemoveChars(o, 0, i.column - r.column)))
: v == -1 && (l.addRemoveChars(s, 0, i.column - r.column), l.shiftRow(u)),
(c = f.indexOf(l) + 1)
}
for (c; c < f.length; c++) {
var l = f[c]
l.start.row >= s && l.shiftRow(u)
}
}
else {
;(u = Math.abs(e.start.column - e.end.column)),
n === 'remove' && ((a = this.getFoldsInRange(e)), this.removeFolds(a), (u = -u))
var l = this.getFoldLine(s)
l && l.addRemoveChars(s, r.column, u)
}
return (
t &&
this.$wrapData.length != this.doc.getLength() &&
console.error('doc.getLength() and $wrapData.length have to be the same!'),
(this.$updating = !1),
t ? this.$updateWrapData(s, o) : this.$updateRowLengthCache(s, o),
a
)
}),
(this.$updateRowLengthCache = function (e, t, n) {
;(this.$rowLengthCache[e] = null), (this.$rowLengthCache[t] = null)
}),
(this.$updateWrapData = function (e, t) {
var r = this.doc.getAllLines(),
i = this.getTabSize(),
o = this.$wrapData,
u = this.$wrapLimit,
a,
f,
l = e
t = Math.min(t, r.length - 1)
while (l <= t)
(f = this.getFoldLine(l, f)),
f
? ((a = []),
f.walk(
function (e, t, i, o) {
var u
if (e != null) {
;(u = this.$getDisplayTokens(e, a.length)), (u[0] = n)
for (var f = 1; f < u.length; f++) u[f] = s
} else u = this.$getDisplayTokens(r[t].substring(o, i), a.length)
a = a.concat(u)
}.bind(this),
f.end.row,
r[f.end.row].length + 1
),
(o[f.start.row] = this.$computeWrapSplits(a, u, i)),
(l = f.end.row + 1))
: ((a = this.$getDisplayTokens(r[l])),
(o[l] = this.$computeWrapSplits(a, u, i)),
l++)
})
var e = 1,
t = 2,
n = 3,
s = 4,
a = 9,
c = 10,
d = 11,
v = 12
;(this.$computeWrapSplits = function (e, r, i) {
function g() {
var t = 0
if (m === 0) return t
if (p)
for (var n = 0; n < e.length; n++) {
var r = e[n]
if (r == c) t += 1
else {
if (r != d) {
if (r == v) continue
break
}
t += i
}
}
return h && p !== !1 && (t += i), Math.min(t, m)
}
function y(t) {
var n = t - f
for (var r = f; r < t; r++) {
var i = e[r]
if (i === 12 || i === 2) n -= 1
}
o.length || ((b = g()), (o.indent = b)), (l += n), o.push(l), (f = t)
}
if (e.length == 0) return []
var o = [],
u = e.length,
f = 0,
l = 0,
h = this.$wrapAsCode,
p = this.$indentedSoftWrap,
m = r <= Math.max(2 * i, 8) || p === !1 ? 0 : Math.floor(r / 2),
b = 0
while (u - f > r - b) {
var w = f + r - b
if (e[w - 1] >= c && e[w] >= c) {
y(w)
continue
}
if (e[w] == n || e[w] == s) {
for (w; w != f - 1; w--) if (e[w] == n) break
if (w > f) {
y(w)
continue
}
w = f + r
for (w; w < e.length; w++) if (e[w] != s) break
if (w == e.length) break
y(w)
continue
}
var E = Math.max(w - (r - (r >> 2)), f - 1)
while (w > E && e[w] < n) w--
if (h) {
while (w > E && e[w] < n) w--
while (w > E && e[w] == a) w--
} else while (w > E && e[w] < c) w--
if (w > E) {
y(++w)
continue
}
;(w = f + r), e[w] == t && w--, y(w - b)
}
return o
}),
(this.$getDisplayTokens = function (n, r) {
var i = [],
s
r = r || 0
for (var o = 0; o < n.length; o++) {
var u = n.charCodeAt(o)
if (u == 9) {
;(s = this.getScreenTabSize(i.length + r)), i.push(d)
for (var f = 1; f < s; f++) i.push(v)
} else
u == 32
? i.push(c)
: (u > 39 && u < 48) || (u > 57 && u < 64)
? i.push(a)
: u >= 4352 && m(u)
? i.push(e, t)
: i.push(e)
}
return i
}),
(this.$getStringScreenWidth = function (e, t, n) {
if (t == 0) return [0, 0]
t == null && (t = Infinity), (n = n || 0)
var r, i
for (i = 0; i < e.length; i++) {
;(r = e.charCodeAt(i)),
r == 9 ? (n += this.getScreenTabSize(n)) : r >= 4352 && m(r) ? (n += 2) : (n += 1)
if (n > t) break
}
return [n, i]
}),
(this.lineWidgets = null),
(this.getRowLength = function (e) {
var t = 1
return (
this.lineWidgets &&
(t += (this.lineWidgets[e] && this.lineWidgets[e].rowCount) || 0),
!this.$useWrapMode || !this.$wrapData[e] ? t : this.$wrapData[e].length + t
)
}),
(this.getRowLineCount = function (e) {
return !this.$useWrapMode || !this.$wrapData[e] ? 1 : this.$wrapData[e].length + 1
}),
(this.getRowWrapIndent = function (e) {
if (this.$useWrapMode) {
var t = this.screenToDocumentPosition(e, Number.MAX_VALUE),
n = this.$wrapData[t.row]
return n.length && n[0] < t.column ? n.indent : 0
}
return 0
}),
(this.getScreenLastRowColumn = function (e) {
var t = this.screenToDocumentPosition(e, Number.MAX_VALUE)
return this.documentToScreenColumn(t.row, t.column)
}),
(this.getDocumentLastRowColumn = function (e, t) {
var n = this.documentToScreenRow(e, t)
return this.getScreenLastRowColumn(n)
}),
(this.getDocumentLastRowColumnPosition = function (e, t) {
var n = this.documentToScreenRow(e, t)
return this.screenToDocumentPosition(n, Number.MAX_VALUE / 10)
}),
(this.getRowSplitData = function (e) {
return this.$useWrapMode ? this.$wrapData[e] : undefined
}),
(this.getScreenTabSize = function (e) {
return this.$tabSize - (e % this.$tabSize | 0)
}),
(this.screenToDocumentRow = function (e, t) {
return this.screenToDocumentPosition(e, t).row
}),
(this.screenToDocumentColumn = function (e, t) {
return this.screenToDocumentPosition(e, t).column
}),
(this.screenToDocumentPosition = function (e, t, n) {
if (e < 0) return { row: 0, column: 0 }
var r,
i = 0,
s = 0,
o,
u = 0,
a = 0,
f = this.$screenRowCache,
l = this.$getRowCacheIndex(f, e),
c = f.length
if (c && l >= 0)
var u = f[l],
i = this.$docRowCache[l],
h = e > f[c - 1]
else var h = !c
var p = this.getLength() - 1,
d = this.getNextFoldLine(i),
v = d ? d.start.row : Infinity
while (u <= e) {
a = this.getRowLength(i)
if (u + a > e || i >= p) break
;(u += a),
i++,
i > v &&
((i = d.end.row + 1),
(d = this.getNextFoldLine(i, d)),
(v = d ? d.start.row : Infinity)),
h && (this.$docRowCache.push(i), this.$screenRowCache.push(u))
}
if (d && d.start.row <= i) (r = this.getFoldDisplayLine(d)), (i = d.start.row)
else {
if (u + a <= e || i > p) return { row: p, column: this.getLine(p).length }
;(r = this.getLine(i)), (d = null)
}
var m = 0,
g = Math.floor(e - u)
if (this.$useWrapMode) {
var y = this.$wrapData[i]
y &&
((o = y[g]),
g > 0 &&
y.length &&
((m = y.indent), (s = y[g - 1] || y[y.length - 1]), (r = r.substring(s))))
}
return (
n !== undefined &&
this.$bidiHandler.isBidiRow(u + g, i, g) &&
(t = this.$bidiHandler.offsetToCol(n)),
(s += this.$getStringScreenWidth(r, t - m)[1]),
this.$useWrapMode && s >= o && (s = o - 1),
d ? d.idxToPosition(s) : { row: i, column: s }
)
}),
(this.documentToScreenPosition = function (e, t) {
if (typeof t == 'undefined') var n = this.$clipPositionToDocument(e.row, e.column)
else n = this.$clipPositionToDocument(e, t)
;(e = n.row), (t = n.column)
var r = 0,
i = null,
s = null
;(s = this.getFoldAt(e, t, 1)), s && ((e = s.start.row), (t = s.start.column))
var o,
u = 0,
a = this.$docRowCache,
f = this.$getRowCacheIndex(a, e),
l = a.length
if (l && f >= 0)
var u = a[f],
r = this.$screenRowCache[f],
c = e > a[l - 1]
else var c = !l
var h = this.getNextFoldLine(u),
p = h ? h.start.row : Infinity
while (u < e) {
if (u >= p) {
o = h.end.row + 1
if (o > e) break
;(h = this.getNextFoldLine(o, h)), (p = h ? h.start.row : Infinity)
} else o = u + 1
;(r += this.getRowLength(u)),
(u = o),
c && (this.$docRowCache.push(u), this.$screenRowCache.push(r))
}
var d = ''
h && u >= p
? ((d = this.getFoldDisplayLine(h, e, t)), (i = h.start.row))
: ((d = this.getLine(e).substring(0, t)), (i = e))
var v = 0
if (this.$useWrapMode) {
var m = this.$wrapData[i]
if (m) {
var g = 0
while (d.length >= m[g]) r++, g++
;(d = d.substring(m[g - 1] || 0, d.length)), (v = g > 0 ? m.indent : 0)
}
}
return (
this.lineWidgets &&
this.lineWidgets[u] &&
this.lineWidgets[u].rowsAbove &&
(r += this.lineWidgets[u].rowsAbove),
{ row: r, column: v + this.$getStringScreenWidth(d)[0] }
)
}),
(this.documentToScreenColumn = function (e, t) {
return this.documentToScreenPosition(e, t).column
}),
(this.documentToScreenRow = function (e, t) {
return this.documentToScreenPosition(e, t).row
}),
(this.getScreenLength = function () {
var e = 0,
t = null
if (!this.$useWrapMode) {
e = this.getLength()
var n = this.$foldData
for (var r = 0; r < n.length; r++) (t = n[r]), (e -= t.end.row - t.start.row)
} else {
var i = this.$wrapData.length,
s = 0,
r = 0,
t = this.$foldData[r++],
o = t ? t.start.row : Infinity
while (s < i) {
var u = this.$wrapData[s]
;(e += u ? u.length + 1 : 1),
s++,
s > o &&
((s = t.end.row + 1),
(t = this.$foldData[r++]),
(o = t ? t.start.row : Infinity))
}
}
return this.lineWidgets && (e += this.$getWidgetScreenLength()), e
}),
(this.$setFontMetrics = function (e) {
if (!this.$enableVarChar) return
this.$getStringScreenWidth = function (t, n, r) {
if (n === 0) return [0, 0]
n || (n = Infinity), (r = r || 0)
var i, s
for (s = 0; s < t.length; s++) {
;(i = t.charAt(s)),
i === ' ' ? (r += this.getScreenTabSize(r)) : (r += e.getCharacterWidth(i))
if (r > n) break
}
return [r, s]
}
}),
(this.destroy = function () {
this.bgTokenizer && (this.bgTokenizer.setDocument(null), (this.bgTokenizer = null)),
this.$stopWorker(),
this.removeAllListeners(),
this.selection.detach()
}),
(this.isFullWidth = m)
}.call(d.prototype),
e('./edit_session/folding').Folding.call(d.prototype),
e('./edit_session/bracket_match').BracketMatch.call(d.prototype),
o.defineOptions(d.prototype, 'session', {
wrap: {
set: function (e) {
!e || e == 'off'
? (e = !1)
: e == 'free'
? (e = !0)
: e == 'printMargin'
? (e = -1)
: typeof e == 'string' && (e = parseInt(e, 10) || !1)
if (this.$wrap == e) return
this.$wrap = e
if (!e) this.setUseWrapMode(!1)
else {
var t = typeof e == 'number' ? e : null
this.setWrapLimitRange(t, t), this.setUseWrapMode(!0)
}
},
get: function () {
return this.getUseWrapMode()
? this.$wrap == -1
? 'printMargin'
: this.getWrapLimitRange().min
? this.$wrap
: 'free'
: 'off'
},
handlesSet: !0,
},
wrapMethod: {
set: function (e) {
;(e = e == 'auto' ? this.$mode.type != 'text' : e != 'text'),
e != this.$wrapAsCode &&
((this.$wrapAsCode = e),
this.$useWrapMode && ((this.$useWrapMode = !1), this.setUseWrapMode(!0)))
},
initialValue: 'auto',
},
indentedSoftWrap: {
set: function () {
this.$useWrapMode && ((this.$useWrapMode = !1), this.setUseWrapMode(!0))
},
initialValue: !0,
},
firstLineNumber: {
set: function () {
this._signal('changeBreakpoint')
},
initialValue: 1,
},
useWorker: {
set: function (e) {
;(this.$useWorker = e), this.$stopWorker(), e && this.$startWorker()
},
initialValue: !0,
},
useSoftTabs: { initialValue: !0 },
tabSize: {
set: function (e) {
;(e = parseInt(e)),
e > 0 &&
this.$tabSize !== e &&
((this.$modified = !0),
(this.$rowLengthCache = []),
(this.$tabSize = e),
this._signal('changeTabSize'))
},
initialValue: 4,
handlesSet: !0,
},
navigateWithinSoftTabs: { initialValue: !1 },
foldStyle: {
set: function (e) {
this.setFoldStyle(e)
},
handlesSet: !0,
},
overwrite: {
set: function (e) {
this._signal('changeOverwrite')
},
initialValue: !1,
},
newLineMode: {
set: function (e) {
this.doc.setNewLineMode(e)
},
get: function () {
return this.doc.getNewLineMode()
},
handlesSet: !0,
},
mode: {
set: function (e) {
this.setMode(e)
},
get: function () {
return this.$modeId
},
handlesSet: !0,
},
}),
(t.EditSession = d)
}
),
ace.define(
'ace/search',
['require', 'exports', 'module', 'ace/lib/lang', 'ace/lib/oop', 'ace/range'],
function (e, t, n) {
'use strict'
function u(e, t) {
function n(e) {
return /\w/.test(e) || t.regExp ? '\\b' : ''
}
return n(e[0]) + e + n(e[e.length - 1])
}
var r = e('./lib/lang'),
i = e('./lib/oop'),
s = e('./range').Range,
o = function () {
this.$options = {}
}
;(function () {
;(this.set = function (e) {
return i.mixin(this.$options, e), this
}),
(this.getOptions = function () {
return r.copyObject(this.$options)
}),
(this.setOptions = function (e) {
this.$options = e
}),
(this.find = function (e) {
var t = this.$options,
n = this.$matchIterator(e, t)
if (!n) return !1
var r = null
return (
n.forEach(function (e, n, i, o) {
return (
(r = new s(e, n, i, o)),
n == o && t.start && t.start.start && t.skipCurrent != 0 && r.isEqual(t.start)
? ((r = null), !1)
: !0
)
}),
r
)
}),
(this.findAll = function (e) {
var t = this.$options
if (!t.needle) return []
this.$assembleRegExp(t)
var n = t.range,
i = n ? e.getLines(n.start.row, n.end.row) : e.doc.getAllLines(),
o = [],
u = t.re
if (t.$isMultiLine) {
var a = u.length,
f = i.length - a,
l
e: for (var c = u.offset || 0; c <= f; c++) {
for (var h = 0; h < a; h++) if (i[c + h].search(u[h]) == -1) continue e
var p = i[c],
d = i[c + a - 1],
v = p.length - p.match(u[0])[0].length,
m = d.match(u[a - 1])[0].length
if (l && l.end.row === c && l.end.column > v) continue
o.push((l = new s(c, v, c + a - 1, m))), a > 2 && (c = c + a - 2)
}
} else
for (var g = 0; g < i.length; g++) {
var y = r.getMatchOffsets(i[g], u)
for (var h = 0; h < y.length; h++) {
var b = y[h]
o.push(new s(g, b.offset, g, b.offset + b.length))
}
}
if (n) {
var w = n.start.column,
E = n.start.column,
g = 0,
h = o.length - 1
while (g < h && o[g].start.column < w && o[g].start.row == n.start.row) g++
while (g < h && o[h].end.column > E && o[h].end.row == n.end.row) h--
o = o.slice(g, h + 1)
for (g = 0, h = o.length; g < h; g++)
(o[g].start.row += n.start.row), (o[g].end.row += n.start.row)
}
return o
}),
(this.replace = function (e, t) {
var n = this.$options,
r = this.$assembleRegExp(n)
if (n.$isMultiLine) return t
if (!r) return
var i = r.exec(e)
if (!i || i[0].length != e.length) return null
t = e.replace(r, t)
if (n.preserveCase) {
t = t.split('')
for (var s = Math.min(e.length, e.length); s--; ) {
var o = e[s]
o && o.toLowerCase() != o
? (t[s] = t[s].toUpperCase())
: (t[s] = t[s].toLowerCase())
}
t = t.join('')
}
return t
}),
(this.$assembleRegExp = function (e, t) {
if (e.needle instanceof RegExp) return (e.re = e.needle)
var n = e.needle
if (!e.needle) return (e.re = !1)
e.regExp || (n = r.escapeRegExp(n)), e.wholeWord && (n = u(n, e))
var i = e.caseSensitive ? 'gm' : 'gmi'
e.$isMultiLine = !t && /[\n\r]/.test(n)
if (e.$isMultiLine) return (e.re = this.$assembleMultilineRegExp(n, i))
try {
var s = new RegExp(n, i)
} catch (o) {
s = !1
}
return (e.re = s)
}),
(this.$assembleMultilineRegExp = function (e, t) {
var n = e.replace(/\r\n|\r|\n/g, '$\n^').split('\n'),
r = []
for (var i = 0; i < n.length; i++)
try {
r.push(new RegExp(n[i], t))
} catch (s) {
return !1
}
return r
}),
(this.$matchIterator = function (e, t) {
var n = this.$assembleRegExp(t)
if (!n) return !1
var r = t.backwards == 1,
i = t.skipCurrent != 0,
s = t.range,
o = t.start
o || (o = s ? s[r ? 'end' : 'start'] : e.selection.getRange()),
o.start && (o = o[i != r ? 'end' : 'start'])
var u = s ? s.start.row : 0,
a = s ? s.end.row : e.getLength() - 1
if (r)
var f = function (e) {
var n = o.row
if (c(n, o.column, e)) return
for (n--; n >= u; n--) if (c(n, Number.MAX_VALUE, e)) return
if (t.wrap == 0) return
for (n = a, u = o.row; n >= u; n--) if (c(n, Number.MAX_VALUE, e)) return
}
else
var f = function (e) {
var n = o.row
if (c(n, o.column, e)) return
for (n += 1; n <= a; n++) if (c(n, 0, e)) return
if (t.wrap == 0) return
for (n = u, a = o.row; n <= a; n++) if (c(n, 0, e)) return
}
if (t.$isMultiLine)
var l = n.length,
c = function (t, i, s) {
var o = r ? t - l + 1 : t
if (o < 0) return
var u = e.getLine(o),
a = u.search(n[0])
if ((!r && a < i) || a === -1) return
for (var f = 1; f < l; f++) {
u = e.getLine(o + f)
if (u.search(n[f]) == -1) return
}
var c = u.match(n[l - 1])[0].length
if (r && c > i) return
if (s(o, a, o + l - 1, c)) return !0
}
else if (r)
var c = function (t, r, i) {
var s = e.getLine(t),
o = [],
u,
a = 0
n.lastIndex = 0
while ((u = n.exec(s))) {
var f = u[0].length
a = u.index
if (!f) {
if (a >= s.length) break
n.lastIndex = a += 1
}
if (u.index + f > r) break
o.push(u.index, f)
}
for (var l = o.length - 1; l >= 0; l -= 2) {
var c = o[l - 1],
f = o[l]
if (i(t, c, t, c + f)) return !0
}
}
else
var c = function (t, r, i) {
var s = e.getLine(t),
o,
u
n.lastIndex = r
while ((u = n.exec(s))) {
var a = u[0].length
o = u.index
if (i(t, o, t, o + a)) return !0
if (!a) {
n.lastIndex = o += 1
if (o >= s.length) return !1
}
}
}
return { forEach: f }
})
}).call(o.prototype),
(t.Search = o)
}
),
ace.define(
'ace/keyboard/hash_handler',
['require', 'exports', 'module', 'ace/lib/keys', 'ace/lib/useragent'],
function (e, t, n) {
'use strict'
function o(e, t) {
;(this.platform = t || (i.isMac ? 'mac' : 'win')),
(this.commands = {}),
(this.commandKeyBinding = {}),
this.addCommands(e),
(this.$singleCommand = !0)
}
function u(e, t) {
o.call(this, e, t), (this.$singleCommand = !1)
}
var r = e('../lib/keys'),
i = e('../lib/useragent'),
s = r.KEY_MODS
;(u.prototype = o.prototype),
function () {
function e(e) {
return (
(typeof e == 'object' && e.bindKey && e.bindKey.position) || (e.isDefault ? -100 : 0)
)
}
;(this.addCommand = function (e) {
this.commands[e.name] && this.removeCommand(e),
(this.commands[e.name] = e),
e.bindKey && this._buildKeyHash(e)
}),
(this.removeCommand = function (e, t) {
var n = e && (typeof e == 'string' ? e : e.name)
;(e = this.commands[n]), t || delete this.commands[n]
var r = this.commandKeyBinding
for (var i in r) {
var s = r[i]
if (s == e) delete r[i]
else if (Array.isArray(s)) {
var o = s.indexOf(e)
o != -1 && (s.splice(o, 1), s.length == 1 && (r[i] = s[0]))
}
}
}),
(this.bindKey = function (e, t, n) {
typeof e == 'object' &&
e &&
(n == undefined && (n = e.position), (e = e[this.platform]))
if (!e) return
if (typeof t == 'function')
return this.addCommand({ exec: t, bindKey: e, name: t.name || e })
e.split('|').forEach(function (e) {
var r = ''
if (e.indexOf(' ') != -1) {
var i = e.split(/\s+/)
;(e = i.pop()),
i.forEach(function (e) {
var t = this.parseKeys(e),
n = s[t.hashId] + t.key
;(r += (r ? ' ' : '') + n), this._addCommandToBinding(r, 'chainKeys')
}, this),
(r += ' ')
}
var o = this.parseKeys(e),
u = s[o.hashId] + o.key
this._addCommandToBinding(r + u, t, n)
}, this)
}),
(this._addCommandToBinding = function (t, n, r) {
var i = this.commandKeyBinding,
s
if (!n) delete i[t]
else if (!i[t] || this.$singleCommand) i[t] = n
else {
Array.isArray(i[t])
? (s = i[t].indexOf(n)) != -1 && i[t].splice(s, 1)
: (i[t] = [i[t]]),
typeof r != 'number' && (r = e(n))
var o = i[t]
for (s = 0; s < o.length; s++) {
var u = o[s],
a = e(u)
if (a > r) break
}
o.splice(s, 0, n)
}
}),
(this.addCommands = function (e) {
e &&
Object.keys(e).forEach(function (t) {
var n = e[t]
if (!n) return
if (typeof n == 'string') return this.bindKey(n, t)
typeof n == 'function' && (n = { exec: n })
if (typeof n != 'object') return
n.name || (n.name = t), this.addCommand(n)
}, this)
}),
(this.removeCommands = function (e) {
Object.keys(e).forEach(function (t) {
this.removeCommand(e[t])
}, this)
}),
(this.bindKeys = function (e) {
Object.keys(e).forEach(function (t) {
this.bindKey(t, e[t])
}, this)
}),
(this._buildKeyHash = function (e) {
this.bindKey(e.bindKey, e)
}),
(this.parseKeys = function (e) {
var t = e
.toLowerCase()
.split(/[\-\+]([\-\+])?/)
.filter(function (e) {
return e
}),
n = t.pop(),
i = r[n]
if (r.FUNCTION_KEYS[i]) n = r.FUNCTION_KEYS[i].toLowerCase()
else {
if (!t.length) return { key: n, hashId: -1 }
if (t.length == 1 && t[0] == 'shift') return { key: n.toUpperCase(), hashId: -1 }
}
var s = 0
for (var o = t.length; o--; ) {
var u = r.KEY_MODS[t[o]]
if (u == null)
return (
typeof console != 'undefined' &&
console.error('invalid modifier ' + t[o] + ' in ' + e),
!1
)
s |= u
}
return { key: n, hashId: s }
}),
(this.findKeyCommand = function (t, n) {
var r = s[t] + n
return this.commandKeyBinding[r]
}),
(this.handleKeyboard = function (e, t, n, r) {
if (r < 0) return
var i = s[t] + n,
o = this.commandKeyBinding[i]
e.$keyChain &&
((e.$keyChain += ' ' + i), (o = this.commandKeyBinding[e.$keyChain] || o))
if (o)
if (o == 'chainKeys' || o[o.length - 1] == 'chainKeys')
return (e.$keyChain = e.$keyChain || i), { command: 'null' }
if (e.$keyChain)
if ((!!t && t != 4) || n.length != 1) {
if (t == -1 || r > 0) e.$keyChain = ''
} else e.$keyChain = e.$keyChain.slice(0, -i.length - 1)
return { command: o }
}),
(this.getStatusText = function (e, t) {
return t.$keyChain || ''
})
}.call(o.prototype),
(t.HashHandler = o),
(t.MultiHashHandler = u)
}
),
ace.define(
'ace/commands/command_manager',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/keyboard/hash_handler',
'ace/lib/event_emitter',
],
function (e, t, n) {
'use strict'
var r = e('../lib/oop'),
i = e('../keyboard/hash_handler').MultiHashHandler,
s = e('../lib/event_emitter').EventEmitter,
o = function (e, t) {
i.call(this, t, e),
(this.byName = this.commands),
this.setDefaultHandler('exec', function (e) {
return e.command.exec(e.editor, e.args || {})
})
}
r.inherits(o, i),
function () {
r.implement(this, s),
(this.exec = function (e, t, n) {
if (Array.isArray(e)) {
for (var r = e.length; r--; ) if (this.exec(e[r], t, n)) return !0
return !1
}
typeof e == 'string' && (e = this.commands[e])
if (!e) return !1
if (t && t.$readOnly && !e.readOnly) return !1
if (this.$checkCommandState != 0 && e.isAvailable && !e.isAvailable(t)) return !1
var i = { editor: t, command: e, args: n }
return (
(i.returnValue = this._emit('exec', i)),
this._signal('afterExec', i),
i.returnValue === !1 ? !1 : !0
)
}),
(this.toggleRecording = function (e) {
if (this.$inReplay) return
return (
e && e._emit('changeStatus'),
this.recording
? (this.macro.pop(),
this.off('exec', this.$addCommandToMacro),
this.macro.length || (this.macro = this.oldMacro),
(this.recording = !1))
: (this.$addCommandToMacro ||
(this.$addCommandToMacro = function (e) {
this.macro.push([e.command, e.args])
}.bind(this)),
(this.oldMacro = this.macro),
(this.macro = []),
this.on('exec', this.$addCommandToMacro),
(this.recording = !0))
)
}),
(this.replay = function (e) {
if (this.$inReplay || !this.macro) return
if (this.recording) return this.toggleRecording(e)
try {
;(this.$inReplay = !0),
this.macro.forEach(function (t) {
typeof t == 'string' ? this.exec(t, e) : this.exec(t[0], e, t[1])
}, this)
} finally {
this.$inReplay = !1
}
}),
(this.trimMacro = function (e) {
return e.map(function (e) {
return typeof e[0] != 'string' && (e[0] = e[0].name), e[1] || (e = e[0]), e
})
})
}.call(o.prototype),
(t.CommandManager = o)
}
),
ace.define(
'ace/commands/default_commands',
['require', 'exports', 'module', 'ace/lib/lang', 'ace/config', 'ace/range'],
function (e, t, n) {
'use strict'
function o(e, t) {
return { win: e, mac: t }
}
var r = e('../lib/lang'),
i = e('../config'),
s = e('../range').Range
t.commands = [
{
name: 'showSettingsMenu',
bindKey: o('Ctrl-,', 'Command-,'),
exec: function (e) {
i.loadModule('ace/ext/settings_menu', function (t) {
t.init(e), e.showSettingsMenu()
})
},
readOnly: !0,
},
{
name: 'goToNextError',
bindKey: o('Alt-E', 'F4'),
exec: function (e) {
i.loadModule('./ext/error_marker', function (t) {
t.showErrorMarker(e, 1)
})
},
scrollIntoView: 'animate',
readOnly: !0,
},
{
name: 'goToPreviousError',
bindKey: o('Alt-Shift-E', 'Shift-F4'),
exec: function (e) {
i.loadModule('./ext/error_marker', function (t) {
t.showErrorMarker(e, -1)
})
},
scrollIntoView: 'animate',
readOnly: !0,
},
{
name: 'selectall',
description: 'Select all',
bindKey: o('Ctrl-A', 'Command-A'),
exec: function (e) {
e.selectAll()
},
readOnly: !0,
},
{
name: 'centerselection',
description: 'Center selection',
bindKey: o(null, 'Ctrl-L'),
exec: function (e) {
e.centerSelection()
},
readOnly: !0,
},
{
name: 'gotoline',
description: 'Go to line...',
bindKey: o('Ctrl-L', 'Command-L'),
exec: function (e, t) {
typeof t == 'number' && !isNaN(t) && e.gotoLine(t), e.prompt({ $type: 'gotoLine' })
},
readOnly: !0,
},
{
name: 'fold',
bindKey: o('Alt-L|Ctrl-F1', 'Command-Alt-L|Command-F1'),
exec: function (e) {
e.session.toggleFold(!1)
},
multiSelectAction: 'forEach',
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'unfold',
bindKey: o('Alt-Shift-L|Ctrl-Shift-F1', 'Command-Alt-Shift-L|Command-Shift-F1'),
exec: function (e) {
e.session.toggleFold(!0)
},
multiSelectAction: 'forEach',
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'toggleFoldWidget',
bindKey: o('F2', 'F2'),
exec: function (e) {
e.session.toggleFoldWidget()
},
multiSelectAction: 'forEach',
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'toggleParentFoldWidget',
bindKey: o('Alt-F2', 'Alt-F2'),
exec: function (e) {
e.session.toggleFoldWidget(!0)
},
multiSelectAction: 'forEach',
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'foldall',
description: 'Fold all',
bindKey: o(null, 'Ctrl-Command-Option-0'),
exec: function (e) {
e.session.foldAll()
},
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'foldAllComments',
description: 'Fold all comments',
bindKey: o(null, 'Ctrl-Command-Option-0'),
exec: function (e) {
e.session.foldAllComments()
},
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'foldOther',
description: 'Fold other',
bindKey: o('Alt-0', 'Command-Option-0'),
exec: function (e) {
e.session.foldAll(), e.session.unfold(e.selection.getAllRanges())
},
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'unfoldall',
description: 'Unfold all',
bindKey: o('Alt-Shift-0', 'Command-Option-Shift-0'),
exec: function (e) {
e.session.unfold()
},
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'findnext',
description: 'Find next',
bindKey: o('Ctrl-K', 'Command-G'),
exec: function (e) {
e.findNext()
},
multiSelectAction: 'forEach',
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'findprevious',
description: 'Find previous',
bindKey: o('Ctrl-Shift-K', 'Command-Shift-G'),
exec: function (e) {
e.findPrevious()
},
multiSelectAction: 'forEach',
scrollIntoView: 'center',
readOnly: !0,
},
{
name: 'selectOrFindNext',
description: 'Select or find next',
bindKey: o('Alt-K', 'Ctrl-G'),
exec: function (e) {
e.selection.isEmpty() ? e.selection.selectWord() : e.findNext()
},
readOnly: !0,
},
{
name: 'selectOrFindPrevious',
description: 'Select or find previous',
bindKey: o('Alt-Shift-K', 'Ctrl-Shift-G'),
exec: function (e) {
e.selection.isEmpty() ? e.selection.selectWord() : e.findPrevious()
},
readOnly: !0,
},
{
name: 'find',
description: 'Find',
bindKey: o('Ctrl-F', 'Command-F'),
exec: function (e) {
i.loadModule('ace/ext/searchbox', function (t) {
t.Search(e)
})
},
readOnly: !0,
},
{
name: 'overwrite',
description: 'Overwrite',
bindKey: 'Insert',
exec: function (e) {
e.toggleOverwrite()
},
readOnly: !0,
},
{
name: 'selecttostart',
description: 'Select to start',
bindKey: o('Ctrl-Shift-Home', 'Command-Shift-Home|Command-Shift-Up'),
exec: function (e) {
e.getSelection().selectFileStart()
},
multiSelectAction: 'forEach',
readOnly: !0,
scrollIntoView: 'animate',
aceCommandGroup: 'fileJump',
},
{
name: 'gotostart',
description: 'Go to start',
bindKey: o('Ctrl-Home', 'Command-Home|Command-Up'),
exec: function (e) {
e.navigateFileStart()
},
multiSelectAction: 'forEach',
readOnly: !0,
scrollIntoView: 'animate',
aceCommandGroup: 'fileJump',
},
{
name: 'selectup',
description: 'Select up',
bindKey: o('Shift-Up', 'Shift-Up|Ctrl-Shift-P'),
exec: function (e) {
e.getSelection().selectUp()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'golineup',
description: 'Go line up',
bindKey: o('Up', 'Up|Ctrl-P'),
exec: function (e, t) {
e.navigateUp(t.times)
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selecttoend',
description: 'Select to end',
bindKey: o('Ctrl-Shift-End', 'Command-Shift-End|Command-Shift-Down'),
exec: function (e) {
e.getSelection().selectFileEnd()
},
multiSelectAction: 'forEach',
readOnly: !0,
scrollIntoView: 'animate',
aceCommandGroup: 'fileJump',
},
{
name: 'gotoend',
description: 'Go to end',
bindKey: o('Ctrl-End', 'Command-End|Command-Down'),
exec: function (e) {
e.navigateFileEnd()
},
multiSelectAction: 'forEach',
readOnly: !0,
scrollIntoView: 'animate',
aceCommandGroup: 'fileJump',
},
{
name: 'selectdown',
description: 'Select down',
bindKey: o('Shift-Down', 'Shift-Down|Ctrl-Shift-N'),
exec: function (e) {
e.getSelection().selectDown()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'golinedown',
description: 'Go line down',
bindKey: o('Down', 'Down|Ctrl-N'),
exec: function (e, t) {
e.navigateDown(t.times)
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectwordleft',
description: 'Select word left',
bindKey: o('Ctrl-Shift-Left', 'Option-Shift-Left'),
exec: function (e) {
e.getSelection().selectWordLeft()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'gotowordleft',
description: 'Go to word left',
bindKey: o('Ctrl-Left', 'Option-Left'),
exec: function (e) {
e.navigateWordLeft()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selecttolinestart',
description: 'Select to line start',
bindKey: o('Alt-Shift-Left', 'Command-Shift-Left|Ctrl-Shift-A'),
exec: function (e) {
e.getSelection().selectLineStart()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'gotolinestart',
description: 'Go to line start',
bindKey: o('Alt-Left|Home', 'Command-Left|Home|Ctrl-A'),
exec: function (e) {
e.navigateLineStart()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectleft',
description: 'Select left',
bindKey: o('Shift-Left', 'Shift-Left|Ctrl-Shift-B'),
exec: function (e) {
e.getSelection().selectLeft()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'gotoleft',
description: 'Go to left',
bindKey: o('Left', 'Left|Ctrl-B'),
exec: function (e, t) {
e.navigateLeft(t.times)
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectwordright',
description: 'Select word right',
bindKey: o('Ctrl-Shift-Right', 'Option-Shift-Right'),
exec: function (e) {
e.getSelection().selectWordRight()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'gotowordright',
description: 'Go to word right',
bindKey: o('Ctrl-Right', 'Option-Right'),
exec: function (e) {
e.navigateWordRight()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selecttolineend',
description: 'Select to line end',
bindKey: o('Alt-Shift-Right', 'Command-Shift-Right|Shift-End|Ctrl-Shift-E'),
exec: function (e) {
e.getSelection().selectLineEnd()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'gotolineend',
description: 'Go to line end',
bindKey: o('Alt-Right|End', 'Command-Right|End|Ctrl-E'),
exec: function (e) {
e.navigateLineEnd()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectright',
description: 'Select right',
bindKey: o('Shift-Right', 'Shift-Right'),
exec: function (e) {
e.getSelection().selectRight()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'gotoright',
description: 'Go to right',
bindKey: o('Right', 'Right|Ctrl-F'),
exec: function (e, t) {
e.navigateRight(t.times)
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectpagedown',
description: 'Select page down',
bindKey: 'Shift-PageDown',
exec: function (e) {
e.selectPageDown()
},
readOnly: !0,
},
{
name: 'pagedown',
description: 'Page down',
bindKey: o(null, 'Option-PageDown'),
exec: function (e) {
e.scrollPageDown()
},
readOnly: !0,
},
{
name: 'gotopagedown',
description: 'Go to page down',
bindKey: o('PageDown', 'PageDown|Ctrl-V'),
exec: function (e) {
e.gotoPageDown()
},
readOnly: !0,
},
{
name: 'selectpageup',
description: 'Select page up',
bindKey: 'Shift-PageUp',
exec: function (e) {
e.selectPageUp()
},
readOnly: !0,
},
{
name: 'pageup',
description: 'Page up',
bindKey: o(null, 'Option-PageUp'),
exec: function (e) {
e.scrollPageUp()
},
readOnly: !0,
},
{
name: 'gotopageup',
description: 'Go to page up',
bindKey: 'PageUp',
exec: function (e) {
e.gotoPageUp()
},
readOnly: !0,
},
{
name: 'scrollup',
description: 'Scroll up',
bindKey: o('Ctrl-Up', null),
exec: function (e) {
e.renderer.scrollBy(0, -2 * e.renderer.layerConfig.lineHeight)
},
readOnly: !0,
},
{
name: 'scrolldown',
description: 'Scroll down',
bindKey: o('Ctrl-Down', null),
exec: function (e) {
e.renderer.scrollBy(0, 2 * e.renderer.layerConfig.lineHeight)
},
readOnly: !0,
},
{
name: 'selectlinestart',
description: 'Select line start',
bindKey: 'Shift-Home',
exec: function (e) {
e.getSelection().selectLineStart()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectlineend',
description: 'Select line end',
bindKey: 'Shift-End',
exec: function (e) {
e.getSelection().selectLineEnd()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'togglerecording',
description: 'Toggle recording',
bindKey: o('Ctrl-Alt-E', 'Command-Option-E'),
exec: function (e) {
e.commands.toggleRecording(e)
},
readOnly: !0,
},
{
name: 'replaymacro',
description: 'Replay macro',
bindKey: o('Ctrl-Shift-E', 'Command-Shift-E'),
exec: function (e) {
e.commands.replay(e)
},
readOnly: !0,
},
{
name: 'jumptomatching',
description: 'Jump to matching',
bindKey: o('Ctrl-\\|Ctrl-P', 'Command-\\'),
exec: function (e) {
e.jumpToMatching()
},
multiSelectAction: 'forEach',
scrollIntoView: 'animate',
readOnly: !0,
},
{
name: 'selecttomatching',
description: 'Select to matching',
bindKey: o('Ctrl-Shift-\\|Ctrl-Shift-P', 'Command-Shift-\\'),
exec: function (e) {
e.jumpToMatching(!0)
},
multiSelectAction: 'forEach',
scrollIntoView: 'animate',
readOnly: !0,
},
{
name: 'expandToMatching',
description: 'Expand to matching',
bindKey: o('Ctrl-Shift-M', 'Ctrl-Shift-M'),
exec: function (e) {
e.jumpToMatching(!0, !0)
},
multiSelectAction: 'forEach',
scrollIntoView: 'animate',
readOnly: !0,
},
{
name: 'passKeysToBrowser',
description: 'Pass keys to browser',
bindKey: o(null, null),
exec: function () {},
passEvent: !0,
readOnly: !0,
},
{ name: 'copy', description: 'Copy', exec: function (e) {}, readOnly: !0 },
{
name: 'cut',
description: 'Cut',
exec: function (e) {
var t = e.$copyWithEmptySelection && e.selection.isEmpty(),
n = t ? e.selection.getLineRange() : e.selection.getRange()
e._emit('cut', n), n.isEmpty() || e.session.remove(n), e.clearSelection()
},
scrollIntoView: 'cursor',
multiSelectAction: 'forEach',
},
{
name: 'paste',
description: 'Paste',
exec: function (e, t) {
e.$handlePaste(t)
},
scrollIntoView: 'cursor',
},
{
name: 'removeline',
description: 'Remove line',
bindKey: o('Ctrl-D', 'Command-D'),
exec: function (e) {
e.removeLines()
},
scrollIntoView: 'cursor',
multiSelectAction: 'forEachLine',
},
{
name: 'duplicateSelection',
description: 'Duplicate selection',
bindKey: o('Ctrl-Shift-D', 'Command-Shift-D'),
exec: function (e) {
e.duplicateSelection()
},
scrollIntoView: 'cursor',
multiSelectAction: 'forEach',
},
{
name: 'sortlines',
description: 'Sort lines',
bindKey: o('Ctrl-Alt-S', 'Command-Alt-S'),
exec: function (e) {
e.sortLines()
},
scrollIntoView: 'selection',
multiSelectAction: 'forEachLine',
},
{
name: 'togglecomment',
description: 'Toggle comment',
bindKey: o('Ctrl-/', 'Command-/'),
exec: function (e) {
e.toggleCommentLines()
},
multiSelectAction: 'forEachLine',
scrollIntoView: 'selectionPart',
},
{
name: 'toggleBlockComment',
description: 'Toggle block comment',
bindKey: o('Ctrl-Shift-/', 'Command-Shift-/'),
exec: function (e) {
e.toggleBlockComment()
},
multiSelectAction: 'forEach',
scrollIntoView: 'selectionPart',
},
{
name: 'modifyNumberUp',
description: 'Modify number up',
bindKey: o('Ctrl-Shift-Up', 'Alt-Shift-Up'),
exec: function (e) {
e.modifyNumber(1)
},
scrollIntoView: 'cursor',
multiSelectAction: 'forEach',
},
{
name: 'modifyNumberDown',
description: 'Modify number down',
bindKey: o('Ctrl-Shift-Down', 'Alt-Shift-Down'),
exec: function (e) {
e.modifyNumber(-1)
},
scrollIntoView: 'cursor',
multiSelectAction: 'forEach',
},
{
name: 'replace',
description: 'Replace',
bindKey: o('Ctrl-H', 'Command-Option-F'),
exec: function (e) {
i.loadModule('ace/ext/searchbox', function (t) {
t.Search(e, !0)
})
},
},
{
name: 'undo',
description: 'Undo',
bindKey: o('Ctrl-Z', 'Command-Z'),
exec: function (e) {
e.undo()
},
},
{
name: 'redo',
description: 'Redo',
bindKey: o('Ctrl-Shift-Z|Ctrl-Y', 'Command-Shift-Z|Command-Y'),
exec: function (e) {
e.redo()
},
},
{
name: 'copylinesup',
description: 'Copy lines up',
bindKey: o('Alt-Shift-Up', 'Command-Option-Up'),
exec: function (e) {
e.copyLinesUp()
},
scrollIntoView: 'cursor',
},
{
name: 'movelinesup',
description: 'Move lines up',
bindKey: o('Alt-Up', 'Option-Up'),
exec: function (e) {
e.moveLinesUp()
},
scrollIntoView: 'cursor',
},
{
name: 'copylinesdown',
description: 'Copy lines down',
bindKey: o('Alt-Shift-Down', 'Command-Option-Down'),
exec: function (e) {
e.copyLinesDown()
},
scrollIntoView: 'cursor',
},
{
name: 'movelinesdown',
description: 'Move lines down',
bindKey: o('Alt-Down', 'Option-Down'),
exec: function (e) {
e.moveLinesDown()
},
scrollIntoView: 'cursor',
},
{
name: 'del',
description: 'Delete',
bindKey: o('Delete', 'Delete|Ctrl-D|Shift-Delete'),
exec: function (e) {
e.remove('right')
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'backspace',
description: 'Backspace',
bindKey: o(
'Shift-Backspace|Backspace',
'Ctrl-Backspace|Shift-Backspace|Backspace|Ctrl-H'
),
exec: function (e) {
e.remove('left')
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'cut_or_delete',
description: 'Cut or delete',
bindKey: o('Shift-Delete', null),
exec: function (e) {
if (!e.selection.isEmpty()) return !1
e.remove('left')
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'removetolinestart',
description: 'Remove to line start',
bindKey: o('Alt-Backspace', 'Command-Backspace'),
exec: function (e) {
e.removeToLineStart()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'removetolineend',
description: 'Remove to line end',
bindKey: o('Alt-Delete', 'Ctrl-K|Command-Delete'),
exec: function (e) {
e.removeToLineEnd()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'removetolinestarthard',
description: 'Remove to line start hard',
bindKey: o('Ctrl-Shift-Backspace', null),
exec: function (e) {
var t = e.selection.getRange()
;(t.start.column = 0), e.session.remove(t)
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'removetolineendhard',
description: 'Remove to line end hard',
bindKey: o('Ctrl-Shift-Delete', null),
exec: function (e) {
var t = e.selection.getRange()
;(t.end.column = Number.MAX_VALUE), e.session.remove(t)
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'removewordleft',
description: 'Remove word left',
bindKey: o('Ctrl-Backspace', 'Alt-Backspace|Ctrl-Alt-Backspace'),
exec: function (e) {
e.removeWordLeft()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'removewordright',
description: 'Remove word right',
bindKey: o('Ctrl-Delete', 'Alt-Delete'),
exec: function (e) {
e.removeWordRight()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'outdent',
description: 'Outdent',
bindKey: o('Shift-Tab', 'Shift-Tab'),
exec: function (e) {
e.blockOutdent()
},
multiSelectAction: 'forEach',
scrollIntoView: 'selectionPart',
},
{
name: 'indent',
description: 'Indent',
bindKey: o('Tab', 'Tab'),
exec: function (e) {
e.indent()
},
multiSelectAction: 'forEach',
scrollIntoView: 'selectionPart',
},
{
name: 'blockoutdent',
description: 'Block outdent',
bindKey: o('Ctrl-[', 'Ctrl-['),
exec: function (e) {
e.blockOutdent()
},
multiSelectAction: 'forEachLine',
scrollIntoView: 'selectionPart',
},
{
name: 'blockindent',
description: 'Block indent',
bindKey: o('Ctrl-]', 'Ctrl-]'),
exec: function (e) {
e.blockIndent()
},
multiSelectAction: 'forEachLine',
scrollIntoView: 'selectionPart',
},
{
name: 'insertstring',
description: 'Insert string',
exec: function (e, t) {
e.insert(t)
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'inserttext',
description: 'Insert text',
exec: function (e, t) {
e.insert(r.stringRepeat(t.text || '', t.times || 1))
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'splitline',
description: 'Split line',
bindKey: o(null, 'Ctrl-O'),
exec: function (e) {
e.splitLine()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'transposeletters',
description: 'Transpose letters',
bindKey: o('Alt-Shift-X', 'Ctrl-T'),
exec: function (e) {
e.transposeLetters()
},
multiSelectAction: function (e) {
e.transposeSelections(1)
},
scrollIntoView: 'cursor',
},
{
name: 'touppercase',
description: 'To uppercase',
bindKey: o('Ctrl-U', 'Ctrl-U'),
exec: function (e) {
e.toUpperCase()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'tolowercase',
description: 'To lowercase',
bindKey: o('Ctrl-Shift-U', 'Ctrl-Shift-U'),
exec: function (e) {
e.toLowerCase()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'autoindent',
description: 'Auto Indent',
bindKey: o(null, null),
exec: function (e) {
e.autoIndent()
},
multiSelectAction: 'forEachLine',
scrollIntoView: 'animate',
},
{
name: 'expandtoline',
description: 'Expand to line',
bindKey: o('Ctrl-Shift-L', 'Command-Shift-L'),
exec: function (e) {
var t = e.selection.getRange()
;(t.start.column = t.end.column = 0), t.end.row++, e.selection.setRange(t, !1)
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'joinlines',
description: 'Join lines',
bindKey: o(null, null),
exec: function (e) {
var t = e.selection.isBackwards(),
n = t ? e.selection.getSelectionLead() : e.selection.getSelectionAnchor(),
i = t ? e.selection.getSelectionAnchor() : e.selection.getSelectionLead(),
o = e.session.doc.getLine(n.row).length,
u = e.session.doc.getTextRange(e.selection.getRange()),
a = u.replace(/\n\s*/, ' ').length,
f = e.session.doc.getLine(n.row)
for (var l = n.row + 1; l <= i.row + 1; l++) {
var c = r.stringTrimLeft(r.stringTrimRight(e.session.doc.getLine(l)))
c.length !== 0 && (c = ' ' + c), (f += c)
}
i.row + 1 < e.session.doc.getLength() - 1 && (f += e.session.doc.getNewLineCharacter()),
e.clearSelection(),
e.session.doc.replace(new s(n.row, 0, i.row + 2, 0), f),
a > 0
? (e.selection.moveCursorTo(n.row, n.column),
e.selection.selectTo(n.row, n.column + a))
: ((o = e.session.doc.getLine(n.row).length > o ? o + 1 : o),
e.selection.moveCursorTo(n.row, o))
},
multiSelectAction: 'forEach',
readOnly: !0,
},
{
name: 'invertSelection',
description: 'Invert selection',
bindKey: o(null, null),
exec: function (e) {
var t = e.session.doc.getLength() - 1,
n = e.session.doc.getLine(t).length,
r = e.selection.rangeList.ranges,
i = []
r.length < 1 && (r = [e.selection.getRange()])
for (var o = 0; o < r.length; o++)
o == r.length - 1 &&
(r[o].end.row !== t || r[o].end.column !== n) &&
i.push(new s(r[o].end.row, r[o].end.column, t, n)),
o === 0
? (r[o].start.row !== 0 || r[o].start.column !== 0) &&
i.push(new s(0, 0, r[o].start.row, r[o].start.column))
: i.push(
new s(
r[o - 1].end.row,
r[o - 1].end.column,
r[o].start.row,
r[o].start.column
)
)
e.exitMultiSelectMode(), e.clearSelection()
for (var o = 0; o < i.length; o++) e.selection.addRange(i[o], !1)
},
readOnly: !0,
scrollIntoView: 'none',
},
{
name: 'addLineAfter',
exec: function (e) {
e.selection.clearSelection(), e.navigateLineEnd(), e.insert('\n')
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'addLineBefore',
exec: function (e) {
e.selection.clearSelection()
var t = e.getCursorPosition()
e.selection.moveTo(t.row - 1, Number.MAX_VALUE),
e.insert('\n'),
t.row === 0 && e.navigateUp()
},
multiSelectAction: 'forEach',
scrollIntoView: 'cursor',
},
{
name: 'openCommandPallete',
description: 'Open command pallete',
bindKey: o('F1', 'F1'),
exec: function (e) {
e.prompt({ $type: 'commands' })
},
readOnly: !0,
},
{
name: 'modeSelect',
description: 'Change language mode...',
bindKey: o(null, null),
exec: function (e) {
e.prompt({ $type: 'modes' })
},
readOnly: !0,
},
]
for (var u = 1; u < 9; u++)
t.commands.push({
name: 'foldToLevel' + u,
description: 'Fold To Level ' + u,
level: u,
exec: function (e) {
e.session.foldToLevel(this.level)
},
scrollIntoView: 'center',
readOnly: !0,
})
}
),
ace.define(
'ace/editor',
[
'require',
'exports',
'module',
'ace/lib/fixoldbrowsers',
'ace/lib/oop',
'ace/lib/dom',
'ace/lib/lang',
'ace/lib/useragent',
'ace/keyboard/textinput',
'ace/mouse/mouse_handler',
'ace/mouse/fold_handler',
'ace/keyboard/keybinding',
'ace/edit_session',
'ace/search',
'ace/range',
'ace/lib/event_emitter',
'ace/commands/command_manager',
'ace/commands/default_commands',
'ace/config',
'ace/token_iterator',
'ace/clipboard',
],
function (e, t, n) {
'use strict'
e('./lib/fixoldbrowsers')
var r = e('./lib/oop'),
i = e('./lib/dom'),
s = e('./lib/lang'),
o = e('./lib/useragent'),
u = e('./keyboard/textinput').TextInput,
a = e('./mouse/mouse_handler').MouseHandler,
f = e('./mouse/fold_handler').FoldHandler,
l = e('./keyboard/keybinding').KeyBinding,
c = e('./edit_session').EditSession,
h = e('./search').Search,
p = e('./range').Range,
d = e('./lib/event_emitter').EventEmitter,
v = e('./commands/command_manager').CommandManager,
m = e('./commands/default_commands').commands,
g = e('./config'),
y = e('./token_iterator').TokenIterator,
b = e('./clipboard'),
w = function (e, t, n) {
this.$toDestroy = []
var r = e.getContainerElement()
;(this.container = r),
(this.renderer = e),
(this.id = 'editor' + ++w.$uid),
(this.commands = new v(o.isMac ? 'mac' : 'win', m)),
typeof document == 'object' &&
((this.textInput = new u(e.getTextAreaContainer(), this)),
(this.renderer.textarea = this.textInput.getElement()),
(this.$mouseHandler = new a(this)),
new f(this)),
(this.keyBinding = new l(this)),
(this.$search = new h().set({ wrap: !0 })),
(this.$historyTracker = this.$historyTracker.bind(this)),
this.commands.on('exec', this.$historyTracker),
this.$initOperationListeners(),
(this._$emitInputEvent = s.delayedCall(
function () {
this._signal('input', {}),
this.session &&
this.session.bgTokenizer &&
this.session.bgTokenizer.scheduleStart()
}.bind(this)
)),
this.on('change', function (e, t) {
t._$emitInputEvent.schedule(31)
}),
this.setSession(t || (n && n.session) || new c('')),
g.resetOptions(this),
n && this.setOptions(n),
g._signal('editor', this)
}
;(w.$uid = 0),
function () {
r.implement(this, d),
(this.$initOperationListeners = function () {
this.commands.on('exec', this.startOperation.bind(this), !0),
this.commands.on('afterExec', this.endOperation.bind(this), !0),
(this.$opResetTimer = s.delayedCall(this.endOperation.bind(this, !0))),
this.on(
'change',
function () {
this.curOp ||
(this.startOperation(), (this.curOp.selectionBefore = this.$lastSel)),
(this.curOp.docChanged = !0)
}.bind(this),
!0
),
this.on(
'changeSelection',
function () {
this.curOp ||
(this.startOperation(), (this.curOp.selectionBefore = this.$lastSel)),
(this.curOp.selectionChanged = !0)
}.bind(this),
!0
)
}),
(this.curOp = null),
(this.prevOp = {}),
(this.startOperation = function (e) {
if (this.curOp) {
if (!e || this.curOp.command) return
this.prevOp = this.curOp
}
e || ((this.previousCommand = null), (e = {})),
this.$opResetTimer.schedule(),
(this.curOp = this.session.curOp =
{ command: e.command || {}, args: e.args, scrollTop: this.renderer.scrollTop }),
(this.curOp.selectionBefore = this.selection.toJSON())
}),
(this.endOperation = function (e) {
if (this.curOp && this.session) {
if ((e && e.returnValue === !1) || !this.session) return (this.curOp = null)
if (e == 1 && this.curOp.command && this.curOp.command.name == 'mouse') return
this._signal('beforeEndOperation')
if (!this.curOp) return
var t = this.curOp.command,
n = t && t.scrollIntoView
if (n) {
switch (n) {
case 'center-animate':
n = 'animate'
case 'center':
this.renderer.scrollCursorIntoView(null, 0.5)
break
case 'animate':
case 'cursor':
this.renderer.scrollCursorIntoView()
break
case 'selectionPart':
var r = this.selection.getRange(),
i = this.renderer.layerConfig
;(r.start.row >= i.lastRow || r.end.row <= i.firstRow) &&
this.renderer.scrollSelectionIntoView(
this.selection.anchor,
this.selection.lead
)
break
default:
}
n == 'animate' && this.renderer.animateScrolling(this.curOp.scrollTop)
}
var s = this.selection.toJSON()
;(this.curOp.selectionAfter = s),
(this.$lastSel = this.selection.toJSON()),
this.session.getUndoManager().addSelection(s),
(this.prevOp = this.curOp),
(this.curOp = null)
}
}),
(this.$mergeableCommands = ['backspace', 'del', 'insertstring']),
(this.$historyTracker = function (e) {
if (!this.$mergeUndoDeltas) return
var t = this.prevOp,
n = this.$mergeableCommands,
r = t.command && e.command.name == t.command.name
if (e.command.name == 'insertstring') {
var i = e.args
this.mergeNextCommand === undefined && (this.mergeNextCommand = !0),
(r = r && this.mergeNextCommand && (!/\s/.test(i) || /\s/.test(t.args))),
(this.mergeNextCommand = !0)
} else r = r && n.indexOf(e.command.name) !== -1
this.$mergeUndoDeltas != 'always' &&
Date.now() - this.sequenceStartTime > 2e3 &&
(r = !1),
r
? (this.session.mergeUndoDeltas = !0)
: n.indexOf(e.command.name) !== -1 && (this.sequenceStartTime = Date.now())
}),
(this.setKeyboardHandler = function (e, t) {
if (e && typeof e == 'string' && e != 'ace') {
this.$keybindingId = e
var n = this
g.loadModule(['keybinding', e], function (r) {
n.$keybindingId == e && n.keyBinding.setKeyboardHandler(r && r.handler), t && t()
})
} else (this.$keybindingId = null), this.keyBinding.setKeyboardHandler(e), t && t()
}),
(this.getKeyboardHandler = function () {
return this.keyBinding.getKeyboardHandler()
}),
(this.setSession = function (e) {
if (this.session == e) return
this.curOp && this.endOperation(), (this.curOp = {})
var t = this.session
if (t) {
this.session.off('change', this.$onDocumentChange),
this.session.off('changeMode', this.$onChangeMode),
this.session.off('tokenizerUpdate', this.$onTokenizerUpdate),
this.session.off('changeTabSize', this.$onChangeTabSize),
this.session.off('changeWrapLimit', this.$onChangeWrapLimit),
this.session.off('changeWrapMode', this.$onChangeWrapMode),
this.session.off('changeFold', this.$onChangeFold),
this.session.off('changeFrontMarker', this.$onChangeFrontMarker),
this.session.off('changeBackMarker', this.$onChangeBackMarker),
this.session.off('changeBreakpoint', this.$onChangeBreakpoint),
this.session.off('changeAnnotation', this.$onChangeAnnotation),
this.session.off('changeOverwrite', this.$onCursorChange),
this.session.off('changeScrollTop', this.$onScrollTopChange),
this.session.off('changeScrollLeft', this.$onScrollLeftChange)
var n = this.session.getSelection()
n.off('changeCursor', this.$onCursorChange),
n.off('changeSelection', this.$onSelectionChange)
}
;(this.session = e),
e
? ((this.$onDocumentChange = this.onDocumentChange.bind(this)),
e.on('change', this.$onDocumentChange),
this.renderer.setSession(e),
(this.$onChangeMode = this.onChangeMode.bind(this)),
e.on('changeMode', this.$onChangeMode),
(this.$onTokenizerUpdate = this.onTokenizerUpdate.bind(this)),
e.on('tokenizerUpdate', this.$onTokenizerUpdate),
(this.$onChangeTabSize = this.renderer.onChangeTabSize.bind(this.renderer)),
e.on('changeTabSize', this.$onChangeTabSize),
(this.$onChangeWrapLimit = this.onChangeWrapLimit.bind(this)),
e.on('changeWrapLimit', this.$onChangeWrapLimit),
(this.$onChangeWrapMode = this.onChangeWrapMode.bind(this)),
e.on('changeWrapMode', this.$onChangeWrapMode),
(this.$onChangeFold = this.onChangeFold.bind(this)),
e.on('changeFold', this.$onChangeFold),
(this.$onChangeFrontMarker = this.onChangeFrontMarker.bind(this)),
this.session.on('changeFrontMarker', this.$onChangeFrontMarker),
(this.$onChangeBackMarker = this.onChangeBackMarker.bind(this)),
this.session.on('changeBackMarker', this.$onChangeBackMarker),
(this.$onChangeBreakpoint = this.onChangeBreakpoint.bind(this)),
this.session.on('changeBreakpoint', this.$onChangeBreakpoint),
(this.$onChangeAnnotation = this.onChangeAnnotation.bind(this)),
this.session.on('changeAnnotation', this.$onChangeAnnotation),
(this.$onCursorChange = this.onCursorChange.bind(this)),
this.session.on('changeOverwrite', this.$onCursorChange),
(this.$onScrollTopChange = this.onScrollTopChange.bind(this)),
this.session.on('changeScrollTop', this.$onScrollTopChange),
(this.$onScrollLeftChange = this.onScrollLeftChange.bind(this)),
this.session.on('changeScrollLeft', this.$onScrollLeftChange),
(this.selection = e.getSelection()),
this.selection.on('changeCursor', this.$onCursorChange),
(this.$onSelectionChange = this.onSelectionChange.bind(this)),
this.selection.on('changeSelection', this.$onSelectionChange),
this.onChangeMode(),
this.onCursorChange(),
this.onScrollTopChange(),
this.onScrollLeftChange(),
this.onSelectionChange(),
this.onChangeFrontMarker(),
this.onChangeBackMarker(),
this.onChangeBreakpoint(),
this.onChangeAnnotation(),
this.session.getUseWrapMode() && this.renderer.adjustWrapLimit(),
this.renderer.updateFull())
: ((this.selection = null), this.renderer.setSession(e)),
this._signal('changeSession', { session: e, oldSession: t }),
(this.curOp = null),
t && t._signal('changeEditor', { oldEditor: this }),
e && e._signal('changeEditor', { editor: this }),
e && e.bgTokenizer && e.bgTokenizer.scheduleStart()
}),
(this.getSession = function () {
return this.session
}),
(this.setValue = function (e, t) {
return (
this.session.doc.setValue(e),
t
? t == 1
? this.navigateFileEnd()
: t == -1 && this.navigateFileStart()
: this.selectAll(),
e
)
}),
(this.getValue = function () {
return this.session.getValue()
}),
(this.getSelection = function () {
return this.selection
}),
(this.resize = function (e) {
this.renderer.onResize(e)
}),
(this.setTheme = function (e, t) {
this.renderer.setTheme(e, t)
}),
(this.getTheme = function () {
return this.renderer.getTheme()
}),
(this.setStyle = function (e) {
this.renderer.setStyle(e)
}),
(this.unsetStyle = function (e) {
this.renderer.unsetStyle(e)
}),
(this.getFontSize = function () {
return this.getOption('fontSize') || i.computedStyle(this.container).fontSize
}),
(this.setFontSize = function (e) {
this.setOption('fontSize', e)
}),
(this.$highlightBrackets = function () {
if (this.$highlightPending) return
var e = this
;(this.$highlightPending = !0),
setTimeout(function () {
e.$highlightPending = !1
var t = e.session
if (!t || !t.bgTokenizer) return
t.$bracketHighlight &&
(t.$bracketHighlight.markerIds.forEach(function (e) {
t.removeMarker(e)
}),
(t.$bracketHighlight = null))
var n = t.getMatchingBracketRanges(e.getCursorPosition())
!n && t.$mode.getMatching && (n = t.$mode.getMatching(e.session))
if (!n) return
var r = 'ace_bracket'
Array.isArray(n) ? n.length == 1 && (r = 'ace_error_bracket') : (n = [n]),
n.length == 2 &&
(p.comparePoints(n[0].end, n[1].start) == 0
? (n = [p.fromPoints(n[0].start, n[1].end)])
: p.comparePoints(n[0].start, n[1].end) == 0 &&
(n = [p.fromPoints(n[1].start, n[0].end)])),
(t.$bracketHighlight = {
ranges: n,
markerIds: n.map(function (e) {
return t.addMarker(e, r, 'text')
}),
})
}, 50)
}),
(this.$highlightTags = function () {
if (this.$highlightTagPending) return
var e = this
;(this.$highlightTagPending = !0),
setTimeout(function () {
e.$highlightTagPending = !1
var t = e.session
if (!t || !t.bgTokenizer) return
var n = e.getCursorPosition(),
r = new y(e.session, n.row, n.column),
i = r.getCurrentToken()
if (!i || !/\b(?:tag-open|tag-name)/.test(i.type)) {
t.removeMarker(t.$tagHighlight), (t.$tagHighlight = null)
return
}
if (i.type.indexOf('tag-open') !== -1) {
i = r.stepForward()
if (!i) return
}
var s = i.value,
o = i.value,
u = 0,
a = r.stepBackward()
if (a.value === '<') {
do
(a = i),
(i = r.stepForward()),
i &&
(i.type.indexOf('tag-name') !== -1
? ((o = i.value),
s === o && (a.value === '<' ? u++ : a.value === '' && u--))
: s === o && i.value === '/>' && u--)
while (i && u >= 0)
} else {
do {
;(i = a), (a = r.stepBackward())
if (i)
if (i.type.indexOf('tag-name') !== -1)
s === i.value && (a.value === '<' ? u++ : a.value === '' && u--)
else if (i.value === '/>') {
var f = 0,
l = a
while (l) {
if (l.type.indexOf('tag-name') !== -1 && l.value === s) {
u--
break
}
if (l.value === '<') break
;(l = r.stepBackward()), f++
}
for (var c = 0; c < f; c++) r.stepForward()
}
} while (a && u <= 0)
r.stepForward()
}
if (!i) {
t.removeMarker(t.$tagHighlight), (t.$tagHighlight = null)
return
}
var h = r.getCurrentTokenRow(),
d = r.getCurrentTokenColumn(),
v = new p(h, d, h, d + i.value.length),
m = t.$backMarkers[t.$tagHighlight]
t.$tagHighlight &&
m != undefined &&
v.compareRange(m.range) !== 0 &&
(t.removeMarker(t.$tagHighlight), (t.$tagHighlight = null)),
t.$tagHighlight || (t.$tagHighlight = t.addMarker(v, 'ace_bracket', 'text'))
}, 50)
}),
(this.focus = function () {
var e = this
setTimeout(function () {
e.isFocused() || e.textInput.focus()
}),
this.textInput.focus()
}),
(this.isFocused = function () {
return this.textInput.isFocused()
}),
(this.blur = function () {
this.textInput.blur()
}),
(this.onFocus = function (e) {
if (this.$isFocused) return
;(this.$isFocused = !0),
this.renderer.showCursor(),
this.renderer.visualizeFocus(),
this._emit('focus', e)
}),
(this.onBlur = function (e) {
if (!this.$isFocused) return
;(this.$isFocused = !1),
this.renderer.hideCursor(),
this.renderer.visualizeBlur(),
this._emit('blur', e)
}),
(this.$cursorChange = function () {
this.renderer.updateCursor(),
this.$highlightBrackets(),
this.$highlightTags(),
this.$updateHighlightActiveLine()
}),
(this.onDocumentChange = function (e) {
var t = this.session.$useWrapMode,
n = e.start.row == e.end.row ? e.end.row : Infinity
this.renderer.updateLines(e.start.row, n, t),
this._signal('change', e),
this.$cursorChange()
}),
(this.onTokenizerUpdate = function (e) {
var t = e.data
this.renderer.updateLines(t.first, t.last)
}),
(this.onScrollTopChange = function () {
this.renderer.scrollToY(this.session.getScrollTop())
}),
(this.onScrollLeftChange = function () {
this.renderer.scrollToX(this.session.getScrollLeft())
}),
(this.onCursorChange = function () {
this.$cursorChange(), this._signal('changeSelection')
}),
(this.$updateHighlightActiveLine = function () {
var e = this.getSession(),
t
if (this.$highlightActiveLine) {
if (this.$selectionStyle != 'line' || !this.selection.isMultiLine())
t = this.getCursorPosition()
this.renderer.theme &&
this.renderer.theme.$selectionColorConflict &&
!this.selection.isEmpty() &&
(t = !1),
this.renderer.$maxLines &&
this.session.getLength() === 1 &&
!(this.renderer.$minLines > 1) &&
(t = !1)
}
if (e.$highlightLineMarker && !t)
e.removeMarker(e.$highlightLineMarker.id), (e.$highlightLineMarker = null)
else if (!e.$highlightLineMarker && t) {
var n = new p(t.row, t.column, t.row, Infinity)
;(n.id = e.addMarker(n, 'ace_active-line', 'screenLine')),
(e.$highlightLineMarker = n)
} else
t &&
((e.$highlightLineMarker.start.row = t.row),
(e.$highlightLineMarker.end.row = t.row),
(e.$highlightLineMarker.start.column = t.column),
e._signal('changeBackMarker'))
}),
(this.onSelectionChange = function (e) {
var t = this.session
t.$selectionMarker && t.removeMarker(t.$selectionMarker), (t.$selectionMarker = null)
if (!this.selection.isEmpty()) {
var n = this.selection.getRange(),
r = this.getSelectionStyle()
t.$selectionMarker = t.addMarker(n, 'ace_selection', r)
} else this.$updateHighlightActiveLine()
var i = this.$highlightSelectedWord && this.$getSelectionHighLightRegexp()
this.session.highlight(i), this._signal('changeSelection')
}),
(this.$getSelectionHighLightRegexp = function () {
var e = this.session,
t = this.getSelectionRange()
if (t.isEmpty() || t.isMultiLine()) return
var n = t.start.column,
r = t.end.column,
i = e.getLine(t.start.row),
s = i.substring(n, r)
if (s.length > 5e3 || !/[\w\d]/.test(s)) return
var o = this.$search.$assembleRegExp({ wholeWord: !0, caseSensitive: !0, needle: s }),
u = i.substring(n - 1, r + 1)
if (!o.test(u)) return
return o
}),
(this.onChangeFrontMarker = function () {
this.renderer.updateFrontMarkers()
}),
(this.onChangeBackMarker = function () {
this.renderer.updateBackMarkers()
}),
(this.onChangeBreakpoint = function () {
this.renderer.updateBreakpoints()
}),
(this.onChangeAnnotation = function () {
this.renderer.setAnnotations(this.session.getAnnotations())
}),
(this.onChangeMode = function (e) {
this.renderer.updateText(), this._emit('changeMode', e)
}),
(this.onChangeWrapLimit = function () {
this.renderer.updateFull()
}),
(this.onChangeWrapMode = function () {
this.renderer.onResize(!0)
}),
(this.onChangeFold = function () {
this.$updateHighlightActiveLine(), this.renderer.updateFull()
}),
(this.getSelectedText = function () {
return this.session.getTextRange(this.getSelectionRange())
}),
(this.getCopyText = function () {
var e = this.getSelectedText(),
t = this.session.doc.getNewLineCharacter(),
n = !1
if (!e && this.$copyWithEmptySelection) {
n = !0
var r = this.selection.getAllRanges()
for (var i = 0; i < r.length; i++) {
var s = r[i]
if (i && r[i - 1].start.row == s.start.row) continue
e += this.session.getLine(s.start.row) + t
}
}
var o = { text: e }
return this._signal('copy', o), (b.lineMode = n ? o.text : ''), o.text
}),
(this.onCopy = function () {
this.commands.exec('copy', this)
}),
(this.onCut = function () {
this.commands.exec('cut', this)
}),
(this.onPaste = function (e, t) {
var n = { text: e, event: t }
this.commands.exec('paste', this, n)
}),
(this.$handlePaste = function (e) {
typeof e == 'string' && (e = { text: e }), this._signal('paste', e)
var t = e.text,
n = t == b.lineMode,
r = this.session
if (!this.inMultiSelectMode || this.inVirtualSelectionMode)
n ? r.insert({ row: this.selection.lead.row, column: 0 }, t) : this.insert(t)
else if (n)
this.selection.rangeList.ranges.forEach(function (e) {
r.insert({ row: e.start.row, column: 0 }, t)
})
else {
var i = t.split(/\r\n|\r|\n/),
s = this.selection.rangeList.ranges,
o = i.length == 2 && (!i[0] || !i[1])
if (i.length != s.length || o) return this.commands.exec('insertstring', this, t)
for (var u = s.length; u--; ) {
var a = s[u]
a.isEmpty() || r.remove(a), r.insert(a.start, i[u])
}
}
}),
(this.execCommand = function (e, t) {
return this.commands.exec(e, this, t)
}),
(this.insert = function (e, t) {
var n = this.session,
r = n.getMode(),
i = this.getCursorPosition()
if (this.getBehavioursEnabled() && !t) {
var s = r.transformAction(n.getState(i.row), 'insertion', this, n, e)
s &&
(e !== s.text &&
(this.inVirtualSelectionMode ||
((this.session.mergeUndoDeltas = !1), (this.mergeNextCommand = !1))),
(e = s.text))
}
e == ' ' && (e = this.session.getTabString())
if (!this.selection.isEmpty()) {
var o = this.getSelectionRange()
;(i = this.session.remove(o)), this.clearSelection()
} else if (this.session.getOverwrite() && e.indexOf('\n') == -1) {
var o = new p.fromPoints(i, i)
;(o.end.column += e.length), this.session.remove(o)
}
if (e == '\n' || e == '\r\n') {
var u = n.getLine(i.row)
if (i.column > u.search(/\S|$/)) {
var a = u.substr(i.column).search(/\S|$/)
n.doc.removeInLine(i.row, i.column, i.column + a)
}
}
this.clearSelection()
var f = i.column,
l = n.getState(i.row),
u = n.getLine(i.row),
c = r.checkOutdent(l, u, e)
n.insert(i, e),
s &&
s.selection &&
(s.selection.length == 2
? this.selection.setSelectionRange(
new p(i.row, f + s.selection[0], i.row, f + s.selection[1])
)
: this.selection.setSelectionRange(
new p(
i.row + s.selection[0],
s.selection[1],
i.row + s.selection[2],
s.selection[3]
)
))
if (this.$enableAutoIndent) {
if (n.getDocument().isNewLine(e)) {
var h = r.getNextLineIndent(l, u.slice(0, i.column), n.getTabString())
n.insert({ row: i.row + 1, column: 0 }, h)
}
c && r.autoOutdent(l, n, i.row)
}
}),
(this.autoIndent = function () {
var e = this.session,
t = e.getMode(),
n,
r
if (this.selection.isEmpty()) (n = 0), (r = e.doc.getLength() - 1)
else {
var i = this.getSelectionRange()
;(n = i.start.row), (r = i.end.row)
}
var s = '',
o = '',
u = '',
a,
f,
l,
c = e.getTabString()
for (var h = n; h <= r; h++)
h > 0 &&
((s = e.getState(h - 1)),
(o = e.getLine(h - 1)),
(u = t.getNextLineIndent(s, o, c))),
(a = e.getLine(h)),
(f = t.$getIndent(a)),
u !== f &&
(f.length > 0 && ((l = new p(h, 0, h, f.length)), e.remove(l)),
u.length > 0 && e.insert({ row: h, column: 0 }, u)),
t.autoOutdent(s, e, h)
}),
(this.onTextInput = function (e, t) {
if (!t) return this.keyBinding.onTextInput(e)
this.startOperation({ command: { name: 'insertstring' } })
var n = this.applyComposition.bind(this, e, t)
this.selection.rangeCount ? this.forEachSelection(n) : n(), this.endOperation()
}),
(this.applyComposition = function (e, t) {
if (t.extendLeft || t.extendRight) {
var n = this.selection.getRange()
;(n.start.column -= t.extendLeft),
(n.end.column += t.extendRight),
n.start.column < 0 &&
(n.start.row--,
(n.start.column += this.session.getLine(n.start.row).length + 1)),
this.selection.setRange(n),
!e && !n.isEmpty() && this.remove()
}
;(e || !this.selection.isEmpty()) && this.insert(e, !0)
if (t.restoreStart || t.restoreEnd) {
var n = this.selection.getRange()
;(n.start.column -= t.restoreStart),
(n.end.column -= t.restoreEnd),
this.selection.setRange(n)
}
}),
(this.onCommandKey = function (e, t, n) {
return this.keyBinding.onCommandKey(e, t, n)
}),
(this.setOverwrite = function (e) {
this.session.setOverwrite(e)
}),
(this.getOverwrite = function () {
return this.session.getOverwrite()
}),
(this.toggleOverwrite = function () {
this.session.toggleOverwrite()
}),
(this.setScrollSpeed = function (e) {
this.setOption('scrollSpeed', e)
}),
(this.getScrollSpeed = function () {
return this.getOption('scrollSpeed')
}),
(this.setDragDelay = function (e) {
this.setOption('dragDelay', e)
}),
(this.getDragDelay = function () {
return this.getOption('dragDelay')
}),
(this.setSelectionStyle = function (e) {
this.setOption('selectionStyle', e)
}),
(this.getSelectionStyle = function () {
return this.getOption('selectionStyle')
}),
(this.setHighlightActiveLine = function (e) {
this.setOption('highlightActiveLine', e)
}),
(this.getHighlightActiveLine = function () {
return this.getOption('highlightActiveLine')
}),
(this.setHighlightGutterLine = function (e) {
this.setOption('highlightGutterLine', e)
}),
(this.getHighlightGutterLine = function () {
return this.getOption('highlightGutterLine')
}),
(this.setHighlightSelectedWord = function (e) {
this.setOption('highlightSelectedWord', e)
}),
(this.getHighlightSelectedWord = function () {
return this.$highlightSelectedWord
}),
(this.setAnimatedScroll = function (e) {
this.renderer.setAnimatedScroll(e)
}),
(this.getAnimatedScroll = function () {
return this.renderer.getAnimatedScroll()
}),
(this.setShowInvisibles = function (e) {
this.renderer.setShowInvisibles(e)
}),
(this.getShowInvisibles = function () {
return this.renderer.getShowInvisibles()
}),
(this.setDisplayIndentGuides = function (e) {
this.renderer.setDisplayIndentGuides(e)
}),
(this.getDisplayIndentGuides = function () {
return this.renderer.getDisplayIndentGuides()
}),
(this.setShowPrintMargin = function (e) {
this.renderer.setShowPrintMargin(e)
}),
(this.getShowPrintMargin = function () {
return this.renderer.getShowPrintMargin()
}),
(this.setPrintMarginColumn = function (e) {
this.renderer.setPrintMarginColumn(e)
}),
(this.getPrintMarginColumn = function () {
return this.renderer.getPrintMarginColumn()
}),
(this.setReadOnly = function (e) {
this.setOption('readOnly', e)
}),
(this.getReadOnly = function () {
return this.getOption('readOnly')
}),
(this.setBehavioursEnabled = function (e) {
this.setOption('behavioursEnabled', e)
}),
(this.getBehavioursEnabled = function () {
return this.getOption('behavioursEnabled')
}),
(this.setWrapBehavioursEnabled = function (e) {
this.setOption('wrapBehavioursEnabled', e)
}),
(this.getWrapBehavioursEnabled = function () {
return this.getOption('wrapBehavioursEnabled')
}),
(this.setShowFoldWidgets = function (e) {
this.setOption('showFoldWidgets', e)
}),
(this.getShowFoldWidgets = function () {
return this.getOption('showFoldWidgets')
}),
(this.setFadeFoldWidgets = function (e) {
this.setOption('fadeFoldWidgets', e)
}),
(this.getFadeFoldWidgets = function () {
return this.getOption('fadeFoldWidgets')
}),
(this.remove = function (e) {
this.selection.isEmpty() &&
(e == 'left' ? this.selection.selectLeft() : this.selection.selectRight())
var t = this.getSelectionRange()
if (this.getBehavioursEnabled()) {
var n = this.session,
r = n.getState(t.start.row),
i = n.getMode().transformAction(r, 'deletion', this, n, t)
if (t.end.column === 0) {
var s = n.getTextRange(t)
if (s[s.length - 1] == '\n') {
var o = n.getLine(t.end.row)
;/^\s+$/.test(o) && (t.end.column = o.length)
}
}
i && (t = i)
}
this.session.remove(t), this.clearSelection()
}),
(this.removeWordRight = function () {
this.selection.isEmpty() && this.selection.selectWordRight(),
this.session.remove(this.getSelectionRange()),
this.clearSelection()
}),
(this.removeWordLeft = function () {
this.selection.isEmpty() && this.selection.selectWordLeft(),
this.session.remove(this.getSelectionRange()),
this.clearSelection()
}),
(this.removeToLineStart = function () {
this.selection.isEmpty() && this.selection.selectLineStart(),
this.selection.isEmpty() && this.selection.selectLeft(),
this.session.remove(this.getSelectionRange()),
this.clearSelection()
}),
(this.removeToLineEnd = function () {
this.selection.isEmpty() && this.selection.selectLineEnd()
var e = this.getSelectionRange()
e.start.column == e.end.column &&
e.start.row == e.end.row &&
((e.end.column = 0), e.end.row++),
this.session.remove(e),
this.clearSelection()
}),
(this.splitLine = function () {
this.selection.isEmpty() ||
(this.session.remove(this.getSelectionRange()), this.clearSelection())
var e = this.getCursorPosition()
this.insert('\n'), this.moveCursorToPosition(e)
}),
(this.transposeLetters = function () {
if (!this.selection.isEmpty()) return
var e = this.getCursorPosition(),
t = e.column
if (t === 0) return
var n = this.session.getLine(e.row),
r,
i
t < n.length
? ((r = n.charAt(t) + n.charAt(t - 1)), (i = new p(e.row, t - 1, e.row, t + 1)))
: ((r = n.charAt(t - 1) + n.charAt(t - 2)), (i = new p(e.row, t - 2, e.row, t))),
this.session.replace(i, r),
this.session.selection.moveToPosition(i.end)
}),
(this.toLowerCase = function () {
var e = this.getSelectionRange()
this.selection.isEmpty() && this.selection.selectWord()
var t = this.getSelectionRange(),
n = this.session.getTextRange(t)
this.session.replace(t, n.toLowerCase()), this.selection.setSelectionRange(e)
}),
(this.toUpperCase = function () {
var e = this.getSelectionRange()
this.selection.isEmpty() && this.selection.selectWord()
var t = this.getSelectionRange(),
n = this.session.getTextRange(t)
this.session.replace(t, n.toUpperCase()), this.selection.setSelectionRange(e)
}),
(this.indent = function () {
var e = this.session,
t = this.getSelectionRange()
if (t.start.row < t.end.row) {
var n = this.$getSelectedRows()
e.indentRows(n.first, n.last, ' ')
return
}
if (t.start.column < t.end.column) {
var r = e.getTextRange(t)
if (!/^\s+$/.test(r)) {
var n = this.$getSelectedRows()
e.indentRows(n.first, n.last, ' ')
return
}
}
var i = e.getLine(t.start.row),
o = t.start,
u = e.getTabSize(),
a = e.documentToScreenColumn(o.row, o.column)
if (this.session.getUseSoftTabs())
var f = u - (a % u),
l = s.stringRepeat(' ', f)
else {
var f = a % u
while (i[t.start.column - 1] == ' ' && f) t.start.column--, f--
this.selection.setSelectionRange(t), (l = ' ')
}
return this.insert(l)
}),
(this.blockIndent = function () {
var e = this.$getSelectedRows()
this.session.indentRows(e.first, e.last, ' ')
}),
(this.blockOutdent = function () {
var e = this.session.getSelection()
this.session.outdentRows(e.getRange())
}),
(this.sortLines = function () {
var e = this.$getSelectedRows(),
t = this.session,
n = []
for (var r = e.first; r <= e.last; r++) n.push(t.getLine(r))
n.sort(function (e, t) {
return e.toLowerCase() < t.toLowerCase()
? -1
: e.toLowerCase() > t.toLowerCase()
? 1
: 0
})
var i = new p(0, 0, 0, 0)
for (var r = e.first; r <= e.last; r++) {
var s = t.getLine(r)
;(i.start.row = r),
(i.end.row = r),
(i.end.column = s.length),
t.replace(i, n[r - e.first])
}
}),
(this.toggleCommentLines = function () {
var e = this.session.getState(this.getCursorPosition().row),
t = this.$getSelectedRows()
this.session.getMode().toggleCommentLines(e, this.session, t.first, t.last)
}),
(this.toggleBlockComment = function () {
var e = this.getCursorPosition(),
t = this.session.getState(e.row),
n = this.getSelectionRange()
this.session.getMode().toggleBlockComment(t, this.session, n, e)
}),
(this.getNumberAt = function (e, t) {
var n = /[\-]?[0-9]+(?:\.[0-9]+)?/g
n.lastIndex = 0
var r = this.session.getLine(e)
while (n.lastIndex < t) {
var i = n.exec(r)
if (i.index <= t && i.index + i[0].length >= t) {
var s = { value: i[0], start: i.index, end: i.index + i[0].length }
return s
}
}
return null
}),
(this.modifyNumber = function (e) {
var t = this.selection.getCursor().row,
n = this.selection.getCursor().column,
r = new p(t, n - 1, t, n),
i = this.session.getTextRange(r)
if (!isNaN(parseFloat(i)) && isFinite(i)) {
var s = this.getNumberAt(t, n)
if (s) {
var o = s.value.indexOf('.') >= 0 ? s.start + s.value.indexOf('.') + 1 : s.end,
u = s.start + s.value.length - o,
a = parseFloat(s.value)
;(a *= Math.pow(10, u)),
o !== s.end && n < o
? (e *= Math.pow(10, s.end - n - 1))
: (e *= Math.pow(10, s.end - n)),
(a += e),
(a /= Math.pow(10, u))
var f = a.toFixed(u),
l = new p(t, s.start, t, s.end)
this.session.replace(l, f),
this.moveCursorTo(t, Math.max(s.start + 1, n + f.length - s.value.length))
}
} else this.toggleWord()
}),
(this.$toggleWordPairs = [
['first', 'last'],
['true', 'false'],
['yes', 'no'],
['width', 'height'],
['top', 'bottom'],
['right', 'left'],
['on', 'off'],
['x', 'y'],
['get', 'set'],
['max', 'min'],
['horizontal', 'vertical'],
['show', 'hide'],
['add', 'remove'],
['up', 'down'],
['before', 'after'],
['even', 'odd'],
['in', 'out'],
['inside', 'outside'],
['next', 'previous'],
['increase', 'decrease'],
['attach', 'detach'],
['&&', '||'],
['==', '!='],
]),
(this.toggleWord = function () {
var e = this.selection.getCursor().row,
t = this.selection.getCursor().column
this.selection.selectWord()
var n = this.getSelectedText(),
r = this.selection.getWordRange().start.column,
i = n.replace(/([a-z]+|[A-Z]+)(?=[A-Z_]|$)/g, '$1 ').split(/\s/),
o = t - r - 1
o < 0 && (o = 0)
var u = 0,
a = 0,
f = this
n.match(/[A-Za-z0-9_]+/) &&
i.forEach(function (t, i) {
;(a = u + t.length),
o >= u &&
o <= a &&
((n = t),
f.selection.clearSelection(),
f.moveCursorTo(e, u + r),
f.selection.selectTo(e, a + r)),
(u = a)
})
var l = this.$toggleWordPairs,
c
for (var h = 0; h < l.length; h++) {
var p = l[h]
for (var d = 0; d <= 1; d++) {
var v = +!d,
m = n.match(new RegExp('^\\s?_?(' + s.escapeRegExp(p[d]) + ')\\s?$', 'i'))
if (m) {
var g = n.match(
new RegExp('([_]|^|\\s)(' + s.escapeRegExp(m[1]) + ')($|\\s)', 'g')
)
g &&
((c = n.replace(new RegExp(s.escapeRegExp(p[d]), 'i'), function (e) {
var t = p[v]
return (
e.toUpperCase() == e
? (t = t.toUpperCase())
: e.charAt(0).toUpperCase() == e.charAt(0) &&
(t = t.substr(0, 0) + p[v].charAt(0).toUpperCase() + t.substr(1)),
t
)
})),
this.insert(c),
(c = ''))
}
}
}
}),
(this.removeLines = function () {
var e = this.$getSelectedRows()
this.session.removeFullLines(e.first, e.last), this.clearSelection()
}),
(this.duplicateSelection = function () {
var e = this.selection,
t = this.session,
n = e.getRange(),
r = e.isBackwards()
if (n.isEmpty()) {
var i = n.start.row
t.duplicateLines(i, i)
} else {
var s = r ? n.start : n.end,
o = t.insert(s, t.getTextRange(n), !1)
;(n.start = s), (n.end = o), e.setSelectionRange(n, r)
}
}),
(this.moveLinesDown = function () {
this.$moveLines(1, !1)
}),
(this.moveLinesUp = function () {
this.$moveLines(-1, !1)
}),
(this.moveText = function (e, t, n) {
return this.session.moveText(e, t, n)
}),
(this.copyLinesUp = function () {
this.$moveLines(-1, !0)
}),
(this.copyLinesDown = function () {
this.$moveLines(1, !0)
}),
(this.$moveLines = function (e, t) {
var n,
r,
i = this.selection
if (!i.inMultiSelectMode || this.inVirtualSelectionMode) {
var s = i.toOrientedRange()
;(n = this.$getSelectedRows(s)),
(r = this.session.$moveLines(n.first, n.last, t ? 0 : e)),
t && e == -1 && (r = 0),
s.moveBy(r, 0),
i.fromOrientedRange(s)
} else {
var o = i.rangeList.ranges
i.rangeList.detach(this.session), (this.inVirtualSelectionMode = !0)
var u = 0,
a = 0,
f = o.length
for (var l = 0; l < f; l++) {
var c = l
o[l].moveBy(u, 0), (n = this.$getSelectedRows(o[l]))
var h = n.first,
p = n.last
while (++l < f) {
a && o[l].moveBy(a, 0)
var d = this.$getSelectedRows(o[l])
if (t && d.first != p) break
if (!t && d.first > p + 1) break
p = d.last
}
l--, (u = this.session.$moveLines(h, p, t ? 0 : e)), t && e == -1 && (c = l + 1)
while (c <= l) o[c].moveBy(u, 0), c++
t || (u = 0), (a += u)
}
i.fromOrientedRange(i.ranges[0]),
i.rangeList.attach(this.session),
(this.inVirtualSelectionMode = !1)
}
}),
(this.$getSelectedRows = function (e) {
return (
(e = (e || this.getSelectionRange()).collapseRows()),
{
first: this.session.getRowFoldStart(e.start.row),
last: this.session.getRowFoldEnd(e.end.row),
}
)
}),
(this.onCompositionStart = function (e) {
this.renderer.showComposition(e)
}),
(this.onCompositionUpdate = function (e) {
this.renderer.setCompositionText(e)
}),
(this.onCompositionEnd = function () {
this.renderer.hideComposition()
}),
(this.getFirstVisibleRow = function () {
return this.renderer.getFirstVisibleRow()
}),
(this.getLastVisibleRow = function () {
return this.renderer.getLastVisibleRow()
}),
(this.isRowVisible = function (e) {
return e >= this.getFirstVisibleRow() && e <= this.getLastVisibleRow()
}),
(this.isRowFullyVisible = function (e) {
return (
e >= this.renderer.getFirstFullyVisibleRow() &&
e <= this.renderer.getLastFullyVisibleRow()
)
}),
(this.$getVisibleRowCount = function () {
return this.renderer.getScrollBottomRow() - this.renderer.getScrollTopRow() + 1
}),
(this.$moveByPage = function (e, t) {
var n = this.renderer,
r = this.renderer.layerConfig,
i = e * Math.floor(r.height / r.lineHeight)
t === !0
? this.selection.$moveSelection(function () {
this.moveCursorBy(i, 0)
})
: t === !1 && (this.selection.moveCursorBy(i, 0), this.selection.clearSelection())
var s = n.scrollTop
n.scrollBy(0, i * r.lineHeight),
t != null && n.scrollCursorIntoView(null, 0.5),
n.animateScrolling(s)
}),
(this.selectPageDown = function () {
this.$moveByPage(1, !0)
}),
(this.selectPageUp = function () {
this.$moveByPage(-1, !0)
}),
(this.gotoPageDown = function () {
this.$moveByPage(1, !1)
}),
(this.gotoPageUp = function () {
this.$moveByPage(-1, !1)
}),
(this.scrollPageDown = function () {
this.$moveByPage(1)
}),
(this.scrollPageUp = function () {
this.$moveByPage(-1)
}),
(this.scrollToRow = function (e) {
this.renderer.scrollToRow(e)
}),
(this.scrollToLine = function (e, t, n, r) {
this.renderer.scrollToLine(e, t, n, r)
}),
(this.centerSelection = function () {
var e = this.getSelectionRange(),
t = {
row: Math.floor(e.start.row + (e.end.row - e.start.row) / 2),
column: Math.floor(e.start.column + (e.end.column - e.start.column) / 2),
}
this.renderer.alignCursor(t, 0.5)
}),
(this.getCursorPosition = function () {
return this.selection.getCursor()
}),
(this.getCursorPositionScreen = function () {
return this.session.documentToScreenPosition(this.getCursorPosition())
}),
(this.getSelectionRange = function () {
return this.selection.getRange()
}),
(this.selectAll = function () {
this.selection.selectAll()
}),
(this.clearSelection = function () {
this.selection.clearSelection()
}),
(this.moveCursorTo = function (e, t) {
this.selection.moveCursorTo(e, t)
}),
(this.moveCursorToPosition = function (e) {
this.selection.moveCursorToPosition(e)
}),
(this.jumpToMatching = function (e, t) {
var n = this.getCursorPosition(),
r = new y(this.session, n.row, n.column),
i = r.getCurrentToken(),
s = i || r.stepForward()
if (!s) return
var o,
u = !1,
a = {},
f = n.column - s.start,
l,
c = { ')': '(', '(': '(', ']': '[', '[': '[', '{': '{', '}': '{' }
do {
if (s.value.match(/[{}()\[\]]/g))
for (; f < s.value.length && !u; f++) {
if (!c[s.value[f]]) continue
;(l = c[s.value[f]] + '.' + s.type.replace('rparen', 'lparen')),
isNaN(a[l]) && (a[l] = 0)
switch (s.value[f]) {
case '(':
case '[':
case '{':
a[l]++
break
case ')':
case ']':
case '}':
a[l]--, a[l] === -1 && ((o = 'bracket'), (u = !0))
}
}
else
s.type.indexOf('tag-name') !== -1 &&
(isNaN(a[s.value]) && (a[s.value] = 0),
i.value === '<' ? a[s.value]++ : i.value === '' && a[s.value]--,
a[s.value] === -1 && ((o = 'tag'), (u = !0)))
u || ((i = s), (s = r.stepForward()), (f = 0))
} while (s && !u)
if (!o) return
var h, d
if (o === 'bracket') {
h = this.session.getBracketRange(n)
if (!h) {
;(h = new p(
r.getCurrentTokenRow(),
r.getCurrentTokenColumn() + f - 1,
r.getCurrentTokenRow(),
r.getCurrentTokenColumn() + f - 1
)),
(d = h.start)
if (t || (d.row === n.row && Math.abs(d.column - n.column) < 2))
h = this.session.getBracketRange(d)
}
} else if (o === 'tag') {
if (!s || s.type.indexOf('tag-name') === -1) return
var v = s.value
h = new p(
r.getCurrentTokenRow(),
r.getCurrentTokenColumn() - 2,
r.getCurrentTokenRow(),
r.getCurrentTokenColumn() - 2
)
if (h.compare(n.row, n.column) === 0) {
u = !1
do
(s = i),
(i = r.stepBackward()),
i &&
(i.type.indexOf('tag-close') !== -1 &&
h.setEnd(r.getCurrentTokenRow(), r.getCurrentTokenColumn() + 1),
s.value === v &&
s.type.indexOf('tag-name') !== -1 &&
(i.value === '<' ? a[v]++ : i.value === '' && a[v]--,
a[v] === 0 && (u = !0)))
while (i && !u)
}
s &&
s.type.indexOf('tag-name') &&
((d = h.start),
d.row == n.row && Math.abs(d.column - n.column) < 2 && (d = h.end))
}
;(d = (h && h.cursor) || d),
d &&
(e
? h && t
? this.selection.setRange(h)
: h && h.isEqual(this.getSelectionRange())
? this.clearSelection()
: this.selection.selectTo(d.row, d.column)
: this.selection.moveTo(d.row, d.column))
}),
(this.gotoLine = function (e, t, n) {
this.selection.clearSelection(),
this.session.unfold({ row: e - 1, column: t || 0 }),
this.exitMultiSelectMode && this.exitMultiSelectMode(),
this.moveCursorTo(e - 1, t || 0),
this.isRowFullyVisible(e - 1) || this.scrollToLine(e - 1, !0, n)
}),
(this.navigateTo = function (e, t) {
this.selection.moveTo(e, t)
}),
(this.navigateUp = function (e) {
if (this.selection.isMultiLine() && !this.selection.isBackwards()) {
var t = this.selection.anchor.getPosition()
return this.moveCursorToPosition(t)
}
this.selection.clearSelection(), this.selection.moveCursorBy(-e || -1, 0)
}),
(this.navigateDown = function (e) {
if (this.selection.isMultiLine() && this.selection.isBackwards()) {
var t = this.selection.anchor.getPosition()
return this.moveCursorToPosition(t)
}
this.selection.clearSelection(), this.selection.moveCursorBy(e || 1, 0)
}),
(this.navigateLeft = function (e) {
if (!this.selection.isEmpty()) {
var t = this.getSelectionRange().start
this.moveCursorToPosition(t)
} else {
e = e || 1
while (e--) this.selection.moveCursorLeft()
}
this.clearSelection()
}),
(this.navigateRight = function (e) {
if (!this.selection.isEmpty()) {
var t = this.getSelectionRange().end
this.moveCursorToPosition(t)
} else {
e = e || 1
while (e--) this.selection.moveCursorRight()
}
this.clearSelection()
}),
(this.navigateLineStart = function () {
this.selection.moveCursorLineStart(), this.clearSelection()
}),
(this.navigateLineEnd = function () {
this.selection.moveCursorLineEnd(), this.clearSelection()
}),
(this.navigateFileEnd = function () {
this.selection.moveCursorFileEnd(), this.clearSelection()
}),
(this.navigateFileStart = function () {
this.selection.moveCursorFileStart(), this.clearSelection()
}),
(this.navigateWordRight = function () {
this.selection.moveCursorWordRight(), this.clearSelection()
}),
(this.navigateWordLeft = function () {
this.selection.moveCursorWordLeft(), this.clearSelection()
}),
(this.replace = function (e, t) {
t && this.$search.set(t)
var n = this.$search.find(this.session),
r = 0
return n
? (this.$tryReplace(n, e) && (r = 1),
this.selection.setSelectionRange(n),
this.renderer.scrollSelectionIntoView(n.start, n.end),
r)
: r
}),
(this.replaceAll = function (e, t) {
t && this.$search.set(t)
var n = this.$search.findAll(this.session),
r = 0
if (!n.length) return r
var i = this.getSelectionRange()
this.selection.moveTo(0, 0)
for (var s = n.length - 1; s >= 0; --s) this.$tryReplace(n[s], e) && r++
return this.selection.setSelectionRange(i), r
}),
(this.$tryReplace = function (e, t) {
var n = this.session.getTextRange(e)
return (
(t = this.$search.replace(n, t)),
t !== null ? ((e.end = this.session.replace(e, t)), e) : null
)
}),
(this.getLastSearchOptions = function () {
return this.$search.getOptions()
}),
(this.find = function (e, t, n) {
t || (t = {}),
typeof e == 'string' || e instanceof RegExp
? (t.needle = e)
: typeof e == 'object' && r.mixin(t, e)
var i = this.selection.getRange()
t.needle == null &&
((e = this.session.getTextRange(i) || this.$search.$options.needle),
e ||
((i = this.session.getWordRange(i.start.row, i.start.column)),
(e = this.session.getTextRange(i))),
this.$search.set({ needle: e })),
this.$search.set(t),
t.start || this.$search.set({ start: i })
var s = this.$search.find(this.session)
if (t.preventScroll) return s
if (s) return this.revealRange(s, n), s
t.backwards ? (i.start = i.end) : (i.end = i.start), this.selection.setRange(i)
}),
(this.findNext = function (e, t) {
this.find({ skipCurrent: !0, backwards: !1 }, e, t)
}),
(this.findPrevious = function (e, t) {
this.find(e, { skipCurrent: !0, backwards: !0 }, t)
}),
(this.revealRange = function (e, t) {
this.session.unfold(e), this.selection.setSelectionRange(e)
var n = this.renderer.scrollTop
this.renderer.scrollSelectionIntoView(e.start, e.end, 0.5),
t !== !1 && this.renderer.animateScrolling(n)
}),
(this.undo = function () {
this.session.getUndoManager().undo(this.session),
this.renderer.scrollCursorIntoView(null, 0.5)
}),
(this.redo = function () {
this.session.getUndoManager().redo(this.session),
this.renderer.scrollCursorIntoView(null, 0.5)
}),
(this.destroy = function () {
this.$toDestroy &&
(this.$toDestroy.forEach(function (e) {
e.destroy()
}),
(this.$toDestroy = null)),
this.$mouseHandler && this.$mouseHandler.destroy(),
this.renderer.destroy(),
this._signal('destroy', this),
this.session && this.session.destroy(),
this._$emitInputEvent && this._$emitInputEvent.cancel(),
this.removeAllListeners()
}),
(this.setAutoScrollEditorIntoView = function (e) {
if (!e) return
var t,
n = this,
r = !1
this.$scrollAnchor || (this.$scrollAnchor = document.createElement('div'))
var i = this.$scrollAnchor
;(i.style.cssText = 'position:absolute'),
this.container.insertBefore(i, this.container.firstChild)
var s = this.on('changeSelection', function () {
r = !0
}),
o = this.renderer.on('beforeRender', function () {
r && (t = n.renderer.container.getBoundingClientRect())
}),
u = this.renderer.on('afterRender', function () {
if (r && t && (n.isFocused() || (n.searchBox && n.searchBox.isFocused()))) {
var e = n.renderer,
s = e.$cursorLayer.$pixelPos,
o = e.layerConfig,
u = s.top - o.offset
s.top >= 0 && u + t.top < 0
? (r = !0)
: s.top < o.height && s.top + t.top + o.lineHeight > window.innerHeight
? (r = !1)
: (r = null),
r != null &&
((i.style.top = u + 'px'),
(i.style.left = s.left + 'px'),
(i.style.height = o.lineHeight + 'px'),
i.scrollIntoView(r)),
(r = t = null)
}
})
this.setAutoScrollEditorIntoView = function (e) {
if (e) return
delete this.setAutoScrollEditorIntoView,
this.off('changeSelection', s),
this.renderer.off('afterRender', u),
this.renderer.off('beforeRender', o)
}
}),
(this.$resetCursorStyle = function () {
var e = this.$cursorStyle || 'ace',
t = this.renderer.$cursorLayer
if (!t) return
t.setSmoothBlinking(/smooth/.test(e)),
(t.isBlinking = !this.$readOnly && e != 'wide'),
i.setCssClass(t.element, 'ace_slim-cursors', /slim/.test(e))
}),
(this.prompt = function (e, t, n) {
var r = this
g.loadModule('./ext/prompt', function (i) {
i.prompt(r, e, t, n)
})
})
}.call(w.prototype),
g.defineOptions(w.prototype, 'editor', {
selectionStyle: {
set: function (e) {
this.onSelectionChange(), this._signal('changeSelectionStyle', { data: e })
},
initialValue: 'line',
},
highlightActiveLine: {
set: function () {
this.$updateHighlightActiveLine()
},
initialValue: !0,
},
highlightSelectedWord: {
set: function (e) {
this.$onSelectionChange()
},
initialValue: !0,
},
readOnly: {
set: function (e) {
this.textInput.setReadOnly(e), this.$resetCursorStyle()
},
initialValue: !1,
},
copyWithEmptySelection: {
set: function (e) {
this.textInput.setCopyWithEmptySelection(e)
},
initialValue: !1,
},
cursorStyle: {
set: function (e) {
this.$resetCursorStyle()
},
values: ['ace', 'slim', 'smooth', 'wide'],
initialValue: 'ace',
},
mergeUndoDeltas: { values: [!1, !0, 'always'], initialValue: !0 },
behavioursEnabled: { initialValue: !0 },
wrapBehavioursEnabled: { initialValue: !0 },
enableAutoIndent: { initialValue: !0 },
autoScrollEditorIntoView: {
set: function (e) {
this.setAutoScrollEditorIntoView(e)
},
},
keyboardHandler: {
set: function (e) {
this.setKeyboardHandler(e)
},
get: function () {
return this.$keybindingId
},
handlesSet: !0,
},
value: {
set: function (e) {
this.session.setValue(e)
},
get: function () {
return this.getValue()
},
handlesSet: !0,
hidden: !0,
},
session: {
set: function (e) {
this.setSession(e)
},
get: function () {
return this.session
},
handlesSet: !0,
hidden: !0,
},
showLineNumbers: {
set: function (e) {
this.renderer.$gutterLayer.setShowLineNumbers(e),
this.renderer.$loop.schedule(this.renderer.CHANGE_GUTTER),
e && this.$relativeLineNumbers ? E.attach(this) : E.detach(this)
},
initialValue: !0,
},
relativeLineNumbers: {
set: function (e) {
this.$showLineNumbers && e ? E.attach(this) : E.detach(this)
},
},
placeholder: {
set: function (e) {
this.$updatePlaceholder ||
((this.$updatePlaceholder = function () {
var e = this.session && (this.renderer.$composition || this.getValue())
if (e && this.renderer.placeholderNode)
this.renderer.off('afterRender', this.$updatePlaceholder),
i.removeCssClass(this.container, 'ace_hasPlaceholder'),
this.renderer.placeholderNode.remove(),
(this.renderer.placeholderNode = null)
else if (!e && !this.renderer.placeholderNode) {
this.renderer.on('afterRender', this.$updatePlaceholder),
i.addCssClass(this.container, 'ace_hasPlaceholder')
var t = i.createElement('div')
;(t.className = 'ace_placeholder'),
(t.textContent = this.$placeholder || ''),
(this.renderer.placeholderNode = t),
this.renderer.content.appendChild(this.renderer.placeholderNode)
} else
!e &&
this.renderer.placeholderNode &&
(this.renderer.placeholderNode.textContent = this.$placeholder || '')
}.bind(this)),
this.on('input', this.$updatePlaceholder)),
this.$updatePlaceholder()
},
},
hScrollBarAlwaysVisible: 'renderer',
vScrollBarAlwaysVisible: 'renderer',
highlightGutterLine: 'renderer',
animatedScroll: 'renderer',
showInvisibles: 'renderer',
showPrintMargin: 'renderer',
printMarginColumn: 'renderer',
printMargin: 'renderer',
fadeFoldWidgets: 'renderer',
showFoldWidgets: 'renderer',
displayIndentGuides: 'renderer',
showGutter: 'renderer',
fontSize: 'renderer',
fontFamily: 'renderer',
maxLines: 'renderer',
minLines: 'renderer',
scrollPastEnd: 'renderer',
fixedWidthGutter: 'renderer',
theme: 'renderer',
hasCssTransforms: 'renderer',
maxPixelHeight: 'renderer',
useTextareaForIME: 'renderer',
scrollSpeed: '$mouseHandler',
dragDelay: '$mouseHandler',
dragEnabled: '$mouseHandler',
focusTimeout: '$mouseHandler',
tooltipFollowsMouse: '$mouseHandler',
firstLineNumber: 'session',
overwrite: 'session',
newLineMode: 'session',
useWorker: 'session',
useSoftTabs: 'session',
navigateWithinSoftTabs: 'session',
tabSize: 'session',
wrap: 'session',
indentedSoftWrap: 'session',
foldStyle: 'session',
mode: 'session',
})
var E = {
getText: function (e, t) {
return (Math.abs(e.selection.lead.row - t) || t + 1 + (t < 9 ? '\u00b7' : '')) + ''
},
getWidth: function (e, t, n) {
return (
Math.max(t.toString().length, (n.lastRow + 1).toString().length, 2) * n.characterWidth
)
},
update: function (e, t) {
t.renderer.$loop.schedule(t.renderer.CHANGE_GUTTER)
},
attach: function (e) {
;(e.renderer.$gutterLayer.$renderer = this),
e.on('changeSelection', this.update),
this.update(null, e)
},
detach: function (e) {
e.renderer.$gutterLayer.$renderer == this && (e.renderer.$gutterLayer.$renderer = null),
e.off('changeSelection', this.update),
this.update(null, e)
},
}
t.Editor = w
}
),
ace.define('ace/undomanager', ['require', 'exports', 'module', 'ace/range'], function (e, t, n) {
'use strict'
function i(e, t) {
for (var n = t; n--; ) {
var r = e[n]
if (r && !r[0].ignore) {
while (n < t - 1) {
var i = d(e[n], e[n + 1])
;(e[n] = i[0]), (e[n + 1] = i[1]), n++
}
return !0
}
}
}
function a(e) {
var t = e.action == 'insert',
n = e.start,
r = e.end,
i = (r.row - n.row) * (t ? 1 : -1),
s = (r.column - n.column) * (t ? 1 : -1)
t && (r = n)
for (var o in this.marks) {
var a = this.marks[o],
f = u(a, n)
if (f < 0) continue
if (f === 0 && t) {
if (a.bias != 1) {
a.bias == -1
continue
}
f = 1
}
var l = t ? f : u(a, r)
if (l > 0) {
;(a.row += i), (a.column += a.row == r.row ? s : 0)
continue
}
!t && l <= 0 && ((a.row = n.row), (a.column = n.column), l === 0 && (a.bias = 1))
}
}
function f(e) {
return { row: e.row, column: e.column }
}
function l(e) {
return { start: f(e.start), end: f(e.end), action: e.action, lines: e.lines.slice() }
}
function c(e) {
e = e || this
if (Array.isArray(e)) return e.map(c).join('\n')
var t = ''
e.action
? ((t = e.action == 'insert' ? '+' : '-'), (t += '[' + e.lines + ']'))
: e.value && (Array.isArray(e.value) ? (t = e.value.map(h).join('\n')) : (t = h(e.value))),
e.start && (t += h(e))
if (e.id || e.rev) t += ' (' + (e.id || e.rev) + ')'
return t
}
function h(e) {
return e.start.row + ':' + e.start.column + '=>' + e.end.row + ':' + e.end.column
}
function p(e, t) {
var n = e.action == 'insert',
r = t.action == 'insert'
if (n && r)
if (o(t.start, e.end) >= 0) m(t, e, -1)
else {
if (!(o(t.start, e.start) <= 0)) return null
m(e, t, 1)
}
else if (n && !r)
if (o(t.start, e.end) >= 0) m(t, e, -1)
else {
if (!(o(t.end, e.start) <= 0)) return null
m(e, t, -1)
}
else if (!n && r)
if (o(t.start, e.start) >= 0) m(t, e, 1)
else {
if (!(o(t.start, e.start) <= 0)) return null
m(e, t, 1)
}
else if (!n && !r)
if (o(t.start, e.start) >= 0) m(t, e, 1)
else {
if (!(o(t.end, e.start) <= 0)) return null
m(e, t, -1)
}
return [t, e]
}
function d(e, t) {
for (var n = e.length; n--; )
for (var r = 0; r < t.length; r++)
if (!p(e[n], t[r])) {
while (n < e.length) {
while (r--) p(t[r], e[n])
;(r = t.length), n++
}
return [e, t]
}
return (
(e.selectionBefore = t.selectionBefore = e.selectionAfter = t.selectionAfter = null), [t, e]
)
}
function v(e, t) {
var n = e.action == 'insert',
r = t.action == 'insert'
if (n && r) o(e.start, t.start) < 0 ? m(t, e, 1) : m(e, t, 1)
else if (n && !r)
o(e.start, t.end) >= 0
? m(e, t, -1)
: o(e.start, t.start) <= 0
? m(t, e, 1)
: (m(e, s.fromPoints(t.start, e.start), -1), m(t, e, 1))
else if (!n && r)
o(t.start, e.end) >= 0
? m(t, e, -1)
: o(t.start, e.start) <= 0
? m(e, t, 1)
: (m(t, s.fromPoints(e.start, t.start), -1), m(e, t, 1))
else if (!n && !r)
if (o(t.start, e.end) >= 0) m(t, e, -1)
else {
if (!(o(t.end, e.start) <= 0)) {
var i, u
return (
o(e.start, t.start) < 0 && ((i = e), (e = y(e, t.start))),
o(e.end, t.end) > 0 && (u = y(e, t.end)),
g(t.end, e.start, e.end, -1),
u && !i && ((e.lines = u.lines), (e.start = u.start), (e.end = u.end), (u = e)),
[t, i, u].filter(Boolean)
)
}
m(e, t, -1)
}
return [t, e]
}
function m(e, t, n) {
g(e.start, t.start, t.end, n), g(e.end, t.start, t.end, n)
}
function g(e, t, n, r) {
e.row == (r == 1 ? t : n).row && (e.column += r * (n.column - t.column)),
(e.row += r * (n.row - t.row))
}
function y(e, t) {
var n = e.lines,
r = e.end
e.end = f(t)
var i = e.end.row - e.start.row,
s = n.splice(i, n.length),
o = i ? t.column : t.column - e.start.column
n.push(s[0].substring(0, o)), (s[0] = s[0].substr(o))
var u = { start: f(t), end: r, lines: s, action: e.action }
return u
}
function b(e, t) {
t = l(t)
for (var n = e.length; n--; ) {
var r = e[n]
for (var i = 0; i < r.length; i++) {
var s = r[i],
o = v(s, t)
;(t = o[0]),
o.length != 2 &&
(o[2] ? (r.splice(i + 1, 1, o[1], o[2]), i++) : o[1] || (r.splice(i, 1), i--))
}
r.length || e.splice(n, 1)
}
return e
}
function w(e, t) {
for (var n = 0; n < t.length; n++) {
var r = t[n]
for (var i = 0; i < r.length; i++) b(e, r[i])
}
}
var r = function () {
;(this.$maxRev = 0), (this.$fromUndo = !1), this.reset()
}
;(function () {
;(this.addSession = function (e) {
this.$session = e
}),
(this.add = function (e, t, n) {
if (this.$fromUndo) return
if (e == this.$lastDelta) return
this.$keepRedoStack || (this.$redoStack.length = 0)
if (t === !1 || !this.lastDeltas)
(this.lastDeltas = []),
this.$undoStack.push(this.lastDeltas),
(e.id = this.$rev = ++this.$maxRev)
if (e.action == 'remove' || e.action == 'insert') this.$lastDelta = e
this.lastDeltas.push(e)
}),
(this.addSelection = function (e, t) {
this.selections.push({ value: e, rev: t || this.$rev })
}),
(this.startNewGroup = function () {
return (this.lastDeltas = null), this.$rev
}),
(this.markIgnored = function (e, t) {
t == null && (t = this.$rev + 1)
var n = this.$undoStack
for (var r = n.length; r--; ) {
var i = n[r][0]
if (i.id <= e) break
i.id < t && (i.ignore = !0)
}
this.lastDeltas = null
}),
(this.getSelection = function (e, t) {
var n = this.selections
for (var r = n.length; r--; ) {
var i = n[r]
if (i.rev < e) return t && (i = n[r + 1]), i
}
}),
(this.getRevision = function () {
return this.$rev
}),
(this.getDeltas = function (e, t) {
t == null && (t = this.$rev + 1)
var n = this.$undoStack,
r = null,
i = 0
for (var s = n.length; s--; ) {
var o = n[s][0]
o.id < t && !r && (r = s + 1)
if (o.id <= e) {
i = s + 1
break
}
}
return n.slice(i, r)
}),
(this.getChangedRanges = function (e, t) {
t == null && (t = this.$rev + 1)
}),
(this.getChangedLines = function (e, t) {
t == null && (t = this.$rev + 1)
}),
(this.undo = function (e, t) {
this.lastDeltas = null
var n = this.$undoStack
if (!i(n, n.length)) return
e || (e = this.$session),
this.$redoStackBaseRev !== this.$rev &&
this.$redoStack.length &&
(this.$redoStack = []),
(this.$fromUndo = !0)
var r = n.pop(),
s = null
return (
r && ((s = e.undoChanges(r, t)), this.$redoStack.push(r), this.$syncRev()),
(this.$fromUndo = !1),
s
)
}),
(this.redo = function (e, t) {
;(this.lastDeltas = null), e || (e = this.$session), (this.$fromUndo = !0)
if (this.$redoStackBaseRev != this.$rev) {
var n = this.getDeltas(this.$redoStackBaseRev, this.$rev + 1)
w(this.$redoStack, n),
(this.$redoStackBaseRev = this.$rev),
this.$redoStack.forEach(function (e) {
e[0].id = ++this.$maxRev
}, this)
}
var r = this.$redoStack.pop(),
i = null
return (
r && ((i = e.redoChanges(r, t)), this.$undoStack.push(r), this.$syncRev()),
(this.$fromUndo = !1),
i
)
}),
(this.$syncRev = function () {
var e = this.$undoStack,
t = e[e.length - 1],
n = (t && t[0].id) || 0
;(this.$redoStackBaseRev = n), (this.$rev = n)
}),
(this.reset = function () {
;(this.lastDeltas = null),
(this.$lastDelta = null),
(this.$undoStack = []),
(this.$redoStack = []),
(this.$rev = 0),
(this.mark = 0),
(this.$redoStackBaseRev = this.$rev),
(this.selections = [])
}),
(this.canUndo = function () {
return this.$undoStack.length > 0
}),
(this.canRedo = function () {
return this.$redoStack.length > 0
}),
(this.bookmark = function (e) {
e == undefined && (e = this.$rev), (this.mark = e)
}),
(this.isAtBookmark = function () {
return this.$rev === this.mark
}),
(this.toJSON = function () {}),
(this.fromJSON = function () {}),
(this.hasUndo = this.canUndo),
(this.hasRedo = this.canRedo),
(this.isClean = this.isAtBookmark),
(this.markClean = this.bookmark),
(this.$prettyPrint = function (e) {
return e ? c(e) : c(this.$undoStack) + '\n---\n' + c(this.$redoStack)
})
}).call(r.prototype)
var s = e('./range').Range,
o = s.comparePoints,
u = s.comparePoints
t.UndoManager = r
}),
ace.define(
'ace/layer/lines',
['require', 'exports', 'module', 'ace/lib/dom'],
function (e, t, n) {
'use strict'
var r = e('../lib/dom'),
i = function (e, t) {
;(this.element = e),
(this.canvasHeight = t || 5e5),
(this.element.style.height = this.canvasHeight * 2 + 'px'),
(this.cells = []),
(this.cellCache = []),
(this.$offsetCoefficient = 0)
}
;(function () {
;(this.moveContainer = function (e) {
r.translate(
this.element,
0,
-((e.firstRowScreen * e.lineHeight) % this.canvasHeight) -
e.offset * this.$offsetCoefficient
)
}),
(this.pageChanged = function (e, t) {
return (
Math.floor((e.firstRowScreen * e.lineHeight) / this.canvasHeight) !==
Math.floor((t.firstRowScreen * t.lineHeight) / this.canvasHeight)
)
}),
(this.computeLineTop = function (e, t, n) {
var r = t.firstRowScreen * t.lineHeight,
i = Math.floor(r / this.canvasHeight),
s = n.documentToScreenRow(e, 0) * t.lineHeight
return s - i * this.canvasHeight
}),
(this.computeLineHeight = function (e, t, n) {
return t.lineHeight * n.getRowLineCount(e)
}),
(this.getLength = function () {
return this.cells.length
}),
(this.get = function (e) {
return this.cells[e]
}),
(this.shift = function () {
this.$cacheCell(this.cells.shift())
}),
(this.pop = function () {
this.$cacheCell(this.cells.pop())
}),
(this.push = function (e) {
if (Array.isArray(e)) {
this.cells.push.apply(this.cells, e)
var t = r.createFragment(this.element)
for (var n = 0; n < e.length; n++) t.appendChild(e[n].element)
this.element.appendChild(t)
} else this.cells.push(e), this.element.appendChild(e.element)
}),
(this.unshift = function (e) {
if (Array.isArray(e)) {
this.cells.unshift.apply(this.cells, e)
var t = r.createFragment(this.element)
for (var n = 0; n < e.length; n++) t.appendChild(e[n].element)
this.element.firstChild
? this.element.insertBefore(t, this.element.firstChild)
: this.element.appendChild(t)
} else
this.cells.unshift(e), this.element.insertAdjacentElement('afterbegin', e.element)
}),
(this.last = function () {
return this.cells.length ? this.cells[this.cells.length - 1] : null
}),
(this.$cacheCell = function (e) {
if (!e) return
e.element.remove(), this.cellCache.push(e)
}),
(this.createCell = function (e, t, n, i) {
var s = this.cellCache.pop()
if (!s) {
var o = r.createElement('div')
i && i(o), this.element.appendChild(o), (s = { element: o, text: '', row: e })
}
return (s.row = e), s
})
}).call(i.prototype),
(t.Lines = i)
}
),
ace.define(
'ace/layer/gutter',
[
'require',
'exports',
'module',
'ace/lib/dom',
'ace/lib/oop',
'ace/lib/lang',
'ace/lib/event_emitter',
'ace/layer/lines',
],
function (e, t, n) {
'use strict'
function f(e) {
var t = document.createTextNode('')
e.appendChild(t)
var n = r.createElement('span')
return e.appendChild(n), e
}
var r = e('../lib/dom'),
i = e('../lib/oop'),
s = e('../lib/lang'),
o = e('../lib/event_emitter').EventEmitter,
u = e('./lines').Lines,
a = function (e) {
;(this.element = r.createElement('div')),
(this.element.className = 'ace_layer ace_gutter-layer'),
e.appendChild(this.element),
this.setShowFoldWidgets(this.$showFoldWidgets),
(this.gutterWidth = 0),
(this.$annotations = []),
(this.$updateAnnotations = this.$updateAnnotations.bind(this)),
(this.$lines = new u(this.element)),
(this.$lines.$offsetCoefficient = 1)
}
;(function () {
i.implement(this, o),
(this.setSession = function (e) {
this.session && this.session.off('change', this.$updateAnnotations),
(this.session = e),
e && e.on('change', this.$updateAnnotations)
}),
(this.addGutterDecoration = function (e, t) {
window.console &&
console.warn &&
console.warn('deprecated use session.addGutterDecoration'),
this.session.addGutterDecoration(e, t)
}),
(this.removeGutterDecoration = function (e, t) {
window.console &&
console.warn &&
console.warn('deprecated use session.removeGutterDecoration'),
this.session.removeGutterDecoration(e, t)
}),
(this.setAnnotations = function (e) {
this.$annotations = []
for (var t = 0; t < e.length; t++) {
var n = e[t],
r = n.row,
i = this.$annotations[r]
i || (i = this.$annotations[r] = { text: [] })
var o = n.text
;(o = o ? s.escapeHTML(o) : n.html || ''), i.text.indexOf(o) === -1 && i.text.push(o)
var u = n.type
u == 'error'
? (i.className = ' ace_error')
: u == 'warning' && i.className != ' ace_error'
? (i.className = ' ace_warning')
: u == 'info' && !i.className && (i.className = ' ace_info')
}
}),
(this.$updateAnnotations = function (e) {
if (!this.$annotations.length) return
var t = e.start.row,
n = e.end.row - t
if (n !== 0)
if (e.action == 'remove') this.$annotations.splice(t, n + 1, null)
else {
var r = new Array(n + 1)
r.unshift(t, 1), this.$annotations.splice.apply(this.$annotations, r)
}
}),
(this.update = function (e) {
this.config = e
var t = this.session,
n = e.firstRow,
r = Math.min(e.lastRow + e.gutterOffset, t.getLength() - 1)
;(this.oldLastRow = r),
(this.config = e),
this.$lines.moveContainer(e),
this.$updateCursorRow()
var i = t.getNextFoldLine(n),
s = i ? i.start.row : Infinity,
o = null,
u = -1,
a = n
for (;;) {
a > s &&
((a = i.end.row + 1),
(i = t.getNextFoldLine(a, i)),
(s = i ? i.start.row : Infinity))
if (a > r) {
while (this.$lines.getLength() > u + 1) this.$lines.pop()
break
}
;(o = this.$lines.get(++u)),
o
? (o.row = a)
: ((o = this.$lines.createCell(a, e, this.session, f)), this.$lines.push(o)),
this.$renderCell(o, e, i, a),
a++
}
this._signal('afterRender'), this.$updateGutterWidth(e)
}),
(this.$updateGutterWidth = function (e) {
var t = this.session,
n = t.gutterRenderer || this.$renderer,
r = t.$firstLineNumber,
i = this.$lines.last() ? this.$lines.last().text : ''
if (this.$fixedWidth || t.$useWrapMode) i = t.getLength() + r - 1
var s = n ? n.getWidth(t, i, e) : i.toString().length * e.characterWidth,
o = this.$padding || this.$computePadding()
;(s += o.left + o.right),
s !== this.gutterWidth &&
!isNaN(s) &&
((this.gutterWidth = s),
(this.element.parentNode.style.width = this.element.style.width =
Math.ceil(this.gutterWidth) + 'px'),
this._signal('changeGutterWidth', s))
}),
(this.$updateCursorRow = function () {
if (!this.$highlightGutterLine) return
var e = this.session.selection.getCursor()
if (this.$cursorRow === e.row) return
this.$cursorRow = e.row
}),
(this.updateLineHighlight = function () {
if (!this.$highlightGutterLine) return
var e = this.session.selection.cursor.row
this.$cursorRow = e
if (this.$cursorCell && this.$cursorCell.row == e) return
this.$cursorCell &&
(this.$cursorCell.element.className = this.$cursorCell.element.className.replace(
'ace_gutter-active-line ',
''
))
var t = this.$lines.cells
this.$cursorCell = null
for (var n = 0; n < t.length; n++) {
var r = t[n]
if (r.row >= this.$cursorRow) {
if (r.row > this.$cursorRow) {
var i = this.session.getFoldLine(this.$cursorRow)
if (!(n > 0 && i && i.start.row == t[n - 1].row)) break
r = t[n - 1]
}
;(r.element.className = 'ace_gutter-active-line ' + r.element.className),
(this.$cursorCell = r)
break
}
}
}),
(this.scrollLines = function (e) {
var t = this.config
;(this.config = e), this.$updateCursorRow()
if (this.$lines.pageChanged(t, e)) return this.update(e)
this.$lines.moveContainer(e)
var n = Math.min(e.lastRow + e.gutterOffset, this.session.getLength() - 1),
r = this.oldLastRow
this.oldLastRow = n
if (!t || r < e.firstRow) return this.update(e)
if (n < t.firstRow) return this.update(e)
if (t.firstRow < e.firstRow)
for (var i = this.session.getFoldedRowCount(t.firstRow, e.firstRow - 1); i > 0; i--)
this.$lines.shift()
if (r > n)
for (var i = this.session.getFoldedRowCount(n + 1, r); i > 0; i--) this.$lines.pop()
e.firstRow < t.firstRow &&
this.$lines.unshift(this.$renderLines(e, e.firstRow, t.firstRow - 1)),
n > r && this.$lines.push(this.$renderLines(e, r + 1, n)),
this.updateLineHighlight(),
this._signal('afterRender'),
this.$updateGutterWidth(e)
}),
(this.$renderLines = function (e, t, n) {
var r = [],
i = t,
s = this.session.getNextFoldLine(i),
o = s ? s.start.row : Infinity
for (;;) {
i > o &&
((i = s.end.row + 1),
(s = this.session.getNextFoldLine(i, s)),
(o = s ? s.start.row : Infinity))
if (i > n) break
var u = this.$lines.createCell(i, e, this.session, f)
this.$renderCell(u, e, s, i), r.push(u), i++
}
return r
}),
(this.$renderCell = function (e, t, n, i) {
var s = e.element,
o = this.session,
u = s.childNodes[0],
a = s.childNodes[1],
f = o.$firstLineNumber,
l = o.$breakpoints,
c = o.$decorations,
h = o.gutterRenderer || this.$renderer,
p = this.$showFoldWidgets && o.foldWidgets,
d = n ? n.start.row : Number.MAX_VALUE,
v = 'ace_gutter-cell '
this.$highlightGutterLine &&
(i == this.$cursorRow ||
(n && i < this.$cursorRow && i >= d && this.$cursorRow <= n.end.row)) &&
((v += 'ace_gutter-active-line '),
this.$cursorCell != e &&
(this.$cursorCell &&
(this.$cursorCell.element.className = this.$cursorCell.element.className.replace(
'ace_gutter-active-line ',
''
)),
(this.$cursorCell = e))),
l[i] && (v += l[i]),
c[i] && (v += c[i]),
this.$annotations[i] && (v += this.$annotations[i].className),
s.className != v && (s.className = v)
if (p) {
var m = p[i]
m == null && (m = p[i] = o.getFoldWidget(i))
}
if (m) {
var v = 'ace_fold-widget ace_' + m
m == 'start' && i == d && i < n.end.row ? (v += ' ace_closed') : (v += ' ace_open'),
a.className != v && (a.className = v)
var g = t.lineHeight + 'px'
r.setStyle(a.style, 'height', g), r.setStyle(a.style, 'display', 'inline-block')
} else a && r.setStyle(a.style, 'display', 'none')
var y = (h ? h.getText(o, i) : i + f).toString()
return (
y !== u.data && (u.data = y),
r.setStyle(e.element.style, 'height', this.$lines.computeLineHeight(i, t, o) + 'px'),
r.setStyle(e.element.style, 'top', this.$lines.computeLineTop(i, t, o) + 'px'),
(e.text = y),
e
)
}),
(this.$fixedWidth = !1),
(this.$highlightGutterLine = !0),
(this.$renderer = ''),
(this.setHighlightGutterLine = function (e) {
this.$highlightGutterLine = e
}),
(this.$showLineNumbers = !0),
(this.$renderer = ''),
(this.setShowLineNumbers = function (e) {
this.$renderer = !e && {
getWidth: function () {
return 0
},
getText: function () {
return ''
},
}
}),
(this.getShowLineNumbers = function () {
return this.$showLineNumbers
}),
(this.$showFoldWidgets = !0),
(this.setShowFoldWidgets = function (e) {
e
? r.addCssClass(this.element, 'ace_folding-enabled')
: r.removeCssClass(this.element, 'ace_folding-enabled'),
(this.$showFoldWidgets = e),
(this.$padding = null)
}),
(this.getShowFoldWidgets = function () {
return this.$showFoldWidgets
}),
(this.$computePadding = function () {
if (!this.element.firstChild) return { left: 0, right: 0 }
var e = r.computedStyle(this.element.firstChild)
return (
(this.$padding = {}),
(this.$padding.left =
(parseInt(e.borderLeftWidth) || 0) + (parseInt(e.paddingLeft) || 0) + 1),
(this.$padding.right =
(parseInt(e.borderRightWidth) || 0) + (parseInt(e.paddingRight) || 0)),
this.$padding
)
}),
(this.getRegion = function (e) {
var t = this.$padding || this.$computePadding(),
n = this.element.getBoundingClientRect()
if (e.x < t.left + n.left) return 'markers'
if (this.$showFoldWidgets && e.x > n.right - t.right) return 'foldWidgets'
})
}).call(a.prototype),
(t.Gutter = a)
}
),
ace.define(
'ace/layer/marker',
['require', 'exports', 'module', 'ace/range', 'ace/lib/dom'],
function (e, t, n) {
'use strict'
var r = e('../range').Range,
i = e('../lib/dom'),
s = function (e) {
;(this.element = i.createElement('div')),
(this.element.className = 'ace_layer ace_marker-layer'),
e.appendChild(this.element)
}
;(function () {
function e(e, t, n, r) {
return (e ? 1 : 0) | (t ? 2 : 0) | (n ? 4 : 0) | (r ? 8 : 0)
}
;(this.$padding = 0),
(this.setPadding = function (e) {
this.$padding = e
}),
(this.setSession = function (e) {
this.session = e
}),
(this.setMarkers = function (e) {
this.markers = e
}),
(this.elt = function (e, t) {
var n = this.i != -1 && this.element.childNodes[this.i]
n
? this.i++
: ((n = document.createElement('div')), this.element.appendChild(n), (this.i = -1)),
(n.style.cssText = t),
(n.className = e)
}),
(this.update = function (e) {
if (!e) return
;(this.config = e), (this.i = 0)
var t
for (var n in this.markers) {
var r = this.markers[n]
if (!r.range) {
r.update(t, this, this.session, e)
continue
}
var i = r.range.clipRows(e.firstRow, e.lastRow)
if (i.isEmpty()) continue
i = i.toScreenRange(this.session)
if (r.renderer) {
var s = this.$getTop(i.start.row, e),
o = this.$padding + i.start.column * e.characterWidth
r.renderer(t, i, o, s, e)
} else
r.type == 'fullLine'
? this.drawFullLineMarker(t, i, r.clazz, e)
: r.type == 'screenLine'
? this.drawScreenLineMarker(t, i, r.clazz, e)
: i.isMultiLine()
? r.type == 'text'
? this.drawTextMarker(t, i, r.clazz, e)
: this.drawMultiLineMarker(t, i, r.clazz, e)
: this.drawSingleLineMarker(t, i, r.clazz + ' ace_start' + ' ace_br15', e)
}
if (this.i != -1)
while (this.i < this.element.childElementCount)
this.element.removeChild(this.element.lastChild)
}),
(this.$getTop = function (e, t) {
return (e - t.firstRowScreen) * t.lineHeight
}),
(this.drawTextMarker = function (t, n, i, s, o) {
var u = this.session,
a = n.start.row,
f = n.end.row,
l = a,
c = 0,
h = 0,
p = u.getScreenLastRowColumn(l),
d = new r(l, n.start.column, l, h)
for (; l <= f; l++)
(d.start.row = d.end.row = l),
(d.start.column = l == a ? n.start.column : u.getRowWrapIndent(l)),
(d.end.column = p),
(c = h),
(h = p),
(p = l + 1 < f ? u.getScreenLastRowColumn(l + 1) : l == f ? 0 : n.end.column),
this.drawSingleLineMarker(
t,
d,
i +
(l == a ? ' ace_start' : '') +
' ace_br' +
e(l == a || (l == a + 1 && n.start.column), c < h, h > p, l == f),
s,
l == f ? 0 : 1,
o
)
}),
(this.drawMultiLineMarker = function (e, t, n, r, i) {
var s = this.$padding,
o = r.lineHeight,
u = this.$getTop(t.start.row, r),
a = s + t.start.column * r.characterWidth
i = i || ''
if (this.session.$bidiHandler.isBidiRow(t.start.row)) {
var f = t.clone()
;(f.end.row = f.start.row),
(f.end.column = this.session.getLine(f.start.row).length),
this.drawBidiSingleLineMarker(e, f, n + ' ace_br1 ace_start', r, null, i)
} else
this.elt(
n + ' ace_br1 ace_start',
'height:' + o + 'px;' + 'right:0;' + 'top:' + u + 'px;left:' + a + 'px;' + (i || '')
)
if (this.session.$bidiHandler.isBidiRow(t.end.row)) {
var f = t.clone()
;(f.start.row = f.end.row),
(f.start.column = 0),
this.drawBidiSingleLineMarker(e, f, n + ' ace_br12', r, null, i)
} else {
u = this.$getTop(t.end.row, r)
var l = t.end.column * r.characterWidth
this.elt(
n + ' ace_br12',
'height:' +
o +
'px;' +
'width:' +
l +
'px;' +
'top:' +
u +
'px;' +
'left:' +
s +
'px;' +
(i || '')
)
}
o = (t.end.row - t.start.row - 1) * r.lineHeight
if (o <= 0) return
u = this.$getTop(t.start.row + 1, r)
var c = (t.start.column ? 1 : 0) | (t.end.column ? 0 : 8)
this.elt(
n + (c ? ' ace_br' + c : ''),
'height:' +
o +
'px;' +
'right:0;' +
'top:' +
u +
'px;' +
'left:' +
s +
'px;' +
(i || '')
)
}),
(this.drawSingleLineMarker = function (e, t, n, r, i, s) {
if (this.session.$bidiHandler.isBidiRow(t.start.row))
return this.drawBidiSingleLineMarker(e, t, n, r, i, s)
var o = r.lineHeight,
u = (t.end.column + (i || 0) - t.start.column) * r.characterWidth,
a = this.$getTop(t.start.row, r),
f = this.$padding + t.start.column * r.characterWidth
this.elt(
n,
'height:' +
o +
'px;' +
'width:' +
u +
'px;' +
'top:' +
a +
'px;' +
'left:' +
f +
'px;' +
(s || '')
)
}),
(this.drawBidiSingleLineMarker = function (e, t, n, r, i, s) {
var o = r.lineHeight,
u = this.$getTop(t.start.row, r),
a = this.$padding,
f = this.session.$bidiHandler.getSelections(t.start.column, t.end.column)
f.forEach(function (e) {
this.elt(
n,
'height:' +
o +
'px;' +
'width:' +
e.width +
(i || 0) +
'px;' +
'top:' +
u +
'px;' +
'left:' +
(a + e.left) +
'px;' +
(s || '')
)
}, this)
}),
(this.drawFullLineMarker = function (e, t, n, r, i) {
var s = this.$getTop(t.start.row, r),
o = r.lineHeight
t.start.row != t.end.row && (o += this.$getTop(t.end.row, r) - s),
this.elt(
n,
'height:' + o + 'px;' + 'top:' + s + 'px;' + 'left:0;right:0;' + (i || '')
)
}),
(this.drawScreenLineMarker = function (e, t, n, r, i) {
var s = this.$getTop(t.start.row, r),
o = r.lineHeight
this.elt(n, 'height:' + o + 'px;' + 'top:' + s + 'px;' + 'left:0;right:0;' + (i || ''))
})
}).call(s.prototype),
(t.Marker = s)
}
),
ace.define(
'ace/layer/text',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/lib/dom',
'ace/lib/lang',
'ace/layer/lines',
'ace/lib/event_emitter',
],
function (e, t, n) {
'use strict'
var r = e('../lib/oop'),
i = e('../lib/dom'),
s = e('../lib/lang'),
o = e('./lines').Lines,
u = e('../lib/event_emitter').EventEmitter,
a = function (e) {
;(this.dom = i),
(this.element = this.dom.createElement('div')),
(this.element.className = 'ace_layer ace_text-layer'),
e.appendChild(this.element),
(this.$updateEolChar = this.$updateEolChar.bind(this)),
(this.$lines = new o(this.element))
}
;(function () {
r.implement(this, u),
(this.EOF_CHAR = '\u00b6'),
(this.EOL_CHAR_LF = '\u00ac'),
(this.EOL_CHAR_CRLF = '\u00a4'),
(this.EOL_CHAR = this.EOL_CHAR_LF),
(this.TAB_CHAR = '\u2014'),
(this.SPACE_CHAR = '\u00b7'),
(this.$padding = 0),
(this.MAX_LINE_LENGTH = 1e4),
(this.$updateEolChar = function () {
var e = this.session.doc,
t = e.getNewLineCharacter() == '\n' && e.getNewLineMode() != 'windows',
n = t ? this.EOL_CHAR_LF : this.EOL_CHAR_CRLF
if (this.EOL_CHAR != n) return (this.EOL_CHAR = n), !0
}),
(this.setPadding = function (e) {
;(this.$padding = e), (this.element.style.margin = '0 ' + e + 'px')
}),
(this.getLineHeight = function () {
return this.$fontMetrics.$characterSize.height || 0
}),
(this.getCharacterWidth = function () {
return this.$fontMetrics.$characterSize.width || 0
}),
(this.$setFontMetrics = function (e) {
;(this.$fontMetrics = e),
this.$fontMetrics.on(
'changeCharacterSize',
function (e) {
this._signal('changeCharacterSize', e)
}.bind(this)
),
this.$pollSizeChanges()
}),
(this.checkForSizeChanges = function () {
this.$fontMetrics.checkForSizeChanges()
}),
(this.$pollSizeChanges = function () {
return (this.$pollSizeChangesTimer = this.$fontMetrics.$pollSizeChanges())
}),
(this.setSession = function (e) {
;(this.session = e), e && this.$computeTabString()
}),
(this.showInvisibles = !1),
(this.showSpaces = !1),
(this.showTabs = !1),
(this.showEOL = !1),
(this.setShowInvisibles = function (e) {
return this.showInvisibles == e
? !1
: ((this.showInvisibles = e),
typeof e == 'string'
? ((this.showSpaces = /tab/i.test(e)),
(this.showTabs = /space/i.test(e)),
(this.showEOL = /eol/i.test(e)))
: (this.showSpaces = this.showTabs = this.showEOL = e),
this.$computeTabString(),
!0)
}),
(this.displayIndentGuides = !0),
(this.setDisplayIndentGuides = function (e) {
return this.displayIndentGuides == e
? !1
: ((this.displayIndentGuides = e), this.$computeTabString(), !0)
}),
(this.$tabStrings = []),
(this.onChangeTabSize = this.$computeTabString =
function () {
var e = this.session.getTabSize()
this.tabSize = e
var t = (this.$tabStrings = [0])
for (var n = 1; n < e + 1; n++)
if (this.showTabs) {
var r = this.dom.createElement('span')
;(r.className = 'ace_invisible ace_invisible_tab'),
(r.textContent = s.stringRepeat(this.TAB_CHAR, n)),
t.push(r)
} else t.push(this.dom.createTextNode(s.stringRepeat(' ', n), this.element))
if (this.displayIndentGuides) {
this.$indentGuideRe = /\s\S| \t|\t |\s$/
var i = 'ace_indent-guide',
o = this.showSpaces ? ' ace_invisible ace_invisible_space' : '',
u = this.showSpaces
? s.stringRepeat(this.SPACE_CHAR, this.tabSize)
: s.stringRepeat(' ', this.tabSize),
a = this.showTabs ? ' ace_invisible ace_invisible_tab' : '',
f = this.showTabs ? s.stringRepeat(this.TAB_CHAR, this.tabSize) : u,
r = this.dom.createElement('span')
;(r.className = i + o), (r.textContent = u), (this.$tabStrings[' '] = r)
var r = this.dom.createElement('span')
;(r.className = i + a), (r.textContent = f), (this.$tabStrings[' '] = r)
}
}),
(this.updateLines = function (e, t, n) {
if (this.config.lastRow != e.lastRow || this.config.firstRow != e.firstRow)
return this.update(e)
this.config = e
var r = Math.max(t, e.firstRow),
i = Math.min(n, e.lastRow),
s = this.element.childNodes,
o = 0
for (var u = e.firstRow; u < r; u++) {
var a = this.session.getFoldLine(u)
if (a) {
if (a.containsRow(r)) {
r = a.start.row
break
}
u = a.end.row
}
o++
}
var f = !1,
u = r,
a = this.session.getNextFoldLine(u),
l = a ? a.start.row : Infinity
for (;;) {
u > l &&
((u = a.end.row + 1),
(a = this.session.getNextFoldLine(u, a)),
(l = a ? a.start.row : Infinity))
if (u > i) break
var c = s[o++]
if (c) {
this.dom.removeChildren(c),
this.$renderLine(c, u, u == l ? a : !1),
f && (c.style.top = this.$lines.computeLineTop(u, e, this.session) + 'px')
var h = e.lineHeight * this.session.getRowLength(u) + 'px'
c.style.height != h && ((f = !0), (c.style.height = h))
}
u++
}
if (f)
while (o < this.$lines.cells.length) {
var p = this.$lines.cells[o++]
p.element.style.top = this.$lines.computeLineTop(p.row, e, this.session) + 'px'
}
}),
(this.scrollLines = function (e) {
var t = this.config
this.config = e
if (this.$lines.pageChanged(t, e)) return this.update(e)
this.$lines.moveContainer(e)
var n = e.lastRow,
r = t ? t.lastRow : -1
if (!t || r < e.firstRow) return this.update(e)
if (n < t.firstRow) return this.update(e)
if (!t || t.lastRow < e.firstRow) return this.update(e)
if (e.lastRow < t.firstRow) return this.update(e)
if (t.firstRow < e.firstRow)
for (var i = this.session.getFoldedRowCount(t.firstRow, e.firstRow - 1); i > 0; i--)
this.$lines.shift()
if (t.lastRow > e.lastRow)
for (var i = this.session.getFoldedRowCount(e.lastRow + 1, t.lastRow); i > 0; i--)
this.$lines.pop()
e.firstRow < t.firstRow &&
this.$lines.unshift(this.$renderLinesFragment(e, e.firstRow, t.firstRow - 1)),
e.lastRow > t.lastRow &&
this.$lines.push(this.$renderLinesFragment(e, t.lastRow + 1, e.lastRow))
}),
(this.$renderLinesFragment = function (e, t, n) {
var r = [],
s = t,
o = this.session.getNextFoldLine(s),
u = o ? o.start.row : Infinity
for (;;) {
s > u &&
((s = o.end.row + 1),
(o = this.session.getNextFoldLine(s, o)),
(u = o ? o.start.row : Infinity))
if (s > n) break
var a = this.$lines.createCell(s, e, this.session),
f = a.element
this.dom.removeChildren(f),
i.setStyle(
f.style,
'height',
this.$lines.computeLineHeight(s, e, this.session) + 'px'
),
i.setStyle(f.style, 'top', this.$lines.computeLineTop(s, e, this.session) + 'px'),
this.$renderLine(f, s, s == u ? o : !1),
this.$useLineGroups()
? (f.className = 'ace_line_group')
: (f.className = 'ace_line'),
r.push(a),
s++
}
return r
}),
(this.update = function (e) {
this.$lines.moveContainer(e), (this.config = e)
var t = e.firstRow,
n = e.lastRow,
r = this.$lines
while (r.getLength()) r.pop()
r.push(this.$renderLinesFragment(e, t, n))
}),
(this.$textToken = { text: !0, rparen: !0, lparen: !0 }),
(this.$renderToken = function (e, t, n, r) {
var i = this,
o =
/(\t)|( +)|([\x00-\x1f\x80-\xa0\xad\u1680\u180E\u2000-\u200f\u2028\u2029\u202F\u205F\uFEFF\uFFF9-\uFFFC]+)|(\u3000)|([\u1100-\u115F\u11A3-\u11A7\u11FA-\u11FF\u2329-\u232A\u2E80-\u2E99\u2E9B-\u2EF3\u2F00-\u2FD5\u2FF0-\u2FFB\u3001-\u303E\u3041-\u3096\u3099-\u30FF\u3105-\u312D\u3131-\u318E\u3190-\u31BA\u31C0-\u31E3\u31F0-\u321E\u3220-\u3247\u3250-\u32FE\u3300-\u4DBF\u4E00-\uA48C\uA490-\uA4C6\uA960-\uA97C\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFAFF\uFE10-\uFE19\uFE30-\uFE52\uFE54-\uFE66\uFE68-\uFE6B\uFF01-\uFF60\uFFE0-\uFFE6]|[\uD800-\uDBFF][\uDC00-\uDFFF])/g,
u = this.dom.createFragment(this.element),
a,
f = 0
while ((a = o.exec(r))) {
var l = a[1],
c = a[2],
h = a[3],
p = a[4],
d = a[5]
if (!i.showSpaces && c) continue
var v = f != a.index ? r.slice(f, a.index) : ''
;(f = a.index + a[0].length),
v && u.appendChild(this.dom.createTextNode(v, this.element))
if (l) {
var m = i.session.getScreenTabSize(t + a.index)
u.appendChild(i.$tabStrings[m].cloneNode(!0)), (t += m - 1)
} else if (c)
if (i.showSpaces) {
var g = this.dom.createElement('span')
;(g.className = 'ace_invisible ace_invisible_space'),
(g.textContent = s.stringRepeat(i.SPACE_CHAR, c.length)),
u.appendChild(g)
} else u.appendChild(this.com.createTextNode(c, this.element))
else if (h) {
var g = this.dom.createElement('span')
;(g.className = 'ace_invisible ace_invisible_space ace_invalid'),
(g.textContent = s.stringRepeat(i.SPACE_CHAR, h.length)),
u.appendChild(g)
} else if (p) {
t += 1
var g = this.dom.createElement('span')
;(g.style.width = i.config.characterWidth * 2 + 'px'),
(g.className = i.showSpaces
? 'ace_cjk ace_invisible ace_invisible_space'
: 'ace_cjk'),
(g.textContent = i.showSpaces ? i.SPACE_CHAR : p),
u.appendChild(g)
} else if (d) {
t += 1
var g = this.dom.createElement('span')
;(g.style.width = i.config.characterWidth * 2 + 'px'),
(g.className = 'ace_cjk'),
(g.textContent = d),
u.appendChild(g)
}
}
u.appendChild(this.dom.createTextNode(f ? r.slice(f) : r, this.element))
if (!this.$textToken[n.type]) {
var y = 'ace_' + n.type.replace(/\./g, ' ace_'),
g = this.dom.createElement('span')
n.type == 'fold' &&
(g.style.width = n.value.length * this.config.characterWidth + 'px'),
(g.className = y),
g.appendChild(u),
e.appendChild(g)
} else e.appendChild(u)
return t + r.length
}),
(this.renderIndentGuide = function (e, t, n) {
var r = t.search(this.$indentGuideRe)
if (r <= 0 || r >= n) return t
if (t[0] == ' ') {
r -= r % this.tabSize
var i = r / this.tabSize
for (var s = 0; s < i; s++) e.appendChild(this.$tabStrings[' '].cloneNode(!0))
return t.substr(r)
}
if (t[0] == ' ') {
for (var s = 0; s < r; s++) e.appendChild(this.$tabStrings[' '].cloneNode(!0))
return t.substr(r)
}
return t
}),
(this.$createLineElement = function (e) {
var t = this.dom.createElement('div')
return (t.className = 'ace_line'), (t.style.height = this.config.lineHeight + 'px'), t
}),
(this.$renderWrappedLine = function (e, t, n) {
var r = 0,
i = 0,
o = n[0],
u = 0,
a = this.$createLineElement()
e.appendChild(a)
for (var f = 0; f < t.length; f++) {
var l = t[f],
c = l.value
if (f == 0 && this.displayIndentGuides) {
;(r = c.length), (c = this.renderIndentGuide(a, c, o))
if (!c) continue
r -= c.length
}
if (r + c.length < o) (u = this.$renderToken(a, u, l, c)), (r += c.length)
else {
while (r + c.length >= o)
(u = this.$renderToken(a, u, l, c.substring(0, o - r))),
(c = c.substring(o - r)),
(r = o),
(a = this.$createLineElement()),
e.appendChild(a),
a.appendChild(
this.dom.createTextNode(s.stringRepeat('\u00a0', n.indent), this.element)
),
i++,
(u = 0),
(o = n[i] || Number.MAX_VALUE)
c.length != 0 && ((r += c.length), (u = this.$renderToken(a, u, l, c)))
}
}
n[n.length - 1] > this.MAX_LINE_LENGTH &&
this.$renderOverflowMessage(a, u, null, '', !0)
}),
(this.$renderSimpleLine = function (e, t) {
var n = 0,
r = t[0],
i = r.value
this.displayIndentGuides && (i = this.renderIndentGuide(e, i)),
i && (n = this.$renderToken(e, n, r, i))
for (var s = 1; s < t.length; s++) {
;(r = t[s]), (i = r.value)
if (n + i.length > this.MAX_LINE_LENGTH)
return this.$renderOverflowMessage(e, n, r, i)
n = this.$renderToken(e, n, r, i)
}
}),
(this.$renderOverflowMessage = function (e, t, n, r, i) {
n && this.$renderToken(e, t, n, r.slice(0, this.MAX_LINE_LENGTH - t))
var s = this.dom.createElement('span')
;(s.className = 'ace_inline_button ace_keyword ace_toggle_wrap'),
(s.textContent = i ? '' : ''),
e.appendChild(s)
}),
(this.$renderLine = function (e, t, n) {
!n && n != 0 && (n = this.session.getFoldLine(t))
if (n) var r = this.$getFoldLineTokens(t, n)
else var r = this.session.getTokens(t)
var i = e
if (r.length) {
var s = this.session.getRowSplitData(t)
if (s && s.length) {
this.$renderWrappedLine(e, r, s)
var i = e.lastChild
} else {
var i = e
this.$useLineGroups() && ((i = this.$createLineElement()), e.appendChild(i)),
this.$renderSimpleLine(i, r)
}
} else this.$useLineGroups() && ((i = this.$createLineElement()), e.appendChild(i))
if (this.showEOL && i) {
n && (t = n.end.row)
var o = this.dom.createElement('span')
;(o.className = 'ace_invisible ace_invisible_eol'),
(o.textContent = t == this.session.getLength() - 1 ? this.EOF_CHAR : this.EOL_CHAR),
i.appendChild(o)
}
}),
(this.$getFoldLineTokens = function (e, t) {
function i(e, t, n) {
var i = 0,
s = 0
while (s + e[i].value.length < t) {
;(s += e[i].value.length), i++
if (i == e.length) return
}
if (s != t) {
var o = e[i].value.substring(t - s)
o.length > n - t && (o = o.substring(0, n - t)),
r.push({ type: e[i].type, value: o }),
(s = t + o.length),
(i += 1)
}
while (s < n && i < e.length) {
var o = e[i].value
o.length + s > n
? r.push({ type: e[i].type, value: o.substring(0, n - s) })
: r.push(e[i]),
(s += o.length),
(i += 1)
}
}
var n = this.session,
r = [],
s = n.getTokens(e)
return (
t.walk(
function (e, t, o, u, a) {
e != null
? r.push({ type: 'fold', value: e })
: (a && (s = n.getTokens(t)), s.length && i(s, u, o))
},
t.end.row,
this.session.getLine(t.end.row).length
),
r
)
}),
(this.$useLineGroups = function () {
return this.session.getUseWrapMode()
}),
(this.destroy = function () {})
}).call(a.prototype),
(t.Text = a)
}
),
ace.define(
'ace/layer/cursor',
['require', 'exports', 'module', 'ace/lib/dom'],
function (e, t, n) {
'use strict'
var r = e('../lib/dom'),
i = function (e) {
;(this.element = r.createElement('div')),
(this.element.className = 'ace_layer ace_cursor-layer'),
e.appendChild(this.element),
(this.isVisible = !1),
(this.isBlinking = !0),
(this.blinkInterval = 1e3),
(this.smoothBlinking = !1),
(this.cursors = []),
(this.cursor = this.addCursor()),
r.addCssClass(this.element, 'ace_hidden-cursors'),
(this.$updateCursors = this.$updateOpacity.bind(this))
}
;(function () {
;(this.$updateOpacity = function (e) {
var t = this.cursors
for (var n = t.length; n--; ) r.setStyle(t[n].style, 'opacity', e ? '' : '0')
}),
(this.$startCssAnimation = function () {
var e = this.cursors
for (var t = e.length; t--; ) e[t].style.animationDuration = this.blinkInterval + 'ms'
setTimeout(
function () {
r.addCssClass(this.element, 'ace_animate-blinking')
}.bind(this)
)
}),
(this.$stopCssAnimation = function () {
r.removeCssClass(this.element, 'ace_animate-blinking')
}),
(this.$padding = 0),
(this.setPadding = function (e) {
this.$padding = e
}),
(this.setSession = function (e) {
this.session = e
}),
(this.setBlinking = function (e) {
e != this.isBlinking && ((this.isBlinking = e), this.restartTimer())
}),
(this.setBlinkInterval = function (e) {
e != this.blinkInterval && ((this.blinkInterval = e), this.restartTimer())
}),
(this.setSmoothBlinking = function (e) {
e != this.smoothBlinking &&
((this.smoothBlinking = e),
r.setCssClass(this.element, 'ace_smooth-blinking', e),
this.$updateCursors(!0),
this.restartTimer())
}),
(this.addCursor = function () {
var e = r.createElement('div')
return (
(e.className = 'ace_cursor'), this.element.appendChild(e), this.cursors.push(e), e
)
}),
(this.removeCursor = function () {
if (this.cursors.length > 1) {
var e = this.cursors.pop()
return e.parentNode.removeChild(e), e
}
}),
(this.hideCursor = function () {
;(this.isVisible = !1),
r.addCssClass(this.element, 'ace_hidden-cursors'),
this.restartTimer()
}),
(this.showCursor = function () {
;(this.isVisible = !0),
r.removeCssClass(this.element, 'ace_hidden-cursors'),
this.restartTimer()
}),
(this.restartTimer = function () {
var e = this.$updateCursors
clearInterval(this.intervalId),
clearTimeout(this.timeoutId),
this.$stopCssAnimation(),
this.smoothBlinking && r.removeCssClass(this.element, 'ace_smooth-blinking'),
e(!0)
if (!this.isBlinking || !this.blinkInterval || !this.isVisible) {
this.$stopCssAnimation()
return
}
this.smoothBlinking &&
setTimeout(
function () {
r.addCssClass(this.element, 'ace_smooth-blinking')
}.bind(this)
)
if (r.HAS_CSS_ANIMATION) this.$startCssAnimation()
else {
var t = function () {
this.timeoutId = setTimeout(function () {
e(!1)
}, 0.6 * this.blinkInterval)
}.bind(this)
;(this.intervalId = setInterval(function () {
e(!0), t()
}, this.blinkInterval)),
t()
}
}),
(this.getPixelPosition = function (e, t) {
if (!this.config || !this.session) return { left: 0, top: 0 }
e || (e = this.session.selection.getCursor())
var n = this.session.documentToScreenPosition(e),
r =
this.$padding +
(this.session.$bidiHandler.isBidiRow(n.row, e.row)
? this.session.$bidiHandler.getPosLeft(n.column)
: n.column * this.config.characterWidth),
i = (n.row - (t ? this.config.firstRowScreen : 0)) * this.config.lineHeight
return { left: r, top: i }
}),
(this.isCursorInView = function (e, t) {
return e.top >= 0 && e.top < t.maxHeight
}),
(this.update = function (e) {
this.config = e
var t = this.session.$selectionMarkers,
n = 0,
i = 0
if (t === undefined || t.length === 0) t = [{ cursor: null }]
for (var n = 0, s = t.length; n < s; n++) {
var o = this.getPixelPosition(t[n].cursor, !0)
if ((o.top > e.height + e.offset || o.top < 0) && n > 1) continue
var u = this.cursors[i++] || this.addCursor(),
a = u.style
this.drawCursor
? this.drawCursor(u, o, e, t[n], this.session)
: this.isCursorInView(o, e)
? (r.setStyle(a, 'display', 'block'),
r.translate(u, o.left, o.top),
r.setStyle(a, 'width', Math.round(e.characterWidth) + 'px'),
r.setStyle(a, 'height', e.lineHeight + 'px'))
: r.setStyle(a, 'display', 'none')
}
while (this.cursors.length > i) this.removeCursor()
var f = this.session.getOverwrite()
this.$setOverwrite(f), (this.$pixelPos = o), this.restartTimer()
}),
(this.drawCursor = null),
(this.$setOverwrite = function (e) {
e != this.overwrite &&
((this.overwrite = e),
e
? r.addCssClass(this.element, 'ace_overwrite-cursors')
: r.removeCssClass(this.element, 'ace_overwrite-cursors'))
}),
(this.destroy = function () {
clearInterval(this.intervalId), clearTimeout(this.timeoutId)
})
}).call(i.prototype),
(t.Cursor = i)
}
),
ace.define(
'ace/scrollbar',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/lib/dom',
'ace/lib/event',
'ace/lib/event_emitter',
],
function (e, t, n) {
'use strict'
var r = e('./lib/oop'),
i = e('./lib/dom'),
s = e('./lib/event'),
o = e('./lib/event_emitter').EventEmitter,
u = 32768,
a = function (e) {
;(this.element = i.createElement('div')),
(this.element.className = 'ace_scrollbar ace_scrollbar' + this.classSuffix),
(this.inner = i.createElement('div')),
(this.inner.className = 'ace_scrollbar-inner'),
(this.inner.textContent = '\u00a0'),
this.element.appendChild(this.inner),
e.appendChild(this.element),
this.setVisible(!1),
(this.skipEvent = !1),
s.addListener(this.element, 'scroll', this.onScroll.bind(this)),
s.addListener(this.element, 'mousedown', s.preventDefault)
}
;(function () {
r.implement(this, o),
(this.setVisible = function (e) {
;(this.element.style.display = e ? '' : 'none'), (this.isVisible = e), (this.coeff = 1)
})
}).call(a.prototype)
var f = function (e, t) {
a.call(this, e),
(this.scrollTop = 0),
(this.scrollHeight = 0),
(t.$scrollbarWidth = this.width = i.scrollbarWidth(e.ownerDocument)),
(this.inner.style.width = this.element.style.width = (this.width || 15) + 5 + 'px'),
(this.$minWidth = 0)
}
r.inherits(f, a),
function () {
;(this.classSuffix = '-v'),
(this.onScroll = function () {
if (!this.skipEvent) {
this.scrollTop = this.element.scrollTop
if (this.coeff != 1) {
var e = this.element.clientHeight / this.scrollHeight
this.scrollTop = (this.scrollTop * (1 - e)) / (this.coeff - e)
}
this._emit('scroll', { data: this.scrollTop })
}
this.skipEvent = !1
}),
(this.getWidth = function () {
return Math.max(this.isVisible ? this.width : 0, this.$minWidth || 0)
}),
(this.setHeight = function (e) {
this.element.style.height = e + 'px'
}),
(this.setInnerHeight = this.setScrollHeight =
function (e) {
;(this.scrollHeight = e),
e > u ? ((this.coeff = u / e), (e = u)) : this.coeff != 1 && (this.coeff = 1),
(this.inner.style.height = e + 'px')
}),
(this.setScrollTop = function (e) {
this.scrollTop != e &&
((this.skipEvent = !0),
(this.scrollTop = e),
(this.element.scrollTop = e * this.coeff))
})
}.call(f.prototype)
var l = function (e, t) {
a.call(this, e),
(this.scrollLeft = 0),
(this.height = t.$scrollbarWidth),
(this.inner.style.height = this.element.style.height = (this.height || 15) + 5 + 'px')
}
r.inherits(l, a),
function () {
;(this.classSuffix = '-h'),
(this.onScroll = function () {
this.skipEvent ||
((this.scrollLeft = this.element.scrollLeft),
this._emit('scroll', { data: this.scrollLeft })),
(this.skipEvent = !1)
}),
(this.getHeight = function () {
return this.isVisible ? this.height : 0
}),
(this.setWidth = function (e) {
this.element.style.width = e + 'px'
}),
(this.setInnerWidth = function (e) {
this.inner.style.width = e + 'px'
}),
(this.setScrollWidth = function (e) {
this.inner.style.width = e + 'px'
}),
(this.setScrollLeft = function (e) {
this.scrollLeft != e &&
((this.skipEvent = !0), (this.scrollLeft = this.element.scrollLeft = e))
})
}.call(l.prototype),
(t.ScrollBar = f),
(t.ScrollBarV = f),
(t.ScrollBarH = l),
(t.VScrollBar = f),
(t.HScrollBar = l)
}
),
ace.define(
'ace/renderloop',
['require', 'exports', 'module', 'ace/lib/event'],
function (e, t, n) {
'use strict'
var r = e('./lib/event'),
i = function (e, t) {
;(this.onRender = e),
(this.pending = !1),
(this.changes = 0),
(this.$recursionLimit = 2),
(this.window = t || window)
var n = this
this._flush = function (e) {
n.pending = !1
var t = n.changes
t && (r.blockIdle(100), (n.changes = 0), n.onRender(t))
if (n.changes) {
if (n.$recursionLimit-- < 0) return
n.schedule()
} else n.$recursionLimit = 2
}
}
;(function () {
;(this.schedule = function (e) {
;(this.changes = this.changes | e),
this.changes && !this.pending && (r.nextFrame(this._flush), (this.pending = !0))
}),
(this.clear = function (e) {
var t = this.changes
return (this.changes = 0), t
})
}).call(i.prototype),
(t.RenderLoop = i)
}
),
ace.define(
'ace/layer/font_metrics',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/lib/dom',
'ace/lib/lang',
'ace/lib/event',
'ace/lib/useragent',
'ace/lib/event_emitter',
],
function (e, t, n) {
var r = e('../lib/oop'),
i = e('../lib/dom'),
s = e('../lib/lang'),
o = e('../lib/event'),
u = e('../lib/useragent'),
a = e('../lib/event_emitter').EventEmitter,
f = 256,
l = typeof ResizeObserver == 'function',
c = 200,
h = (t.FontMetrics = function (e) {
;(this.el = i.createElement('div')),
this.$setMeasureNodeStyles(this.el.style, !0),
(this.$main = i.createElement('div')),
this.$setMeasureNodeStyles(this.$main.style),
(this.$measureNode = i.createElement('div')),
this.$setMeasureNodeStyles(this.$measureNode.style),
this.el.appendChild(this.$main),
this.el.appendChild(this.$measureNode),
e.appendChild(this.el),
(this.$measureNode.textContent = s.stringRepeat('X', f)),
(this.$characterSize = { width: 0, height: 0 }),
l ? this.$addObserver() : this.checkForSizeChanges()
})
;(function () {
r.implement(this, a),
(this.$characterSize = { width: 0, height: 0 }),
(this.$setMeasureNodeStyles = function (e, t) {
;(e.width = e.height = 'auto'),
(e.left = e.top = '0px'),
(e.visibility = 'hidden'),
(e.position = 'absolute'),
(e.whiteSpace = 'pre'),
u.isIE < 8 ? (e['font-family'] = 'inherit') : (e.font = 'inherit'),
(e.overflow = t ? 'hidden' : 'visible')
}),
(this.checkForSizeChanges = function (e) {
e === undefined && (e = this.$measureSizes())
if (
e &&
(this.$characterSize.width !== e.width || this.$characterSize.height !== e.height)
) {
this.$measureNode.style.fontWeight = 'bold'
var t = this.$measureSizes()
;(this.$measureNode.style.fontWeight = ''),
(this.$characterSize = e),
(this.charSizes = Object.create(null)),
(this.allowBoldFonts = t && t.width === e.width && t.height === e.height),
this._emit('changeCharacterSize', { data: e })
}
}),
(this.$addObserver = function () {
var e = this
;(this.$observer = new window.ResizeObserver(function (t) {
e.checkForSizeChanges()
})),
this.$observer.observe(this.$measureNode)
}),
(this.$pollSizeChanges = function () {
if (this.$pollSizeChangesTimer || this.$observer) return this.$pollSizeChangesTimer
var e = this
return (this.$pollSizeChangesTimer = o.onIdle(function t() {
e.checkForSizeChanges(), o.onIdle(t, 500)
}, 500))
}),
(this.setPolling = function (e) {
e
? this.$pollSizeChanges()
: this.$pollSizeChangesTimer &&
(clearInterval(this.$pollSizeChangesTimer), (this.$pollSizeChangesTimer = 0))
}),
(this.$measureSizes = function (e) {
var t = {
height: (e || this.$measureNode).clientHeight,
width: (e || this.$measureNode).clientWidth / f,
}
return t.width === 0 || t.height === 0 ? null : t
}),
(this.$measureCharWidth = function (e) {
this.$main.textContent = s.stringRepeat(e, f)
var t = this.$main.getBoundingClientRect()
return t.width / f
}),
(this.getCharacterWidth = function (e) {
var t = this.charSizes[e]
return (
t === undefined &&
(t = this.charSizes[e] = this.$measureCharWidth(e) / this.$characterSize.width),
t
)
}),
(this.destroy = function () {
clearInterval(this.$pollSizeChangesTimer),
this.$observer && this.$observer.disconnect(),
this.el && this.el.parentNode && this.el.parentNode.removeChild(this.el)
}),
(this.$getZoom = function e(t) {
return !t || !t.parentElement
? 1
: (window.getComputedStyle(t).zoom || 1) * e(t.parentElement)
}),
(this.$initTransformMeasureNodes = function () {
var e = function (e, t) {
return ['div', { style: 'position: absolute;top:' + e + 'px;left:' + t + 'px;' }]
}
this.els = i.buildDom([e(0, 0), e(c, 0), e(0, c), e(c, c)], this.el)
}),
(this.transformCoordinates = function (e, t) {
function r(e, t, n) {
var r = e[1] * t[0] - e[0] * t[1]
return [(-t[1] * n[0] + t[0] * n[1]) / r, (+e[1] * n[0] - e[0] * n[1]) / r]
}
function i(e, t) {
return [e[0] - t[0], e[1] - t[1]]
}
function s(e, t) {
return [e[0] + t[0], e[1] + t[1]]
}
function o(e, t) {
return [e * t[0], e * t[1]]
}
function u(e) {
var t = e.getBoundingClientRect()
return [t.left, t.top]
}
if (e) {
var n = this.$getZoom(this.el)
e = o(1 / n, e)
}
this.els || this.$initTransformMeasureNodes()
var a = u(this.els[0]),
f = u(this.els[1]),
l = u(this.els[2]),
h = u(this.els[3]),
p = r(i(h, f), i(h, l), i(s(f, l), s(h, a))),
d = o(1 + p[0], i(f, a)),
v = o(1 + p[1], i(l, a))
if (t) {
var m = t,
g = (p[0] * m[0]) / c + (p[1] * m[1]) / c + 1,
y = s(o(m[0], d), o(m[1], v))
return s(o(1 / g / c, y), a)
}
var b = i(e, a),
w = r(i(d, o(p[0], b)), i(v, o(p[1], b)), b)
return o(c, w)
})
}).call(h.prototype)
}
),
ace.define(
'ace/virtual_renderer',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/lib/dom',
'ace/config',
'ace/layer/gutter',
'ace/layer/marker',
'ace/layer/text',
'ace/layer/cursor',
'ace/scrollbar',
'ace/scrollbar',
'ace/renderloop',
'ace/layer/font_metrics',
'ace/lib/event_emitter',
'ace/lib/useragent',
],
function (e, t, n) {
'use strict'
var r = e('./lib/oop'),
i = e('./lib/dom'),
s = e('./config'),
o = e('./layer/gutter').Gutter,
u = e('./layer/marker').Marker,
a = e('./layer/text').Text,
f = e('./layer/cursor').Cursor,
l = e('./scrollbar').HScrollBar,
c = e('./scrollbar').VScrollBar,
h = e('./renderloop').RenderLoop,
p = e('./layer/font_metrics').FontMetrics,
d = e('./lib/event_emitter').EventEmitter,
v =
'.ace_br1 {border-top-left-radius : 3px;}.ace_br2 {border-top-right-radius : 3px;}.ace_br3 {border-top-left-radius : 3px; border-top-right-radius: 3px;}.ace_br4 {border-bottom-right-radius: 3px;}.ace_br5 {border-top-left-radius : 3px; border-bottom-right-radius: 3px;}.ace_br6 {border-top-right-radius : 3px; border-bottom-right-radius: 3px;}.ace_br7 {border-top-left-radius : 3px; border-top-right-radius: 3px; border-bottom-right-radius: 3px;}.ace_br8 {border-bottom-left-radius : 3px;}.ace_br9 {border-top-left-radius : 3px; border-bottom-left-radius: 3px;}.ace_br10{border-top-right-radius : 3px; border-bottom-left-radius: 3px;}.ace_br11{border-top-left-radius : 3px; border-top-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_br12{border-bottom-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_br13{border-top-left-radius : 3px; border-bottom-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_br14{border-top-right-radius : 3px; border-bottom-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_br15{border-top-left-radius : 3px; border-top-right-radius: 3px; border-bottom-right-radius: 3px; border-bottom-left-radius: 3px;}.ace_editor {position: relative;overflow: hidden;padding: 0;font: 12px/normal \'Monaco\', \'Menlo\', \'Ubuntu Mono\', \'Consolas\', \'source-code-pro\', monospace;direction: ltr;text-align: left;-webkit-tap-highlight-color: rgba(0, 0, 0, 0);}.ace_scroller {position: absolute;overflow: hidden;top: 0;bottom: 0;background-color: inherit;-ms-user-select: none;-moz-user-select: none;-webkit-user-select: none;user-select: none;cursor: text;}.ace_content {position: absolute;box-sizing: border-box;min-width: 100%;contain: style size layout;font-variant-ligatures: no-common-ligatures;}.ace_dragging .ace_scroller:before{position: absolute;top: 0;left: 0;right: 0;bottom: 0;content: \'\';background: rgba(250, 250, 250, 0.01);z-index: 1000;}.ace_dragging.ace_dark .ace_scroller:before{background: rgba(0, 0, 0, 0.01);}.ace_selecting, .ace_selecting * {cursor: text !important;}.ace_gutter {position: absolute;overflow : hidden;width: auto;top: 0;bottom: 0;left: 0;cursor: default;z-index: 4;-ms-user-select: none;-moz-user-select: none;-webkit-user-select: none;user-select: none;contain: style size layout;}.ace_gutter-active-line {position: absolute;left: 0;right: 0;}.ace_scroller.ace_scroll-left {box-shadow: 17px 0 16px -16px rgba(0, 0, 0, 0.4) inset;}.ace_gutter-cell {position: absolute;top: 0;left: 0;right: 0;padding-left: 19px;padding-right: 6px;background-repeat: no-repeat;}.ace_gutter-cell.ace_error {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAABOFBMVEX/////////QRswFAb/Ui4wFAYwFAYwFAaWGAfDRymzOSH/PxswFAb/SiUwFAYwFAbUPRvjQiDllog5HhHdRybsTi3/Tyv9Tir+Syj/UC3////XurebMBIwFAb/RSHbPx/gUzfdwL3kzMivKBAwFAbbvbnhPx66NhowFAYwFAaZJg8wFAaxKBDZurf/RB6mMxb/SCMwFAYwFAbxQB3+RB4wFAb/Qhy4Oh+4QifbNRcwFAYwFAYwFAb/QRzdNhgwFAYwFAbav7v/Uy7oaE68MBK5LxLewr/r2NXewLswFAaxJw4wFAbkPRy2PyYwFAaxKhLm1tMwFAazPiQwFAaUGAb/QBrfOx3bvrv/VC/maE4wFAbRPBq6MRO8Qynew8Dp2tjfwb0wFAbx6eju5+by6uns4uH9/f36+vr/GkHjAAAAYnRSTlMAGt+64rnWu/bo8eAA4InH3+DwoN7j4eLi4xP99Nfg4+b+/u9B/eDs1MD1mO7+4PHg2MXa347g7vDizMLN4eG+Pv7i5evs/v79yu7S3/DV7/498Yv24eH+4ufQ3Ozu/v7+y13sRqwAAADLSURBVHjaZc/XDsFgGIBhtDrshlitmk2IrbHFqL2pvXf/+78DPokj7+Fz9qpU/9UXJIlhmPaTaQ6QPaz0mm+5gwkgovcV6GZzd5JtCQwgsxoHOvJO15kleRLAnMgHFIESUEPmawB9ngmelTtipwwfASilxOLyiV5UVUyVAfbG0cCPHig+GBkzAENHS0AstVF6bacZIOzgLmxsHbt2OecNgJC83JERmePUYq8ARGkJx6XtFsdddBQgZE2nPR6CICZhawjA4Fb/chv+399kfR+MMMDGOQAAAABJRU5ErkJggg==");background-repeat: no-repeat;background-position: 2px center;}.ace_gutter-cell.ace_warning {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAAAmVBMVEX///8AAAD///8AAAAAAABPSzb/5sAAAAB/blH/73z/ulkAAAAAAAD85pkAAAAAAAACAgP/vGz/rkDerGbGrV7/pkQICAf////e0IsAAAD/oED/qTvhrnUAAAD/yHD/njcAAADuv2r/nz//oTj/p064oGf/zHAAAAA9Nir/tFIAAAD/tlTiuWf/tkIAAACynXEAAAAAAAAtIRW7zBpBAAAAM3RSTlMAABR1m7RXO8Ln31Z36zT+neXe5OzooRDfn+TZ4p3h2hTf4t3k3ucyrN1K5+Xaks52Sfs9CXgrAAAAjklEQVR42o3PbQ+CIBQFYEwboPhSYgoYunIqqLn6/z8uYdH8Vmdnu9vz4WwXgN/xTPRD2+sgOcZjsge/whXZgUaYYvT8QnuJaUrjrHUQreGczuEafQCO/SJTufTbroWsPgsllVhq3wJEk2jUSzX3CUEDJC84707djRc5MTAQxoLgupWRwW6UB5fS++NV8AbOZgnsC7BpEAAAAABJRU5ErkJggg==");background-position: 2px center;}.ace_gutter-cell.ace_info {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAAAAAA6mKC9AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAAJ0Uk5TAAB2k804AAAAPklEQVQY02NgIB68QuO3tiLznjAwpKTgNyDbMegwisCHZUETUZV0ZqOquBpXj2rtnpSJT1AEnnRmL2OgGgAAIKkRQap2htgAAAAASUVORK5CYII=");background-position: 2px center;}.ace_dark .ace_gutter-cell.ace_info {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQBAMAAADt3eJSAAAAJFBMVEUAAAChoaGAgIAqKiq+vr6tra1ZWVmUlJSbm5s8PDxubm56enrdgzg3AAAAAXRSTlMAQObYZgAAAClJREFUeNpjYMAPdsMYHegyJZFQBlsUlMFVCWUYKkAZMxZAGdxlDMQBAG+TBP4B6RyJAAAAAElFTkSuQmCC");}.ace_scrollbar {contain: strict;position: absolute;right: 0;bottom: 0;z-index: 6;}.ace_scrollbar-inner {position: absolute;cursor: text;left: 0;top: 0;}.ace_scrollbar-v{overflow-x: hidden;overflow-y: scroll;top: 0;}.ace_scrollbar-h {overflow-x: scroll;overflow-y: hidden;left: 0;}.ace_print-margin {position: absolute;height: 100%;}.ace_text-input {position: absolute;z-index: 0;width: 0.5em;height: 1em;opacity: 0;background: transparent;-moz-appearance: none;appearance: none;border: none;resize: none;outline: none;overflow: hidden;font: inherit;padding: 0 1px;margin: 0 -1px;contain: strict;-ms-user-select: text;-moz-user-select: text;-webkit-user-select: text;user-select: text;white-space: pre!important;}.ace_text-input.ace_composition {background: transparent;color: inherit;z-index: 1000;opacity: 1;}.ace_composition_placeholder { color: transparent }.ace_composition_marker { border-bottom: 1px solid;position: absolute;border-radius: 0;margin-top: 1px;}[ace_nocontext=true] {transform: none!important;filter: none!important;clip-path: none!important;mask : none!important;contain: none!important;perspective: none!important;mix-blend-mode: initial!important;z-index: auto;}.ace_layer {z-index: 1;position: absolute;overflow: hidden;word-wrap: normal;white-space: pre;height: 100%;width: 100%;box-sizing: border-box;pointer-events: none;}.ace_gutter-layer {position: relative;width: auto;text-align: right;pointer-events: auto;height: 1000000px;contain: style size layout;}.ace_text-layer {font: inherit !important;position: absolute;height: 1000000px;width: 1000000px;contain: style size layout;}.ace_text-layer > .ace_line, .ace_text-layer > .ace_line_group {contain: style size layout;position: absolute;top: 0;left: 0;right: 0;}.ace_hidpi .ace_text-layer,.ace_hidpi .ace_gutter-layer,.ace_hidpi .ace_content,.ace_hidpi .ace_gutter {contain: strict;will-change: transform;}.ace_hidpi .ace_text-layer > .ace_line, .ace_hidpi .ace_text-layer > .ace_line_group {contain: strict;}.ace_cjk {display: inline-block;text-align: center;}.ace_cursor-layer {z-index: 4;}.ace_cursor {z-index: 4;position: absolute;box-sizing: border-box;border-left: 2px solid;transform: translatez(0);}.ace_multiselect .ace_cursor {border-left-width: 1px;}.ace_slim-cursors .ace_cursor {border-left-width: 1px;}.ace_overwrite-cursors .ace_cursor {border-left-width: 0;border-bottom: 1px solid;}.ace_hidden-cursors .ace_cursor {opacity: 0.2;}.ace_hasPlaceholder .ace_hidden-cursors .ace_cursor {opacity: 0;}.ace_smooth-blinking .ace_cursor {transition: opacity 0.18s;}.ace_animate-blinking .ace_cursor {animation-duration: 1000ms;animation-timing-function: step-end;animation-name: blink-ace-animate;animation-iteration-count: infinite;}.ace_animate-blinking.ace_smooth-blinking .ace_cursor {animation-duration: 1000ms;animation-timing-function: ease-in-out;animation-name: blink-ace-animate-smooth;}@keyframes blink-ace-animate {from, to { opacity: 1; }60% { opacity: 0; }}@keyframes blink-ace-animate-smooth {from, to { opacity: 1; }45% { opacity: 1; }60% { opacity: 0; }85% { opacity: 0; }}.ace_marker-layer .ace_step, .ace_marker-layer .ace_stack {position: absolute;z-index: 3;}.ace_marker-layer .ace_selection {position: absolute;z-index: 5;}.ace_marker-layer .ace_bracket {position: absolute;z-index: 6;}.ace_marker-layer .ace_error_bracket {position: absolute;border-bottom: 1px solid #DE5555;border-radius: 0;}.ace_marker-layer .ace_active-line {position: absolute;z-index: 2;}.ace_marker-layer .ace_selected-word {position: absolute;z-index: 4;box-sizing: border-box;}.ace_line .ace_fold {box-sizing: border-box;display: inline-block;height: 11px;margin-top: -2px;vertical-align: middle;background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABEAAAAJCAYAAADU6McMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAJpJREFUeNpi/P//PwOlgAXGYGRklAVSokD8GmjwY1wasKljQpYACtpCFeADcHVQfQyMQAwzwAZI3wJKvCLkfKBaMSClBlR7BOQikCFGQEErIH0VqkabiGCAqwUadAzZJRxQr/0gwiXIal8zQQPnNVTgJ1TdawL0T5gBIP1MUJNhBv2HKoQHHjqNrA4WO4zY0glyNKLT2KIfIMAAQsdgGiXvgnYAAAAASUVORK5CYII="),url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAA3CAYAAADNNiA5AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAACJJREFUeNpi+P//fxgTAwPDBxDxD078RSX+YeEyDFMCIMAAI3INmXiwf2YAAAAASUVORK5CYII=");background-repeat: no-repeat, repeat-x;background-position: center center, top left;color: transparent;border: 1px solid black;border-radius: 2px;cursor: pointer;pointer-events: auto;}.ace_dark .ace_fold {}.ace_fold:hover{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABEAAAAJCAYAAADU6McMAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAJpJREFUeNpi/P//PwOlgAXGYGRklAVSokD8GmjwY1wasKljQpYACtpCFeADcHVQfQyMQAwzwAZI3wJKvCLkfKBaMSClBlR7BOQikCFGQEErIH0VqkabiGCAqwUadAzZJRxQr/0gwiXIal8zQQPnNVTgJ1TdawL0T5gBIP1MUJNhBv2HKoQHHjqNrA4WO4zY0glyNKLT2KIfIMAAQsdgGiXvgnYAAAAASUVORK5CYII="),url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAA3CAYAAADNNiA5AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAACBJREFUeNpi+P//fz4TAwPDZxDxD5X4i5fLMEwJgAADAEPVDbjNw87ZAAAAAElFTkSuQmCC");}.ace_tooltip {background-color: #FFF;background-image: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.1));border: 1px solid gray;border-radius: 1px;box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);color: black;max-width: 100%;padding: 3px 4px;position: fixed;z-index: 999999;box-sizing: border-box;cursor: default;white-space: pre;word-wrap: break-word;line-height: normal;font-style: normal;font-weight: normal;letter-spacing: normal;pointer-events: none;}.ace_folding-enabled > .ace_gutter-cell {padding-right: 13px;}.ace_fold-widget {box-sizing: border-box;margin: 0 -12px 0 1px;display: none;width: 11px;vertical-align: top;background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAANElEQVR42mWKsQ0AMAzC8ixLlrzQjzmBiEjp0A6WwBCSPgKAXoLkqSot7nN3yMwR7pZ32NzpKkVoDBUxKAAAAABJRU5ErkJggg==");background-repeat: no-repeat;background-position: center;border-radius: 3px;border: 1px solid transparent;cursor: pointer;}.ace_folding-enabled .ace_fold-widget {display: inline-block; }.ace_fold-widget.ace_end {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAANElEQVR42m3HwQkAMAhD0YzsRchFKI7sAikeWkrxwScEB0nh5e7KTPWimZki4tYfVbX+MNl4pyZXejUO1QAAAABJRU5ErkJggg==");}.ace_fold-widget.ace_closed {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAAGCAYAAAAG5SQMAAAAOUlEQVR42jXKwQkAMAgDwKwqKD4EwQ26sSOkVWjgIIHAzPiCgaqiqnJHZnKICBERHN194O5b9vbLuAVRL+l0YWnZAAAAAElFTkSuQmCCXA==");}.ace_fold-widget:hover {border: 1px solid rgba(0, 0, 0, 0.3);background-color: rgba(255, 255, 255, 0.2);box-shadow: 0 1px 1px rgba(255, 255, 255, 0.7);}.ace_fold-widget:active {border: 1px solid rgba(0, 0, 0, 0.4);background-color: rgba(0, 0, 0, 0.05);box-shadow: 0 1px 1px rgba(255, 255, 255, 0.8);}.ace_dark .ace_fold-widget {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHklEQVQIW2P4//8/AzoGEQ7oGCaLLAhWiSwB146BAQCSTPYocqT0AAAAAElFTkSuQmCC");}.ace_dark .ace_fold-widget.ace_end {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAH0lEQVQIW2P4//8/AxQ7wNjIAjDMgC4AxjCVKBirIAAF0kz2rlhxpAAAAABJRU5ErkJggg==");}.ace_dark .ace_fold-widget.ace_closed {background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAMAAAAFCAYAAACAcVaiAAAAHElEQVQIW2P4//+/AxAzgDADlOOAznHAKgPWAwARji8UIDTfQQAAAABJRU5ErkJggg==");}.ace_dark .ace_fold-widget:hover {box-shadow: 0 1px 1px rgba(255, 255, 255, 0.2);background-color: rgba(255, 255, 255, 0.1);}.ace_dark .ace_fold-widget:active {box-shadow: 0 1px 1px rgba(255, 255, 255, 0.2);}.ace_inline_button {border: 1px solid lightgray;display: inline-block;margin: -1px 8px;padding: 0 5px;pointer-events: auto;cursor: pointer;}.ace_inline_button:hover {border-color: gray;background: rgba(200,200,200,0.2);display: inline-block;pointer-events: auto;}.ace_fold-widget.ace_invalid {background-color: #FFB4B4;border-color: #DE5555;}.ace_fade-fold-widgets .ace_fold-widget {transition: opacity 0.4s ease 0.05s;opacity: 0;}.ace_fade-fold-widgets:hover .ace_fold-widget {transition: opacity 0.05s ease 0.05s;opacity:1;}.ace_underline {text-decoration: underline;}.ace_bold {font-weight: bold;}.ace_nobold .ace_bold {font-weight: normal;}.ace_italic {font-style: italic;}.ace_error-marker {background-color: rgba(255, 0, 0,0.2);position: absolute;z-index: 9;}.ace_highlight-marker {background-color: rgba(255, 255, 0,0.2);position: absolute;z-index: 8;}.ace_mobile-menu {position: absolute;line-height: 1.5;border-radius: 4px;-ms-user-select: none;-moz-user-select: none;-webkit-user-select: none;user-select: none;background: white;box-shadow: 1px 3px 2px grey;border: 1px solid #dcdcdc;color: black;}.ace_dark > .ace_mobile-menu {background: #333;color: #ccc;box-shadow: 1px 3px 2px grey;border: 1px solid #444;}.ace_mobile-button {padding: 2px;cursor: pointer;overflow: hidden;}.ace_mobile-button:hover {background-color: #eee;opacity:1;}.ace_mobile-button:active {background-color: #ddd;}.ace_placeholder {font-family: arial;transform: scale(0.9);transform-origin: left;white-space: pre;opacity: 0.7;margin: 0 10px;}',
m = e('./lib/useragent'),
g = m.isIE
i.importCssString(v, 'ace_editor.css')
var y = function (e, t) {
var n = this
;(this.container = e || i.createElement('div')),
i.addCssClass(this.container, 'ace_editor'),
i.HI_DPI && i.addCssClass(this.container, 'ace_hidpi'),
this.setTheme(t),
(this.$gutter = i.createElement('div')),
(this.$gutter.className = 'ace_gutter'),
this.container.appendChild(this.$gutter),
this.$gutter.setAttribute('aria-hidden', !0),
(this.scroller = i.createElement('div')),
(this.scroller.className = 'ace_scroller'),
this.container.appendChild(this.scroller),
(this.content = i.createElement('div')),
(this.content.className = 'ace_content'),
this.scroller.appendChild(this.content),
(this.$gutterLayer = new o(this.$gutter)),
this.$gutterLayer.on('changeGutterWidth', this.onGutterResize.bind(this)),
(this.$markerBack = new u(this.content))
var r = (this.$textLayer = new a(this.content))
;(this.canvas = r.element),
(this.$markerFront = new u(this.content)),
(this.$cursorLayer = new f(this.content)),
(this.$horizScroll = !1),
(this.$vScroll = !1),
(this.scrollBar = this.scrollBarV = new c(this.container, this)),
(this.scrollBarH = new l(this.container, this)),
this.scrollBarV.on('scroll', function (e) {
n.$scrollAnimation || n.session.setScrollTop(e.data - n.scrollMargin.top)
}),
this.scrollBarH.on('scroll', function (e) {
n.$scrollAnimation || n.session.setScrollLeft(e.data - n.scrollMargin.left)
}),
(this.scrollTop = 0),
(this.scrollLeft = 0),
(this.cursorPos = { row: 0, column: 0 }),
(this.$fontMetrics = new p(this.container)),
this.$textLayer.$setFontMetrics(this.$fontMetrics),
this.$textLayer.on('changeCharacterSize', function (e) {
n.updateCharacterSize(),
n.onResize(!0, n.gutterWidth, n.$size.width, n.$size.height),
n._signal('changeCharacterSize', e)
}),
(this.$size = { width: 0, height: 0, scrollerHeight: 0, scrollerWidth: 0, $dirty: !0 }),
(this.layerConfig = {
width: 1,
padding: 0,
firstRow: 0,
firstRowScreen: 0,
lastRow: 0,
lineHeight: 0,
characterWidth: 0,
minHeight: 1,
maxHeight: 1,
offset: 0,
height: 1,
gutterOffset: 1,
}),
(this.scrollMargin = { left: 0, right: 0, top: 0, bottom: 0, v: 0, h: 0 }),
(this.margin = { left: 0, right: 0, top: 0, bottom: 0, v: 0, h: 0 }),
(this.$keepTextAreaAtCursor = !m.isIOS),
(this.$loop = new h(
this.$renderChanges.bind(this),
this.container.ownerDocument.defaultView
)),
this.$loop.schedule(this.CHANGE_FULL),
this.updateCharacterSize(),
this.setPadding(4),
s.resetOptions(this),
s._signal('renderer', this)
}
;(function () {
;(this.CHANGE_CURSOR = 1),
(this.CHANGE_MARKER = 2),
(this.CHANGE_GUTTER = 4),
(this.CHANGE_SCROLL = 8),
(this.CHANGE_LINES = 16),
(this.CHANGE_TEXT = 32),
(this.CHANGE_SIZE = 64),
(this.CHANGE_MARKER_BACK = 128),
(this.CHANGE_MARKER_FRONT = 256),
(this.CHANGE_FULL = 512),
(this.CHANGE_H_SCROLL = 1024),
r.implement(this, d),
(this.updateCharacterSize = function () {
this.$textLayer.allowBoldFonts != this.$allowBoldFonts &&
((this.$allowBoldFonts = this.$textLayer.allowBoldFonts),
this.setStyle('ace_nobold', !this.$allowBoldFonts)),
(this.layerConfig.characterWidth = this.characterWidth =
this.$textLayer.getCharacterWidth()),
(this.layerConfig.lineHeight = this.lineHeight = this.$textLayer.getLineHeight()),
this.$updatePrintMargin(),
i.setStyle(this.scroller.style, 'line-height', this.lineHeight + 'px')
}),
(this.setSession = function (e) {
this.session && this.session.doc.off('changeNewLineMode', this.onChangeNewLineMode),
(this.session = e),
e &&
this.scrollMargin.top &&
e.getScrollTop() <= 0 &&
e.setScrollTop(-this.scrollMargin.top),
this.$cursorLayer.setSession(e),
this.$markerBack.setSession(e),
this.$markerFront.setSession(e),
this.$gutterLayer.setSession(e),
this.$textLayer.setSession(e)
if (!e) return
this.$loop.schedule(this.CHANGE_FULL),
this.session.$setFontMetrics(this.$fontMetrics),
(this.scrollBarH.scrollLeft = this.scrollBarV.scrollTop = null),
(this.onChangeNewLineMode = this.onChangeNewLineMode.bind(this)),
this.onChangeNewLineMode(),
this.session.doc.on('changeNewLineMode', this.onChangeNewLineMode)
}),
(this.updateLines = function (e, t, n) {
t === undefined && (t = Infinity),
this.$changedLines
? (this.$changedLines.firstRow > e && (this.$changedLines.firstRow = e),
this.$changedLines.lastRow < t && (this.$changedLines.lastRow = t))
: (this.$changedLines = { firstRow: e, lastRow: t })
if (this.$changedLines.lastRow < this.layerConfig.firstRow) {
if (!n) return
this.$changedLines.lastRow = this.layerConfig.lastRow
}
if (this.$changedLines.firstRow > this.layerConfig.lastRow) return
this.$loop.schedule(this.CHANGE_LINES)
}),
(this.onChangeNewLineMode = function () {
this.$loop.schedule(this.CHANGE_TEXT),
this.$textLayer.$updateEolChar(),
this.session.$bidiHandler.setEolChar(this.$textLayer.EOL_CHAR)
}),
(this.onChangeTabSize = function () {
this.$loop.schedule(this.CHANGE_TEXT | this.CHANGE_MARKER),
this.$textLayer.onChangeTabSize()
}),
(this.updateText = function () {
this.$loop.schedule(this.CHANGE_TEXT)
}),
(this.updateFull = function (e) {
e ? this.$renderChanges(this.CHANGE_FULL, !0) : this.$loop.schedule(this.CHANGE_FULL)
}),
(this.updateFontSize = function () {
this.$textLayer.checkForSizeChanges()
}),
(this.$changes = 0),
(this.$updateSizeAsync = function () {
this.$loop.pending ? (this.$size.$dirty = !0) : this.onResize()
}),
(this.onResize = function (e, t, n, r) {
if (this.resizing > 2) return
this.resizing > 0 ? this.resizing++ : (this.resizing = e ? 1 : 0)
var i = this.container
r || (r = i.clientHeight || i.scrollHeight), n || (n = i.clientWidth || i.scrollWidth)
var s = this.$updateCachedSize(e, t, n, r)
if (!this.$size.scrollerHeight || (!n && !r)) return (this.resizing = 0)
e && (this.$gutterLayer.$padding = null),
e
? this.$renderChanges(s | this.$changes, !0)
: this.$loop.schedule(s | this.$changes),
this.resizing && (this.resizing = 0),
(this.scrollBarV.scrollLeft = this.scrollBarV.scrollTop = null)
}),
(this.$updateCachedSize = function (e, t, n, r) {
r -= this.$extraHeight || 0
var s = 0,
o = this.$size,
u = {
width: o.width,
height: o.height,
scrollerHeight: o.scrollerHeight,
scrollerWidth: o.scrollerWidth,
}
r &&
(e || o.height != r) &&
((o.height = r),
(s |= this.CHANGE_SIZE),
(o.scrollerHeight = o.height),
this.$horizScroll && (o.scrollerHeight -= this.scrollBarH.getHeight()),
(this.scrollBarV.element.style.bottom = this.scrollBarH.getHeight() + 'px'),
(s |= this.CHANGE_SCROLL))
if (n && (e || o.width != n)) {
;(s |= this.CHANGE_SIZE),
(o.width = n),
t == null && (t = this.$showGutter ? this.$gutter.offsetWidth : 0),
(this.gutterWidth = t),
i.setStyle(this.scrollBarH.element.style, 'left', t + 'px'),
i.setStyle(this.scroller.style, 'left', t + this.margin.left + 'px'),
(o.scrollerWidth = Math.max(0, n - t - this.scrollBarV.getWidth() - this.margin.h)),
i.setStyle(this.$gutter.style, 'left', this.margin.left + 'px')
var a = this.scrollBarV.getWidth() + 'px'
i.setStyle(this.scrollBarH.element.style, 'right', a),
i.setStyle(this.scroller.style, 'right', a),
i.setStyle(this.scroller.style, 'bottom', this.scrollBarH.getHeight())
if ((this.session && this.session.getUseWrapMode() && this.adjustWrapLimit()) || e)
s |= this.CHANGE_FULL
}
return (o.$dirty = !n || !r), s && this._signal('resize', u), s
}),
(this.onGutterResize = function (e) {
var t = this.$showGutter ? e : 0
t != this.gutterWidth &&
(this.$changes |= this.$updateCachedSize(!0, t, this.$size.width, this.$size.height)),
this.session.getUseWrapMode() && this.adjustWrapLimit()
? this.$loop.schedule(this.CHANGE_FULL)
: this.$size.$dirty
? this.$loop.schedule(this.CHANGE_FULL)
: this.$computeLayerConfig()
}),
(this.adjustWrapLimit = function () {
var e = this.$size.scrollerWidth - this.$padding * 2,
t = Math.floor(e / this.characterWidth)
return this.session.adjustWrapLimit(t, this.$showPrintMargin && this.$printMarginColumn)
}),
(this.setAnimatedScroll = function (e) {
this.setOption('animatedScroll', e)
}),
(this.getAnimatedScroll = function () {
return this.$animatedScroll
}),
(this.setShowInvisibles = function (e) {
this.setOption('showInvisibles', e), this.session.$bidiHandler.setShowInvisibles(e)
}),
(this.getShowInvisibles = function () {
return this.getOption('showInvisibles')
}),
(this.getDisplayIndentGuides = function () {
return this.getOption('displayIndentGuides')
}),
(this.setDisplayIndentGuides = function (e) {
this.setOption('displayIndentGuides', e)
}),
(this.setShowPrintMargin = function (e) {
this.setOption('showPrintMargin', e)
}),
(this.getShowPrintMargin = function () {
return this.getOption('showPrintMargin')
}),
(this.setPrintMarginColumn = function (e) {
this.setOption('printMarginColumn', e)
}),
(this.getPrintMarginColumn = function () {
return this.getOption('printMarginColumn')
}),
(this.getShowGutter = function () {
return this.getOption('showGutter')
}),
(this.setShowGutter = function (e) {
return this.setOption('showGutter', e)
}),
(this.getFadeFoldWidgets = function () {
return this.getOption('fadeFoldWidgets')
}),
(this.setFadeFoldWidgets = function (e) {
this.setOption('fadeFoldWidgets', e)
}),
(this.setHighlightGutterLine = function (e) {
this.setOption('highlightGutterLine', e)
}),
(this.getHighlightGutterLine = function () {
return this.getOption('highlightGutterLine')
}),
(this.$updatePrintMargin = function () {
if (!this.$showPrintMargin && !this.$printMarginEl) return
if (!this.$printMarginEl) {
var e = i.createElement('div')
;(e.className = 'ace_layer ace_print-margin-layer'),
(this.$printMarginEl = i.createElement('div')),
(this.$printMarginEl.className = 'ace_print-margin'),
e.appendChild(this.$printMarginEl),
this.content.insertBefore(e, this.content.firstChild)
}
var t = this.$printMarginEl.style
;(t.left =
Math.round(this.characterWidth * this.$printMarginColumn + this.$padding) + 'px'),
(t.visibility = this.$showPrintMargin ? 'visible' : 'hidden'),
this.session && this.session.$wrap == -1 && this.adjustWrapLimit()
}),
(this.getContainerElement = function () {
return this.container
}),
(this.getMouseEventTarget = function () {
return this.scroller
}),
(this.getTextAreaContainer = function () {
return this.container
}),
(this.$moveTextAreaToCursor = function () {
if (this.$isMousePressed) return
var e = this.textarea.style,
t = this.$composition
if (!this.$keepTextAreaAtCursor && !t) {
i.translate(this.textarea, -100, 0)
return
}
var n = this.$cursorLayer.$pixelPos
if (!n) return
t && t.markerRange && (n = this.$cursorLayer.getPixelPosition(t.markerRange.start, !0))
var r = this.layerConfig,
s = n.top,
o = n.left
s -= r.offset
var u = t && t.useTextareaForIME ? this.lineHeight : g ? 0 : 1
if (s < 0 || s > r.height - u) {
i.translate(this.textarea, 0, 0)
return
}
var a = 1,
f = this.$size.height - u
if (!t) s += this.lineHeight
else if (t.useTextareaForIME) {
var l = this.textarea.value
a = this.characterWidth * this.session.$getStringScreenWidth(l)[0]
} else s += this.lineHeight + 2
;(o -= this.scrollLeft),
o > this.$size.scrollerWidth - a && (o = this.$size.scrollerWidth - a),
(o += this.gutterWidth + this.margin.left),
i.setStyle(e, 'height', u + 'px'),
i.setStyle(e, 'width', a + 'px'),
i.translate(this.textarea, Math.min(o, this.$size.scrollerWidth - a), Math.min(s, f))
}),
(this.getFirstVisibleRow = function () {
return this.layerConfig.firstRow
}),
(this.getFirstFullyVisibleRow = function () {
return this.layerConfig.firstRow + (this.layerConfig.offset === 0 ? 0 : 1)
}),
(this.getLastFullyVisibleRow = function () {
var e = this.layerConfig,
t = e.lastRow,
n = this.session.documentToScreenRow(t, 0) * e.lineHeight
return n - this.session.getScrollTop() > e.height - e.lineHeight ? t - 1 : t
}),
(this.getLastVisibleRow = function () {
return this.layerConfig.lastRow
}),
(this.$padding = null),
(this.setPadding = function (e) {
;(this.$padding = e),
this.$textLayer.setPadding(e),
this.$cursorLayer.setPadding(e),
this.$markerFront.setPadding(e),
this.$markerBack.setPadding(e),
this.$loop.schedule(this.CHANGE_FULL),
this.$updatePrintMargin()
}),
(this.setScrollMargin = function (e, t, n, r) {
var i = this.scrollMargin
;(i.top = e | 0),
(i.bottom = t | 0),
(i.right = r | 0),
(i.left = n | 0),
(i.v = i.top + i.bottom),
(i.h = i.left + i.right),
i.top && this.scrollTop <= 0 && this.session && this.session.setScrollTop(-i.top),
this.updateFull()
}),
(this.setMargin = function (e, t, n, r) {
var i = this.margin
;(i.top = e | 0),
(i.bottom = t | 0),
(i.right = r | 0),
(i.left = n | 0),
(i.v = i.top + i.bottom),
(i.h = i.left + i.right),
this.$updateCachedSize(!0, this.gutterWidth, this.$size.width, this.$size.height),
this.updateFull()
}),
(this.getHScrollBarAlwaysVisible = function () {
return this.$hScrollBarAlwaysVisible
}),
(this.setHScrollBarAlwaysVisible = function (e) {
this.setOption('hScrollBarAlwaysVisible', e)
}),
(this.getVScrollBarAlwaysVisible = function () {
return this.$vScrollBarAlwaysVisible
}),
(this.setVScrollBarAlwaysVisible = function (e) {
this.setOption('vScrollBarAlwaysVisible', e)
}),
(this.$updateScrollBarV = function () {
var e = this.layerConfig.maxHeight,
t = this.$size.scrollerHeight
!this.$maxLines &&
this.$scrollPastEnd &&
((e -= (t - this.lineHeight) * this.$scrollPastEnd),
this.scrollTop > e - t &&
((e = this.scrollTop + t), (this.scrollBarV.scrollTop = null))),
this.scrollBarV.setScrollHeight(e + this.scrollMargin.v),
this.scrollBarV.setScrollTop(this.scrollTop + this.scrollMargin.top)
}),
(this.$updateScrollBarH = function () {
this.scrollBarH.setScrollWidth(
this.layerConfig.width + 2 * this.$padding + this.scrollMargin.h
),
this.scrollBarH.setScrollLeft(this.scrollLeft + this.scrollMargin.left)
}),
(this.$frozen = !1),
(this.freeze = function () {
this.$frozen = !0
}),
(this.unfreeze = function () {
this.$frozen = !1
}),
(this.$renderChanges = function (e, t) {
this.$changes && ((e |= this.$changes), (this.$changes = 0))
if (!this.session || !this.container.offsetWidth || this.$frozen || (!e && !t)) {
this.$changes |= e
return
}
if (this.$size.$dirty) return (this.$changes |= e), this.onResize(!0)
this.lineHeight || this.$textLayer.checkForSizeChanges(),
this._signal('beforeRender', e),
this.session &&
this.session.$bidiHandler &&
this.session.$bidiHandler.updateCharacterWidths(this.$fontMetrics)
var n = this.layerConfig
if (
e & this.CHANGE_FULL ||
e & this.CHANGE_SIZE ||
e & this.CHANGE_TEXT ||
e & this.CHANGE_LINES ||
e & this.CHANGE_SCROLL ||
e & this.CHANGE_H_SCROLL
) {
e |= this.$computeLayerConfig() | this.$loop.clear()
if (
n.firstRow != this.layerConfig.firstRow &&
n.firstRowScreen == this.layerConfig.firstRowScreen
) {
var r = this.scrollTop + (n.firstRow - this.layerConfig.firstRow) * this.lineHeight
r > 0 &&
((this.scrollTop = r),
(e |= this.CHANGE_SCROLL),
(e |= this.$computeLayerConfig() | this.$loop.clear()))
}
;(n = this.layerConfig),
this.$updateScrollBarV(),
e & this.CHANGE_H_SCROLL && this.$updateScrollBarH(),
i.translate(this.content, -this.scrollLeft, -n.offset)
var s = n.width + 2 * this.$padding + 'px',
o = n.minHeight + 'px'
i.setStyle(this.content.style, 'width', s),
i.setStyle(this.content.style, 'height', o)
}
e & this.CHANGE_H_SCROLL &&
(i.translate(this.content, -this.scrollLeft, -n.offset),
(this.scroller.className =
this.scrollLeft <= 0 ? 'ace_scroller' : 'ace_scroller ace_scroll-left'))
if (e & this.CHANGE_FULL) {
;(this.$changedLines = null),
this.$textLayer.update(n),
this.$showGutter && this.$gutterLayer.update(n),
this.$markerBack.update(n),
this.$markerFront.update(n),
this.$cursorLayer.update(n),
this.$moveTextAreaToCursor(),
this._signal('afterRender', e)
return
}
if (e & this.CHANGE_SCROLL) {
;(this.$changedLines = null),
e & this.CHANGE_TEXT || e & this.CHANGE_LINES
? this.$textLayer.update(n)
: this.$textLayer.scrollLines(n),
this.$showGutter &&
(e & this.CHANGE_GUTTER || e & this.CHANGE_LINES
? this.$gutterLayer.update(n)
: this.$gutterLayer.scrollLines(n)),
this.$markerBack.update(n),
this.$markerFront.update(n),
this.$cursorLayer.update(n),
this.$moveTextAreaToCursor(),
this._signal('afterRender', e)
return
}
e & this.CHANGE_TEXT
? ((this.$changedLines = null),
this.$textLayer.update(n),
this.$showGutter && this.$gutterLayer.update(n))
: e & this.CHANGE_LINES
? (this.$updateLines() || (e & this.CHANGE_GUTTER && this.$showGutter)) &&
this.$gutterLayer.update(n)
: e & this.CHANGE_TEXT || e & this.CHANGE_GUTTER
? this.$showGutter && this.$gutterLayer.update(n)
: e & this.CHANGE_CURSOR &&
this.$highlightGutterLine &&
this.$gutterLayer.updateLineHighlight(n),
e & this.CHANGE_CURSOR && (this.$cursorLayer.update(n), this.$moveTextAreaToCursor()),
e & (this.CHANGE_MARKER | this.CHANGE_MARKER_FRONT) && this.$markerFront.update(n),
e & (this.CHANGE_MARKER | this.CHANGE_MARKER_BACK) && this.$markerBack.update(n),
this._signal('afterRender', e)
}),
(this.$autosize = function () {
var e = this.session.getScreenLength() * this.lineHeight,
t = this.$maxLines * this.lineHeight,
n =
Math.min(t, Math.max((this.$minLines || 1) * this.lineHeight, e)) +
this.scrollMargin.v +
(this.$extraHeight || 0)
this.$horizScroll && (n += this.scrollBarH.getHeight()),
this.$maxPixelHeight && n > this.$maxPixelHeight && (n = this.$maxPixelHeight)
var r = n <= 2 * this.lineHeight,
i = !r && e > t
if (
n != this.desiredHeight ||
this.$size.height != this.desiredHeight ||
i != this.$vScroll
) {
i != this.$vScroll && ((this.$vScroll = i), this.scrollBarV.setVisible(i))
var s = this.container.clientWidth
;(this.container.style.height = n + 'px'),
this.$updateCachedSize(!0, this.$gutterWidth, s, n),
(this.desiredHeight = n),
this._signal('autosize')
}
}),
(this.$computeLayerConfig = function () {
var e = this.session,
t = this.$size,
n = t.height <= 2 * this.lineHeight,
r = this.session.getScreenLength(),
i = r * this.lineHeight,
s = this.$getLongestLine(),
o =
!n &&
(this.$hScrollBarAlwaysVisible || t.scrollerWidth - s - 2 * this.$padding < 0),
u = this.$horizScroll !== o
u && ((this.$horizScroll = o), this.scrollBarH.setVisible(o))
var a = this.$vScroll
this.$maxLines && this.lineHeight > 1 && this.$autosize()
var f = t.scrollerHeight + this.lineHeight,
l =
!this.$maxLines && this.$scrollPastEnd
? (t.scrollerHeight - this.lineHeight) * this.$scrollPastEnd
: 0
i += l
var c = this.scrollMargin
this.session.setScrollTop(
Math.max(-c.top, Math.min(this.scrollTop, i - t.scrollerHeight + c.bottom))
),
this.session.setScrollLeft(
Math.max(
-c.left,
Math.min(this.scrollLeft, s + 2 * this.$padding - t.scrollerWidth + c.right)
)
)
var h =
!n &&
(this.$vScrollBarAlwaysVisible ||
t.scrollerHeight - i + l < 0 ||
this.scrollTop > c.top),
p = a !== h
p && ((this.$vScroll = h), this.scrollBarV.setVisible(h))
var d = this.scrollTop % this.lineHeight,
v = Math.ceil(f / this.lineHeight) - 1,
m = Math.max(0, Math.round((this.scrollTop - d) / this.lineHeight)),
g = m + v,
y,
b,
w = this.lineHeight
m = e.screenToDocumentRow(m, 0)
var E = e.getFoldLine(m)
E && (m = E.start.row),
(y = e.documentToScreenRow(m, 0)),
(b = e.getRowLength(m) * w),
(g = Math.min(e.screenToDocumentRow(g, 0), e.getLength() - 1)),
(f = t.scrollerHeight + e.getRowLength(g) * w + b),
(d = this.scrollTop - y * w)
var S = 0
if (this.layerConfig.width != s || u) S = this.CHANGE_H_SCROLL
if (u || p)
(S |= this.$updateCachedSize(!0, this.gutterWidth, t.width, t.height)),
this._signal('scrollbarVisibilityChanged'),
p && (s = this.$getLongestLine())
return (
(this.layerConfig = {
width: s,
padding: this.$padding,
firstRow: m,
firstRowScreen: y,
lastRow: g,
lineHeight: w,
characterWidth: this.characterWidth,
minHeight: f,
maxHeight: i,
offset: d,
gutterOffset: w ? Math.max(0, Math.ceil((d + t.height - t.scrollerHeight) / w)) : 0,
height: this.$size.scrollerHeight,
}),
this.session.$bidiHandler &&
this.session.$bidiHandler.setContentWidth(s - this.$padding),
S
)
}),
(this.$updateLines = function () {
if (!this.$changedLines) return
var e = this.$changedLines.firstRow,
t = this.$changedLines.lastRow
this.$changedLines = null
var n = this.layerConfig
if (e > n.lastRow + 1) return
if (t < n.firstRow) return
if (t === Infinity) {
this.$showGutter && this.$gutterLayer.update(n), this.$textLayer.update(n)
return
}
return this.$textLayer.updateLines(n, e, t), !0
}),
(this.$getLongestLine = function () {
var e = this.session.getScreenWidth()
return (
this.showInvisibles && !this.session.$useWrapMode && (e += 1),
this.$textLayer &&
e > this.$textLayer.MAX_LINE_LENGTH &&
(e = this.$textLayer.MAX_LINE_LENGTH + 30),
Math.max(
this.$size.scrollerWidth - 2 * this.$padding,
Math.round(e * this.characterWidth)
)
)
}),
(this.updateFrontMarkers = function () {
this.$markerFront.setMarkers(this.session.getMarkers(!0)),
this.$loop.schedule(this.CHANGE_MARKER_FRONT)
}),
(this.updateBackMarkers = function () {
this.$markerBack.setMarkers(this.session.getMarkers()),
this.$loop.schedule(this.CHANGE_MARKER_BACK)
}),
(this.addGutterDecoration = function (e, t) {
this.$gutterLayer.addGutterDecoration(e, t)
}),
(this.removeGutterDecoration = function (e, t) {
this.$gutterLayer.removeGutterDecoration(e, t)
}),
(this.updateBreakpoints = function (e) {
this.$loop.schedule(this.CHANGE_GUTTER)
}),
(this.setAnnotations = function (e) {
this.$gutterLayer.setAnnotations(e), this.$loop.schedule(this.CHANGE_GUTTER)
}),
(this.updateCursor = function () {
this.$loop.schedule(this.CHANGE_CURSOR)
}),
(this.hideCursor = function () {
this.$cursorLayer.hideCursor()
}),
(this.showCursor = function () {
this.$cursorLayer.showCursor()
}),
(this.scrollSelectionIntoView = function (e, t, n) {
this.scrollCursorIntoView(e, n), this.scrollCursorIntoView(t, n)
}),
(this.scrollCursorIntoView = function (e, t, n) {
if (this.$size.scrollerHeight === 0) return
var r = this.$cursorLayer.getPixelPosition(e),
i = r.left,
s = r.top,
o = (n && n.top) || 0,
u = (n && n.bottom) || 0,
a = this.$scrollAnimation ? this.session.getScrollTop() : this.scrollTop
a + o > s
? (t && a + o > s + this.lineHeight && (s -= t * this.$size.scrollerHeight),
s === 0 && (s = -this.scrollMargin.top),
this.session.setScrollTop(s))
: a + this.$size.scrollerHeight - u < s + this.lineHeight &&
(t &&
a + this.$size.scrollerHeight - u < s - this.lineHeight &&
(s += t * this.$size.scrollerHeight),
this.session.setScrollTop(s + this.lineHeight + u - this.$size.scrollerHeight))
var f = this.scrollLeft
f > i
? (i < this.$padding + 2 * this.layerConfig.characterWidth &&
(i = -this.scrollMargin.left),
this.session.setScrollLeft(i))
: f + this.$size.scrollerWidth < i + this.characterWidth
? this.session.setScrollLeft(
Math.round(i + this.characterWidth - this.$size.scrollerWidth)
)
: f <= this.$padding && i - f < this.characterWidth && this.session.setScrollLeft(0)
}),
(this.getScrollTop = function () {
return this.session.getScrollTop()
}),
(this.getScrollLeft = function () {
return this.session.getScrollLeft()
}),
(this.getScrollTopRow = function () {
return this.scrollTop / this.lineHeight
}),
(this.getScrollBottomRow = function () {
return Math.max(
0,
Math.floor((this.scrollTop + this.$size.scrollerHeight) / this.lineHeight) - 1
)
}),
(this.scrollToRow = function (e) {
this.session.setScrollTop(e * this.lineHeight)
}),
(this.alignCursor = function (e, t) {
typeof e == 'number' && (e = { row: e, column: 0 })
var n = this.$cursorLayer.getPixelPosition(e),
r = this.$size.scrollerHeight - this.lineHeight,
i = n.top - r * (t || 0)
return this.session.setScrollTop(i), i
}),
(this.STEPS = 8),
(this.$calcSteps = function (e, t) {
var n = 0,
r = this.STEPS,
i = [],
s = function (e, t, n) {
return n * (Math.pow(e - 1, 3) + 1) + t
}
for (n = 0; n < r; ++n) i.push(s(n / this.STEPS, e, t - e))
return i
}),
(this.scrollToLine = function (e, t, n, r) {
var i = this.$cursorLayer.getPixelPosition({ row: e, column: 0 }),
s = i.top
t && (s -= this.$size.scrollerHeight / 2)
var o = this.scrollTop
this.session.setScrollTop(s), n !== !1 && this.animateScrolling(o, r)
}),
(this.animateScrolling = function (e, t) {
var n = this.scrollTop
if (!this.$animatedScroll) return
var r = this
if (e == n) return
if (this.$scrollAnimation) {
var i = this.$scrollAnimation.steps
if (i.length) {
e = i[0]
if (e == n) return
}
}
var s = r.$calcSteps(e, n)
;(this.$scrollAnimation = { from: e, to: n, steps: s }),
clearInterval(this.$timer),
r.session.setScrollTop(s.shift()),
(r.session.$scrollTop = n),
(this.$timer = setInterval(function () {
if (!r.session) return clearInterval(r.$timer)
s.length
? (r.session.setScrollTop(s.shift()), (r.session.$scrollTop = n))
: n != null
? ((r.session.$scrollTop = -1), r.session.setScrollTop(n), (n = null))
: ((r.$timer = clearInterval(r.$timer)), (r.$scrollAnimation = null), t && t())
}, 10))
}),
(this.scrollToY = function (e) {
this.scrollTop !== e && (this.$loop.schedule(this.CHANGE_SCROLL), (this.scrollTop = e))
}),
(this.scrollToX = function (e) {
this.scrollLeft !== e && (this.scrollLeft = e),
this.$loop.schedule(this.CHANGE_H_SCROLL)
}),
(this.scrollTo = function (e, t) {
this.session.setScrollTop(t), this.session.setScrollLeft(t)
}),
(this.scrollBy = function (e, t) {
t && this.session.setScrollTop(this.session.getScrollTop() + t),
e && this.session.setScrollLeft(this.session.getScrollLeft() + e)
}),
(this.isScrollableBy = function (e, t) {
if (t < 0 && this.session.getScrollTop() >= 1 - this.scrollMargin.top) return !0
if (
t > 0 &&
this.session.getScrollTop() + this.$size.scrollerHeight - this.layerConfig.maxHeight <
-1 + this.scrollMargin.bottom
)
return !0
if (e < 0 && this.session.getScrollLeft() >= 1 - this.scrollMargin.left) return !0
if (
e > 0 &&
this.session.getScrollLeft() + this.$size.scrollerWidth - this.layerConfig.width <
-1 + this.scrollMargin.right
)
return !0
}),
(this.pixelToScreenCoordinates = function (e, t) {
var n
if (this.$hasCssTransforms) {
n = { top: 0, left: 0 }
var r = this.$fontMetrics.transformCoordinates([e, t])
;(e = r[1] - this.gutterWidth - this.margin.left), (t = r[0])
} else n = this.scroller.getBoundingClientRect()
var i = e + this.scrollLeft - n.left - this.$padding,
s = i / this.characterWidth,
o = Math.floor((t + this.scrollTop - n.top) / this.lineHeight),
u = this.$blockCursor ? Math.floor(s) : Math.round(s)
return { row: o, column: u, side: s - u > 0 ? 1 : -1, offsetX: i }
}),
(this.screenToTextCoordinates = function (e, t) {
var n
if (this.$hasCssTransforms) {
n = { top: 0, left: 0 }
var r = this.$fontMetrics.transformCoordinates([e, t])
;(e = r[1] - this.gutterWidth - this.margin.left), (t = r[0])
} else n = this.scroller.getBoundingClientRect()
var i = e + this.scrollLeft - n.left - this.$padding,
s = i / this.characterWidth,
o = this.$blockCursor ? Math.floor(s) : Math.round(s),
u = Math.floor((t + this.scrollTop - n.top) / this.lineHeight)
return this.session.screenToDocumentPosition(u, Math.max(o, 0), i)
}),
(this.textToScreenCoordinates = function (e, t) {
var n = this.scroller.getBoundingClientRect(),
r = this.session.documentToScreenPosition(e, t),
i =
this.$padding +
(this.session.$bidiHandler.isBidiRow(r.row, e)
? this.session.$bidiHandler.getPosLeft(r.column)
: Math.round(r.column * this.characterWidth)),
s = r.row * this.lineHeight
return { pageX: n.left + i - this.scrollLeft, pageY: n.top + s - this.scrollTop }
}),
(this.visualizeFocus = function () {
i.addCssClass(this.container, 'ace_focus')
}),
(this.visualizeBlur = function () {
i.removeCssClass(this.container, 'ace_focus')
}),
(this.showComposition = function (e) {
;(this.$composition = e),
e.cssText || (e.cssText = this.textarea.style.cssText),
e.useTextareaForIME == undefined && (e.useTextareaForIME = this.$useTextareaForIME),
this.$useTextareaForIME
? (i.addCssClass(this.textarea, 'ace_composition'),
(this.textarea.style.cssText = ''),
this.$moveTextAreaToCursor(),
(this.$cursorLayer.element.style.display = 'none'))
: (e.markerId = this.session.addMarker(
e.markerRange,
'ace_composition_marker',
'text'
))
}),
(this.setCompositionText = function (e) {
var t = this.session.selection.cursor
this.addToken(e, 'composition_placeholder', t.row, t.column),
this.$moveTextAreaToCursor()
}),
(this.hideComposition = function () {
if (!this.$composition) return
this.$composition.markerId && this.session.removeMarker(this.$composition.markerId),
i.removeCssClass(this.textarea, 'ace_composition'),
(this.textarea.style.cssText = this.$composition.cssText)
var e = this.session.selection.cursor
this.removeExtraToken(e.row, e.column),
(this.$composition = null),
(this.$cursorLayer.element.style.display = '')
}),
(this.addToken = function (e, t, n, r) {
var i = this.session
i.bgTokenizer.lines[n] = null
var s = { type: t, value: e },
o = i.getTokens(n)
if (r == null) o.push(s)
else {
var u = 0
for (var a = 0; a < o.length; a++) {
var f = o[a]
u += f.value.length
if (r <= u) {
var l = f.value.length - (u - r),
c = f.value.slice(0, l),
h = f.value.slice(l)
o.splice(a, 1, { type: f.type, value: c }, s, { type: f.type, value: h })
break
}
}
}
this.updateLines(n, n)
}),
(this.removeExtraToken = function (e, t) {
this.updateLines(e, e)
}),
(this.setTheme = function (e, t) {
function o(r) {
if (n.$themeId != e) return t && t()
if (!r || !r.cssClass)
throw new Error("couldn't load module " + e + " or it didn't call define")
r.$id && (n.$themeId = r.$id),
i.importCssString(r.cssText, r.cssClass, n.container),
n.theme && i.removeCssClass(n.container, n.theme.cssClass)
var s = 'padding' in r ? r.padding : 'padding' in (n.theme || {}) ? 4 : n.$padding
n.$padding && s != n.$padding && n.setPadding(s),
(n.$theme = r.cssClass),
(n.theme = r),
i.addCssClass(n.container, r.cssClass),
i.setCssClass(n.container, 'ace_dark', r.isDark),
n.$size && ((n.$size.width = 0), n.$updateSizeAsync()),
n._dispatchEvent('themeLoaded', { theme: r }),
t && t()
}
var n = this
;(this.$themeId = e), n._dispatchEvent('themeChange', { theme: e })
if (!e || typeof e == 'string') {
var r = e || this.$options.theme.initialValue
s.loadModule(['theme', r], o)
} else o(e)
}),
(this.getTheme = function () {
return this.$themeId
}),
(this.setStyle = function (e, t) {
i.setCssClass(this.container, e, t !== !1)
}),
(this.unsetStyle = function (e) {
i.removeCssClass(this.container, e)
}),
(this.setCursorStyle = function (e) {
i.setStyle(this.scroller.style, 'cursor', e)
}),
(this.setMouseCursor = function (e) {
i.setStyle(this.scroller.style, 'cursor', e)
}),
(this.attachToShadowRoot = function () {
i.importCssString(v, 'ace_editor.css', this.container)
}),
(this.destroy = function () {
this.freeze(),
this.$fontMetrics.destroy(),
this.$cursorLayer.destroy(),
this.removeAllListeners(),
(this.container.textContent = '')
})
}).call(y.prototype),
s.defineOptions(y.prototype, 'renderer', {
animatedScroll: { initialValue: !1 },
showInvisibles: {
set: function (e) {
this.$textLayer.setShowInvisibles(e) && this.$loop.schedule(this.CHANGE_TEXT)
},
initialValue: !1,
},
showPrintMargin: {
set: function () {
this.$updatePrintMargin()
},
initialValue: !0,
},
printMarginColumn: {
set: function () {
this.$updatePrintMargin()
},
initialValue: 80,
},
printMargin: {
set: function (e) {
typeof e == 'number' && (this.$printMarginColumn = e),
(this.$showPrintMargin = !!e),
this.$updatePrintMargin()
},
get: function () {
return this.$showPrintMargin && this.$printMarginColumn
},
},
showGutter: {
set: function (e) {
;(this.$gutter.style.display = e ? 'block' : 'none'),
this.$loop.schedule(this.CHANGE_FULL),
this.onGutterResize()
},
initialValue: !0,
},
fadeFoldWidgets: {
set: function (e) {
i.setCssClass(this.$gutter, 'ace_fade-fold-widgets', e)
},
initialValue: !1,
},
showFoldWidgets: {
set: function (e) {
this.$gutterLayer.setShowFoldWidgets(e), this.$loop.schedule(this.CHANGE_GUTTER)
},
initialValue: !0,
},
displayIndentGuides: {
set: function (e) {
this.$textLayer.setDisplayIndentGuides(e) && this.$loop.schedule(this.CHANGE_TEXT)
},
initialValue: !0,
},
highlightGutterLine: {
set: function (e) {
this.$gutterLayer.setHighlightGutterLine(e), this.$loop.schedule(this.CHANGE_GUTTER)
},
initialValue: !0,
},
hScrollBarAlwaysVisible: {
set: function (e) {
;(!this.$hScrollBarAlwaysVisible || !this.$horizScroll) &&
this.$loop.schedule(this.CHANGE_SCROLL)
},
initialValue: !1,
},
vScrollBarAlwaysVisible: {
set: function (e) {
;(!this.$vScrollBarAlwaysVisible || !this.$vScroll) &&
this.$loop.schedule(this.CHANGE_SCROLL)
},
initialValue: !1,
},
fontSize: {
set: function (e) {
typeof e == 'number' && (e += 'px'),
(this.container.style.fontSize = e),
this.updateFontSize()
},
initialValue: 12,
},
fontFamily: {
set: function (e) {
;(this.container.style.fontFamily = e), this.updateFontSize()
},
},
maxLines: {
set: function (e) {
this.updateFull()
},
},
minLines: {
set: function (e) {
this.$minLines < 562949953421311 || (this.$minLines = 0), this.updateFull()
},
},
maxPixelHeight: {
set: function (e) {
this.updateFull()
},
initialValue: 0,
},
scrollPastEnd: {
set: function (e) {
e = +e || 0
if (this.$scrollPastEnd == e) return
;(this.$scrollPastEnd = e), this.$loop.schedule(this.CHANGE_SCROLL)
},
initialValue: 0,
handlesSet: !0,
},
fixedWidthGutter: {
set: function (e) {
;(this.$gutterLayer.$fixedWidth = !!e), this.$loop.schedule(this.CHANGE_GUTTER)
},
},
theme: {
set: function (e) {
this.setTheme(e)
},
get: function () {
return this.$themeId || this.theme
},
initialValue: './theme/textmate',
handlesSet: !0,
},
hasCssTransforms: {},
useTextareaForIME: { initialValue: !m.isMobile && !m.isIE },
}),
(t.VirtualRenderer = y)
}
),
ace.define(
'ace/worker/worker_client',
[
'require',
'exports',
'module',
'ace/lib/oop',
'ace/lib/net',
'ace/lib/event_emitter',
'ace/config',
],
function (e, t, n) {
'use strict'
function u(e) {
var t = "importScripts('" + i.qualifyURL(e) + "');"
try {
return new Blob([t], { type: 'application/javascript' })
} catch (n) {
var r = window.BlobBuilder || window.WebKitBlobBuilder || window.MozBlobBuilder,
s = new r()
return s.append(t), s.getBlob('application/javascript')
}
}
function a(e) {
if (typeof Worker == 'undefined')
return { postMessage: function () {}, terminate: function () {} }
if (o.get('loadWorkerFromBlob')) {
var t = u(e),
n = window.URL || window.webkitURL,
r = n.createObjectURL(t)
return new Worker(r)
}
return new Worker(e)
}
var r = e('../lib/oop'),
i = e('../lib/net'),
s = e('../lib/event_emitter').EventEmitter,
o = e('../config'),
f = function (e) {
e.postMessage || (e = this.$createWorkerFromOldConfig.apply(this, arguments)),
(this.$worker = e),
(this.$sendDeltaQueue = this.$sendDeltaQueue.bind(this)),
(this.changeListener = this.changeListener.bind(this)),
(this.onMessage = this.onMessage.bind(this)),
(this.callbackId = 1),
(this.callbacks = {}),
(this.$worker.onmessage = this.onMessage)
}
;(function () {
r.implement(this, s),
(this.$createWorkerFromOldConfig = function (t, n, r, i, s) {
e.nameToUrl && !e.toUrl && (e.toUrl = e.nameToUrl)
if (o.get('packaged') || !e.toUrl) i = i || o.moduleUrl(n, 'worker')
else {
var u = this.$normalizePath
i = i || u(e.toUrl('ace/worker/worker.js', null, '_'))
var f = {}
t.forEach(function (t) {
f[t] = u(e.toUrl(t, null, '_').replace(/(\.js)?(\?.*)?$/, ''))
})
}
return (
(this.$worker = a(i)),
s && this.send('importScripts', s),
this.$worker.postMessage({ init: !0, tlns: f, module: n, classname: r }),
this.$worker
)
}),
(this.onMessage = function (e) {
var t = e.data
switch (t.type) {
case 'event':
this._signal(t.name, { data: t.data })
break
case 'call':
var n = this.callbacks[t.id]
n && (n(t.data), delete this.callbacks[t.id])
break
case 'error':
this.reportError(t.data)
break
case 'log':
window.console && console.log && console.log.apply(console, t.data)
}
}),
(this.reportError = function (e) {
window.console && console.error && console.error(e)
}),
(this.$normalizePath = function (e) {
return i.qualifyURL(e)
}),
(this.terminate = function () {
this._signal('terminate', {}),
(this.deltaQueue = null),
this.$worker.terminate(),
(this.$worker = null),
this.$doc && this.$doc.off('change', this.changeListener),
(this.$doc = null)
}),
(this.send = function (e, t) {
this.$worker.postMessage({ command: e, args: t })
}),
(this.call = function (e, t, n) {
if (n) {
var r = this.callbackId++
;(this.callbacks[r] = n), t.push(r)
}
this.send(e, t)
}),
(this.emit = function (e, t) {
try {
t.data &&
t.data.err &&
(t.data.err = {
message: t.data.err.message,
stack: t.data.err.stack,
code: t.data.err.code,
}),
this.$worker.postMessage({ event: e, data: { data: t.data } })
} catch (n) {
console.error(n.stack)
}
}),
(this.attachToDocument = function (e) {
this.$doc && this.terminate(),
(this.$doc = e),
this.call('setValue', [e.getValue()]),
e.on('change', this.changeListener)
}),
(this.changeListener = function (e) {
this.deltaQueue || ((this.deltaQueue = []), setTimeout(this.$sendDeltaQueue, 0)),
e.action == 'insert'
? this.deltaQueue.push(e.start, e.lines)
: this.deltaQueue.push(e.start, e.end)
}),
(this.$sendDeltaQueue = function () {
var e = this.deltaQueue
if (!e) return
;(this.deltaQueue = null),
e.length > 50 && e.length > this.$doc.getLength() >> 1
? this.call('setValue', [this.$doc.getValue()])
: this.emit('change', { data: e })
})
}).call(f.prototype)
var l = function (e, t, n) {
var r = null,
i = !1,
u = Object.create(s),
a = [],
l = new f({
messageBuffer: a,
terminate: function () {},
postMessage: function (e) {
a.push(e)
if (!r) return
i ? setTimeout(c) : c()
},
})
l.setEmitSync = function (e) {
i = e
}
var c = function () {
var e = a.shift()
e.command ? r[e.command].apply(r, e.args) : e.event && u._signal(e.event, e.data)
}
return (
(u.postMessage = function (e) {
l.onMessage({ data: e })
}),
(u.callback = function (e, t) {
this.postMessage({ type: 'call', id: t, data: e })
}),
(u.emit = function (e, t) {
this.postMessage({ type: 'event', name: e, data: t })
}),
o.loadModule(['worker', t], function (e) {
r = new e[n](u)
while (a.length) c()
}),
l
)
}
;(t.UIWorkerClient = l), (t.WorkerClient = f), (t.createWorker = a)
}
),
ace.define(
'ace/placeholder',
['require', 'exports', 'module', 'ace/range', 'ace/lib/event_emitter', 'ace/lib/oop'],
function (e, t, n) {
'use strict'
var r = e('./range').Range,
i = e('./lib/event_emitter').EventEmitter,
s = e('./lib/oop'),
o = function (e, t, n, r, i, s) {
var o = this
;(this.length = t),
(this.session = e),
(this.doc = e.getDocument()),
(this.mainClass = i),
(this.othersClass = s),
(this.$onUpdate = this.onUpdate.bind(this)),
this.doc.on('change', this.$onUpdate),
(this.$others = r),
(this.$onCursorChange = function () {
setTimeout(function () {
o.onCursorChange()
})
}),
(this.$pos = n)
var u = e.getUndoManager().$undoStack || e.getUndoManager().$undostack || { length: -1 }
;(this.$undoStackDepth = u.length),
this.setup(),
e.selection.on('changeCursor', this.$onCursorChange)
}
;(function () {
s.implement(this, i),
(this.setup = function () {
var e = this,
t = this.doc,
n = this.session
;(this.selectionBefore = n.selection.toJSON()),
n.selection.inMultiSelectMode && n.selection.toSingleRange(),
(this.pos = t.createAnchor(this.$pos.row, this.$pos.column))
var i = this.pos
;(i.$insertRight = !0),
i.detach(),
(i.markerId = n.addMarker(
new r(i.row, i.column, i.row, i.column + this.length),
this.mainClass,
null,
!1
)),
(this.others = []),
this.$others.forEach(function (n) {
var r = t.createAnchor(n.row, n.column)
;(r.$insertRight = !0), r.detach(), e.others.push(r)
}),
n.setUndoSelect(!1)
}),
(this.showOtherMarkers = function () {
if (this.othersActive) return
var e = this.session,
t = this
;(this.othersActive = !0),
this.others.forEach(function (n) {
n.markerId = e.addMarker(
new r(n.row, n.column, n.row, n.column + t.length),
t.othersClass,
null,
!1
)
})
}),
(this.hideOtherMarkers = function () {
if (!this.othersActive) return
this.othersActive = !1
for (var e = 0; e < this.others.length; e++)
this.session.removeMarker(this.others[e].markerId)
}),
(this.onUpdate = function (e) {
if (this.$updating) return this.updateAnchors(e)
var t = e
if (t.start.row !== t.end.row) return
if (t.start.row !== this.pos.row) return
this.$updating = !0
var n =
e.action === 'insert'
? t.end.column - t.start.column
: t.start.column - t.end.column,
i =
t.start.column >= this.pos.column &&
t.start.column <= this.pos.column + this.length + 1,
s = t.start.column - this.pos.column
this.updateAnchors(e), i && (this.length += n)
if (i && !this.session.$fromUndo)
if (e.action === 'insert')
for (var o = this.others.length - 1; o >= 0; o--) {
var u = this.others[o],
a = { row: u.row, column: u.column + s }
this.doc.insertMergedLines(a, e.lines)
}
else if (e.action === 'remove')
for (var o = this.others.length - 1; o >= 0; o--) {
var u = this.others[o],
a = { row: u.row, column: u.column + s }
this.doc.remove(new r(a.row, a.column, a.row, a.column - n))
}
;(this.$updating = !1), this.updateMarkers()
}),
(this.updateAnchors = function (e) {
this.pos.onChange(e)
for (var t = this.others.length; t--; ) this.others[t].onChange(e)
this.updateMarkers()
}),
(this.updateMarkers = function () {
if (this.$updating) return
var e = this,
t = this.session,
n = function (n, i) {
t.removeMarker(n.markerId),
(n.markerId = t.addMarker(
new r(n.row, n.column, n.row, n.column + e.length),
i,
null,
!1
))
}
n(this.pos, this.mainClass)
for (var i = this.others.length; i--; ) n(this.others[i], this.othersClass)
}),
(this.onCursorChange = function (e) {
if (this.$updating || !this.session) return
var t = this.session.selection.getCursor()
t.row === this.pos.row &&
t.column >= this.pos.column &&
t.column <= this.pos.column + this.length
? (this.showOtherMarkers(), this._emit('cursorEnter', e))
: (this.hideOtherMarkers(), this._emit('cursorLeave', e))
}),
(this.detach = function () {
this.session.removeMarker(this.pos && this.pos.markerId),
this.hideOtherMarkers(),
this.doc.off('change', this.$onUpdate),
this.session.selection.off('changeCursor', this.$onCursorChange),
this.session.setUndoSelect(!0),
(this.session = null)
}),
(this.cancel = function () {
if (this.$undoStackDepth === -1) return
var e = this.session.getUndoManager(),
t = (e.$undoStack || e.$undostack).length - this.$undoStackDepth
for (var n = 0; n < t; n++) e.undo(this.session, !0)
this.selectionBefore && this.session.selection.fromJSON(this.selectionBefore)
})
}).call(o.prototype),
(t.PlaceHolder = o)
}
),
ace.define(
'ace/mouse/multi_select_handler',
['require', 'exports', 'module', 'ace/lib/event', 'ace/lib/useragent'],
function (e, t, n) {
function s(e, t) {
return e.row == t.row && e.column == t.column
}
function o(e) {
var t = e.domEvent,
n = t.altKey,
o = t.shiftKey,
u = t.ctrlKey,
a = e.getAccelKey(),
f = e.getButton()
u && i.isMac && (f = t.button)
if (e.editor.inMultiSelectMode && f == 2) {
e.editor.textInput.onContextMenu(e.domEvent)
return
}
if (!u && !n && !a) {
f === 0 && e.editor.inMultiSelectMode && e.editor.exitMultiSelectMode()
return
}
if (f !== 0) return
var l = e.editor,
c = l.selection,
h = l.inMultiSelectMode,
p = e.getDocumentPosition(),
d = c.getCursor(),
v = e.inSelection() || (c.isEmpty() && s(p, d)),
m = e.x,
g = e.y,
y = function (e) {
;(m = e.clientX), (g = e.clientY)
},
b = l.session,
w = l.renderer.pixelToScreenCoordinates(m, g),
E = w,
S
if (l.$mouseHandler.$enableJumpToDef)
(u && n) || (a && n)
? (S = o ? 'block' : 'add')
: n && l.$blockSelectEnabled && (S = 'block')
else if (a && !n) {
S = 'add'
if (!h && o) return
} else n && l.$blockSelectEnabled && (S = 'block')
S && i.isMac && t.ctrlKey && l.$mouseHandler.cancelContextMenu()
if (S == 'add') {
if (!h && v) return
if (!h) {
var x = c.toOrientedRange()
l.addSelectionMarker(x)
}
var T = c.rangeList.rangeAtPoint(p)
;(l.inVirtualSelectionMode = !0),
o && ((T = null), (x = c.ranges[0] || x), l.removeSelectionMarker(x)),
l.once('mouseup', function () {
var e = c.toOrientedRange()
T && e.isEmpty() && s(T.cursor, e.cursor)
? c.substractPoint(e.cursor)
: (o
? c.substractPoint(x.cursor)
: x && (l.removeSelectionMarker(x), c.addRange(x)),
c.addRange(e)),
(l.inVirtualSelectionMode = !1)
})
} else if (S == 'block') {
e.stop(), (l.inVirtualSelectionMode = !0)
var N,
C = [],
k = function () {
var e = l.renderer.pixelToScreenCoordinates(m, g),
t = b.screenToDocumentPosition(e.row, e.column, e.offsetX)
if (s(E, e) && s(t, c.lead)) return
;(E = e),
l.selection.moveToPosition(t),
l.renderer.scrollCursorIntoView(),
l.removeSelectionMarkers(C),
(C = c.rectangularRangeBlock(E, w)),
l.$mouseHandler.$clickSelection &&
C.length == 1 &&
C[0].isEmpty() &&
(C[0] = l.$mouseHandler.$clickSelection.clone()),
C.forEach(l.addSelectionMarker, l),
l.updateSelectionMarkers()
}
h && !a
? c.toSingleRange()
: !h && a && ((N = c.toOrientedRange()), l.addSelectionMarker(N)),
o ? (w = b.documentToScreenPosition(c.lead)) : c.moveToPosition(p),
(E = { row: -1, column: -1 })
var L = function (e) {
k(),
clearInterval(O),
l.removeSelectionMarkers(C),
C.length || (C = [c.toOrientedRange()]),
N && (l.removeSelectionMarker(N), c.toSingleRange(N))
for (var t = 0; t < C.length; t++) c.addRange(C[t])
;(l.inVirtualSelectionMode = !1), (l.$mouseHandler.$clickSelection = null)
},
A = k
r.capture(l.container, y, L)
var O = setInterval(function () {
A()
}, 20)
return e.preventDefault()
}
}
var r = e('../lib/event'),
i = e('../lib/useragent')
t.onMouseDown = o
}
),
ace.define(
'ace/commands/multi_select_commands',
['require', 'exports', 'module', 'ace/keyboard/hash_handler'],
function (e, t, n) {
;(t.defaultCommands = [
{
name: 'addCursorAbove',
description: 'Add cursor above',
exec: function (e) {
e.selectMoreLines(-1)
},
bindKey: { win: 'Ctrl-Alt-Up', mac: 'Ctrl-Alt-Up' },
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'addCursorBelow',
description: 'Add cursor below',
exec: function (e) {
e.selectMoreLines(1)
},
bindKey: { win: 'Ctrl-Alt-Down', mac: 'Ctrl-Alt-Down' },
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'addCursorAboveSkipCurrent',
description: 'Add cursor above (skip current)',
exec: function (e) {
e.selectMoreLines(-1, !0)
},
bindKey: { win: 'Ctrl-Alt-Shift-Up', mac: 'Ctrl-Alt-Shift-Up' },
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'addCursorBelowSkipCurrent',
description: 'Add cursor below (skip current)',
exec: function (e) {
e.selectMoreLines(1, !0)
},
bindKey: { win: 'Ctrl-Alt-Shift-Down', mac: 'Ctrl-Alt-Shift-Down' },
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectMoreBefore',
description: 'Select more before',
exec: function (e) {
e.selectMore(-1)
},
bindKey: { win: 'Ctrl-Alt-Left', mac: 'Ctrl-Alt-Left' },
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectMoreAfter',
description: 'Select more after',
exec: function (e) {
e.selectMore(1)
},
bindKey: { win: 'Ctrl-Alt-Right', mac: 'Ctrl-Alt-Right' },
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectNextBefore',
description: 'Select next before',
exec: function (e) {
e.selectMore(-1, !0)
},
bindKey: { win: 'Ctrl-Alt-Shift-Left', mac: 'Ctrl-Alt-Shift-Left' },
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'selectNextAfter',
description: 'Select next after',
exec: function (e) {
e.selectMore(1, !0)
},
bindKey: { win: 'Ctrl-Alt-Shift-Right', mac: 'Ctrl-Alt-Shift-Right' },
scrollIntoView: 'cursor',
readOnly: !0,
},
{
name: 'toggleSplitSelectionIntoLines',
description: 'Split into lines',
exec: function (e) {
e.multiSelect.rangeCount > 1
? e.multiSelect.joinSelections()
: e.multiSelect.splitIntoLines()
},
bindKey: { win: 'Ctrl-Alt-L', mac: 'Ctrl-Alt-L' },
readOnly: !0,
},
{
name: 'splitSelectionIntoLines',
description: 'Split into lines',
exec: function (e) {
e.multiSelect.splitIntoLines()
},
readOnly: !0,
},
{
name: 'alignCursors',
description: 'Align cursors',
exec: function (e) {
e.alignCursors()
},
bindKey: { win: 'Ctrl-Alt-A', mac: 'Ctrl-Alt-A' },
scrollIntoView: 'cursor',
},
{
name: 'findAll',
description: 'Find all',
exec: function (e) {
e.findAll()
},
bindKey: { win: 'Ctrl-Alt-K', mac: 'Ctrl-Alt-G' },
scrollIntoView: 'cursor',
readOnly: !0,
},
]),
(t.multiSelectCommands = [
{
name: 'singleSelection',
description: 'Single selection',
bindKey: 'esc',
exec: function (e) {
e.exitMultiSelectMode()
},
scrollIntoView: 'cursor',
readOnly: !0,
isAvailable: function (e) {
return e && e.inMultiSelectMode
},
},
])
var r = e('../keyboard/hash_handler').HashHandler
t.keyboardHandler = new r(t.multiSelectCommands)
}
),
ace.define(
'ace/multi_select',
[
'require',
'exports',
'module',
'ace/range_list',
'ace/range',
'ace/selection',
'ace/mouse/multi_select_handler',
'ace/lib/event',
'ace/lib/lang',
'ace/commands/multi_select_commands',
'ace/search',
'ace/edit_session',
'ace/editor',
'ace/config',
],
function (e, t, n) {
function h(e, t, n) {
return (
(c.$options.wrap = !0),
(c.$options.needle = t),
(c.$options.backwards = n == -1),
c.find(e)
)
}
function v(e, t) {
return e.row == t.row && e.column == t.column
}
function m(e) {
if (e.$multiselectOnSessionChange) return
;(e.$onAddRange = e.$onAddRange.bind(e)),
(e.$onRemoveRange = e.$onRemoveRange.bind(e)),
(e.$onMultiSelect = e.$onMultiSelect.bind(e)),
(e.$onSingleSelect = e.$onSingleSelect.bind(e)),
(e.$multiselectOnSessionChange = t.onSessionChange.bind(e)),
(e.$checkMultiselectChange = e.$checkMultiselectChange.bind(e)),
e.$multiselectOnSessionChange(e),
e.on('changeSession', e.$multiselectOnSessionChange),
e.on('mousedown', o),
e.commands.addCommands(f.defaultCommands),
g(e)
}
function g(e) {
function r(t) {
n && (e.renderer.setMouseCursor(''), (n = !1))
}
if (!e.textInput) return
var t = e.textInput.getElement(),
n = !1
u.addListener(
t,
'keydown',
function (t) {
var i = t.keyCode == 18 && !(t.ctrlKey || t.shiftKey || t.metaKey)
e.$blockSelectEnabled && i
? n || (e.renderer.setMouseCursor('crosshair'), (n = !0))
: n && r()
},
e
),
u.addListener(t, 'keyup', r, e),
u.addListener(t, 'blur', r, e)
}
var r = e('./range_list').RangeList,
i = e('./range').Range,
s = e('./selection').Selection,
o = e('./mouse/multi_select_handler').onMouseDown,
u = e('./lib/event'),
a = e('./lib/lang'),
f = e('./commands/multi_select_commands')
t.commands = f.defaultCommands.concat(f.multiSelectCommands)
var l = e('./search').Search,
c = new l(),
p = e('./edit_session').EditSession
;(function () {
this.getSelectionMarkers = function () {
return this.$selectionMarkers
}
}).call(p.prototype),
function () {
;(this.ranges = null),
(this.rangeList = null),
(this.addRange = function (e, t) {
if (!e) return
if (!this.inMultiSelectMode && this.rangeCount === 0) {
var n = this.toOrientedRange()
this.rangeList.add(n), this.rangeList.add(e)
if (this.rangeList.ranges.length != 2)
return this.rangeList.removeAll(), t || this.fromOrientedRange(e)
this.rangeList.removeAll(), this.rangeList.add(n), this.$onAddRange(n)
}
e.cursor || (e.cursor = e.end)
var r = this.rangeList.add(e)
return (
this.$onAddRange(e),
r.length && this.$onRemoveRange(r),
this.rangeCount > 1 &&
!this.inMultiSelectMode &&
(this._signal('multiSelect'),
(this.inMultiSelectMode = !0),
(this.session.$undoSelect = !1),
this.rangeList.attach(this.session)),
t || this.fromOrientedRange(e)
)
}),
(this.toSingleRange = function (e) {
e = e || this.ranges[0]
var t = this.rangeList.removeAll()
t.length && this.$onRemoveRange(t), e && this.fromOrientedRange(e)
}),
(this.substractPoint = function (e) {
var t = this.rangeList.substractPoint(e)
if (t) return this.$onRemoveRange(t), t[0]
}),
(this.mergeOverlappingRanges = function () {
var e = this.rangeList.merge()
e.length && this.$onRemoveRange(e)
}),
(this.$onAddRange = function (e) {
;(this.rangeCount = this.rangeList.ranges.length),
this.ranges.unshift(e),
this._signal('addRange', { range: e })
}),
(this.$onRemoveRange = function (e) {
this.rangeCount = this.rangeList.ranges.length
if (this.rangeCount == 1 && this.inMultiSelectMode) {
var t = this.rangeList.ranges.pop()
e.push(t), (this.rangeCount = 0)
}
for (var n = e.length; n--; ) {
var r = this.ranges.indexOf(e[n])
this.ranges.splice(r, 1)
}
this._signal('removeRange', { ranges: e }),
this.rangeCount === 0 &&
this.inMultiSelectMode &&
((this.inMultiSelectMode = !1),
this._signal('singleSelect'),
(this.session.$undoSelect = !0),
this.rangeList.detach(this.session)),
(t = t || this.ranges[0]),
t && !t.isEqual(this.getRange()) && this.fromOrientedRange(t)
}),
(this.$initRangeList = function () {
if (this.rangeList) return
;(this.rangeList = new r()), (this.ranges = []), (this.rangeCount = 0)
}),
(this.getAllRanges = function () {
return this.rangeCount ? this.rangeList.ranges.concat() : [this.getRange()]
}),
(this.splitIntoLines = function () {
var e = this.ranges.length ? this.ranges : [this.getRange()],
t = []
for (var n = 0; n < e.length; n++) {
var r = e[n],
s = r.start.row,
o = r.end.row
if (s === o) t.push(r.clone())
else {
t.push(new i(s, r.start.column, s, this.session.getLine(s).length))
while (++s < o) t.push(this.getLineRange(s, !0))
t.push(new i(o, 0, o, r.end.column))
}
n == 0 && !this.isBackwards() && (t = t.reverse())
}
this.toSingleRange()
for (var n = t.length; n--; ) this.addRange(t[n])
}),
(this.joinSelections = function () {
var e = this.rangeList.ranges,
t = e[e.length - 1],
n = i.fromPoints(e[0].start, t.end)
this.toSingleRange(), this.setSelectionRange(n, t.cursor == t.start)
}),
(this.toggleBlockSelection = function () {
if (this.rangeCount > 1) {
var e = this.rangeList.ranges,
t = e[e.length - 1],
n = i.fromPoints(e[0].start, t.end)
this.toSingleRange(), this.setSelectionRange(n, t.cursor == t.start)
} else {
var r = this.session.documentToScreenPosition(this.cursor),
s = this.session.documentToScreenPosition(this.anchor),
o = this.rectangularRangeBlock(r, s)
o.forEach(this.addRange, this)
}
}),
(this.rectangularRangeBlock = function (e, t, n) {
var r = [],
s = e.column < t.column
if (s)
var o = e.column,
u = t.column,
a = e.offsetX,
f = t.offsetX
else
var o = t.column,
u = e.column,
a = t.offsetX,
f = e.offsetX
var l = e.row < t.row
if (l)
var c = e.row,
h = t.row
else
var c = t.row,
h = e.row
o < 0 && (o = 0), c < 0 && (c = 0), c == h && (n = !0)
var p
for (var d = c; d <= h; d++) {
var m = i.fromPoints(
this.session.screenToDocumentPosition(d, o, a),
this.session.screenToDocumentPosition(d, u, f)
)
if (m.isEmpty()) {
if (p && v(m.end, p)) break
p = m.end
}
;(m.cursor = s ? m.start : m.end), r.push(m)
}
l && r.reverse()
if (!n) {
var g = r.length - 1
while (r[g].isEmpty() && g > 0) g--
if (g > 0) {
var y = 0
while (r[y].isEmpty()) y++
}
for (var b = g; b >= y; b--) r[b].isEmpty() && r.splice(b, 1)
}
return r
})
}.call(s.prototype)
var d = e('./editor').Editor
;(function () {
;(this.updateSelectionMarkers = function () {
this.renderer.updateCursor(), this.renderer.updateBackMarkers()
}),
(this.addSelectionMarker = function (e) {
e.cursor || (e.cursor = e.end)
var t = this.getSelectionStyle()
return (
(e.marker = this.session.addMarker(e, 'ace_selection', t)),
this.session.$selectionMarkers.push(e),
(this.session.selectionMarkerCount = this.session.$selectionMarkers.length),
e
)
}),
(this.removeSelectionMarker = function (e) {
if (!e.marker) return
this.session.removeMarker(e.marker)
var t = this.session.$selectionMarkers.indexOf(e)
t != -1 && this.session.$selectionMarkers.splice(t, 1),
(this.session.selectionMarkerCount = this.session.$selectionMarkers.length)
}),
(this.removeSelectionMarkers = function (e) {
var t = this.session.$selectionMarkers
for (var n = e.length; n--; ) {
var r = e[n]
if (!r.marker) continue
this.session.removeMarker(r.marker)
var i = t.indexOf(r)
i != -1 && t.splice(i, 1)
}
this.session.selectionMarkerCount = t.length
}),
(this.$onAddRange = function (e) {
this.addSelectionMarker(e.range),
this.renderer.updateCursor(),
this.renderer.updateBackMarkers()
}),
(this.$onRemoveRange = function (e) {
this.removeSelectionMarkers(e.ranges),
this.renderer.updateCursor(),
this.renderer.updateBackMarkers()
}),
(this.$onMultiSelect = function (e) {
if (this.inMultiSelectMode) return
;(this.inMultiSelectMode = !0),
this.setStyle('ace_multiselect'),
this.keyBinding.addKeyboardHandler(f.keyboardHandler),
this.commands.setDefaultHandler('exec', this.$onMultiSelectExec),
this.renderer.updateCursor(),
this.renderer.updateBackMarkers()
}),
(this.$onSingleSelect = function (e) {
if (this.session.multiSelect.inVirtualMode) return
;(this.inMultiSelectMode = !1),
this.unsetStyle('ace_multiselect'),
this.keyBinding.removeKeyboardHandler(f.keyboardHandler),
this.commands.removeDefaultHandler('exec', this.$onMultiSelectExec),
this.renderer.updateCursor(),
this.renderer.updateBackMarkers(),
this._emit('changeSelection')
}),
(this.$onMultiSelectExec = function (e) {
var t = e.command,
n = e.editor
if (!n.multiSelect) return
if (!t.multiSelectAction) {
var r = t.exec(n, e.args || {})
n.multiSelect.addRange(n.multiSelect.toOrientedRange()),
n.multiSelect.mergeOverlappingRanges()
} else
t.multiSelectAction == 'forEach'
? (r = n.forEachSelection(t, e.args))
: t.multiSelectAction == 'forEachLine'
? (r = n.forEachSelection(t, e.args, !0))
: t.multiSelectAction == 'single'
? (n.exitMultiSelectMode(), (r = t.exec(n, e.args || {})))
: (r = t.multiSelectAction(n, e.args || {}))
return r
}),
(this.forEachSelection = function (e, t, n) {
if (this.inVirtualSelectionMode) return
var r = n && n.keepOrder,
i = n == 1 || (n && n.$byLines),
o = this.session,
u = this.selection,
a = u.rangeList,
f = (r ? u : a).ranges,
l
if (!f.length) return e.exec ? e.exec(this, t || {}) : e(this, t || {})
var c = u._eventRegistry
u._eventRegistry = {}
var h = new s(o)
this.inVirtualSelectionMode = !0
for (var p = f.length; p--; ) {
if (i) while (p > 0 && f[p].start.row == f[p - 1].end.row) p--
h.fromOrientedRange(f[p]), (h.index = p), (this.selection = o.selection = h)
var d = e.exec ? e.exec(this, t || {}) : e(this, t || {})
!l && d !== undefined && (l = d), h.toOrientedRange(f[p])
}
h.detach(),
(this.selection = o.selection = u),
(this.inVirtualSelectionMode = !1),
(u._eventRegistry = c),
u.mergeOverlappingRanges(),
u.ranges[0] && u.fromOrientedRange(u.ranges[0])
var v = this.renderer.$scrollAnimation
return (
this.onCursorChange(),
this.onSelectionChange(),
v && v.from == v.to && this.renderer.animateScrolling(v.from),
l
)
}),
(this.exitMultiSelectMode = function () {
if (!this.inMultiSelectMode || this.inVirtualSelectionMode) return
this.multiSelect.toSingleRange()
}),
(this.getSelectedText = function () {
var e = ''
if (this.inMultiSelectMode && !this.inVirtualSelectionMode) {
var t = this.multiSelect.rangeList.ranges,
n = []
for (var r = 0; r < t.length; r++) n.push(this.session.getTextRange(t[r]))
var i = this.session.getDocument().getNewLineCharacter()
;(e = n.join(i)), e.length == (n.length - 1) * i.length && (e = '')
} else
this.selection.isEmpty() || (e = this.session.getTextRange(this.getSelectionRange()))
return e
}),
(this.$checkMultiselectChange = function (e, t) {
if (this.inMultiSelectMode && !this.inVirtualSelectionMode) {
var n = this.multiSelect.ranges[0]
if (this.multiSelect.isEmpty() && t == this.multiSelect.anchor) return
var r =
t == this.multiSelect.anchor ? (n.cursor == n.start ? n.end : n.start) : n.cursor
r.row != t.row ||
this.session.$clipPositionToDocument(r.row, r.column).column != t.column
? this.multiSelect.toSingleRange(this.multiSelect.toOrientedRange())
: this.multiSelect.mergeOverlappingRanges()
}
}),
(this.findAll = function (e, t, n) {
;(t = t || {}), (t.needle = e || t.needle)
if (t.needle == undefined) {
var r = this.selection.isEmpty()
? this.selection.getWordRange()
: this.selection.getRange()
t.needle = this.session.getTextRange(r)
}
this.$search.set(t)
var i = this.$search.findAll(this.session)
if (!i.length) return 0
var s = this.multiSelect
n || s.toSingleRange(i[0])
for (var o = i.length; o--; ) s.addRange(i[o], !0)
return r && s.rangeList.rangeAtPoint(r.start) && s.addRange(r, !0), i.length
}),
(this.selectMoreLines = function (e, t) {
var n = this.selection.toOrientedRange(),
r = n.cursor == n.end,
s = this.session.documentToScreenPosition(n.cursor)
this.selection.$desiredColumn && (s.column = this.selection.$desiredColumn)
var o = this.session.screenToDocumentPosition(s.row + e, s.column)
if (!n.isEmpty())
var u = this.session.documentToScreenPosition(r ? n.end : n.start),
a = this.session.screenToDocumentPosition(u.row + e, u.column)
else var a = o
if (r) {
var f = i.fromPoints(o, a)
f.cursor = f.start
} else {
var f = i.fromPoints(a, o)
f.cursor = f.end
}
f.desiredColumn = s.column
if (!this.selection.inMultiSelectMode) this.selection.addRange(n)
else if (t) var l = n.cursor
this.selection.addRange(f), l && this.selection.substractPoint(l)
}),
(this.transposeSelections = function (e) {
var t = this.session,
n = t.multiSelect,
r = n.ranges
for (var i = r.length; i--; ) {
var s = r[i]
if (s.isEmpty()) {
var o = t.getWordRange(s.start.row, s.start.column)
;(s.start.row = o.start.row),
(s.start.column = o.start.column),
(s.end.row = o.end.row),
(s.end.column = o.end.column)
}
}
n.mergeOverlappingRanges()
var u = []
for (var i = r.length; i--; ) {
var s = r[i]
u.unshift(t.getTextRange(s))
}
e < 0 ? u.unshift(u.pop()) : u.push(u.shift())
for (var i = r.length; i--; ) {
var s = r[i],
o = s.clone()
t.replace(s, u[i]), (s.start.row = o.start.row), (s.start.column = o.start.column)
}
n.fromOrientedRange(n.ranges[0])
}),
(this.selectMore = function (e, t, n) {
var r = this.session,
i = r.multiSelect,
s = i.toOrientedRange()
if (s.isEmpty()) {
;(s = r.getWordRange(s.start.row, s.start.column)),
(s.cursor = e == -1 ? s.start : s.end),
this.multiSelect.addRange(s)
if (n) return
}
var o = r.getTextRange(s),
u = h(r, o, e)
u &&
((u.cursor = e == -1 ? u.start : u.end),
this.session.unfold(u),
this.multiSelect.addRange(u),
this.renderer.scrollCursorIntoView(null, 0.5)),
t && this.multiSelect.substractPoint(s.cursor)
}),
(this.alignCursors = function () {
var e = this.session,
t = e.multiSelect,
n = t.ranges,
r = -1,
s = n.filter(function (e) {
if (e.cursor.row == r) return !0
r = e.cursor.row
})
if (!n.length || s.length == n.length - 1) {
var o = this.selection.getRange(),
u = o.start.row,
f = o.end.row,
l = u == f
if (l) {
var c = this.session.getLength(),
h
do h = this.session.getLine(f)
while (/[=:]/.test(h) && ++f < c)
do h = this.session.getLine(u)
while (/[=:]/.test(h) && --u > 0)
u < 0 && (u = 0), f >= c && (f = c - 1)
}
var p = this.session.removeFullLines(u, f)
;(p = this.$reAlignText(p, l)),
this.session.insert({ row: u, column: 0 }, p.join('\n') + '\n'),
l || ((o.start.column = 0), (o.end.column = p[p.length - 1].length)),
this.selection.setRange(o)
} else {
s.forEach(function (e) {
t.substractPoint(e.cursor)
})
var d = 0,
v = Infinity,
m = n.map(function (t) {
var n = t.cursor,
r = e.getLine(n.row),
i = r.substr(n.column).search(/\S/g)
return i == -1 && (i = 0), n.column > d && (d = n.column), i < v && (v = i), i
})
n.forEach(function (t, n) {
var r = t.cursor,
s = d - r.column,
o = m[n] - v
s > o
? e.insert(r, a.stringRepeat(' ', s - o))
: e.remove(new i(r.row, r.column, r.row, r.column - s + o)),
(t.start.column = t.end.column = d),
(t.start.row = t.end.row = r.row),
(t.cursor = t.end)
}),
t.fromOrientedRange(n[0]),
this.renderer.updateCursor(),
this.renderer.updateBackMarkers()
}
}),
(this.$reAlignText = function (e, t) {
function u(e) {
return a.stringRepeat(' ', e)
}
function f(e) {
return e[2]
? u(i) + e[2] + u(s - e[2].length + o) + e[4].replace(/^([=:])\s+/, '$1 ')
: e[0]
}
function l(e) {
return e[2]
? u(i + s - e[2].length) + e[2] + u(o) + e[4].replace(/^([=:])\s+/, '$1 ')
: e[0]
}
function c(e) {
return e[2] ? u(i) + e[2] + u(o) + e[4].replace(/^([=:])\s+/, '$1 ') : e[0]
}
var n = !0,
r = !0,
i,
s,
o
return e
.map(function (e) {
var t = e.match(/(\s*)(.*?)(\s*)([=:].*)/)
return t
? i == null
? ((i = t[1].length), (s = t[2].length), (o = t[3].length), t)
: (i + s + o != t[1].length + t[2].length + t[3].length && (r = !1),
i != t[1].length && (n = !1),
i > t[1].length && (i = t[1].length),
s < t[2].length && (s = t[2].length),
o > t[3].length && (o = t[3].length),
t)
: [e]
})
.map(t ? f : n ? (r ? l : f) : c)
})
}).call(d.prototype),
(t.onSessionChange = function (e) {
var t = e.session
t &&
!t.multiSelect &&
((t.$selectionMarkers = []),
t.selection.$initRangeList(),
(t.multiSelect = t.selection)),
(this.multiSelect = t && t.multiSelect)
var n = e.oldSession
n &&
(n.multiSelect.off('addRange', this.$onAddRange),
n.multiSelect.off('removeRange', this.$onRemoveRange),
n.multiSelect.off('multiSelect', this.$onMultiSelect),
n.multiSelect.off('singleSelect', this.$onSingleSelect),
n.multiSelect.lead.off('change', this.$checkMultiselectChange),
n.multiSelect.anchor.off('change', this.$checkMultiselectChange)),
t &&
(t.multiSelect.on('addRange', this.$onAddRange),
t.multiSelect.on('removeRange', this.$onRemoveRange),
t.multiSelect.on('multiSelect', this.$onMultiSelect),
t.multiSelect.on('singleSelect', this.$onSingleSelect),
t.multiSelect.lead.on('change', this.$checkMultiselectChange),
t.multiSelect.anchor.on('change', this.$checkMultiselectChange)),
t &&
this.inMultiSelectMode != t.selection.inMultiSelectMode &&
(t.selection.inMultiSelectMode ? this.$onMultiSelect() : this.$onSingleSelect())
}),
(t.MultiSelect = m),
e('./config').defineOptions(d.prototype, 'editor', {
enableMultiselect: {
set: function (e) {
m(this),
e
? (this.on('changeSession', this.$multiselectOnSessionChange),
this.on('mousedown', o))
: (this.off('changeSession', this.$multiselectOnSessionChange),
this.off('mousedown', o))
},
value: !0,
},
enableBlockSelect: {
set: function (e) {
this.$blockSelectEnabled = e
},
value: !0,
},
})
}
),
ace.define(
'ace/mode/folding/fold_mode',
['require', 'exports', 'module', 'ace/range'],
function (e, t, n) {
'use strict'
var r = e('../../range').Range,
i = (t.FoldMode = function () {})
;(function () {
;(this.foldingStartMarker = null),
(this.foldingStopMarker = null),
(this.getFoldWidget = function (e, t, n) {
var r = e.getLine(n)
return this.foldingStartMarker.test(r)
? 'start'
: t == 'markbeginend' && this.foldingStopMarker && this.foldingStopMarker.test(r)
? 'end'
: ''
}),
(this.getFoldWidgetRange = function (e, t, n) {
return null
}),
(this.indentationBlock = function (e, t, n) {
var i = /\S/,
s = e.getLine(t),
o = s.search(i)
if (o == -1) return
var u = n || s.length,
a = e.getLength(),
f = t,
l = t
while (++t < a) {
var c = e.getLine(t).search(i)
if (c == -1) continue
if (c <= o) {
var h = e.getTokenAt(t, 0)
if (!h || h.type !== 'string') break
}
l = t
}
if (l > f) {
var p = e.getLine(l).length
return new r(f, u, l, p)
}
}),
(this.openingBracketBlock = function (e, t, n, i, s) {
var o = { row: n, column: i + 1 },
u = e.$findClosingBracket(t, o, s)
if (!u) return
var a = e.foldWidgets[u.row]
return (
a == null && (a = e.getFoldWidget(u.row)),
a == 'start' && u.row > o.row && (u.row--, (u.column = e.getLine(u.row).length)),
r.fromPoints(o, u)
)
}),
(this.closingBracketBlock = function (e, t, n, i, s) {
var o = { row: n, column: i },
u = e.$findOpeningBracket(t, o)
if (!u) return
return u.column++, o.column--, r.fromPoints(u, o)
})
}).call(i.prototype)
}
),
ace.define(
'ace/theme/textmate',
['require', 'exports', 'module', 'ace/lib/dom'],
function (e, t, n) {
'use strict'
;(t.isDark = !1),
(t.cssClass = 'ace-tm'),
(t.cssText =
'.ace-tm .ace_gutter {background: #f0f0f0;color: #333;}.ace-tm .ace_print-margin {width: 1px;background: #e8e8e8;}.ace-tm .ace_fold {background-color: #6B72E6;}.ace-tm {background-color: #FFFFFF;color: black;}.ace-tm .ace_cursor {color: black;}.ace-tm .ace_invisible {color: rgb(191, 191, 191);}.ace-tm .ace_storage,.ace-tm .ace_keyword {color: blue;}.ace-tm .ace_constant {color: rgb(197, 6, 11);}.ace-tm .ace_constant.ace_buildin {color: rgb(88, 72, 246);}.ace-tm .ace_constant.ace_language {color: rgb(88, 92, 246);}.ace-tm .ace_constant.ace_library {color: rgb(6, 150, 14);}.ace-tm .ace_invalid {background-color: rgba(255, 0, 0, 0.1);color: red;}.ace-tm .ace_support.ace_function {color: rgb(60, 76, 114);}.ace-tm .ace_support.ace_constant {color: rgb(6, 150, 14);}.ace-tm .ace_support.ace_type,.ace-tm .ace_support.ace_class {color: rgb(109, 121, 222);}.ace-tm .ace_keyword.ace_operator {color: rgb(104, 118, 135);}.ace-tm .ace_string {color: rgb(3, 106, 7);}.ace-tm .ace_comment {color: rgb(76, 136, 107);}.ace-tm .ace_comment.ace_doc {color: rgb(0, 102, 255);}.ace-tm .ace_comment.ace_doc.ace_tag {color: rgb(128, 159, 191);}.ace-tm .ace_constant.ace_numeric {color: rgb(0, 0, 205);}.ace-tm .ace_variable {color: rgb(49, 132, 149);}.ace-tm .ace_xml-pe {color: rgb(104, 104, 91);}.ace-tm .ace_entity.ace_name.ace_function {color: #0000A2;}.ace-tm .ace_heading {color: rgb(12, 7, 255);}.ace-tm .ace_list {color:rgb(185, 6, 144);}.ace-tm .ace_meta.ace_tag {color:rgb(0, 22, 142);}.ace-tm .ace_string.ace_regex {color: rgb(255, 0, 0)}.ace-tm .ace_marker-layer .ace_selection {background: rgb(181, 213, 255);}.ace-tm.ace_multiselect .ace_selection.ace_start {box-shadow: 0 0 3px 0px white;}.ace-tm .ace_marker-layer .ace_step {background: rgb(252, 255, 0);}.ace-tm .ace_marker-layer .ace_stack {background: rgb(164, 229, 101);}.ace-tm .ace_marker-layer .ace_bracket {margin: -1px 0 0 -1px;border: 1px solid rgb(192, 192, 192);}.ace-tm .ace_marker-layer .ace_active-line {background: rgba(0, 0, 0, 0.07);}.ace-tm .ace_gutter-active-line {background-color : #dcdcdc;}.ace-tm .ace_marker-layer .ace_selected-word {background: rgb(250, 250, 255);border: 1px solid rgb(200, 200, 250);}.ace-tm .ace_indent-guide {background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAACCAYAAACZgbYnAAAAE0lEQVQImWP4////f4bLly//BwAmVgd1/w11/gAAAABJRU5ErkJggg==") right repeat-y;}'),
(t.$id = 'ace/theme/textmate')
var r = e('../lib/dom')
r.importCssString(t.cssText, t.cssClass)
}
),
ace.define(
'ace/line_widgets',
['require', 'exports', 'module', 'ace/lib/dom'],
function (e, t, n) {
'use strict'
function i(e) {
;(this.session = e),
(this.session.widgetManager = this),
(this.session.getRowLength = this.getRowLength),
(this.session.$getWidgetScreenLength = this.$getWidgetScreenLength),
(this.updateOnChange = this.updateOnChange.bind(this)),
(this.renderWidgets = this.renderWidgets.bind(this)),
(this.measureWidgets = this.measureWidgets.bind(this)),
(this.session._changedWidgets = []),
(this.$onChangeEditor = this.$onChangeEditor.bind(this)),
this.session.on('change', this.updateOnChange),
this.session.on('changeFold', this.updateOnFold),
this.session.on('changeEditor', this.$onChangeEditor)
}
var r = e('./lib/dom')
;(function () {
;(this.getRowLength = function (e) {
var t
return (
this.lineWidgets
? (t = (this.lineWidgets[e] && this.lineWidgets[e].rowCount) || 0)
: (t = 0),
!this.$useWrapMode || !this.$wrapData[e] ? 1 + t : this.$wrapData[e].length + 1 + t
)
}),
(this.$getWidgetScreenLength = function () {
var e = 0
return (
this.lineWidgets.forEach(function (t) {
t && t.rowCount && !t.hidden && (e += t.rowCount)
}),
e
)
}),
(this.$onChangeEditor = function (e) {
this.attach(e.editor)
}),
(this.attach = function (e) {
e && e.widgetManager && e.widgetManager != this && e.widgetManager.detach()
if (this.editor == e) return
this.detach(),
(this.editor = e),
e &&
((e.widgetManager = this),
e.renderer.on('beforeRender', this.measureWidgets),
e.renderer.on('afterRender', this.renderWidgets))
}),
(this.detach = function (e) {
var t = this.editor
if (!t) return
;(this.editor = null),
(t.widgetManager = null),
t.renderer.off('beforeRender', this.measureWidgets),
t.renderer.off('afterRender', this.renderWidgets)
var n = this.session.lineWidgets
n &&
n.forEach(function (e) {
e &&
e.el &&
e.el.parentNode &&
((e._inDocument = !1), e.el.parentNode.removeChild(e.el))
})
}),
(this.updateOnFold = function (e, t) {
var n = t.lineWidgets
if (!n || !e.action) return
var r = e.data,
i = r.start.row,
s = r.end.row,
o = e.action == 'add'
for (var u = i + 1; u < s; u++) n[u] && (n[u].hidden = o)
n[s] &&
(o
? n[i]
? (n[s].hidden = o)
: (n[i] = n[s])
: (n[i] == n[s] && (n[i] = undefined), (n[s].hidden = o)))
}),
(this.updateOnChange = function (e) {
var t = this.session.lineWidgets
if (!t) return
var n = e.start.row,
r = e.end.row - n
if (r !== 0)
if (e.action == 'remove') {
var i = t.splice(n + 1, r)
!t[n] && i[i.length - 1] && (t[n] = i.pop()),
i.forEach(function (e) {
e && this.removeLineWidget(e)
}, this),
this.$updateRows()
} else {
var s = new Array(r)
t[n] && t[n].column != null && e.start.column > t[n].column && n++,
s.unshift(n, 0),
t.splice.apply(t, s),
this.$updateRows()
}
}),
(this.$updateRows = function () {
var e = this.session.lineWidgets
if (!e) return
var t = !0
e.forEach(function (e, n) {
if (e) {
;(t = !1), (e.row = n)
while (e.$oldWidget) (e.$oldWidget.row = n), (e = e.$oldWidget)
}
}),
t && (this.session.lineWidgets = null)
}),
(this.$registerLineWidget = function (e) {
this.session.lineWidgets ||
(this.session.lineWidgets = new Array(this.session.getLength()))
var t = this.session.lineWidgets[e.row]
return (
t &&
((e.$oldWidget = t),
t.el &&
t.el.parentNode &&
(t.el.parentNode.removeChild(t.el), (t._inDocument = !1))),
(this.session.lineWidgets[e.row] = e),
e
)
}),
(this.addLineWidget = function (e) {
this.$registerLineWidget(e), (e.session = this.session)
if (!this.editor) return e
var t = this.editor.renderer
e.html && !e.el && ((e.el = r.createElement('div')), (e.el.innerHTML = e.html)),
e.el &&
(r.addCssClass(e.el, 'ace_lineWidgetContainer'),
(e.el.style.position = 'absolute'),
(e.el.style.zIndex = 5),
t.container.appendChild(e.el),
(e._inDocument = !0),
e.coverGutter || (e.el.style.zIndex = 3),
e.pixelHeight == null && (e.pixelHeight = e.el.offsetHeight)),
e.rowCount == null && (e.rowCount = e.pixelHeight / t.layerConfig.lineHeight)
var n = this.session.getFoldAt(e.row, 0)
e.$fold = n
if (n) {
var i = this.session.lineWidgets
e.row == n.end.row && !i[n.start.row] ? (i[n.start.row] = e) : (e.hidden = !0)
}
return (
this.session._emit('changeFold', { data: { start: { row: e.row } } }),
this.$updateRows(),
this.renderWidgets(null, t),
this.onWidgetChanged(e),
e
)
}),
(this.removeLineWidget = function (e) {
;(e._inDocument = !1),
(e.session = null),
e.el && e.el.parentNode && e.el.parentNode.removeChild(e.el)
if (e.editor && e.editor.destroy)
try {
e.editor.destroy()
} catch (t) {}
if (this.session.lineWidgets) {
var n = this.session.lineWidgets[e.row]
if (n == e)
(this.session.lineWidgets[e.row] = e.$oldWidget),
e.$oldWidget && this.onWidgetChanged(e.$oldWidget)
else
while (n) {
if (n.$oldWidget == e) {
n.$oldWidget = e.$oldWidget
break
}
n = n.$oldWidget
}
}
this.session._emit('changeFold', { data: { start: { row: e.row } } }),
this.$updateRows()
}),
(this.getWidgetsAtRow = function (e) {
var t = this.session.lineWidgets,
n = t && t[e],
r = []
while (n) r.push(n), (n = n.$oldWidget)
return r
}),
(this.onWidgetChanged = function (e) {
this.session._changedWidgets.push(e), this.editor && this.editor.renderer.updateFull()
}),
(this.measureWidgets = function (e, t) {
var n = this.session._changedWidgets,
r = t.layerConfig
if (!n || !n.length) return
var i = Infinity
for (var s = 0; s < n.length; s++) {
var o = n[s]
if (!o || !o.el) continue
if (o.session != this.session) continue
if (!o._inDocument) {
if (this.session.lineWidgets[o.row] != o) continue
;(o._inDocument = !0), t.container.appendChild(o.el)
}
;(o.h = o.el.offsetHeight),
o.fixedWidth ||
((o.w = o.el.offsetWidth), (o.screenWidth = Math.ceil(o.w / r.characterWidth)))
var u = o.h / r.lineHeight
o.coverLine && ((u -= this.session.getRowLineCount(o.row)), u < 0 && (u = 0)),
o.rowCount != u && ((o.rowCount = u), o.row < i && (i = o.row))
}
i != Infinity &&
(this.session._emit('changeFold', { data: { start: { row: i } } }),
(this.session.lineWidgetWidth = null)),
(this.session._changedWidgets = [])
}),
(this.renderWidgets = function (e, t) {
var n = t.layerConfig,
r = this.session.lineWidgets
if (!r) return
var i = Math.min(this.firstRow, n.firstRow),
s = Math.max(this.lastRow, n.lastRow, r.length)
while (i > 0 && !r[i]) i--
;(this.firstRow = n.firstRow), (this.lastRow = n.lastRow), (t.$cursorLayer.config = n)
for (var o = i; o <= s; o++) {
var u = r[o]
if (!u || !u.el) continue
if (u.hidden) {
u.el.style.top = -100 - (u.pixelHeight || 0) + 'px'
continue
}
u._inDocument || ((u._inDocument = !0), t.container.appendChild(u.el))
var a = t.$cursorLayer.getPixelPosition({ row: o, column: 0 }, !0).top
u.coverLine || (a += n.lineHeight * this.session.getRowLineCount(u.row)),
(u.el.style.top = a - n.offset + 'px')
var f = u.coverGutter ? 0 : t.gutterWidth
u.fixedWidth || (f -= t.scrollLeft),
(u.el.style.left = f + 'px'),
u.fullWidth &&
u.screenWidth &&
(u.el.style.minWidth = n.width + 2 * n.padding + 'px'),
u.fixedWidth
? (u.el.style.right = t.scrollBar.getWidth() + 'px')
: (u.el.style.right = '')
}
})
}).call(i.prototype),
(t.LineWidgets = i)
}
),
ace.define(
'ace/ext/error_marker',
['require', 'exports', 'module', 'ace/line_widgets', 'ace/lib/dom', 'ace/range'],
function (e, t, n) {
'use strict'
function o(e, t, n) {
var r = 0,
i = e.length - 1
while (r <= i) {
var s = (r + i) >> 1,
o = n(t, e[s])
if (o > 0) r = s + 1
else {
if (!(o < 0)) return s
i = s - 1
}
}
return -(r + 1)
}
function u(e, t, n) {
var r = e.getAnnotations().sort(s.comparePoints)
if (!r.length) return
var i = o(r, { row: t, column: -1 }, s.comparePoints)
i < 0 && (i = -i - 1),
i >= r.length ? (i = n > 0 ? 0 : r.length - 1) : i === 0 && n < 0 && (i = r.length - 1)
var u = r[i]
if (!u || !n) return
if (u.row === t) {
do u = r[(i += n)]
while (u && u.row === t)
if (!u) return r.slice()
}
var a = []
t = u.row
do a[n < 0 ? 'unshift' : 'push'](u), (u = r[(i += n)])
while (u && u.row == t)
return a.length && a
}
var r = e('../line_widgets').LineWidgets,
i = e('../lib/dom'),
s = e('../range').Range
;(t.showErrorMarker = function (e, t) {
var n = e.session
n.widgetManager || ((n.widgetManager = new r(n)), n.widgetManager.attach(e))
var s = e.getCursorPosition(),
o = s.row,
a = n.widgetManager.getWidgetsAtRow(o).filter(function (e) {
return e.type == 'errorMarker'
})[0]
a ? a.destroy() : (o -= t)
var f = u(n, o, t),
l
if (f) {
var c = f[0]
;(s.column = (c.pos && typeof c.column != 'number' ? c.pos.sc : c.column) || 0),
(s.row = c.row),
(l = e.renderer.$gutterLayer.$annotations[s.row])
} else {
if (a) return
l = { text: ['Looks good!'], className: 'ace_ok' }
}
e.session.unfold(s.row), e.selection.moveToPosition(s)
var h = {
row: s.row,
fixedWidth: !0,
coverGutter: !0,
el: i.createElement('div'),
type: 'errorMarker',
},
p = h.el.appendChild(i.createElement('div')),
d = h.el.appendChild(i.createElement('div'))
d.className = 'error_widget_arrow ' + l.className
var v = e.renderer.$cursorLayer.getPixelPosition(s).left
;(d.style.left = v + e.renderer.gutterWidth - 5 + 'px'),
(h.el.className = 'error_widget_wrapper'),
(p.className = 'error_widget ' + l.className),
(p.innerHTML = l.text.join('
')),
p.appendChild(i.createElement('div'))
var m = function (e, t, n) {
if (t === 0 && (n === 'esc' || n === 'return')) return h.destroy(), { command: 'null' }
}
;(h.destroy = function () {
if (e.$mouseHandler.isMousePressed) return
e.keyBinding.removeKeyboardHandler(m),
n.widgetManager.removeLineWidget(h),
e.off('changeSelection', h.destroy),
e.off('changeSession', h.destroy),
e.off('mouseup', h.destroy),
e.off('change', h.destroy)
}),
e.keyBinding.addKeyboardHandler(m),
e.on('changeSelection', h.destroy),
e.on('changeSession', h.destroy),
e.on('mouseup', h.destroy),
e.on('change', h.destroy),
e.session.widgetManager.addLineWidget(h),
(h.el.onmousedown = e.focus.bind(e)),
e.renderer.scrollCursorIntoView(null, 0.5, { bottom: h.el.offsetHeight })
}),
i.importCssString(
' .error_widget_wrapper { background: inherit; color: inherit; border:none } .error_widget { border-top: solid 2px; border-bottom: solid 2px; margin: 5px 0; padding: 10px 40px; white-space: pre-wrap; } .error_widget.ace_error, .error_widget_arrow.ace_error{ border-color: #ff5a5a } .error_widget.ace_warning, .error_widget_arrow.ace_warning{ border-color: #F1D817 } .error_widget.ace_info, .error_widget_arrow.ace_info{ border-color: #5a5a5a } .error_widget.ace_ok, .error_widget_arrow.ace_ok{ border-color: #5aaa5a } .error_widget_arrow { position: absolute; border: solid 5px; border-top-color: transparent!important; border-right-color: transparent!important; border-left-color: transparent!important; top: -5px; }',
''
)
}
),
ace.define(
'ace/ace',
[
'require',
'exports',
'module',
'ace/lib/fixoldbrowsers',
'ace/lib/dom',
'ace/lib/event',
'ace/range',
'ace/editor',
'ace/edit_session',
'ace/undomanager',
'ace/virtual_renderer',
'ace/worker/worker_client',
'ace/keyboard/hash_handler',
'ace/placeholder',
'ace/multi_select',
'ace/mode/folding/fold_mode',
'ace/theme/textmate',
'ace/ext/error_marker',
'ace/config',
],
function (e, t, n) {
'use strict'
e('./lib/fixoldbrowsers')
var r = e('./lib/dom'),
i = e('./lib/event'),
s = e('./range').Range,
o = e('./editor').Editor,
u = e('./edit_session').EditSession,
a = e('./undomanager').UndoManager,
f = e('./virtual_renderer').VirtualRenderer
e('./worker/worker_client'),
e('./keyboard/hash_handler'),
e('./placeholder'),
e('./multi_select'),
e('./mode/folding/fold_mode'),
e('./theme/textmate'),
e('./ext/error_marker'),
(t.config = e('./config')),
(t.require = e),
typeof define == 'function' && (t.define = define),
(t.edit = function (e, n) {
if (typeof e == 'string') {
var s = e
e = document.getElementById(s)
if (!e) throw new Error("ace.edit can't find div #" + s)
}
if (e && e.env && e.env.editor instanceof o) return e.env.editor
var u = ''
if (e && /input|textarea/i.test(e.tagName)) {
var a = e
;(u = a.value), (e = r.createElement('pre')), a.parentNode.replaceChild(e, a)
} else e && ((u = e.textContent), (e.innerHTML = ''))
var l = t.createEditSession(u),
c = new o(new f(e), l, n),
h = { document: l, editor: c, onResize: c.resize.bind(c, null) }
return (
a && (h.textarea = a),
i.addListener(window, 'resize', h.onResize),
c.on('destroy', function () {
i.removeListener(window, 'resize', h.onResize), (h.editor.container.env = null)
}),
(c.container.env = c.env = h),
c
)
}),
(t.createEditSession = function (e, t) {
var n = new u(e, t)
return n.setUndoManager(new a()), n
}),
(t.Range = s),
(t.Editor = o),
(t.EditSession = u),
(t.UndoManager = a),
(t.VirtualRenderer = f),
(t.version = t.config.version)
}
)
;(function () {
ace.require(['ace/ace'], function (a) {
if (a) {
a.config.init(true)
a.define = ace.define
}
if (!window.ace) window.ace = a
for (var key in a) if (a.hasOwnProperty(key)) window.ace[key] = a[key]
window.ace['default'] = window.ace
if (typeof module == 'object' && typeof exports == 'object' && module) {
module.exports = window.ace
}
})
})()