You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
18891 lines
630 KiB
18891 lines
630 KiB
import { __commonJSMin, __toESM, getHot } from "./hot-D67q3Up2.js";
|
|
import { Fragment, computed, createBaseVNode, createBlock, createCommentVNode, createElementBlock, createTextVNode, createVNode, customRef, defineComponent, getCurrentInstance, h, inject, nextTick, normalizeClass, normalizeStyle, onBeforeUnmount, onMounted, openBlock, provide, ref, renderList, renderSlot, resolveComponent, resolveDynamicComponent, toDisplayString, toRefs, toValue, unref, useSlots, useTemplateRef, watch, watchEffect, withAsyncContext, withCtx, withDirectives } from "./runtime-core.esm-bundler-Cyv4obHQ.js";
|
|
import { useRoute, useRouter, vShow } from "./vue-router-BxYGFXy-.js";
|
|
import { guessMode, inspectSourcemaps, isStaticMode, onModuleUpdated, rpc, safeJsonParse, tryOnScopeDispose, usePayloadStore } from "./payload-BX9lTMvN.js";
|
|
import "./_plugin-vue_export-helper-DfavQbjy.js";
|
|
import { Badge_default, Container_default, NavBar_default, PluginName_default, QuerySelector_default } from "./QuerySelector-iLRAQoow.js";
|
|
import { DurationDisplay_default, useOptionsStore } from "./options-D_MMddT_.js";
|
|
import { ModuleId_default, ModuleList_default, kt } from "./ModuleList-ByxGSHde.js";
|
|
const Pe = {
|
|
__name: "splitpanes",
|
|
props: {
|
|
horizontal: {
|
|
type: Boolean,
|
|
default: !1
|
|
},
|
|
pushOtherPanes: {
|
|
type: Boolean,
|
|
default: !0
|
|
},
|
|
maximizePanes: {
|
|
type: Boolean,
|
|
default: !0
|
|
},
|
|
rtl: {
|
|
type: Boolean,
|
|
default: !1
|
|
},
|
|
firstSplitter: {
|
|
type: Boolean,
|
|
default: !1
|
|
}
|
|
},
|
|
emits: [
|
|
"ready",
|
|
"resize",
|
|
"resized",
|
|
"pane-click",
|
|
"pane-maximize",
|
|
"pane-add",
|
|
"pane-remove",
|
|
"splitter-click",
|
|
"splitter-dblclick"
|
|
],
|
|
setup(D, { emit: h$1 }) {
|
|
const y = h$1, u = D, E = useSlots(), l = ref([]), M = computed(() => l.value.reduce((e, n) => (e[~~n.id] = n) && e, {})), m = computed(() => l.value.length), x = ref(null), S = ref(!1), c = ref({
|
|
mouseDown: !1,
|
|
dragging: !1,
|
|
activeSplitter: null,
|
|
cursorOffset: 0
|
|
}), f = ref({
|
|
splitter: null,
|
|
timeoutId: null
|
|
}), _ = computed(() => ({
|
|
[`splitpanes splitpanes--${u.horizontal ? "horizontal" : "vertical"}`]: !0,
|
|
"splitpanes--dragging": c.value.dragging
|
|
})), R = () => {
|
|
document.addEventListener("mousemove", r, { passive: !1 }), document.addEventListener("mouseup", P), "ontouchstart" in window && (document.addEventListener("touchmove", r, { passive: !1 }), document.addEventListener("touchend", P));
|
|
}, O = () => {
|
|
document.removeEventListener("mousemove", r, { passive: !1 }), document.removeEventListener("mouseup", P), "ontouchstart" in window && (document.removeEventListener("touchmove", r, { passive: !1 }), document.removeEventListener("touchend", P));
|
|
}, b = (e, n) => {
|
|
const t = e.target.closest(".splitpanes__splitter");
|
|
if (t) {
|
|
const { left: i, top: a } = t.getBoundingClientRect(), { clientX: s, clientY: o } = "ontouchstart" in window && e.touches ? e.touches[0] : e;
|
|
c.value.cursorOffset = u.horizontal ? o - a : s - i;
|
|
}
|
|
R(), c.value.mouseDown = !0, c.value.activeSplitter = n;
|
|
}, r = (e) => {
|
|
c.value.mouseDown && (e.preventDefault(), c.value.dragging = !0, requestAnimationFrame(() => {
|
|
K(I(e)), d("resize", { event: e }, !0);
|
|
}));
|
|
}, P = (e) => {
|
|
c.value.dragging && (window.getSelection().removeAllRanges(), d("resized", { event: e }, !0)), c.value.mouseDown = !1, c.value.activeSplitter = null, setTimeout(() => {
|
|
c.value.dragging = !1, O();
|
|
}, 100);
|
|
}, A = (e, n) => {
|
|
"ontouchstart" in window && (e.preventDefault(), f.value.splitter === n ? (clearTimeout(f.value.timeoutId), f.value.timeoutId = null, U(e, n), f.value.splitter = null) : (f.value.splitter = n, f.value.timeoutId = setTimeout(() => f.value.splitter = null, 500))), c.value.dragging || d("splitter-click", {
|
|
event: e,
|
|
index: n
|
|
}, !0);
|
|
}, U = (e, n) => {
|
|
if (d("splitter-dblclick", {
|
|
event: e,
|
|
index: n
|
|
}, !0), u.maximizePanes) {
|
|
let t = 0;
|
|
l.value = l.value.map((i, a) => (i.size = a === n ? i.max : i.min, a !== n && (t += i.min), i)), l.value[n].size -= t, d("pane-maximize", {
|
|
event: e,
|
|
index: n,
|
|
pane: l.value[n]
|
|
}), d("resized", {
|
|
event: e,
|
|
index: n
|
|
}, !0);
|
|
}
|
|
}, W = (e, n) => {
|
|
d("pane-click", {
|
|
event: e,
|
|
index: M.value[n].index,
|
|
pane: M.value[n]
|
|
});
|
|
}, I = (e) => {
|
|
const n = x.value.getBoundingClientRect(), { clientX: t, clientY: i } = "ontouchstart" in window && e.touches ? e.touches[0] : e;
|
|
return {
|
|
x: t - (u.horizontal ? 0 : c.value.cursorOffset) - n.left,
|
|
y: i - (u.horizontal ? c.value.cursorOffset : 0) - n.top
|
|
};
|
|
}, J = (e) => {
|
|
e = e[u.horizontal ? "y" : "x"];
|
|
const n = x.value[u.horizontal ? "clientHeight" : "clientWidth"];
|
|
return u.rtl && !u.horizontal && (e = n - e), e * 100 / n;
|
|
}, K = (e) => {
|
|
const n = c.value.activeSplitter;
|
|
let t = {
|
|
prevPanesSize: $(n),
|
|
nextPanesSize: N(n),
|
|
prevReachedMinPanes: 0,
|
|
nextReachedMinPanes: 0
|
|
};
|
|
const i = 0 + (u.pushOtherPanes ? 0 : t.prevPanesSize), a = 100 - (u.pushOtherPanes ? 0 : t.nextPanesSize), s = Math.max(Math.min(J(e), a), i);
|
|
let o = [n, n + 1], v = l.value[o[0]] || null, p = l.value[o[1]] || null;
|
|
const H = v.max < 100 && s >= v.max + t.prevPanesSize, ue = p.max < 100 && s <= 100 - (p.max + N(n + 1));
|
|
if (H || ue) {
|
|
H ? (v.size = v.max, p.size = Math.max(100 - v.max - t.prevPanesSize - t.nextPanesSize, 0)) : (v.size = Math.max(100 - p.max - t.prevPanesSize - N(n + 1), 0), p.size = p.max);
|
|
return;
|
|
}
|
|
if (u.pushOtherPanes) {
|
|
const j = Q(t, s);
|
|
if (!j) return;
|
|
({sums: t, panesToResize: o} = j), v = l.value[o[0]] || null, p = l.value[o[1]] || null;
|
|
}
|
|
v !== null && (v.size = Math.min(Math.max(s - t.prevPanesSize - t.prevReachedMinPanes, v.min), v.max)), p !== null && (p.size = Math.min(Math.max(100 - s - t.nextPanesSize - t.nextReachedMinPanes, p.min), p.max));
|
|
}, Q = (e, n) => {
|
|
const t = c.value.activeSplitter, i = [t, t + 1];
|
|
return n < e.prevPanesSize + l.value[i[0]].min && (i[0] = V(t).index, e.prevReachedMinPanes = 0, i[0] < t && l.value.forEach((a, s) => {
|
|
s > i[0] && s <= t && (a.size = a.min, e.prevReachedMinPanes += a.min);
|
|
}), e.prevPanesSize = $(i[0]), i[0] === void 0) ? (e.prevReachedMinPanes = 0, l.value[0].size = l.value[0].min, l.value.forEach((a, s) => {
|
|
s > 0 && s <= t && (a.size = a.min, e.prevReachedMinPanes += a.min);
|
|
}), l.value[i[1]].size = 100 - e.prevReachedMinPanes - l.value[0].min - e.prevPanesSize - e.nextPanesSize, null) : n > 100 - e.nextPanesSize - l.value[i[1]].min && (i[1] = Z(t).index, e.nextReachedMinPanes = 0, i[1] > t + 1 && l.value.forEach((a, s) => {
|
|
s > t && s < i[1] && (a.size = a.min, e.nextReachedMinPanes += a.min);
|
|
}), e.nextPanesSize = N(i[1] - 1), i[1] === void 0) ? (e.nextReachedMinPanes = 0, l.value.forEach((a, s) => {
|
|
s < m.value - 1 && s >= t + 1 && (a.size = a.min, e.nextReachedMinPanes += a.min);
|
|
}), l.value[i[0]].size = 100 - e.prevPanesSize - N(i[0] - 1), null) : {
|
|
sums: e,
|
|
panesToResize: i
|
|
};
|
|
}, $ = (e) => l.value.reduce((n, t, i) => n + (i < e ? t.size : 0), 0), N = (e) => l.value.reduce((n, t, i) => n + (i > e + 1 ? t.size : 0), 0), V = (e) => [...l.value].reverse().find((t) => t.index < e && t.size > t.min) || {}, Z = (e) => l.value.find((t) => t.index > e + 1 && t.size > t.min) || {}, ee = () => {
|
|
var n;
|
|
const e = Array.from(((n = x.value) == null ? void 0 : n.children) || []);
|
|
for (const t of e) {
|
|
const i = t.classList.contains("splitpanes__pane"), a = t.classList.contains("splitpanes__splitter");
|
|
!i && !a && (t.remove(), console.warn("Splitpanes: Only <pane> elements are allowed at the root of <splitpanes>. One of your DOM nodes was removed."));
|
|
}
|
|
}, F = (e, n, t = !1) => {
|
|
const i = e - 1, a = document.createElement("div");
|
|
a.classList.add("splitpanes__splitter"), t || (a.onmousedown = (s) => b(s, i), typeof window < "u" && "ontouchstart" in window && (a.ontouchstart = (s) => b(s, i)), a.onclick = (s) => A(s, i + 1)), a.ondblclick = (s) => U(s, i + 1), n.parentNode.insertBefore(a, n);
|
|
}, ne = (e) => {
|
|
e.onmousedown = void 0, e.onclick = void 0, e.ondblclick = void 0, e.remove();
|
|
}, C = () => {
|
|
var t;
|
|
const e = Array.from(((t = x.value) == null ? void 0 : t.children) || []);
|
|
for (const i of e) i.className.includes("splitpanes__splitter") && ne(i);
|
|
let n = 0;
|
|
for (const i of e) i.className.includes("splitpanes__pane") && (!n && u.firstSplitter ? F(n, i, !0) : n && F(n, i), n++);
|
|
}, ie = ({ uid: e,...n }) => {
|
|
const t = M.value[e];
|
|
for (const [i, a] of Object.entries(n)) t[i] = a;
|
|
}, te = (e) => {
|
|
var t;
|
|
let n = -1;
|
|
Array.from(((t = x.value) == null ? void 0 : t.children) || []).some((i) => (i.className.includes("splitpanes__pane") && n++, i.isSameNode(e.el))), l.value.splice(n, 0, {
|
|
...e,
|
|
index: n
|
|
}), l.value.forEach((i, a) => i.index = a), S.value && nextTick(() => {
|
|
C(), L({ addedPane: l.value[n] }), d("pane-add", { pane: l.value[n] });
|
|
});
|
|
}, ae = (e) => {
|
|
const n = l.value.findIndex((i) => i.id === e);
|
|
l.value[n].el = null;
|
|
const t = l.value.splice(n, 1)[0];
|
|
l.value.forEach((i, a) => i.index = a), nextTick(() => {
|
|
C(), d("pane-remove", { pane: t }), L({ removedPane: { ...t } });
|
|
});
|
|
}, L = (e = {}) => {
|
|
!e.addedPane && !e.removedPane ? le() : l.value.some((n) => n.givenSize !== null || n.min || n.max < 100) ? oe(e) : se(), S.value && d("resized");
|
|
}, se = () => {
|
|
const e = 100 / m.value;
|
|
let n = 0;
|
|
const t = [], i = [];
|
|
for (const a of l.value) a.size = Math.max(Math.min(e, a.max), a.min), n -= a.size, a.size >= a.max && t.push(a.id), a.size <= a.min && i.push(a.id);
|
|
n > .1 && q(n, t, i);
|
|
}, le = () => {
|
|
let e = 100;
|
|
const n = [], t = [];
|
|
let i = 0;
|
|
for (const s of l.value) e -= s.size, s.givenSize !== null && i++, s.size >= s.max && n.push(s.id), s.size <= s.min && t.push(s.id);
|
|
let a = 100;
|
|
if (e > .1) {
|
|
for (const s of l.value) s.givenSize === null && (s.size = Math.max(Math.min(e / (m.value - i), s.max), s.min)), a -= s.size;
|
|
a > .1 && q(a, n, t);
|
|
}
|
|
}, oe = ({ addedPane: e, removedPane: n } = {}) => {
|
|
let t = 100 / m.value, i = 0;
|
|
const a = [], s = [];
|
|
((e == null ? void 0 : e.givenSize) ?? null) !== null && (t = (100 - e.givenSize) / (m.value - 1));
|
|
for (const o of l.value) i -= o.size, o.size >= o.max && a.push(o.id), o.size <= o.min && s.push(o.id);
|
|
if (!(Math.abs(i) < .1)) {
|
|
for (const o of l.value) (e == null ? void 0 : e.givenSize) !== null && (e == null ? void 0 : e.id) === o.id || (o.size = Math.max(Math.min(t, o.max), o.min)), i -= o.size, o.size >= o.max && a.push(o.id), o.size <= o.min && s.push(o.id);
|
|
i > .1 && q(i, a, s);
|
|
}
|
|
}, q = (e, n, t) => {
|
|
let i;
|
|
e > 0 ? i = e / (m.value - n.length) : i = e / (m.value - t.length), l.value.forEach((a, s) => {
|
|
if (e > 0 && !n.includes(a.id)) {
|
|
const o = Math.max(Math.min(a.size + i, a.max), a.min), v = o - a.size;
|
|
e -= v, a.size = o;
|
|
} else if (!t.includes(a.id)) {
|
|
const o = Math.max(Math.min(a.size + i, a.max), a.min), v = o - a.size;
|
|
e -= v, a.size = o;
|
|
}
|
|
}), Math.abs(e) > .1 && nextTick(() => {
|
|
S.value && console.warn("Splitpanes: Could not resize panes correctly due to their constraints.");
|
|
});
|
|
}, d = (e, n = void 0, t = !1) => {
|
|
const i = (n == null ? void 0 : n.index) ?? c.value.activeSplitter ?? null;
|
|
y(e, {
|
|
...n,
|
|
...i !== null && { index: i },
|
|
...t && i !== null && {
|
|
prevPane: l.value[i - (u.firstSplitter ? 1 : 0)],
|
|
nextPane: l.value[i + (u.firstSplitter ? 0 : 1)]
|
|
},
|
|
panes: l.value.map((a) => ({
|
|
min: a.min,
|
|
max: a.max,
|
|
size: a.size
|
|
}))
|
|
});
|
|
};
|
|
watch(() => u.firstSplitter, () => C()), onMounted(() => {
|
|
ee(), C(), L(), d("ready"), S.value = !0;
|
|
}), onBeforeUnmount(() => S.value = !1);
|
|
const re = () => {
|
|
var e;
|
|
return h("div", {
|
|
ref: x,
|
|
class: _.value
|
|
}, (e = E.default) == null ? void 0 : e.call(E));
|
|
};
|
|
return provide("panes", l), provide("indexedPanes", M), provide("horizontal", computed(() => u.horizontal)), provide("requestUpdate", ie), provide("onPaneAdd", te), provide("onPaneRemove", ae), provide("onPaneClick", W), (e, n) => (openBlock(), createBlock(resolveDynamicComponent(re)));
|
|
}
|
|
}, ge = {
|
|
__name: "pane",
|
|
props: {
|
|
size: { type: [Number, String] },
|
|
minSize: {
|
|
type: [Number, String],
|
|
default: 0
|
|
},
|
|
maxSize: {
|
|
type: [Number, String],
|
|
default: 100
|
|
}
|
|
},
|
|
setup(D) {
|
|
var b;
|
|
const h$1 = D, y = inject("requestUpdate"), u = inject("onPaneAdd"), E = inject("horizontal"), l = inject("onPaneRemove"), M = inject("onPaneClick"), m = (b = getCurrentInstance()) == null ? void 0 : b.uid, x = inject("indexedPanes"), S = computed(() => x.value[m]), c = ref(null), f = computed(() => {
|
|
const r = isNaN(h$1.size) || h$1.size === void 0 ? 0 : parseFloat(h$1.size);
|
|
return Math.max(Math.min(r, R.value), _.value);
|
|
}), _ = computed(() => {
|
|
const r = parseFloat(h$1.minSize);
|
|
return isNaN(r) ? 0 : r;
|
|
}), R = computed(() => {
|
|
const r = parseFloat(h$1.maxSize);
|
|
return isNaN(r) ? 100 : r;
|
|
}), O = computed(() => {
|
|
var r;
|
|
return `${E.value ? "height" : "width"}: ${(r = S.value) == null ? void 0 : r.size}%`;
|
|
});
|
|
return watch(() => f.value, (r) => y({
|
|
uid: m,
|
|
size: r
|
|
})), watch(() => _.value, (r) => y({
|
|
uid: m,
|
|
min: r
|
|
})), watch(() => R.value, (r) => y({
|
|
uid: m,
|
|
max: r
|
|
})), onMounted(() => {
|
|
u({
|
|
id: m,
|
|
el: c.value,
|
|
min: _.value,
|
|
max: R.value,
|
|
givenSize: h$1.size === void 0 ? null : f.value,
|
|
size: f.value
|
|
});
|
|
}), onBeforeUnmount(() => l(m)), (r, P) => (openBlock(), createElementBlock("div", {
|
|
ref_key: "paneEl",
|
|
ref: c,
|
|
class: "splitpanes__pane",
|
|
onClick: P[0] || (P[0] = (A) => unref(M)(A, r._.uid)),
|
|
style: normalizeStyle(O.value)
|
|
}, [renderSlot(r.$slots, "default")], 4));
|
|
}
|
|
};
|
|
var require_codemirror = __commonJSMin((exports, module) => {
|
|
(function(global, factory) {
|
|
typeof exports === "object" && typeof module !== "undefined" ? module.exports = factory() : typeof define === "function" && define.amd ? define(factory) : (global = global || self, global.CodeMirror = factory());
|
|
})(exports, function() {
|
|
"use strict";
|
|
var userAgent = navigator.userAgent;
|
|
var platform = navigator.platform;
|
|
var gecko = /gecko\/\d/i.test(userAgent);
|
|
var ie_upto10 = /MSIE \d/.test(userAgent);
|
|
var ie_11up = /Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(userAgent);
|
|
var edge = /Edge\/(\d+)/.exec(userAgent);
|
|
var ie = ie_upto10 || ie_11up || edge;
|
|
var ie_version = ie && (ie_upto10 ? document.documentMode || 6 : +(edge || ie_11up)[1]);
|
|
var webkit = !edge && /WebKit\//.test(userAgent);
|
|
var qtwebkit = webkit && /Qt\/\d+\.\d+/.test(userAgent);
|
|
var chrome = !edge && /Chrome\/(\d+)/.exec(userAgent);
|
|
var chrome_version = chrome && +chrome[1];
|
|
var presto = /Opera\//.test(userAgent);
|
|
var safari = /Apple Computer/.test(navigator.vendor);
|
|
var mac_geMountainLion = /Mac OS X 1\d\D([8-9]|\d\d)\D/.test(userAgent);
|
|
var phantom = /PhantomJS/.test(userAgent);
|
|
var ios = safari && (/Mobile\/\w+/.test(userAgent) || navigator.maxTouchPoints > 2);
|
|
var android = /Android/.test(userAgent);
|
|
var mobile = ios || android || /webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent);
|
|
var mac = ios || /Mac/.test(platform);
|
|
var chromeOS = /\bCrOS\b/.test(userAgent);
|
|
var windows = /win/i.test(platform);
|
|
var presto_version = presto && userAgent.match(/Version\/(\d*\.\d*)/);
|
|
if (presto_version) presto_version = Number(presto_version[1]);
|
|
if (presto_version && presto_version >= 15) {
|
|
presto = false;
|
|
webkit = true;
|
|
}
|
|
var flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11));
|
|
var captureRightClick = gecko || ie && ie_version >= 9;
|
|
function classTest(cls) {
|
|
return new RegExp("(^|\\s)" + cls + "(?:$|\\s)\\s*");
|
|
}
|
|
var rmClass = function(node, cls) {
|
|
var current = node.className;
|
|
var match = classTest(cls).exec(current);
|
|
if (match) {
|
|
var after = current.slice(match.index + match[0].length);
|
|
node.className = current.slice(0, match.index) + (after ? match[1] + after : "");
|
|
}
|
|
};
|
|
function removeChildren(e) {
|
|
for (var count = e.childNodes.length; count > 0; --count) e.removeChild(e.firstChild);
|
|
return e;
|
|
}
|
|
function removeChildrenAndAdd(parent, e) {
|
|
return removeChildren(parent).appendChild(e);
|
|
}
|
|
function elt(tag, content, className, style) {
|
|
var e = document.createElement(tag);
|
|
if (className) e.className = className;
|
|
if (style) e.style.cssText = style;
|
|
if (typeof content == "string") e.appendChild(document.createTextNode(content));
|
|
else if (content) for (var i$3 = 0; i$3 < content.length; ++i$3) e.appendChild(content[i$3]);
|
|
return e;
|
|
}
|
|
function eltP(tag, content, className, style) {
|
|
var e = elt(tag, content, className, style);
|
|
e.setAttribute("role", "presentation");
|
|
return e;
|
|
}
|
|
var range;
|
|
if (document.createRange) range = function(node, start, end, endNode) {
|
|
var r = document.createRange();
|
|
r.setEnd(endNode || node, end);
|
|
r.setStart(node, start);
|
|
return r;
|
|
};
|
|
else range = function(node, start, end) {
|
|
var r = document.body.createTextRange();
|
|
try {
|
|
r.moveToElementText(node.parentNode);
|
|
} catch (e) {
|
|
return r;
|
|
}
|
|
r.collapse(true);
|
|
r.moveEnd("character", end);
|
|
r.moveStart("character", start);
|
|
return r;
|
|
};
|
|
function contains(parent, child) {
|
|
if (child.nodeType == 3) child = child.parentNode;
|
|
if (parent.contains) return parent.contains(child);
|
|
do {
|
|
if (child.nodeType == 11) child = child.host;
|
|
if (child == parent) return true;
|
|
} while (child = child.parentNode);
|
|
}
|
|
function activeElt(rootNode$1) {
|
|
var doc$1 = rootNode$1.ownerDocument || rootNode$1;
|
|
var activeElement;
|
|
try {
|
|
activeElement = rootNode$1.activeElement;
|
|
} catch (e) {
|
|
activeElement = doc$1.body || null;
|
|
}
|
|
while (activeElement && activeElement.shadowRoot && activeElement.shadowRoot.activeElement) activeElement = activeElement.shadowRoot.activeElement;
|
|
return activeElement;
|
|
}
|
|
function addClass(node, cls) {
|
|
var current = node.className;
|
|
if (!classTest(cls).test(current)) node.className += (current ? " " : "") + cls;
|
|
}
|
|
function joinClasses(a, b) {
|
|
var as = a.split(" ");
|
|
for (var i$3 = 0; i$3 < as.length; i$3++) if (as[i$3] && !classTest(as[i$3]).test(b)) b += " " + as[i$3];
|
|
return b;
|
|
}
|
|
var selectInput = function(node) {
|
|
node.select();
|
|
};
|
|
if (ios) selectInput = function(node) {
|
|
node.selectionStart = 0;
|
|
node.selectionEnd = node.value.length;
|
|
};
|
|
else if (ie) selectInput = function(node) {
|
|
try {
|
|
node.select();
|
|
} catch (_e) {}
|
|
};
|
|
function doc(cm) {
|
|
return cm.display.wrapper.ownerDocument;
|
|
}
|
|
function root(cm) {
|
|
return rootNode(cm.display.wrapper);
|
|
}
|
|
function rootNode(element) {
|
|
return element.getRootNode ? element.getRootNode() : element.ownerDocument;
|
|
}
|
|
function win(cm) {
|
|
return doc(cm).defaultView;
|
|
}
|
|
function bind(f) {
|
|
var args = Array.prototype.slice.call(arguments, 1);
|
|
return function() {
|
|
return f.apply(null, args);
|
|
};
|
|
}
|
|
function copyObj(obj, target, overwrite) {
|
|
if (!target) target = {};
|
|
for (var prop$1 in obj) if (obj.hasOwnProperty(prop$1) && (overwrite !== false || !target.hasOwnProperty(prop$1))) target[prop$1] = obj[prop$1];
|
|
return target;
|
|
}
|
|
function countColumn(string, end, tabSize, startIndex, startValue) {
|
|
if (end == null) {
|
|
end = string.search(/[^\s\u00a0]/);
|
|
if (end == -1) end = string.length;
|
|
}
|
|
for (var i$3 = startIndex || 0, n = startValue || 0;;) {
|
|
var nextTab = string.indexOf(" ", i$3);
|
|
if (nextTab < 0 || nextTab >= end) return n + (end - i$3);
|
|
n += nextTab - i$3;
|
|
n += tabSize - n % tabSize;
|
|
i$3 = nextTab + 1;
|
|
}
|
|
}
|
|
var Delayed = function() {
|
|
this.id = null;
|
|
this.f = null;
|
|
this.time = 0;
|
|
this.handler = bind(this.onTimeout, this);
|
|
};
|
|
Delayed.prototype.onTimeout = function(self$1) {
|
|
self$1.id = 0;
|
|
if (self$1.time <= +new Date()) self$1.f();
|
|
else setTimeout(self$1.handler, self$1.time - +new Date());
|
|
};
|
|
Delayed.prototype.set = function(ms, f) {
|
|
this.f = f;
|
|
var time = +new Date() + ms;
|
|
if (!this.id || time < this.time) {
|
|
clearTimeout(this.id);
|
|
this.id = setTimeout(this.handler, ms);
|
|
this.time = time;
|
|
}
|
|
};
|
|
function indexOf(array, elt$1) {
|
|
for (var i$3 = 0; i$3 < array.length; ++i$3) if (array[i$3] == elt$1) return i$3;
|
|
return -1;
|
|
}
|
|
var scrollerGap = 50;
|
|
var Pass = { toString: function() {
|
|
return "CodeMirror.Pass";
|
|
} };
|
|
var sel_dontScroll = { scroll: false }, sel_mouse = { origin: "*mouse" }, sel_move = { origin: "+move" };
|
|
function findColumn(string, goal, tabSize) {
|
|
for (var pos = 0, col = 0;;) {
|
|
var nextTab = string.indexOf(" ", pos);
|
|
if (nextTab == -1) nextTab = string.length;
|
|
var skipped = nextTab - pos;
|
|
if (nextTab == string.length || col + skipped >= goal) return pos + Math.min(skipped, goal - col);
|
|
col += nextTab - pos;
|
|
col += tabSize - col % tabSize;
|
|
pos = nextTab + 1;
|
|
if (col >= goal) return pos;
|
|
}
|
|
}
|
|
var spaceStrs = [""];
|
|
function spaceStr(n) {
|
|
while (spaceStrs.length <= n) spaceStrs.push(lst(spaceStrs) + " ");
|
|
return spaceStrs[n];
|
|
}
|
|
function lst(arr) {
|
|
return arr[arr.length - 1];
|
|
}
|
|
function map(array, f) {
|
|
var out = [];
|
|
for (var i$3 = 0; i$3 < array.length; i$3++) out[i$3] = f(array[i$3], i$3);
|
|
return out;
|
|
}
|
|
function insertSorted(array, value, score) {
|
|
var pos = 0, priority = score(value);
|
|
while (pos < array.length && score(array[pos]) <= priority) pos++;
|
|
array.splice(pos, 0, value);
|
|
}
|
|
function nothing() {}
|
|
function createObj(base, props) {
|
|
var inst;
|
|
if (Object.create) inst = Object.create(base);
|
|
else {
|
|
nothing.prototype = base;
|
|
inst = new nothing();
|
|
}
|
|
if (props) copyObj(props, inst);
|
|
return inst;
|
|
}
|
|
var nonASCIISingleCaseWordChar = /[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/;
|
|
function isWordCharBasic(ch) {
|
|
return /\w/.test(ch) || ch > "" && (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch));
|
|
}
|
|
function isWordChar(ch, helper) {
|
|
if (!helper) return isWordCharBasic(ch);
|
|
if (helper.source.indexOf("\\w") > -1 && isWordCharBasic(ch)) return true;
|
|
return helper.test(ch);
|
|
}
|
|
function isEmpty(obj) {
|
|
for (var n in obj) if (obj.hasOwnProperty(n) && obj[n]) return false;
|
|
return true;
|
|
}
|
|
var extendingChars = /[\u0300-\u036f\u0483-\u0489\u0591-\u05bd\u05bf\u05c1\u05c2\u05c4\u05c5\u05c7\u0610-\u061a\u064b-\u065e\u0670\u06d6-\u06dc\u06de-\u06e4\u06e7\u06e8\u06ea-\u06ed\u0711\u0730-\u074a\u07a6-\u07b0\u07eb-\u07f3\u0816-\u0819\u081b-\u0823\u0825-\u0827\u0829-\u082d\u0900-\u0902\u093c\u0941-\u0948\u094d\u0951-\u0955\u0962\u0963\u0981\u09bc\u09be\u09c1-\u09c4\u09cd\u09d7\u09e2\u09e3\u0a01\u0a02\u0a3c\u0a41\u0a42\u0a47\u0a48\u0a4b-\u0a4d\u0a51\u0a70\u0a71\u0a75\u0a81\u0a82\u0abc\u0ac1-\u0ac5\u0ac7\u0ac8\u0acd\u0ae2\u0ae3\u0b01\u0b3c\u0b3e\u0b3f\u0b41-\u0b44\u0b4d\u0b56\u0b57\u0b62\u0b63\u0b82\u0bbe\u0bc0\u0bcd\u0bd7\u0c3e-\u0c40\u0c46-\u0c48\u0c4a-\u0c4d\u0c55\u0c56\u0c62\u0c63\u0cbc\u0cbf\u0cc2\u0cc6\u0ccc\u0ccd\u0cd5\u0cd6\u0ce2\u0ce3\u0d3e\u0d41-\u0d44\u0d4d\u0d57\u0d62\u0d63\u0dca\u0dcf\u0dd2-\u0dd4\u0dd6\u0ddf\u0e31\u0e34-\u0e3a\u0e47-\u0e4e\u0eb1\u0eb4-\u0eb9\u0ebb\u0ebc\u0ec8-\u0ecd\u0f18\u0f19\u0f35\u0f37\u0f39\u0f71-\u0f7e\u0f80-\u0f84\u0f86\u0f87\u0f90-\u0f97\u0f99-\u0fbc\u0fc6\u102d-\u1030\u1032-\u1037\u1039\u103a\u103d\u103e\u1058\u1059\u105e-\u1060\u1071-\u1074\u1082\u1085\u1086\u108d\u109d\u135f\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17b7-\u17bd\u17c6\u17c9-\u17d3\u17dd\u180b-\u180d\u18a9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193b\u1a17\u1a18\u1a56\u1a58-\u1a5e\u1a60\u1a62\u1a65-\u1a6c\u1a73-\u1a7c\u1a7f\u1b00-\u1b03\u1b34\u1b36-\u1b3a\u1b3c\u1b42\u1b6b-\u1b73\u1b80\u1b81\u1ba2-\u1ba5\u1ba8\u1ba9\u1c2c-\u1c33\u1c36\u1c37\u1cd0-\u1cd2\u1cd4-\u1ce0\u1ce2-\u1ce8\u1ced\u1dc0-\u1de6\u1dfd-\u1dff\u200c\u200d\u20d0-\u20f0\u2cef-\u2cf1\u2de0-\u2dff\u302a-\u302f\u3099\u309a\ua66f-\ua672\ua67c\ua67d\ua6f0\ua6f1\ua802\ua806\ua80b\ua825\ua826\ua8c4\ua8e0-\ua8f1\ua926-\ua92d\ua947-\ua951\ua980-\ua982\ua9b3\ua9b6-\ua9b9\ua9bc\uaa29-\uaa2e\uaa31\uaa32\uaa35\uaa36\uaa43\uaa4c\uaab0\uaab2-\uaab4\uaab7\uaab8\uaabe\uaabf\uaac1\uabe5\uabe8\uabed\udc00-\udfff\ufb1e\ufe00-\ufe0f\ufe20-\ufe26\uff9e\uff9f]/;
|
|
function isExtendingChar(ch) {
|
|
return ch.charCodeAt(0) >= 768 && extendingChars.test(ch);
|
|
}
|
|
function skipExtendingChars(str, pos, dir) {
|
|
while ((dir < 0 ? pos > 0 : pos < str.length) && isExtendingChar(str.charAt(pos))) pos += dir;
|
|
return pos;
|
|
}
|
|
function findFirst(pred, from, to) {
|
|
var dir = from > to ? -1 : 1;
|
|
for (;;) {
|
|
if (from == to) return from;
|
|
var midF = (from + to) / 2, mid = dir < 0 ? Math.ceil(midF) : Math.floor(midF);
|
|
if (mid == from) return pred(mid) ? from : to;
|
|
if (pred(mid)) to = mid;
|
|
else from = mid + dir;
|
|
}
|
|
}
|
|
function iterateBidiSections(order, from, to, f) {
|
|
if (!order) return f(from, to, "ltr", 0);
|
|
var found = false;
|
|
for (var i$3 = 0; i$3 < order.length; ++i$3) {
|
|
var part = order[i$3];
|
|
if (part.from < to && part.to > from || from == to && part.to == from) {
|
|
f(Math.max(part.from, from), Math.min(part.to, to), part.level == 1 ? "rtl" : "ltr", i$3);
|
|
found = true;
|
|
}
|
|
}
|
|
if (!found) f(from, to, "ltr");
|
|
}
|
|
var bidiOther = null;
|
|
function getBidiPartAt(order, ch, sticky) {
|
|
var found;
|
|
bidiOther = null;
|
|
for (var i$3 = 0; i$3 < order.length; ++i$3) {
|
|
var cur = order[i$3];
|
|
if (cur.from < ch && cur.to > ch) return i$3;
|
|
if (cur.to == ch) if (cur.from != cur.to && sticky == "before") found = i$3;
|
|
else bidiOther = i$3;
|
|
if (cur.from == ch) if (cur.from != cur.to && sticky != "before") found = i$3;
|
|
else bidiOther = i$3;
|
|
}
|
|
return found != null ? found : bidiOther;
|
|
}
|
|
var bidiOrdering = function() {
|
|
var lowTypes = "bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN";
|
|
var arabicTypes = "nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111";
|
|
function charType(code) {
|
|
if (code <= 247) return lowTypes.charAt(code);
|
|
else if (1424 <= code && code <= 1524) return "R";
|
|
else if (1536 <= code && code <= 1785) return arabicTypes.charAt(code - 1536);
|
|
else if (1774 <= code && code <= 2220) return "r";
|
|
else if (8192 <= code && code <= 8203) return "w";
|
|
else if (code == 8204) return "b";
|
|
else return "L";
|
|
}
|
|
var bidiRE = /[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/;
|
|
var isNeutral = /[stwN]/, isStrong = /[LRr]/, countsAsLeft = /[Lb1n]/, countsAsNum = /[1n]/;
|
|
function BidiSpan(level, from, to) {
|
|
this.level = level;
|
|
this.from = from;
|
|
this.to = to;
|
|
}
|
|
return function(str, direction) {
|
|
var outerType = direction == "ltr" ? "L" : "R";
|
|
if (str.length == 0 || direction == "ltr" && !bidiRE.test(str)) return false;
|
|
var len = str.length, types = [];
|
|
for (var i$3 = 0; i$3 < len; ++i$3) types.push(charType(str.charCodeAt(i$3)));
|
|
for (var i$1$1 = 0, prev = outerType; i$1$1 < len; ++i$1$1) {
|
|
var type = types[i$1$1];
|
|
if (type == "m") types[i$1$1] = prev;
|
|
else prev = type;
|
|
}
|
|
for (var i$2$1 = 0, cur = outerType; i$2$1 < len; ++i$2$1) {
|
|
var type$1 = types[i$2$1];
|
|
if (type$1 == "1" && cur == "r") types[i$2$1] = "n";
|
|
else if (isStrong.test(type$1)) {
|
|
cur = type$1;
|
|
if (type$1 == "r") types[i$2$1] = "R";
|
|
}
|
|
}
|
|
for (var i$3$1 = 1, prev$1 = types[0]; i$3$1 < len - 1; ++i$3$1) {
|
|
var type$2 = types[i$3$1];
|
|
if (type$2 == "+" && prev$1 == "1" && types[i$3$1 + 1] == "1") types[i$3$1] = "1";
|
|
else if (type$2 == "," && prev$1 == types[i$3$1 + 1] && (prev$1 == "1" || prev$1 == "n")) types[i$3$1] = prev$1;
|
|
prev$1 = type$2;
|
|
}
|
|
for (var i$4 = 0; i$4 < len; ++i$4) {
|
|
var type$3 = types[i$4];
|
|
if (type$3 == ",") types[i$4] = "N";
|
|
else if (type$3 == "%") {
|
|
var end = void 0;
|
|
for (end = i$4 + 1; end < len && types[end] == "%"; ++end);
|
|
var replace = i$4 && types[i$4 - 1] == "!" || end < len && types[end] == "1" ? "1" : "N";
|
|
for (var j = i$4; j < end; ++j) types[j] = replace;
|
|
i$4 = end - 1;
|
|
}
|
|
}
|
|
for (var i$5 = 0, cur$1 = outerType; i$5 < len; ++i$5) {
|
|
var type$4 = types[i$5];
|
|
if (cur$1 == "L" && type$4 == "1") types[i$5] = "L";
|
|
else if (isStrong.test(type$4)) cur$1 = type$4;
|
|
}
|
|
for (var i$6 = 0; i$6 < len; ++i$6) if (isNeutral.test(types[i$6])) {
|
|
var end$1 = void 0;
|
|
for (end$1 = i$6 + 1; end$1 < len && isNeutral.test(types[end$1]); ++end$1);
|
|
var before = (i$6 ? types[i$6 - 1] : outerType) == "L";
|
|
var after = (end$1 < len ? types[end$1] : outerType) == "L";
|
|
var replace$1 = before == after ? before ? "L" : "R" : outerType;
|
|
for (var j$1 = i$6; j$1 < end$1; ++j$1) types[j$1] = replace$1;
|
|
i$6 = end$1 - 1;
|
|
}
|
|
var order = [], m;
|
|
for (var i$7 = 0; i$7 < len;) if (countsAsLeft.test(types[i$7])) {
|
|
var start = i$7;
|
|
for (++i$7; i$7 < len && countsAsLeft.test(types[i$7]); ++i$7);
|
|
order.push(new BidiSpan(0, start, i$7));
|
|
} else {
|
|
var pos = i$7, at = order.length, isRTL = direction == "rtl" ? 1 : 0;
|
|
for (++i$7; i$7 < len && types[i$7] != "L"; ++i$7);
|
|
for (var j$2 = pos; j$2 < i$7;) if (countsAsNum.test(types[j$2])) {
|
|
if (pos < j$2) {
|
|
order.splice(at, 0, new BidiSpan(1, pos, j$2));
|
|
at += isRTL;
|
|
}
|
|
var nstart = j$2;
|
|
for (++j$2; j$2 < i$7 && countsAsNum.test(types[j$2]); ++j$2);
|
|
order.splice(at, 0, new BidiSpan(2, nstart, j$2));
|
|
at += isRTL;
|
|
pos = j$2;
|
|
} else ++j$2;
|
|
if (pos < i$7) order.splice(at, 0, new BidiSpan(1, pos, i$7));
|
|
}
|
|
if (direction == "ltr") {
|
|
if (order[0].level == 1 && (m = str.match(/^\s+/))) {
|
|
order[0].from = m[0].length;
|
|
order.unshift(new BidiSpan(0, 0, m[0].length));
|
|
}
|
|
if (lst(order).level == 1 && (m = str.match(/\s+$/))) {
|
|
lst(order).to -= m[0].length;
|
|
order.push(new BidiSpan(0, len - m[0].length, len));
|
|
}
|
|
}
|
|
return direction == "rtl" ? order.reverse() : order;
|
|
};
|
|
}();
|
|
function getOrder(line, direction) {
|
|
var order = line.order;
|
|
if (order == null) order = line.order = bidiOrdering(line.text, direction);
|
|
return order;
|
|
}
|
|
var noHandlers = [];
|
|
var on = function(emitter, type, f) {
|
|
if (emitter.addEventListener) emitter.addEventListener(type, f, false);
|
|
else if (emitter.attachEvent) emitter.attachEvent("on" + type, f);
|
|
else {
|
|
var map$1 = emitter._handlers || (emitter._handlers = {});
|
|
map$1[type] = (map$1[type] || noHandlers).concat(f);
|
|
}
|
|
};
|
|
function getHandlers(emitter, type) {
|
|
return emitter._handlers && emitter._handlers[type] || noHandlers;
|
|
}
|
|
function off(emitter, type, f) {
|
|
if (emitter.removeEventListener) emitter.removeEventListener(type, f, false);
|
|
else if (emitter.detachEvent) emitter.detachEvent("on" + type, f);
|
|
else {
|
|
var map$1 = emitter._handlers, arr = map$1 && map$1[type];
|
|
if (arr) {
|
|
var index = indexOf(arr, f);
|
|
if (index > -1) map$1[type] = arr.slice(0, index).concat(arr.slice(index + 1));
|
|
}
|
|
}
|
|
}
|
|
function signal(emitter, type) {
|
|
var handlers = getHandlers(emitter, type);
|
|
if (!handlers.length) return;
|
|
var args = Array.prototype.slice.call(arguments, 2);
|
|
for (var i$3 = 0; i$3 < handlers.length; ++i$3) handlers[i$3].apply(null, args);
|
|
}
|
|
function signalDOMEvent(cm, e, override) {
|
|
if (typeof e == "string") e = {
|
|
type: e,
|
|
preventDefault: function() {
|
|
this.defaultPrevented = true;
|
|
}
|
|
};
|
|
signal(cm, override || e.type, cm, e);
|
|
return e_defaultPrevented(e) || e.codemirrorIgnore;
|
|
}
|
|
function signalCursorActivity(cm) {
|
|
var arr = cm._handlers && cm._handlers.cursorActivity;
|
|
if (!arr) return;
|
|
var set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = []);
|
|
for (var i$3 = 0; i$3 < arr.length; ++i$3) if (indexOf(set, arr[i$3]) == -1) set.push(arr[i$3]);
|
|
}
|
|
function hasHandler(emitter, type) {
|
|
return getHandlers(emitter, type).length > 0;
|
|
}
|
|
function eventMixin(ctor) {
|
|
ctor.prototype.on = function(type, f) {
|
|
on(this, type, f);
|
|
};
|
|
ctor.prototype.off = function(type, f) {
|
|
off(this, type, f);
|
|
};
|
|
}
|
|
function e_preventDefault(e) {
|
|
if (e.preventDefault) e.preventDefault();
|
|
else e.returnValue = false;
|
|
}
|
|
function e_stopPropagation(e) {
|
|
if (e.stopPropagation) e.stopPropagation();
|
|
else e.cancelBubble = true;
|
|
}
|
|
function e_defaultPrevented(e) {
|
|
return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false;
|
|
}
|
|
function e_stop(e) {
|
|
e_preventDefault(e);
|
|
e_stopPropagation(e);
|
|
}
|
|
function e_target(e) {
|
|
return e.target || e.srcElement;
|
|
}
|
|
function e_button(e) {
|
|
var b = e.which;
|
|
if (b == null) {
|
|
if (e.button & 1) b = 1;
|
|
else if (e.button & 2) b = 3;
|
|
else if (e.button & 4) b = 2;
|
|
}
|
|
if (mac && e.ctrlKey && b == 1) b = 3;
|
|
return b;
|
|
}
|
|
var dragAndDrop = function() {
|
|
if (ie && ie_version < 9) return false;
|
|
var div = elt("div");
|
|
return "draggable" in div || "dragDrop" in div;
|
|
}();
|
|
var zwspSupported;
|
|
function zeroWidthElement(measure) {
|
|
if (zwspSupported == null) {
|
|
var test = elt("span", "");
|
|
removeChildrenAndAdd(measure, elt("span", [test, document.createTextNode("x")]));
|
|
if (measure.firstChild.offsetHeight != 0) zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8);
|
|
}
|
|
var node = zwspSupported ? elt("span", "") : elt("span", "\xA0", null, "display: inline-block; width: 1px; margin-right: -1px");
|
|
node.setAttribute("cm-text", "");
|
|
return node;
|
|
}
|
|
var badBidiRects;
|
|
function hasBadBidiRects(measure) {
|
|
if (badBidiRects != null) return badBidiRects;
|
|
var txt = removeChildrenAndAdd(measure, document.createTextNode("AخA"));
|
|
var r0 = range(txt, 0, 1).getBoundingClientRect();
|
|
var r1 = range(txt, 1, 2).getBoundingClientRect();
|
|
removeChildren(measure);
|
|
if (!r0 || r0.left == r0.right) return false;
|
|
return badBidiRects = r1.right - r0.right < 3;
|
|
}
|
|
var splitLinesAuto = "\n\nb".split(/\n/).length != 3 ? function(string) {
|
|
var pos = 0, result = [], l = string.length;
|
|
while (pos <= l) {
|
|
var nl = string.indexOf("\n", pos);
|
|
if (nl == -1) nl = string.length;
|
|
var line = string.slice(pos, string.charAt(nl - 1) == "\r" ? nl - 1 : nl);
|
|
var rt = line.indexOf("\r");
|
|
if (rt != -1) {
|
|
result.push(line.slice(0, rt));
|
|
pos += rt + 1;
|
|
} else {
|
|
result.push(line);
|
|
pos = nl + 1;
|
|
}
|
|
}
|
|
return result;
|
|
} : function(string) {
|
|
return string.split(/\r\n?|\n/);
|
|
};
|
|
var hasSelection = window.getSelection ? function(te) {
|
|
try {
|
|
return te.selectionStart != te.selectionEnd;
|
|
} catch (e) {
|
|
return false;
|
|
}
|
|
} : function(te) {
|
|
var range$1;
|
|
try {
|
|
range$1 = te.ownerDocument.selection.createRange();
|
|
} catch (e) {}
|
|
if (!range$1 || range$1.parentElement() != te) return false;
|
|
return range$1.compareEndPoints("StartToEnd", range$1) != 0;
|
|
};
|
|
var hasCopyEvent = function() {
|
|
var e = elt("div");
|
|
if ("oncopy" in e) return true;
|
|
e.setAttribute("oncopy", "return;");
|
|
return typeof e.oncopy == "function";
|
|
}();
|
|
var badZoomedRects = null;
|
|
function hasBadZoomedRects(measure) {
|
|
if (badZoomedRects != null) return badZoomedRects;
|
|
var node = removeChildrenAndAdd(measure, elt("span", "x"));
|
|
var normal = node.getBoundingClientRect();
|
|
var fromRange = range(node, 0, 1).getBoundingClientRect();
|
|
return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1;
|
|
}
|
|
var modes = {}, mimeModes = {};
|
|
function defineMode(name, mode) {
|
|
if (arguments.length > 2) mode.dependencies = Array.prototype.slice.call(arguments, 2);
|
|
modes[name] = mode;
|
|
}
|
|
function defineMIME(mime, spec) {
|
|
mimeModes[mime] = spec;
|
|
}
|
|
function resolveMode(spec) {
|
|
if (typeof spec == "string" && mimeModes.hasOwnProperty(spec)) spec = mimeModes[spec];
|
|
else if (spec && typeof spec.name == "string" && mimeModes.hasOwnProperty(spec.name)) {
|
|
var found = mimeModes[spec.name];
|
|
if (typeof found == "string") found = { name: found };
|
|
spec = createObj(found, spec);
|
|
spec.name = found.name;
|
|
} else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+xml$/.test(spec)) return resolveMode("application/xml");
|
|
else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+json$/.test(spec)) return resolveMode("application/json");
|
|
if (typeof spec == "string") return { name: spec };
|
|
else return spec || { name: "null" };
|
|
}
|
|
function getMode(options, spec) {
|
|
spec = resolveMode(spec);
|
|
var mfactory = modes[spec.name];
|
|
if (!mfactory) return getMode(options, "text/plain");
|
|
var modeObj = mfactory(options, spec);
|
|
if (modeExtensions.hasOwnProperty(spec.name)) {
|
|
var exts = modeExtensions[spec.name];
|
|
for (var prop$1 in exts) {
|
|
if (!exts.hasOwnProperty(prop$1)) continue;
|
|
if (modeObj.hasOwnProperty(prop$1)) modeObj["_" + prop$1] = modeObj[prop$1];
|
|
modeObj[prop$1] = exts[prop$1];
|
|
}
|
|
}
|
|
modeObj.name = spec.name;
|
|
if (spec.helperType) modeObj.helperType = spec.helperType;
|
|
if (spec.modeProps) for (var prop$1$1 in spec.modeProps) modeObj[prop$1$1] = spec.modeProps[prop$1$1];
|
|
return modeObj;
|
|
}
|
|
var modeExtensions = {};
|
|
function extendMode(mode, properties) {
|
|
var exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : modeExtensions[mode] = {};
|
|
copyObj(properties, exts);
|
|
}
|
|
function copyState(mode, state) {
|
|
if (state === true) return state;
|
|
if (mode.copyState) return mode.copyState(state);
|
|
var nstate = {};
|
|
for (var n in state) {
|
|
var val = state[n];
|
|
if (val instanceof Array) val = val.concat([]);
|
|
nstate[n] = val;
|
|
}
|
|
return nstate;
|
|
}
|
|
function innerMode(mode, state) {
|
|
var info;
|
|
while (mode.innerMode) {
|
|
info = mode.innerMode(state);
|
|
if (!info || info.mode == mode) break;
|
|
state = info.state;
|
|
mode = info.mode;
|
|
}
|
|
return info || {
|
|
mode,
|
|
state
|
|
};
|
|
}
|
|
function startState(mode, a1, a2) {
|
|
return mode.startState ? mode.startState(a1, a2) : true;
|
|
}
|
|
var StringStream = function(string, tabSize, lineOracle) {
|
|
this.pos = this.start = 0;
|
|
this.string = string;
|
|
this.tabSize = tabSize || 8;
|
|
this.lastColumnPos = this.lastColumnValue = 0;
|
|
this.lineStart = 0;
|
|
this.lineOracle = lineOracle;
|
|
};
|
|
StringStream.prototype.eol = function() {
|
|
return this.pos >= this.string.length;
|
|
};
|
|
StringStream.prototype.sol = function() {
|
|
return this.pos == this.lineStart;
|
|
};
|
|
StringStream.prototype.peek = function() {
|
|
return this.string.charAt(this.pos) || void 0;
|
|
};
|
|
StringStream.prototype.next = function() {
|
|
if (this.pos < this.string.length) return this.string.charAt(this.pos++);
|
|
};
|
|
StringStream.prototype.eat = function(match) {
|
|
var ch = this.string.charAt(this.pos);
|
|
var ok;
|
|
if (typeof match == "string") ok = ch == match;
|
|
else ok = ch && (match.test ? match.test(ch) : match(ch));
|
|
if (ok) {
|
|
++this.pos;
|
|
return ch;
|
|
}
|
|
};
|
|
StringStream.prototype.eatWhile = function(match) {
|
|
var start = this.pos;
|
|
while (this.eat(match));
|
|
return this.pos > start;
|
|
};
|
|
StringStream.prototype.eatSpace = function() {
|
|
var start = this.pos;
|
|
while (/[\s\u00a0]/.test(this.string.charAt(this.pos))) ++this.pos;
|
|
return this.pos > start;
|
|
};
|
|
StringStream.prototype.skipToEnd = function() {
|
|
this.pos = this.string.length;
|
|
};
|
|
StringStream.prototype.skipTo = function(ch) {
|
|
var found = this.string.indexOf(ch, this.pos);
|
|
if (found > -1) {
|
|
this.pos = found;
|
|
return true;
|
|
}
|
|
};
|
|
StringStream.prototype.backUp = function(n) {
|
|
this.pos -= n;
|
|
};
|
|
StringStream.prototype.column = function() {
|
|
if (this.lastColumnPos < this.start) {
|
|
this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue);
|
|
this.lastColumnPos = this.start;
|
|
}
|
|
return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0);
|
|
};
|
|
StringStream.prototype.indentation = function() {
|
|
return countColumn(this.string, null, this.tabSize) - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0);
|
|
};
|
|
StringStream.prototype.match = function(pattern, consume, caseInsensitive) {
|
|
if (typeof pattern == "string") {
|
|
var cased = function(str) {
|
|
return caseInsensitive ? str.toLowerCase() : str;
|
|
};
|
|
var substr = this.string.substr(this.pos, pattern.length);
|
|
if (cased(substr) == cased(pattern)) {
|
|
if (consume !== false) this.pos += pattern.length;
|
|
return true;
|
|
}
|
|
} else {
|
|
var match = this.string.slice(this.pos).match(pattern);
|
|
if (match && match.index > 0) return null;
|
|
if (match && consume !== false) this.pos += match[0].length;
|
|
return match;
|
|
}
|
|
};
|
|
StringStream.prototype.current = function() {
|
|
return this.string.slice(this.start, this.pos);
|
|
};
|
|
StringStream.prototype.hideFirstChars = function(n, inner) {
|
|
this.lineStart += n;
|
|
try {
|
|
return inner();
|
|
} finally {
|
|
this.lineStart -= n;
|
|
}
|
|
};
|
|
StringStream.prototype.lookAhead = function(n) {
|
|
var oracle = this.lineOracle;
|
|
return oracle && oracle.lookAhead(n);
|
|
};
|
|
StringStream.prototype.baseToken = function() {
|
|
var oracle = this.lineOracle;
|
|
return oracle && oracle.baseToken(this.pos);
|
|
};
|
|
function getLine(doc$1, n) {
|
|
n -= doc$1.first;
|
|
if (n < 0 || n >= doc$1.size) throw new Error("There is no line " + (n + doc$1.first) + " in the document.");
|
|
var chunk = doc$1;
|
|
while (!chunk.lines) for (var i$3 = 0;; ++i$3) {
|
|
var child = chunk.children[i$3], sz = child.chunkSize();
|
|
if (n < sz) {
|
|
chunk = child;
|
|
break;
|
|
}
|
|
n -= sz;
|
|
}
|
|
return chunk.lines[n];
|
|
}
|
|
function getBetween(doc$1, start, end) {
|
|
var out = [], n = start.line;
|
|
doc$1.iter(start.line, end.line + 1, function(line) {
|
|
var text = line.text;
|
|
if (n == end.line) text = text.slice(0, end.ch);
|
|
if (n == start.line) text = text.slice(start.ch);
|
|
out.push(text);
|
|
++n;
|
|
});
|
|
return out;
|
|
}
|
|
function getLines(doc$1, from, to) {
|
|
var out = [];
|
|
doc$1.iter(from, to, function(line) {
|
|
out.push(line.text);
|
|
});
|
|
return out;
|
|
}
|
|
function updateLineHeight(line, height) {
|
|
var diff = height - line.height;
|
|
if (diff) for (var n = line; n; n = n.parent) n.height += diff;
|
|
}
|
|
function lineNo(line) {
|
|
if (line.parent == null) return null;
|
|
var cur = line.parent, no = indexOf(cur.lines, line);
|
|
for (var chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) for (var i$3 = 0;; ++i$3) {
|
|
if (chunk.children[i$3] == cur) break;
|
|
no += chunk.children[i$3].chunkSize();
|
|
}
|
|
return no + cur.first;
|
|
}
|
|
function lineAtHeight(chunk, h$1) {
|
|
var n = chunk.first;
|
|
outer: do {
|
|
for (var i$1$1 = 0; i$1$1 < chunk.children.length; ++i$1$1) {
|
|
var child = chunk.children[i$1$1], ch = child.height;
|
|
if (h$1 < ch) {
|
|
chunk = child;
|
|
continue outer;
|
|
}
|
|
h$1 -= ch;
|
|
n += child.chunkSize();
|
|
}
|
|
return n;
|
|
} while (!chunk.lines);
|
|
var i$3 = 0;
|
|
for (; i$3 < chunk.lines.length; ++i$3) {
|
|
var line = chunk.lines[i$3], lh = line.height;
|
|
if (h$1 < lh) break;
|
|
h$1 -= lh;
|
|
}
|
|
return n + i$3;
|
|
}
|
|
function isLine(doc$1, l) {
|
|
return l >= doc$1.first && l < doc$1.first + doc$1.size;
|
|
}
|
|
function lineNumberFor(options, i$3) {
|
|
return String(options.lineNumberFormatter(i$3 + options.firstLineNumber));
|
|
}
|
|
function Pos(line, ch, sticky) {
|
|
if (sticky === void 0) sticky = null;
|
|
if (!(this instanceof Pos)) return new Pos(line, ch, sticky);
|
|
this.line = line;
|
|
this.ch = ch;
|
|
this.sticky = sticky;
|
|
}
|
|
function cmp(a, b) {
|
|
return a.line - b.line || a.ch - b.ch;
|
|
}
|
|
function equalCursorPos(a, b) {
|
|
return a.sticky == b.sticky && cmp(a, b) == 0;
|
|
}
|
|
function copyPos(x) {
|
|
return Pos(x.line, x.ch);
|
|
}
|
|
function maxPos(a, b) {
|
|
return cmp(a, b) < 0 ? b : a;
|
|
}
|
|
function minPos(a, b) {
|
|
return cmp(a, b) < 0 ? a : b;
|
|
}
|
|
function clipLine(doc$1, n) {
|
|
return Math.max(doc$1.first, Math.min(n, doc$1.first + doc$1.size - 1));
|
|
}
|
|
function clipPos(doc$1, pos) {
|
|
if (pos.line < doc$1.first) return Pos(doc$1.first, 0);
|
|
var last = doc$1.first + doc$1.size - 1;
|
|
if (pos.line > last) return Pos(last, getLine(doc$1, last).text.length);
|
|
return clipToLen(pos, getLine(doc$1, pos.line).text.length);
|
|
}
|
|
function clipToLen(pos, linelen) {
|
|
var ch = pos.ch;
|
|
if (ch == null || ch > linelen) return Pos(pos.line, linelen);
|
|
else if (ch < 0) return Pos(pos.line, 0);
|
|
else return pos;
|
|
}
|
|
function clipPosArray(doc$1, array) {
|
|
var out = [];
|
|
for (var i$3 = 0; i$3 < array.length; i$3++) out[i$3] = clipPos(doc$1, array[i$3]);
|
|
return out;
|
|
}
|
|
var SavedContext = function(state, lookAhead) {
|
|
this.state = state;
|
|
this.lookAhead = lookAhead;
|
|
};
|
|
var Context = function(doc$1, state, line, lookAhead) {
|
|
this.state = state;
|
|
this.doc = doc$1;
|
|
this.line = line;
|
|
this.maxLookAhead = lookAhead || 0;
|
|
this.baseTokens = null;
|
|
this.baseTokenPos = 1;
|
|
};
|
|
Context.prototype.lookAhead = function(n) {
|
|
var line = this.doc.getLine(this.line + n);
|
|
if (line != null && n > this.maxLookAhead) this.maxLookAhead = n;
|
|
return line;
|
|
};
|
|
Context.prototype.baseToken = function(n) {
|
|
if (!this.baseTokens) return null;
|
|
while (this.baseTokens[this.baseTokenPos] <= n) this.baseTokenPos += 2;
|
|
var type = this.baseTokens[this.baseTokenPos + 1];
|
|
return {
|
|
type: type && type.replace(/( |^)overlay .*/, ""),
|
|
size: this.baseTokens[this.baseTokenPos] - n
|
|
};
|
|
};
|
|
Context.prototype.nextLine = function() {
|
|
this.line++;
|
|
if (this.maxLookAhead > 0) this.maxLookAhead--;
|
|
};
|
|
Context.fromSaved = function(doc$1, saved, line) {
|
|
if (saved instanceof SavedContext) return new Context(doc$1, copyState(doc$1.mode, saved.state), line, saved.lookAhead);
|
|
else return new Context(doc$1, copyState(doc$1.mode, saved), line);
|
|
};
|
|
Context.prototype.save = function(copy) {
|
|
var state = copy !== false ? copyState(this.doc.mode, this.state) : this.state;
|
|
return this.maxLookAhead > 0 ? new SavedContext(state, this.maxLookAhead) : state;
|
|
};
|
|
function highlightLine(cm, line, context, forceToEnd) {
|
|
var st = [cm.state.modeGen], lineClasses = {};
|
|
runMode(cm, line.text, cm.doc.mode, context, function(end, style) {
|
|
return st.push(end, style);
|
|
}, lineClasses, forceToEnd);
|
|
var state = context.state;
|
|
var loop = function(o$1) {
|
|
context.baseTokens = st;
|
|
var overlay = cm.state.overlays[o$1], i$3 = 1, at = 0;
|
|
context.state = true;
|
|
runMode(cm, line.text, overlay.mode, context, function(end, style) {
|
|
var start = i$3;
|
|
while (at < end) {
|
|
var i_end = st[i$3];
|
|
if (i_end > end) st.splice(i$3, 1, end, st[i$3 + 1], i_end);
|
|
i$3 += 2;
|
|
at = Math.min(end, i_end);
|
|
}
|
|
if (!style) return;
|
|
if (overlay.opaque) {
|
|
st.splice(start, i$3 - start, end, "overlay " + style);
|
|
i$3 = start + 2;
|
|
} else for (; start < i$3; start += 2) {
|
|
var cur = st[start + 1];
|
|
st[start + 1] = (cur ? cur + " " : "") + "overlay " + style;
|
|
}
|
|
}, lineClasses);
|
|
context.state = state;
|
|
context.baseTokens = null;
|
|
context.baseTokenPos = 1;
|
|
};
|
|
for (var o = 0; o < cm.state.overlays.length; ++o) loop(o);
|
|
return {
|
|
styles: st,
|
|
classes: lineClasses.bgClass || lineClasses.textClass ? lineClasses : null
|
|
};
|
|
}
|
|
function getLineStyles(cm, line, updateFrontier) {
|
|
if (!line.styles || line.styles[0] != cm.state.modeGen) {
|
|
var context = getContextBefore(cm, lineNo(line));
|
|
var resetState = line.text.length > cm.options.maxHighlightLength && copyState(cm.doc.mode, context.state);
|
|
var result = highlightLine(cm, line, context);
|
|
if (resetState) context.state = resetState;
|
|
line.stateAfter = context.save(!resetState);
|
|
line.styles = result.styles;
|
|
if (result.classes) line.styleClasses = result.classes;
|
|
else if (line.styleClasses) line.styleClasses = null;
|
|
if (updateFrontier === cm.doc.highlightFrontier) cm.doc.modeFrontier = Math.max(cm.doc.modeFrontier, ++cm.doc.highlightFrontier);
|
|
}
|
|
return line.styles;
|
|
}
|
|
function getContextBefore(cm, n, precise) {
|
|
var doc$1 = cm.doc, display = cm.display;
|
|
if (!doc$1.mode.startState) return new Context(doc$1, true, n);
|
|
var start = findStartLine(cm, n, precise);
|
|
var saved = start > doc$1.first && getLine(doc$1, start - 1).stateAfter;
|
|
var context = saved ? Context.fromSaved(doc$1, saved, start) : new Context(doc$1, startState(doc$1.mode), start);
|
|
doc$1.iter(start, n, function(line) {
|
|
processLine(cm, line.text, context);
|
|
var pos = context.line;
|
|
line.stateAfter = pos == n - 1 || pos % 5 == 0 || pos >= display.viewFrom && pos < display.viewTo ? context.save() : null;
|
|
context.nextLine();
|
|
});
|
|
if (precise) doc$1.modeFrontier = context.line;
|
|
return context;
|
|
}
|
|
function processLine(cm, text, context, startAt) {
|
|
var mode = cm.doc.mode;
|
|
var stream = new StringStream(text, cm.options.tabSize, context);
|
|
stream.start = stream.pos = startAt || 0;
|
|
if (text == "") callBlankLine(mode, context.state);
|
|
while (!stream.eol()) {
|
|
readToken(mode, stream, context.state);
|
|
stream.start = stream.pos;
|
|
}
|
|
}
|
|
function callBlankLine(mode, state) {
|
|
if (mode.blankLine) return mode.blankLine(state);
|
|
if (!mode.innerMode) return;
|
|
var inner = innerMode(mode, state);
|
|
if (inner.mode.blankLine) return inner.mode.blankLine(inner.state);
|
|
}
|
|
function readToken(mode, stream, state, inner) {
|
|
for (var i$3 = 0; i$3 < 10; i$3++) {
|
|
if (inner) inner[0] = innerMode(mode, state).mode;
|
|
var style = mode.token(stream, state);
|
|
if (stream.pos > stream.start) return style;
|
|
}
|
|
throw new Error("Mode " + mode.name + " failed to advance stream.");
|
|
}
|
|
var Token = function(stream, type, state) {
|
|
this.start = stream.start;
|
|
this.end = stream.pos;
|
|
this.string = stream.current();
|
|
this.type = type || null;
|
|
this.state = state;
|
|
};
|
|
function takeToken(cm, pos, precise, asArray) {
|
|
var doc$1 = cm.doc, mode = doc$1.mode, style;
|
|
pos = clipPos(doc$1, pos);
|
|
var line = getLine(doc$1, pos.line), context = getContextBefore(cm, pos.line, precise);
|
|
var stream = new StringStream(line.text, cm.options.tabSize, context), tokens;
|
|
if (asArray) tokens = [];
|
|
while ((asArray || stream.pos < pos.ch) && !stream.eol()) {
|
|
stream.start = stream.pos;
|
|
style = readToken(mode, stream, context.state);
|
|
if (asArray) tokens.push(new Token(stream, style, copyState(doc$1.mode, context.state)));
|
|
}
|
|
return asArray ? tokens : new Token(stream, style, context.state);
|
|
}
|
|
function extractLineClasses(type, output) {
|
|
if (type) for (;;) {
|
|
var lineClass = type.match(/(?:^|\s+)line-(background-)?(\S+)/);
|
|
if (!lineClass) break;
|
|
type = type.slice(0, lineClass.index) + type.slice(lineClass.index + lineClass[0].length);
|
|
var prop$1 = lineClass[1] ? "bgClass" : "textClass";
|
|
if (output[prop$1] == null) output[prop$1] = lineClass[2];
|
|
else if (!new RegExp("(?:^|\\s)" + lineClass[2] + "(?:$|\\s)").test(output[prop$1])) output[prop$1] += " " + lineClass[2];
|
|
}
|
|
return type;
|
|
}
|
|
function runMode(cm, text, mode, context, f, lineClasses, forceToEnd) {
|
|
var flattenSpans = mode.flattenSpans;
|
|
if (flattenSpans == null) flattenSpans = cm.options.flattenSpans;
|
|
var curStart = 0, curStyle = null;
|
|
var stream = new StringStream(text, cm.options.tabSize, context), style;
|
|
var inner = cm.options.addModeClass && [null];
|
|
if (text == "") extractLineClasses(callBlankLine(mode, context.state), lineClasses);
|
|
while (!stream.eol()) {
|
|
if (stream.pos > cm.options.maxHighlightLength) {
|
|
flattenSpans = false;
|
|
if (forceToEnd) processLine(cm, text, context, stream.pos);
|
|
stream.pos = text.length;
|
|
style = null;
|
|
} else style = extractLineClasses(readToken(mode, stream, context.state, inner), lineClasses);
|
|
if (inner) {
|
|
var mName = inner[0].name;
|
|
if (mName) style = "m-" + (style ? mName + " " + style : mName);
|
|
}
|
|
if (!flattenSpans || curStyle != style) {
|
|
while (curStart < stream.start) {
|
|
curStart = Math.min(stream.start, curStart + 5e3);
|
|
f(curStart, curStyle);
|
|
}
|
|
curStyle = style;
|
|
}
|
|
stream.start = stream.pos;
|
|
}
|
|
while (curStart < stream.pos) {
|
|
var pos = Math.min(stream.pos, curStart + 5e3);
|
|
f(pos, curStyle);
|
|
curStart = pos;
|
|
}
|
|
}
|
|
function findStartLine(cm, n, precise) {
|
|
var minindent, minline, doc$1 = cm.doc;
|
|
var lim = precise ? -1 : n - (cm.doc.mode.innerMode ? 1e3 : 100);
|
|
for (var search = n; search > lim; --search) {
|
|
if (search <= doc$1.first) return doc$1.first;
|
|
var line = getLine(doc$1, search - 1), after = line.stateAfter;
|
|
if (after && (!precise || search + (after instanceof SavedContext ? after.lookAhead : 0) <= doc$1.modeFrontier)) return search;
|
|
var indented = countColumn(line.text, null, cm.options.tabSize);
|
|
if (minline == null || minindent > indented) {
|
|
minline = search - 1;
|
|
minindent = indented;
|
|
}
|
|
}
|
|
return minline;
|
|
}
|
|
function retreatFrontier(doc$1, n) {
|
|
doc$1.modeFrontier = Math.min(doc$1.modeFrontier, n);
|
|
if (doc$1.highlightFrontier < n - 10) return;
|
|
var start = doc$1.first;
|
|
for (var line = n - 1; line > start; line--) {
|
|
var saved = getLine(doc$1, line).stateAfter;
|
|
if (saved && (!(saved instanceof SavedContext) || line + saved.lookAhead < n)) {
|
|
start = line + 1;
|
|
break;
|
|
}
|
|
}
|
|
doc$1.highlightFrontier = Math.min(doc$1.highlightFrontier, start);
|
|
}
|
|
var sawReadOnlySpans = false, sawCollapsedSpans = false;
|
|
function seeReadOnlySpans() {
|
|
sawReadOnlySpans = true;
|
|
}
|
|
function seeCollapsedSpans() {
|
|
sawCollapsedSpans = true;
|
|
}
|
|
function MarkedSpan(marker, from, to) {
|
|
this.marker = marker;
|
|
this.from = from;
|
|
this.to = to;
|
|
}
|
|
function getMarkedSpanFor(spans, marker) {
|
|
if (spans) for (var i$3 = 0; i$3 < spans.length; ++i$3) {
|
|
var span = spans[i$3];
|
|
if (span.marker == marker) return span;
|
|
}
|
|
}
|
|
function removeMarkedSpan(spans, span) {
|
|
var r;
|
|
for (var i$3 = 0; i$3 < spans.length; ++i$3) if (spans[i$3] != span) (r || (r = [])).push(spans[i$3]);
|
|
return r;
|
|
}
|
|
function addMarkedSpan(line, span, op) {
|
|
var inThisOp = op && window.WeakSet && (op.markedSpans || (op.markedSpans = new WeakSet()));
|
|
if (inThisOp && line.markedSpans && inThisOp.has(line.markedSpans)) line.markedSpans.push(span);
|
|
else {
|
|
line.markedSpans = line.markedSpans ? line.markedSpans.concat([span]) : [span];
|
|
if (inThisOp) inThisOp.add(line.markedSpans);
|
|
}
|
|
span.marker.attachLine(line);
|
|
}
|
|
function markedSpansBefore(old, startCh, isInsert) {
|
|
var nw;
|
|
if (old) for (var i$3 = 0; i$3 < old.length; ++i$3) {
|
|
var span = old[i$3], marker = span.marker;
|
|
var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= startCh : span.from < startCh);
|
|
if (startsBefore || span.from == startCh && marker.type == "bookmark" && (!isInsert || !span.marker.insertLeft)) {
|
|
var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= startCh : span.to > startCh);
|
|
(nw || (nw = [])).push(new MarkedSpan(marker, span.from, endsAfter ? null : span.to));
|
|
}
|
|
}
|
|
return nw;
|
|
}
|
|
function markedSpansAfter(old, endCh, isInsert) {
|
|
var nw;
|
|
if (old) for (var i$3 = 0; i$3 < old.length; ++i$3) {
|
|
var span = old[i$3], marker = span.marker;
|
|
var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= endCh : span.to > endCh);
|
|
if (endsAfter || span.from == endCh && marker.type == "bookmark" && (!isInsert || span.marker.insertLeft)) {
|
|
var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= endCh : span.from < endCh);
|
|
(nw || (nw = [])).push(new MarkedSpan(marker, startsBefore ? null : span.from - endCh, span.to == null ? null : span.to - endCh));
|
|
}
|
|
}
|
|
return nw;
|
|
}
|
|
function stretchSpansOverChange(doc$1, change) {
|
|
if (change.full) return null;
|
|
var oldFirst = isLine(doc$1, change.from.line) && getLine(doc$1, change.from.line).markedSpans;
|
|
var oldLast = isLine(doc$1, change.to.line) && getLine(doc$1, change.to.line).markedSpans;
|
|
if (!oldFirst && !oldLast) return null;
|
|
var startCh = change.from.ch, endCh = change.to.ch, isInsert = cmp(change.from, change.to) == 0;
|
|
var first = markedSpansBefore(oldFirst, startCh, isInsert);
|
|
var last = markedSpansAfter(oldLast, endCh, isInsert);
|
|
var sameLine = change.text.length == 1, offset = lst(change.text).length + (sameLine ? startCh : 0);
|
|
if (first) for (var i$3 = 0; i$3 < first.length; ++i$3) {
|
|
var span = first[i$3];
|
|
if (span.to == null) {
|
|
var found = getMarkedSpanFor(last, span.marker);
|
|
if (!found) span.to = startCh;
|
|
else if (sameLine) span.to = found.to == null ? null : found.to + offset;
|
|
}
|
|
}
|
|
if (last) for (var i$1$1 = 0; i$1$1 < last.length; ++i$1$1) {
|
|
var span$1 = last[i$1$1];
|
|
if (span$1.to != null) span$1.to += offset;
|
|
if (span$1.from == null) {
|
|
var found$1 = getMarkedSpanFor(first, span$1.marker);
|
|
if (!found$1) {
|
|
span$1.from = offset;
|
|
if (sameLine) (first || (first = [])).push(span$1);
|
|
}
|
|
} else {
|
|
span$1.from += offset;
|
|
if (sameLine) (first || (first = [])).push(span$1);
|
|
}
|
|
}
|
|
if (first) first = clearEmptySpans(first);
|
|
if (last && last != first) last = clearEmptySpans(last);
|
|
var newMarkers = [first];
|
|
if (!sameLine) {
|
|
var gap = change.text.length - 2, gapMarkers;
|
|
if (gap > 0 && first) {
|
|
for (var i$2$1 = 0; i$2$1 < first.length; ++i$2$1) if (first[i$2$1].to == null) (gapMarkers || (gapMarkers = [])).push(new MarkedSpan(first[i$2$1].marker, null, null));
|
|
}
|
|
for (var i$3$1 = 0; i$3$1 < gap; ++i$3$1) newMarkers.push(gapMarkers);
|
|
newMarkers.push(last);
|
|
}
|
|
return newMarkers;
|
|
}
|
|
function clearEmptySpans(spans) {
|
|
for (var i$3 = 0; i$3 < spans.length; ++i$3) {
|
|
var span = spans[i$3];
|
|
if (span.from != null && span.from == span.to && span.marker.clearWhenEmpty !== false) spans.splice(i$3--, 1);
|
|
}
|
|
if (!spans.length) return null;
|
|
return spans;
|
|
}
|
|
function removeReadOnlyRanges(doc$1, from, to) {
|
|
var markers = null;
|
|
doc$1.iter(from.line, to.line + 1, function(line) {
|
|
if (line.markedSpans) for (var i$4 = 0; i$4 < line.markedSpans.length; ++i$4) {
|
|
var mark = line.markedSpans[i$4].marker;
|
|
if (mark.readOnly && (!markers || indexOf(markers, mark) == -1)) (markers || (markers = [])).push(mark);
|
|
}
|
|
});
|
|
if (!markers) return null;
|
|
var parts = [{
|
|
from,
|
|
to
|
|
}];
|
|
for (var i$3 = 0; i$3 < markers.length; ++i$3) {
|
|
var mk = markers[i$3], m = mk.find(0);
|
|
for (var j = 0; j < parts.length; ++j) {
|
|
var p = parts[j];
|
|
if (cmp(p.to, m.from) < 0 || cmp(p.from, m.to) > 0) continue;
|
|
var newParts = [j, 1], dfrom = cmp(p.from, m.from), dto = cmp(p.to, m.to);
|
|
if (dfrom < 0 || !mk.inclusiveLeft && !dfrom) newParts.push({
|
|
from: p.from,
|
|
to: m.from
|
|
});
|
|
if (dto > 0 || !mk.inclusiveRight && !dto) newParts.push({
|
|
from: m.to,
|
|
to: p.to
|
|
});
|
|
parts.splice.apply(parts, newParts);
|
|
j += newParts.length - 3;
|
|
}
|
|
}
|
|
return parts;
|
|
}
|
|
function detachMarkedSpans(line) {
|
|
var spans = line.markedSpans;
|
|
if (!spans) return;
|
|
for (var i$3 = 0; i$3 < spans.length; ++i$3) spans[i$3].marker.detachLine(line);
|
|
line.markedSpans = null;
|
|
}
|
|
function attachMarkedSpans(line, spans) {
|
|
if (!spans) return;
|
|
for (var i$3 = 0; i$3 < spans.length; ++i$3) spans[i$3].marker.attachLine(line);
|
|
line.markedSpans = spans;
|
|
}
|
|
function extraLeft(marker) {
|
|
return marker.inclusiveLeft ? -1 : 0;
|
|
}
|
|
function extraRight(marker) {
|
|
return marker.inclusiveRight ? 1 : 0;
|
|
}
|
|
function compareCollapsedMarkers(a, b) {
|
|
var lenDiff = a.lines.length - b.lines.length;
|
|
if (lenDiff != 0) return lenDiff;
|
|
var aPos = a.find(), bPos = b.find();
|
|
var fromCmp = cmp(aPos.from, bPos.from) || extraLeft(a) - extraLeft(b);
|
|
if (fromCmp) return -fromCmp;
|
|
var toCmp = cmp(aPos.to, bPos.to) || extraRight(a) - extraRight(b);
|
|
if (toCmp) return toCmp;
|
|
return b.id - a.id;
|
|
}
|
|
function collapsedSpanAtSide(line, start) {
|
|
var sps = sawCollapsedSpans && line.markedSpans, found;
|
|
if (sps) for (var sp = void 0, i$3 = 0; i$3 < sps.length; ++i$3) {
|
|
sp = sps[i$3];
|
|
if (sp.marker.collapsed && (start ? sp.from : sp.to) == null && (!found || compareCollapsedMarkers(found, sp.marker) < 0)) found = sp.marker;
|
|
}
|
|
return found;
|
|
}
|
|
function collapsedSpanAtStart(line) {
|
|
return collapsedSpanAtSide(line, true);
|
|
}
|
|
function collapsedSpanAtEnd(line) {
|
|
return collapsedSpanAtSide(line, false);
|
|
}
|
|
function collapsedSpanAround(line, ch) {
|
|
var sps = sawCollapsedSpans && line.markedSpans, found;
|
|
if (sps) for (var i$3 = 0; i$3 < sps.length; ++i$3) {
|
|
var sp = sps[i$3];
|
|
if (sp.marker.collapsed && (sp.from == null || sp.from < ch) && (sp.to == null || sp.to > ch) && (!found || compareCollapsedMarkers(found, sp.marker) < 0)) found = sp.marker;
|
|
}
|
|
return found;
|
|
}
|
|
function conflictingCollapsedRange(doc$1, lineNo$1, from, to, marker) {
|
|
var line = getLine(doc$1, lineNo$1);
|
|
var sps = sawCollapsedSpans && line.markedSpans;
|
|
if (sps) for (var i$3 = 0; i$3 < sps.length; ++i$3) {
|
|
var sp = sps[i$3];
|
|
if (!sp.marker.collapsed) continue;
|
|
var found = sp.marker.find(0);
|
|
var fromCmp = cmp(found.from, from) || extraLeft(sp.marker) - extraLeft(marker);
|
|
var toCmp = cmp(found.to, to) || extraRight(sp.marker) - extraRight(marker);
|
|
if (fromCmp >= 0 && toCmp <= 0 || fromCmp <= 0 && toCmp >= 0) continue;
|
|
if (fromCmp <= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.to, from) >= 0 : cmp(found.to, from) > 0) || fromCmp >= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.from, to) <= 0 : cmp(found.from, to) < 0)) return true;
|
|
}
|
|
}
|
|
function visualLine(line) {
|
|
var merged;
|
|
while (merged = collapsedSpanAtStart(line)) line = merged.find(-1, true).line;
|
|
return line;
|
|
}
|
|
function visualLineEnd(line) {
|
|
var merged;
|
|
while (merged = collapsedSpanAtEnd(line)) line = merged.find(1, true).line;
|
|
return line;
|
|
}
|
|
function visualLineContinued(line) {
|
|
var merged, lines;
|
|
while (merged = collapsedSpanAtEnd(line)) {
|
|
line = merged.find(1, true).line;
|
|
(lines || (lines = [])).push(line);
|
|
}
|
|
return lines;
|
|
}
|
|
function visualLineNo(doc$1, lineN) {
|
|
var line = getLine(doc$1, lineN), vis = visualLine(line);
|
|
if (line == vis) return lineN;
|
|
return lineNo(vis);
|
|
}
|
|
function visualLineEndNo(doc$1, lineN) {
|
|
if (lineN > doc$1.lastLine()) return lineN;
|
|
var line = getLine(doc$1, lineN), merged;
|
|
if (!lineIsHidden(doc$1, line)) return lineN;
|
|
while (merged = collapsedSpanAtEnd(line)) line = merged.find(1, true).line;
|
|
return lineNo(line) + 1;
|
|
}
|
|
function lineIsHidden(doc$1, line) {
|
|
var sps = sawCollapsedSpans && line.markedSpans;
|
|
if (sps) for (var sp = void 0, i$3 = 0; i$3 < sps.length; ++i$3) {
|
|
sp = sps[i$3];
|
|
if (!sp.marker.collapsed) continue;
|
|
if (sp.from == null) return true;
|
|
if (sp.marker.widgetNode) continue;
|
|
if (sp.from == 0 && sp.marker.inclusiveLeft && lineIsHiddenInner(doc$1, line, sp)) return true;
|
|
}
|
|
}
|
|
function lineIsHiddenInner(doc$1, line, span) {
|
|
if (span.to == null) {
|
|
var end = span.marker.find(1, true);
|
|
return lineIsHiddenInner(doc$1, end.line, getMarkedSpanFor(end.line.markedSpans, span.marker));
|
|
}
|
|
if (span.marker.inclusiveRight && span.to == line.text.length) return true;
|
|
for (var sp = void 0, i$3 = 0; i$3 < line.markedSpans.length; ++i$3) {
|
|
sp = line.markedSpans[i$3];
|
|
if (sp.marker.collapsed && !sp.marker.widgetNode && sp.from == span.to && (sp.to == null || sp.to != span.from) && (sp.marker.inclusiveLeft || span.marker.inclusiveRight) && lineIsHiddenInner(doc$1, line, sp)) return true;
|
|
}
|
|
}
|
|
function heightAtLine(lineObj) {
|
|
lineObj = visualLine(lineObj);
|
|
var h$1 = 0, chunk = lineObj.parent;
|
|
for (var i$3 = 0; i$3 < chunk.lines.length; ++i$3) {
|
|
var line = chunk.lines[i$3];
|
|
if (line == lineObj) break;
|
|
else h$1 += line.height;
|
|
}
|
|
for (var p = chunk.parent; p; chunk = p, p = chunk.parent) for (var i$1$1 = 0; i$1$1 < p.children.length; ++i$1$1) {
|
|
var cur = p.children[i$1$1];
|
|
if (cur == chunk) break;
|
|
else h$1 += cur.height;
|
|
}
|
|
return h$1;
|
|
}
|
|
function lineLength(line) {
|
|
if (line.height == 0) return 0;
|
|
var len = line.text.length, merged, cur = line;
|
|
while (merged = collapsedSpanAtStart(cur)) {
|
|
var found = merged.find(0, true);
|
|
cur = found.from.line;
|
|
len += found.from.ch - found.to.ch;
|
|
}
|
|
cur = line;
|
|
while (merged = collapsedSpanAtEnd(cur)) {
|
|
var found$1 = merged.find(0, true);
|
|
len -= cur.text.length - found$1.from.ch;
|
|
cur = found$1.to.line;
|
|
len += cur.text.length - found$1.to.ch;
|
|
}
|
|
return len;
|
|
}
|
|
function findMaxLine(cm) {
|
|
var d = cm.display, doc$1 = cm.doc;
|
|
d.maxLine = getLine(doc$1, doc$1.first);
|
|
d.maxLineLength = lineLength(d.maxLine);
|
|
d.maxLineChanged = true;
|
|
doc$1.iter(function(line) {
|
|
var len = lineLength(line);
|
|
if (len > d.maxLineLength) {
|
|
d.maxLineLength = len;
|
|
d.maxLine = line;
|
|
}
|
|
});
|
|
}
|
|
var Line = function(text, markedSpans, estimateHeight$1) {
|
|
this.text = text;
|
|
attachMarkedSpans(this, markedSpans);
|
|
this.height = estimateHeight$1 ? estimateHeight$1(this) : 1;
|
|
};
|
|
Line.prototype.lineNo = function() {
|
|
return lineNo(this);
|
|
};
|
|
eventMixin(Line);
|
|
function updateLine(line, text, markedSpans, estimateHeight$1) {
|
|
line.text = text;
|
|
if (line.stateAfter) line.stateAfter = null;
|
|
if (line.styles) line.styles = null;
|
|
if (line.order != null) line.order = null;
|
|
detachMarkedSpans(line);
|
|
attachMarkedSpans(line, markedSpans);
|
|
var estHeight = estimateHeight$1 ? estimateHeight$1(line) : 1;
|
|
if (estHeight != line.height) updateLineHeight(line, estHeight);
|
|
}
|
|
function cleanUpLine(line) {
|
|
line.parent = null;
|
|
detachMarkedSpans(line);
|
|
}
|
|
var styleToClassCache = {}, styleToClassCacheWithMode = {};
|
|
function interpretTokenStyle(style, options) {
|
|
if (!style || /^\s*$/.test(style)) return null;
|
|
var cache = options.addModeClass ? styleToClassCacheWithMode : styleToClassCache;
|
|
return cache[style] || (cache[style] = style.replace(/\S+/g, "cm-$&"));
|
|
}
|
|
function buildLineContent(cm, lineView) {
|
|
var content = eltP("span", null, null, webkit ? "padding-right: .1px" : null);
|
|
var builder = {
|
|
pre: eltP("pre", [content], "CodeMirror-line"),
|
|
content,
|
|
col: 0,
|
|
pos: 0,
|
|
cm,
|
|
trailingSpace: false,
|
|
splitSpaces: cm.getOption("lineWrapping")
|
|
};
|
|
lineView.measure = {};
|
|
for (var i$3 = 0; i$3 <= (lineView.rest ? lineView.rest.length : 0); i$3++) {
|
|
var line = i$3 ? lineView.rest[i$3 - 1] : lineView.line, order = void 0;
|
|
builder.pos = 0;
|
|
builder.addToken = buildToken;
|
|
if (hasBadBidiRects(cm.display.measure) && (order = getOrder(line, cm.doc.direction))) builder.addToken = buildTokenBadBidi(builder.addToken, order);
|
|
builder.map = [];
|
|
var allowFrontierUpdate = lineView != cm.display.externalMeasured && lineNo(line);
|
|
insertLineContent(line, builder, getLineStyles(cm, line, allowFrontierUpdate));
|
|
if (line.styleClasses) {
|
|
if (line.styleClasses.bgClass) builder.bgClass = joinClasses(line.styleClasses.bgClass, builder.bgClass || "");
|
|
if (line.styleClasses.textClass) builder.textClass = joinClasses(line.styleClasses.textClass, builder.textClass || "");
|
|
}
|
|
if (builder.map.length == 0) builder.map.push(0, 0, builder.content.appendChild(zeroWidthElement(cm.display.measure)));
|
|
if (i$3 == 0) {
|
|
lineView.measure.map = builder.map;
|
|
lineView.measure.cache = {};
|
|
} else {
|
|
(lineView.measure.maps || (lineView.measure.maps = [])).push(builder.map);
|
|
(lineView.measure.caches || (lineView.measure.caches = [])).push({});
|
|
}
|
|
}
|
|
if (webkit) {
|
|
var last = builder.content.lastChild;
|
|
if (/\bcm-tab\b/.test(last.className) || last.querySelector && last.querySelector(".cm-tab")) builder.content.className = "cm-tab-wrap-hack";
|
|
}
|
|
signal(cm, "renderLine", cm, lineView.line, builder.pre);
|
|
if (builder.pre.className) builder.textClass = joinClasses(builder.pre.className, builder.textClass || "");
|
|
return builder;
|
|
}
|
|
function defaultSpecialCharPlaceholder(ch) {
|
|
var token = elt("span", "•", "cm-invalidchar");
|
|
token.title = "\\u" + ch.charCodeAt(0).toString(16);
|
|
token.setAttribute("aria-label", token.title);
|
|
return token;
|
|
}
|
|
function buildToken(builder, text, style, startStyle, endStyle, css, attributes) {
|
|
if (!text) return;
|
|
var displayText = builder.splitSpaces ? splitSpaces(text, builder.trailingSpace) : text;
|
|
var special = builder.cm.state.specialChars, mustWrap = false;
|
|
var content;
|
|
if (!special.test(text)) {
|
|
builder.col += text.length;
|
|
content = document.createTextNode(displayText);
|
|
builder.map.push(builder.pos, builder.pos + text.length, content);
|
|
if (ie && ie_version < 9) mustWrap = true;
|
|
builder.pos += text.length;
|
|
} else {
|
|
content = document.createDocumentFragment();
|
|
var pos = 0;
|
|
while (true) {
|
|
special.lastIndex = pos;
|
|
var m = special.exec(text);
|
|
var skipped = m ? m.index - pos : text.length - pos;
|
|
if (skipped) {
|
|
var txt = document.createTextNode(displayText.slice(pos, pos + skipped));
|
|
if (ie && ie_version < 9) content.appendChild(elt("span", [txt]));
|
|
else content.appendChild(txt);
|
|
builder.map.push(builder.pos, builder.pos + skipped, txt);
|
|
builder.col += skipped;
|
|
builder.pos += skipped;
|
|
}
|
|
if (!m) break;
|
|
pos += skipped + 1;
|
|
var txt$1 = void 0;
|
|
if (m[0] == " ") {
|
|
var tabSize = builder.cm.options.tabSize, tabWidth = tabSize - builder.col % tabSize;
|
|
txt$1 = content.appendChild(elt("span", spaceStr(tabWidth), "cm-tab"));
|
|
txt$1.setAttribute("role", "presentation");
|
|
txt$1.setAttribute("cm-text", " ");
|
|
builder.col += tabWidth;
|
|
} else if (m[0] == "\r" || m[0] == "\n") {
|
|
txt$1 = content.appendChild(elt("span", m[0] == "\r" ? "␍" : "", "cm-invalidchar"));
|
|
txt$1.setAttribute("cm-text", m[0]);
|
|
builder.col += 1;
|
|
} else {
|
|
txt$1 = builder.cm.options.specialCharPlaceholder(m[0]);
|
|
txt$1.setAttribute("cm-text", m[0]);
|
|
if (ie && ie_version < 9) content.appendChild(elt("span", [txt$1]));
|
|
else content.appendChild(txt$1);
|
|
builder.col += 1;
|
|
}
|
|
builder.map.push(builder.pos, builder.pos + 1, txt$1);
|
|
builder.pos++;
|
|
}
|
|
}
|
|
builder.trailingSpace = displayText.charCodeAt(text.length - 1) == 32;
|
|
if (style || startStyle || endStyle || mustWrap || css || attributes) {
|
|
var fullStyle = style || "";
|
|
if (startStyle) fullStyle += startStyle;
|
|
if (endStyle) fullStyle += endStyle;
|
|
var token = elt("span", [content], fullStyle, css);
|
|
if (attributes) {
|
|
for (var attr in attributes) if (attributes.hasOwnProperty(attr) && attr != "style" && attr != "class") token.setAttribute(attr, attributes[attr]);
|
|
}
|
|
return builder.content.appendChild(token);
|
|
}
|
|
builder.content.appendChild(content);
|
|
}
|
|
function splitSpaces(text, trailingBefore) {
|
|
if (text.length > 1 && !/ /.test(text)) return text;
|
|
var spaceBefore = trailingBefore, result = "";
|
|
for (var i$3 = 0; i$3 < text.length; i$3++) {
|
|
var ch = text.charAt(i$3);
|
|
if (ch == " " && spaceBefore && (i$3 == text.length - 1 || text.charCodeAt(i$3 + 1) == 32)) ch = "\xA0";
|
|
result += ch;
|
|
spaceBefore = ch == " ";
|
|
}
|
|
return result;
|
|
}
|
|
function buildTokenBadBidi(inner, order) {
|
|
return function(builder, text, style, startStyle, endStyle, css, attributes) {
|
|
style = style ? style + " cm-force-border" : "cm-force-border";
|
|
var start = builder.pos, end = start + text.length;
|
|
for (;;) {
|
|
var part = void 0;
|
|
for (var i$3 = 0; i$3 < order.length; i$3++) {
|
|
part = order[i$3];
|
|
if (part.to > start && part.from <= start) break;
|
|
}
|
|
if (part.to >= end) return inner(builder, text, style, startStyle, endStyle, css, attributes);
|
|
inner(builder, text.slice(0, part.to - start), style, startStyle, null, css, attributes);
|
|
startStyle = null;
|
|
text = text.slice(part.to - start);
|
|
start = part.to;
|
|
}
|
|
};
|
|
}
|
|
function buildCollapsedSpan(builder, size, marker, ignoreWidget) {
|
|
var widget = !ignoreWidget && marker.widgetNode;
|
|
if (widget) builder.map.push(builder.pos, builder.pos + size, widget);
|
|
if (!ignoreWidget && builder.cm.display.input.needsContentAttribute) {
|
|
if (!widget) widget = builder.content.appendChild(document.createElement("span"));
|
|
widget.setAttribute("cm-marker", marker.id);
|
|
}
|
|
if (widget) {
|
|
builder.cm.display.input.setUneditable(widget);
|
|
builder.content.appendChild(widget);
|
|
}
|
|
builder.pos += size;
|
|
builder.trailingSpace = false;
|
|
}
|
|
function insertLineContent(line, builder, styles) {
|
|
var spans = line.markedSpans, allText = line.text, at = 0;
|
|
if (!spans) {
|
|
for (var i$1$1 = 1; i$1$1 < styles.length; i$1$1 += 2) builder.addToken(builder, allText.slice(at, at = styles[i$1$1]), interpretTokenStyle(styles[i$1$1 + 1], builder.cm.options));
|
|
return;
|
|
}
|
|
var len = allText.length, pos = 0, i$3 = 1, text = "", style, css;
|
|
var nextChange = 0, spanStyle, spanEndStyle, spanStartStyle, collapsed, attributes;
|
|
for (;;) {
|
|
if (nextChange == pos) {
|
|
spanStyle = spanEndStyle = spanStartStyle = css = "";
|
|
attributes = null;
|
|
collapsed = null;
|
|
nextChange = Infinity;
|
|
var foundBookmarks = [], endStyles = void 0;
|
|
for (var j = 0; j < spans.length; ++j) {
|
|
var sp = spans[j], m = sp.marker;
|
|
if (m.type == "bookmark" && sp.from == pos && m.widgetNode) foundBookmarks.push(m);
|
|
else if (sp.from <= pos && (sp.to == null || sp.to > pos || m.collapsed && sp.to == pos && sp.from == pos)) {
|
|
if (sp.to != null && sp.to != pos && nextChange > sp.to) {
|
|
nextChange = sp.to;
|
|
spanEndStyle = "";
|
|
}
|
|
if (m.className) spanStyle += " " + m.className;
|
|
if (m.css) css = (css ? css + ";" : "") + m.css;
|
|
if (m.startStyle && sp.from == pos) spanStartStyle += " " + m.startStyle;
|
|
if (m.endStyle && sp.to == nextChange) (endStyles || (endStyles = [])).push(m.endStyle, sp.to);
|
|
if (m.title) (attributes || (attributes = {})).title = m.title;
|
|
if (m.attributes) for (var attr in m.attributes) (attributes || (attributes = {}))[attr] = m.attributes[attr];
|
|
if (m.collapsed && (!collapsed || compareCollapsedMarkers(collapsed.marker, m) < 0)) collapsed = sp;
|
|
} else if (sp.from > pos && nextChange > sp.from) nextChange = sp.from;
|
|
}
|
|
if (endStyles) {
|
|
for (var j$1 = 0; j$1 < endStyles.length; j$1 += 2) if (endStyles[j$1 + 1] == nextChange) spanEndStyle += " " + endStyles[j$1];
|
|
}
|
|
if (!collapsed || collapsed.from == pos) for (var j$2 = 0; j$2 < foundBookmarks.length; ++j$2) buildCollapsedSpan(builder, 0, foundBookmarks[j$2]);
|
|
if (collapsed && (collapsed.from || 0) == pos) {
|
|
buildCollapsedSpan(builder, (collapsed.to == null ? len + 1 : collapsed.to) - pos, collapsed.marker, collapsed.from == null);
|
|
if (collapsed.to == null) return;
|
|
if (collapsed.to == pos) collapsed = false;
|
|
}
|
|
}
|
|
if (pos >= len) break;
|
|
var upto = Math.min(len, nextChange);
|
|
while (true) {
|
|
if (text) {
|
|
var end = pos + text.length;
|
|
if (!collapsed) {
|
|
var tokenText = end > upto ? text.slice(0, upto - pos) : text;
|
|
builder.addToken(builder, tokenText, style ? style + spanStyle : spanStyle, spanStartStyle, pos + tokenText.length == nextChange ? spanEndStyle : "", css, attributes);
|
|
}
|
|
if (end >= upto) {
|
|
text = text.slice(upto - pos);
|
|
pos = upto;
|
|
break;
|
|
}
|
|
pos = end;
|
|
spanStartStyle = "";
|
|
}
|
|
text = allText.slice(at, at = styles[i$3++]);
|
|
style = interpretTokenStyle(styles[i$3++], builder.cm.options);
|
|
}
|
|
}
|
|
}
|
|
function LineView(doc$1, line, lineN) {
|
|
this.line = line;
|
|
this.rest = visualLineContinued(line);
|
|
this.size = this.rest ? lineNo(lst(this.rest)) - lineN + 1 : 1;
|
|
this.node = this.text = null;
|
|
this.hidden = lineIsHidden(doc$1, line);
|
|
}
|
|
function buildViewArray(cm, from, to) {
|
|
var array = [], nextPos;
|
|
for (var pos = from; pos < to; pos = nextPos) {
|
|
var view = new LineView(cm.doc, getLine(cm.doc, pos), pos);
|
|
nextPos = pos + view.size;
|
|
array.push(view);
|
|
}
|
|
return array;
|
|
}
|
|
var operationGroup = null;
|
|
function pushOperation(op) {
|
|
if (operationGroup) operationGroup.ops.push(op);
|
|
else op.ownsGroup = operationGroup = {
|
|
ops: [op],
|
|
delayedCallbacks: []
|
|
};
|
|
}
|
|
function fireCallbacksForOps(group) {
|
|
var callbacks = group.delayedCallbacks, i$3 = 0;
|
|
do {
|
|
for (; i$3 < callbacks.length; i$3++) callbacks[i$3].call(null);
|
|
for (var j = 0; j < group.ops.length; j++) {
|
|
var op = group.ops[j];
|
|
if (op.cursorActivityHandlers) while (op.cursorActivityCalled < op.cursorActivityHandlers.length) op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm);
|
|
}
|
|
} while (i$3 < callbacks.length);
|
|
}
|
|
function finishOperation(op, endCb) {
|
|
var group = op.ownsGroup;
|
|
if (!group) return;
|
|
try {
|
|
fireCallbacksForOps(group);
|
|
} finally {
|
|
operationGroup = null;
|
|
endCb(group);
|
|
}
|
|
}
|
|
var orphanDelayedCallbacks = null;
|
|
function signalLater(emitter, type) {
|
|
var arr = getHandlers(emitter, type);
|
|
if (!arr.length) return;
|
|
var args = Array.prototype.slice.call(arguments, 2), list;
|
|
if (operationGroup) list = operationGroup.delayedCallbacks;
|
|
else if (orphanDelayedCallbacks) list = orphanDelayedCallbacks;
|
|
else {
|
|
list = orphanDelayedCallbacks = [];
|
|
setTimeout(fireOrphanDelayed, 0);
|
|
}
|
|
var loop = function(i$4) {
|
|
list.push(function() {
|
|
return arr[i$4].apply(null, args);
|
|
});
|
|
};
|
|
for (var i$3 = 0; i$3 < arr.length; ++i$3) loop(i$3);
|
|
}
|
|
function fireOrphanDelayed() {
|
|
var delayed = orphanDelayedCallbacks;
|
|
orphanDelayedCallbacks = null;
|
|
for (var i$3 = 0; i$3 < delayed.length; ++i$3) delayed[i$3]();
|
|
}
|
|
function updateLineForChanges(cm, lineView, lineN, dims) {
|
|
for (var j = 0; j < lineView.changes.length; j++) {
|
|
var type = lineView.changes[j];
|
|
if (type == "text") updateLineText(cm, lineView);
|
|
else if (type == "gutter") updateLineGutter(cm, lineView, lineN, dims);
|
|
else if (type == "class") updateLineClasses(cm, lineView);
|
|
else if (type == "widget") updateLineWidgets(cm, lineView, dims);
|
|
}
|
|
lineView.changes = null;
|
|
}
|
|
function ensureLineWrapped(lineView) {
|
|
if (lineView.node == lineView.text) {
|
|
lineView.node = elt("div", null, null, "position: relative");
|
|
if (lineView.text.parentNode) lineView.text.parentNode.replaceChild(lineView.node, lineView.text);
|
|
lineView.node.appendChild(lineView.text);
|
|
if (ie && ie_version < 8) lineView.node.style.zIndex = 2;
|
|
}
|
|
return lineView.node;
|
|
}
|
|
function updateLineBackground(cm, lineView) {
|
|
var cls = lineView.bgClass ? lineView.bgClass + " " + (lineView.line.bgClass || "") : lineView.line.bgClass;
|
|
if (cls) cls += " CodeMirror-linebackground";
|
|
if (lineView.background) if (cls) lineView.background.className = cls;
|
|
else {
|
|
lineView.background.parentNode.removeChild(lineView.background);
|
|
lineView.background = null;
|
|
}
|
|
else if (cls) {
|
|
var wrap$1 = ensureLineWrapped(lineView);
|
|
lineView.background = wrap$1.insertBefore(elt("div", null, cls), wrap$1.firstChild);
|
|
cm.display.input.setUneditable(lineView.background);
|
|
}
|
|
}
|
|
function getLineContent(cm, lineView) {
|
|
var ext = cm.display.externalMeasured;
|
|
if (ext && ext.line == lineView.line) {
|
|
cm.display.externalMeasured = null;
|
|
lineView.measure = ext.measure;
|
|
return ext.built;
|
|
}
|
|
return buildLineContent(cm, lineView);
|
|
}
|
|
function updateLineText(cm, lineView) {
|
|
var cls = lineView.text.className;
|
|
var built = getLineContent(cm, lineView);
|
|
if (lineView.text == lineView.node) lineView.node = built.pre;
|
|
lineView.text.parentNode.replaceChild(built.pre, lineView.text);
|
|
lineView.text = built.pre;
|
|
if (built.bgClass != lineView.bgClass || built.textClass != lineView.textClass) {
|
|
lineView.bgClass = built.bgClass;
|
|
lineView.textClass = built.textClass;
|
|
updateLineClasses(cm, lineView);
|
|
} else if (cls) lineView.text.className = cls;
|
|
}
|
|
function updateLineClasses(cm, lineView) {
|
|
updateLineBackground(cm, lineView);
|
|
if (lineView.line.wrapClass) ensureLineWrapped(lineView).className = lineView.line.wrapClass;
|
|
else if (lineView.node != lineView.text) lineView.node.className = "";
|
|
var textClass = lineView.textClass ? lineView.textClass + " " + (lineView.line.textClass || "") : lineView.line.textClass;
|
|
lineView.text.className = textClass || "";
|
|
}
|
|
function updateLineGutter(cm, lineView, lineN, dims) {
|
|
if (lineView.gutter) {
|
|
lineView.node.removeChild(lineView.gutter);
|
|
lineView.gutter = null;
|
|
}
|
|
if (lineView.gutterBackground) {
|
|
lineView.node.removeChild(lineView.gutterBackground);
|
|
lineView.gutterBackground = null;
|
|
}
|
|
if (lineView.line.gutterClass) {
|
|
var wrap$1 = ensureLineWrapped(lineView);
|
|
lineView.gutterBackground = elt("div", null, "CodeMirror-gutter-background " + lineView.line.gutterClass, "left: " + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + "px; width: " + dims.gutterTotalWidth + "px");
|
|
cm.display.input.setUneditable(lineView.gutterBackground);
|
|
wrap$1.insertBefore(lineView.gutterBackground, lineView.text);
|
|
}
|
|
var markers = lineView.line.gutterMarkers;
|
|
if (cm.options.lineNumbers || markers) {
|
|
var wrap$1$1 = ensureLineWrapped(lineView);
|
|
var gutterWrap = lineView.gutter = elt("div", null, "CodeMirror-gutter-wrapper", "left: " + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + "px");
|
|
gutterWrap.setAttribute("aria-hidden", "true");
|
|
cm.display.input.setUneditable(gutterWrap);
|
|
wrap$1$1.insertBefore(gutterWrap, lineView.text);
|
|
if (lineView.line.gutterClass) gutterWrap.className += " " + lineView.line.gutterClass;
|
|
if (cm.options.lineNumbers && (!markers || !markers["CodeMirror-linenumbers"])) lineView.lineNumber = gutterWrap.appendChild(elt("div", lineNumberFor(cm.options, lineN), "CodeMirror-linenumber CodeMirror-gutter-elt", "left: " + dims.gutterLeft["CodeMirror-linenumbers"] + "px; width: " + cm.display.lineNumInnerWidth + "px"));
|
|
if (markers) for (var k = 0; k < cm.display.gutterSpecs.length; ++k) {
|
|
var id = cm.display.gutterSpecs[k].className, found = markers.hasOwnProperty(id) && markers[id];
|
|
if (found) gutterWrap.appendChild(elt("div", [found], "CodeMirror-gutter-elt", "left: " + dims.gutterLeft[id] + "px; width: " + dims.gutterWidth[id] + "px"));
|
|
}
|
|
}
|
|
}
|
|
function updateLineWidgets(cm, lineView, dims) {
|
|
if (lineView.alignable) lineView.alignable = null;
|
|
var isWidget = classTest("CodeMirror-linewidget");
|
|
for (var node = lineView.node.firstChild, next = void 0; node; node = next) {
|
|
next = node.nextSibling;
|
|
if (isWidget.test(node.className)) lineView.node.removeChild(node);
|
|
}
|
|
insertLineWidgets(cm, lineView, dims);
|
|
}
|
|
function buildLineElement(cm, lineView, lineN, dims) {
|
|
var built = getLineContent(cm, lineView);
|
|
lineView.text = lineView.node = built.pre;
|
|
if (built.bgClass) lineView.bgClass = built.bgClass;
|
|
if (built.textClass) lineView.textClass = built.textClass;
|
|
updateLineClasses(cm, lineView);
|
|
updateLineGutter(cm, lineView, lineN, dims);
|
|
insertLineWidgets(cm, lineView, dims);
|
|
return lineView.node;
|
|
}
|
|
function insertLineWidgets(cm, lineView, dims) {
|
|
insertLineWidgetsFor(cm, lineView.line, lineView, dims, true);
|
|
if (lineView.rest) for (var i$3 = 0; i$3 < lineView.rest.length; i$3++) insertLineWidgetsFor(cm, lineView.rest[i$3], lineView, dims, false);
|
|
}
|
|
function insertLineWidgetsFor(cm, line, lineView, dims, allowAbove) {
|
|
if (!line.widgets) return;
|
|
var wrap$1 = ensureLineWrapped(lineView);
|
|
for (var i$3 = 0, ws = line.widgets; i$3 < ws.length; ++i$3) {
|
|
var widget = ws[i$3], node = elt("div", [widget.node], "CodeMirror-linewidget" + (widget.className ? " " + widget.className : ""));
|
|
if (!widget.handleMouseEvents) node.setAttribute("cm-ignore-events", "true");
|
|
positionLineWidget(widget, node, lineView, dims);
|
|
cm.display.input.setUneditable(node);
|
|
if (allowAbove && widget.above) wrap$1.insertBefore(node, lineView.gutter || lineView.text);
|
|
else wrap$1.appendChild(node);
|
|
signalLater(widget, "redraw");
|
|
}
|
|
}
|
|
function positionLineWidget(widget, node, lineView, dims) {
|
|
if (widget.noHScroll) {
|
|
(lineView.alignable || (lineView.alignable = [])).push(node);
|
|
var width = dims.wrapperWidth;
|
|
node.style.left = dims.fixedPos + "px";
|
|
if (!widget.coverGutter) {
|
|
width -= dims.gutterTotalWidth;
|
|
node.style.paddingLeft = dims.gutterTotalWidth + "px";
|
|
}
|
|
node.style.width = width + "px";
|
|
}
|
|
if (widget.coverGutter) {
|
|
node.style.zIndex = 5;
|
|
node.style.position = "relative";
|
|
if (!widget.noHScroll) node.style.marginLeft = -dims.gutterTotalWidth + "px";
|
|
}
|
|
}
|
|
function widgetHeight(widget) {
|
|
if (widget.height != null) return widget.height;
|
|
var cm = widget.doc.cm;
|
|
if (!cm) return 0;
|
|
if (!contains(document.body, widget.node)) {
|
|
var parentStyle = "position: relative;";
|
|
if (widget.coverGutter) parentStyle += "margin-left: -" + cm.display.gutters.offsetWidth + "px;";
|
|
if (widget.noHScroll) parentStyle += "width: " + cm.display.wrapper.clientWidth + "px;";
|
|
removeChildrenAndAdd(cm.display.measure, elt("div", [widget.node], null, parentStyle));
|
|
}
|
|
return widget.height = widget.node.parentNode.offsetHeight;
|
|
}
|
|
function eventInWidget(display, e) {
|
|
for (var n = e_target(e); n != display.wrapper; n = n.parentNode) if (!n || n.nodeType == 1 && n.getAttribute("cm-ignore-events") == "true" || n.parentNode == display.sizer && n != display.mover) return true;
|
|
}
|
|
function paddingTop(display) {
|
|
return display.lineSpace.offsetTop;
|
|
}
|
|
function paddingVert(display) {
|
|
return display.mover.offsetHeight - display.lineSpace.offsetHeight;
|
|
}
|
|
function paddingH(display) {
|
|
if (display.cachedPaddingH) return display.cachedPaddingH;
|
|
var e = removeChildrenAndAdd(display.measure, elt("pre", "x", "CodeMirror-line-like"));
|
|
var style = window.getComputedStyle ? window.getComputedStyle(e) : e.currentStyle;
|
|
var data = {
|
|
left: parseInt(style.paddingLeft),
|
|
right: parseInt(style.paddingRight)
|
|
};
|
|
if (!isNaN(data.left) && !isNaN(data.right)) display.cachedPaddingH = data;
|
|
return data;
|
|
}
|
|
function scrollGap(cm) {
|
|
return scrollerGap - cm.display.nativeBarWidth;
|
|
}
|
|
function displayWidth(cm) {
|
|
return cm.display.scroller.clientWidth - scrollGap(cm) - cm.display.barWidth;
|
|
}
|
|
function displayHeight(cm) {
|
|
return cm.display.scroller.clientHeight - scrollGap(cm) - cm.display.barHeight;
|
|
}
|
|
function ensureLineHeights(cm, lineView, rect) {
|
|
var wrapping = cm.options.lineWrapping;
|
|
var curWidth = wrapping && displayWidth(cm);
|
|
if (!lineView.measure.heights || wrapping && lineView.measure.width != curWidth) {
|
|
var heights = lineView.measure.heights = [];
|
|
if (wrapping) {
|
|
lineView.measure.width = curWidth;
|
|
var rects = lineView.text.firstChild.getClientRects();
|
|
for (var i$3 = 0; i$3 < rects.length - 1; i$3++) {
|
|
var cur = rects[i$3], next = rects[i$3 + 1];
|
|
if (Math.abs(cur.bottom - next.bottom) > 2) heights.push((cur.bottom + next.top) / 2 - rect.top);
|
|
}
|
|
}
|
|
heights.push(rect.bottom - rect.top);
|
|
}
|
|
}
|
|
function mapFromLineView(lineView, line, lineN) {
|
|
if (lineView.line == line) return {
|
|
map: lineView.measure.map,
|
|
cache: lineView.measure.cache
|
|
};
|
|
if (lineView.rest) {
|
|
for (var i$3 = 0; i$3 < lineView.rest.length; i$3++) if (lineView.rest[i$3] == line) return {
|
|
map: lineView.measure.maps[i$3],
|
|
cache: lineView.measure.caches[i$3]
|
|
};
|
|
for (var i$1$1 = 0; i$1$1 < lineView.rest.length; i$1$1++) if (lineNo(lineView.rest[i$1$1]) > lineN) return {
|
|
map: lineView.measure.maps[i$1$1],
|
|
cache: lineView.measure.caches[i$1$1],
|
|
before: true
|
|
};
|
|
}
|
|
}
|
|
function updateExternalMeasurement(cm, line) {
|
|
line = visualLine(line);
|
|
var lineN = lineNo(line);
|
|
var view = cm.display.externalMeasured = new LineView(cm.doc, line, lineN);
|
|
view.lineN = lineN;
|
|
var built = view.built = buildLineContent(cm, view);
|
|
view.text = built.pre;
|
|
removeChildrenAndAdd(cm.display.lineMeasure, built.pre);
|
|
return view;
|
|
}
|
|
function measureChar(cm, line, ch, bias) {
|
|
return measureCharPrepared(cm, prepareMeasureForLine(cm, line), ch, bias);
|
|
}
|
|
function findViewForLine(cm, lineN) {
|
|
if (lineN >= cm.display.viewFrom && lineN < cm.display.viewTo) return cm.display.view[findViewIndex(cm, lineN)];
|
|
var ext = cm.display.externalMeasured;
|
|
if (ext && lineN >= ext.lineN && lineN < ext.lineN + ext.size) return ext;
|
|
}
|
|
function prepareMeasureForLine(cm, line) {
|
|
var lineN = lineNo(line);
|
|
var view = findViewForLine(cm, lineN);
|
|
if (view && !view.text) view = null;
|
|
else if (view && view.changes) {
|
|
updateLineForChanges(cm, view, lineN, getDimensions(cm));
|
|
cm.curOp.forceUpdate = true;
|
|
}
|
|
if (!view) view = updateExternalMeasurement(cm, line);
|
|
var info = mapFromLineView(view, line, lineN);
|
|
return {
|
|
line,
|
|
view,
|
|
rect: null,
|
|
map: info.map,
|
|
cache: info.cache,
|
|
before: info.before,
|
|
hasHeights: false
|
|
};
|
|
}
|
|
function measureCharPrepared(cm, prepared, ch, bias, varHeight) {
|
|
if (prepared.before) ch = -1;
|
|
var key = ch + (bias || ""), found;
|
|
if (prepared.cache.hasOwnProperty(key)) found = prepared.cache[key];
|
|
else {
|
|
if (!prepared.rect) prepared.rect = prepared.view.text.getBoundingClientRect();
|
|
if (!prepared.hasHeights) {
|
|
ensureLineHeights(cm, prepared.view, prepared.rect);
|
|
prepared.hasHeights = true;
|
|
}
|
|
found = measureCharInner(cm, prepared, ch, bias);
|
|
if (!found.bogus) prepared.cache[key] = found;
|
|
}
|
|
return {
|
|
left: found.left,
|
|
right: found.right,
|
|
top: varHeight ? found.rtop : found.top,
|
|
bottom: varHeight ? found.rbottom : found.bottom
|
|
};
|
|
}
|
|
var nullRect = {
|
|
left: 0,
|
|
right: 0,
|
|
top: 0,
|
|
bottom: 0
|
|
};
|
|
function nodeAndOffsetInLineMap(map$1, ch, bias) {
|
|
var node, start, end, collapse, mStart, mEnd;
|
|
for (var i$3 = 0; i$3 < map$1.length; i$3 += 3) {
|
|
mStart = map$1[i$3];
|
|
mEnd = map$1[i$3 + 1];
|
|
if (ch < mStart) {
|
|
start = 0;
|
|
end = 1;
|
|
collapse = "left";
|
|
} else if (ch < mEnd) {
|
|
start = ch - mStart;
|
|
end = start + 1;
|
|
} else if (i$3 == map$1.length - 3 || ch == mEnd && map$1[i$3 + 3] > ch) {
|
|
end = mEnd - mStart;
|
|
start = end - 1;
|
|
if (ch >= mEnd) collapse = "right";
|
|
}
|
|
if (start != null) {
|
|
node = map$1[i$3 + 2];
|
|
if (mStart == mEnd && bias == (node.insertLeft ? "left" : "right")) collapse = bias;
|
|
if (bias == "left" && start == 0) while (i$3 && map$1[i$3 - 2] == map$1[i$3 - 3] && map$1[i$3 - 1].insertLeft) {
|
|
node = map$1[(i$3 -= 3) + 2];
|
|
collapse = "left";
|
|
}
|
|
if (bias == "right" && start == mEnd - mStart) while (i$3 < map$1.length - 3 && map$1[i$3 + 3] == map$1[i$3 + 4] && !map$1[i$3 + 5].insertLeft) {
|
|
node = map$1[(i$3 += 3) + 2];
|
|
collapse = "right";
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
return {
|
|
node,
|
|
start,
|
|
end,
|
|
collapse,
|
|
coverStart: mStart,
|
|
coverEnd: mEnd
|
|
};
|
|
}
|
|
function getUsefulRect(rects, bias) {
|
|
var rect = nullRect;
|
|
if (bias == "left") {
|
|
for (var i$3 = 0; i$3 < rects.length; i$3++) if ((rect = rects[i$3]).left != rect.right) break;
|
|
} else for (var i$1$1 = rects.length - 1; i$1$1 >= 0; i$1$1--) if ((rect = rects[i$1$1]).left != rect.right) break;
|
|
return rect;
|
|
}
|
|
function measureCharInner(cm, prepared, ch, bias) {
|
|
var place = nodeAndOffsetInLineMap(prepared.map, ch, bias);
|
|
var node = place.node, start = place.start, end = place.end, collapse = place.collapse;
|
|
var rect;
|
|
if (node.nodeType == 3) {
|
|
for (var i$1$1 = 0; i$1$1 < 4; i$1$1++) {
|
|
while (start && isExtendingChar(prepared.line.text.charAt(place.coverStart + start))) --start;
|
|
while (place.coverStart + end < place.coverEnd && isExtendingChar(prepared.line.text.charAt(place.coverStart + end))) ++end;
|
|
if (ie && ie_version < 9 && start == 0 && end == place.coverEnd - place.coverStart) rect = node.parentNode.getBoundingClientRect();
|
|
else rect = getUsefulRect(range(node, start, end).getClientRects(), bias);
|
|
if (rect.left || rect.right || start == 0) break;
|
|
end = start;
|
|
start = start - 1;
|
|
collapse = "right";
|
|
}
|
|
if (ie && ie_version < 11) rect = maybeUpdateRectForZooming(cm.display.measure, rect);
|
|
} else {
|
|
if (start > 0) collapse = bias = "right";
|
|
var rects;
|
|
if (cm.options.lineWrapping && (rects = node.getClientRects()).length > 1) rect = rects[bias == "right" ? rects.length - 1 : 0];
|
|
else rect = node.getBoundingClientRect();
|
|
}
|
|
if (ie && ie_version < 9 && !start && (!rect || !rect.left && !rect.right)) {
|
|
var rSpan = node.parentNode.getClientRects()[0];
|
|
if (rSpan) rect = {
|
|
left: rSpan.left,
|
|
right: rSpan.left + charWidth(cm.display),
|
|
top: rSpan.top,
|
|
bottom: rSpan.bottom
|
|
};
|
|
else rect = nullRect;
|
|
}
|
|
var rtop = rect.top - prepared.rect.top, rbot = rect.bottom - prepared.rect.top;
|
|
var mid = (rtop + rbot) / 2;
|
|
var heights = prepared.view.measure.heights;
|
|
var i$3 = 0;
|
|
for (; i$3 < heights.length - 1; i$3++) if (mid < heights[i$3]) break;
|
|
var top = i$3 ? heights[i$3 - 1] : 0, bot = heights[i$3];
|
|
var result = {
|
|
left: (collapse == "right" ? rect.right : rect.left) - prepared.rect.left,
|
|
right: (collapse == "left" ? rect.left : rect.right) - prepared.rect.left,
|
|
top,
|
|
bottom: bot
|
|
};
|
|
if (!rect.left && !rect.right) result.bogus = true;
|
|
if (!cm.options.singleCursorHeightPerLine) {
|
|
result.rtop = rtop;
|
|
result.rbottom = rbot;
|
|
}
|
|
return result;
|
|
}
|
|
function maybeUpdateRectForZooming(measure, rect) {
|
|
if (!window.screen || screen.logicalXDPI == null || screen.logicalXDPI == screen.deviceXDPI || !hasBadZoomedRects(measure)) return rect;
|
|
var scaleX = screen.logicalXDPI / screen.deviceXDPI;
|
|
var scaleY = screen.logicalYDPI / screen.deviceYDPI;
|
|
return {
|
|
left: rect.left * scaleX,
|
|
right: rect.right * scaleX,
|
|
top: rect.top * scaleY,
|
|
bottom: rect.bottom * scaleY
|
|
};
|
|
}
|
|
function clearLineMeasurementCacheFor(lineView) {
|
|
if (lineView.measure) {
|
|
lineView.measure.cache = {};
|
|
lineView.measure.heights = null;
|
|
if (lineView.rest) for (var i$3 = 0; i$3 < lineView.rest.length; i$3++) lineView.measure.caches[i$3] = {};
|
|
}
|
|
}
|
|
function clearLineMeasurementCache(cm) {
|
|
cm.display.externalMeasure = null;
|
|
removeChildren(cm.display.lineMeasure);
|
|
for (var i$3 = 0; i$3 < cm.display.view.length; i$3++) clearLineMeasurementCacheFor(cm.display.view[i$3]);
|
|
}
|
|
function clearCaches(cm) {
|
|
clearLineMeasurementCache(cm);
|
|
cm.display.cachedCharWidth = cm.display.cachedTextHeight = cm.display.cachedPaddingH = null;
|
|
if (!cm.options.lineWrapping) cm.display.maxLineChanged = true;
|
|
cm.display.lineNumChars = null;
|
|
}
|
|
function pageScrollX(doc$1) {
|
|
if (chrome && android) return -(doc$1.body.getBoundingClientRect().left - parseInt(getComputedStyle(doc$1.body).marginLeft));
|
|
return doc$1.defaultView.pageXOffset || (doc$1.documentElement || doc$1.body).scrollLeft;
|
|
}
|
|
function pageScrollY(doc$1) {
|
|
if (chrome && android) return -(doc$1.body.getBoundingClientRect().top - parseInt(getComputedStyle(doc$1.body).marginTop));
|
|
return doc$1.defaultView.pageYOffset || (doc$1.documentElement || doc$1.body).scrollTop;
|
|
}
|
|
function widgetTopHeight(lineObj) {
|
|
var ref$1 = visualLine(lineObj);
|
|
var widgets = ref$1.widgets;
|
|
var height = 0;
|
|
if (widgets) {
|
|
for (var i$3 = 0; i$3 < widgets.length; ++i$3) if (widgets[i$3].above) height += widgetHeight(widgets[i$3]);
|
|
}
|
|
return height;
|
|
}
|
|
function intoCoordSystem(cm, lineObj, rect, context, includeWidgets) {
|
|
if (!includeWidgets) {
|
|
var height = widgetTopHeight(lineObj);
|
|
rect.top += height;
|
|
rect.bottom += height;
|
|
}
|
|
if (context == "line") return rect;
|
|
if (!context) context = "local";
|
|
var yOff = heightAtLine(lineObj);
|
|
if (context == "local") yOff += paddingTop(cm.display);
|
|
else yOff -= cm.display.viewOffset;
|
|
if (context == "page" || context == "window") {
|
|
var lOff = cm.display.lineSpace.getBoundingClientRect();
|
|
yOff += lOff.top + (context == "window" ? 0 : pageScrollY(doc(cm)));
|
|
var xOff = lOff.left + (context == "window" ? 0 : pageScrollX(doc(cm)));
|
|
rect.left += xOff;
|
|
rect.right += xOff;
|
|
}
|
|
rect.top += yOff;
|
|
rect.bottom += yOff;
|
|
return rect;
|
|
}
|
|
function fromCoordSystem(cm, coords, context) {
|
|
if (context == "div") return coords;
|
|
var left = coords.left, top = coords.top;
|
|
if (context == "page") {
|
|
left -= pageScrollX(doc(cm));
|
|
top -= pageScrollY(doc(cm));
|
|
} else if (context == "local" || !context) {
|
|
var localBox = cm.display.sizer.getBoundingClientRect();
|
|
left += localBox.left;
|
|
top += localBox.top;
|
|
}
|
|
var lineSpaceBox = cm.display.lineSpace.getBoundingClientRect();
|
|
return {
|
|
left: left - lineSpaceBox.left,
|
|
top: top - lineSpaceBox.top
|
|
};
|
|
}
|
|
function charCoords(cm, pos, context, lineObj, bias) {
|
|
if (!lineObj) lineObj = getLine(cm.doc, pos.line);
|
|
return intoCoordSystem(cm, lineObj, measureChar(cm, lineObj, pos.ch, bias), context);
|
|
}
|
|
function cursorCoords(cm, pos, context, lineObj, preparedMeasure, varHeight) {
|
|
lineObj = lineObj || getLine(cm.doc, pos.line);
|
|
if (!preparedMeasure) preparedMeasure = prepareMeasureForLine(cm, lineObj);
|
|
function get(ch$1, right) {
|
|
var m = measureCharPrepared(cm, preparedMeasure, ch$1, right ? "right" : "left", varHeight);
|
|
if (right) m.left = m.right;
|
|
else m.right = m.left;
|
|
return intoCoordSystem(cm, lineObj, m, context);
|
|
}
|
|
var order = getOrder(lineObj, cm.doc.direction), ch = pos.ch, sticky = pos.sticky;
|
|
if (ch >= lineObj.text.length) {
|
|
ch = lineObj.text.length;
|
|
sticky = "before";
|
|
} else if (ch <= 0) {
|
|
ch = 0;
|
|
sticky = "after";
|
|
}
|
|
if (!order) return get(sticky == "before" ? ch - 1 : ch, sticky == "before");
|
|
function getBidi(ch$1, partPos$1, invert) {
|
|
var part = order[partPos$1], right = part.level == 1;
|
|
return get(invert ? ch$1 - 1 : ch$1, right != invert);
|
|
}
|
|
var partPos = getBidiPartAt(order, ch, sticky);
|
|
var other = bidiOther;
|
|
var val = getBidi(ch, partPos, sticky == "before");
|
|
if (other != null) val.other = getBidi(ch, other, sticky != "before");
|
|
return val;
|
|
}
|
|
function estimateCoords(cm, pos) {
|
|
var left = 0;
|
|
pos = clipPos(cm.doc, pos);
|
|
if (!cm.options.lineWrapping) left = charWidth(cm.display) * pos.ch;
|
|
var lineObj = getLine(cm.doc, pos.line);
|
|
var top = heightAtLine(lineObj) + paddingTop(cm.display);
|
|
return {
|
|
left,
|
|
right: left,
|
|
top,
|
|
bottom: top + lineObj.height
|
|
};
|
|
}
|
|
function PosWithInfo(line, ch, sticky, outside, xRel) {
|
|
var pos = Pos(line, ch, sticky);
|
|
pos.xRel = xRel;
|
|
if (outside) pos.outside = outside;
|
|
return pos;
|
|
}
|
|
function coordsChar(cm, x, y) {
|
|
var doc$1 = cm.doc;
|
|
y += cm.display.viewOffset;
|
|
if (y < 0) return PosWithInfo(doc$1.first, 0, null, -1, -1);
|
|
var lineN = lineAtHeight(doc$1, y), last = doc$1.first + doc$1.size - 1;
|
|
if (lineN > last) return PosWithInfo(doc$1.first + doc$1.size - 1, getLine(doc$1, last).text.length, null, 1, 1);
|
|
if (x < 0) x = 0;
|
|
var lineObj = getLine(doc$1, lineN);
|
|
for (;;) {
|
|
var found = coordsCharInner(cm, lineObj, lineN, x, y);
|
|
var collapsed = collapsedSpanAround(lineObj, found.ch + (found.xRel > 0 || found.outside > 0 ? 1 : 0));
|
|
if (!collapsed) return found;
|
|
var rangeEnd = collapsed.find(1);
|
|
if (rangeEnd.line == lineN) return rangeEnd;
|
|
lineObj = getLine(doc$1, lineN = rangeEnd.line);
|
|
}
|
|
}
|
|
function wrappedLineExtent(cm, lineObj, preparedMeasure, y) {
|
|
y -= widgetTopHeight(lineObj);
|
|
var end = lineObj.text.length;
|
|
var begin = findFirst(function(ch) {
|
|
return measureCharPrepared(cm, preparedMeasure, ch - 1).bottom <= y;
|
|
}, end, 0);
|
|
end = findFirst(function(ch) {
|
|
return measureCharPrepared(cm, preparedMeasure, ch).top > y;
|
|
}, begin, end);
|
|
return {
|
|
begin,
|
|
end
|
|
};
|
|
}
|
|
function wrappedLineExtentChar(cm, lineObj, preparedMeasure, target) {
|
|
if (!preparedMeasure) preparedMeasure = prepareMeasureForLine(cm, lineObj);
|
|
var targetTop = intoCoordSystem(cm, lineObj, measureCharPrepared(cm, preparedMeasure, target), "line").top;
|
|
return wrappedLineExtent(cm, lineObj, preparedMeasure, targetTop);
|
|
}
|
|
function boxIsAfter(box, x, y, left) {
|
|
return box.bottom <= y ? false : box.top > y ? true : (left ? box.left : box.right) > x;
|
|
}
|
|
function coordsCharInner(cm, lineObj, lineNo$1, x, y) {
|
|
y -= heightAtLine(lineObj);
|
|
var preparedMeasure = prepareMeasureForLine(cm, lineObj);
|
|
var widgetHeight$1 = widgetTopHeight(lineObj);
|
|
var begin = 0, end = lineObj.text.length, ltr = true;
|
|
var order = getOrder(lineObj, cm.doc.direction);
|
|
if (order) {
|
|
var part = (cm.options.lineWrapping ? coordsBidiPartWrapped : coordsBidiPart)(cm, lineObj, lineNo$1, preparedMeasure, order, x, y);
|
|
ltr = part.level != 1;
|
|
begin = ltr ? part.from : part.to - 1;
|
|
end = ltr ? part.to : part.from - 1;
|
|
}
|
|
var chAround = null, boxAround = null;
|
|
var ch = findFirst(function(ch$1) {
|
|
var box = measureCharPrepared(cm, preparedMeasure, ch$1);
|
|
box.top += widgetHeight$1;
|
|
box.bottom += widgetHeight$1;
|
|
if (!boxIsAfter(box, x, y, false)) return false;
|
|
if (box.top <= y && box.left <= x) {
|
|
chAround = ch$1;
|
|
boxAround = box;
|
|
}
|
|
return true;
|
|
}, begin, end);
|
|
var baseX, sticky, outside = false;
|
|
if (boxAround) {
|
|
var atLeft = x - boxAround.left < boxAround.right - x, atStart = atLeft == ltr;
|
|
ch = chAround + (atStart ? 0 : 1);
|
|
sticky = atStart ? "after" : "before";
|
|
baseX = atLeft ? boxAround.left : boxAround.right;
|
|
} else {
|
|
if (!ltr && (ch == end || ch == begin)) ch++;
|
|
sticky = ch == 0 ? "after" : ch == lineObj.text.length ? "before" : measureCharPrepared(cm, preparedMeasure, ch - (ltr ? 1 : 0)).bottom + widgetHeight$1 <= y == ltr ? "after" : "before";
|
|
var coords = cursorCoords(cm, Pos(lineNo$1, ch, sticky), "line", lineObj, preparedMeasure);
|
|
baseX = coords.left;
|
|
outside = y < coords.top ? -1 : y >= coords.bottom ? 1 : 0;
|
|
}
|
|
ch = skipExtendingChars(lineObj.text, ch, 1);
|
|
return PosWithInfo(lineNo$1, ch, sticky, outside, x - baseX);
|
|
}
|
|
function coordsBidiPart(cm, lineObj, lineNo$1, preparedMeasure, order, x, y) {
|
|
var index = findFirst(function(i$3) {
|
|
var part$1 = order[i$3], ltr$1 = part$1.level != 1;
|
|
return boxIsAfter(cursorCoords(cm, Pos(lineNo$1, ltr$1 ? part$1.to : part$1.from, ltr$1 ? "before" : "after"), "line", lineObj, preparedMeasure), x, y, true);
|
|
}, 0, order.length - 1);
|
|
var part = order[index];
|
|
if (index > 0) {
|
|
var ltr = part.level != 1;
|
|
var start = cursorCoords(cm, Pos(lineNo$1, ltr ? part.from : part.to, ltr ? "after" : "before"), "line", lineObj, preparedMeasure);
|
|
if (boxIsAfter(start, x, y, true) && start.top > y) part = order[index - 1];
|
|
}
|
|
return part;
|
|
}
|
|
function coordsBidiPartWrapped(cm, lineObj, _lineNo, preparedMeasure, order, x, y) {
|
|
var ref$1 = wrappedLineExtent(cm, lineObj, preparedMeasure, y);
|
|
var begin = ref$1.begin;
|
|
var end = ref$1.end;
|
|
if (/\s/.test(lineObj.text.charAt(end - 1))) end--;
|
|
var part = null, closestDist = null;
|
|
for (var i$3 = 0; i$3 < order.length; i$3++) {
|
|
var p = order[i$3];
|
|
if (p.from >= end || p.to <= begin) continue;
|
|
var ltr = p.level != 1;
|
|
var endX = measureCharPrepared(cm, preparedMeasure, ltr ? Math.min(end, p.to) - 1 : Math.max(begin, p.from)).right;
|
|
var dist = endX < x ? x - endX + 1e9 : endX - x;
|
|
if (!part || closestDist > dist) {
|
|
part = p;
|
|
closestDist = dist;
|
|
}
|
|
}
|
|
if (!part) part = order[order.length - 1];
|
|
if (part.from < begin) part = {
|
|
from: begin,
|
|
to: part.to,
|
|
level: part.level
|
|
};
|
|
if (part.to > end) part = {
|
|
from: part.from,
|
|
to: end,
|
|
level: part.level
|
|
};
|
|
return part;
|
|
}
|
|
var measureText;
|
|
function textHeight(display) {
|
|
if (display.cachedTextHeight != null) return display.cachedTextHeight;
|
|
if (measureText == null) {
|
|
measureText = elt("pre", null, "CodeMirror-line-like");
|
|
for (var i$3 = 0; i$3 < 49; ++i$3) {
|
|
measureText.appendChild(document.createTextNode("x"));
|
|
measureText.appendChild(elt("br"));
|
|
}
|
|
measureText.appendChild(document.createTextNode("x"));
|
|
}
|
|
removeChildrenAndAdd(display.measure, measureText);
|
|
var height = measureText.offsetHeight / 50;
|
|
if (height > 3) display.cachedTextHeight = height;
|
|
removeChildren(display.measure);
|
|
return height || 1;
|
|
}
|
|
function charWidth(display) {
|
|
if (display.cachedCharWidth != null) return display.cachedCharWidth;
|
|
var anchor = elt("span", "xxxxxxxxxx");
|
|
var pre = elt("pre", [anchor], "CodeMirror-line-like");
|
|
removeChildrenAndAdd(display.measure, pre);
|
|
var rect = anchor.getBoundingClientRect(), width = (rect.right - rect.left) / 10;
|
|
if (width > 2) display.cachedCharWidth = width;
|
|
return width || 10;
|
|
}
|
|
function getDimensions(cm) {
|
|
var d = cm.display, left = {}, width = {};
|
|
var gutterLeft = d.gutters.clientLeft;
|
|
for (var n = d.gutters.firstChild, i$3 = 0; n; n = n.nextSibling, ++i$3) {
|
|
var id = cm.display.gutterSpecs[i$3].className;
|
|
left[id] = n.offsetLeft + n.clientLeft + gutterLeft;
|
|
width[id] = n.clientWidth;
|
|
}
|
|
return {
|
|
fixedPos: compensateForHScroll(d),
|
|
gutterTotalWidth: d.gutters.offsetWidth,
|
|
gutterLeft: left,
|
|
gutterWidth: width,
|
|
wrapperWidth: d.wrapper.clientWidth
|
|
};
|
|
}
|
|
function compensateForHScroll(display) {
|
|
return display.scroller.getBoundingClientRect().left - display.sizer.getBoundingClientRect().left;
|
|
}
|
|
function estimateHeight(cm) {
|
|
var th = textHeight(cm.display), wrapping = cm.options.lineWrapping;
|
|
var perLine = wrapping && Math.max(5, cm.display.scroller.clientWidth / charWidth(cm.display) - 3);
|
|
return function(line) {
|
|
if (lineIsHidden(cm.doc, line)) return 0;
|
|
var widgetsHeight = 0;
|
|
if (line.widgets) {
|
|
for (var i$3 = 0; i$3 < line.widgets.length; i$3++) if (line.widgets[i$3].height) widgetsHeight += line.widgets[i$3].height;
|
|
}
|
|
if (wrapping) return widgetsHeight + (Math.ceil(line.text.length / perLine) || 1) * th;
|
|
else return widgetsHeight + th;
|
|
};
|
|
}
|
|
function estimateLineHeights(cm) {
|
|
var doc$1 = cm.doc, est = estimateHeight(cm);
|
|
doc$1.iter(function(line) {
|
|
var estHeight = est(line);
|
|
if (estHeight != line.height) updateLineHeight(line, estHeight);
|
|
});
|
|
}
|
|
function posFromMouse(cm, e, liberal, forRect) {
|
|
var display = cm.display;
|
|
if (!liberal && e_target(e).getAttribute("cm-not-content") == "true") return null;
|
|
var x, y, space = display.lineSpace.getBoundingClientRect();
|
|
try {
|
|
x = e.clientX - space.left;
|
|
y = e.clientY - space.top;
|
|
} catch (e$1) {
|
|
return null;
|
|
}
|
|
var coords = coordsChar(cm, x, y), line;
|
|
if (forRect && coords.xRel > 0 && (line = getLine(cm.doc, coords.line).text).length == coords.ch) {
|
|
var colDiff = countColumn(line, line.length, cm.options.tabSize) - line.length;
|
|
coords = Pos(coords.line, Math.max(0, Math.round((x - paddingH(cm.display).left) / charWidth(cm.display)) - colDiff));
|
|
}
|
|
return coords;
|
|
}
|
|
function findViewIndex(cm, n) {
|
|
if (n >= cm.display.viewTo) return null;
|
|
n -= cm.display.viewFrom;
|
|
if (n < 0) return null;
|
|
var view = cm.display.view;
|
|
for (var i$3 = 0; i$3 < view.length; i$3++) {
|
|
n -= view[i$3].size;
|
|
if (n < 0) return i$3;
|
|
}
|
|
}
|
|
function regChange(cm, from, to, lendiff) {
|
|
if (from == null) from = cm.doc.first;
|
|
if (to == null) to = cm.doc.first + cm.doc.size;
|
|
if (!lendiff) lendiff = 0;
|
|
var display = cm.display;
|
|
if (lendiff && to < display.viewTo && (display.updateLineNumbers == null || display.updateLineNumbers > from)) display.updateLineNumbers = from;
|
|
cm.curOp.viewChanged = true;
|
|
if (from >= display.viewTo) {
|
|
if (sawCollapsedSpans && visualLineNo(cm.doc, from) < display.viewTo) resetView(cm);
|
|
} else if (to <= display.viewFrom) if (sawCollapsedSpans && visualLineEndNo(cm.doc, to + lendiff) > display.viewFrom) resetView(cm);
|
|
else {
|
|
display.viewFrom += lendiff;
|
|
display.viewTo += lendiff;
|
|
}
|
|
else if (from <= display.viewFrom && to >= display.viewTo) resetView(cm);
|
|
else if (from <= display.viewFrom) {
|
|
var cut = viewCuttingPoint(cm, to, to + lendiff, 1);
|
|
if (cut) {
|
|
display.view = display.view.slice(cut.index);
|
|
display.viewFrom = cut.lineN;
|
|
display.viewTo += lendiff;
|
|
} else resetView(cm);
|
|
} else if (to >= display.viewTo) {
|
|
var cut$1 = viewCuttingPoint(cm, from, from, -1);
|
|
if (cut$1) {
|
|
display.view = display.view.slice(0, cut$1.index);
|
|
display.viewTo = cut$1.lineN;
|
|
} else resetView(cm);
|
|
} else {
|
|
var cutTop = viewCuttingPoint(cm, from, from, -1);
|
|
var cutBot = viewCuttingPoint(cm, to, to + lendiff, 1);
|
|
if (cutTop && cutBot) {
|
|
display.view = display.view.slice(0, cutTop.index).concat(buildViewArray(cm, cutTop.lineN, cutBot.lineN)).concat(display.view.slice(cutBot.index));
|
|
display.viewTo += lendiff;
|
|
} else resetView(cm);
|
|
}
|
|
var ext = display.externalMeasured;
|
|
if (ext) {
|
|
if (to < ext.lineN) ext.lineN += lendiff;
|
|
else if (from < ext.lineN + ext.size) display.externalMeasured = null;
|
|
}
|
|
}
|
|
function regLineChange(cm, line, type) {
|
|
cm.curOp.viewChanged = true;
|
|
var display = cm.display, ext = cm.display.externalMeasured;
|
|
if (ext && line >= ext.lineN && line < ext.lineN + ext.size) display.externalMeasured = null;
|
|
if (line < display.viewFrom || line >= display.viewTo) return;
|
|
var lineView = display.view[findViewIndex(cm, line)];
|
|
if (lineView.node == null) return;
|
|
var arr = lineView.changes || (lineView.changes = []);
|
|
if (indexOf(arr, type) == -1) arr.push(type);
|
|
}
|
|
function resetView(cm) {
|
|
cm.display.viewFrom = cm.display.viewTo = cm.doc.first;
|
|
cm.display.view = [];
|
|
cm.display.viewOffset = 0;
|
|
}
|
|
function viewCuttingPoint(cm, oldN, newN, dir) {
|
|
var index = findViewIndex(cm, oldN), diff, view = cm.display.view;
|
|
if (!sawCollapsedSpans || newN == cm.doc.first + cm.doc.size) return {
|
|
index,
|
|
lineN: newN
|
|
};
|
|
var n = cm.display.viewFrom;
|
|
for (var i$3 = 0; i$3 < index; i$3++) n += view[i$3].size;
|
|
if (n != oldN) {
|
|
if (dir > 0) {
|
|
if (index == view.length - 1) return null;
|
|
diff = n + view[index].size - oldN;
|
|
index++;
|
|
} else diff = n - oldN;
|
|
oldN += diff;
|
|
newN += diff;
|
|
}
|
|
while (visualLineNo(cm.doc, newN) != newN) {
|
|
if (index == (dir < 0 ? 0 : view.length - 1)) return null;
|
|
newN += dir * view[index - (dir < 0 ? 1 : 0)].size;
|
|
index += dir;
|
|
}
|
|
return {
|
|
index,
|
|
lineN: newN
|
|
};
|
|
}
|
|
function adjustView(cm, from, to) {
|
|
var display = cm.display, view = display.view;
|
|
if (view.length == 0 || from >= display.viewTo || to <= display.viewFrom) {
|
|
display.view = buildViewArray(cm, from, to);
|
|
display.viewFrom = from;
|
|
} else {
|
|
if (display.viewFrom > from) display.view = buildViewArray(cm, from, display.viewFrom).concat(display.view);
|
|
else if (display.viewFrom < from) display.view = display.view.slice(findViewIndex(cm, from));
|
|
display.viewFrom = from;
|
|
if (display.viewTo < to) display.view = display.view.concat(buildViewArray(cm, display.viewTo, to));
|
|
else if (display.viewTo > to) display.view = display.view.slice(0, findViewIndex(cm, to));
|
|
}
|
|
display.viewTo = to;
|
|
}
|
|
function countDirtyView(cm) {
|
|
var view = cm.display.view, dirty = 0;
|
|
for (var i$3 = 0; i$3 < view.length; i$3++) {
|
|
var lineView = view[i$3];
|
|
if (!lineView.hidden && (!lineView.node || lineView.changes)) ++dirty;
|
|
}
|
|
return dirty;
|
|
}
|
|
function updateSelection(cm) {
|
|
cm.display.input.showSelection(cm.display.input.prepareSelection());
|
|
}
|
|
function prepareSelection(cm, primary) {
|
|
if (primary === void 0) primary = true;
|
|
var doc$1 = cm.doc, result = {};
|
|
var curFragment = result.cursors = document.createDocumentFragment();
|
|
var selFragment = result.selection = document.createDocumentFragment();
|
|
var customCursor = cm.options.$customCursor;
|
|
if (customCursor) primary = true;
|
|
for (var i$3 = 0; i$3 < doc$1.sel.ranges.length; i$3++) {
|
|
if (!primary && i$3 == doc$1.sel.primIndex) continue;
|
|
var range$1 = doc$1.sel.ranges[i$3];
|
|
if (range$1.from().line >= cm.display.viewTo || range$1.to().line < cm.display.viewFrom) continue;
|
|
var collapsed = range$1.empty();
|
|
if (customCursor) {
|
|
var head = customCursor(cm, range$1);
|
|
if (head) drawSelectionCursor(cm, head, curFragment);
|
|
} else if (collapsed || cm.options.showCursorWhenSelecting) drawSelectionCursor(cm, range$1.head, curFragment);
|
|
if (!collapsed) drawSelectionRange(cm, range$1, selFragment);
|
|
}
|
|
return result;
|
|
}
|
|
function drawSelectionCursor(cm, head, output) {
|
|
var pos = cursorCoords(cm, head, "div", null, null, !cm.options.singleCursorHeightPerLine);
|
|
var cursor = output.appendChild(elt("div", "\xA0", "CodeMirror-cursor"));
|
|
cursor.style.left = pos.left + "px";
|
|
cursor.style.top = pos.top + "px";
|
|
cursor.style.height = Math.max(0, pos.bottom - pos.top) * cm.options.cursorHeight + "px";
|
|
if (/\bcm-fat-cursor\b/.test(cm.getWrapperElement().className)) {
|
|
var charPos = charCoords(cm, head, "div", null, null);
|
|
var width = charPos.right - charPos.left;
|
|
cursor.style.width = (width > 0 ? width : cm.defaultCharWidth()) + "px";
|
|
}
|
|
if (pos.other) {
|
|
var otherCursor = output.appendChild(elt("div", "\xA0", "CodeMirror-cursor CodeMirror-secondarycursor"));
|
|
otherCursor.style.display = "";
|
|
otherCursor.style.left = pos.other.left + "px";
|
|
otherCursor.style.top = pos.other.top + "px";
|
|
otherCursor.style.height = (pos.other.bottom - pos.other.top) * .85 + "px";
|
|
}
|
|
}
|
|
function cmpCoords(a, b) {
|
|
return a.top - b.top || a.left - b.left;
|
|
}
|
|
function drawSelectionRange(cm, range$1, output) {
|
|
var display = cm.display, doc$1 = cm.doc;
|
|
var fragment = document.createDocumentFragment();
|
|
var padding = paddingH(cm.display), leftSide = padding.left;
|
|
var rightSide = Math.max(display.sizerWidth, displayWidth(cm) - display.sizer.offsetLeft) - padding.right;
|
|
var docLTR = doc$1.direction == "ltr";
|
|
function add(left, top, width, bottom) {
|
|
if (top < 0) top = 0;
|
|
top = Math.round(top);
|
|
bottom = Math.round(bottom);
|
|
fragment.appendChild(elt("div", null, "CodeMirror-selected", "position: absolute; left: " + left + "px;\n top: " + top + "px; width: " + (width == null ? rightSide - left : width) + "px;\n height: " + (bottom - top) + "px"));
|
|
}
|
|
function drawForLine(line, fromArg, toArg) {
|
|
var lineObj = getLine(doc$1, line);
|
|
var lineLen = lineObj.text.length;
|
|
var start, end;
|
|
function coords(ch, bias) {
|
|
return charCoords(cm, Pos(line, ch), "div", lineObj, bias);
|
|
}
|
|
function wrapX(pos, dir, side) {
|
|
var extent = wrappedLineExtentChar(cm, lineObj, null, pos);
|
|
var prop$1 = dir == "ltr" == (side == "after") ? "left" : "right";
|
|
var ch = side == "after" ? extent.begin : extent.end - (/\s/.test(lineObj.text.charAt(extent.end - 1)) ? 2 : 1);
|
|
return coords(ch, prop$1)[prop$1];
|
|
}
|
|
var order = getOrder(lineObj, doc$1.direction);
|
|
iterateBidiSections(order, fromArg || 0, toArg == null ? lineLen : toArg, function(from, to, dir, i$3) {
|
|
var ltr = dir == "ltr";
|
|
var fromPos = coords(from, ltr ? "left" : "right");
|
|
var toPos = coords(to - 1, ltr ? "right" : "left");
|
|
var openStart = fromArg == null && from == 0, openEnd = toArg == null && to == lineLen;
|
|
var first = i$3 == 0, last = !order || i$3 == order.length - 1;
|
|
if (toPos.top - fromPos.top <= 3) {
|
|
var openLeft = (docLTR ? openStart : openEnd) && first;
|
|
var openRight = (docLTR ? openEnd : openStart) && last;
|
|
var left = openLeft ? leftSide : (ltr ? fromPos : toPos).left;
|
|
var right = openRight ? rightSide : (ltr ? toPos : fromPos).right;
|
|
add(left, fromPos.top, right - left, fromPos.bottom);
|
|
} else {
|
|
var topLeft, topRight, botLeft, botRight;
|
|
if (ltr) {
|
|
topLeft = docLTR && openStart && first ? leftSide : fromPos.left;
|
|
topRight = docLTR ? rightSide : wrapX(from, dir, "before");
|
|
botLeft = docLTR ? leftSide : wrapX(to, dir, "after");
|
|
botRight = docLTR && openEnd && last ? rightSide : toPos.right;
|
|
} else {
|
|
topLeft = !docLTR ? leftSide : wrapX(from, dir, "before");
|
|
topRight = !docLTR && openStart && first ? rightSide : fromPos.right;
|
|
botLeft = !docLTR && openEnd && last ? leftSide : toPos.left;
|
|
botRight = !docLTR ? rightSide : wrapX(to, dir, "after");
|
|
}
|
|
add(topLeft, fromPos.top, topRight - topLeft, fromPos.bottom);
|
|
if (fromPos.bottom < toPos.top) add(leftSide, fromPos.bottom, null, toPos.top);
|
|
add(botLeft, toPos.top, botRight - botLeft, toPos.bottom);
|
|
}
|
|
if (!start || cmpCoords(fromPos, start) < 0) start = fromPos;
|
|
if (cmpCoords(toPos, start) < 0) start = toPos;
|
|
if (!end || cmpCoords(fromPos, end) < 0) end = fromPos;
|
|
if (cmpCoords(toPos, end) < 0) end = toPos;
|
|
});
|
|
return {
|
|
start,
|
|
end
|
|
};
|
|
}
|
|
var sFrom = range$1.from(), sTo = range$1.to();
|
|
if (sFrom.line == sTo.line) drawForLine(sFrom.line, sFrom.ch, sTo.ch);
|
|
else {
|
|
var fromLine = getLine(doc$1, sFrom.line), toLine = getLine(doc$1, sTo.line);
|
|
var singleVLine = visualLine(fromLine) == visualLine(toLine);
|
|
var leftEnd = drawForLine(sFrom.line, sFrom.ch, singleVLine ? fromLine.text.length + 1 : null).end;
|
|
var rightStart = drawForLine(sTo.line, singleVLine ? 0 : null, sTo.ch).start;
|
|
if (singleVLine) if (leftEnd.top < rightStart.top - 2) {
|
|
add(leftEnd.right, leftEnd.top, null, leftEnd.bottom);
|
|
add(leftSide, rightStart.top, rightStart.left, rightStart.bottom);
|
|
} else add(leftEnd.right, leftEnd.top, rightStart.left - leftEnd.right, leftEnd.bottom);
|
|
if (leftEnd.bottom < rightStart.top) add(leftSide, leftEnd.bottom, null, rightStart.top);
|
|
}
|
|
output.appendChild(fragment);
|
|
}
|
|
function restartBlink(cm) {
|
|
if (!cm.state.focused) return;
|
|
var display = cm.display;
|
|
clearInterval(display.blinker);
|
|
var on$1 = true;
|
|
display.cursorDiv.style.visibility = "";
|
|
if (cm.options.cursorBlinkRate > 0) display.blinker = setInterval(function() {
|
|
if (!cm.hasFocus()) onBlur(cm);
|
|
display.cursorDiv.style.visibility = (on$1 = !on$1) ? "" : "hidden";
|
|
}, cm.options.cursorBlinkRate);
|
|
else if (cm.options.cursorBlinkRate < 0) display.cursorDiv.style.visibility = "hidden";
|
|
}
|
|
function ensureFocus(cm) {
|
|
if (!cm.hasFocus()) {
|
|
cm.display.input.focus();
|
|
if (!cm.state.focused) onFocus(cm);
|
|
}
|
|
}
|
|
function delayBlurEvent(cm) {
|
|
cm.state.delayingBlurEvent = true;
|
|
setTimeout(function() {
|
|
if (cm.state.delayingBlurEvent) {
|
|
cm.state.delayingBlurEvent = false;
|
|
if (cm.state.focused) onBlur(cm);
|
|
}
|
|
}, 100);
|
|
}
|
|
function onFocus(cm, e) {
|
|
if (cm.state.delayingBlurEvent && !cm.state.draggingText) cm.state.delayingBlurEvent = false;
|
|
if (cm.options.readOnly == "nocursor") return;
|
|
if (!cm.state.focused) {
|
|
signal(cm, "focus", cm, e);
|
|
cm.state.focused = true;
|
|
addClass(cm.display.wrapper, "CodeMirror-focused");
|
|
if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) {
|
|
cm.display.input.reset();
|
|
if (webkit) setTimeout(function() {
|
|
return cm.display.input.reset(true);
|
|
}, 20);
|
|
}
|
|
cm.display.input.receivedFocus();
|
|
}
|
|
restartBlink(cm);
|
|
}
|
|
function onBlur(cm, e) {
|
|
if (cm.state.delayingBlurEvent) return;
|
|
if (cm.state.focused) {
|
|
signal(cm, "blur", cm, e);
|
|
cm.state.focused = false;
|
|
rmClass(cm.display.wrapper, "CodeMirror-focused");
|
|
}
|
|
clearInterval(cm.display.blinker);
|
|
setTimeout(function() {
|
|
if (!cm.state.focused) cm.display.shift = false;
|
|
}, 150);
|
|
}
|
|
function updateHeightsInViewport(cm) {
|
|
var display = cm.display;
|
|
var prevBottom = display.lineDiv.offsetTop;
|
|
var viewTop = Math.max(0, display.scroller.getBoundingClientRect().top);
|
|
var oldHeight = display.lineDiv.getBoundingClientRect().top;
|
|
var mustScroll = 0;
|
|
for (var i$3 = 0; i$3 < display.view.length; i$3++) {
|
|
var cur = display.view[i$3], wrapping = cm.options.lineWrapping;
|
|
var height = void 0, width = 0;
|
|
if (cur.hidden) continue;
|
|
oldHeight += cur.line.height;
|
|
if (ie && ie_version < 8) {
|
|
var bot = cur.node.offsetTop + cur.node.offsetHeight;
|
|
height = bot - prevBottom;
|
|
prevBottom = bot;
|
|
} else {
|
|
var box = cur.node.getBoundingClientRect();
|
|
height = box.bottom - box.top;
|
|
if (!wrapping && cur.text.firstChild) width = cur.text.firstChild.getBoundingClientRect().right - box.left - 1;
|
|
}
|
|
var diff = cur.line.height - height;
|
|
if (diff > .005 || diff < -.005) {
|
|
if (oldHeight < viewTop) mustScroll -= diff;
|
|
updateLineHeight(cur.line, height);
|
|
updateWidgetHeight(cur.line);
|
|
if (cur.rest) for (var j = 0; j < cur.rest.length; j++) updateWidgetHeight(cur.rest[j]);
|
|
}
|
|
if (width > cm.display.sizerWidth) {
|
|
var chWidth = Math.ceil(width / charWidth(cm.display));
|
|
if (chWidth > cm.display.maxLineLength) {
|
|
cm.display.maxLineLength = chWidth;
|
|
cm.display.maxLine = cur.line;
|
|
cm.display.maxLineChanged = true;
|
|
}
|
|
}
|
|
}
|
|
if (Math.abs(mustScroll) > 2) display.scroller.scrollTop += mustScroll;
|
|
}
|
|
function updateWidgetHeight(line) {
|
|
if (line.widgets) for (var i$3 = 0; i$3 < line.widgets.length; ++i$3) {
|
|
var w = line.widgets[i$3], parent = w.node.parentNode;
|
|
if (parent) w.height = parent.offsetHeight;
|
|
}
|
|
}
|
|
function visibleLines(display, doc$1, viewport) {
|
|
var top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop;
|
|
top = Math.floor(top - paddingTop(display));
|
|
var bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight;
|
|
var from = lineAtHeight(doc$1, top), to = lineAtHeight(doc$1, bottom);
|
|
if (viewport && viewport.ensure) {
|
|
var ensureFrom = viewport.ensure.from.line, ensureTo = viewport.ensure.to.line;
|
|
if (ensureFrom < from) {
|
|
from = ensureFrom;
|
|
to = lineAtHeight(doc$1, heightAtLine(getLine(doc$1, ensureFrom)) + display.wrapper.clientHeight);
|
|
} else if (Math.min(ensureTo, doc$1.lastLine()) >= to) {
|
|
from = lineAtHeight(doc$1, heightAtLine(getLine(doc$1, ensureTo)) - display.wrapper.clientHeight);
|
|
to = ensureTo;
|
|
}
|
|
}
|
|
return {
|
|
from,
|
|
to: Math.max(to, from + 1)
|
|
};
|
|
}
|
|
function maybeScrollWindow(cm, rect) {
|
|
if (signalDOMEvent(cm, "scrollCursorIntoView")) return;
|
|
var display = cm.display, box = display.sizer.getBoundingClientRect(), doScroll = null;
|
|
var doc$1 = display.wrapper.ownerDocument;
|
|
if (rect.top + box.top < 0) doScroll = true;
|
|
else if (rect.bottom + box.top > (doc$1.defaultView.innerHeight || doc$1.documentElement.clientHeight)) doScroll = false;
|
|
if (doScroll != null && !phantom) {
|
|
var scrollNode = elt("div", "", null, "position: absolute;\n top: " + (rect.top - display.viewOffset - paddingTop(cm.display)) + "px;\n height: " + (rect.bottom - rect.top + scrollGap(cm) + display.barHeight) + "px;\n left: " + rect.left + "px; width: " + Math.max(2, rect.right - rect.left) + "px;");
|
|
cm.display.lineSpace.appendChild(scrollNode);
|
|
scrollNode.scrollIntoView(doScroll);
|
|
cm.display.lineSpace.removeChild(scrollNode);
|
|
}
|
|
}
|
|
function scrollPosIntoView(cm, pos, end, margin) {
|
|
if (margin == null) margin = 0;
|
|
var rect;
|
|
if (!cm.options.lineWrapping && pos == end) {
|
|
end = pos.sticky == "before" ? Pos(pos.line, pos.ch + 1, "before") : pos;
|
|
pos = pos.ch ? Pos(pos.line, pos.sticky == "before" ? pos.ch - 1 : pos.ch, "after") : pos;
|
|
}
|
|
for (var limit = 0; limit < 5; limit++) {
|
|
var changed = false;
|
|
var coords = cursorCoords(cm, pos);
|
|
var endCoords = !end || end == pos ? coords : cursorCoords(cm, end);
|
|
rect = {
|
|
left: Math.min(coords.left, endCoords.left),
|
|
top: Math.min(coords.top, endCoords.top) - margin,
|
|
right: Math.max(coords.left, endCoords.left),
|
|
bottom: Math.max(coords.bottom, endCoords.bottom) + margin
|
|
};
|
|
var scrollPos = calculateScrollPos(cm, rect);
|
|
var startTop = cm.doc.scrollTop, startLeft = cm.doc.scrollLeft;
|
|
if (scrollPos.scrollTop != null) {
|
|
updateScrollTop(cm, scrollPos.scrollTop);
|
|
if (Math.abs(cm.doc.scrollTop - startTop) > 1) changed = true;
|
|
}
|
|
if (scrollPos.scrollLeft != null) {
|
|
setScrollLeft(cm, scrollPos.scrollLeft);
|
|
if (Math.abs(cm.doc.scrollLeft - startLeft) > 1) changed = true;
|
|
}
|
|
if (!changed) break;
|
|
}
|
|
return rect;
|
|
}
|
|
function scrollIntoView(cm, rect) {
|
|
var scrollPos = calculateScrollPos(cm, rect);
|
|
if (scrollPos.scrollTop != null) updateScrollTop(cm, scrollPos.scrollTop);
|
|
if (scrollPos.scrollLeft != null) setScrollLeft(cm, scrollPos.scrollLeft);
|
|
}
|
|
function calculateScrollPos(cm, rect) {
|
|
var display = cm.display, snapMargin = textHeight(cm.display);
|
|
if (rect.top < 0) rect.top = 0;
|
|
var screentop = cm.curOp && cm.curOp.scrollTop != null ? cm.curOp.scrollTop : display.scroller.scrollTop;
|
|
var screen$1 = displayHeight(cm), result = {};
|
|
if (rect.bottom - rect.top > screen$1) rect.bottom = rect.top + screen$1;
|
|
var docBottom = cm.doc.height + paddingVert(display);
|
|
var atTop = rect.top < snapMargin, atBottom = rect.bottom > docBottom - snapMargin;
|
|
if (rect.top < screentop) result.scrollTop = atTop ? 0 : rect.top;
|
|
else if (rect.bottom > screentop + screen$1) {
|
|
var newTop = Math.min(rect.top, (atBottom ? docBottom : rect.bottom) - screen$1);
|
|
if (newTop != screentop) result.scrollTop = newTop;
|
|
}
|
|
var gutterSpace = cm.options.fixedGutter ? 0 : display.gutters.offsetWidth;
|
|
var screenleft = cm.curOp && cm.curOp.scrollLeft != null ? cm.curOp.scrollLeft : display.scroller.scrollLeft - gutterSpace;
|
|
var screenw = displayWidth(cm) - display.gutters.offsetWidth;
|
|
var tooWide = rect.right - rect.left > screenw;
|
|
if (tooWide) rect.right = rect.left + screenw;
|
|
if (rect.left < 10) result.scrollLeft = 0;
|
|
else if (rect.left < screenleft) result.scrollLeft = Math.max(0, rect.left + gutterSpace - (tooWide ? 0 : 10));
|
|
else if (rect.right > screenw + screenleft - 3) result.scrollLeft = rect.right + (tooWide ? 0 : 10) - screenw;
|
|
return result;
|
|
}
|
|
function addToScrollTop(cm, top) {
|
|
if (top == null) return;
|
|
resolveScrollToPos(cm);
|
|
cm.curOp.scrollTop = (cm.curOp.scrollTop == null ? cm.doc.scrollTop : cm.curOp.scrollTop) + top;
|
|
}
|
|
function ensureCursorVisible(cm) {
|
|
resolveScrollToPos(cm);
|
|
var cur = cm.getCursor();
|
|
cm.curOp.scrollToPos = {
|
|
from: cur,
|
|
to: cur,
|
|
margin: cm.options.cursorScrollMargin
|
|
};
|
|
}
|
|
function scrollToCoords(cm, x, y) {
|
|
if (x != null || y != null) resolveScrollToPos(cm);
|
|
if (x != null) cm.curOp.scrollLeft = x;
|
|
if (y != null) cm.curOp.scrollTop = y;
|
|
}
|
|
function scrollToRange(cm, range$1) {
|
|
resolveScrollToPos(cm);
|
|
cm.curOp.scrollToPos = range$1;
|
|
}
|
|
function resolveScrollToPos(cm) {
|
|
var range$1 = cm.curOp.scrollToPos;
|
|
if (range$1) {
|
|
cm.curOp.scrollToPos = null;
|
|
var from = estimateCoords(cm, range$1.from), to = estimateCoords(cm, range$1.to);
|
|
scrollToCoordsRange(cm, from, to, range$1.margin);
|
|
}
|
|
}
|
|
function scrollToCoordsRange(cm, from, to, margin) {
|
|
var sPos = calculateScrollPos(cm, {
|
|
left: Math.min(from.left, to.left),
|
|
top: Math.min(from.top, to.top) - margin,
|
|
right: Math.max(from.right, to.right),
|
|
bottom: Math.max(from.bottom, to.bottom) + margin
|
|
});
|
|
scrollToCoords(cm, sPos.scrollLeft, sPos.scrollTop);
|
|
}
|
|
function updateScrollTop(cm, val) {
|
|
if (Math.abs(cm.doc.scrollTop - val) < 2) return;
|
|
if (!gecko) updateDisplaySimple(cm, { top: val });
|
|
setScrollTop(cm, val, true);
|
|
if (gecko) updateDisplaySimple(cm);
|
|
startWorker(cm, 100);
|
|
}
|
|
function setScrollTop(cm, val, forceScroll) {
|
|
val = Math.max(0, Math.min(cm.display.scroller.scrollHeight - cm.display.scroller.clientHeight, val));
|
|
if (cm.display.scroller.scrollTop == val && !forceScroll) return;
|
|
cm.doc.scrollTop = val;
|
|
cm.display.scrollbars.setScrollTop(val);
|
|
if (cm.display.scroller.scrollTop != val) cm.display.scroller.scrollTop = val;
|
|
}
|
|
function setScrollLeft(cm, val, isScroller, forceScroll) {
|
|
val = Math.max(0, Math.min(val, cm.display.scroller.scrollWidth - cm.display.scroller.clientWidth));
|
|
if ((isScroller ? val == cm.doc.scrollLeft : Math.abs(cm.doc.scrollLeft - val) < 2) && !forceScroll) return;
|
|
cm.doc.scrollLeft = val;
|
|
alignHorizontally(cm);
|
|
if (cm.display.scroller.scrollLeft != val) cm.display.scroller.scrollLeft = val;
|
|
cm.display.scrollbars.setScrollLeft(val);
|
|
}
|
|
function measureForScrollbars(cm) {
|
|
var d = cm.display, gutterW = d.gutters.offsetWidth;
|
|
var docH = Math.round(cm.doc.height + paddingVert(cm.display));
|
|
return {
|
|
clientHeight: d.scroller.clientHeight,
|
|
viewHeight: d.wrapper.clientHeight,
|
|
scrollWidth: d.scroller.scrollWidth,
|
|
clientWidth: d.scroller.clientWidth,
|
|
viewWidth: d.wrapper.clientWidth,
|
|
barLeft: cm.options.fixedGutter ? gutterW : 0,
|
|
docHeight: docH,
|
|
scrollHeight: docH + scrollGap(cm) + d.barHeight,
|
|
nativeBarWidth: d.nativeBarWidth,
|
|
gutterWidth: gutterW
|
|
};
|
|
}
|
|
var NativeScrollbars = function(place, scroll, cm) {
|
|
this.cm = cm;
|
|
var vert = this.vert = elt("div", [elt("div", null, null, "min-width: 1px")], "CodeMirror-vscrollbar");
|
|
var horiz = this.horiz = elt("div", [elt("div", null, null, "height: 100%; min-height: 1px")], "CodeMirror-hscrollbar");
|
|
vert.tabIndex = horiz.tabIndex = -1;
|
|
place(vert);
|
|
place(horiz);
|
|
on(vert, "scroll", function() {
|
|
if (vert.clientHeight) scroll(vert.scrollTop, "vertical");
|
|
});
|
|
on(horiz, "scroll", function() {
|
|
if (horiz.clientWidth) scroll(horiz.scrollLeft, "horizontal");
|
|
});
|
|
this.checkedZeroWidth = false;
|
|
if (ie && ie_version < 8) this.horiz.style.minHeight = this.vert.style.minWidth = "18px";
|
|
};
|
|
NativeScrollbars.prototype.update = function(measure) {
|
|
var needsH = measure.scrollWidth > measure.clientWidth + 1;
|
|
var needsV = measure.scrollHeight > measure.clientHeight + 1;
|
|
var sWidth = measure.nativeBarWidth;
|
|
if (needsV) {
|
|
this.vert.style.display = "block";
|
|
this.vert.style.bottom = needsH ? sWidth + "px" : "0";
|
|
var totalHeight = measure.viewHeight - (needsH ? sWidth : 0);
|
|
this.vert.firstChild.style.height = Math.max(0, measure.scrollHeight - measure.clientHeight + totalHeight) + "px";
|
|
} else {
|
|
this.vert.scrollTop = 0;
|
|
this.vert.style.display = "";
|
|
this.vert.firstChild.style.height = "0";
|
|
}
|
|
if (needsH) {
|
|
this.horiz.style.display = "block";
|
|
this.horiz.style.right = needsV ? sWidth + "px" : "0";
|
|
this.horiz.style.left = measure.barLeft + "px";
|
|
var totalWidth = measure.viewWidth - measure.barLeft - (needsV ? sWidth : 0);
|
|
this.horiz.firstChild.style.width = Math.max(0, measure.scrollWidth - measure.clientWidth + totalWidth) + "px";
|
|
} else {
|
|
this.horiz.style.display = "";
|
|
this.horiz.firstChild.style.width = "0";
|
|
}
|
|
if (!this.checkedZeroWidth && measure.clientHeight > 0) {
|
|
if (sWidth == 0) this.zeroWidthHack();
|
|
this.checkedZeroWidth = true;
|
|
}
|
|
return {
|
|
right: needsV ? sWidth : 0,
|
|
bottom: needsH ? sWidth : 0
|
|
};
|
|
};
|
|
NativeScrollbars.prototype.setScrollLeft = function(pos) {
|
|
if (this.horiz.scrollLeft != pos) this.horiz.scrollLeft = pos;
|
|
if (this.disableHoriz) this.enableZeroWidthBar(this.horiz, this.disableHoriz, "horiz");
|
|
};
|
|
NativeScrollbars.prototype.setScrollTop = function(pos) {
|
|
if (this.vert.scrollTop != pos) this.vert.scrollTop = pos;
|
|
if (this.disableVert) this.enableZeroWidthBar(this.vert, this.disableVert, "vert");
|
|
};
|
|
NativeScrollbars.prototype.zeroWidthHack = function() {
|
|
var w = mac && !mac_geMountainLion ? "12px" : "18px";
|
|
this.horiz.style.height = this.vert.style.width = w;
|
|
this.horiz.style.visibility = this.vert.style.visibility = "hidden";
|
|
this.disableHoriz = new Delayed();
|
|
this.disableVert = new Delayed();
|
|
};
|
|
NativeScrollbars.prototype.enableZeroWidthBar = function(bar, delay, type) {
|
|
bar.style.visibility = "";
|
|
function maybeDisable() {
|
|
var box = bar.getBoundingClientRect();
|
|
var elt$1 = type == "vert" ? document.elementFromPoint(box.right - 1, (box.top + box.bottom) / 2) : document.elementFromPoint((box.right + box.left) / 2, box.bottom - 1);
|
|
if (elt$1 != bar) bar.style.visibility = "hidden";
|
|
else delay.set(1e3, maybeDisable);
|
|
}
|
|
delay.set(1e3, maybeDisable);
|
|
};
|
|
NativeScrollbars.prototype.clear = function() {
|
|
var parent = this.horiz.parentNode;
|
|
parent.removeChild(this.horiz);
|
|
parent.removeChild(this.vert);
|
|
};
|
|
var NullScrollbars = function() {};
|
|
NullScrollbars.prototype.update = function() {
|
|
return {
|
|
bottom: 0,
|
|
right: 0
|
|
};
|
|
};
|
|
NullScrollbars.prototype.setScrollLeft = function() {};
|
|
NullScrollbars.prototype.setScrollTop = function() {};
|
|
NullScrollbars.prototype.clear = function() {};
|
|
function updateScrollbars(cm, measure) {
|
|
if (!measure) measure = measureForScrollbars(cm);
|
|
var startWidth = cm.display.barWidth, startHeight = cm.display.barHeight;
|
|
updateScrollbarsInner(cm, measure);
|
|
for (var i$3 = 0; i$3 < 4 && startWidth != cm.display.barWidth || startHeight != cm.display.barHeight; i$3++) {
|
|
if (startWidth != cm.display.barWidth && cm.options.lineWrapping) updateHeightsInViewport(cm);
|
|
updateScrollbarsInner(cm, measureForScrollbars(cm));
|
|
startWidth = cm.display.barWidth;
|
|
startHeight = cm.display.barHeight;
|
|
}
|
|
}
|
|
function updateScrollbarsInner(cm, measure) {
|
|
var d = cm.display;
|
|
var sizes = d.scrollbars.update(measure);
|
|
d.sizer.style.paddingRight = (d.barWidth = sizes.right) + "px";
|
|
d.sizer.style.paddingBottom = (d.barHeight = sizes.bottom) + "px";
|
|
d.heightForcer.style.borderBottom = sizes.bottom + "px solid transparent";
|
|
if (sizes.right && sizes.bottom) {
|
|
d.scrollbarFiller.style.display = "block";
|
|
d.scrollbarFiller.style.height = sizes.bottom + "px";
|
|
d.scrollbarFiller.style.width = sizes.right + "px";
|
|
} else d.scrollbarFiller.style.display = "";
|
|
if (sizes.bottom && cm.options.coverGutterNextToScrollbar && cm.options.fixedGutter) {
|
|
d.gutterFiller.style.display = "block";
|
|
d.gutterFiller.style.height = sizes.bottom + "px";
|
|
d.gutterFiller.style.width = measure.gutterWidth + "px";
|
|
} else d.gutterFiller.style.display = "";
|
|
}
|
|
var scrollbarModel = {
|
|
"native": NativeScrollbars,
|
|
"null": NullScrollbars
|
|
};
|
|
function initScrollbars(cm) {
|
|
if (cm.display.scrollbars) {
|
|
cm.display.scrollbars.clear();
|
|
if (cm.display.scrollbars.addClass) rmClass(cm.display.wrapper, cm.display.scrollbars.addClass);
|
|
}
|
|
cm.display.scrollbars = new scrollbarModel[cm.options.scrollbarStyle](function(node) {
|
|
cm.display.wrapper.insertBefore(node, cm.display.scrollbarFiller);
|
|
on(node, "mousedown", function() {
|
|
if (cm.state.focused) setTimeout(function() {
|
|
return cm.display.input.focus();
|
|
}, 0);
|
|
});
|
|
node.setAttribute("cm-not-content", "true");
|
|
}, function(pos, axis) {
|
|
if (axis == "horizontal") setScrollLeft(cm, pos);
|
|
else updateScrollTop(cm, pos);
|
|
}, cm);
|
|
if (cm.display.scrollbars.addClass) addClass(cm.display.wrapper, cm.display.scrollbars.addClass);
|
|
}
|
|
var nextOpId = 0;
|
|
function startOperation(cm) {
|
|
cm.curOp = {
|
|
cm,
|
|
viewChanged: false,
|
|
startHeight: cm.doc.height,
|
|
forceUpdate: false,
|
|
updateInput: 0,
|
|
typing: false,
|
|
changeObjs: null,
|
|
cursorActivityHandlers: null,
|
|
cursorActivityCalled: 0,
|
|
selectionChanged: false,
|
|
updateMaxLine: false,
|
|
scrollLeft: null,
|
|
scrollTop: null,
|
|
scrollToPos: null,
|
|
focus: false,
|
|
id: ++nextOpId,
|
|
markArrays: null
|
|
};
|
|
pushOperation(cm.curOp);
|
|
}
|
|
function endOperation(cm) {
|
|
var op = cm.curOp;
|
|
if (op) finishOperation(op, function(group) {
|
|
for (var i$3 = 0; i$3 < group.ops.length; i$3++) group.ops[i$3].cm.curOp = null;
|
|
endOperations(group);
|
|
});
|
|
}
|
|
function endOperations(group) {
|
|
var ops = group.ops;
|
|
for (var i$3 = 0; i$3 < ops.length; i$3++) endOperation_R1(ops[i$3]);
|
|
for (var i$1$1 = 0; i$1$1 < ops.length; i$1$1++) endOperation_W1(ops[i$1$1]);
|
|
for (var i$2$1 = 0; i$2$1 < ops.length; i$2$1++) endOperation_R2(ops[i$2$1]);
|
|
for (var i$3$1 = 0; i$3$1 < ops.length; i$3$1++) endOperation_W2(ops[i$3$1]);
|
|
for (var i$4 = 0; i$4 < ops.length; i$4++) endOperation_finish(ops[i$4]);
|
|
}
|
|
function endOperation_R1(op) {
|
|
var cm = op.cm, display = cm.display;
|
|
maybeClipScrollbars(cm);
|
|
if (op.updateMaxLine) findMaxLine(cm);
|
|
op.mustUpdate = op.viewChanged || op.forceUpdate || op.scrollTop != null || op.scrollToPos && (op.scrollToPos.from.line < display.viewFrom || op.scrollToPos.to.line >= display.viewTo) || display.maxLineChanged && cm.options.lineWrapping;
|
|
op.update = op.mustUpdate && new DisplayUpdate(cm, op.mustUpdate && {
|
|
top: op.scrollTop,
|
|
ensure: op.scrollToPos
|
|
}, op.forceUpdate);
|
|
}
|
|
function endOperation_W1(op) {
|
|
op.updatedDisplay = op.mustUpdate && updateDisplayIfNeeded(op.cm, op.update);
|
|
}
|
|
function endOperation_R2(op) {
|
|
var cm = op.cm, display = cm.display;
|
|
if (op.updatedDisplay) updateHeightsInViewport(cm);
|
|
op.barMeasure = measureForScrollbars(cm);
|
|
if (display.maxLineChanged && !cm.options.lineWrapping) {
|
|
op.adjustWidthTo = measureChar(cm, display.maxLine, display.maxLine.text.length).left + 3;
|
|
cm.display.sizerWidth = op.adjustWidthTo;
|
|
op.barMeasure.scrollWidth = Math.max(display.scroller.clientWidth, display.sizer.offsetLeft + op.adjustWidthTo + scrollGap(cm) + cm.display.barWidth);
|
|
op.maxScrollLeft = Math.max(0, display.sizer.offsetLeft + op.adjustWidthTo - displayWidth(cm));
|
|
}
|
|
if (op.updatedDisplay || op.selectionChanged) op.preparedSelection = display.input.prepareSelection();
|
|
}
|
|
function endOperation_W2(op) {
|
|
var cm = op.cm;
|
|
if (op.adjustWidthTo != null) {
|
|
cm.display.sizer.style.minWidth = op.adjustWidthTo + "px";
|
|
if (op.maxScrollLeft < cm.doc.scrollLeft) setScrollLeft(cm, Math.min(cm.display.scroller.scrollLeft, op.maxScrollLeft), true);
|
|
cm.display.maxLineChanged = false;
|
|
}
|
|
var takeFocus = op.focus && op.focus == activeElt(root(cm));
|
|
if (op.preparedSelection) cm.display.input.showSelection(op.preparedSelection, takeFocus);
|
|
if (op.updatedDisplay || op.startHeight != cm.doc.height) updateScrollbars(cm, op.barMeasure);
|
|
if (op.updatedDisplay) setDocumentHeight(cm, op.barMeasure);
|
|
if (op.selectionChanged) restartBlink(cm);
|
|
if (cm.state.focused && op.updateInput) cm.display.input.reset(op.typing);
|
|
if (takeFocus) ensureFocus(op.cm);
|
|
}
|
|
function endOperation_finish(op) {
|
|
var cm = op.cm, display = cm.display, doc$1 = cm.doc;
|
|
if (op.updatedDisplay) postUpdateDisplay(cm, op.update);
|
|
if (display.wheelStartX != null && (op.scrollTop != null || op.scrollLeft != null || op.scrollToPos)) display.wheelStartX = display.wheelStartY = null;
|
|
if (op.scrollTop != null) setScrollTop(cm, op.scrollTop, op.forceScroll);
|
|
if (op.scrollLeft != null) setScrollLeft(cm, op.scrollLeft, true, true);
|
|
if (op.scrollToPos) {
|
|
var rect = scrollPosIntoView(cm, clipPos(doc$1, op.scrollToPos.from), clipPos(doc$1, op.scrollToPos.to), op.scrollToPos.margin);
|
|
maybeScrollWindow(cm, rect);
|
|
}
|
|
var hidden = op.maybeHiddenMarkers, unhidden = op.maybeUnhiddenMarkers;
|
|
if (hidden) {
|
|
for (var i$3 = 0; i$3 < hidden.length; ++i$3) if (!hidden[i$3].lines.length) signal(hidden[i$3], "hide");
|
|
}
|
|
if (unhidden) {
|
|
for (var i$1$1 = 0; i$1$1 < unhidden.length; ++i$1$1) if (unhidden[i$1$1].lines.length) signal(unhidden[i$1$1], "unhide");
|
|
}
|
|
if (display.wrapper.offsetHeight) doc$1.scrollTop = cm.display.scroller.scrollTop;
|
|
if (op.changeObjs) signal(cm, "changes", cm, op.changeObjs);
|
|
if (op.update) op.update.finish();
|
|
}
|
|
function runInOp(cm, f) {
|
|
if (cm.curOp) return f();
|
|
startOperation(cm);
|
|
try {
|
|
return f();
|
|
} finally {
|
|
endOperation(cm);
|
|
}
|
|
}
|
|
function operation(cm, f) {
|
|
return function() {
|
|
if (cm.curOp) return f.apply(cm, arguments);
|
|
startOperation(cm);
|
|
try {
|
|
return f.apply(cm, arguments);
|
|
} finally {
|
|
endOperation(cm);
|
|
}
|
|
};
|
|
}
|
|
function methodOp(f) {
|
|
return function() {
|
|
if (this.curOp) return f.apply(this, arguments);
|
|
startOperation(this);
|
|
try {
|
|
return f.apply(this, arguments);
|
|
} finally {
|
|
endOperation(this);
|
|
}
|
|
};
|
|
}
|
|
function docMethodOp(f) {
|
|
return function() {
|
|
var cm = this.cm;
|
|
if (!cm || cm.curOp) return f.apply(this, arguments);
|
|
startOperation(cm);
|
|
try {
|
|
return f.apply(this, arguments);
|
|
} finally {
|
|
endOperation(cm);
|
|
}
|
|
};
|
|
}
|
|
function startWorker(cm, time) {
|
|
if (cm.doc.highlightFrontier < cm.display.viewTo) cm.state.highlight.set(time, bind(highlightWorker, cm));
|
|
}
|
|
function highlightWorker(cm) {
|
|
var doc$1 = cm.doc;
|
|
if (doc$1.highlightFrontier >= cm.display.viewTo) return;
|
|
var end = +new Date() + cm.options.workTime;
|
|
var context = getContextBefore(cm, doc$1.highlightFrontier);
|
|
var changedLines = [];
|
|
doc$1.iter(context.line, Math.min(doc$1.first + doc$1.size, cm.display.viewTo + 500), function(line) {
|
|
if (context.line >= cm.display.viewFrom) {
|
|
var oldStyles = line.styles;
|
|
var resetState = line.text.length > cm.options.maxHighlightLength ? copyState(doc$1.mode, context.state) : null;
|
|
var highlighted = highlightLine(cm, line, context, true);
|
|
if (resetState) context.state = resetState;
|
|
line.styles = highlighted.styles;
|
|
var oldCls = line.styleClasses, newCls = highlighted.classes;
|
|
if (newCls) line.styleClasses = newCls;
|
|
else if (oldCls) line.styleClasses = null;
|
|
var ischange = !oldStyles || oldStyles.length != line.styles.length || oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass);
|
|
for (var i$3 = 0; !ischange && i$3 < oldStyles.length; ++i$3) ischange = oldStyles[i$3] != line.styles[i$3];
|
|
if (ischange) changedLines.push(context.line);
|
|
line.stateAfter = context.save();
|
|
context.nextLine();
|
|
} else {
|
|
if (line.text.length <= cm.options.maxHighlightLength) processLine(cm, line.text, context);
|
|
line.stateAfter = context.line % 5 == 0 ? context.save() : null;
|
|
context.nextLine();
|
|
}
|
|
if (+new Date() > end) {
|
|
startWorker(cm, cm.options.workDelay);
|
|
return true;
|
|
}
|
|
});
|
|
doc$1.highlightFrontier = context.line;
|
|
doc$1.modeFrontier = Math.max(doc$1.modeFrontier, context.line);
|
|
if (changedLines.length) runInOp(cm, function() {
|
|
for (var i$3 = 0; i$3 < changedLines.length; i$3++) regLineChange(cm, changedLines[i$3], "text");
|
|
});
|
|
}
|
|
var DisplayUpdate = function(cm, viewport, force) {
|
|
var display = cm.display;
|
|
this.viewport = viewport;
|
|
this.visible = visibleLines(display, cm.doc, viewport);
|
|
this.editorIsHidden = !display.wrapper.offsetWidth;
|
|
this.wrapperHeight = display.wrapper.clientHeight;
|
|
this.wrapperWidth = display.wrapper.clientWidth;
|
|
this.oldDisplayWidth = displayWidth(cm);
|
|
this.force = force;
|
|
this.dims = getDimensions(cm);
|
|
this.events = [];
|
|
};
|
|
DisplayUpdate.prototype.signal = function(emitter, type) {
|
|
if (hasHandler(emitter, type)) this.events.push(arguments);
|
|
};
|
|
DisplayUpdate.prototype.finish = function() {
|
|
for (var i$3 = 0; i$3 < this.events.length; i$3++) signal.apply(null, this.events[i$3]);
|
|
};
|
|
function maybeClipScrollbars(cm) {
|
|
var display = cm.display;
|
|
if (!display.scrollbarsClipped && display.scroller.offsetWidth) {
|
|
display.nativeBarWidth = display.scroller.offsetWidth - display.scroller.clientWidth;
|
|
display.heightForcer.style.height = scrollGap(cm) + "px";
|
|
display.sizer.style.marginBottom = -display.nativeBarWidth + "px";
|
|
display.sizer.style.borderRightWidth = scrollGap(cm) + "px";
|
|
display.scrollbarsClipped = true;
|
|
}
|
|
}
|
|
function selectionSnapshot(cm) {
|
|
if (cm.hasFocus()) return null;
|
|
var active = activeElt(root(cm));
|
|
if (!active || !contains(cm.display.lineDiv, active)) return null;
|
|
var result = { activeElt: active };
|
|
if (window.getSelection) {
|
|
var sel = win(cm).getSelection();
|
|
if (sel.anchorNode && sel.extend && contains(cm.display.lineDiv, sel.anchorNode)) {
|
|
result.anchorNode = sel.anchorNode;
|
|
result.anchorOffset = sel.anchorOffset;
|
|
result.focusNode = sel.focusNode;
|
|
result.focusOffset = sel.focusOffset;
|
|
}
|
|
}
|
|
return result;
|
|
}
|
|
function restoreSelection(snapshot) {
|
|
if (!snapshot || !snapshot.activeElt || snapshot.activeElt == activeElt(rootNode(snapshot.activeElt))) return;
|
|
snapshot.activeElt.focus();
|
|
if (!/^(INPUT|TEXTAREA)$/.test(snapshot.activeElt.nodeName) && snapshot.anchorNode && contains(document.body, snapshot.anchorNode) && contains(document.body, snapshot.focusNode)) {
|
|
var doc$1 = snapshot.activeElt.ownerDocument;
|
|
var sel = doc$1.defaultView.getSelection(), range$1 = doc$1.createRange();
|
|
range$1.setEnd(snapshot.anchorNode, snapshot.anchorOffset);
|
|
range$1.collapse(false);
|
|
sel.removeAllRanges();
|
|
sel.addRange(range$1);
|
|
sel.extend(snapshot.focusNode, snapshot.focusOffset);
|
|
}
|
|
}
|
|
function updateDisplayIfNeeded(cm, update) {
|
|
var display = cm.display, doc$1 = cm.doc;
|
|
if (update.editorIsHidden) {
|
|
resetView(cm);
|
|
return false;
|
|
}
|
|
if (!update.force && update.visible.from >= display.viewFrom && update.visible.to <= display.viewTo && (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo) && display.renderedView == display.view && countDirtyView(cm) == 0) return false;
|
|
if (maybeUpdateLineNumberWidth(cm)) {
|
|
resetView(cm);
|
|
update.dims = getDimensions(cm);
|
|
}
|
|
var end = doc$1.first + doc$1.size;
|
|
var from = Math.max(update.visible.from - cm.options.viewportMargin, doc$1.first);
|
|
var to = Math.min(end, update.visible.to + cm.options.viewportMargin);
|
|
if (display.viewFrom < from && from - display.viewFrom < 20) from = Math.max(doc$1.first, display.viewFrom);
|
|
if (display.viewTo > to && display.viewTo - to < 20) to = Math.min(end, display.viewTo);
|
|
if (sawCollapsedSpans) {
|
|
from = visualLineNo(cm.doc, from);
|
|
to = visualLineEndNo(cm.doc, to);
|
|
}
|
|
var different = from != display.viewFrom || to != display.viewTo || display.lastWrapHeight != update.wrapperHeight || display.lastWrapWidth != update.wrapperWidth;
|
|
adjustView(cm, from, to);
|
|
display.viewOffset = heightAtLine(getLine(cm.doc, display.viewFrom));
|
|
cm.display.mover.style.top = display.viewOffset + "px";
|
|
var toUpdate = countDirtyView(cm);
|
|
if (!different && toUpdate == 0 && !update.force && display.renderedView == display.view && (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo)) return false;
|
|
var selSnapshot = selectionSnapshot(cm);
|
|
if (toUpdate > 4) display.lineDiv.style.display = "none";
|
|
patchDisplay(cm, display.updateLineNumbers, update.dims);
|
|
if (toUpdate > 4) display.lineDiv.style.display = "";
|
|
display.renderedView = display.view;
|
|
restoreSelection(selSnapshot);
|
|
removeChildren(display.cursorDiv);
|
|
removeChildren(display.selectionDiv);
|
|
display.gutters.style.height = display.sizer.style.minHeight = 0;
|
|
if (different) {
|
|
display.lastWrapHeight = update.wrapperHeight;
|
|
display.lastWrapWidth = update.wrapperWidth;
|
|
startWorker(cm, 400);
|
|
}
|
|
display.updateLineNumbers = null;
|
|
return true;
|
|
}
|
|
function postUpdateDisplay(cm, update) {
|
|
var viewport = update.viewport;
|
|
for (var first = true;; first = false) {
|
|
if (!first || !cm.options.lineWrapping || update.oldDisplayWidth == displayWidth(cm)) {
|
|
if (viewport && viewport.top != null) viewport = { top: Math.min(cm.doc.height + paddingVert(cm.display) - displayHeight(cm), viewport.top) };
|
|
update.visible = visibleLines(cm.display, cm.doc, viewport);
|
|
if (update.visible.from >= cm.display.viewFrom && update.visible.to <= cm.display.viewTo) break;
|
|
} else if (first) update.visible = visibleLines(cm.display, cm.doc, viewport);
|
|
if (!updateDisplayIfNeeded(cm, update)) break;
|
|
updateHeightsInViewport(cm);
|
|
var barMeasure = measureForScrollbars(cm);
|
|
updateSelection(cm);
|
|
updateScrollbars(cm, barMeasure);
|
|
setDocumentHeight(cm, barMeasure);
|
|
update.force = false;
|
|
}
|
|
update.signal(cm, "update", cm);
|
|
if (cm.display.viewFrom != cm.display.reportedViewFrom || cm.display.viewTo != cm.display.reportedViewTo) {
|
|
update.signal(cm, "viewportChange", cm, cm.display.viewFrom, cm.display.viewTo);
|
|
cm.display.reportedViewFrom = cm.display.viewFrom;
|
|
cm.display.reportedViewTo = cm.display.viewTo;
|
|
}
|
|
}
|
|
function updateDisplaySimple(cm, viewport) {
|
|
var update = new DisplayUpdate(cm, viewport);
|
|
if (updateDisplayIfNeeded(cm, update)) {
|
|
updateHeightsInViewport(cm);
|
|
postUpdateDisplay(cm, update);
|
|
var barMeasure = measureForScrollbars(cm);
|
|
updateSelection(cm);
|
|
updateScrollbars(cm, barMeasure);
|
|
setDocumentHeight(cm, barMeasure);
|
|
update.finish();
|
|
}
|
|
}
|
|
function patchDisplay(cm, updateNumbersFrom, dims) {
|
|
var display = cm.display, lineNumbers = cm.options.lineNumbers;
|
|
var container = display.lineDiv, cur = container.firstChild;
|
|
function rm(node$1) {
|
|
var next = node$1.nextSibling;
|
|
if (webkit && mac && cm.display.currentWheelTarget == node$1) node$1.style.display = "none";
|
|
else node$1.parentNode.removeChild(node$1);
|
|
return next;
|
|
}
|
|
var view = display.view, lineN = display.viewFrom;
|
|
for (var i$3 = 0; i$3 < view.length; i$3++) {
|
|
var lineView = view[i$3];
|
|
if (lineView.hidden);
|
|
else if (!lineView.node || lineView.node.parentNode != container) {
|
|
var node = buildLineElement(cm, lineView, lineN, dims);
|
|
container.insertBefore(node, cur);
|
|
} else {
|
|
while (cur != lineView.node) cur = rm(cur);
|
|
var updateNumber = lineNumbers && updateNumbersFrom != null && updateNumbersFrom <= lineN && lineView.lineNumber;
|
|
if (lineView.changes) {
|
|
if (indexOf(lineView.changes, "gutter") > -1) updateNumber = false;
|
|
updateLineForChanges(cm, lineView, lineN, dims);
|
|
}
|
|
if (updateNumber) {
|
|
removeChildren(lineView.lineNumber);
|
|
lineView.lineNumber.appendChild(document.createTextNode(lineNumberFor(cm.options, lineN)));
|
|
}
|
|
cur = lineView.node.nextSibling;
|
|
}
|
|
lineN += lineView.size;
|
|
}
|
|
while (cur) cur = rm(cur);
|
|
}
|
|
function updateGutterSpace(display) {
|
|
var width = display.gutters.offsetWidth;
|
|
display.sizer.style.marginLeft = width + "px";
|
|
signalLater(display, "gutterChanged", display);
|
|
}
|
|
function setDocumentHeight(cm, measure) {
|
|
cm.display.sizer.style.minHeight = measure.docHeight + "px";
|
|
cm.display.heightForcer.style.top = measure.docHeight + "px";
|
|
cm.display.gutters.style.height = measure.docHeight + cm.display.barHeight + scrollGap(cm) + "px";
|
|
}
|
|
function alignHorizontally(cm) {
|
|
var display = cm.display, view = display.view;
|
|
if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) return;
|
|
var comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft;
|
|
var gutterW = display.gutters.offsetWidth, left = comp + "px";
|
|
for (var i$3 = 0; i$3 < view.length; i$3++) if (!view[i$3].hidden) {
|
|
if (cm.options.fixedGutter) {
|
|
if (view[i$3].gutter) view[i$3].gutter.style.left = left;
|
|
if (view[i$3].gutterBackground) view[i$3].gutterBackground.style.left = left;
|
|
}
|
|
var align = view[i$3].alignable;
|
|
if (align) for (var j = 0; j < align.length; j++) align[j].style.left = left;
|
|
}
|
|
if (cm.options.fixedGutter) display.gutters.style.left = comp + gutterW + "px";
|
|
}
|
|
function maybeUpdateLineNumberWidth(cm) {
|
|
if (!cm.options.lineNumbers) return false;
|
|
var doc$1 = cm.doc, last = lineNumberFor(cm.options, doc$1.first + doc$1.size - 1), display = cm.display;
|
|
if (last.length != display.lineNumChars) {
|
|
var test = display.measure.appendChild(elt("div", [elt("div", last)], "CodeMirror-linenumber CodeMirror-gutter-elt"));
|
|
var innerW = test.firstChild.offsetWidth, padding = test.offsetWidth - innerW;
|
|
display.lineGutter.style.width = "";
|
|
display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1;
|
|
display.lineNumWidth = display.lineNumInnerWidth + padding;
|
|
display.lineNumChars = display.lineNumInnerWidth ? last.length : -1;
|
|
display.lineGutter.style.width = display.lineNumWidth + "px";
|
|
updateGutterSpace(cm.display);
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
function getGutters(gutters, lineNumbers) {
|
|
var result = [], sawLineNumbers = false;
|
|
for (var i$3 = 0; i$3 < gutters.length; i$3++) {
|
|
var name = gutters[i$3], style = null;
|
|
if (typeof name != "string") {
|
|
style = name.style;
|
|
name = name.className;
|
|
}
|
|
if (name == "CodeMirror-linenumbers") if (!lineNumbers) continue;
|
|
else sawLineNumbers = true;
|
|
result.push({
|
|
className: name,
|
|
style
|
|
});
|
|
}
|
|
if (lineNumbers && !sawLineNumbers) result.push({
|
|
className: "CodeMirror-linenumbers",
|
|
style: null
|
|
});
|
|
return result;
|
|
}
|
|
function renderGutters(display) {
|
|
var gutters = display.gutters, specs = display.gutterSpecs;
|
|
removeChildren(gutters);
|
|
display.lineGutter = null;
|
|
for (var i$3 = 0; i$3 < specs.length; ++i$3) {
|
|
var ref$1 = specs[i$3];
|
|
var className = ref$1.className;
|
|
var style = ref$1.style;
|
|
var gElt = gutters.appendChild(elt("div", null, "CodeMirror-gutter " + className));
|
|
if (style) gElt.style.cssText = style;
|
|
if (className == "CodeMirror-linenumbers") {
|
|
display.lineGutter = gElt;
|
|
gElt.style.width = (display.lineNumWidth || 1) + "px";
|
|
}
|
|
}
|
|
gutters.style.display = specs.length ? "" : "none";
|
|
updateGutterSpace(display);
|
|
}
|
|
function updateGutters(cm) {
|
|
renderGutters(cm.display);
|
|
regChange(cm);
|
|
alignHorizontally(cm);
|
|
}
|
|
function Display(place, doc$1, input, options) {
|
|
var d = this;
|
|
this.input = input;
|
|
d.scrollbarFiller = elt("div", null, "CodeMirror-scrollbar-filler");
|
|
d.scrollbarFiller.setAttribute("cm-not-content", "true");
|
|
d.gutterFiller = elt("div", null, "CodeMirror-gutter-filler");
|
|
d.gutterFiller.setAttribute("cm-not-content", "true");
|
|
d.lineDiv = eltP("div", null, "CodeMirror-code");
|
|
d.selectionDiv = elt("div", null, null, "position: relative; z-index: 1");
|
|
d.cursorDiv = elt("div", null, "CodeMirror-cursors");
|
|
d.measure = elt("div", null, "CodeMirror-measure");
|
|
d.lineMeasure = elt("div", null, "CodeMirror-measure");
|
|
d.lineSpace = eltP("div", [
|
|
d.measure,
|
|
d.lineMeasure,
|
|
d.selectionDiv,
|
|
d.cursorDiv,
|
|
d.lineDiv
|
|
], null, "position: relative; outline: none");
|
|
var lines = eltP("div", [d.lineSpace], "CodeMirror-lines");
|
|
d.mover = elt("div", [lines], null, "position: relative");
|
|
d.sizer = elt("div", [d.mover], "CodeMirror-sizer");
|
|
d.sizerWidth = null;
|
|
d.heightForcer = elt("div", null, null, "position: absolute; height: " + scrollerGap + "px; width: 1px;");
|
|
d.gutters = elt("div", null, "CodeMirror-gutters");
|
|
d.lineGutter = null;
|
|
d.scroller = elt("div", [
|
|
d.sizer,
|
|
d.heightForcer,
|
|
d.gutters
|
|
], "CodeMirror-scroll");
|
|
d.scroller.setAttribute("tabIndex", "-1");
|
|
d.wrapper = elt("div", [
|
|
d.scrollbarFiller,
|
|
d.gutterFiller,
|
|
d.scroller
|
|
], "CodeMirror");
|
|
if (chrome && chrome_version >= 105) d.wrapper.style.clipPath = "inset(0px)";
|
|
d.wrapper.setAttribute("translate", "no");
|
|
if (ie && ie_version < 8) {
|
|
d.gutters.style.zIndex = -1;
|
|
d.scroller.style.paddingRight = 0;
|
|
}
|
|
if (!webkit && !(gecko && mobile)) d.scroller.draggable = true;
|
|
if (place) if (place.appendChild) place.appendChild(d.wrapper);
|
|
else place(d.wrapper);
|
|
d.viewFrom = d.viewTo = doc$1.first;
|
|
d.reportedViewFrom = d.reportedViewTo = doc$1.first;
|
|
d.view = [];
|
|
d.renderedView = null;
|
|
d.externalMeasured = null;
|
|
d.viewOffset = 0;
|
|
d.lastWrapHeight = d.lastWrapWidth = 0;
|
|
d.updateLineNumbers = null;
|
|
d.nativeBarWidth = d.barHeight = d.barWidth = 0;
|
|
d.scrollbarsClipped = false;
|
|
d.lineNumWidth = d.lineNumInnerWidth = d.lineNumChars = null;
|
|
d.alignWidgets = false;
|
|
d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;
|
|
d.maxLine = null;
|
|
d.maxLineLength = 0;
|
|
d.maxLineChanged = false;
|
|
d.wheelDX = d.wheelDY = d.wheelStartX = d.wheelStartY = null;
|
|
d.shift = false;
|
|
d.selForContextMenu = null;
|
|
d.activeTouch = null;
|
|
d.gutterSpecs = getGutters(options.gutters, options.lineNumbers);
|
|
renderGutters(d);
|
|
input.init(d);
|
|
}
|
|
var wheelSamples = 0, wheelPixelsPerUnit = null;
|
|
if (ie) wheelPixelsPerUnit = -.53;
|
|
else if (gecko) wheelPixelsPerUnit = 15;
|
|
else if (chrome) wheelPixelsPerUnit = -.7;
|
|
else if (safari) wheelPixelsPerUnit = -1 / 3;
|
|
function wheelEventDelta(e) {
|
|
var dx = e.wheelDeltaX, dy = e.wheelDeltaY;
|
|
if (dx == null && e.detail && e.axis == e.HORIZONTAL_AXIS) dx = e.detail;
|
|
if (dy == null && e.detail && e.axis == e.VERTICAL_AXIS) dy = e.detail;
|
|
else if (dy == null) dy = e.wheelDelta;
|
|
return {
|
|
x: dx,
|
|
y: dy
|
|
};
|
|
}
|
|
function wheelEventPixels(e) {
|
|
var delta = wheelEventDelta(e);
|
|
delta.x *= wheelPixelsPerUnit;
|
|
delta.y *= wheelPixelsPerUnit;
|
|
return delta;
|
|
}
|
|
function onScrollWheel(cm, e) {
|
|
if (chrome && chrome_version == 102) {
|
|
if (cm.display.chromeScrollHack == null) cm.display.sizer.style.pointerEvents = "none";
|
|
else clearTimeout(cm.display.chromeScrollHack);
|
|
cm.display.chromeScrollHack = setTimeout(function() {
|
|
cm.display.chromeScrollHack = null;
|
|
cm.display.sizer.style.pointerEvents = "";
|
|
}, 100);
|
|
}
|
|
var delta = wheelEventDelta(e), dx = delta.x, dy = delta.y;
|
|
var pixelsPerUnit = wheelPixelsPerUnit;
|
|
if (e.deltaMode === 0) {
|
|
dx = e.deltaX;
|
|
dy = e.deltaY;
|
|
pixelsPerUnit = 1;
|
|
}
|
|
var display = cm.display, scroll = display.scroller;
|
|
var canScrollX = scroll.scrollWidth > scroll.clientWidth;
|
|
var canScrollY = scroll.scrollHeight > scroll.clientHeight;
|
|
if (!(dx && canScrollX || dy && canScrollY)) return;
|
|
if (dy && mac && webkit) {
|
|
outer: for (var cur = e.target, view = display.view; cur != scroll; cur = cur.parentNode) for (var i$3 = 0; i$3 < view.length; i$3++) if (view[i$3].node == cur) {
|
|
cm.display.currentWheelTarget = cur;
|
|
break outer;
|
|
}
|
|
}
|
|
if (dx && !gecko && !presto && pixelsPerUnit != null) {
|
|
if (dy && canScrollY) updateScrollTop(cm, Math.max(0, scroll.scrollTop + dy * pixelsPerUnit));
|
|
setScrollLeft(cm, Math.max(0, scroll.scrollLeft + dx * pixelsPerUnit));
|
|
if (!dy || dy && canScrollY) e_preventDefault(e);
|
|
display.wheelStartX = null;
|
|
return;
|
|
}
|
|
if (dy && pixelsPerUnit != null) {
|
|
var pixels = dy * pixelsPerUnit;
|
|
var top = cm.doc.scrollTop, bot = top + display.wrapper.clientHeight;
|
|
if (pixels < 0) top = Math.max(0, top + pixels - 50);
|
|
else bot = Math.min(cm.doc.height, bot + pixels + 50);
|
|
updateDisplaySimple(cm, {
|
|
top,
|
|
bottom: bot
|
|
});
|
|
}
|
|
if (wheelSamples < 20 && e.deltaMode !== 0) if (display.wheelStartX == null) {
|
|
display.wheelStartX = scroll.scrollLeft;
|
|
display.wheelStartY = scroll.scrollTop;
|
|
display.wheelDX = dx;
|
|
display.wheelDY = dy;
|
|
setTimeout(function() {
|
|
if (display.wheelStartX == null) return;
|
|
var movedX = scroll.scrollLeft - display.wheelStartX;
|
|
var movedY = scroll.scrollTop - display.wheelStartY;
|
|
var sample = movedY && display.wheelDY && movedY / display.wheelDY || movedX && display.wheelDX && movedX / display.wheelDX;
|
|
display.wheelStartX = display.wheelStartY = null;
|
|
if (!sample) return;
|
|
wheelPixelsPerUnit = (wheelPixelsPerUnit * wheelSamples + sample) / (wheelSamples + 1);
|
|
++wheelSamples;
|
|
}, 200);
|
|
} else {
|
|
display.wheelDX += dx;
|
|
display.wheelDY += dy;
|
|
}
|
|
}
|
|
var Selection = function(ranges, primIndex) {
|
|
this.ranges = ranges;
|
|
this.primIndex = primIndex;
|
|
};
|
|
Selection.prototype.primary = function() {
|
|
return this.ranges[this.primIndex];
|
|
};
|
|
Selection.prototype.equals = function(other) {
|
|
if (other == this) return true;
|
|
if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) return false;
|
|
for (var i$3 = 0; i$3 < this.ranges.length; i$3++) {
|
|
var here = this.ranges[i$3], there = other.ranges[i$3];
|
|
if (!equalCursorPos(here.anchor, there.anchor) || !equalCursorPos(here.head, there.head)) return false;
|
|
}
|
|
return true;
|
|
};
|
|
Selection.prototype.deepCopy = function() {
|
|
var out = [];
|
|
for (var i$3 = 0; i$3 < this.ranges.length; i$3++) out[i$3] = new Range(copyPos(this.ranges[i$3].anchor), copyPos(this.ranges[i$3].head));
|
|
return new Selection(out, this.primIndex);
|
|
};
|
|
Selection.prototype.somethingSelected = function() {
|
|
for (var i$3 = 0; i$3 < this.ranges.length; i$3++) if (!this.ranges[i$3].empty()) return true;
|
|
return false;
|
|
};
|
|
Selection.prototype.contains = function(pos, end) {
|
|
if (!end) end = pos;
|
|
for (var i$3 = 0; i$3 < this.ranges.length; i$3++) {
|
|
var range$1 = this.ranges[i$3];
|
|
if (cmp(end, range$1.from()) >= 0 && cmp(pos, range$1.to()) <= 0) return i$3;
|
|
}
|
|
return -1;
|
|
};
|
|
var Range = function(anchor, head) {
|
|
this.anchor = anchor;
|
|
this.head = head;
|
|
};
|
|
Range.prototype.from = function() {
|
|
return minPos(this.anchor, this.head);
|
|
};
|
|
Range.prototype.to = function() {
|
|
return maxPos(this.anchor, this.head);
|
|
};
|
|
Range.prototype.empty = function() {
|
|
return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch;
|
|
};
|
|
function normalizeSelection(cm, ranges, primIndex) {
|
|
var mayTouch = cm && cm.options.selectionsMayTouch;
|
|
var prim = ranges[primIndex];
|
|
ranges.sort(function(a, b) {
|
|
return cmp(a.from(), b.from());
|
|
});
|
|
primIndex = indexOf(ranges, prim);
|
|
for (var i$3 = 1; i$3 < ranges.length; i$3++) {
|
|
var cur = ranges[i$3], prev = ranges[i$3 - 1];
|
|
var diff = cmp(prev.to(), cur.from());
|
|
if (mayTouch && !cur.empty() ? diff > 0 : diff >= 0) {
|
|
var from = minPos(prev.from(), cur.from()), to = maxPos(prev.to(), cur.to());
|
|
var inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head;
|
|
if (i$3 <= primIndex) --primIndex;
|
|
ranges.splice(--i$3, 2, new Range(inv ? to : from, inv ? from : to));
|
|
}
|
|
}
|
|
return new Selection(ranges, primIndex);
|
|
}
|
|
function simpleSelection(anchor, head) {
|
|
return new Selection([new Range(anchor, head || anchor)], 0);
|
|
}
|
|
function changeEnd(change) {
|
|
if (!change.text) return change.to;
|
|
return Pos(change.from.line + change.text.length - 1, lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0));
|
|
}
|
|
function adjustForChange(pos, change) {
|
|
if (cmp(pos, change.from) < 0) return pos;
|
|
if (cmp(pos, change.to) <= 0) return changeEnd(change);
|
|
var line = pos.line + change.text.length - (change.to.line - change.from.line) - 1, ch = pos.ch;
|
|
if (pos.line == change.to.line) ch += changeEnd(change).ch - change.to.ch;
|
|
return Pos(line, ch);
|
|
}
|
|
function computeSelAfterChange(doc$1, change) {
|
|
var out = [];
|
|
for (var i$3 = 0; i$3 < doc$1.sel.ranges.length; i$3++) {
|
|
var range$1 = doc$1.sel.ranges[i$3];
|
|
out.push(new Range(adjustForChange(range$1.anchor, change), adjustForChange(range$1.head, change)));
|
|
}
|
|
return normalizeSelection(doc$1.cm, out, doc$1.sel.primIndex);
|
|
}
|
|
function offsetPos(pos, old, nw) {
|
|
if (pos.line == old.line) return Pos(nw.line, pos.ch - old.ch + nw.ch);
|
|
else return Pos(nw.line + (pos.line - old.line), pos.ch);
|
|
}
|
|
function computeReplacedSel(doc$1, changes, hint) {
|
|
var out = [];
|
|
var oldPrev = Pos(doc$1.first, 0), newPrev = oldPrev;
|
|
for (var i$3 = 0; i$3 < changes.length; i$3++) {
|
|
var change = changes[i$3];
|
|
var from = offsetPos(change.from, oldPrev, newPrev);
|
|
var to = offsetPos(changeEnd(change), oldPrev, newPrev);
|
|
oldPrev = change.to;
|
|
newPrev = to;
|
|
if (hint == "around") {
|
|
var range$1 = doc$1.sel.ranges[i$3], inv = cmp(range$1.head, range$1.anchor) < 0;
|
|
out[i$3] = new Range(inv ? to : from, inv ? from : to);
|
|
} else out[i$3] = new Range(from, from);
|
|
}
|
|
return new Selection(out, doc$1.sel.primIndex);
|
|
}
|
|
function loadMode(cm) {
|
|
cm.doc.mode = getMode(cm.options, cm.doc.modeOption);
|
|
resetModeState(cm);
|
|
}
|
|
function resetModeState(cm) {
|
|
cm.doc.iter(function(line) {
|
|
if (line.stateAfter) line.stateAfter = null;
|
|
if (line.styles) line.styles = null;
|
|
});
|
|
cm.doc.modeFrontier = cm.doc.highlightFrontier = cm.doc.first;
|
|
startWorker(cm, 100);
|
|
cm.state.modeGen++;
|
|
if (cm.curOp) regChange(cm);
|
|
}
|
|
function isWholeLineUpdate(doc$1, change) {
|
|
return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == "" && (!doc$1.cm || doc$1.cm.options.wholeLineUpdateBefore);
|
|
}
|
|
function updateDoc(doc$1, change, markedSpans, estimateHeight$1) {
|
|
function spansFor(n) {
|
|
return markedSpans ? markedSpans[n] : null;
|
|
}
|
|
function update(line, text$1, spans) {
|
|
updateLine(line, text$1, spans, estimateHeight$1);
|
|
signalLater(line, "change", line, change);
|
|
}
|
|
function linesFor(start, end) {
|
|
var result = [];
|
|
for (var i$3 = start; i$3 < end; ++i$3) result.push(new Line(text[i$3], spansFor(i$3), estimateHeight$1));
|
|
return result;
|
|
}
|
|
var from = change.from, to = change.to, text = change.text;
|
|
var firstLine = getLine(doc$1, from.line), lastLine = getLine(doc$1, to.line);
|
|
var lastText = lst(text), lastSpans = spansFor(text.length - 1), nlines = to.line - from.line;
|
|
if (change.full) {
|
|
doc$1.insert(0, linesFor(0, text.length));
|
|
doc$1.remove(text.length, doc$1.size - text.length);
|
|
} else if (isWholeLineUpdate(doc$1, change)) {
|
|
var added = linesFor(0, text.length - 1);
|
|
update(lastLine, lastLine.text, lastSpans);
|
|
if (nlines) doc$1.remove(from.line, nlines);
|
|
if (added.length) doc$1.insert(from.line, added);
|
|
} else if (firstLine == lastLine) if (text.length == 1) update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans);
|
|
else {
|
|
var added$1 = linesFor(1, text.length - 1);
|
|
added$1.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight$1));
|
|
update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));
|
|
doc$1.insert(from.line + 1, added$1);
|
|
}
|
|
else if (text.length == 1) {
|
|
update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0));
|
|
doc$1.remove(from.line + 1, nlines);
|
|
} else {
|
|
update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));
|
|
update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans);
|
|
var added$2 = linesFor(1, text.length - 1);
|
|
if (nlines > 1) doc$1.remove(from.line + 1, nlines - 1);
|
|
doc$1.insert(from.line + 1, added$2);
|
|
}
|
|
signalLater(doc$1, "change", doc$1, change);
|
|
}
|
|
function linkedDocs(doc$1, f, sharedHistOnly) {
|
|
function propagate(doc$2, skip, sharedHist) {
|
|
if (doc$2.linked) for (var i$3 = 0; i$3 < doc$2.linked.length; ++i$3) {
|
|
var rel = doc$2.linked[i$3];
|
|
if (rel.doc == skip) continue;
|
|
var shared = sharedHist && rel.sharedHist;
|
|
if (sharedHistOnly && !shared) continue;
|
|
f(rel.doc, shared);
|
|
propagate(rel.doc, doc$2, shared);
|
|
}
|
|
}
|
|
propagate(doc$1, null, true);
|
|
}
|
|
function attachDoc(cm, doc$1) {
|
|
if (doc$1.cm) throw new Error("This document is already in use.");
|
|
cm.doc = doc$1;
|
|
doc$1.cm = cm;
|
|
estimateLineHeights(cm);
|
|
loadMode(cm);
|
|
setDirectionClass(cm);
|
|
cm.options.direction = doc$1.direction;
|
|
if (!cm.options.lineWrapping) findMaxLine(cm);
|
|
cm.options.mode = doc$1.modeOption;
|
|
regChange(cm);
|
|
}
|
|
function setDirectionClass(cm) {
|
|
(cm.doc.direction == "rtl" ? addClass : rmClass)(cm.display.lineDiv, "CodeMirror-rtl");
|
|
}
|
|
function directionChanged(cm) {
|
|
runInOp(cm, function() {
|
|
setDirectionClass(cm);
|
|
regChange(cm);
|
|
});
|
|
}
|
|
function History(prev) {
|
|
this.done = [];
|
|
this.undone = [];
|
|
this.undoDepth = prev ? prev.undoDepth : Infinity;
|
|
this.lastModTime = this.lastSelTime = 0;
|
|
this.lastOp = this.lastSelOp = null;
|
|
this.lastOrigin = this.lastSelOrigin = null;
|
|
this.generation = this.maxGeneration = prev ? prev.maxGeneration : 1;
|
|
}
|
|
function historyChangeFromChange(doc$1, change) {
|
|
var histChange = {
|
|
from: copyPos(change.from),
|
|
to: changeEnd(change),
|
|
text: getBetween(doc$1, change.from, change.to)
|
|
};
|
|
attachLocalSpans(doc$1, histChange, change.from.line, change.to.line + 1);
|
|
linkedDocs(doc$1, function(doc$2) {
|
|
return attachLocalSpans(doc$2, histChange, change.from.line, change.to.line + 1);
|
|
}, true);
|
|
return histChange;
|
|
}
|
|
function clearSelectionEvents(array) {
|
|
while (array.length) {
|
|
var last = lst(array);
|
|
if (last.ranges) array.pop();
|
|
else break;
|
|
}
|
|
}
|
|
function lastChangeEvent(hist, force) {
|
|
if (force) {
|
|
clearSelectionEvents(hist.done);
|
|
return lst(hist.done);
|
|
} else if (hist.done.length && !lst(hist.done).ranges) return lst(hist.done);
|
|
else if (hist.done.length > 1 && !hist.done[hist.done.length - 2].ranges) {
|
|
hist.done.pop();
|
|
return lst(hist.done);
|
|
}
|
|
}
|
|
function addChangeToHistory(doc$1, change, selAfter, opId) {
|
|
var hist = doc$1.history;
|
|
hist.undone.length = 0;
|
|
var time = +new Date(), cur;
|
|
var last;
|
|
if ((hist.lastOp == opId || hist.lastOrigin == change.origin && change.origin && (change.origin.charAt(0) == "+" && hist.lastModTime > time - (doc$1.cm ? doc$1.cm.options.historyEventDelay : 500) || change.origin.charAt(0) == "*")) && (cur = lastChangeEvent(hist, hist.lastOp == opId))) {
|
|
last = lst(cur.changes);
|
|
if (cmp(change.from, change.to) == 0 && cmp(change.from, last.to) == 0) last.to = changeEnd(change);
|
|
else cur.changes.push(historyChangeFromChange(doc$1, change));
|
|
} else {
|
|
var before = lst(hist.done);
|
|
if (!before || !before.ranges) pushSelectionToHistory(doc$1.sel, hist.done);
|
|
cur = {
|
|
changes: [historyChangeFromChange(doc$1, change)],
|
|
generation: hist.generation
|
|
};
|
|
hist.done.push(cur);
|
|
while (hist.done.length > hist.undoDepth) {
|
|
hist.done.shift();
|
|
if (!hist.done[0].ranges) hist.done.shift();
|
|
}
|
|
}
|
|
hist.done.push(selAfter);
|
|
hist.generation = ++hist.maxGeneration;
|
|
hist.lastModTime = hist.lastSelTime = time;
|
|
hist.lastOp = hist.lastSelOp = opId;
|
|
hist.lastOrigin = hist.lastSelOrigin = change.origin;
|
|
if (!last) signal(doc$1, "historyAdded");
|
|
}
|
|
function selectionEventCanBeMerged(doc$1, origin, prev, sel) {
|
|
var ch = origin.charAt(0);
|
|
return ch == "*" || ch == "+" && prev.ranges.length == sel.ranges.length && prev.somethingSelected() == sel.somethingSelected() && new Date() - doc$1.history.lastSelTime <= (doc$1.cm ? doc$1.cm.options.historyEventDelay : 500);
|
|
}
|
|
function addSelectionToHistory(doc$1, sel, opId, options) {
|
|
var hist = doc$1.history, origin = options && options.origin;
|
|
if (opId == hist.lastSelOp || origin && hist.lastSelOrigin == origin && (hist.lastModTime == hist.lastSelTime && hist.lastOrigin == origin || selectionEventCanBeMerged(doc$1, origin, lst(hist.done), sel))) hist.done[hist.done.length - 1] = sel;
|
|
else pushSelectionToHistory(sel, hist.done);
|
|
hist.lastSelTime = +new Date();
|
|
hist.lastSelOrigin = origin;
|
|
hist.lastSelOp = opId;
|
|
if (options && options.clearRedo !== false) clearSelectionEvents(hist.undone);
|
|
}
|
|
function pushSelectionToHistory(sel, dest) {
|
|
var top = lst(dest);
|
|
if (!(top && top.ranges && top.equals(sel))) dest.push(sel);
|
|
}
|
|
function attachLocalSpans(doc$1, change, from, to) {
|
|
var existing = change["spans_" + doc$1.id], n = 0;
|
|
doc$1.iter(Math.max(doc$1.first, from), Math.min(doc$1.first + doc$1.size, to), function(line) {
|
|
if (line.markedSpans) (existing || (existing = change["spans_" + doc$1.id] = {}))[n] = line.markedSpans;
|
|
++n;
|
|
});
|
|
}
|
|
function removeClearedSpans(spans) {
|
|
if (!spans) return null;
|
|
var out;
|
|
for (var i$3 = 0; i$3 < spans.length; ++i$3) if (spans[i$3].marker.explicitlyCleared) {
|
|
if (!out) out = spans.slice(0, i$3);
|
|
} else if (out) out.push(spans[i$3]);
|
|
return !out ? spans : out.length ? out : null;
|
|
}
|
|
function getOldSpans(doc$1, change) {
|
|
var found = change["spans_" + doc$1.id];
|
|
if (!found) return null;
|
|
var nw = [];
|
|
for (var i$3 = 0; i$3 < change.text.length; ++i$3) nw.push(removeClearedSpans(found[i$3]));
|
|
return nw;
|
|
}
|
|
function mergeOldSpans(doc$1, change) {
|
|
var old = getOldSpans(doc$1, change);
|
|
var stretched = stretchSpansOverChange(doc$1, change);
|
|
if (!old) return stretched;
|
|
if (!stretched) return old;
|
|
for (var i$3 = 0; i$3 < old.length; ++i$3) {
|
|
var oldCur = old[i$3], stretchCur = stretched[i$3];
|
|
if (oldCur && stretchCur) spans: for (var j = 0; j < stretchCur.length; ++j) {
|
|
var span = stretchCur[j];
|
|
for (var k = 0; k < oldCur.length; ++k) if (oldCur[k].marker == span.marker) continue spans;
|
|
oldCur.push(span);
|
|
}
|
|
else if (stretchCur) old[i$3] = stretchCur;
|
|
}
|
|
return old;
|
|
}
|
|
function copyHistoryArray(events, newGroup, instantiateSel) {
|
|
var copy = [];
|
|
for (var i$3 = 0; i$3 < events.length; ++i$3) {
|
|
var event = events[i$3];
|
|
if (event.ranges) {
|
|
copy.push(instantiateSel ? Selection.prototype.deepCopy.call(event) : event);
|
|
continue;
|
|
}
|
|
var changes = event.changes, newChanges = [];
|
|
copy.push({ changes: newChanges });
|
|
for (var j = 0; j < changes.length; ++j) {
|
|
var change = changes[j], m = void 0;
|
|
newChanges.push({
|
|
from: change.from,
|
|
to: change.to,
|
|
text: change.text
|
|
});
|
|
if (newGroup) {
|
|
for (var prop$1 in change) if (m = prop$1.match(/^spans_(\d+)$/)) {
|
|
if (indexOf(newGroup, Number(m[1])) > -1) {
|
|
lst(newChanges)[prop$1] = change[prop$1];
|
|
delete change[prop$1];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return copy;
|
|
}
|
|
function extendRange(range$1, head, other, extend) {
|
|
if (extend) {
|
|
var anchor = range$1.anchor;
|
|
if (other) {
|
|
var posBefore = cmp(head, anchor) < 0;
|
|
if (posBefore != cmp(other, anchor) < 0) {
|
|
anchor = head;
|
|
head = other;
|
|
} else if (posBefore != cmp(head, other) < 0) head = other;
|
|
}
|
|
return new Range(anchor, head);
|
|
} else return new Range(other || head, head);
|
|
}
|
|
function extendSelection(doc$1, head, other, options, extend) {
|
|
if (extend == null) extend = doc$1.cm && (doc$1.cm.display.shift || doc$1.extend);
|
|
setSelection(doc$1, new Selection([extendRange(doc$1.sel.primary(), head, other, extend)], 0), options);
|
|
}
|
|
function extendSelections(doc$1, heads, options) {
|
|
var out = [];
|
|
var extend = doc$1.cm && (doc$1.cm.display.shift || doc$1.extend);
|
|
for (var i$3 = 0; i$3 < doc$1.sel.ranges.length; i$3++) out[i$3] = extendRange(doc$1.sel.ranges[i$3], heads[i$3], null, extend);
|
|
var newSel = normalizeSelection(doc$1.cm, out, doc$1.sel.primIndex);
|
|
setSelection(doc$1, newSel, options);
|
|
}
|
|
function replaceOneSelection(doc$1, i$3, range$1, options) {
|
|
var ranges = doc$1.sel.ranges.slice(0);
|
|
ranges[i$3] = range$1;
|
|
setSelection(doc$1, normalizeSelection(doc$1.cm, ranges, doc$1.sel.primIndex), options);
|
|
}
|
|
function setSimpleSelection(doc$1, anchor, head, options) {
|
|
setSelection(doc$1, simpleSelection(anchor, head), options);
|
|
}
|
|
function filterSelectionChange(doc$1, sel, options) {
|
|
var obj = {
|
|
ranges: sel.ranges,
|
|
update: function(ranges) {
|
|
this.ranges = [];
|
|
for (var i$3 = 0; i$3 < ranges.length; i$3++) this.ranges[i$3] = new Range(clipPos(doc$1, ranges[i$3].anchor), clipPos(doc$1, ranges[i$3].head));
|
|
},
|
|
origin: options && options.origin
|
|
};
|
|
signal(doc$1, "beforeSelectionChange", doc$1, obj);
|
|
if (doc$1.cm) signal(doc$1.cm, "beforeSelectionChange", doc$1.cm, obj);
|
|
if (obj.ranges != sel.ranges) return normalizeSelection(doc$1.cm, obj.ranges, obj.ranges.length - 1);
|
|
else return sel;
|
|
}
|
|
function setSelectionReplaceHistory(doc$1, sel, options) {
|
|
var done = doc$1.history.done, last = lst(done);
|
|
if (last && last.ranges) {
|
|
done[done.length - 1] = sel;
|
|
setSelectionNoUndo(doc$1, sel, options);
|
|
} else setSelection(doc$1, sel, options);
|
|
}
|
|
function setSelection(doc$1, sel, options) {
|
|
setSelectionNoUndo(doc$1, sel, options);
|
|
addSelectionToHistory(doc$1, doc$1.sel, doc$1.cm ? doc$1.cm.curOp.id : NaN, options);
|
|
}
|
|
function setSelectionNoUndo(doc$1, sel, options) {
|
|
if (hasHandler(doc$1, "beforeSelectionChange") || doc$1.cm && hasHandler(doc$1.cm, "beforeSelectionChange")) sel = filterSelectionChange(doc$1, sel, options);
|
|
var bias = options && options.bias || (cmp(sel.primary().head, doc$1.sel.primary().head) < 0 ? -1 : 1);
|
|
setSelectionInner(doc$1, skipAtomicInSelection(doc$1, sel, bias, true));
|
|
if (!(options && options.scroll === false) && doc$1.cm && doc$1.cm.getOption("readOnly") != "nocursor") ensureCursorVisible(doc$1.cm);
|
|
}
|
|
function setSelectionInner(doc$1, sel) {
|
|
if (sel.equals(doc$1.sel)) return;
|
|
doc$1.sel = sel;
|
|
if (doc$1.cm) {
|
|
doc$1.cm.curOp.updateInput = 1;
|
|
doc$1.cm.curOp.selectionChanged = true;
|
|
signalCursorActivity(doc$1.cm);
|
|
}
|
|
signalLater(doc$1, "cursorActivity", doc$1);
|
|
}
|
|
function reCheckSelection(doc$1) {
|
|
setSelectionInner(doc$1, skipAtomicInSelection(doc$1, doc$1.sel, null, false));
|
|
}
|
|
function skipAtomicInSelection(doc$1, sel, bias, mayClear) {
|
|
var out;
|
|
for (var i$3 = 0; i$3 < sel.ranges.length; i$3++) {
|
|
var range$1 = sel.ranges[i$3];
|
|
var old = sel.ranges.length == doc$1.sel.ranges.length && doc$1.sel.ranges[i$3];
|
|
var newAnchor = skipAtomic(doc$1, range$1.anchor, old && old.anchor, bias, mayClear);
|
|
var newHead = range$1.head == range$1.anchor ? newAnchor : skipAtomic(doc$1, range$1.head, old && old.head, bias, mayClear);
|
|
if (out || newAnchor != range$1.anchor || newHead != range$1.head) {
|
|
if (!out) out = sel.ranges.slice(0, i$3);
|
|
out[i$3] = new Range(newAnchor, newHead);
|
|
}
|
|
}
|
|
return out ? normalizeSelection(doc$1.cm, out, sel.primIndex) : sel;
|
|
}
|
|
function skipAtomicInner(doc$1, pos, oldPos, dir, mayClear) {
|
|
var line = getLine(doc$1, pos.line);
|
|
if (line.markedSpans) for (var i$3 = 0; i$3 < line.markedSpans.length; ++i$3) {
|
|
var sp = line.markedSpans[i$3], m = sp.marker;
|
|
var preventCursorLeft = "selectLeft" in m ? !m.selectLeft : m.inclusiveLeft;
|
|
var preventCursorRight = "selectRight" in m ? !m.selectRight : m.inclusiveRight;
|
|
if ((sp.from == null || (preventCursorLeft ? sp.from <= pos.ch : sp.from < pos.ch)) && (sp.to == null || (preventCursorRight ? sp.to >= pos.ch : sp.to > pos.ch))) {
|
|
if (mayClear) {
|
|
signal(m, "beforeCursorEnter");
|
|
if (m.explicitlyCleared) if (!line.markedSpans) break;
|
|
else {
|
|
--i$3;
|
|
continue;
|
|
}
|
|
}
|
|
if (!m.atomic) continue;
|
|
if (oldPos) {
|
|
var near = m.find(dir < 0 ? 1 : -1), diff = void 0;
|
|
if (dir < 0 ? preventCursorRight : preventCursorLeft) near = movePos(doc$1, near, -dir, near && near.line == pos.line ? line : null);
|
|
if (near && near.line == pos.line && (diff = cmp(near, oldPos)) && (dir < 0 ? diff < 0 : diff > 0)) return skipAtomicInner(doc$1, near, pos, dir, mayClear);
|
|
}
|
|
var far = m.find(dir < 0 ? -1 : 1);
|
|
if (dir < 0 ? preventCursorLeft : preventCursorRight) far = movePos(doc$1, far, dir, far.line == pos.line ? line : null);
|
|
return far ? skipAtomicInner(doc$1, far, pos, dir, mayClear) : null;
|
|
}
|
|
}
|
|
return pos;
|
|
}
|
|
function skipAtomic(doc$1, pos, oldPos, bias, mayClear) {
|
|
var dir = bias || 1;
|
|
var found = skipAtomicInner(doc$1, pos, oldPos, dir, mayClear) || !mayClear && skipAtomicInner(doc$1, pos, oldPos, dir, true) || skipAtomicInner(doc$1, pos, oldPos, -dir, mayClear) || !mayClear && skipAtomicInner(doc$1, pos, oldPos, -dir, true);
|
|
if (!found) {
|
|
doc$1.cantEdit = true;
|
|
return Pos(doc$1.first, 0);
|
|
}
|
|
return found;
|
|
}
|
|
function movePos(doc$1, pos, dir, line) {
|
|
if (dir < 0 && pos.ch == 0) if (pos.line > doc$1.first) return clipPos(doc$1, Pos(pos.line - 1));
|
|
else return null;
|
|
else if (dir > 0 && pos.ch == (line || getLine(doc$1, pos.line)).text.length) if (pos.line < doc$1.first + doc$1.size - 1) return Pos(pos.line + 1, 0);
|
|
else return null;
|
|
else return new Pos(pos.line, pos.ch + dir);
|
|
}
|
|
function selectAll(cm) {
|
|
cm.setSelection(Pos(cm.firstLine(), 0), Pos(cm.lastLine()), sel_dontScroll);
|
|
}
|
|
function filterChange(doc$1, change, update) {
|
|
var obj = {
|
|
canceled: false,
|
|
from: change.from,
|
|
to: change.to,
|
|
text: change.text,
|
|
origin: change.origin,
|
|
cancel: function() {
|
|
return obj.canceled = true;
|
|
}
|
|
};
|
|
if (update) obj.update = function(from, to, text, origin) {
|
|
if (from) obj.from = clipPos(doc$1, from);
|
|
if (to) obj.to = clipPos(doc$1, to);
|
|
if (text) obj.text = text;
|
|
if (origin !== void 0) obj.origin = origin;
|
|
};
|
|
signal(doc$1, "beforeChange", doc$1, obj);
|
|
if (doc$1.cm) signal(doc$1.cm, "beforeChange", doc$1.cm, obj);
|
|
if (obj.canceled) {
|
|
if (doc$1.cm) doc$1.cm.curOp.updateInput = 2;
|
|
return null;
|
|
}
|
|
return {
|
|
from: obj.from,
|
|
to: obj.to,
|
|
text: obj.text,
|
|
origin: obj.origin
|
|
};
|
|
}
|
|
function makeChange(doc$1, change, ignoreReadOnly) {
|
|
if (doc$1.cm) {
|
|
if (!doc$1.cm.curOp) return operation(doc$1.cm, makeChange)(doc$1, change, ignoreReadOnly);
|
|
if (doc$1.cm.state.suppressEdits) return;
|
|
}
|
|
if (hasHandler(doc$1, "beforeChange") || doc$1.cm && hasHandler(doc$1.cm, "beforeChange")) {
|
|
change = filterChange(doc$1, change, true);
|
|
if (!change) return;
|
|
}
|
|
var split = sawReadOnlySpans && !ignoreReadOnly && removeReadOnlyRanges(doc$1, change.from, change.to);
|
|
if (split) for (var i$3 = split.length - 1; i$3 >= 0; --i$3) makeChangeInner(doc$1, {
|
|
from: split[i$3].from,
|
|
to: split[i$3].to,
|
|
text: i$3 ? [""] : change.text,
|
|
origin: change.origin
|
|
});
|
|
else makeChangeInner(doc$1, change);
|
|
}
|
|
function makeChangeInner(doc$1, change) {
|
|
if (change.text.length == 1 && change.text[0] == "" && cmp(change.from, change.to) == 0) return;
|
|
var selAfter = computeSelAfterChange(doc$1, change);
|
|
addChangeToHistory(doc$1, change, selAfter, doc$1.cm ? doc$1.cm.curOp.id : NaN);
|
|
makeChangeSingleDoc(doc$1, change, selAfter, stretchSpansOverChange(doc$1, change));
|
|
var rebased = [];
|
|
linkedDocs(doc$1, function(doc$2, sharedHist) {
|
|
if (!sharedHist && indexOf(rebased, doc$2.history) == -1) {
|
|
rebaseHist(doc$2.history, change);
|
|
rebased.push(doc$2.history);
|
|
}
|
|
makeChangeSingleDoc(doc$2, change, null, stretchSpansOverChange(doc$2, change));
|
|
});
|
|
}
|
|
function makeChangeFromHistory(doc$1, type, allowSelectionOnly) {
|
|
var suppress = doc$1.cm && doc$1.cm.state.suppressEdits;
|
|
if (suppress && !allowSelectionOnly) return;
|
|
var hist = doc$1.history, event, selAfter = doc$1.sel;
|
|
var source = type == "undo" ? hist.done : hist.undone, dest = type == "undo" ? hist.undone : hist.done;
|
|
var i$3 = 0;
|
|
for (; i$3 < source.length; i$3++) {
|
|
event = source[i$3];
|
|
if (allowSelectionOnly ? event.ranges && !event.equals(doc$1.sel) : !event.ranges) break;
|
|
}
|
|
if (i$3 == source.length) return;
|
|
hist.lastOrigin = hist.lastSelOrigin = null;
|
|
for (;;) {
|
|
event = source.pop();
|
|
if (event.ranges) {
|
|
pushSelectionToHistory(event, dest);
|
|
if (allowSelectionOnly && !event.equals(doc$1.sel)) {
|
|
setSelection(doc$1, event, { clearRedo: false });
|
|
return;
|
|
}
|
|
selAfter = event;
|
|
} else if (suppress) {
|
|
source.push(event);
|
|
return;
|
|
} else break;
|
|
}
|
|
var antiChanges = [];
|
|
pushSelectionToHistory(selAfter, dest);
|
|
dest.push({
|
|
changes: antiChanges,
|
|
generation: hist.generation
|
|
});
|
|
hist.generation = event.generation || ++hist.maxGeneration;
|
|
var filter = hasHandler(doc$1, "beforeChange") || doc$1.cm && hasHandler(doc$1.cm, "beforeChange");
|
|
var loop = function(i$4) {
|
|
var change = event.changes[i$4];
|
|
change.origin = type;
|
|
if (filter && !filterChange(doc$1, change, false)) {
|
|
source.length = 0;
|
|
return {};
|
|
}
|
|
antiChanges.push(historyChangeFromChange(doc$1, change));
|
|
var after = i$4 ? computeSelAfterChange(doc$1, change) : lst(source);
|
|
makeChangeSingleDoc(doc$1, change, after, mergeOldSpans(doc$1, change));
|
|
if (!i$4 && doc$1.cm) doc$1.cm.scrollIntoView({
|
|
from: change.from,
|
|
to: changeEnd(change)
|
|
});
|
|
var rebased = [];
|
|
linkedDocs(doc$1, function(doc$2, sharedHist) {
|
|
if (!sharedHist && indexOf(rebased, doc$2.history) == -1) {
|
|
rebaseHist(doc$2.history, change);
|
|
rebased.push(doc$2.history);
|
|
}
|
|
makeChangeSingleDoc(doc$2, change, null, mergeOldSpans(doc$2, change));
|
|
});
|
|
};
|
|
for (var i$1$1 = event.changes.length - 1; i$1$1 >= 0; --i$1$1) {
|
|
var returned = loop(i$1$1);
|
|
if (returned) return returned.v;
|
|
}
|
|
}
|
|
function shiftDoc(doc$1, distance) {
|
|
if (distance == 0) return;
|
|
doc$1.first += distance;
|
|
doc$1.sel = new Selection(map(doc$1.sel.ranges, function(range$1) {
|
|
return new Range(Pos(range$1.anchor.line + distance, range$1.anchor.ch), Pos(range$1.head.line + distance, range$1.head.ch));
|
|
}), doc$1.sel.primIndex);
|
|
if (doc$1.cm) {
|
|
regChange(doc$1.cm, doc$1.first, doc$1.first - distance, distance);
|
|
for (var d = doc$1.cm.display, l = d.viewFrom; l < d.viewTo; l++) regLineChange(doc$1.cm, l, "gutter");
|
|
}
|
|
}
|
|
function makeChangeSingleDoc(doc$1, change, selAfter, spans) {
|
|
if (doc$1.cm && !doc$1.cm.curOp) return operation(doc$1.cm, makeChangeSingleDoc)(doc$1, change, selAfter, spans);
|
|
if (change.to.line < doc$1.first) {
|
|
shiftDoc(doc$1, change.text.length - 1 - (change.to.line - change.from.line));
|
|
return;
|
|
}
|
|
if (change.from.line > doc$1.lastLine()) return;
|
|
if (change.from.line < doc$1.first) {
|
|
var shift = change.text.length - 1 - (doc$1.first - change.from.line);
|
|
shiftDoc(doc$1, shift);
|
|
change = {
|
|
from: Pos(doc$1.first, 0),
|
|
to: Pos(change.to.line + shift, change.to.ch),
|
|
text: [lst(change.text)],
|
|
origin: change.origin
|
|
};
|
|
}
|
|
var last = doc$1.lastLine();
|
|
if (change.to.line > last) change = {
|
|
from: change.from,
|
|
to: Pos(last, getLine(doc$1, last).text.length),
|
|
text: [change.text[0]],
|
|
origin: change.origin
|
|
};
|
|
change.removed = getBetween(doc$1, change.from, change.to);
|
|
if (!selAfter) selAfter = computeSelAfterChange(doc$1, change);
|
|
if (doc$1.cm) makeChangeSingleDocInEditor(doc$1.cm, change, spans);
|
|
else updateDoc(doc$1, change, spans);
|
|
setSelectionNoUndo(doc$1, selAfter, sel_dontScroll);
|
|
if (doc$1.cantEdit && skipAtomic(doc$1, Pos(doc$1.firstLine(), 0))) doc$1.cantEdit = false;
|
|
}
|
|
function makeChangeSingleDocInEditor(cm, change, spans) {
|
|
var doc$1 = cm.doc, display = cm.display, from = change.from, to = change.to;
|
|
var recomputeMaxLength = false, checkWidthStart = from.line;
|
|
if (!cm.options.lineWrapping) {
|
|
checkWidthStart = lineNo(visualLine(getLine(doc$1, from.line)));
|
|
doc$1.iter(checkWidthStart, to.line + 1, function(line) {
|
|
if (line == display.maxLine) {
|
|
recomputeMaxLength = true;
|
|
return true;
|
|
}
|
|
});
|
|
}
|
|
if (doc$1.sel.contains(change.from, change.to) > -1) signalCursorActivity(cm);
|
|
updateDoc(doc$1, change, spans, estimateHeight(cm));
|
|
if (!cm.options.lineWrapping) {
|
|
doc$1.iter(checkWidthStart, from.line + change.text.length, function(line) {
|
|
var len = lineLength(line);
|
|
if (len > display.maxLineLength) {
|
|
display.maxLine = line;
|
|
display.maxLineLength = len;
|
|
display.maxLineChanged = true;
|
|
recomputeMaxLength = false;
|
|
}
|
|
});
|
|
if (recomputeMaxLength) cm.curOp.updateMaxLine = true;
|
|
}
|
|
retreatFrontier(doc$1, from.line);
|
|
startWorker(cm, 400);
|
|
var lendiff = change.text.length - (to.line - from.line) - 1;
|
|
if (change.full) regChange(cm);
|
|
else if (from.line == to.line && change.text.length == 1 && !isWholeLineUpdate(cm.doc, change)) regLineChange(cm, from.line, "text");
|
|
else regChange(cm, from.line, to.line + 1, lendiff);
|
|
var changesHandler = hasHandler(cm, "changes"), changeHandler = hasHandler(cm, "change");
|
|
if (changeHandler || changesHandler) {
|
|
var obj = {
|
|
from,
|
|
to,
|
|
text: change.text,
|
|
removed: change.removed,
|
|
origin: change.origin
|
|
};
|
|
if (changeHandler) signalLater(cm, "change", cm, obj);
|
|
if (changesHandler) (cm.curOp.changeObjs || (cm.curOp.changeObjs = [])).push(obj);
|
|
}
|
|
cm.display.selForContextMenu = null;
|
|
}
|
|
function replaceRange(doc$1, code, from, to, origin) {
|
|
var assign;
|
|
if (!to) to = from;
|
|
if (cmp(to, from) < 0) assign = [to, from], from = assign[0], to = assign[1];
|
|
if (typeof code == "string") code = doc$1.splitLines(code);
|
|
makeChange(doc$1, {
|
|
from,
|
|
to,
|
|
text: code,
|
|
origin
|
|
});
|
|
}
|
|
function rebaseHistSelSingle(pos, from, to, diff) {
|
|
if (to < pos.line) pos.line += diff;
|
|
else if (from < pos.line) {
|
|
pos.line = from;
|
|
pos.ch = 0;
|
|
}
|
|
}
|
|
function rebaseHistArray(array, from, to, diff) {
|
|
for (var i$3 = 0; i$3 < array.length; ++i$3) {
|
|
var sub = array[i$3], ok = true;
|
|
if (sub.ranges) {
|
|
if (!sub.copied) {
|
|
sub = array[i$3] = sub.deepCopy();
|
|
sub.copied = true;
|
|
}
|
|
for (var j = 0; j < sub.ranges.length; j++) {
|
|
rebaseHistSelSingle(sub.ranges[j].anchor, from, to, diff);
|
|
rebaseHistSelSingle(sub.ranges[j].head, from, to, diff);
|
|
}
|
|
continue;
|
|
}
|
|
for (var j$1 = 0; j$1 < sub.changes.length; ++j$1) {
|
|
var cur = sub.changes[j$1];
|
|
if (to < cur.from.line) {
|
|
cur.from = Pos(cur.from.line + diff, cur.from.ch);
|
|
cur.to = Pos(cur.to.line + diff, cur.to.ch);
|
|
} else if (from <= cur.to.line) {
|
|
ok = false;
|
|
break;
|
|
}
|
|
}
|
|
if (!ok) {
|
|
array.splice(0, i$3 + 1);
|
|
i$3 = 0;
|
|
}
|
|
}
|
|
}
|
|
function rebaseHist(hist, change) {
|
|
var from = change.from.line, to = change.to.line, diff = change.text.length - (to - from) - 1;
|
|
rebaseHistArray(hist.done, from, to, diff);
|
|
rebaseHistArray(hist.undone, from, to, diff);
|
|
}
|
|
function changeLine(doc$1, handle, changeType, op) {
|
|
var no = handle, line = handle;
|
|
if (typeof handle == "number") line = getLine(doc$1, clipLine(doc$1, handle));
|
|
else no = lineNo(handle);
|
|
if (no == null) return null;
|
|
if (op(line, no) && doc$1.cm) regLineChange(doc$1.cm, no, changeType);
|
|
return line;
|
|
}
|
|
function LeafChunk(lines) {
|
|
this.lines = lines;
|
|
this.parent = null;
|
|
var height = 0;
|
|
for (var i$3 = 0; i$3 < lines.length; ++i$3) {
|
|
lines[i$3].parent = this;
|
|
height += lines[i$3].height;
|
|
}
|
|
this.height = height;
|
|
}
|
|
LeafChunk.prototype = {
|
|
chunkSize: function() {
|
|
return this.lines.length;
|
|
},
|
|
removeInner: function(at, n) {
|
|
for (var i$3 = at, e = at + n; i$3 < e; ++i$3) {
|
|
var line = this.lines[i$3];
|
|
this.height -= line.height;
|
|
cleanUpLine(line);
|
|
signalLater(line, "delete");
|
|
}
|
|
this.lines.splice(at, n);
|
|
},
|
|
collapse: function(lines) {
|
|
lines.push.apply(lines, this.lines);
|
|
},
|
|
insertInner: function(at, lines, height) {
|
|
this.height += height;
|
|
this.lines = this.lines.slice(0, at).concat(lines).concat(this.lines.slice(at));
|
|
for (var i$3 = 0; i$3 < lines.length; ++i$3) lines[i$3].parent = this;
|
|
},
|
|
iterN: function(at, n, op) {
|
|
for (var e = at + n; at < e; ++at) if (op(this.lines[at])) return true;
|
|
}
|
|
};
|
|
function BranchChunk(children) {
|
|
this.children = children;
|
|
var size = 0, height = 0;
|
|
for (var i$3 = 0; i$3 < children.length; ++i$3) {
|
|
var ch = children[i$3];
|
|
size += ch.chunkSize();
|
|
height += ch.height;
|
|
ch.parent = this;
|
|
}
|
|
this.size = size;
|
|
this.height = height;
|
|
this.parent = null;
|
|
}
|
|
BranchChunk.prototype = {
|
|
chunkSize: function() {
|
|
return this.size;
|
|
},
|
|
removeInner: function(at, n) {
|
|
this.size -= n;
|
|
for (var i$3 = 0; i$3 < this.children.length; ++i$3) {
|
|
var child = this.children[i$3], sz = child.chunkSize();
|
|
if (at < sz) {
|
|
var rm = Math.min(n, sz - at), oldHeight = child.height;
|
|
child.removeInner(at, rm);
|
|
this.height -= oldHeight - child.height;
|
|
if (sz == rm) {
|
|
this.children.splice(i$3--, 1);
|
|
child.parent = null;
|
|
}
|
|
if ((n -= rm) == 0) break;
|
|
at = 0;
|
|
} else at -= sz;
|
|
}
|
|
if (this.size - n < 25 && (this.children.length > 1 || !(this.children[0] instanceof LeafChunk))) {
|
|
var lines = [];
|
|
this.collapse(lines);
|
|
this.children = [new LeafChunk(lines)];
|
|
this.children[0].parent = this;
|
|
}
|
|
},
|
|
collapse: function(lines) {
|
|
for (var i$3 = 0; i$3 < this.children.length; ++i$3) this.children[i$3].collapse(lines);
|
|
},
|
|
insertInner: function(at, lines, height) {
|
|
this.size += lines.length;
|
|
this.height += height;
|
|
for (var i$3 = 0; i$3 < this.children.length; ++i$3) {
|
|
var child = this.children[i$3], sz = child.chunkSize();
|
|
if (at <= sz) {
|
|
child.insertInner(at, lines, height);
|
|
if (child.lines && child.lines.length > 50) {
|
|
var remaining = child.lines.length % 25 + 25;
|
|
for (var pos = remaining; pos < child.lines.length;) {
|
|
var leaf = new LeafChunk(child.lines.slice(pos, pos += 25));
|
|
child.height -= leaf.height;
|
|
this.children.splice(++i$3, 0, leaf);
|
|
leaf.parent = this;
|
|
}
|
|
child.lines = child.lines.slice(0, remaining);
|
|
this.maybeSpill();
|
|
}
|
|
break;
|
|
}
|
|
at -= sz;
|
|
}
|
|
},
|
|
maybeSpill: function() {
|
|
if (this.children.length <= 10) return;
|
|
var me = this;
|
|
do {
|
|
var spilled = me.children.splice(me.children.length - 5, 5);
|
|
var sibling = new BranchChunk(spilled);
|
|
if (!me.parent) {
|
|
var copy = new BranchChunk(me.children);
|
|
copy.parent = me;
|
|
me.children = [copy, sibling];
|
|
me = copy;
|
|
} else {
|
|
me.size -= sibling.size;
|
|
me.height -= sibling.height;
|
|
var myIndex = indexOf(me.parent.children, me);
|
|
me.parent.children.splice(myIndex + 1, 0, sibling);
|
|
}
|
|
sibling.parent = me.parent;
|
|
} while (me.children.length > 10);
|
|
me.parent.maybeSpill();
|
|
},
|
|
iterN: function(at, n, op) {
|
|
for (var i$3 = 0; i$3 < this.children.length; ++i$3) {
|
|
var child = this.children[i$3], sz = child.chunkSize();
|
|
if (at < sz) {
|
|
var used = Math.min(n, sz - at);
|
|
if (child.iterN(at, used, op)) return true;
|
|
if ((n -= used) == 0) break;
|
|
at = 0;
|
|
} else at -= sz;
|
|
}
|
|
}
|
|
};
|
|
var LineWidget = function(doc$1, node, options) {
|
|
if (options) {
|
|
for (var opt in options) if (options.hasOwnProperty(opt)) this[opt] = options[opt];
|
|
}
|
|
this.doc = doc$1;
|
|
this.node = node;
|
|
};
|
|
LineWidget.prototype.clear = function() {
|
|
var cm = this.doc.cm, ws = this.line.widgets, line = this.line, no = lineNo(line);
|
|
if (no == null || !ws) return;
|
|
for (var i$3 = 0; i$3 < ws.length; ++i$3) if (ws[i$3] == this) ws.splice(i$3--, 1);
|
|
if (!ws.length) line.widgets = null;
|
|
var height = widgetHeight(this);
|
|
updateLineHeight(line, Math.max(0, line.height - height));
|
|
if (cm) {
|
|
runInOp(cm, function() {
|
|
adjustScrollWhenAboveVisible(cm, line, -height);
|
|
regLineChange(cm, no, "widget");
|
|
});
|
|
signalLater(cm, "lineWidgetCleared", cm, this, no);
|
|
}
|
|
};
|
|
LineWidget.prototype.changed = function() {
|
|
var this$1 = this;
|
|
var oldH = this.height, cm = this.doc.cm, line = this.line;
|
|
this.height = null;
|
|
var diff = widgetHeight(this) - oldH;
|
|
if (!diff) return;
|
|
if (!lineIsHidden(this.doc, line)) updateLineHeight(line, line.height + diff);
|
|
if (cm) runInOp(cm, function() {
|
|
cm.curOp.forceUpdate = true;
|
|
adjustScrollWhenAboveVisible(cm, line, diff);
|
|
signalLater(cm, "lineWidgetChanged", cm, this$1, lineNo(line));
|
|
});
|
|
};
|
|
eventMixin(LineWidget);
|
|
function adjustScrollWhenAboveVisible(cm, line, diff) {
|
|
if (heightAtLine(line) < (cm.curOp && cm.curOp.scrollTop || cm.doc.scrollTop)) addToScrollTop(cm, diff);
|
|
}
|
|
function addLineWidget(doc$1, handle, node, options) {
|
|
var widget = new LineWidget(doc$1, node, options);
|
|
var cm = doc$1.cm;
|
|
if (cm && widget.noHScroll) cm.display.alignWidgets = true;
|
|
changeLine(doc$1, handle, "widget", function(line) {
|
|
var widgets = line.widgets || (line.widgets = []);
|
|
if (widget.insertAt == null) widgets.push(widget);
|
|
else widgets.splice(Math.min(widgets.length, Math.max(0, widget.insertAt)), 0, widget);
|
|
widget.line = line;
|
|
if (cm && !lineIsHidden(doc$1, line)) {
|
|
var aboveVisible = heightAtLine(line) < doc$1.scrollTop;
|
|
updateLineHeight(line, line.height + widgetHeight(widget));
|
|
if (aboveVisible) addToScrollTop(cm, widget.height);
|
|
cm.curOp.forceUpdate = true;
|
|
}
|
|
return true;
|
|
});
|
|
if (cm) signalLater(cm, "lineWidgetAdded", cm, widget, typeof handle == "number" ? handle : lineNo(handle));
|
|
return widget;
|
|
}
|
|
var nextMarkerId = 0;
|
|
var TextMarker = function(doc$1, type) {
|
|
this.lines = [];
|
|
this.type = type;
|
|
this.doc = doc$1;
|
|
this.id = ++nextMarkerId;
|
|
};
|
|
TextMarker.prototype.clear = function() {
|
|
if (this.explicitlyCleared) return;
|
|
var cm = this.doc.cm, withOp = cm && !cm.curOp;
|
|
if (withOp) startOperation(cm);
|
|
if (hasHandler(this, "clear")) {
|
|
var found = this.find();
|
|
if (found) signalLater(this, "clear", found.from, found.to);
|
|
}
|
|
var min = null, max = null;
|
|
for (var i$3 = 0; i$3 < this.lines.length; ++i$3) {
|
|
var line = this.lines[i$3];
|
|
var span = getMarkedSpanFor(line.markedSpans, this);
|
|
if (cm && !this.collapsed) regLineChange(cm, lineNo(line), "text");
|
|
else if (cm) {
|
|
if (span.to != null) max = lineNo(line);
|
|
if (span.from != null) min = lineNo(line);
|
|
}
|
|
line.markedSpans = removeMarkedSpan(line.markedSpans, span);
|
|
if (span.from == null && this.collapsed && !lineIsHidden(this.doc, line) && cm) updateLineHeight(line, textHeight(cm.display));
|
|
}
|
|
if (cm && this.collapsed && !cm.options.lineWrapping) for (var i$1$1 = 0; i$1$1 < this.lines.length; ++i$1$1) {
|
|
var visual = visualLine(this.lines[i$1$1]), len = lineLength(visual);
|
|
if (len > cm.display.maxLineLength) {
|
|
cm.display.maxLine = visual;
|
|
cm.display.maxLineLength = len;
|
|
cm.display.maxLineChanged = true;
|
|
}
|
|
}
|
|
if (min != null && cm && this.collapsed) regChange(cm, min, max + 1);
|
|
this.lines.length = 0;
|
|
this.explicitlyCleared = true;
|
|
if (this.atomic && this.doc.cantEdit) {
|
|
this.doc.cantEdit = false;
|
|
if (cm) reCheckSelection(cm.doc);
|
|
}
|
|
if (cm) signalLater(cm, "markerCleared", cm, this, min, max);
|
|
if (withOp) endOperation(cm);
|
|
if (this.parent) this.parent.clear();
|
|
};
|
|
TextMarker.prototype.find = function(side, lineObj) {
|
|
if (side == null && this.type == "bookmark") side = 1;
|
|
var from, to;
|
|
for (var i$3 = 0; i$3 < this.lines.length; ++i$3) {
|
|
var line = this.lines[i$3];
|
|
var span = getMarkedSpanFor(line.markedSpans, this);
|
|
if (span.from != null) {
|
|
from = Pos(lineObj ? line : lineNo(line), span.from);
|
|
if (side == -1) return from;
|
|
}
|
|
if (span.to != null) {
|
|
to = Pos(lineObj ? line : lineNo(line), span.to);
|
|
if (side == 1) return to;
|
|
}
|
|
}
|
|
return from && {
|
|
from,
|
|
to
|
|
};
|
|
};
|
|
TextMarker.prototype.changed = function() {
|
|
var this$1 = this;
|
|
var pos = this.find(-1, true), widget = this, cm = this.doc.cm;
|
|
if (!pos || !cm) return;
|
|
runInOp(cm, function() {
|
|
var line = pos.line, lineN = lineNo(pos.line);
|
|
var view = findViewForLine(cm, lineN);
|
|
if (view) {
|
|
clearLineMeasurementCacheFor(view);
|
|
cm.curOp.selectionChanged = cm.curOp.forceUpdate = true;
|
|
}
|
|
cm.curOp.updateMaxLine = true;
|
|
if (!lineIsHidden(widget.doc, line) && widget.height != null) {
|
|
var oldHeight = widget.height;
|
|
widget.height = null;
|
|
var dHeight = widgetHeight(widget) - oldHeight;
|
|
if (dHeight) updateLineHeight(line, line.height + dHeight);
|
|
}
|
|
signalLater(cm, "markerChanged", cm, this$1);
|
|
});
|
|
};
|
|
TextMarker.prototype.attachLine = function(line) {
|
|
if (!this.lines.length && this.doc.cm) {
|
|
var op = this.doc.cm.curOp;
|
|
if (!op.maybeHiddenMarkers || indexOf(op.maybeHiddenMarkers, this) == -1) (op.maybeUnhiddenMarkers || (op.maybeUnhiddenMarkers = [])).push(this);
|
|
}
|
|
this.lines.push(line);
|
|
};
|
|
TextMarker.prototype.detachLine = function(line) {
|
|
this.lines.splice(indexOf(this.lines, line), 1);
|
|
if (!this.lines.length && this.doc.cm) {
|
|
var op = this.doc.cm.curOp;
|
|
(op.maybeHiddenMarkers || (op.maybeHiddenMarkers = [])).push(this);
|
|
}
|
|
};
|
|
eventMixin(TextMarker);
|
|
function markText(doc$1, from, to, options, type) {
|
|
if (options && options.shared) return markTextShared(doc$1, from, to, options, type);
|
|
if (doc$1.cm && !doc$1.cm.curOp) return operation(doc$1.cm, markText)(doc$1, from, to, options, type);
|
|
var marker = new TextMarker(doc$1, type), diff = cmp(from, to);
|
|
if (options) copyObj(options, marker, false);
|
|
if (diff > 0 || diff == 0 && marker.clearWhenEmpty !== false) return marker;
|
|
if (marker.replacedWith) {
|
|
marker.collapsed = true;
|
|
marker.widgetNode = eltP("span", [marker.replacedWith], "CodeMirror-widget");
|
|
if (!options.handleMouseEvents) marker.widgetNode.setAttribute("cm-ignore-events", "true");
|
|
if (options.insertLeft) marker.widgetNode.insertLeft = true;
|
|
}
|
|
if (marker.collapsed) {
|
|
if (conflictingCollapsedRange(doc$1, from.line, from, to, marker) || from.line != to.line && conflictingCollapsedRange(doc$1, to.line, from, to, marker)) throw new Error("Inserting collapsed marker partially overlapping an existing one");
|
|
seeCollapsedSpans();
|
|
}
|
|
if (marker.addToHistory) addChangeToHistory(doc$1, {
|
|
from,
|
|
to,
|
|
origin: "markText"
|
|
}, doc$1.sel, NaN);
|
|
var curLine = from.line, cm = doc$1.cm, updateMaxLine;
|
|
doc$1.iter(curLine, to.line + 1, function(line) {
|
|
if (cm && marker.collapsed && !cm.options.lineWrapping && visualLine(line) == cm.display.maxLine) updateMaxLine = true;
|
|
if (marker.collapsed && curLine != from.line) updateLineHeight(line, 0);
|
|
addMarkedSpan(line, new MarkedSpan(marker, curLine == from.line ? from.ch : null, curLine == to.line ? to.ch : null), doc$1.cm && doc$1.cm.curOp);
|
|
++curLine;
|
|
});
|
|
if (marker.collapsed) doc$1.iter(from.line, to.line + 1, function(line) {
|
|
if (lineIsHidden(doc$1, line)) updateLineHeight(line, 0);
|
|
});
|
|
if (marker.clearOnEnter) on(marker, "beforeCursorEnter", function() {
|
|
return marker.clear();
|
|
});
|
|
if (marker.readOnly) {
|
|
seeReadOnlySpans();
|
|
if (doc$1.history.done.length || doc$1.history.undone.length) doc$1.clearHistory();
|
|
}
|
|
if (marker.collapsed) {
|
|
marker.id = ++nextMarkerId;
|
|
marker.atomic = true;
|
|
}
|
|
if (cm) {
|
|
if (updateMaxLine) cm.curOp.updateMaxLine = true;
|
|
if (marker.collapsed) regChange(cm, from.line, to.line + 1);
|
|
else if (marker.className || marker.startStyle || marker.endStyle || marker.css || marker.attributes || marker.title) for (var i$3 = from.line; i$3 <= to.line; i$3++) regLineChange(cm, i$3, "text");
|
|
if (marker.atomic) reCheckSelection(cm.doc);
|
|
signalLater(cm, "markerAdded", cm, marker);
|
|
}
|
|
return marker;
|
|
}
|
|
var SharedTextMarker = function(markers, primary) {
|
|
this.markers = markers;
|
|
this.primary = primary;
|
|
for (var i$3 = 0; i$3 < markers.length; ++i$3) markers[i$3].parent = this;
|
|
};
|
|
SharedTextMarker.prototype.clear = function() {
|
|
if (this.explicitlyCleared) return;
|
|
this.explicitlyCleared = true;
|
|
for (var i$3 = 0; i$3 < this.markers.length; ++i$3) this.markers[i$3].clear();
|
|
signalLater(this, "clear");
|
|
};
|
|
SharedTextMarker.prototype.find = function(side, lineObj) {
|
|
return this.primary.find(side, lineObj);
|
|
};
|
|
eventMixin(SharedTextMarker);
|
|
function markTextShared(doc$1, from, to, options, type) {
|
|
options = copyObj(options);
|
|
options.shared = false;
|
|
var markers = [markText(doc$1, from, to, options, type)], primary = markers[0];
|
|
var widget = options.widgetNode;
|
|
linkedDocs(doc$1, function(doc$2) {
|
|
if (widget) options.widgetNode = widget.cloneNode(true);
|
|
markers.push(markText(doc$2, clipPos(doc$2, from), clipPos(doc$2, to), options, type));
|
|
for (var i$3 = 0; i$3 < doc$2.linked.length; ++i$3) if (doc$2.linked[i$3].isParent) return;
|
|
primary = lst(markers);
|
|
});
|
|
return new SharedTextMarker(markers, primary);
|
|
}
|
|
function findSharedMarkers(doc$1) {
|
|
return doc$1.findMarks(Pos(doc$1.first, 0), doc$1.clipPos(Pos(doc$1.lastLine())), function(m) {
|
|
return m.parent;
|
|
});
|
|
}
|
|
function copySharedMarkers(doc$1, markers) {
|
|
for (var i$3 = 0; i$3 < markers.length; i$3++) {
|
|
var marker = markers[i$3], pos = marker.find();
|
|
var mFrom = doc$1.clipPos(pos.from), mTo = doc$1.clipPos(pos.to);
|
|
if (cmp(mFrom, mTo)) {
|
|
var subMark = markText(doc$1, mFrom, mTo, marker.primary, marker.primary.type);
|
|
marker.markers.push(subMark);
|
|
subMark.parent = marker;
|
|
}
|
|
}
|
|
}
|
|
function detachSharedMarkers(markers) {
|
|
var loop = function(i$4) {
|
|
var marker = markers[i$4], linked = [marker.primary.doc];
|
|
linkedDocs(marker.primary.doc, function(d) {
|
|
return linked.push(d);
|
|
});
|
|
for (var j = 0; j < marker.markers.length; j++) {
|
|
var subMarker = marker.markers[j];
|
|
if (indexOf(linked, subMarker.doc) == -1) {
|
|
subMarker.parent = null;
|
|
marker.markers.splice(j--, 1);
|
|
}
|
|
}
|
|
};
|
|
for (var i$3 = 0; i$3 < markers.length; i$3++) loop(i$3);
|
|
}
|
|
var nextDocId = 0;
|
|
var Doc = function(text, mode, firstLine, lineSep, direction) {
|
|
if (!(this instanceof Doc)) return new Doc(text, mode, firstLine, lineSep, direction);
|
|
if (firstLine == null) firstLine = 0;
|
|
BranchChunk.call(this, [new LeafChunk([new Line("", null)])]);
|
|
this.first = firstLine;
|
|
this.scrollTop = this.scrollLeft = 0;
|
|
this.cantEdit = false;
|
|
this.cleanGeneration = 1;
|
|
this.modeFrontier = this.highlightFrontier = firstLine;
|
|
var start = Pos(firstLine, 0);
|
|
this.sel = simpleSelection(start);
|
|
this.history = new History(null);
|
|
this.id = ++nextDocId;
|
|
this.modeOption = mode;
|
|
this.lineSep = lineSep;
|
|
this.direction = direction == "rtl" ? "rtl" : "ltr";
|
|
this.extend = false;
|
|
if (typeof text == "string") text = this.splitLines(text);
|
|
updateDoc(this, {
|
|
from: start,
|
|
to: start,
|
|
text
|
|
});
|
|
setSelection(this, simpleSelection(start), sel_dontScroll);
|
|
};
|
|
Doc.prototype = createObj(BranchChunk.prototype, {
|
|
constructor: Doc,
|
|
iter: function(from, to, op) {
|
|
if (op) this.iterN(from - this.first, to - from, op);
|
|
else this.iterN(this.first, this.first + this.size, from);
|
|
},
|
|
insert: function(at, lines) {
|
|
var height = 0;
|
|
for (var i$3 = 0; i$3 < lines.length; ++i$3) height += lines[i$3].height;
|
|
this.insertInner(at - this.first, lines, height);
|
|
},
|
|
remove: function(at, n) {
|
|
this.removeInner(at - this.first, n);
|
|
},
|
|
getValue: function(lineSep) {
|
|
var lines = getLines(this, this.first, this.first + this.size);
|
|
if (lineSep === false) return lines;
|
|
return lines.join(lineSep || this.lineSeparator());
|
|
},
|
|
setValue: docMethodOp(function(code) {
|
|
var top = Pos(this.first, 0), last = this.first + this.size - 1;
|
|
makeChange(this, {
|
|
from: top,
|
|
to: Pos(last, getLine(this, last).text.length),
|
|
text: this.splitLines(code),
|
|
origin: "setValue",
|
|
full: true
|
|
}, true);
|
|
if (this.cm) scrollToCoords(this.cm, 0, 0);
|
|
setSelection(this, simpleSelection(top), sel_dontScroll);
|
|
}),
|
|
replaceRange: function(code, from, to, origin) {
|
|
from = clipPos(this, from);
|
|
to = to ? clipPos(this, to) : from;
|
|
replaceRange(this, code, from, to, origin);
|
|
},
|
|
getRange: function(from, to, lineSep) {
|
|
var lines = getBetween(this, clipPos(this, from), clipPos(this, to));
|
|
if (lineSep === false) return lines;
|
|
if (lineSep === "") return lines.join("");
|
|
return lines.join(lineSep || this.lineSeparator());
|
|
},
|
|
getLine: function(line) {
|
|
var l = this.getLineHandle(line);
|
|
return l && l.text;
|
|
},
|
|
getLineHandle: function(line) {
|
|
if (isLine(this, line)) return getLine(this, line);
|
|
},
|
|
getLineNumber: function(line) {
|
|
return lineNo(line);
|
|
},
|
|
getLineHandleVisualStart: function(line) {
|
|
if (typeof line == "number") line = getLine(this, line);
|
|
return visualLine(line);
|
|
},
|
|
lineCount: function() {
|
|
return this.size;
|
|
},
|
|
firstLine: function() {
|
|
return this.first;
|
|
},
|
|
lastLine: function() {
|
|
return this.first + this.size - 1;
|
|
},
|
|
clipPos: function(pos) {
|
|
return clipPos(this, pos);
|
|
},
|
|
getCursor: function(start) {
|
|
var range$1 = this.sel.primary(), pos;
|
|
if (start == null || start == "head") pos = range$1.head;
|
|
else if (start == "anchor") pos = range$1.anchor;
|
|
else if (start == "end" || start == "to" || start === false) pos = range$1.to();
|
|
else pos = range$1.from();
|
|
return pos;
|
|
},
|
|
listSelections: function() {
|
|
return this.sel.ranges;
|
|
},
|
|
somethingSelected: function() {
|
|
return this.sel.somethingSelected();
|
|
},
|
|
setCursor: docMethodOp(function(line, ch, options) {
|
|
setSimpleSelection(this, clipPos(this, typeof line == "number" ? Pos(line, ch || 0) : line), null, options);
|
|
}),
|
|
setSelection: docMethodOp(function(anchor, head, options) {
|
|
setSimpleSelection(this, clipPos(this, anchor), clipPos(this, head || anchor), options);
|
|
}),
|
|
extendSelection: docMethodOp(function(head, other, options) {
|
|
extendSelection(this, clipPos(this, head), other && clipPos(this, other), options);
|
|
}),
|
|
extendSelections: docMethodOp(function(heads, options) {
|
|
extendSelections(this, clipPosArray(this, heads), options);
|
|
}),
|
|
extendSelectionsBy: docMethodOp(function(f, options) {
|
|
var heads = map(this.sel.ranges, f);
|
|
extendSelections(this, clipPosArray(this, heads), options);
|
|
}),
|
|
setSelections: docMethodOp(function(ranges, primary, options) {
|
|
if (!ranges.length) return;
|
|
var out = [];
|
|
for (var i$3 = 0; i$3 < ranges.length; i$3++) out[i$3] = new Range(clipPos(this, ranges[i$3].anchor), clipPos(this, ranges[i$3].head || ranges[i$3].anchor));
|
|
if (primary == null) primary = Math.min(ranges.length - 1, this.sel.primIndex);
|
|
setSelection(this, normalizeSelection(this.cm, out, primary), options);
|
|
}),
|
|
addSelection: docMethodOp(function(anchor, head, options) {
|
|
var ranges = this.sel.ranges.slice(0);
|
|
ranges.push(new Range(clipPos(this, anchor), clipPos(this, head || anchor)));
|
|
setSelection(this, normalizeSelection(this.cm, ranges, ranges.length - 1), options);
|
|
}),
|
|
getSelection: function(lineSep) {
|
|
var ranges = this.sel.ranges, lines;
|
|
for (var i$3 = 0; i$3 < ranges.length; i$3++) {
|
|
var sel = getBetween(this, ranges[i$3].from(), ranges[i$3].to());
|
|
lines = lines ? lines.concat(sel) : sel;
|
|
}
|
|
if (lineSep === false) return lines;
|
|
else return lines.join(lineSep || this.lineSeparator());
|
|
},
|
|
getSelections: function(lineSep) {
|
|
var parts = [], ranges = this.sel.ranges;
|
|
for (var i$3 = 0; i$3 < ranges.length; i$3++) {
|
|
var sel = getBetween(this, ranges[i$3].from(), ranges[i$3].to());
|
|
if (lineSep !== false) sel = sel.join(lineSep || this.lineSeparator());
|
|
parts[i$3] = sel;
|
|
}
|
|
return parts;
|
|
},
|
|
replaceSelection: function(code, collapse, origin) {
|
|
var dup = [];
|
|
for (var i$3 = 0; i$3 < this.sel.ranges.length; i$3++) dup[i$3] = code;
|
|
this.replaceSelections(dup, collapse, origin || "+input");
|
|
},
|
|
replaceSelections: docMethodOp(function(code, collapse, origin) {
|
|
var changes = [], sel = this.sel;
|
|
for (var i$3 = 0; i$3 < sel.ranges.length; i$3++) {
|
|
var range$1 = sel.ranges[i$3];
|
|
changes[i$3] = {
|
|
from: range$1.from(),
|
|
to: range$1.to(),
|
|
text: this.splitLines(code[i$3]),
|
|
origin
|
|
};
|
|
}
|
|
var newSel = collapse && collapse != "end" && computeReplacedSel(this, changes, collapse);
|
|
for (var i$1$1 = changes.length - 1; i$1$1 >= 0; i$1$1--) makeChange(this, changes[i$1$1]);
|
|
if (newSel) setSelectionReplaceHistory(this, newSel);
|
|
else if (this.cm) ensureCursorVisible(this.cm);
|
|
}),
|
|
undo: docMethodOp(function() {
|
|
makeChangeFromHistory(this, "undo");
|
|
}),
|
|
redo: docMethodOp(function() {
|
|
makeChangeFromHistory(this, "redo");
|
|
}),
|
|
undoSelection: docMethodOp(function() {
|
|
makeChangeFromHistory(this, "undo", true);
|
|
}),
|
|
redoSelection: docMethodOp(function() {
|
|
makeChangeFromHistory(this, "redo", true);
|
|
}),
|
|
setExtending: function(val) {
|
|
this.extend = val;
|
|
},
|
|
getExtending: function() {
|
|
return this.extend;
|
|
},
|
|
historySize: function() {
|
|
var hist = this.history, done = 0, undone = 0;
|
|
for (var i$3 = 0; i$3 < hist.done.length; i$3++) if (!hist.done[i$3].ranges) ++done;
|
|
for (var i$1$1 = 0; i$1$1 < hist.undone.length; i$1$1++) if (!hist.undone[i$1$1].ranges) ++undone;
|
|
return {
|
|
undo: done,
|
|
redo: undone
|
|
};
|
|
},
|
|
clearHistory: function() {
|
|
var this$1 = this;
|
|
this.history = new History(this.history);
|
|
linkedDocs(this, function(doc$1) {
|
|
return doc$1.history = this$1.history;
|
|
}, true);
|
|
},
|
|
markClean: function() {
|
|
this.cleanGeneration = this.changeGeneration(true);
|
|
},
|
|
changeGeneration: function(forceSplit) {
|
|
if (forceSplit) this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null;
|
|
return this.history.generation;
|
|
},
|
|
isClean: function(gen) {
|
|
return this.history.generation == (gen || this.cleanGeneration);
|
|
},
|
|
getHistory: function() {
|
|
return {
|
|
done: copyHistoryArray(this.history.done),
|
|
undone: copyHistoryArray(this.history.undone)
|
|
};
|
|
},
|
|
setHistory: function(histData) {
|
|
var hist = this.history = new History(this.history);
|
|
hist.done = copyHistoryArray(histData.done.slice(0), null, true);
|
|
hist.undone = copyHistoryArray(histData.undone.slice(0), null, true);
|
|
},
|
|
setGutterMarker: docMethodOp(function(line, gutterID, value) {
|
|
return changeLine(this, line, "gutter", function(line$1) {
|
|
var markers = line$1.gutterMarkers || (line$1.gutterMarkers = {});
|
|
markers[gutterID] = value;
|
|
if (!value && isEmpty(markers)) line$1.gutterMarkers = null;
|
|
return true;
|
|
});
|
|
}),
|
|
clearGutter: docMethodOp(function(gutterID) {
|
|
var this$1 = this;
|
|
this.iter(function(line) {
|
|
if (line.gutterMarkers && line.gutterMarkers[gutterID]) changeLine(this$1, line, "gutter", function() {
|
|
line.gutterMarkers[gutterID] = null;
|
|
if (isEmpty(line.gutterMarkers)) line.gutterMarkers = null;
|
|
return true;
|
|
});
|
|
});
|
|
}),
|
|
lineInfo: function(line) {
|
|
var n;
|
|
if (typeof line == "number") {
|
|
if (!isLine(this, line)) return null;
|
|
n = line;
|
|
line = getLine(this, line);
|
|
if (!line) return null;
|
|
} else {
|
|
n = lineNo(line);
|
|
if (n == null) return null;
|
|
}
|
|
return {
|
|
line: n,
|
|
handle: line,
|
|
text: line.text,
|
|
gutterMarkers: line.gutterMarkers,
|
|
textClass: line.textClass,
|
|
bgClass: line.bgClass,
|
|
wrapClass: line.wrapClass,
|
|
widgets: line.widgets
|
|
};
|
|
},
|
|
addLineClass: docMethodOp(function(handle, where, cls) {
|
|
return changeLine(this, handle, where == "gutter" ? "gutter" : "class", function(line) {
|
|
var prop$1 = where == "text" ? "textClass" : where == "background" ? "bgClass" : where == "gutter" ? "gutterClass" : "wrapClass";
|
|
if (!line[prop$1]) line[prop$1] = cls;
|
|
else if (classTest(cls).test(line[prop$1])) return false;
|
|
else line[prop$1] += " " + cls;
|
|
return true;
|
|
});
|
|
}),
|
|
removeLineClass: docMethodOp(function(handle, where, cls) {
|
|
return changeLine(this, handle, where == "gutter" ? "gutter" : "class", function(line) {
|
|
var prop$1 = where == "text" ? "textClass" : where == "background" ? "bgClass" : where == "gutter" ? "gutterClass" : "wrapClass";
|
|
var cur = line[prop$1];
|
|
if (!cur) return false;
|
|
else if (cls == null) line[prop$1] = null;
|
|
else {
|
|
var found = cur.match(classTest(cls));
|
|
if (!found) return false;
|
|
var end = found.index + found[0].length;
|
|
line[prop$1] = cur.slice(0, found.index) + (!found.index || end == cur.length ? "" : " ") + cur.slice(end) || null;
|
|
}
|
|
return true;
|
|
});
|
|
}),
|
|
addLineWidget: docMethodOp(function(handle, node, options) {
|
|
return addLineWidget(this, handle, node, options);
|
|
}),
|
|
removeLineWidget: function(widget) {
|
|
widget.clear();
|
|
},
|
|
markText: function(from, to, options) {
|
|
return markText(this, clipPos(this, from), clipPos(this, to), options, options && options.type || "range");
|
|
},
|
|
setBookmark: function(pos, options) {
|
|
var realOpts = {
|
|
replacedWith: options && (options.nodeType == null ? options.widget : options),
|
|
insertLeft: options && options.insertLeft,
|
|
clearWhenEmpty: false,
|
|
shared: options && options.shared,
|
|
handleMouseEvents: options && options.handleMouseEvents
|
|
};
|
|
pos = clipPos(this, pos);
|
|
return markText(this, pos, pos, realOpts, "bookmark");
|
|
},
|
|
findMarksAt: function(pos) {
|
|
pos = clipPos(this, pos);
|
|
var markers = [], spans = getLine(this, pos.line).markedSpans;
|
|
if (spans) for (var i$3 = 0; i$3 < spans.length; ++i$3) {
|
|
var span = spans[i$3];
|
|
if ((span.from == null || span.from <= pos.ch) && (span.to == null || span.to >= pos.ch)) markers.push(span.marker.parent || span.marker);
|
|
}
|
|
return markers;
|
|
},
|
|
findMarks: function(from, to, filter) {
|
|
from = clipPos(this, from);
|
|
to = clipPos(this, to);
|
|
var found = [], lineNo$1 = from.line;
|
|
this.iter(from.line, to.line + 1, function(line) {
|
|
var spans = line.markedSpans;
|
|
if (spans) for (var i$3 = 0; i$3 < spans.length; i$3++) {
|
|
var span = spans[i$3];
|
|
if (!(span.to != null && lineNo$1 == from.line && from.ch >= span.to || span.from == null && lineNo$1 != from.line || span.from != null && lineNo$1 == to.line && span.from >= to.ch) && (!filter || filter(span.marker))) found.push(span.marker.parent || span.marker);
|
|
}
|
|
++lineNo$1;
|
|
});
|
|
return found;
|
|
},
|
|
getAllMarks: function() {
|
|
var markers = [];
|
|
this.iter(function(line) {
|
|
var sps = line.markedSpans;
|
|
if (sps) {
|
|
for (var i$3 = 0; i$3 < sps.length; ++i$3) if (sps[i$3].from != null) markers.push(sps[i$3].marker);
|
|
}
|
|
});
|
|
return markers;
|
|
},
|
|
posFromIndex: function(off$1) {
|
|
var ch, lineNo$1 = this.first, sepSize = this.lineSeparator().length;
|
|
this.iter(function(line) {
|
|
var sz = line.text.length + sepSize;
|
|
if (sz > off$1) {
|
|
ch = off$1;
|
|
return true;
|
|
}
|
|
off$1 -= sz;
|
|
++lineNo$1;
|
|
});
|
|
return clipPos(this, Pos(lineNo$1, ch));
|
|
},
|
|
indexFromPos: function(coords) {
|
|
coords = clipPos(this, coords);
|
|
var index = coords.ch;
|
|
if (coords.line < this.first || coords.ch < 0) return 0;
|
|
var sepSize = this.lineSeparator().length;
|
|
this.iter(this.first, coords.line, function(line) {
|
|
index += line.text.length + sepSize;
|
|
});
|
|
return index;
|
|
},
|
|
copy: function(copyHistory) {
|
|
var doc$1 = new Doc(getLines(this, this.first, this.first + this.size), this.modeOption, this.first, this.lineSep, this.direction);
|
|
doc$1.scrollTop = this.scrollTop;
|
|
doc$1.scrollLeft = this.scrollLeft;
|
|
doc$1.sel = this.sel;
|
|
doc$1.extend = false;
|
|
if (copyHistory) {
|
|
doc$1.history.undoDepth = this.history.undoDepth;
|
|
doc$1.setHistory(this.getHistory());
|
|
}
|
|
return doc$1;
|
|
},
|
|
linkedDoc: function(options) {
|
|
if (!options) options = {};
|
|
var from = this.first, to = this.first + this.size;
|
|
if (options.from != null && options.from > from) from = options.from;
|
|
if (options.to != null && options.to < to) to = options.to;
|
|
var copy = new Doc(getLines(this, from, to), options.mode || this.modeOption, from, this.lineSep, this.direction);
|
|
if (options.sharedHist) copy.history = this.history;
|
|
(this.linked || (this.linked = [])).push({
|
|
doc: copy,
|
|
sharedHist: options.sharedHist
|
|
});
|
|
copy.linked = [{
|
|
doc: this,
|
|
isParent: true,
|
|
sharedHist: options.sharedHist
|
|
}];
|
|
copySharedMarkers(copy, findSharedMarkers(this));
|
|
return copy;
|
|
},
|
|
unlinkDoc: function(other) {
|
|
if (other instanceof CodeMirror$1) other = other.doc;
|
|
if (this.linked) for (var i$3 = 0; i$3 < this.linked.length; ++i$3) {
|
|
var link = this.linked[i$3];
|
|
if (link.doc != other) continue;
|
|
this.linked.splice(i$3, 1);
|
|
other.unlinkDoc(this);
|
|
detachSharedMarkers(findSharedMarkers(this));
|
|
break;
|
|
}
|
|
if (other.history == this.history) {
|
|
var splitIds = [other.id];
|
|
linkedDocs(other, function(doc$1) {
|
|
return splitIds.push(doc$1.id);
|
|
}, true);
|
|
other.history = new History(null);
|
|
other.history.done = copyHistoryArray(this.history.done, splitIds);
|
|
other.history.undone = copyHistoryArray(this.history.undone, splitIds);
|
|
}
|
|
},
|
|
iterLinkedDocs: function(f) {
|
|
linkedDocs(this, f);
|
|
},
|
|
getMode: function() {
|
|
return this.mode;
|
|
},
|
|
getEditor: function() {
|
|
return this.cm;
|
|
},
|
|
splitLines: function(str) {
|
|
if (this.lineSep) return str.split(this.lineSep);
|
|
return splitLinesAuto(str);
|
|
},
|
|
lineSeparator: function() {
|
|
return this.lineSep || "\n";
|
|
},
|
|
setDirection: docMethodOp(function(dir) {
|
|
if (dir != "rtl") dir = "ltr";
|
|
if (dir == this.direction) return;
|
|
this.direction = dir;
|
|
this.iter(function(line) {
|
|
return line.order = null;
|
|
});
|
|
if (this.cm) directionChanged(this.cm);
|
|
})
|
|
});
|
|
Doc.prototype.eachLine = Doc.prototype.iter;
|
|
var lastDrop = 0;
|
|
function onDrop(e) {
|
|
var cm = this;
|
|
clearDragCursor(cm);
|
|
if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) return;
|
|
e_preventDefault(e);
|
|
if (ie) lastDrop = +new Date();
|
|
var pos = posFromMouse(cm, e, true), files = e.dataTransfer.files;
|
|
if (!pos || cm.isReadOnly()) return;
|
|
if (files && files.length && window.FileReader && window.File) {
|
|
var n = files.length, text = Array(n), read = 0;
|
|
var markAsReadAndPasteIfAllFilesAreRead = function() {
|
|
if (++read == n) operation(cm, function() {
|
|
pos = clipPos(cm.doc, pos);
|
|
var change = {
|
|
from: pos,
|
|
to: pos,
|
|
text: cm.doc.splitLines(text.filter(function(t) {
|
|
return t != null;
|
|
}).join(cm.doc.lineSeparator())),
|
|
origin: "paste"
|
|
};
|
|
makeChange(cm.doc, change);
|
|
setSelectionReplaceHistory(cm.doc, simpleSelection(clipPos(cm.doc, pos), clipPos(cm.doc, changeEnd(change))));
|
|
})();
|
|
};
|
|
var readTextFromFile = function(file, i$4) {
|
|
if (cm.options.allowDropFileTypes && indexOf(cm.options.allowDropFileTypes, file.type) == -1) {
|
|
markAsReadAndPasteIfAllFilesAreRead();
|
|
return;
|
|
}
|
|
var reader = new FileReader();
|
|
reader.onerror = function() {
|
|
return markAsReadAndPasteIfAllFilesAreRead();
|
|
};
|
|
reader.onload = function() {
|
|
var content = reader.result;
|
|
if (/[\x00-\x08\x0e-\x1f]{2}/.test(content)) {
|
|
markAsReadAndPasteIfAllFilesAreRead();
|
|
return;
|
|
}
|
|
text[i$4] = content;
|
|
markAsReadAndPasteIfAllFilesAreRead();
|
|
};
|
|
reader.readAsText(file);
|
|
};
|
|
for (var i$3 = 0; i$3 < files.length; i$3++) readTextFromFile(files[i$3], i$3);
|
|
} else {
|
|
if (cm.state.draggingText && cm.doc.sel.contains(pos) > -1) {
|
|
cm.state.draggingText(e);
|
|
setTimeout(function() {
|
|
return cm.display.input.focus();
|
|
}, 20);
|
|
return;
|
|
}
|
|
try {
|
|
var text$1 = e.dataTransfer.getData("Text");
|
|
if (text$1) {
|
|
var selected;
|
|
if (cm.state.draggingText && !cm.state.draggingText.copy) selected = cm.listSelections();
|
|
setSelectionNoUndo(cm.doc, simpleSelection(pos, pos));
|
|
if (selected) for (var i$1$1 = 0; i$1$1 < selected.length; ++i$1$1) replaceRange(cm.doc, "", selected[i$1$1].anchor, selected[i$1$1].head, "drag");
|
|
cm.replaceSelection(text$1, "around", "paste");
|
|
cm.display.input.focus();
|
|
}
|
|
} catch (e$1) {}
|
|
}
|
|
}
|
|
function onDragStart(cm, e) {
|
|
if (ie && (!cm.state.draggingText || +new Date() - lastDrop < 100)) {
|
|
e_stop(e);
|
|
return;
|
|
}
|
|
if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) return;
|
|
e.dataTransfer.setData("Text", cm.getSelection());
|
|
e.dataTransfer.effectAllowed = "copyMove";
|
|
if (e.dataTransfer.setDragImage && !safari) {
|
|
var img = elt("img", null, null, "position: fixed; left: 0; top: 0;");
|
|
img.src = "";
|
|
if (presto) {
|
|
img.width = img.height = 1;
|
|
cm.display.wrapper.appendChild(img);
|
|
img._top = img.offsetTop;
|
|
}
|
|
e.dataTransfer.setDragImage(img, 0, 0);
|
|
if (presto) img.parentNode.removeChild(img);
|
|
}
|
|
}
|
|
function onDragOver(cm, e) {
|
|
var pos = posFromMouse(cm, e);
|
|
if (!pos) return;
|
|
var frag = document.createDocumentFragment();
|
|
drawSelectionCursor(cm, pos, frag);
|
|
if (!cm.display.dragCursor) {
|
|
cm.display.dragCursor = elt("div", null, "CodeMirror-cursors CodeMirror-dragcursors");
|
|
cm.display.lineSpace.insertBefore(cm.display.dragCursor, cm.display.cursorDiv);
|
|
}
|
|
removeChildrenAndAdd(cm.display.dragCursor, frag);
|
|
}
|
|
function clearDragCursor(cm) {
|
|
if (cm.display.dragCursor) {
|
|
cm.display.lineSpace.removeChild(cm.display.dragCursor);
|
|
cm.display.dragCursor = null;
|
|
}
|
|
}
|
|
function forEachCodeMirror(f) {
|
|
if (!document.getElementsByClassName) return;
|
|
var byClass = document.getElementsByClassName("CodeMirror"), editors = [];
|
|
for (var i$3 = 0; i$3 < byClass.length; i$3++) {
|
|
var cm = byClass[i$3].CodeMirror;
|
|
if (cm) editors.push(cm);
|
|
}
|
|
if (editors.length) editors[0].operation(function() {
|
|
for (var i$4 = 0; i$4 < editors.length; i$4++) f(editors[i$4]);
|
|
});
|
|
}
|
|
var globalsRegistered = false;
|
|
function ensureGlobalHandlers() {
|
|
if (globalsRegistered) return;
|
|
registerGlobalHandlers();
|
|
globalsRegistered = true;
|
|
}
|
|
function registerGlobalHandlers() {
|
|
var resizeTimer;
|
|
on(window, "resize", function() {
|
|
if (resizeTimer == null) resizeTimer = setTimeout(function() {
|
|
resizeTimer = null;
|
|
forEachCodeMirror(onResize);
|
|
}, 100);
|
|
});
|
|
on(window, "blur", function() {
|
|
return forEachCodeMirror(onBlur);
|
|
});
|
|
}
|
|
function onResize(cm) {
|
|
var d = cm.display;
|
|
d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;
|
|
d.scrollbarsClipped = false;
|
|
cm.setSize();
|
|
}
|
|
var keyNames = {
|
|
3: "Pause",
|
|
8: "Backspace",
|
|
9: "Tab",
|
|
13: "Enter",
|
|
16: "Shift",
|
|
17: "Ctrl",
|
|
18: "Alt",
|
|
19: "Pause",
|
|
20: "CapsLock",
|
|
27: "Esc",
|
|
32: "Space",
|
|
33: "PageUp",
|
|
34: "PageDown",
|
|
35: "End",
|
|
36: "Home",
|
|
37: "Left",
|
|
38: "Up",
|
|
39: "Right",
|
|
40: "Down",
|
|
44: "PrintScrn",
|
|
45: "Insert",
|
|
46: "Delete",
|
|
59: ";",
|
|
61: "=",
|
|
91: "Mod",
|
|
92: "Mod",
|
|
93: "Mod",
|
|
106: "*",
|
|
107: "=",
|
|
109: "-",
|
|
110: ".",
|
|
111: "/",
|
|
145: "ScrollLock",
|
|
173: "-",
|
|
186: ";",
|
|
187: "=",
|
|
188: ",",
|
|
189: "-",
|
|
190: ".",
|
|
191: "/",
|
|
192: "`",
|
|
219: "[",
|
|
220: "\\",
|
|
221: "]",
|
|
222: "'",
|
|
224: "Mod",
|
|
63232: "Up",
|
|
63233: "Down",
|
|
63234: "Left",
|
|
63235: "Right",
|
|
63272: "Delete",
|
|
63273: "Home",
|
|
63275: "End",
|
|
63276: "PageUp",
|
|
63277: "PageDown",
|
|
63302: "Insert"
|
|
};
|
|
for (var i = 0; i < 10; i++) keyNames[i + 48] = keyNames[i + 96] = String(i);
|
|
for (var i$1 = 65; i$1 <= 90; i$1++) keyNames[i$1] = String.fromCharCode(i$1);
|
|
for (var i$2 = 1; i$2 <= 12; i$2++) keyNames[i$2 + 111] = keyNames[i$2 + 63235] = "F" + i$2;
|
|
var keyMap = {};
|
|
keyMap.basic = {
|
|
"Left": "goCharLeft",
|
|
"Right": "goCharRight",
|
|
"Up": "goLineUp",
|
|
"Down": "goLineDown",
|
|
"End": "goLineEnd",
|
|
"Home": "goLineStartSmart",
|
|
"PageUp": "goPageUp",
|
|
"PageDown": "goPageDown",
|
|
"Delete": "delCharAfter",
|
|
"Backspace": "delCharBefore",
|
|
"Shift-Backspace": "delCharBefore",
|
|
"Tab": "defaultTab",
|
|
"Shift-Tab": "indentAuto",
|
|
"Enter": "newlineAndIndent",
|
|
"Insert": "toggleOverwrite",
|
|
"Esc": "singleSelection"
|
|
};
|
|
keyMap.pcDefault = {
|
|
"Ctrl-A": "selectAll",
|
|
"Ctrl-D": "deleteLine",
|
|
"Ctrl-Z": "undo",
|
|
"Shift-Ctrl-Z": "redo",
|
|
"Ctrl-Y": "redo",
|
|
"Ctrl-Home": "goDocStart",
|
|
"Ctrl-End": "goDocEnd",
|
|
"Ctrl-Up": "goLineUp",
|
|
"Ctrl-Down": "goLineDown",
|
|
"Ctrl-Left": "goGroupLeft",
|
|
"Ctrl-Right": "goGroupRight",
|
|
"Alt-Left": "goLineStart",
|
|
"Alt-Right": "goLineEnd",
|
|
"Ctrl-Backspace": "delGroupBefore",
|
|
"Ctrl-Delete": "delGroupAfter",
|
|
"Ctrl-S": "save",
|
|
"Ctrl-F": "find",
|
|
"Ctrl-G": "findNext",
|
|
"Shift-Ctrl-G": "findPrev",
|
|
"Shift-Ctrl-F": "replace",
|
|
"Shift-Ctrl-R": "replaceAll",
|
|
"Ctrl-[": "indentLess",
|
|
"Ctrl-]": "indentMore",
|
|
"Ctrl-U": "undoSelection",
|
|
"Shift-Ctrl-U": "redoSelection",
|
|
"Alt-U": "redoSelection",
|
|
"fallthrough": "basic"
|
|
};
|
|
keyMap.emacsy = {
|
|
"Ctrl-F": "goCharRight",
|
|
"Ctrl-B": "goCharLeft",
|
|
"Ctrl-P": "goLineUp",
|
|
"Ctrl-N": "goLineDown",
|
|
"Ctrl-A": "goLineStart",
|
|
"Ctrl-E": "goLineEnd",
|
|
"Ctrl-V": "goPageDown",
|
|
"Shift-Ctrl-V": "goPageUp",
|
|
"Ctrl-D": "delCharAfter",
|
|
"Ctrl-H": "delCharBefore",
|
|
"Alt-Backspace": "delWordBefore",
|
|
"Ctrl-K": "killLine",
|
|
"Ctrl-T": "transposeChars",
|
|
"Ctrl-O": "openLine"
|
|
};
|
|
keyMap.macDefault = {
|
|
"Cmd-A": "selectAll",
|
|
"Cmd-D": "deleteLine",
|
|
"Cmd-Z": "undo",
|
|
"Shift-Cmd-Z": "redo",
|
|
"Cmd-Y": "redo",
|
|
"Cmd-Home": "goDocStart",
|
|
"Cmd-Up": "goDocStart",
|
|
"Cmd-End": "goDocEnd",
|
|
"Cmd-Down": "goDocEnd",
|
|
"Alt-Left": "goGroupLeft",
|
|
"Alt-Right": "goGroupRight",
|
|
"Cmd-Left": "goLineLeft",
|
|
"Cmd-Right": "goLineRight",
|
|
"Alt-Backspace": "delGroupBefore",
|
|
"Ctrl-Alt-Backspace": "delGroupAfter",
|
|
"Alt-Delete": "delGroupAfter",
|
|
"Cmd-S": "save",
|
|
"Cmd-F": "find",
|
|
"Cmd-G": "findNext",
|
|
"Shift-Cmd-G": "findPrev",
|
|
"Cmd-Alt-F": "replace",
|
|
"Shift-Cmd-Alt-F": "replaceAll",
|
|
"Cmd-[": "indentLess",
|
|
"Cmd-]": "indentMore",
|
|
"Cmd-Backspace": "delWrappedLineLeft",
|
|
"Cmd-Delete": "delWrappedLineRight",
|
|
"Cmd-U": "undoSelection",
|
|
"Shift-Cmd-U": "redoSelection",
|
|
"Ctrl-Up": "goDocStart",
|
|
"Ctrl-Down": "goDocEnd",
|
|
"fallthrough": ["basic", "emacsy"]
|
|
};
|
|
keyMap["default"] = mac ? keyMap.macDefault : keyMap.pcDefault;
|
|
function normalizeKeyName(name) {
|
|
var parts = name.split(/-(?!$)/);
|
|
name = parts[parts.length - 1];
|
|
var alt, ctrl, shift, cmd;
|
|
for (var i$3 = 0; i$3 < parts.length - 1; i$3++) {
|
|
var mod = parts[i$3];
|
|
if (/^(cmd|meta|m)$/i.test(mod)) cmd = true;
|
|
else if (/^a(lt)?$/i.test(mod)) alt = true;
|
|
else if (/^(c|ctrl|control)$/i.test(mod)) ctrl = true;
|
|
else if (/^s(hift)?$/i.test(mod)) shift = true;
|
|
else throw new Error("Unrecognized modifier name: " + mod);
|
|
}
|
|
if (alt) name = "Alt-" + name;
|
|
if (ctrl) name = "Ctrl-" + name;
|
|
if (cmd) name = "Cmd-" + name;
|
|
if (shift) name = "Shift-" + name;
|
|
return name;
|
|
}
|
|
function normalizeKeyMap(keymap) {
|
|
var copy = {};
|
|
for (var keyname in keymap) if (keymap.hasOwnProperty(keyname)) {
|
|
var value = keymap[keyname];
|
|
if (/^(name|fallthrough|(de|at)tach)$/.test(keyname)) continue;
|
|
if (value == "...") {
|
|
delete keymap[keyname];
|
|
continue;
|
|
}
|
|
var keys = map(keyname.split(" "), normalizeKeyName);
|
|
for (var i$3 = 0; i$3 < keys.length; i$3++) {
|
|
var val = void 0, name = void 0;
|
|
if (i$3 == keys.length - 1) {
|
|
name = keys.join(" ");
|
|
val = value;
|
|
} else {
|
|
name = keys.slice(0, i$3 + 1).join(" ");
|
|
val = "...";
|
|
}
|
|
var prev = copy[name];
|
|
if (!prev) copy[name] = val;
|
|
else if (prev != val) throw new Error("Inconsistent bindings for " + name);
|
|
}
|
|
delete keymap[keyname];
|
|
}
|
|
for (var prop$1 in copy) keymap[prop$1] = copy[prop$1];
|
|
return keymap;
|
|
}
|
|
function lookupKey(key, map$1, handle, context) {
|
|
map$1 = getKeyMap(map$1);
|
|
var found = map$1.call ? map$1.call(key, context) : map$1[key];
|
|
if (found === false) return "nothing";
|
|
if (found === "...") return "multi";
|
|
if (found != null && handle(found)) return "handled";
|
|
if (map$1.fallthrough) {
|
|
if (Object.prototype.toString.call(map$1.fallthrough) != "[object Array]") return lookupKey(key, map$1.fallthrough, handle, context);
|
|
for (var i$3 = 0; i$3 < map$1.fallthrough.length; i$3++) {
|
|
var result = lookupKey(key, map$1.fallthrough[i$3], handle, context);
|
|
if (result) return result;
|
|
}
|
|
}
|
|
}
|
|
function isModifierKey(value) {
|
|
var name = typeof value == "string" ? value : keyNames[value.keyCode];
|
|
return name == "Ctrl" || name == "Alt" || name == "Shift" || name == "Mod";
|
|
}
|
|
function addModifierNames(name, event, noShift) {
|
|
var base = name;
|
|
if (event.altKey && base != "Alt") name = "Alt-" + name;
|
|
if ((flipCtrlCmd ? event.metaKey : event.ctrlKey) && base != "Ctrl") name = "Ctrl-" + name;
|
|
if ((flipCtrlCmd ? event.ctrlKey : event.metaKey) && base != "Mod") name = "Cmd-" + name;
|
|
if (!noShift && event.shiftKey && base != "Shift") name = "Shift-" + name;
|
|
return name;
|
|
}
|
|
function keyName(event, noShift) {
|
|
if (presto && event.keyCode == 34 && event["char"]) return false;
|
|
var name = keyNames[event.keyCode];
|
|
if (name == null || event.altGraphKey) return false;
|
|
if (event.keyCode == 3 && event.code) name = event.code;
|
|
return addModifierNames(name, event, noShift);
|
|
}
|
|
function getKeyMap(val) {
|
|
return typeof val == "string" ? keyMap[val] : val;
|
|
}
|
|
function deleteNearSelection(cm, compute) {
|
|
var ranges = cm.doc.sel.ranges, kill = [];
|
|
for (var i$3 = 0; i$3 < ranges.length; i$3++) {
|
|
var toKill = compute(ranges[i$3]);
|
|
while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) {
|
|
var replaced = kill.pop();
|
|
if (cmp(replaced.from, toKill.from) < 0) {
|
|
toKill.from = replaced.from;
|
|
break;
|
|
}
|
|
}
|
|
kill.push(toKill);
|
|
}
|
|
runInOp(cm, function() {
|
|
for (var i$4 = kill.length - 1; i$4 >= 0; i$4--) replaceRange(cm.doc, "", kill[i$4].from, kill[i$4].to, "+delete");
|
|
ensureCursorVisible(cm);
|
|
});
|
|
}
|
|
function moveCharLogically(line, ch, dir) {
|
|
var target = skipExtendingChars(line.text, ch + dir, dir);
|
|
return target < 0 || target > line.text.length ? null : target;
|
|
}
|
|
function moveLogically(line, start, dir) {
|
|
var ch = moveCharLogically(line, start.ch, dir);
|
|
return ch == null ? null : new Pos(start.line, ch, dir < 0 ? "after" : "before");
|
|
}
|
|
function endOfLine(visually, cm, lineObj, lineNo$1, dir) {
|
|
if (visually) {
|
|
if (cm.doc.direction == "rtl") dir = -dir;
|
|
var order = getOrder(lineObj, cm.doc.direction);
|
|
if (order) {
|
|
var part = dir < 0 ? lst(order) : order[0];
|
|
var moveInStorageOrder = dir < 0 == (part.level == 1);
|
|
var sticky = moveInStorageOrder ? "after" : "before";
|
|
var ch;
|
|
if (part.level > 0 || cm.doc.direction == "rtl") {
|
|
var prep = prepareMeasureForLine(cm, lineObj);
|
|
ch = dir < 0 ? lineObj.text.length - 1 : 0;
|
|
var targetTop = measureCharPrepared(cm, prep, ch).top;
|
|
ch = findFirst(function(ch$1) {
|
|
return measureCharPrepared(cm, prep, ch$1).top == targetTop;
|
|
}, dir < 0 == (part.level == 1) ? part.from : part.to - 1, ch);
|
|
if (sticky == "before") ch = moveCharLogically(lineObj, ch, 1);
|
|
} else ch = dir < 0 ? part.to : part.from;
|
|
return new Pos(lineNo$1, ch, sticky);
|
|
}
|
|
}
|
|
return new Pos(lineNo$1, dir < 0 ? lineObj.text.length : 0, dir < 0 ? "before" : "after");
|
|
}
|
|
function moveVisually(cm, line, start, dir) {
|
|
var bidi = getOrder(line, cm.doc.direction);
|
|
if (!bidi) return moveLogically(line, start, dir);
|
|
if (start.ch >= line.text.length) {
|
|
start.ch = line.text.length;
|
|
start.sticky = "before";
|
|
} else if (start.ch <= 0) {
|
|
start.ch = 0;
|
|
start.sticky = "after";
|
|
}
|
|
var partPos = getBidiPartAt(bidi, start.ch, start.sticky), part = bidi[partPos];
|
|
if (cm.doc.direction == "ltr" && part.level % 2 == 0 && (dir > 0 ? part.to > start.ch : part.from < start.ch)) return moveLogically(line, start, dir);
|
|
var mv = function(pos, dir$1) {
|
|
return moveCharLogically(line, pos instanceof Pos ? pos.ch : pos, dir$1);
|
|
};
|
|
var prep;
|
|
var getWrappedLineExtent = function(ch$1) {
|
|
if (!cm.options.lineWrapping) return {
|
|
begin: 0,
|
|
end: line.text.length
|
|
};
|
|
prep = prep || prepareMeasureForLine(cm, line);
|
|
return wrappedLineExtentChar(cm, line, prep, ch$1);
|
|
};
|
|
var wrappedLineExtent$1 = getWrappedLineExtent(start.sticky == "before" ? mv(start, -1) : start.ch);
|
|
if (cm.doc.direction == "rtl" || part.level == 1) {
|
|
var moveInStorageOrder = part.level == 1 == dir < 0;
|
|
var ch = mv(start, moveInStorageOrder ? 1 : -1);
|
|
if (ch != null && (!moveInStorageOrder ? ch >= part.from && ch >= wrappedLineExtent$1.begin : ch <= part.to && ch <= wrappedLineExtent$1.end)) {
|
|
var sticky = moveInStorageOrder ? "before" : "after";
|
|
return new Pos(start.line, ch, sticky);
|
|
}
|
|
}
|
|
var searchInVisualLine = function(partPos$1, dir$1, wrappedLineExtent$2) {
|
|
var getRes = function(ch$2, moveInStorageOrder$2) {
|
|
return moveInStorageOrder$2 ? new Pos(start.line, mv(ch$2, 1), "before") : new Pos(start.line, ch$2, "after");
|
|
};
|
|
for (; partPos$1 >= 0 && partPos$1 < bidi.length; partPos$1 += dir$1) {
|
|
var part$1 = bidi[partPos$1];
|
|
var moveInStorageOrder$1 = dir$1 > 0 == (part$1.level != 1);
|
|
var ch$1 = moveInStorageOrder$1 ? wrappedLineExtent$2.begin : mv(wrappedLineExtent$2.end, -1);
|
|
if (part$1.from <= ch$1 && ch$1 < part$1.to) return getRes(ch$1, moveInStorageOrder$1);
|
|
ch$1 = moveInStorageOrder$1 ? part$1.from : mv(part$1.to, -1);
|
|
if (wrappedLineExtent$2.begin <= ch$1 && ch$1 < wrappedLineExtent$2.end) return getRes(ch$1, moveInStorageOrder$1);
|
|
}
|
|
};
|
|
var res = searchInVisualLine(partPos + dir, dir, wrappedLineExtent$1);
|
|
if (res) return res;
|
|
var nextCh = dir > 0 ? wrappedLineExtent$1.end : mv(wrappedLineExtent$1.begin, -1);
|
|
if (nextCh != null && !(dir > 0 && nextCh == line.text.length)) {
|
|
res = searchInVisualLine(dir > 0 ? 0 : bidi.length - 1, dir, getWrappedLineExtent(nextCh));
|
|
if (res) return res;
|
|
}
|
|
return null;
|
|
}
|
|
var commands = {
|
|
selectAll,
|
|
singleSelection: function(cm) {
|
|
return cm.setSelection(cm.getCursor("anchor"), cm.getCursor("head"), sel_dontScroll);
|
|
},
|
|
killLine: function(cm) {
|
|
return deleteNearSelection(cm, function(range$1) {
|
|
if (range$1.empty()) {
|
|
var len = getLine(cm.doc, range$1.head.line).text.length;
|
|
if (range$1.head.ch == len && range$1.head.line < cm.lastLine()) return {
|
|
from: range$1.head,
|
|
to: Pos(range$1.head.line + 1, 0)
|
|
};
|
|
else return {
|
|
from: range$1.head,
|
|
to: Pos(range$1.head.line, len)
|
|
};
|
|
} else return {
|
|
from: range$1.from(),
|
|
to: range$1.to()
|
|
};
|
|
});
|
|
},
|
|
deleteLine: function(cm) {
|
|
return deleteNearSelection(cm, function(range$1) {
|
|
return {
|
|
from: Pos(range$1.from().line, 0),
|
|
to: clipPos(cm.doc, Pos(range$1.to().line + 1, 0))
|
|
};
|
|
});
|
|
},
|
|
delLineLeft: function(cm) {
|
|
return deleteNearSelection(cm, function(range$1) {
|
|
return {
|
|
from: Pos(range$1.from().line, 0),
|
|
to: range$1.from()
|
|
};
|
|
});
|
|
},
|
|
delWrappedLineLeft: function(cm) {
|
|
return deleteNearSelection(cm, function(range$1) {
|
|
var top = cm.charCoords(range$1.head, "div").top + 5;
|
|
var leftPos = cm.coordsChar({
|
|
left: 0,
|
|
top
|
|
}, "div");
|
|
return {
|
|
from: leftPos,
|
|
to: range$1.from()
|
|
};
|
|
});
|
|
},
|
|
delWrappedLineRight: function(cm) {
|
|
return deleteNearSelection(cm, function(range$1) {
|
|
var top = cm.charCoords(range$1.head, "div").top + 5;
|
|
var rightPos = cm.coordsChar({
|
|
left: cm.display.lineDiv.offsetWidth + 100,
|
|
top
|
|
}, "div");
|
|
return {
|
|
from: range$1.from(),
|
|
to: rightPos
|
|
};
|
|
});
|
|
},
|
|
undo: function(cm) {
|
|
return cm.undo();
|
|
},
|
|
redo: function(cm) {
|
|
return cm.redo();
|
|
},
|
|
undoSelection: function(cm) {
|
|
return cm.undoSelection();
|
|
},
|
|
redoSelection: function(cm) {
|
|
return cm.redoSelection();
|
|
},
|
|
goDocStart: function(cm) {
|
|
return cm.extendSelection(Pos(cm.firstLine(), 0));
|
|
},
|
|
goDocEnd: function(cm) {
|
|
return cm.extendSelection(Pos(cm.lastLine()));
|
|
},
|
|
goLineStart: function(cm) {
|
|
return cm.extendSelectionsBy(function(range$1) {
|
|
return lineStart(cm, range$1.head.line);
|
|
}, {
|
|
origin: "+move",
|
|
bias: 1
|
|
});
|
|
},
|
|
goLineStartSmart: function(cm) {
|
|
return cm.extendSelectionsBy(function(range$1) {
|
|
return lineStartSmart(cm, range$1.head);
|
|
}, {
|
|
origin: "+move",
|
|
bias: 1
|
|
});
|
|
},
|
|
goLineEnd: function(cm) {
|
|
return cm.extendSelectionsBy(function(range$1) {
|
|
return lineEnd(cm, range$1.head.line);
|
|
}, {
|
|
origin: "+move",
|
|
bias: -1
|
|
});
|
|
},
|
|
goLineRight: function(cm) {
|
|
return cm.extendSelectionsBy(function(range$1) {
|
|
var top = cm.cursorCoords(range$1.head, "div").top + 5;
|
|
return cm.coordsChar({
|
|
left: cm.display.lineDiv.offsetWidth + 100,
|
|
top
|
|
}, "div");
|
|
}, sel_move);
|
|
},
|
|
goLineLeft: function(cm) {
|
|
return cm.extendSelectionsBy(function(range$1) {
|
|
var top = cm.cursorCoords(range$1.head, "div").top + 5;
|
|
return cm.coordsChar({
|
|
left: 0,
|
|
top
|
|
}, "div");
|
|
}, sel_move);
|
|
},
|
|
goLineLeftSmart: function(cm) {
|
|
return cm.extendSelectionsBy(function(range$1) {
|
|
var top = cm.cursorCoords(range$1.head, "div").top + 5;
|
|
var pos = cm.coordsChar({
|
|
left: 0,
|
|
top
|
|
}, "div");
|
|
if (pos.ch < cm.getLine(pos.line).search(/\S/)) return lineStartSmart(cm, range$1.head);
|
|
return pos;
|
|
}, sel_move);
|
|
},
|
|
goLineUp: function(cm) {
|
|
return cm.moveV(-1, "line");
|
|
},
|
|
goLineDown: function(cm) {
|
|
return cm.moveV(1, "line");
|
|
},
|
|
goPageUp: function(cm) {
|
|
return cm.moveV(-1, "page");
|
|
},
|
|
goPageDown: function(cm) {
|
|
return cm.moveV(1, "page");
|
|
},
|
|
goCharLeft: function(cm) {
|
|
return cm.moveH(-1, "char");
|
|
},
|
|
goCharRight: function(cm) {
|
|
return cm.moveH(1, "char");
|
|
},
|
|
goColumnLeft: function(cm) {
|
|
return cm.moveH(-1, "column");
|
|
},
|
|
goColumnRight: function(cm) {
|
|
return cm.moveH(1, "column");
|
|
},
|
|
goWordLeft: function(cm) {
|
|
return cm.moveH(-1, "word");
|
|
},
|
|
goGroupRight: function(cm) {
|
|
return cm.moveH(1, "group");
|
|
},
|
|
goGroupLeft: function(cm) {
|
|
return cm.moveH(-1, "group");
|
|
},
|
|
goWordRight: function(cm) {
|
|
return cm.moveH(1, "word");
|
|
},
|
|
delCharBefore: function(cm) {
|
|
return cm.deleteH(-1, "codepoint");
|
|
},
|
|
delCharAfter: function(cm) {
|
|
return cm.deleteH(1, "char");
|
|
},
|
|
delWordBefore: function(cm) {
|
|
return cm.deleteH(-1, "word");
|
|
},
|
|
delWordAfter: function(cm) {
|
|
return cm.deleteH(1, "word");
|
|
},
|
|
delGroupBefore: function(cm) {
|
|
return cm.deleteH(-1, "group");
|
|
},
|
|
delGroupAfter: function(cm) {
|
|
return cm.deleteH(1, "group");
|
|
},
|
|
indentAuto: function(cm) {
|
|
return cm.indentSelection("smart");
|
|
},
|
|
indentMore: function(cm) {
|
|
return cm.indentSelection("add");
|
|
},
|
|
indentLess: function(cm) {
|
|
return cm.indentSelection("subtract");
|
|
},
|
|
insertTab: function(cm) {
|
|
return cm.replaceSelection(" ");
|
|
},
|
|
insertSoftTab: function(cm) {
|
|
var spaces = [], ranges = cm.listSelections(), tabSize = cm.options.tabSize;
|
|
for (var i$3 = 0; i$3 < ranges.length; i$3++) {
|
|
var pos = ranges[i$3].from();
|
|
var col = countColumn(cm.getLine(pos.line), pos.ch, tabSize);
|
|
spaces.push(spaceStr(tabSize - col % tabSize));
|
|
}
|
|
cm.replaceSelections(spaces);
|
|
},
|
|
defaultTab: function(cm) {
|
|
if (cm.somethingSelected()) cm.indentSelection("add");
|
|
else cm.execCommand("insertTab");
|
|
},
|
|
transposeChars: function(cm) {
|
|
return runInOp(cm, function() {
|
|
var ranges = cm.listSelections(), newSel = [];
|
|
for (var i$3 = 0; i$3 < ranges.length; i$3++) {
|
|
if (!ranges[i$3].empty()) continue;
|
|
var cur = ranges[i$3].head, line = getLine(cm.doc, cur.line).text;
|
|
if (line) {
|
|
if (cur.ch == line.length) cur = new Pos(cur.line, cur.ch - 1);
|
|
if (cur.ch > 0) {
|
|
cur = new Pos(cur.line, cur.ch + 1);
|
|
cm.replaceRange(line.charAt(cur.ch - 1) + line.charAt(cur.ch - 2), Pos(cur.line, cur.ch - 2), cur, "+transpose");
|
|
} else if (cur.line > cm.doc.first) {
|
|
var prev = getLine(cm.doc, cur.line - 1).text;
|
|
if (prev) {
|
|
cur = new Pos(cur.line, 1);
|
|
cm.replaceRange(line.charAt(0) + cm.doc.lineSeparator() + prev.charAt(prev.length - 1), Pos(cur.line - 1, prev.length - 1), cur, "+transpose");
|
|
}
|
|
}
|
|
}
|
|
newSel.push(new Range(cur, cur));
|
|
}
|
|
cm.setSelections(newSel);
|
|
});
|
|
},
|
|
newlineAndIndent: function(cm) {
|
|
return runInOp(cm, function() {
|
|
var sels = cm.listSelections();
|
|
for (var i$3 = sels.length - 1; i$3 >= 0; i$3--) cm.replaceRange(cm.doc.lineSeparator(), sels[i$3].anchor, sels[i$3].head, "+input");
|
|
sels = cm.listSelections();
|
|
for (var i$1$1 = 0; i$1$1 < sels.length; i$1$1++) cm.indentLine(sels[i$1$1].from().line, null, true);
|
|
ensureCursorVisible(cm);
|
|
});
|
|
},
|
|
openLine: function(cm) {
|
|
return cm.replaceSelection("\n", "start");
|
|
},
|
|
toggleOverwrite: function(cm) {
|
|
return cm.toggleOverwrite();
|
|
}
|
|
};
|
|
function lineStart(cm, lineN) {
|
|
var line = getLine(cm.doc, lineN);
|
|
var visual = visualLine(line);
|
|
if (visual != line) lineN = lineNo(visual);
|
|
return endOfLine(true, cm, visual, lineN, 1);
|
|
}
|
|
function lineEnd(cm, lineN) {
|
|
var line = getLine(cm.doc, lineN);
|
|
var visual = visualLineEnd(line);
|
|
if (visual != line) lineN = lineNo(visual);
|
|
return endOfLine(true, cm, line, lineN, -1);
|
|
}
|
|
function lineStartSmart(cm, pos) {
|
|
var start = lineStart(cm, pos.line);
|
|
var line = getLine(cm.doc, start.line);
|
|
var order = getOrder(line, cm.doc.direction);
|
|
if (!order || order[0].level == 0) {
|
|
var firstNonWS = Math.max(start.ch, line.text.search(/\S/));
|
|
var inWS = pos.line == start.line && pos.ch <= firstNonWS && pos.ch;
|
|
return Pos(start.line, inWS ? 0 : firstNonWS, start.sticky);
|
|
}
|
|
return start;
|
|
}
|
|
function doHandleBinding(cm, bound, dropShift) {
|
|
if (typeof bound == "string") {
|
|
bound = commands[bound];
|
|
if (!bound) return false;
|
|
}
|
|
cm.display.input.ensurePolled();
|
|
var prevShift = cm.display.shift, done = false;
|
|
try {
|
|
if (cm.isReadOnly()) cm.state.suppressEdits = true;
|
|
if (dropShift) cm.display.shift = false;
|
|
done = bound(cm) != Pass;
|
|
} finally {
|
|
cm.display.shift = prevShift;
|
|
cm.state.suppressEdits = false;
|
|
}
|
|
return done;
|
|
}
|
|
function lookupKeyForEditor(cm, name, handle) {
|
|
for (var i$3 = 0; i$3 < cm.state.keyMaps.length; i$3++) {
|
|
var result = lookupKey(name, cm.state.keyMaps[i$3], handle, cm);
|
|
if (result) return result;
|
|
}
|
|
return cm.options.extraKeys && lookupKey(name, cm.options.extraKeys, handle, cm) || lookupKey(name, cm.options.keyMap, handle, cm);
|
|
}
|
|
var stopSeq = new Delayed();
|
|
function dispatchKey(cm, name, e, handle) {
|
|
var seq = cm.state.keySeq;
|
|
if (seq) {
|
|
if (isModifierKey(name)) return "handled";
|
|
if (/\'$/.test(name)) cm.state.keySeq = null;
|
|
else stopSeq.set(50, function() {
|
|
if (cm.state.keySeq == seq) {
|
|
cm.state.keySeq = null;
|
|
cm.display.input.reset();
|
|
}
|
|
});
|
|
if (dispatchKeyInner(cm, seq + " " + name, e, handle)) return true;
|
|
}
|
|
return dispatchKeyInner(cm, name, e, handle);
|
|
}
|
|
function dispatchKeyInner(cm, name, e, handle) {
|
|
var result = lookupKeyForEditor(cm, name, handle);
|
|
if (result == "multi") cm.state.keySeq = name;
|
|
if (result == "handled") signalLater(cm, "keyHandled", cm, name, e);
|
|
if (result == "handled" || result == "multi") {
|
|
e_preventDefault(e);
|
|
restartBlink(cm);
|
|
}
|
|
return !!result;
|
|
}
|
|
function handleKeyBinding(cm, e) {
|
|
var name = keyName(e, true);
|
|
if (!name) return false;
|
|
if (e.shiftKey && !cm.state.keySeq) return dispatchKey(cm, "Shift-" + name, e, function(b) {
|
|
return doHandleBinding(cm, b, true);
|
|
}) || dispatchKey(cm, name, e, function(b) {
|
|
if (typeof b == "string" ? /^go[A-Z]/.test(b) : b.motion) return doHandleBinding(cm, b);
|
|
});
|
|
else return dispatchKey(cm, name, e, function(b) {
|
|
return doHandleBinding(cm, b);
|
|
});
|
|
}
|
|
function handleCharBinding(cm, e, ch) {
|
|
return dispatchKey(cm, "'" + ch + "'", e, function(b) {
|
|
return doHandleBinding(cm, b, true);
|
|
});
|
|
}
|
|
var lastStoppedKey = null;
|
|
function onKeyDown(e) {
|
|
var cm = this;
|
|
if (e.target && e.target != cm.display.input.getField()) return;
|
|
cm.curOp.focus = activeElt(root(cm));
|
|
if (signalDOMEvent(cm, e)) return;
|
|
if (ie && ie_version < 11 && e.keyCode == 27) e.returnValue = false;
|
|
var code = e.keyCode;
|
|
cm.display.shift = code == 16 || e.shiftKey;
|
|
var handled = handleKeyBinding(cm, e);
|
|
if (presto) {
|
|
lastStoppedKey = handled ? code : null;
|
|
if (!handled && code == 88 && !hasCopyEvent && (mac ? e.metaKey : e.ctrlKey)) cm.replaceSelection("", null, "cut");
|
|
}
|
|
if (gecko && !mac && !handled && code == 46 && e.shiftKey && !e.ctrlKey && document.execCommand) document.execCommand("cut");
|
|
if (code == 18 && !/\bCodeMirror-crosshair\b/.test(cm.display.lineDiv.className)) showCrossHair(cm);
|
|
}
|
|
function showCrossHair(cm) {
|
|
var lineDiv = cm.display.lineDiv;
|
|
addClass(lineDiv, "CodeMirror-crosshair");
|
|
function up(e) {
|
|
if (e.keyCode == 18 || !e.altKey) {
|
|
rmClass(lineDiv, "CodeMirror-crosshair");
|
|
off(document, "keyup", up);
|
|
off(document, "mouseover", up);
|
|
}
|
|
}
|
|
on(document, "keyup", up);
|
|
on(document, "mouseover", up);
|
|
}
|
|
function onKeyUp(e) {
|
|
if (e.keyCode == 16) this.doc.sel.shift = false;
|
|
signalDOMEvent(this, e);
|
|
}
|
|
function onKeyPress(e) {
|
|
var cm = this;
|
|
if (e.target && e.target != cm.display.input.getField()) return;
|
|
if (eventInWidget(cm.display, e) || signalDOMEvent(cm, e) || e.ctrlKey && !e.altKey || mac && e.metaKey) return;
|
|
var keyCode = e.keyCode, charCode = e.charCode;
|
|
if (presto && keyCode == lastStoppedKey) {
|
|
lastStoppedKey = null;
|
|
e_preventDefault(e);
|
|
return;
|
|
}
|
|
if (presto && (!e.which || e.which < 10) && handleKeyBinding(cm, e)) return;
|
|
var ch = String.fromCharCode(charCode == null ? keyCode : charCode);
|
|
if (ch == "\b") return;
|
|
if (handleCharBinding(cm, e, ch)) return;
|
|
cm.display.input.onKeyPress(e);
|
|
}
|
|
var DOUBLECLICK_DELAY = 400;
|
|
var PastClick = function(time, pos, button) {
|
|
this.time = time;
|
|
this.pos = pos;
|
|
this.button = button;
|
|
};
|
|
PastClick.prototype.compare = function(time, pos, button) {
|
|
return this.time + DOUBLECLICK_DELAY > time && cmp(pos, this.pos) == 0 && button == this.button;
|
|
};
|
|
var lastClick, lastDoubleClick;
|
|
function clickRepeat(pos, button) {
|
|
var now = +new Date();
|
|
if (lastDoubleClick && lastDoubleClick.compare(now, pos, button)) {
|
|
lastClick = lastDoubleClick = null;
|
|
return "triple";
|
|
} else if (lastClick && lastClick.compare(now, pos, button)) {
|
|
lastDoubleClick = new PastClick(now, pos, button);
|
|
lastClick = null;
|
|
return "double";
|
|
} else {
|
|
lastClick = new PastClick(now, pos, button);
|
|
lastDoubleClick = null;
|
|
return "single";
|
|
}
|
|
}
|
|
function onMouseDown(e) {
|
|
var cm = this, display = cm.display;
|
|
if (signalDOMEvent(cm, e) || display.activeTouch && display.input.supportsTouch()) return;
|
|
display.input.ensurePolled();
|
|
display.shift = e.shiftKey;
|
|
if (eventInWidget(display, e)) {
|
|
if (!webkit) {
|
|
display.scroller.draggable = false;
|
|
setTimeout(function() {
|
|
return display.scroller.draggable = true;
|
|
}, 100);
|
|
}
|
|
return;
|
|
}
|
|
if (clickInGutter(cm, e)) return;
|
|
var pos = posFromMouse(cm, e), button = e_button(e), repeat = pos ? clickRepeat(pos, button) : "single";
|
|
win(cm).focus();
|
|
if (button == 1 && cm.state.selectingText) cm.state.selectingText(e);
|
|
if (pos && handleMappedButton(cm, button, pos, repeat, e)) return;
|
|
if (button == 1) {
|
|
if (pos) leftButtonDown(cm, pos, repeat, e);
|
|
else if (e_target(e) == display.scroller) e_preventDefault(e);
|
|
} else if (button == 2) {
|
|
if (pos) extendSelection(cm.doc, pos);
|
|
setTimeout(function() {
|
|
return display.input.focus();
|
|
}, 20);
|
|
} else if (button == 3) if (captureRightClick) cm.display.input.onContextMenu(e);
|
|
else delayBlurEvent(cm);
|
|
}
|
|
function handleMappedButton(cm, button, pos, repeat, event) {
|
|
var name = "Click";
|
|
if (repeat == "double") name = "Double" + name;
|
|
else if (repeat == "triple") name = "Triple" + name;
|
|
name = (button == 1 ? "Left" : button == 2 ? "Middle" : "Right") + name;
|
|
return dispatchKey(cm, addModifierNames(name, event), event, function(bound) {
|
|
if (typeof bound == "string") bound = commands[bound];
|
|
if (!bound) return false;
|
|
var done = false;
|
|
try {
|
|
if (cm.isReadOnly()) cm.state.suppressEdits = true;
|
|
done = bound(cm, pos) != Pass;
|
|
} finally {
|
|
cm.state.suppressEdits = false;
|
|
}
|
|
return done;
|
|
});
|
|
}
|
|
function configureMouse(cm, repeat, event) {
|
|
var option = cm.getOption("configureMouse");
|
|
var value = option ? option(cm, repeat, event) : {};
|
|
if (value.unit == null) {
|
|
var rect = chromeOS ? event.shiftKey && event.metaKey : event.altKey;
|
|
value.unit = rect ? "rectangle" : repeat == "single" ? "char" : repeat == "double" ? "word" : "line";
|
|
}
|
|
if (value.extend == null || cm.doc.extend) value.extend = cm.doc.extend || event.shiftKey;
|
|
if (value.addNew == null) value.addNew = mac ? event.metaKey : event.ctrlKey;
|
|
if (value.moveOnDrag == null) value.moveOnDrag = !(mac ? event.altKey : event.ctrlKey);
|
|
return value;
|
|
}
|
|
function leftButtonDown(cm, pos, repeat, event) {
|
|
if (ie) setTimeout(bind(ensureFocus, cm), 0);
|
|
else cm.curOp.focus = activeElt(root(cm));
|
|
var behavior = configureMouse(cm, repeat, event);
|
|
var sel = cm.doc.sel, contained;
|
|
if (cm.options.dragDrop && dragAndDrop && !cm.isReadOnly() && repeat == "single" && (contained = sel.contains(pos)) > -1 && (cmp((contained = sel.ranges[contained]).from(), pos) < 0 || pos.xRel > 0) && (cmp(contained.to(), pos) > 0 || pos.xRel < 0)) leftButtonStartDrag(cm, event, pos, behavior);
|
|
else leftButtonSelect(cm, event, pos, behavior);
|
|
}
|
|
function leftButtonStartDrag(cm, event, pos, behavior) {
|
|
var display = cm.display, moved = false;
|
|
var dragEnd = operation(cm, function(e) {
|
|
if (webkit) display.scroller.draggable = false;
|
|
cm.state.draggingText = false;
|
|
if (cm.state.delayingBlurEvent) if (cm.hasFocus()) cm.state.delayingBlurEvent = false;
|
|
else delayBlurEvent(cm);
|
|
off(display.wrapper.ownerDocument, "mouseup", dragEnd);
|
|
off(display.wrapper.ownerDocument, "mousemove", mouseMove);
|
|
off(display.scroller, "dragstart", dragStart);
|
|
off(display.scroller, "drop", dragEnd);
|
|
if (!moved) {
|
|
e_preventDefault(e);
|
|
if (!behavior.addNew) extendSelection(cm.doc, pos, null, null, behavior.extend);
|
|
if (webkit && !safari || ie && ie_version == 9) setTimeout(function() {
|
|
display.wrapper.ownerDocument.body.focus({ preventScroll: true });
|
|
display.input.focus();
|
|
}, 20);
|
|
else display.input.focus();
|
|
}
|
|
});
|
|
var mouseMove = function(e2) {
|
|
moved = moved || Math.abs(event.clientX - e2.clientX) + Math.abs(event.clientY - e2.clientY) >= 10;
|
|
};
|
|
var dragStart = function() {
|
|
return moved = true;
|
|
};
|
|
if (webkit) display.scroller.draggable = true;
|
|
cm.state.draggingText = dragEnd;
|
|
dragEnd.copy = !behavior.moveOnDrag;
|
|
on(display.wrapper.ownerDocument, "mouseup", dragEnd);
|
|
on(display.wrapper.ownerDocument, "mousemove", mouseMove);
|
|
on(display.scroller, "dragstart", dragStart);
|
|
on(display.scroller, "drop", dragEnd);
|
|
cm.state.delayingBlurEvent = true;
|
|
setTimeout(function() {
|
|
return display.input.focus();
|
|
}, 20);
|
|
if (display.scroller.dragDrop) display.scroller.dragDrop();
|
|
}
|
|
function rangeForUnit(cm, pos, unit) {
|
|
if (unit == "char") return new Range(pos, pos);
|
|
if (unit == "word") return cm.findWordAt(pos);
|
|
if (unit == "line") return new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0)));
|
|
var result = unit(cm, pos);
|
|
return new Range(result.from, result.to);
|
|
}
|
|
function leftButtonSelect(cm, event, start, behavior) {
|
|
if (ie) delayBlurEvent(cm);
|
|
var display = cm.display, doc$1 = cm.doc;
|
|
e_preventDefault(event);
|
|
var ourRange, ourIndex, startSel = doc$1.sel, ranges = startSel.ranges;
|
|
if (behavior.addNew && !behavior.extend) {
|
|
ourIndex = doc$1.sel.contains(start);
|
|
if (ourIndex > -1) ourRange = ranges[ourIndex];
|
|
else ourRange = new Range(start, start);
|
|
} else {
|
|
ourRange = doc$1.sel.primary();
|
|
ourIndex = doc$1.sel.primIndex;
|
|
}
|
|
if (behavior.unit == "rectangle") {
|
|
if (!behavior.addNew) ourRange = new Range(start, start);
|
|
start = posFromMouse(cm, event, true, true);
|
|
ourIndex = -1;
|
|
} else {
|
|
var range$1 = rangeForUnit(cm, start, behavior.unit);
|
|
if (behavior.extend) ourRange = extendRange(ourRange, range$1.anchor, range$1.head, behavior.extend);
|
|
else ourRange = range$1;
|
|
}
|
|
if (!behavior.addNew) {
|
|
ourIndex = 0;
|
|
setSelection(doc$1, new Selection([ourRange], 0), sel_mouse);
|
|
startSel = doc$1.sel;
|
|
} else if (ourIndex == -1) {
|
|
ourIndex = ranges.length;
|
|
setSelection(doc$1, normalizeSelection(cm, ranges.concat([ourRange]), ourIndex), {
|
|
scroll: false,
|
|
origin: "*mouse"
|
|
});
|
|
} else if (ranges.length > 1 && ranges[ourIndex].empty() && behavior.unit == "char" && !behavior.extend) {
|
|
setSelection(doc$1, normalizeSelection(cm, ranges.slice(0, ourIndex).concat(ranges.slice(ourIndex + 1)), 0), {
|
|
scroll: false,
|
|
origin: "*mouse"
|
|
});
|
|
startSel = doc$1.sel;
|
|
} else replaceOneSelection(doc$1, ourIndex, ourRange, sel_mouse);
|
|
var lastPos = start;
|
|
function extendTo(pos) {
|
|
if (cmp(lastPos, pos) == 0) return;
|
|
lastPos = pos;
|
|
if (behavior.unit == "rectangle") {
|
|
var ranges$1 = [], tabSize = cm.options.tabSize;
|
|
var startCol = countColumn(getLine(doc$1, start.line).text, start.ch, tabSize);
|
|
var posCol = countColumn(getLine(doc$1, pos.line).text, pos.ch, tabSize);
|
|
var left = Math.min(startCol, posCol), right = Math.max(startCol, posCol);
|
|
for (var line = Math.min(start.line, pos.line), end = Math.min(cm.lastLine(), Math.max(start.line, pos.line)); line <= end; line++) {
|
|
var text = getLine(doc$1, line).text, leftPos = findColumn(text, left, tabSize);
|
|
if (left == right) ranges$1.push(new Range(Pos(line, leftPos), Pos(line, leftPos)));
|
|
else if (text.length > leftPos) ranges$1.push(new Range(Pos(line, leftPos), Pos(line, findColumn(text, right, tabSize))));
|
|
}
|
|
if (!ranges$1.length) ranges$1.push(new Range(start, start));
|
|
setSelection(doc$1, normalizeSelection(cm, startSel.ranges.slice(0, ourIndex).concat(ranges$1), ourIndex), {
|
|
origin: "*mouse",
|
|
scroll: false
|
|
});
|
|
cm.scrollIntoView(pos);
|
|
} else {
|
|
var oldRange = ourRange;
|
|
var range$2 = rangeForUnit(cm, pos, behavior.unit);
|
|
var anchor = oldRange.anchor, head;
|
|
if (cmp(range$2.anchor, anchor) > 0) {
|
|
head = range$2.head;
|
|
anchor = minPos(oldRange.from(), range$2.anchor);
|
|
} else {
|
|
head = range$2.anchor;
|
|
anchor = maxPos(oldRange.to(), range$2.head);
|
|
}
|
|
var ranges$1$1 = startSel.ranges.slice(0);
|
|
ranges$1$1[ourIndex] = bidiSimplify(cm, new Range(clipPos(doc$1, anchor), head));
|
|
setSelection(doc$1, normalizeSelection(cm, ranges$1$1, ourIndex), sel_mouse);
|
|
}
|
|
}
|
|
var editorSize = display.wrapper.getBoundingClientRect();
|
|
var counter = 0;
|
|
function extend(e) {
|
|
var curCount = ++counter;
|
|
var cur = posFromMouse(cm, e, true, behavior.unit == "rectangle");
|
|
if (!cur) return;
|
|
if (cmp(cur, lastPos) != 0) {
|
|
cm.curOp.focus = activeElt(root(cm));
|
|
extendTo(cur);
|
|
var visible = visibleLines(display, doc$1);
|
|
if (cur.line >= visible.to || cur.line < visible.from) setTimeout(operation(cm, function() {
|
|
if (counter == curCount) extend(e);
|
|
}), 150);
|
|
} else {
|
|
var outside = e.clientY < editorSize.top ? -20 : e.clientY > editorSize.bottom ? 20 : 0;
|
|
if (outside) setTimeout(operation(cm, function() {
|
|
if (counter != curCount) return;
|
|
display.scroller.scrollTop += outside;
|
|
extend(e);
|
|
}), 50);
|
|
}
|
|
}
|
|
function done(e) {
|
|
cm.state.selectingText = false;
|
|
counter = Infinity;
|
|
if (e) {
|
|
e_preventDefault(e);
|
|
display.input.focus();
|
|
}
|
|
off(display.wrapper.ownerDocument, "mousemove", move);
|
|
off(display.wrapper.ownerDocument, "mouseup", up);
|
|
doc$1.history.lastSelOrigin = null;
|
|
}
|
|
var move = operation(cm, function(e) {
|
|
if (e.buttons === 0 || !e_button(e)) done(e);
|
|
else extend(e);
|
|
});
|
|
var up = operation(cm, done);
|
|
cm.state.selectingText = up;
|
|
on(display.wrapper.ownerDocument, "mousemove", move);
|
|
on(display.wrapper.ownerDocument, "mouseup", up);
|
|
}
|
|
function bidiSimplify(cm, range$1) {
|
|
var anchor = range$1.anchor;
|
|
var head = range$1.head;
|
|
var anchorLine = getLine(cm.doc, anchor.line);
|
|
if (cmp(anchor, head) == 0 && anchor.sticky == head.sticky) return range$1;
|
|
var order = getOrder(anchorLine);
|
|
if (!order) return range$1;
|
|
var index = getBidiPartAt(order, anchor.ch, anchor.sticky), part = order[index];
|
|
if (part.from != anchor.ch && part.to != anchor.ch) return range$1;
|
|
var boundary = index + (part.from == anchor.ch == (part.level != 1) ? 0 : 1);
|
|
if (boundary == 0 || boundary == order.length) return range$1;
|
|
var leftSide;
|
|
if (head.line != anchor.line) leftSide = (head.line - anchor.line) * (cm.doc.direction == "ltr" ? 1 : -1) > 0;
|
|
else {
|
|
var headIndex = getBidiPartAt(order, head.ch, head.sticky);
|
|
var dir = headIndex - index || (head.ch - anchor.ch) * (part.level == 1 ? -1 : 1);
|
|
if (headIndex == boundary - 1 || headIndex == boundary) leftSide = dir < 0;
|
|
else leftSide = dir > 0;
|
|
}
|
|
var usePart = order[boundary + (leftSide ? -1 : 0)];
|
|
var from = leftSide == (usePart.level == 1);
|
|
var ch = from ? usePart.from : usePart.to, sticky = from ? "after" : "before";
|
|
return anchor.ch == ch && anchor.sticky == sticky ? range$1 : new Range(new Pos(anchor.line, ch, sticky), head);
|
|
}
|
|
function gutterEvent(cm, e, type, prevent) {
|
|
var mX, mY;
|
|
if (e.touches) {
|
|
mX = e.touches[0].clientX;
|
|
mY = e.touches[0].clientY;
|
|
} else try {
|
|
mX = e.clientX;
|
|
mY = e.clientY;
|
|
} catch (e$1) {
|
|
return false;
|
|
}
|
|
if (mX >= Math.floor(cm.display.gutters.getBoundingClientRect().right)) return false;
|
|
if (prevent) e_preventDefault(e);
|
|
var display = cm.display;
|
|
var lineBox = display.lineDiv.getBoundingClientRect();
|
|
if (mY > lineBox.bottom || !hasHandler(cm, type)) return e_defaultPrevented(e);
|
|
mY -= lineBox.top - display.viewOffset;
|
|
for (var i$3 = 0; i$3 < cm.display.gutterSpecs.length; ++i$3) {
|
|
var g = display.gutters.childNodes[i$3];
|
|
if (g && g.getBoundingClientRect().right >= mX) {
|
|
var line = lineAtHeight(cm.doc, mY);
|
|
var gutter = cm.display.gutterSpecs[i$3];
|
|
signal(cm, type, cm, line, gutter.className, e);
|
|
return e_defaultPrevented(e);
|
|
}
|
|
}
|
|
}
|
|
function clickInGutter(cm, e) {
|
|
return gutterEvent(cm, e, "gutterClick", true);
|
|
}
|
|
function onContextMenu(cm, e) {
|
|
if (eventInWidget(cm.display, e) || contextMenuInGutter(cm, e)) return;
|
|
if (signalDOMEvent(cm, e, "contextmenu")) return;
|
|
if (!captureRightClick) cm.display.input.onContextMenu(e);
|
|
}
|
|
function contextMenuInGutter(cm, e) {
|
|
if (!hasHandler(cm, "gutterContextMenu")) return false;
|
|
return gutterEvent(cm, e, "gutterContextMenu", false);
|
|
}
|
|
function themeChanged(cm) {
|
|
cm.display.wrapper.className = cm.display.wrapper.className.replace(/\s*cm-s-\S+/g, "") + cm.options.theme.replace(/(^|\s)\s*/g, " cm-s-");
|
|
clearCaches(cm);
|
|
}
|
|
var Init = { toString: function() {
|
|
return "CodeMirror.Init";
|
|
} };
|
|
var defaults = {};
|
|
var optionHandlers = {};
|
|
function defineOptions(CodeMirror$2) {
|
|
var optionHandlers$1 = CodeMirror$2.optionHandlers;
|
|
function option(name, deflt, handle, notOnInit) {
|
|
CodeMirror$2.defaults[name] = deflt;
|
|
if (handle) optionHandlers$1[name] = notOnInit ? function(cm, val, old) {
|
|
if (old != Init) handle(cm, val, old);
|
|
} : handle;
|
|
}
|
|
CodeMirror$2.defineOption = option;
|
|
CodeMirror$2.Init = Init;
|
|
option("value", "", function(cm, val) {
|
|
return cm.setValue(val);
|
|
}, true);
|
|
option("mode", null, function(cm, val) {
|
|
cm.doc.modeOption = val;
|
|
loadMode(cm);
|
|
}, true);
|
|
option("indentUnit", 2, loadMode, true);
|
|
option("indentWithTabs", false);
|
|
option("smartIndent", true);
|
|
option("tabSize", 4, function(cm) {
|
|
resetModeState(cm);
|
|
clearCaches(cm);
|
|
regChange(cm);
|
|
}, true);
|
|
option("lineSeparator", null, function(cm, val) {
|
|
cm.doc.lineSep = val;
|
|
if (!val) return;
|
|
var newBreaks = [], lineNo$1 = cm.doc.first;
|
|
cm.doc.iter(function(line) {
|
|
for (var pos = 0;;) {
|
|
var found = line.text.indexOf(val, pos);
|
|
if (found == -1) break;
|
|
pos = found + val.length;
|
|
newBreaks.push(Pos(lineNo$1, found));
|
|
}
|
|
lineNo$1++;
|
|
});
|
|
for (var i$3 = newBreaks.length - 1; i$3 >= 0; i$3--) replaceRange(cm.doc, val, newBreaks[i$3], Pos(newBreaks[i$3].line, newBreaks[i$3].ch + val.length));
|
|
});
|
|
option("specialChars", /[\u0000-\u001f\u007f-\u009f\u00ad\u061c\u200b\u200e\u200f\u2028\u2029\u202d\u202e\u2066\u2067\u2069\ufeff\ufff9-\ufffc]/g, function(cm, val, old) {
|
|
cm.state.specialChars = new RegExp(val.source + (val.test(" ") ? "" : "| "), "g");
|
|
if (old != Init) cm.refresh();
|
|
});
|
|
option("specialCharPlaceholder", defaultSpecialCharPlaceholder, function(cm) {
|
|
return cm.refresh();
|
|
}, true);
|
|
option("electricChars", true);
|
|
option("inputStyle", mobile ? "contenteditable" : "textarea", function() {
|
|
throw new Error("inputStyle can not (yet) be changed in a running editor");
|
|
}, true);
|
|
option("spellcheck", false, function(cm, val) {
|
|
return cm.getInputField().spellcheck = val;
|
|
}, true);
|
|
option("autocorrect", false, function(cm, val) {
|
|
return cm.getInputField().autocorrect = val;
|
|
}, true);
|
|
option("autocapitalize", false, function(cm, val) {
|
|
return cm.getInputField().autocapitalize = val;
|
|
}, true);
|
|
option("rtlMoveVisually", !windows);
|
|
option("wholeLineUpdateBefore", true);
|
|
option("theme", "default", function(cm) {
|
|
themeChanged(cm);
|
|
updateGutters(cm);
|
|
}, true);
|
|
option("keyMap", "default", function(cm, val, old) {
|
|
var next = getKeyMap(val);
|
|
var prev = old != Init && getKeyMap(old);
|
|
if (prev && prev.detach) prev.detach(cm, next);
|
|
if (next.attach) next.attach(cm, prev || null);
|
|
});
|
|
option("extraKeys", null);
|
|
option("configureMouse", null);
|
|
option("lineWrapping", false, wrappingChanged, true);
|
|
option("gutters", [], function(cm, val) {
|
|
cm.display.gutterSpecs = getGutters(val, cm.options.lineNumbers);
|
|
updateGutters(cm);
|
|
}, true);
|
|
option("fixedGutter", true, function(cm, val) {
|
|
cm.display.gutters.style.left = val ? compensateForHScroll(cm.display) + "px" : "0";
|
|
cm.refresh();
|
|
}, true);
|
|
option("coverGutterNextToScrollbar", false, function(cm) {
|
|
return updateScrollbars(cm);
|
|
}, true);
|
|
option("scrollbarStyle", "native", function(cm) {
|
|
initScrollbars(cm);
|
|
updateScrollbars(cm);
|
|
cm.display.scrollbars.setScrollTop(cm.doc.scrollTop);
|
|
cm.display.scrollbars.setScrollLeft(cm.doc.scrollLeft);
|
|
}, true);
|
|
option("lineNumbers", false, function(cm, val) {
|
|
cm.display.gutterSpecs = getGutters(cm.options.gutters, val);
|
|
updateGutters(cm);
|
|
}, true);
|
|
option("firstLineNumber", 1, updateGutters, true);
|
|
option("lineNumberFormatter", function(integer) {
|
|
return integer;
|
|
}, updateGutters, true);
|
|
option("showCursorWhenSelecting", false, updateSelection, true);
|
|
option("resetSelectionOnContextMenu", true);
|
|
option("lineWiseCopyCut", true);
|
|
option("pasteLinesPerSelection", true);
|
|
option("selectionsMayTouch", false);
|
|
option("readOnly", false, function(cm, val) {
|
|
if (val == "nocursor") {
|
|
onBlur(cm);
|
|
cm.display.input.blur();
|
|
}
|
|
cm.display.input.readOnlyChanged(val);
|
|
});
|
|
option("screenReaderLabel", null, function(cm, val) {
|
|
val = val === "" ? null : val;
|
|
cm.display.input.screenReaderLabelChanged(val);
|
|
});
|
|
option("disableInput", false, function(cm, val) {
|
|
if (!val) cm.display.input.reset();
|
|
}, true);
|
|
option("dragDrop", true, dragDropChanged);
|
|
option("allowDropFileTypes", null);
|
|
option("cursorBlinkRate", 530);
|
|
option("cursorScrollMargin", 0);
|
|
option("cursorHeight", 1, updateSelection, true);
|
|
option("singleCursorHeightPerLine", true, updateSelection, true);
|
|
option("workTime", 100);
|
|
option("workDelay", 100);
|
|
option("flattenSpans", true, resetModeState, true);
|
|
option("addModeClass", false, resetModeState, true);
|
|
option("pollInterval", 100);
|
|
option("undoDepth", 200, function(cm, val) {
|
|
return cm.doc.history.undoDepth = val;
|
|
});
|
|
option("historyEventDelay", 1250);
|
|
option("viewportMargin", 10, function(cm) {
|
|
return cm.refresh();
|
|
}, true);
|
|
option("maxHighlightLength", 1e4, resetModeState, true);
|
|
option("moveInputWithCursor", true, function(cm, val) {
|
|
if (!val) cm.display.input.resetPosition();
|
|
});
|
|
option("tabindex", null, function(cm, val) {
|
|
return cm.display.input.getField().tabIndex = val || "";
|
|
});
|
|
option("autofocus", null);
|
|
option("direction", "ltr", function(cm, val) {
|
|
return cm.doc.setDirection(val);
|
|
}, true);
|
|
option("phrases", null);
|
|
}
|
|
function dragDropChanged(cm, value, old) {
|
|
var wasOn = old && old != Init;
|
|
if (!value != !wasOn) {
|
|
var funcs = cm.display.dragFunctions;
|
|
var toggle = value ? on : off;
|
|
toggle(cm.display.scroller, "dragstart", funcs.start);
|
|
toggle(cm.display.scroller, "dragenter", funcs.enter);
|
|
toggle(cm.display.scroller, "dragover", funcs.over);
|
|
toggle(cm.display.scroller, "dragleave", funcs.leave);
|
|
toggle(cm.display.scroller, "drop", funcs.drop);
|
|
}
|
|
}
|
|
function wrappingChanged(cm) {
|
|
if (cm.options.lineWrapping) {
|
|
addClass(cm.display.wrapper, "CodeMirror-wrap");
|
|
cm.display.sizer.style.minWidth = "";
|
|
cm.display.sizerWidth = null;
|
|
} else {
|
|
rmClass(cm.display.wrapper, "CodeMirror-wrap");
|
|
findMaxLine(cm);
|
|
}
|
|
estimateLineHeights(cm);
|
|
regChange(cm);
|
|
clearCaches(cm);
|
|
setTimeout(function() {
|
|
return updateScrollbars(cm);
|
|
}, 100);
|
|
}
|
|
function CodeMirror$1(place, options) {
|
|
var this$1 = this;
|
|
if (!(this instanceof CodeMirror$1)) return new CodeMirror$1(place, options);
|
|
this.options = options = options ? copyObj(options) : {};
|
|
copyObj(defaults, options, false);
|
|
var doc$1 = options.value;
|
|
if (typeof doc$1 == "string") doc$1 = new Doc(doc$1, options.mode, null, options.lineSeparator, options.direction);
|
|
else if (options.mode) doc$1.modeOption = options.mode;
|
|
this.doc = doc$1;
|
|
var input = new CodeMirror$1.inputStyles[options.inputStyle](this);
|
|
var display = this.display = new Display(place, doc$1, input, options);
|
|
display.wrapper.CodeMirror = this;
|
|
themeChanged(this);
|
|
if (options.lineWrapping) this.display.wrapper.className += " CodeMirror-wrap";
|
|
initScrollbars(this);
|
|
this.state = {
|
|
keyMaps: [],
|
|
overlays: [],
|
|
modeGen: 0,
|
|
overwrite: false,
|
|
delayingBlurEvent: false,
|
|
focused: false,
|
|
suppressEdits: false,
|
|
pasteIncoming: -1,
|
|
cutIncoming: -1,
|
|
selectingText: false,
|
|
draggingText: false,
|
|
highlight: new Delayed(),
|
|
keySeq: null,
|
|
specialChars: null
|
|
};
|
|
if (options.autofocus && !mobile) display.input.focus();
|
|
if (ie && ie_version < 11) setTimeout(function() {
|
|
return this$1.display.input.reset(true);
|
|
}, 20);
|
|
registerEventHandlers(this);
|
|
ensureGlobalHandlers();
|
|
startOperation(this);
|
|
this.curOp.forceUpdate = true;
|
|
attachDoc(this, doc$1);
|
|
if (options.autofocus && !mobile || this.hasFocus()) setTimeout(function() {
|
|
if (this$1.hasFocus() && !this$1.state.focused) onFocus(this$1);
|
|
}, 20);
|
|
else onBlur(this);
|
|
for (var opt in optionHandlers) if (optionHandlers.hasOwnProperty(opt)) optionHandlers[opt](this, options[opt], Init);
|
|
maybeUpdateLineNumberWidth(this);
|
|
if (options.finishInit) options.finishInit(this);
|
|
for (var i$3 = 0; i$3 < initHooks.length; ++i$3) initHooks[i$3](this);
|
|
endOperation(this);
|
|
if (webkit && options.lineWrapping && getComputedStyle(display.lineDiv).textRendering == "optimizelegibility") display.lineDiv.style.textRendering = "auto";
|
|
}
|
|
CodeMirror$1.defaults = defaults;
|
|
CodeMirror$1.optionHandlers = optionHandlers;
|
|
function registerEventHandlers(cm) {
|
|
var d = cm.display;
|
|
on(d.scroller, "mousedown", operation(cm, onMouseDown));
|
|
if (ie && ie_version < 11) on(d.scroller, "dblclick", operation(cm, function(e) {
|
|
if (signalDOMEvent(cm, e)) return;
|
|
var pos = posFromMouse(cm, e);
|
|
if (!pos || clickInGutter(cm, e) || eventInWidget(cm.display, e)) return;
|
|
e_preventDefault(e);
|
|
var word = cm.findWordAt(pos);
|
|
extendSelection(cm.doc, word.anchor, word.head);
|
|
}));
|
|
else on(d.scroller, "dblclick", function(e) {
|
|
return signalDOMEvent(cm, e) || e_preventDefault(e);
|
|
});
|
|
on(d.scroller, "contextmenu", function(e) {
|
|
return onContextMenu(cm, e);
|
|
});
|
|
on(d.input.getField(), "contextmenu", function(e) {
|
|
if (!d.scroller.contains(e.target)) onContextMenu(cm, e);
|
|
});
|
|
var touchFinished, prevTouch = { end: 0 };
|
|
function finishTouch() {
|
|
if (d.activeTouch) {
|
|
touchFinished = setTimeout(function() {
|
|
return d.activeTouch = null;
|
|
}, 1e3);
|
|
prevTouch = d.activeTouch;
|
|
prevTouch.end = +new Date();
|
|
}
|
|
}
|
|
function isMouseLikeTouchEvent(e) {
|
|
if (e.touches.length != 1) return false;
|
|
var touch = e.touches[0];
|
|
return touch.radiusX <= 1 && touch.radiusY <= 1;
|
|
}
|
|
function farAway(touch, other) {
|
|
if (other.left == null) return true;
|
|
var dx = other.left - touch.left, dy = other.top - touch.top;
|
|
return dx * dx + dy * dy > 20 * 20;
|
|
}
|
|
on(d.scroller, "touchstart", function(e) {
|
|
if (!signalDOMEvent(cm, e) && !isMouseLikeTouchEvent(e) && !clickInGutter(cm, e)) {
|
|
d.input.ensurePolled();
|
|
clearTimeout(touchFinished);
|
|
var now = +new Date();
|
|
d.activeTouch = {
|
|
start: now,
|
|
moved: false,
|
|
prev: now - prevTouch.end <= 300 ? prevTouch : null
|
|
};
|
|
if (e.touches.length == 1) {
|
|
d.activeTouch.left = e.touches[0].pageX;
|
|
d.activeTouch.top = e.touches[0].pageY;
|
|
}
|
|
}
|
|
});
|
|
on(d.scroller, "touchmove", function() {
|
|
if (d.activeTouch) d.activeTouch.moved = true;
|
|
});
|
|
on(d.scroller, "touchend", function(e) {
|
|
var touch = d.activeTouch;
|
|
if (touch && !eventInWidget(d, e) && touch.left != null && !touch.moved && new Date() - touch.start < 300) {
|
|
var pos = cm.coordsChar(d.activeTouch, "page"), range$1;
|
|
if (!touch.prev || farAway(touch, touch.prev)) range$1 = new Range(pos, pos);
|
|
else if (!touch.prev.prev || farAway(touch, touch.prev.prev)) range$1 = cm.findWordAt(pos);
|
|
else range$1 = new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0)));
|
|
cm.setSelection(range$1.anchor, range$1.head);
|
|
cm.focus();
|
|
e_preventDefault(e);
|
|
}
|
|
finishTouch();
|
|
});
|
|
on(d.scroller, "touchcancel", finishTouch);
|
|
on(d.scroller, "scroll", function() {
|
|
if (d.scroller.clientHeight) {
|
|
updateScrollTop(cm, d.scroller.scrollTop);
|
|
setScrollLeft(cm, d.scroller.scrollLeft, true);
|
|
signal(cm, "scroll", cm);
|
|
}
|
|
});
|
|
on(d.scroller, "mousewheel", function(e) {
|
|
return onScrollWheel(cm, e);
|
|
});
|
|
on(d.scroller, "DOMMouseScroll", function(e) {
|
|
return onScrollWheel(cm, e);
|
|
});
|
|
on(d.wrapper, "scroll", function() {
|
|
return d.wrapper.scrollTop = d.wrapper.scrollLeft = 0;
|
|
});
|
|
d.dragFunctions = {
|
|
enter: function(e) {
|
|
if (!signalDOMEvent(cm, e)) e_stop(e);
|
|
},
|
|
over: function(e) {
|
|
if (!signalDOMEvent(cm, e)) {
|
|
onDragOver(cm, e);
|
|
e_stop(e);
|
|
}
|
|
},
|
|
start: function(e) {
|
|
return onDragStart(cm, e);
|
|
},
|
|
drop: operation(cm, onDrop),
|
|
leave: function(e) {
|
|
if (!signalDOMEvent(cm, e)) clearDragCursor(cm);
|
|
}
|
|
};
|
|
var inp = d.input.getField();
|
|
on(inp, "keyup", function(e) {
|
|
return onKeyUp.call(cm, e);
|
|
});
|
|
on(inp, "keydown", operation(cm, onKeyDown));
|
|
on(inp, "keypress", operation(cm, onKeyPress));
|
|
on(inp, "focus", function(e) {
|
|
return onFocus(cm, e);
|
|
});
|
|
on(inp, "blur", function(e) {
|
|
return onBlur(cm, e);
|
|
});
|
|
}
|
|
var initHooks = [];
|
|
CodeMirror$1.defineInitHook = function(f) {
|
|
return initHooks.push(f);
|
|
};
|
|
function indentLine(cm, n, how, aggressive) {
|
|
var doc$1 = cm.doc, state;
|
|
if (how == null) how = "add";
|
|
if (how == "smart") if (!doc$1.mode.indent) how = "prev";
|
|
else state = getContextBefore(cm, n).state;
|
|
var tabSize = cm.options.tabSize;
|
|
var line = getLine(doc$1, n), curSpace = countColumn(line.text, null, tabSize);
|
|
if (line.stateAfter) line.stateAfter = null;
|
|
var curSpaceString = line.text.match(/^\s*/)[0], indentation;
|
|
if (!aggressive && !/\S/.test(line.text)) {
|
|
indentation = 0;
|
|
how = "not";
|
|
} else if (how == "smart") {
|
|
indentation = doc$1.mode.indent(state, line.text.slice(curSpaceString.length), line.text);
|
|
if (indentation == Pass || indentation > 150) {
|
|
if (!aggressive) return;
|
|
how = "prev";
|
|
}
|
|
}
|
|
if (how == "prev") if (n > doc$1.first) indentation = countColumn(getLine(doc$1, n - 1).text, null, tabSize);
|
|
else indentation = 0;
|
|
else if (how == "add") indentation = curSpace + cm.options.indentUnit;
|
|
else if (how == "subtract") indentation = curSpace - cm.options.indentUnit;
|
|
else if (typeof how == "number") indentation = curSpace + how;
|
|
indentation = Math.max(0, indentation);
|
|
var indentString = "", pos = 0;
|
|
if (cm.options.indentWithTabs) for (var i$3 = Math.floor(indentation / tabSize); i$3; --i$3) {
|
|
pos += tabSize;
|
|
indentString += " ";
|
|
}
|
|
if (pos < indentation) indentString += spaceStr(indentation - pos);
|
|
if (indentString != curSpaceString) {
|
|
replaceRange(doc$1, indentString, Pos(n, 0), Pos(n, curSpaceString.length), "+input");
|
|
line.stateAfter = null;
|
|
return true;
|
|
} else for (var i$1$1 = 0; i$1$1 < doc$1.sel.ranges.length; i$1$1++) {
|
|
var range$1 = doc$1.sel.ranges[i$1$1];
|
|
if (range$1.head.line == n && range$1.head.ch < curSpaceString.length) {
|
|
var pos$1 = Pos(n, curSpaceString.length);
|
|
replaceOneSelection(doc$1, i$1$1, new Range(pos$1, pos$1));
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
var lastCopied = null;
|
|
function setLastCopied(newLastCopied) {
|
|
lastCopied = newLastCopied;
|
|
}
|
|
function applyTextInput(cm, inserted, deleted, sel, origin) {
|
|
var doc$1 = cm.doc;
|
|
cm.display.shift = false;
|
|
if (!sel) sel = doc$1.sel;
|
|
var recent = +new Date() - 200;
|
|
var paste = origin == "paste" || cm.state.pasteIncoming > recent;
|
|
var textLines = splitLinesAuto(inserted), multiPaste = null;
|
|
if (paste && sel.ranges.length > 1) {
|
|
if (lastCopied && lastCopied.text.join("\n") == inserted) {
|
|
if (sel.ranges.length % lastCopied.text.length == 0) {
|
|
multiPaste = [];
|
|
for (var i$3 = 0; i$3 < lastCopied.text.length; i$3++) multiPaste.push(doc$1.splitLines(lastCopied.text[i$3]));
|
|
}
|
|
} else if (textLines.length == sel.ranges.length && cm.options.pasteLinesPerSelection) multiPaste = map(textLines, function(l) {
|
|
return [l];
|
|
});
|
|
}
|
|
var updateInput = cm.curOp.updateInput;
|
|
for (var i$1$1 = sel.ranges.length - 1; i$1$1 >= 0; i$1$1--) {
|
|
var range$1 = sel.ranges[i$1$1];
|
|
var from = range$1.from(), to = range$1.to();
|
|
if (range$1.empty()) {
|
|
if (deleted && deleted > 0) from = Pos(from.line, from.ch - deleted);
|
|
else if (cm.state.overwrite && !paste) to = Pos(to.line, Math.min(getLine(doc$1, to.line).text.length, to.ch + lst(textLines).length));
|
|
else if (paste && lastCopied && lastCopied.lineWise && lastCopied.text.join("\n") == textLines.join("\n")) from = to = Pos(from.line, 0);
|
|
}
|
|
var changeEvent = {
|
|
from,
|
|
to,
|
|
text: multiPaste ? multiPaste[i$1$1 % multiPaste.length] : textLines,
|
|
origin: origin || (paste ? "paste" : cm.state.cutIncoming > recent ? "cut" : "+input")
|
|
};
|
|
makeChange(cm.doc, changeEvent);
|
|
signalLater(cm, "inputRead", cm, changeEvent);
|
|
}
|
|
if (inserted && !paste) triggerElectric(cm, inserted);
|
|
ensureCursorVisible(cm);
|
|
if (cm.curOp.updateInput < 2) cm.curOp.updateInput = updateInput;
|
|
cm.curOp.typing = true;
|
|
cm.state.pasteIncoming = cm.state.cutIncoming = -1;
|
|
}
|
|
function handlePaste(e, cm) {
|
|
var pasted = e.clipboardData && e.clipboardData.getData("Text");
|
|
if (pasted) {
|
|
e.preventDefault();
|
|
if (!cm.isReadOnly() && !cm.options.disableInput && cm.hasFocus()) runInOp(cm, function() {
|
|
return applyTextInput(cm, pasted, 0, null, "paste");
|
|
});
|
|
return true;
|
|
}
|
|
}
|
|
function triggerElectric(cm, inserted) {
|
|
if (!cm.options.electricChars || !cm.options.smartIndent) return;
|
|
var sel = cm.doc.sel;
|
|
for (var i$3 = sel.ranges.length - 1; i$3 >= 0; i$3--) {
|
|
var range$1 = sel.ranges[i$3];
|
|
if (range$1.head.ch > 100 || i$3 && sel.ranges[i$3 - 1].head.line == range$1.head.line) continue;
|
|
var mode = cm.getModeAt(range$1.head);
|
|
var indented = false;
|
|
if (mode.electricChars) {
|
|
for (var j = 0; j < mode.electricChars.length; j++) if (inserted.indexOf(mode.electricChars.charAt(j)) > -1) {
|
|
indented = indentLine(cm, range$1.head.line, "smart");
|
|
break;
|
|
}
|
|
} else if (mode.electricInput) {
|
|
if (mode.electricInput.test(getLine(cm.doc, range$1.head.line).text.slice(0, range$1.head.ch))) indented = indentLine(cm, range$1.head.line, "smart");
|
|
}
|
|
if (indented) signalLater(cm, "electricInput", cm, range$1.head.line);
|
|
}
|
|
}
|
|
function copyableRanges(cm) {
|
|
var text = [], ranges = [];
|
|
for (var i$3 = 0; i$3 < cm.doc.sel.ranges.length; i$3++) {
|
|
var line = cm.doc.sel.ranges[i$3].head.line;
|
|
var lineRange = {
|
|
anchor: Pos(line, 0),
|
|
head: Pos(line + 1, 0)
|
|
};
|
|
ranges.push(lineRange);
|
|
text.push(cm.getRange(lineRange.anchor, lineRange.head));
|
|
}
|
|
return {
|
|
text,
|
|
ranges
|
|
};
|
|
}
|
|
function disableBrowserMagic(field, spellcheck, autocorrect, autocapitalize) {
|
|
field.setAttribute("autocorrect", autocorrect ? "on" : "off");
|
|
field.setAttribute("autocapitalize", autocapitalize ? "on" : "off");
|
|
field.setAttribute("spellcheck", !!spellcheck);
|
|
}
|
|
function hiddenTextarea() {
|
|
var te = elt("textarea", null, null, "position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; min-height: 1em; outline: none");
|
|
var div = elt("div", [te], null, "overflow: hidden; position: relative; width: 3px; height: 0px;");
|
|
if (webkit) te.style.width = "1000px";
|
|
else te.setAttribute("wrap", "off");
|
|
if (ios) te.style.border = "1px solid black";
|
|
return div;
|
|
}
|
|
function addEditorMethods(CodeMirror$2) {
|
|
var optionHandlers$1 = CodeMirror$2.optionHandlers;
|
|
var helpers = CodeMirror$2.helpers = {};
|
|
CodeMirror$2.prototype = {
|
|
constructor: CodeMirror$2,
|
|
focus: function() {
|
|
win(this).focus();
|
|
this.display.input.focus();
|
|
},
|
|
setOption: function(option, value) {
|
|
var options = this.options, old = options[option];
|
|
if (options[option] == value && option != "mode") return;
|
|
options[option] = value;
|
|
if (optionHandlers$1.hasOwnProperty(option)) operation(this, optionHandlers$1[option])(this, value, old);
|
|
signal(this, "optionChange", this, option);
|
|
},
|
|
getOption: function(option) {
|
|
return this.options[option];
|
|
},
|
|
getDoc: function() {
|
|
return this.doc;
|
|
},
|
|
addKeyMap: function(map$1, bottom) {
|
|
this.state.keyMaps[bottom ? "push" : "unshift"](getKeyMap(map$1));
|
|
},
|
|
removeKeyMap: function(map$1) {
|
|
var maps = this.state.keyMaps;
|
|
for (var i$3 = 0; i$3 < maps.length; ++i$3) if (maps[i$3] == map$1 || maps[i$3].name == map$1) {
|
|
maps.splice(i$3, 1);
|
|
return true;
|
|
}
|
|
},
|
|
addOverlay: methodOp(function(spec, options) {
|
|
var mode = spec.token ? spec : CodeMirror$2.getMode(this.options, spec);
|
|
if (mode.startState) throw new Error("Overlays may not be stateful.");
|
|
insertSorted(this.state.overlays, {
|
|
mode,
|
|
modeSpec: spec,
|
|
opaque: options && options.opaque,
|
|
priority: options && options.priority || 0
|
|
}, function(overlay) {
|
|
return overlay.priority;
|
|
});
|
|
this.state.modeGen++;
|
|
regChange(this);
|
|
}),
|
|
removeOverlay: methodOp(function(spec) {
|
|
var overlays = this.state.overlays;
|
|
for (var i$3 = 0; i$3 < overlays.length; ++i$3) {
|
|
var cur = overlays[i$3].modeSpec;
|
|
if (cur == spec || typeof spec == "string" && cur.name == spec) {
|
|
overlays.splice(i$3, 1);
|
|
this.state.modeGen++;
|
|
regChange(this);
|
|
return;
|
|
}
|
|
}
|
|
}),
|
|
indentLine: methodOp(function(n, dir, aggressive) {
|
|
if (typeof dir != "string" && typeof dir != "number") if (dir == null) dir = this.options.smartIndent ? "smart" : "prev";
|
|
else dir = dir ? "add" : "subtract";
|
|
if (isLine(this.doc, n)) indentLine(this, n, dir, aggressive);
|
|
}),
|
|
indentSelection: methodOp(function(how) {
|
|
var ranges = this.doc.sel.ranges, end = -1;
|
|
for (var i$3 = 0; i$3 < ranges.length; i$3++) {
|
|
var range$1 = ranges[i$3];
|
|
if (!range$1.empty()) {
|
|
var from = range$1.from(), to = range$1.to();
|
|
var start = Math.max(end, from.line);
|
|
end = Math.min(this.lastLine(), to.line - (to.ch ? 0 : 1)) + 1;
|
|
for (var j = start; j < end; ++j) indentLine(this, j, how);
|
|
var newRanges = this.doc.sel.ranges;
|
|
if (from.ch == 0 && ranges.length == newRanges.length && newRanges[i$3].from().ch > 0) replaceOneSelection(this.doc, i$3, new Range(from, newRanges[i$3].to()), sel_dontScroll);
|
|
} else if (range$1.head.line > end) {
|
|
indentLine(this, range$1.head.line, how, true);
|
|
end = range$1.head.line;
|
|
if (i$3 == this.doc.sel.primIndex) ensureCursorVisible(this);
|
|
}
|
|
}
|
|
}),
|
|
getTokenAt: function(pos, precise) {
|
|
return takeToken(this, pos, precise);
|
|
},
|
|
getLineTokens: function(line, precise) {
|
|
return takeToken(this, Pos(line), precise, true);
|
|
},
|
|
getTokenTypeAt: function(pos) {
|
|
pos = clipPos(this.doc, pos);
|
|
var styles = getLineStyles(this, getLine(this.doc, pos.line));
|
|
var before = 0, after = (styles.length - 1) / 2, ch = pos.ch;
|
|
var type;
|
|
if (ch == 0) type = styles[2];
|
|
else for (;;) {
|
|
var mid = before + after >> 1;
|
|
if ((mid ? styles[mid * 2 - 1] : 0) >= ch) after = mid;
|
|
else if (styles[mid * 2 + 1] < ch) before = mid + 1;
|
|
else {
|
|
type = styles[mid * 2 + 2];
|
|
break;
|
|
}
|
|
}
|
|
var cut = type ? type.indexOf("overlay ") : -1;
|
|
return cut < 0 ? type : cut == 0 ? null : type.slice(0, cut - 1);
|
|
},
|
|
getModeAt: function(pos) {
|
|
var mode = this.doc.mode;
|
|
if (!mode.innerMode) return mode;
|
|
return CodeMirror$2.innerMode(mode, this.getTokenAt(pos).state).mode;
|
|
},
|
|
getHelper: function(pos, type) {
|
|
return this.getHelpers(pos, type)[0];
|
|
},
|
|
getHelpers: function(pos, type) {
|
|
var found = [];
|
|
if (!helpers.hasOwnProperty(type)) return found;
|
|
var help = helpers[type], mode = this.getModeAt(pos);
|
|
if (typeof mode[type] == "string") {
|
|
if (help[mode[type]]) found.push(help[mode[type]]);
|
|
} else if (mode[type]) for (var i$3 = 0; i$3 < mode[type].length; i$3++) {
|
|
var val = help[mode[type][i$3]];
|
|
if (val) found.push(val);
|
|
}
|
|
else if (mode.helperType && help[mode.helperType]) found.push(help[mode.helperType]);
|
|
else if (help[mode.name]) found.push(help[mode.name]);
|
|
for (var i$1$1 = 0; i$1$1 < help._global.length; i$1$1++) {
|
|
var cur = help._global[i$1$1];
|
|
if (cur.pred(mode, this) && indexOf(found, cur.val) == -1) found.push(cur.val);
|
|
}
|
|
return found;
|
|
},
|
|
getStateAfter: function(line, precise) {
|
|
var doc$1 = this.doc;
|
|
line = clipLine(doc$1, line == null ? doc$1.first + doc$1.size - 1 : line);
|
|
return getContextBefore(this, line + 1, precise).state;
|
|
},
|
|
cursorCoords: function(start, mode) {
|
|
var pos, range$1 = this.doc.sel.primary();
|
|
if (start == null) pos = range$1.head;
|
|
else if (typeof start == "object") pos = clipPos(this.doc, start);
|
|
else pos = start ? range$1.from() : range$1.to();
|
|
return cursorCoords(this, pos, mode || "page");
|
|
},
|
|
charCoords: function(pos, mode) {
|
|
return charCoords(this, clipPos(this.doc, pos), mode || "page");
|
|
},
|
|
coordsChar: function(coords, mode) {
|
|
coords = fromCoordSystem(this, coords, mode || "page");
|
|
return coordsChar(this, coords.left, coords.top);
|
|
},
|
|
lineAtHeight: function(height, mode) {
|
|
height = fromCoordSystem(this, {
|
|
top: height,
|
|
left: 0
|
|
}, mode || "page").top;
|
|
return lineAtHeight(this.doc, height + this.display.viewOffset);
|
|
},
|
|
heightAtLine: function(line, mode, includeWidgets) {
|
|
var end = false, lineObj;
|
|
if (typeof line == "number") {
|
|
var last = this.doc.first + this.doc.size - 1;
|
|
if (line < this.doc.first) line = this.doc.first;
|
|
else if (line > last) {
|
|
line = last;
|
|
end = true;
|
|
}
|
|
lineObj = getLine(this.doc, line);
|
|
} else lineObj = line;
|
|
return intoCoordSystem(this, lineObj, {
|
|
top: 0,
|
|
left: 0
|
|
}, mode || "page", includeWidgets || end).top + (end ? this.doc.height - heightAtLine(lineObj) : 0);
|
|
},
|
|
defaultTextHeight: function() {
|
|
return textHeight(this.display);
|
|
},
|
|
defaultCharWidth: function() {
|
|
return charWidth(this.display);
|
|
},
|
|
getViewport: function() {
|
|
return {
|
|
from: this.display.viewFrom,
|
|
to: this.display.viewTo
|
|
};
|
|
},
|
|
addWidget: function(pos, node, scroll, vert, horiz) {
|
|
var display = this.display;
|
|
pos = cursorCoords(this, clipPos(this.doc, pos));
|
|
var top = pos.bottom, left = pos.left;
|
|
node.style.position = "absolute";
|
|
node.setAttribute("cm-ignore-events", "true");
|
|
this.display.input.setUneditable(node);
|
|
display.sizer.appendChild(node);
|
|
if (vert == "over") top = pos.top;
|
|
else if (vert == "above" || vert == "near") {
|
|
var vspace = Math.max(display.wrapper.clientHeight, this.doc.height), hspace = Math.max(display.sizer.clientWidth, display.lineSpace.clientWidth);
|
|
if ((vert == "above" || pos.bottom + node.offsetHeight > vspace) && pos.top > node.offsetHeight) top = pos.top - node.offsetHeight;
|
|
else if (pos.bottom + node.offsetHeight <= vspace) top = pos.bottom;
|
|
if (left + node.offsetWidth > hspace) left = hspace - node.offsetWidth;
|
|
}
|
|
node.style.top = top + "px";
|
|
node.style.left = node.style.right = "";
|
|
if (horiz == "right") {
|
|
left = display.sizer.clientWidth - node.offsetWidth;
|
|
node.style.right = "0px";
|
|
} else {
|
|
if (horiz == "left") left = 0;
|
|
else if (horiz == "middle") left = (display.sizer.clientWidth - node.offsetWidth) / 2;
|
|
node.style.left = left + "px";
|
|
}
|
|
if (scroll) scrollIntoView(this, {
|
|
left,
|
|
top,
|
|
right: left + node.offsetWidth,
|
|
bottom: top + node.offsetHeight
|
|
});
|
|
},
|
|
triggerOnKeyDown: methodOp(onKeyDown),
|
|
triggerOnKeyPress: methodOp(onKeyPress),
|
|
triggerOnKeyUp: onKeyUp,
|
|
triggerOnMouseDown: methodOp(onMouseDown),
|
|
execCommand: function(cmd) {
|
|
if (commands.hasOwnProperty(cmd)) return commands[cmd].call(null, this);
|
|
},
|
|
triggerElectric: methodOp(function(text) {
|
|
triggerElectric(this, text);
|
|
}),
|
|
findPosH: function(from, amount, unit, visually) {
|
|
var dir = 1;
|
|
if (amount < 0) {
|
|
dir = -1;
|
|
amount = -amount;
|
|
}
|
|
var cur = clipPos(this.doc, from);
|
|
for (var i$3 = 0; i$3 < amount; ++i$3) {
|
|
cur = findPosH(this.doc, cur, dir, unit, visually);
|
|
if (cur.hitSide) break;
|
|
}
|
|
return cur;
|
|
},
|
|
moveH: methodOp(function(dir, unit) {
|
|
var this$1 = this;
|
|
this.extendSelectionsBy(function(range$1) {
|
|
if (this$1.display.shift || this$1.doc.extend || range$1.empty()) return findPosH(this$1.doc, range$1.head, dir, unit, this$1.options.rtlMoveVisually);
|
|
else return dir < 0 ? range$1.from() : range$1.to();
|
|
}, sel_move);
|
|
}),
|
|
deleteH: methodOp(function(dir, unit) {
|
|
var sel = this.doc.sel, doc$1 = this.doc;
|
|
if (sel.somethingSelected()) doc$1.replaceSelection("", null, "+delete");
|
|
else deleteNearSelection(this, function(range$1) {
|
|
var other = findPosH(doc$1, range$1.head, dir, unit, false);
|
|
return dir < 0 ? {
|
|
from: other,
|
|
to: range$1.head
|
|
} : {
|
|
from: range$1.head,
|
|
to: other
|
|
};
|
|
});
|
|
}),
|
|
findPosV: function(from, amount, unit, goalColumn) {
|
|
var dir = 1, x = goalColumn;
|
|
if (amount < 0) {
|
|
dir = -1;
|
|
amount = -amount;
|
|
}
|
|
var cur = clipPos(this.doc, from);
|
|
for (var i$3 = 0; i$3 < amount; ++i$3) {
|
|
var coords = cursorCoords(this, cur, "div");
|
|
if (x == null) x = coords.left;
|
|
else coords.left = x;
|
|
cur = findPosV(this, coords, dir, unit);
|
|
if (cur.hitSide) break;
|
|
}
|
|
return cur;
|
|
},
|
|
moveV: methodOp(function(dir, unit) {
|
|
var this$1 = this;
|
|
var doc$1 = this.doc, goals = [];
|
|
var collapse = !this.display.shift && !doc$1.extend && doc$1.sel.somethingSelected();
|
|
doc$1.extendSelectionsBy(function(range$1) {
|
|
if (collapse) return dir < 0 ? range$1.from() : range$1.to();
|
|
var headPos = cursorCoords(this$1, range$1.head, "div");
|
|
if (range$1.goalColumn != null) headPos.left = range$1.goalColumn;
|
|
goals.push(headPos.left);
|
|
var pos = findPosV(this$1, headPos, dir, unit);
|
|
if (unit == "page" && range$1 == doc$1.sel.primary()) addToScrollTop(this$1, charCoords(this$1, pos, "div").top - headPos.top);
|
|
return pos;
|
|
}, sel_move);
|
|
if (goals.length) for (var i$3 = 0; i$3 < doc$1.sel.ranges.length; i$3++) doc$1.sel.ranges[i$3].goalColumn = goals[i$3];
|
|
}),
|
|
findWordAt: function(pos) {
|
|
var doc$1 = this.doc, line = getLine(doc$1, pos.line).text;
|
|
var start = pos.ch, end = pos.ch;
|
|
if (line) {
|
|
var helper = this.getHelper(pos, "wordChars");
|
|
if ((pos.sticky == "before" || end == line.length) && start) --start;
|
|
else ++end;
|
|
var startChar = line.charAt(start);
|
|
var check = isWordChar(startChar, helper) ? function(ch) {
|
|
return isWordChar(ch, helper);
|
|
} : /\s/.test(startChar) ? function(ch) {
|
|
return /\s/.test(ch);
|
|
} : function(ch) {
|
|
return !/\s/.test(ch) && !isWordChar(ch);
|
|
};
|
|
while (start > 0 && check(line.charAt(start - 1))) --start;
|
|
while (end < line.length && check(line.charAt(end))) ++end;
|
|
}
|
|
return new Range(Pos(pos.line, start), Pos(pos.line, end));
|
|
},
|
|
toggleOverwrite: function(value) {
|
|
if (value != null && value == this.state.overwrite) return;
|
|
if (this.state.overwrite = !this.state.overwrite) addClass(this.display.cursorDiv, "CodeMirror-overwrite");
|
|
else rmClass(this.display.cursorDiv, "CodeMirror-overwrite");
|
|
signal(this, "overwriteToggle", this, this.state.overwrite);
|
|
},
|
|
hasFocus: function() {
|
|
return this.display.input.getField() == activeElt(root(this));
|
|
},
|
|
isReadOnly: function() {
|
|
return !!(this.options.readOnly || this.doc.cantEdit);
|
|
},
|
|
scrollTo: methodOp(function(x, y) {
|
|
scrollToCoords(this, x, y);
|
|
}),
|
|
getScrollInfo: function() {
|
|
var scroller = this.display.scroller;
|
|
return {
|
|
left: scroller.scrollLeft,
|
|
top: scroller.scrollTop,
|
|
height: scroller.scrollHeight - scrollGap(this) - this.display.barHeight,
|
|
width: scroller.scrollWidth - scrollGap(this) - this.display.barWidth,
|
|
clientHeight: displayHeight(this),
|
|
clientWidth: displayWidth(this)
|
|
};
|
|
},
|
|
scrollIntoView: methodOp(function(range$1, margin) {
|
|
if (range$1 == null) {
|
|
range$1 = {
|
|
from: this.doc.sel.primary().head,
|
|
to: null
|
|
};
|
|
if (margin == null) margin = this.options.cursorScrollMargin;
|
|
} else if (typeof range$1 == "number") range$1 = {
|
|
from: Pos(range$1, 0),
|
|
to: null
|
|
};
|
|
else if (range$1.from == null) range$1 = {
|
|
from: range$1,
|
|
to: null
|
|
};
|
|
if (!range$1.to) range$1.to = range$1.from;
|
|
range$1.margin = margin || 0;
|
|
if (range$1.from.line != null) scrollToRange(this, range$1);
|
|
else scrollToCoordsRange(this, range$1.from, range$1.to, range$1.margin);
|
|
}),
|
|
setSize: methodOp(function(width, height) {
|
|
var this$1 = this;
|
|
var interpret = function(val) {
|
|
return typeof val == "number" || /^\d+$/.test(String(val)) ? val + "px" : val;
|
|
};
|
|
if (width != null) this.display.wrapper.style.width = interpret(width);
|
|
if (height != null) this.display.wrapper.style.height = interpret(height);
|
|
if (this.options.lineWrapping) clearLineMeasurementCache(this);
|
|
var lineNo$1 = this.display.viewFrom;
|
|
this.doc.iter(lineNo$1, this.display.viewTo, function(line) {
|
|
if (line.widgets) {
|
|
for (var i$3 = 0; i$3 < line.widgets.length; i$3++) if (line.widgets[i$3].noHScroll) {
|
|
regLineChange(this$1, lineNo$1, "widget");
|
|
break;
|
|
}
|
|
}
|
|
++lineNo$1;
|
|
});
|
|
this.curOp.forceUpdate = true;
|
|
signal(this, "refresh", this);
|
|
}),
|
|
operation: function(f) {
|
|
return runInOp(this, f);
|
|
},
|
|
startOperation: function() {
|
|
return startOperation(this);
|
|
},
|
|
endOperation: function() {
|
|
return endOperation(this);
|
|
},
|
|
refresh: methodOp(function() {
|
|
var oldHeight = this.display.cachedTextHeight;
|
|
regChange(this);
|
|
this.curOp.forceUpdate = true;
|
|
clearCaches(this);
|
|
scrollToCoords(this, this.doc.scrollLeft, this.doc.scrollTop);
|
|
updateGutterSpace(this.display);
|
|
if (oldHeight == null || Math.abs(oldHeight - textHeight(this.display)) > .5 || this.options.lineWrapping) estimateLineHeights(this);
|
|
signal(this, "refresh", this);
|
|
}),
|
|
swapDoc: methodOp(function(doc$1) {
|
|
var old = this.doc;
|
|
old.cm = null;
|
|
if (this.state.selectingText) this.state.selectingText();
|
|
attachDoc(this, doc$1);
|
|
clearCaches(this);
|
|
this.display.input.reset();
|
|
scrollToCoords(this, doc$1.scrollLeft, doc$1.scrollTop);
|
|
this.curOp.forceScroll = true;
|
|
signalLater(this, "swapDoc", this, old);
|
|
return old;
|
|
}),
|
|
phrase: function(phraseText) {
|
|
var phrases = this.options.phrases;
|
|
return phrases && Object.prototype.hasOwnProperty.call(phrases, phraseText) ? phrases[phraseText] : phraseText;
|
|
},
|
|
getInputField: function() {
|
|
return this.display.input.getField();
|
|
},
|
|
getWrapperElement: function() {
|
|
return this.display.wrapper;
|
|
},
|
|
getScrollerElement: function() {
|
|
return this.display.scroller;
|
|
},
|
|
getGutterElement: function() {
|
|
return this.display.gutters;
|
|
}
|
|
};
|
|
eventMixin(CodeMirror$2);
|
|
CodeMirror$2.registerHelper = function(type, name, value) {
|
|
if (!helpers.hasOwnProperty(type)) helpers[type] = CodeMirror$2[type] = { _global: [] };
|
|
helpers[type][name] = value;
|
|
};
|
|
CodeMirror$2.registerGlobalHelper = function(type, name, predicate, value) {
|
|
CodeMirror$2.registerHelper(type, name, value);
|
|
helpers[type]._global.push({
|
|
pred: predicate,
|
|
val: value
|
|
});
|
|
};
|
|
}
|
|
function findPosH(doc$1, pos, dir, unit, visually) {
|
|
var oldPos = pos;
|
|
var origDir = dir;
|
|
var lineObj = getLine(doc$1, pos.line);
|
|
var lineDir = visually && doc$1.direction == "rtl" ? -dir : dir;
|
|
function findNextLine() {
|
|
var l = pos.line + lineDir;
|
|
if (l < doc$1.first || l >= doc$1.first + doc$1.size) return false;
|
|
pos = new Pos(l, pos.ch, pos.sticky);
|
|
return lineObj = getLine(doc$1, l);
|
|
}
|
|
function moveOnce(boundToLine) {
|
|
var next;
|
|
if (unit == "codepoint") {
|
|
var ch = lineObj.text.charCodeAt(pos.ch + (dir > 0 ? 0 : -1));
|
|
if (isNaN(ch)) next = null;
|
|
else {
|
|
var astral = dir > 0 ? ch >= 55296 && ch < 56320 : ch >= 56320 && ch < 57343;
|
|
next = new Pos(pos.line, Math.max(0, Math.min(lineObj.text.length, pos.ch + dir * (astral ? 2 : 1))), -dir);
|
|
}
|
|
} else if (visually) next = moveVisually(doc$1.cm, lineObj, pos, dir);
|
|
else next = moveLogically(lineObj, pos, dir);
|
|
if (next == null) if (!boundToLine && findNextLine()) pos = endOfLine(visually, doc$1.cm, lineObj, pos.line, lineDir);
|
|
else return false;
|
|
else pos = next;
|
|
return true;
|
|
}
|
|
if (unit == "char" || unit == "codepoint") moveOnce();
|
|
else if (unit == "column") moveOnce(true);
|
|
else if (unit == "word" || unit == "group") {
|
|
var sawType = null, group = unit == "group";
|
|
var helper = doc$1.cm && doc$1.cm.getHelper(pos, "wordChars");
|
|
for (var first = true;; first = false) {
|
|
if (dir < 0 && !moveOnce(!first)) break;
|
|
var cur = lineObj.text.charAt(pos.ch) || "\n";
|
|
var type = isWordChar(cur, helper) ? "w" : group && cur == "\n" ? "n" : !group || /\s/.test(cur) ? null : "p";
|
|
if (group && !first && !type) type = "s";
|
|
if (sawType && sawType != type) {
|
|
if (dir < 0) {
|
|
dir = 1;
|
|
moveOnce();
|
|
pos.sticky = "after";
|
|
}
|
|
break;
|
|
}
|
|
if (type) sawType = type;
|
|
if (dir > 0 && !moveOnce(!first)) break;
|
|
}
|
|
}
|
|
var result = skipAtomic(doc$1, pos, oldPos, origDir, true);
|
|
if (equalCursorPos(oldPos, result)) result.hitSide = true;
|
|
return result;
|
|
}
|
|
function findPosV(cm, pos, dir, unit) {
|
|
var doc$1 = cm.doc, x = pos.left, y;
|
|
if (unit == "page") {
|
|
var pageSize = Math.min(cm.display.wrapper.clientHeight, win(cm).innerHeight || doc$1(cm).documentElement.clientHeight);
|
|
var moveAmount = Math.max(pageSize - .5 * textHeight(cm.display), 3);
|
|
y = (dir > 0 ? pos.bottom : pos.top) + dir * moveAmount;
|
|
} else if (unit == "line") y = dir > 0 ? pos.bottom + 3 : pos.top - 3;
|
|
var target;
|
|
for (;;) {
|
|
target = coordsChar(cm, x, y);
|
|
if (!target.outside) break;
|
|
if (dir < 0 ? y <= 0 : y >= doc$1.height) {
|
|
target.hitSide = true;
|
|
break;
|
|
}
|
|
y += dir * 5;
|
|
}
|
|
return target;
|
|
}
|
|
var ContentEditableInput = function(cm) {
|
|
this.cm = cm;
|
|
this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null;
|
|
this.polling = new Delayed();
|
|
this.composing = null;
|
|
this.gracePeriod = false;
|
|
this.readDOMTimeout = null;
|
|
};
|
|
ContentEditableInput.prototype.init = function(display) {
|
|
var this$1 = this;
|
|
var input = this, cm = input.cm;
|
|
var div = input.div = display.lineDiv;
|
|
div.contentEditable = true;
|
|
disableBrowserMagic(div, cm.options.spellcheck, cm.options.autocorrect, cm.options.autocapitalize);
|
|
function belongsToInput(e) {
|
|
for (var t = e.target; t; t = t.parentNode) {
|
|
if (t == div) return true;
|
|
if (/\bCodeMirror-(?:line)?widget\b/.test(t.className)) break;
|
|
}
|
|
return false;
|
|
}
|
|
on(div, "paste", function(e) {
|
|
if (!belongsToInput(e) || signalDOMEvent(cm, e) || handlePaste(e, cm)) return;
|
|
if (ie_version <= 11) setTimeout(operation(cm, function() {
|
|
return this$1.updateFromDOM();
|
|
}), 20);
|
|
});
|
|
on(div, "compositionstart", function(e) {
|
|
this$1.composing = {
|
|
data: e.data,
|
|
done: false
|
|
};
|
|
});
|
|
on(div, "compositionupdate", function(e) {
|
|
if (!this$1.composing) this$1.composing = {
|
|
data: e.data,
|
|
done: false
|
|
};
|
|
});
|
|
on(div, "compositionend", function(e) {
|
|
if (this$1.composing) {
|
|
if (e.data != this$1.composing.data) this$1.readFromDOMSoon();
|
|
this$1.composing.done = true;
|
|
}
|
|
});
|
|
on(div, "touchstart", function() {
|
|
return input.forceCompositionEnd();
|
|
});
|
|
on(div, "input", function() {
|
|
if (!this$1.composing) this$1.readFromDOMSoon();
|
|
});
|
|
function onCopyCut(e) {
|
|
if (!belongsToInput(e) || signalDOMEvent(cm, e)) return;
|
|
if (cm.somethingSelected()) {
|
|
setLastCopied({
|
|
lineWise: false,
|
|
text: cm.getSelections()
|
|
});
|
|
if (e.type == "cut") cm.replaceSelection("", null, "cut");
|
|
} else if (!cm.options.lineWiseCopyCut) return;
|
|
else {
|
|
var ranges = copyableRanges(cm);
|
|
setLastCopied({
|
|
lineWise: true,
|
|
text: ranges.text
|
|
});
|
|
if (e.type == "cut") cm.operation(function() {
|
|
cm.setSelections(ranges.ranges, 0, sel_dontScroll);
|
|
cm.replaceSelection("", null, "cut");
|
|
});
|
|
}
|
|
if (e.clipboardData) {
|
|
e.clipboardData.clearData();
|
|
var content = lastCopied.text.join("\n");
|
|
e.clipboardData.setData("Text", content);
|
|
if (e.clipboardData.getData("Text") == content) {
|
|
e.preventDefault();
|
|
return;
|
|
}
|
|
}
|
|
var kludge = hiddenTextarea(), te = kludge.firstChild;
|
|
disableBrowserMagic(te);
|
|
cm.display.lineSpace.insertBefore(kludge, cm.display.lineSpace.firstChild);
|
|
te.value = lastCopied.text.join("\n");
|
|
var hadFocus = activeElt(rootNode(div));
|
|
selectInput(te);
|
|
setTimeout(function() {
|
|
cm.display.lineSpace.removeChild(kludge);
|
|
hadFocus.focus();
|
|
if (hadFocus == div) input.showPrimarySelection();
|
|
}, 50);
|
|
}
|
|
on(div, "copy", onCopyCut);
|
|
on(div, "cut", onCopyCut);
|
|
};
|
|
ContentEditableInput.prototype.screenReaderLabelChanged = function(label) {
|
|
if (label) this.div.setAttribute("aria-label", label);
|
|
else this.div.removeAttribute("aria-label");
|
|
};
|
|
ContentEditableInput.prototype.prepareSelection = function() {
|
|
var result = prepareSelection(this.cm, false);
|
|
result.focus = activeElt(rootNode(this.div)) == this.div;
|
|
return result;
|
|
};
|
|
ContentEditableInput.prototype.showSelection = function(info, takeFocus) {
|
|
if (!info || !this.cm.display.view.length) return;
|
|
if (info.focus || takeFocus) this.showPrimarySelection();
|
|
this.showMultipleSelections(info);
|
|
};
|
|
ContentEditableInput.prototype.getSelection = function() {
|
|
return this.cm.display.wrapper.ownerDocument.getSelection();
|
|
};
|
|
ContentEditableInput.prototype.showPrimarySelection = function() {
|
|
var sel = this.getSelection(), cm = this.cm, prim = cm.doc.sel.primary();
|
|
var from = prim.from(), to = prim.to();
|
|
if (cm.display.viewTo == cm.display.viewFrom || from.line >= cm.display.viewTo || to.line < cm.display.viewFrom) {
|
|
sel.removeAllRanges();
|
|
return;
|
|
}
|
|
var curAnchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);
|
|
var curFocus = domToPos(cm, sel.focusNode, sel.focusOffset);
|
|
if (curAnchor && !curAnchor.bad && curFocus && !curFocus.bad && cmp(minPos(curAnchor, curFocus), from) == 0 && cmp(maxPos(curAnchor, curFocus), to) == 0) return;
|
|
var view = cm.display.view;
|
|
var start = from.line >= cm.display.viewFrom && posToDOM(cm, from) || {
|
|
node: view[0].measure.map[2],
|
|
offset: 0
|
|
};
|
|
var end = to.line < cm.display.viewTo && posToDOM(cm, to);
|
|
if (!end) {
|
|
var measure = view[view.length - 1].measure;
|
|
var map$1 = measure.maps ? measure.maps[measure.maps.length - 1] : measure.map;
|
|
end = {
|
|
node: map$1[map$1.length - 1],
|
|
offset: map$1[map$1.length - 2] - map$1[map$1.length - 3]
|
|
};
|
|
}
|
|
if (!start || !end) {
|
|
sel.removeAllRanges();
|
|
return;
|
|
}
|
|
var old = sel.rangeCount && sel.getRangeAt(0), rng;
|
|
try {
|
|
rng = range(start.node, start.offset, end.offset, end.node);
|
|
} catch (e) {}
|
|
if (rng) {
|
|
if (!gecko && cm.state.focused) {
|
|
sel.collapse(start.node, start.offset);
|
|
if (!rng.collapsed) {
|
|
sel.removeAllRanges();
|
|
sel.addRange(rng);
|
|
}
|
|
} else {
|
|
sel.removeAllRanges();
|
|
sel.addRange(rng);
|
|
}
|
|
if (old && sel.anchorNode == null) sel.addRange(old);
|
|
else if (gecko) this.startGracePeriod();
|
|
}
|
|
this.rememberSelection();
|
|
};
|
|
ContentEditableInput.prototype.startGracePeriod = function() {
|
|
var this$1 = this;
|
|
clearTimeout(this.gracePeriod);
|
|
this.gracePeriod = setTimeout(function() {
|
|
this$1.gracePeriod = false;
|
|
if (this$1.selectionChanged()) this$1.cm.operation(function() {
|
|
return this$1.cm.curOp.selectionChanged = true;
|
|
});
|
|
}, 20);
|
|
};
|
|
ContentEditableInput.prototype.showMultipleSelections = function(info) {
|
|
removeChildrenAndAdd(this.cm.display.cursorDiv, info.cursors);
|
|
removeChildrenAndAdd(this.cm.display.selectionDiv, info.selection);
|
|
};
|
|
ContentEditableInput.prototype.rememberSelection = function() {
|
|
var sel = this.getSelection();
|
|
this.lastAnchorNode = sel.anchorNode;
|
|
this.lastAnchorOffset = sel.anchorOffset;
|
|
this.lastFocusNode = sel.focusNode;
|
|
this.lastFocusOffset = sel.focusOffset;
|
|
};
|
|
ContentEditableInput.prototype.selectionInEditor = function() {
|
|
var sel = this.getSelection();
|
|
if (!sel.rangeCount) return false;
|
|
var node = sel.getRangeAt(0).commonAncestorContainer;
|
|
return contains(this.div, node);
|
|
};
|
|
ContentEditableInput.prototype.focus = function() {
|
|
if (this.cm.options.readOnly != "nocursor") {
|
|
if (!this.selectionInEditor() || activeElt(rootNode(this.div)) != this.div) this.showSelection(this.prepareSelection(), true);
|
|
this.div.focus();
|
|
}
|
|
};
|
|
ContentEditableInput.prototype.blur = function() {
|
|
this.div.blur();
|
|
};
|
|
ContentEditableInput.prototype.getField = function() {
|
|
return this.div;
|
|
};
|
|
ContentEditableInput.prototype.supportsTouch = function() {
|
|
return true;
|
|
};
|
|
ContentEditableInput.prototype.receivedFocus = function() {
|
|
var this$1 = this;
|
|
var input = this;
|
|
if (this.selectionInEditor()) setTimeout(function() {
|
|
return this$1.pollSelection();
|
|
}, 20);
|
|
else runInOp(this.cm, function() {
|
|
return input.cm.curOp.selectionChanged = true;
|
|
});
|
|
function poll() {
|
|
if (input.cm.state.focused) {
|
|
input.pollSelection();
|
|
input.polling.set(input.cm.options.pollInterval, poll);
|
|
}
|
|
}
|
|
this.polling.set(this.cm.options.pollInterval, poll);
|
|
};
|
|
ContentEditableInput.prototype.selectionChanged = function() {
|
|
var sel = this.getSelection();
|
|
return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset || sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset;
|
|
};
|
|
ContentEditableInput.prototype.pollSelection = function() {
|
|
if (this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged()) return;
|
|
var sel = this.getSelection(), cm = this.cm;
|
|
if (android && chrome && this.cm.display.gutterSpecs.length && isInGutter(sel.anchorNode)) {
|
|
this.cm.triggerOnKeyDown({
|
|
type: "keydown",
|
|
keyCode: 8,
|
|
preventDefault: Math.abs
|
|
});
|
|
this.blur();
|
|
this.focus();
|
|
return;
|
|
}
|
|
if (this.composing) return;
|
|
this.rememberSelection();
|
|
var anchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);
|
|
var head = domToPos(cm, sel.focusNode, sel.focusOffset);
|
|
if (anchor && head) runInOp(cm, function() {
|
|
setSelection(cm.doc, simpleSelection(anchor, head), sel_dontScroll);
|
|
if (anchor.bad || head.bad) cm.curOp.selectionChanged = true;
|
|
});
|
|
};
|
|
ContentEditableInput.prototype.pollContent = function() {
|
|
if (this.readDOMTimeout != null) {
|
|
clearTimeout(this.readDOMTimeout);
|
|
this.readDOMTimeout = null;
|
|
}
|
|
var cm = this.cm, display = cm.display, sel = cm.doc.sel.primary();
|
|
var from = sel.from(), to = sel.to();
|
|
if (from.ch == 0 && from.line > cm.firstLine()) from = Pos(from.line - 1, getLine(cm.doc, from.line - 1).length);
|
|
if (to.ch == getLine(cm.doc, to.line).text.length && to.line < cm.lastLine()) to = Pos(to.line + 1, 0);
|
|
if (from.line < display.viewFrom || to.line > display.viewTo - 1) return false;
|
|
var fromIndex, fromLine, fromNode;
|
|
if (from.line == display.viewFrom || (fromIndex = findViewIndex(cm, from.line)) == 0) {
|
|
fromLine = lineNo(display.view[0].line);
|
|
fromNode = display.view[0].node;
|
|
} else {
|
|
fromLine = lineNo(display.view[fromIndex].line);
|
|
fromNode = display.view[fromIndex - 1].node.nextSibling;
|
|
}
|
|
var toIndex = findViewIndex(cm, to.line);
|
|
var toLine, toNode;
|
|
if (toIndex == display.view.length - 1) {
|
|
toLine = display.viewTo - 1;
|
|
toNode = display.lineDiv.lastChild;
|
|
} else {
|
|
toLine = lineNo(display.view[toIndex + 1].line) - 1;
|
|
toNode = display.view[toIndex + 1].node.previousSibling;
|
|
}
|
|
if (!fromNode) return false;
|
|
var newText = cm.doc.splitLines(domTextBetween(cm, fromNode, toNode, fromLine, toLine));
|
|
var oldText = getBetween(cm.doc, Pos(fromLine, 0), Pos(toLine, getLine(cm.doc, toLine).text.length));
|
|
while (newText.length > 1 && oldText.length > 1) if (lst(newText) == lst(oldText)) {
|
|
newText.pop();
|
|
oldText.pop();
|
|
toLine--;
|
|
} else if (newText[0] == oldText[0]) {
|
|
newText.shift();
|
|
oldText.shift();
|
|
fromLine++;
|
|
} else break;
|
|
var cutFront = 0, cutEnd = 0;
|
|
var newTop = newText[0], oldTop = oldText[0], maxCutFront = Math.min(newTop.length, oldTop.length);
|
|
while (cutFront < maxCutFront && newTop.charCodeAt(cutFront) == oldTop.charCodeAt(cutFront)) ++cutFront;
|
|
var newBot = lst(newText), oldBot = lst(oldText);
|
|
var maxCutEnd = Math.min(newBot.length - (newText.length == 1 ? cutFront : 0), oldBot.length - (oldText.length == 1 ? cutFront : 0));
|
|
while (cutEnd < maxCutEnd && newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) ++cutEnd;
|
|
if (newText.length == 1 && oldText.length == 1 && fromLine == from.line) while (cutFront && cutFront > from.ch && newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) {
|
|
cutFront--;
|
|
cutEnd++;
|
|
}
|
|
newText[newText.length - 1] = newBot.slice(0, newBot.length - cutEnd).replace(/^\u200b+/, "");
|
|
newText[0] = newText[0].slice(cutFront).replace(/\u200b+$/, "");
|
|
var chFrom = Pos(fromLine, cutFront);
|
|
var chTo = Pos(toLine, oldText.length ? lst(oldText).length - cutEnd : 0);
|
|
if (newText.length > 1 || newText[0] || cmp(chFrom, chTo)) {
|
|
replaceRange(cm.doc, newText, chFrom, chTo, "+input");
|
|
return true;
|
|
}
|
|
};
|
|
ContentEditableInput.prototype.ensurePolled = function() {
|
|
this.forceCompositionEnd();
|
|
};
|
|
ContentEditableInput.prototype.reset = function() {
|
|
this.forceCompositionEnd();
|
|
};
|
|
ContentEditableInput.prototype.forceCompositionEnd = function() {
|
|
if (!this.composing) return;
|
|
clearTimeout(this.readDOMTimeout);
|
|
this.composing = null;
|
|
this.updateFromDOM();
|
|
this.div.blur();
|
|
this.div.focus();
|
|
};
|
|
ContentEditableInput.prototype.readFromDOMSoon = function() {
|
|
var this$1 = this;
|
|
if (this.readDOMTimeout != null) return;
|
|
this.readDOMTimeout = setTimeout(function() {
|
|
this$1.readDOMTimeout = null;
|
|
if (this$1.composing) if (this$1.composing.done) this$1.composing = null;
|
|
else return;
|
|
this$1.updateFromDOM();
|
|
}, 80);
|
|
};
|
|
ContentEditableInput.prototype.updateFromDOM = function() {
|
|
var this$1 = this;
|
|
if (this.cm.isReadOnly() || !this.pollContent()) runInOp(this.cm, function() {
|
|
return regChange(this$1.cm);
|
|
});
|
|
};
|
|
ContentEditableInput.prototype.setUneditable = function(node) {
|
|
node.contentEditable = "false";
|
|
};
|
|
ContentEditableInput.prototype.onKeyPress = function(e) {
|
|
if (e.charCode == 0 || this.composing) return;
|
|
e.preventDefault();
|
|
if (!this.cm.isReadOnly()) operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0);
|
|
};
|
|
ContentEditableInput.prototype.readOnlyChanged = function(val) {
|
|
this.div.contentEditable = String(val != "nocursor");
|
|
};
|
|
ContentEditableInput.prototype.onContextMenu = function() {};
|
|
ContentEditableInput.prototype.resetPosition = function() {};
|
|
ContentEditableInput.prototype.needsContentAttribute = true;
|
|
function posToDOM(cm, pos) {
|
|
var view = findViewForLine(cm, pos.line);
|
|
if (!view || view.hidden) return null;
|
|
var line = getLine(cm.doc, pos.line);
|
|
var info = mapFromLineView(view, line, pos.line);
|
|
var order = getOrder(line, cm.doc.direction), side = "left";
|
|
if (order) {
|
|
var partPos = getBidiPartAt(order, pos.ch);
|
|
side = partPos % 2 ? "right" : "left";
|
|
}
|
|
var result = nodeAndOffsetInLineMap(info.map, pos.ch, side);
|
|
result.offset = result.collapse == "right" ? result.end : result.start;
|
|
return result;
|
|
}
|
|
function isInGutter(node) {
|
|
for (var scan = node; scan; scan = scan.parentNode) if (/CodeMirror-gutter-wrapper/.test(scan.className)) return true;
|
|
return false;
|
|
}
|
|
function badPos(pos, bad) {
|
|
if (bad) pos.bad = true;
|
|
return pos;
|
|
}
|
|
function domTextBetween(cm, from, to, fromLine, toLine) {
|
|
var text = "", closing = false, lineSep = cm.doc.lineSeparator(), extraLinebreak = false;
|
|
function recognizeMarker(id) {
|
|
return function(marker) {
|
|
return marker.id == id;
|
|
};
|
|
}
|
|
function close() {
|
|
if (closing) {
|
|
text += lineSep;
|
|
if (extraLinebreak) text += lineSep;
|
|
closing = extraLinebreak = false;
|
|
}
|
|
}
|
|
function addText(str) {
|
|
if (str) {
|
|
close();
|
|
text += str;
|
|
}
|
|
}
|
|
function walk(node) {
|
|
if (node.nodeType == 1) {
|
|
var cmText = node.getAttribute("cm-text");
|
|
if (cmText) {
|
|
addText(cmText);
|
|
return;
|
|
}
|
|
var markerID = node.getAttribute("cm-marker"), range$1;
|
|
if (markerID) {
|
|
var found = cm.findMarks(Pos(fromLine, 0), Pos(toLine + 1, 0), recognizeMarker(+markerID));
|
|
if (found.length && (range$1 = found[0].find(0))) addText(getBetween(cm.doc, range$1.from, range$1.to).join(lineSep));
|
|
return;
|
|
}
|
|
if (node.getAttribute("contenteditable") == "false") return;
|
|
var isBlock = /^(pre|div|p|li|table|br)$/i.test(node.nodeName);
|
|
if (!/^br$/i.test(node.nodeName) && node.textContent.length == 0) return;
|
|
if (isBlock) close();
|
|
for (var i$3 = 0; i$3 < node.childNodes.length; i$3++) walk(node.childNodes[i$3]);
|
|
if (/^(pre|p)$/i.test(node.nodeName)) extraLinebreak = true;
|
|
if (isBlock) closing = true;
|
|
} else if (node.nodeType == 3) addText(node.nodeValue.replace(/\u200b/g, "").replace(/\u00a0/g, " "));
|
|
}
|
|
for (;;) {
|
|
walk(from);
|
|
if (from == to) break;
|
|
from = from.nextSibling;
|
|
extraLinebreak = false;
|
|
}
|
|
return text;
|
|
}
|
|
function domToPos(cm, node, offset) {
|
|
var lineNode;
|
|
if (node == cm.display.lineDiv) {
|
|
lineNode = cm.display.lineDiv.childNodes[offset];
|
|
if (!lineNode) return badPos(cm.clipPos(Pos(cm.display.viewTo - 1)), true);
|
|
node = null;
|
|
offset = 0;
|
|
} else for (lineNode = node;; lineNode = lineNode.parentNode) {
|
|
if (!lineNode || lineNode == cm.display.lineDiv) return null;
|
|
if (lineNode.parentNode && lineNode.parentNode == cm.display.lineDiv) break;
|
|
}
|
|
for (var i$3 = 0; i$3 < cm.display.view.length; i$3++) {
|
|
var lineView = cm.display.view[i$3];
|
|
if (lineView.node == lineNode) return locateNodeInLineView(lineView, node, offset);
|
|
}
|
|
}
|
|
function locateNodeInLineView(lineView, node, offset) {
|
|
var wrapper = lineView.text.firstChild, bad = false;
|
|
if (!node || !contains(wrapper, node)) return badPos(Pos(lineNo(lineView.line), 0), true);
|
|
if (node == wrapper) {
|
|
bad = true;
|
|
node = wrapper.childNodes[offset];
|
|
offset = 0;
|
|
if (!node) {
|
|
var line = lineView.rest ? lst(lineView.rest) : lineView.line;
|
|
return badPos(Pos(lineNo(line), line.text.length), bad);
|
|
}
|
|
}
|
|
var textNode = node.nodeType == 3 ? node : null, topNode = node;
|
|
if (!textNode && node.childNodes.length == 1 && node.firstChild.nodeType == 3) {
|
|
textNode = node.firstChild;
|
|
if (offset) offset = textNode.nodeValue.length;
|
|
}
|
|
while (topNode.parentNode != wrapper) topNode = topNode.parentNode;
|
|
var measure = lineView.measure, maps = measure.maps;
|
|
function find(textNode$1, topNode$1, offset$1) {
|
|
for (var i$3 = -1; i$3 < (maps ? maps.length : 0); i$3++) {
|
|
var map$1 = i$3 < 0 ? measure.map : maps[i$3];
|
|
for (var j = 0; j < map$1.length; j += 3) {
|
|
var curNode = map$1[j + 2];
|
|
if (curNode == textNode$1 || curNode == topNode$1) {
|
|
var line$1 = lineNo(i$3 < 0 ? lineView.line : lineView.rest[i$3]);
|
|
var ch = map$1[j] + offset$1;
|
|
if (offset$1 < 0 || curNode != textNode$1) ch = map$1[j + (offset$1 ? 1 : 0)];
|
|
return Pos(line$1, ch);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
var found = find(textNode, topNode, offset);
|
|
if (found) return badPos(found, bad);
|
|
for (var after = topNode.nextSibling, dist = textNode ? textNode.nodeValue.length - offset : 0; after; after = after.nextSibling) {
|
|
found = find(after, after.firstChild, 0);
|
|
if (found) return badPos(Pos(found.line, found.ch - dist), bad);
|
|
else dist += after.textContent.length;
|
|
}
|
|
for (var before = topNode.previousSibling, dist$1 = offset; before; before = before.previousSibling) {
|
|
found = find(before, before.firstChild, -1);
|
|
if (found) return badPos(Pos(found.line, found.ch + dist$1), bad);
|
|
else dist$1 += before.textContent.length;
|
|
}
|
|
}
|
|
var TextareaInput = function(cm) {
|
|
this.cm = cm;
|
|
this.prevInput = "";
|
|
this.pollingFast = false;
|
|
this.polling = new Delayed();
|
|
this.hasSelection = false;
|
|
this.composing = null;
|
|
this.resetting = false;
|
|
};
|
|
TextareaInput.prototype.init = function(display) {
|
|
var this$1 = this;
|
|
var input = this, cm = this.cm;
|
|
this.createField(display);
|
|
var te = this.textarea;
|
|
display.wrapper.insertBefore(this.wrapper, display.wrapper.firstChild);
|
|
if (ios) te.style.width = "0px";
|
|
on(te, "input", function() {
|
|
if (ie && ie_version >= 9 && this$1.hasSelection) this$1.hasSelection = null;
|
|
input.poll();
|
|
});
|
|
on(te, "paste", function(e) {
|
|
if (signalDOMEvent(cm, e) || handlePaste(e, cm)) return;
|
|
cm.state.pasteIncoming = +new Date();
|
|
input.fastPoll();
|
|
});
|
|
function prepareCopyCut(e) {
|
|
if (signalDOMEvent(cm, e)) return;
|
|
if (cm.somethingSelected()) setLastCopied({
|
|
lineWise: false,
|
|
text: cm.getSelections()
|
|
});
|
|
else if (!cm.options.lineWiseCopyCut) return;
|
|
else {
|
|
var ranges = copyableRanges(cm);
|
|
setLastCopied({
|
|
lineWise: true,
|
|
text: ranges.text
|
|
});
|
|
if (e.type == "cut") cm.setSelections(ranges.ranges, null, sel_dontScroll);
|
|
else {
|
|
input.prevInput = "";
|
|
te.value = ranges.text.join("\n");
|
|
selectInput(te);
|
|
}
|
|
}
|
|
if (e.type == "cut") cm.state.cutIncoming = +new Date();
|
|
}
|
|
on(te, "cut", prepareCopyCut);
|
|
on(te, "copy", prepareCopyCut);
|
|
on(display.scroller, "paste", function(e) {
|
|
if (eventInWidget(display, e) || signalDOMEvent(cm, e)) return;
|
|
if (!te.dispatchEvent) {
|
|
cm.state.pasteIncoming = +new Date();
|
|
input.focus();
|
|
return;
|
|
}
|
|
var event = new Event("paste");
|
|
event.clipboardData = e.clipboardData;
|
|
te.dispatchEvent(event);
|
|
});
|
|
on(display.lineSpace, "selectstart", function(e) {
|
|
if (!eventInWidget(display, e)) e_preventDefault(e);
|
|
});
|
|
on(te, "compositionstart", function() {
|
|
var start = cm.getCursor("from");
|
|
if (input.composing) input.composing.range.clear();
|
|
input.composing = {
|
|
start,
|
|
range: cm.markText(start, cm.getCursor("to"), { className: "CodeMirror-composing" })
|
|
};
|
|
});
|
|
on(te, "compositionend", function() {
|
|
if (input.composing) {
|
|
input.poll();
|
|
input.composing.range.clear();
|
|
input.composing = null;
|
|
}
|
|
});
|
|
};
|
|
TextareaInput.prototype.createField = function(_display) {
|
|
this.wrapper = hiddenTextarea();
|
|
this.textarea = this.wrapper.firstChild;
|
|
var opts = this.cm.options;
|
|
disableBrowserMagic(this.textarea, opts.spellcheck, opts.autocorrect, opts.autocapitalize);
|
|
};
|
|
TextareaInput.prototype.screenReaderLabelChanged = function(label) {
|
|
if (label) this.textarea.setAttribute("aria-label", label);
|
|
else this.textarea.removeAttribute("aria-label");
|
|
};
|
|
TextareaInput.prototype.prepareSelection = function() {
|
|
var cm = this.cm, display = cm.display, doc$1 = cm.doc;
|
|
var result = prepareSelection(cm);
|
|
if (cm.options.moveInputWithCursor) {
|
|
var headPos = cursorCoords(cm, doc$1.sel.primary().head, "div");
|
|
var wrapOff = display.wrapper.getBoundingClientRect(), lineOff = display.lineDiv.getBoundingClientRect();
|
|
result.teTop = Math.max(0, Math.min(display.wrapper.clientHeight - 10, headPos.top + lineOff.top - wrapOff.top));
|
|
result.teLeft = Math.max(0, Math.min(display.wrapper.clientWidth - 10, headPos.left + lineOff.left - wrapOff.left));
|
|
}
|
|
return result;
|
|
};
|
|
TextareaInput.prototype.showSelection = function(drawn) {
|
|
var cm = this.cm, display = cm.display;
|
|
removeChildrenAndAdd(display.cursorDiv, drawn.cursors);
|
|
removeChildrenAndAdd(display.selectionDiv, drawn.selection);
|
|
if (drawn.teTop != null) {
|
|
this.wrapper.style.top = drawn.teTop + "px";
|
|
this.wrapper.style.left = drawn.teLeft + "px";
|
|
}
|
|
};
|
|
TextareaInput.prototype.reset = function(typing) {
|
|
if (this.contextMenuPending || this.composing && typing) return;
|
|
var cm = this.cm;
|
|
this.resetting = true;
|
|
if (cm.somethingSelected()) {
|
|
this.prevInput = "";
|
|
var content = cm.getSelection();
|
|
this.textarea.value = content;
|
|
if (cm.state.focused) selectInput(this.textarea);
|
|
if (ie && ie_version >= 9) this.hasSelection = content;
|
|
} else if (!typing) {
|
|
this.prevInput = this.textarea.value = "";
|
|
if (ie && ie_version >= 9) this.hasSelection = null;
|
|
}
|
|
this.resetting = false;
|
|
};
|
|
TextareaInput.prototype.getField = function() {
|
|
return this.textarea;
|
|
};
|
|
TextareaInput.prototype.supportsTouch = function() {
|
|
return false;
|
|
};
|
|
TextareaInput.prototype.focus = function() {
|
|
if (this.cm.options.readOnly != "nocursor" && (!mobile || activeElt(rootNode(this.textarea)) != this.textarea)) try {
|
|
this.textarea.focus();
|
|
} catch (e) {}
|
|
};
|
|
TextareaInput.prototype.blur = function() {
|
|
this.textarea.blur();
|
|
};
|
|
TextareaInput.prototype.resetPosition = function() {
|
|
this.wrapper.style.top = this.wrapper.style.left = 0;
|
|
};
|
|
TextareaInput.prototype.receivedFocus = function() {
|
|
this.slowPoll();
|
|
};
|
|
TextareaInput.prototype.slowPoll = function() {
|
|
var this$1 = this;
|
|
if (this.pollingFast) return;
|
|
this.polling.set(this.cm.options.pollInterval, function() {
|
|
this$1.poll();
|
|
if (this$1.cm.state.focused) this$1.slowPoll();
|
|
});
|
|
};
|
|
TextareaInput.prototype.fastPoll = function() {
|
|
var missed = false, input = this;
|
|
input.pollingFast = true;
|
|
function p() {
|
|
var changed = input.poll();
|
|
if (!changed && !missed) {
|
|
missed = true;
|
|
input.polling.set(60, p);
|
|
} else {
|
|
input.pollingFast = false;
|
|
input.slowPoll();
|
|
}
|
|
}
|
|
input.polling.set(20, p);
|
|
};
|
|
TextareaInput.prototype.poll = function() {
|
|
var this$1 = this;
|
|
var cm = this.cm, input = this.textarea, prevInput = this.prevInput;
|
|
if (this.contextMenuPending || this.resetting || !cm.state.focused || hasSelection(input) && !prevInput && !this.composing || cm.isReadOnly() || cm.options.disableInput || cm.state.keySeq) return false;
|
|
var text = input.value;
|
|
if (text == prevInput && !cm.somethingSelected()) return false;
|
|
if (ie && ie_version >= 9 && this.hasSelection === text || mac && /[\uf700-\uf7ff]/.test(text)) {
|
|
cm.display.input.reset();
|
|
return false;
|
|
}
|
|
if (cm.doc.sel == cm.display.selForContextMenu) {
|
|
var first = text.charCodeAt(0);
|
|
if (first == 8203 && !prevInput) prevInput = "";
|
|
if (first == 8666) {
|
|
this.reset();
|
|
return this.cm.execCommand("undo");
|
|
}
|
|
}
|
|
var same = 0, l = Math.min(prevInput.length, text.length);
|
|
while (same < l && prevInput.charCodeAt(same) == text.charCodeAt(same)) ++same;
|
|
runInOp(cm, function() {
|
|
applyTextInput(cm, text.slice(same), prevInput.length - same, null, this$1.composing ? "*compose" : null);
|
|
if (text.length > 1e3 || text.indexOf("\n") > -1) input.value = this$1.prevInput = "";
|
|
else this$1.prevInput = text;
|
|
if (this$1.composing) {
|
|
this$1.composing.range.clear();
|
|
this$1.composing.range = cm.markText(this$1.composing.start, cm.getCursor("to"), { className: "CodeMirror-composing" });
|
|
}
|
|
});
|
|
return true;
|
|
};
|
|
TextareaInput.prototype.ensurePolled = function() {
|
|
if (this.pollingFast && this.poll()) this.pollingFast = false;
|
|
};
|
|
TextareaInput.prototype.onKeyPress = function() {
|
|
if (ie && ie_version >= 9) this.hasSelection = null;
|
|
this.fastPoll();
|
|
};
|
|
TextareaInput.prototype.onContextMenu = function(e) {
|
|
var input = this, cm = input.cm, display = cm.display, te = input.textarea;
|
|
if (input.contextMenuPending) input.contextMenuPending();
|
|
var pos = posFromMouse(cm, e), scrollPos = display.scroller.scrollTop;
|
|
if (!pos || presto) return;
|
|
var reset = cm.options.resetSelectionOnContextMenu;
|
|
if (reset && cm.doc.sel.contains(pos) == -1) operation(cm, setSelection)(cm.doc, simpleSelection(pos), sel_dontScroll);
|
|
var oldCSS = te.style.cssText, oldWrapperCSS = input.wrapper.style.cssText;
|
|
var wrapperBox = input.wrapper.offsetParent.getBoundingClientRect();
|
|
input.wrapper.style.cssText = "position: static";
|
|
te.style.cssText = "position: absolute; width: 30px; height: 30px;\n top: " + (e.clientY - wrapperBox.top - 5) + "px; left: " + (e.clientX - wrapperBox.left - 5) + "px;\n z-index: 1000; background: " + (ie ? "rgba(255, 255, 255, .05)" : "transparent") + ";\n outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);";
|
|
var oldScrollY;
|
|
if (webkit) oldScrollY = te.ownerDocument.defaultView.scrollY;
|
|
display.input.focus();
|
|
if (webkit) te.ownerDocument.defaultView.scrollTo(null, oldScrollY);
|
|
display.input.reset();
|
|
if (!cm.somethingSelected()) te.value = input.prevInput = " ";
|
|
input.contextMenuPending = rehide;
|
|
display.selForContextMenu = cm.doc.sel;
|
|
clearTimeout(display.detectingSelectAll);
|
|
function prepareSelectAllHack() {
|
|
if (te.selectionStart != null) {
|
|
var selected = cm.somethingSelected();
|
|
var extval = "" + (selected ? te.value : "");
|
|
te.value = "⇚";
|
|
te.value = extval;
|
|
input.prevInput = selected ? "" : "";
|
|
te.selectionStart = 1;
|
|
te.selectionEnd = extval.length;
|
|
display.selForContextMenu = cm.doc.sel;
|
|
}
|
|
}
|
|
function rehide() {
|
|
if (input.contextMenuPending != rehide) return;
|
|
input.contextMenuPending = false;
|
|
input.wrapper.style.cssText = oldWrapperCSS;
|
|
te.style.cssText = oldCSS;
|
|
if (ie && ie_version < 9) display.scrollbars.setScrollTop(display.scroller.scrollTop = scrollPos);
|
|
if (te.selectionStart != null) {
|
|
if (!ie || ie && ie_version < 9) prepareSelectAllHack();
|
|
var i$3 = 0, poll = function() {
|
|
if (display.selForContextMenu == cm.doc.sel && te.selectionStart == 0 && te.selectionEnd > 0 && input.prevInput == "") operation(cm, selectAll)(cm);
|
|
else if (i$3++ < 10) display.detectingSelectAll = setTimeout(poll, 500);
|
|
else {
|
|
display.selForContextMenu = null;
|
|
display.input.reset();
|
|
}
|
|
};
|
|
display.detectingSelectAll = setTimeout(poll, 200);
|
|
}
|
|
}
|
|
if (ie && ie_version >= 9) prepareSelectAllHack();
|
|
if (captureRightClick) {
|
|
e_stop(e);
|
|
var mouseup = function() {
|
|
off(window, "mouseup", mouseup);
|
|
setTimeout(rehide, 20);
|
|
};
|
|
on(window, "mouseup", mouseup);
|
|
} else setTimeout(rehide, 50);
|
|
};
|
|
TextareaInput.prototype.readOnlyChanged = function(val) {
|
|
if (!val) this.reset();
|
|
this.textarea.disabled = val == "nocursor";
|
|
this.textarea.readOnly = !!val;
|
|
};
|
|
TextareaInput.prototype.setUneditable = function() {};
|
|
TextareaInput.prototype.needsContentAttribute = false;
|
|
function fromTextArea(textarea, options) {
|
|
options = options ? copyObj(options) : {};
|
|
options.value = textarea.value;
|
|
if (!options.tabindex && textarea.tabIndex) options.tabindex = textarea.tabIndex;
|
|
if (!options.placeholder && textarea.placeholder) options.placeholder = textarea.placeholder;
|
|
if (options.autofocus == null) {
|
|
var hasFocus = activeElt(rootNode(textarea));
|
|
options.autofocus = hasFocus == textarea || textarea.getAttribute("autofocus") != null && hasFocus == document.body;
|
|
}
|
|
function save() {
|
|
textarea.value = cm.getValue();
|
|
}
|
|
var realSubmit;
|
|
if (textarea.form) {
|
|
on(textarea.form, "submit", save);
|
|
if (!options.leaveSubmitMethodAlone) {
|
|
var form = textarea.form;
|
|
realSubmit = form.submit;
|
|
try {
|
|
var wrappedSubmit = form.submit = function() {
|
|
save();
|
|
form.submit = realSubmit;
|
|
form.submit();
|
|
form.submit = wrappedSubmit;
|
|
};
|
|
} catch (e) {}
|
|
}
|
|
}
|
|
options.finishInit = function(cm$1) {
|
|
cm$1.save = save;
|
|
cm$1.getTextArea = function() {
|
|
return textarea;
|
|
};
|
|
cm$1.toTextArea = function() {
|
|
cm$1.toTextArea = isNaN;
|
|
save();
|
|
textarea.parentNode.removeChild(cm$1.getWrapperElement());
|
|
textarea.style.display = "";
|
|
if (textarea.form) {
|
|
off(textarea.form, "submit", save);
|
|
if (!options.leaveSubmitMethodAlone && typeof textarea.form.submit == "function") textarea.form.submit = realSubmit;
|
|
}
|
|
};
|
|
};
|
|
textarea.style.display = "none";
|
|
var cm = CodeMirror$1(function(node) {
|
|
return textarea.parentNode.insertBefore(node, textarea.nextSibling);
|
|
}, options);
|
|
return cm;
|
|
}
|
|
function addLegacyProps(CodeMirror$2) {
|
|
CodeMirror$2.off = off;
|
|
CodeMirror$2.on = on;
|
|
CodeMirror$2.wheelEventPixels = wheelEventPixels;
|
|
CodeMirror$2.Doc = Doc;
|
|
CodeMirror$2.splitLines = splitLinesAuto;
|
|
CodeMirror$2.countColumn = countColumn;
|
|
CodeMirror$2.findColumn = findColumn;
|
|
CodeMirror$2.isWordChar = isWordCharBasic;
|
|
CodeMirror$2.Pass = Pass;
|
|
CodeMirror$2.signal = signal;
|
|
CodeMirror$2.Line = Line;
|
|
CodeMirror$2.changeEnd = changeEnd;
|
|
CodeMirror$2.scrollbarModel = scrollbarModel;
|
|
CodeMirror$2.Pos = Pos;
|
|
CodeMirror$2.cmpPos = cmp;
|
|
CodeMirror$2.modes = modes;
|
|
CodeMirror$2.mimeModes = mimeModes;
|
|
CodeMirror$2.resolveMode = resolveMode;
|
|
CodeMirror$2.getMode = getMode;
|
|
CodeMirror$2.modeExtensions = modeExtensions;
|
|
CodeMirror$2.extendMode = extendMode;
|
|
CodeMirror$2.copyState = copyState;
|
|
CodeMirror$2.startState = startState;
|
|
CodeMirror$2.innerMode = innerMode;
|
|
CodeMirror$2.commands = commands;
|
|
CodeMirror$2.keyMap = keyMap;
|
|
CodeMirror$2.keyName = keyName;
|
|
CodeMirror$2.isModifierKey = isModifierKey;
|
|
CodeMirror$2.lookupKey = lookupKey;
|
|
CodeMirror$2.normalizeKeyMap = normalizeKeyMap;
|
|
CodeMirror$2.StringStream = StringStream;
|
|
CodeMirror$2.SharedTextMarker = SharedTextMarker;
|
|
CodeMirror$2.TextMarker = TextMarker;
|
|
CodeMirror$2.LineWidget = LineWidget;
|
|
CodeMirror$2.e_preventDefault = e_preventDefault;
|
|
CodeMirror$2.e_stopPropagation = e_stopPropagation;
|
|
CodeMirror$2.e_stop = e_stop;
|
|
CodeMirror$2.addClass = addClass;
|
|
CodeMirror$2.contains = contains;
|
|
CodeMirror$2.rmClass = rmClass;
|
|
CodeMirror$2.keyNames = keyNames;
|
|
}
|
|
defineOptions(CodeMirror$1);
|
|
addEditorMethods(CodeMirror$1);
|
|
var dontDelegate = "iter insert remove copy getEditor constructor".split(" ");
|
|
for (var prop in Doc.prototype) if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0) CodeMirror$1.prototype[prop] = function(method) {
|
|
return function() {
|
|
return method.apply(this.doc, arguments);
|
|
};
|
|
}(Doc.prototype[prop]);
|
|
eventMixin(Doc);
|
|
CodeMirror$1.inputStyles = {
|
|
"textarea": TextareaInput,
|
|
"contenteditable": ContentEditableInput
|
|
};
|
|
CodeMirror$1.defineMode = function(name) {
|
|
if (!CodeMirror$1.defaults.mode && name != "null") CodeMirror$1.defaults.mode = name;
|
|
defineMode.apply(this, arguments);
|
|
};
|
|
CodeMirror$1.defineMIME = defineMIME;
|
|
CodeMirror$1.defineMode("null", function() {
|
|
return { token: function(stream) {
|
|
return stream.skipToEnd();
|
|
} };
|
|
});
|
|
CodeMirror$1.defineMIME("text/plain", "null");
|
|
CodeMirror$1.defineExtension = function(name, func) {
|
|
CodeMirror$1.prototype[name] = func;
|
|
};
|
|
CodeMirror$1.defineDocExtension = function(name, func) {
|
|
Doc.prototype[name] = func;
|
|
};
|
|
CodeMirror$1.fromTextArea = fromTextArea;
|
|
addLegacyProps(CodeMirror$1);
|
|
CodeMirror$1.version = "5.65.18";
|
|
return CodeMirror$1;
|
|
});
|
|
});
|
|
var import_codemirror = __toESM(require_codemirror());
|
|
var require_dialog = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
function dialogDiv(cm, template, bottom) {
|
|
var wrap$1 = cm.getWrapperElement();
|
|
var dialog;
|
|
dialog = wrap$1.appendChild(document.createElement("div"));
|
|
if (bottom) dialog.className = "CodeMirror-dialog CodeMirror-dialog-bottom";
|
|
else dialog.className = "CodeMirror-dialog CodeMirror-dialog-top";
|
|
if (typeof template == "string") dialog.innerHTML = template;
|
|
else dialog.appendChild(template);
|
|
CodeMirror$1.addClass(wrap$1, "dialog-opened");
|
|
return dialog;
|
|
}
|
|
function closeNotification(cm, newVal) {
|
|
if (cm.state.currentNotificationClose) cm.state.currentNotificationClose();
|
|
cm.state.currentNotificationClose = newVal;
|
|
}
|
|
CodeMirror$1.defineExtension("openDialog", function(template, callback, options) {
|
|
if (!options) options = {};
|
|
closeNotification(this, null);
|
|
var dialog = dialogDiv(this, template, options.bottom);
|
|
var closed = false, me = this;
|
|
function close(newVal) {
|
|
if (typeof newVal == "string") inp.value = newVal;
|
|
else {
|
|
if (closed) return;
|
|
closed = true;
|
|
CodeMirror$1.rmClass(dialog.parentNode, "dialog-opened");
|
|
dialog.parentNode.removeChild(dialog);
|
|
me.focus();
|
|
if (options.onClose) options.onClose(dialog);
|
|
}
|
|
}
|
|
var inp = dialog.getElementsByTagName("input")[0], button;
|
|
if (inp) {
|
|
inp.focus();
|
|
if (options.value) {
|
|
inp.value = options.value;
|
|
if (options.selectValueOnOpen !== false) inp.select();
|
|
}
|
|
if (options.onInput) CodeMirror$1.on(inp, "input", function(e) {
|
|
options.onInput(e, inp.value, close);
|
|
});
|
|
if (options.onKeyUp) CodeMirror$1.on(inp, "keyup", function(e) {
|
|
options.onKeyUp(e, inp.value, close);
|
|
});
|
|
CodeMirror$1.on(inp, "keydown", function(e) {
|
|
if (options && options.onKeyDown && options.onKeyDown(e, inp.value, close)) return;
|
|
if (e.keyCode == 27 || options.closeOnEnter !== false && e.keyCode == 13) {
|
|
inp.blur();
|
|
CodeMirror$1.e_stop(e);
|
|
close();
|
|
}
|
|
if (e.keyCode == 13) callback(inp.value, e);
|
|
});
|
|
if (options.closeOnBlur !== false) CodeMirror$1.on(dialog, "focusout", function(evt) {
|
|
if (evt.relatedTarget !== null) close();
|
|
});
|
|
} else if (button = dialog.getElementsByTagName("button")[0]) {
|
|
CodeMirror$1.on(button, "click", function() {
|
|
close();
|
|
me.focus();
|
|
});
|
|
if (options.closeOnBlur !== false) CodeMirror$1.on(button, "blur", close);
|
|
button.focus();
|
|
}
|
|
return close;
|
|
});
|
|
CodeMirror$1.defineExtension("openConfirm", function(template, callbacks, options) {
|
|
closeNotification(this, null);
|
|
var dialog = dialogDiv(this, template, options && options.bottom);
|
|
var buttons = dialog.getElementsByTagName("button");
|
|
var closed = false, me = this, blurring = 1;
|
|
function close() {
|
|
if (closed) return;
|
|
closed = true;
|
|
CodeMirror$1.rmClass(dialog.parentNode, "dialog-opened");
|
|
dialog.parentNode.removeChild(dialog);
|
|
me.focus();
|
|
}
|
|
buttons[0].focus();
|
|
for (var i = 0; i < buttons.length; ++i) {
|
|
var b = buttons[i];
|
|
(function(callback) {
|
|
CodeMirror$1.on(b, "click", function(e) {
|
|
CodeMirror$1.e_preventDefault(e);
|
|
close();
|
|
if (callback) callback(me);
|
|
});
|
|
})(callbacks[i]);
|
|
CodeMirror$1.on(b, "blur", function() {
|
|
--blurring;
|
|
setTimeout(function() {
|
|
if (blurring <= 0) close();
|
|
}, 200);
|
|
});
|
|
CodeMirror$1.on(b, "focus", function() {
|
|
++blurring;
|
|
});
|
|
}
|
|
});
|
|
CodeMirror$1.defineExtension("openNotification", function(template, options) {
|
|
closeNotification(this, close);
|
|
var dialog = dialogDiv(this, template, options && options.bottom);
|
|
var closed = false, doneTimer;
|
|
var duration = options && typeof options.duration !== "undefined" ? options.duration : 5e3;
|
|
function close() {
|
|
if (closed) return;
|
|
closed = true;
|
|
clearTimeout(doneTimer);
|
|
CodeMirror$1.rmClass(dialog.parentNode, "dialog-opened");
|
|
dialog.parentNode.removeChild(dialog);
|
|
}
|
|
CodeMirror$1.on(dialog, "click", function(e) {
|
|
CodeMirror$1.e_preventDefault(e);
|
|
close();
|
|
});
|
|
if (duration) doneTimer = setTimeout(close, duration);
|
|
return close;
|
|
});
|
|
});
|
|
});
|
|
var require_placeholder = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
CodeMirror$1.defineOption("placeholder", "", function(cm, val, old) {
|
|
var prev = old && old != CodeMirror$1.Init;
|
|
if (val && !prev) {
|
|
cm.on("blur", onBlur);
|
|
cm.on("change", onChange);
|
|
cm.on("swapDoc", onChange);
|
|
CodeMirror$1.on(cm.getInputField(), "compositionupdate", cm.state.placeholderCompose = function() {
|
|
onComposition(cm);
|
|
});
|
|
onChange(cm);
|
|
} else if (!val && prev) {
|
|
cm.off("blur", onBlur);
|
|
cm.off("change", onChange);
|
|
cm.off("swapDoc", onChange);
|
|
CodeMirror$1.off(cm.getInputField(), "compositionupdate", cm.state.placeholderCompose);
|
|
clearPlaceholder(cm);
|
|
var wrapper = cm.getWrapperElement();
|
|
wrapper.className = wrapper.className.replace(" CodeMirror-empty", "");
|
|
}
|
|
if (val && !cm.hasFocus()) onBlur(cm);
|
|
});
|
|
function clearPlaceholder(cm) {
|
|
if (cm.state.placeholder) {
|
|
cm.state.placeholder.parentNode.removeChild(cm.state.placeholder);
|
|
cm.state.placeholder = null;
|
|
}
|
|
}
|
|
function setPlaceholder(cm) {
|
|
clearPlaceholder(cm);
|
|
var elt = cm.state.placeholder = document.createElement("pre");
|
|
elt.style.cssText = "height: 0; overflow: visible";
|
|
elt.style.direction = cm.getOption("direction");
|
|
elt.className = "CodeMirror-placeholder CodeMirror-line-like";
|
|
var placeHolder = cm.getOption("placeholder");
|
|
if (typeof placeHolder == "string") placeHolder = document.createTextNode(placeHolder);
|
|
elt.appendChild(placeHolder);
|
|
cm.display.lineSpace.insertBefore(elt, cm.display.lineSpace.firstChild);
|
|
}
|
|
function onComposition(cm) {
|
|
setTimeout(function() {
|
|
var empty = false;
|
|
if (cm.lineCount() == 1) {
|
|
var input = cm.getInputField();
|
|
empty = input.nodeName == "TEXTAREA" ? !cm.getLine(0).length : !/[^\u200b]/.test(input.querySelector(".CodeMirror-line").textContent);
|
|
}
|
|
if (empty) setPlaceholder(cm);
|
|
else clearPlaceholder(cm);
|
|
}, 20);
|
|
}
|
|
function onBlur(cm) {
|
|
if (isEmpty(cm)) setPlaceholder(cm);
|
|
}
|
|
function onChange(cm) {
|
|
var wrapper = cm.getWrapperElement(), empty = isEmpty(cm);
|
|
wrapper.className = wrapper.className.replace(" CodeMirror-empty", "") + (empty ? " CodeMirror-empty" : "");
|
|
if (empty) setPlaceholder(cm);
|
|
else clearPlaceholder(cm);
|
|
}
|
|
function isEmpty(cm) {
|
|
return cm.lineCount() === 1 && cm.getLine(0) === "";
|
|
}
|
|
});
|
|
});
|
|
var require_jump_to_line = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror(), require_dialog());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror", "../dialog/dialog"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineOption("search", { bottom: false });
|
|
function dialog(cm, text, shortText, deflt, f) {
|
|
if (cm.openDialog) cm.openDialog(text, f, {
|
|
value: deflt,
|
|
selectValueOnOpen: true,
|
|
bottom: cm.options.search.bottom
|
|
});
|
|
else f(prompt(shortText, deflt));
|
|
}
|
|
function getJumpDialog(cm) {
|
|
return cm.phrase("Jump to line:") + " <input type=\"text\" style=\"width: 10em\" class=\"CodeMirror-search-field\"/> <span style=\"color: #888\" class=\"CodeMirror-search-hint\">" + cm.phrase("(Use line:column or scroll% syntax)") + "</span>";
|
|
}
|
|
function interpretLine(cm, string) {
|
|
var num = Number(string);
|
|
if (/^[-+]/.test(string)) return cm.getCursor().line + num;
|
|
else return num - 1;
|
|
}
|
|
CodeMirror$1.commands.jumpToLine = function(cm) {
|
|
var cur = cm.getCursor();
|
|
dialog(cm, getJumpDialog(cm), cm.phrase("Jump to line:"), cur.line + 1 + ":" + cur.ch, function(posStr) {
|
|
if (!posStr) return;
|
|
var match;
|
|
if (match = /^\s*([\+\-]?\d+)\s*\:\s*(\d+)\s*$/.exec(posStr)) cm.setCursor(interpretLine(cm, match[1]), Number(match[2]));
|
|
else if (match = /^\s*([\+\-]?\d+(\.\d+)?)\%\s*/.exec(posStr)) {
|
|
var line = Math.round(cm.lineCount() * Number(match[1]) / 100);
|
|
if (/^[-+]/.test(match[1])) line = cur.line + line + 1;
|
|
cm.setCursor(line - 1, cur.ch);
|
|
} else if (match = /^\s*\:?\s*([\+\-]?\d+)\s*/.exec(posStr)) cm.setCursor(interpretLine(cm, match[1]), cur.ch);
|
|
});
|
|
};
|
|
CodeMirror$1.keyMap["default"]["Alt-G"] = "jumpToLine";
|
|
});
|
|
});
|
|
var require_searchcursor = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
var Pos = CodeMirror$1.Pos;
|
|
function regexpFlags(regexp) {
|
|
var flags = regexp.flags;
|
|
return flags != null ? flags : (regexp.ignoreCase ? "i" : "") + (regexp.global ? "g" : "") + (regexp.multiline ? "m" : "");
|
|
}
|
|
function ensureFlags(regexp, flags) {
|
|
var current = regexpFlags(regexp), target = current;
|
|
for (var i = 0; i < flags.length; i++) if (target.indexOf(flags.charAt(i)) == -1) target += flags.charAt(i);
|
|
return current == target ? regexp : new RegExp(regexp.source, target);
|
|
}
|
|
function maybeMultiline(regexp) {
|
|
return /\\s|\\n|\n|\\W|\\D|\[\^/.test(regexp.source);
|
|
}
|
|
function searchRegexpForward(doc, regexp, start) {
|
|
regexp = ensureFlags(regexp, "g");
|
|
for (var line = start.line, ch = start.ch, last = doc.lastLine(); line <= last; line++, ch = 0) {
|
|
regexp.lastIndex = ch;
|
|
var string = doc.getLine(line), match = regexp.exec(string);
|
|
if (match) return {
|
|
from: Pos(line, match.index),
|
|
to: Pos(line, match.index + match[0].length),
|
|
match
|
|
};
|
|
}
|
|
}
|
|
function searchRegexpForwardMultiline(doc, regexp, start) {
|
|
if (!maybeMultiline(regexp)) return searchRegexpForward(doc, regexp, start);
|
|
regexp = ensureFlags(regexp, "gm");
|
|
var string, chunk = 1;
|
|
for (var line = start.line, last = doc.lastLine(); line <= last;) {
|
|
for (var i = 0; i < chunk; i++) {
|
|
if (line > last) break;
|
|
var curLine = doc.getLine(line++);
|
|
string = string == null ? curLine : string + "\n" + curLine;
|
|
}
|
|
chunk = chunk * 2;
|
|
regexp.lastIndex = start.ch;
|
|
var match = regexp.exec(string);
|
|
if (match) {
|
|
var before = string.slice(0, match.index).split("\n"), inside = match[0].split("\n");
|
|
var startLine = start.line + before.length - 1, startCh = before[before.length - 1].length;
|
|
return {
|
|
from: Pos(startLine, startCh),
|
|
to: Pos(startLine + inside.length - 1, inside.length == 1 ? startCh + inside[0].length : inside[inside.length - 1].length),
|
|
match
|
|
};
|
|
}
|
|
}
|
|
}
|
|
function lastMatchIn(string, regexp, endMargin) {
|
|
var match, from = 0;
|
|
while (from <= string.length) {
|
|
regexp.lastIndex = from;
|
|
var newMatch = regexp.exec(string);
|
|
if (!newMatch) break;
|
|
var end = newMatch.index + newMatch[0].length;
|
|
if (end > string.length - endMargin) break;
|
|
if (!match || end > match.index + match[0].length) match = newMatch;
|
|
from = newMatch.index + 1;
|
|
}
|
|
return match;
|
|
}
|
|
function searchRegexpBackward(doc, regexp, start) {
|
|
regexp = ensureFlags(regexp, "g");
|
|
for (var line = start.line, ch = start.ch, first = doc.firstLine(); line >= first; line--, ch = -1) {
|
|
var string = doc.getLine(line);
|
|
var match = lastMatchIn(string, regexp, ch < 0 ? 0 : string.length - ch);
|
|
if (match) return {
|
|
from: Pos(line, match.index),
|
|
to: Pos(line, match.index + match[0].length),
|
|
match
|
|
};
|
|
}
|
|
}
|
|
function searchRegexpBackwardMultiline(doc, regexp, start) {
|
|
if (!maybeMultiline(regexp)) return searchRegexpBackward(doc, regexp, start);
|
|
regexp = ensureFlags(regexp, "gm");
|
|
var string, chunkSize = 1, endMargin = doc.getLine(start.line).length - start.ch;
|
|
for (var line = start.line, first = doc.firstLine(); line >= first;) {
|
|
for (var i = 0; i < chunkSize && line >= first; i++) {
|
|
var curLine = doc.getLine(line--);
|
|
string = string == null ? curLine : curLine + "\n" + string;
|
|
}
|
|
chunkSize *= 2;
|
|
var match = lastMatchIn(string, regexp, endMargin);
|
|
if (match) {
|
|
var before = string.slice(0, match.index).split("\n"), inside = match[0].split("\n");
|
|
var startLine = line + before.length, startCh = before[before.length - 1].length;
|
|
return {
|
|
from: Pos(startLine, startCh),
|
|
to: Pos(startLine + inside.length - 1, inside.length == 1 ? startCh + inside[0].length : inside[inside.length - 1].length),
|
|
match
|
|
};
|
|
}
|
|
}
|
|
}
|
|
var doFold, noFold;
|
|
if (String.prototype.normalize) {
|
|
doFold = function(str) {
|
|
return str.normalize("NFD").toLowerCase();
|
|
};
|
|
noFold = function(str) {
|
|
return str.normalize("NFD");
|
|
};
|
|
} else {
|
|
doFold = function(str) {
|
|
return str.toLowerCase();
|
|
};
|
|
noFold = function(str) {
|
|
return str;
|
|
};
|
|
}
|
|
function adjustPos(orig, folded, pos, foldFunc) {
|
|
if (orig.length == folded.length) return pos;
|
|
for (var min = 0, max = pos + Math.max(0, orig.length - folded.length);;) {
|
|
if (min == max) return min;
|
|
var mid = min + max >> 1;
|
|
var len = foldFunc(orig.slice(0, mid)).length;
|
|
if (len == pos) return mid;
|
|
else if (len > pos) max = mid;
|
|
else min = mid + 1;
|
|
}
|
|
}
|
|
function searchStringForward(doc, query, start, caseFold) {
|
|
if (!query.length) return null;
|
|
var fold = caseFold ? doFold : noFold;
|
|
var lines = fold(query).split(/\r|\n\r?/);
|
|
search: for (var line = start.line, ch = start.ch, last = doc.lastLine() + 1 - lines.length; line <= last; line++, ch = 0) {
|
|
var orig = doc.getLine(line).slice(ch), string = fold(orig);
|
|
if (lines.length == 1) {
|
|
var found = string.indexOf(lines[0]);
|
|
if (found == -1) continue search;
|
|
var start = adjustPos(orig, string, found, fold) + ch;
|
|
return {
|
|
from: Pos(line, adjustPos(orig, string, found, fold) + ch),
|
|
to: Pos(line, adjustPos(orig, string, found + lines[0].length, fold) + ch)
|
|
};
|
|
} else {
|
|
var cutFrom = string.length - lines[0].length;
|
|
if (string.slice(cutFrom) != lines[0]) continue search;
|
|
for (var i = 1; i < lines.length - 1; i++) if (fold(doc.getLine(line + i)) != lines[i]) continue search;
|
|
var end = doc.getLine(line + lines.length - 1), endString = fold(end), lastLine = lines[lines.length - 1];
|
|
if (endString.slice(0, lastLine.length) != lastLine) continue search;
|
|
return {
|
|
from: Pos(line, adjustPos(orig, string, cutFrom, fold) + ch),
|
|
to: Pos(line + lines.length - 1, adjustPos(end, endString, lastLine.length, fold))
|
|
};
|
|
}
|
|
}
|
|
}
|
|
function searchStringBackward(doc, query, start, caseFold) {
|
|
if (!query.length) return null;
|
|
var fold = caseFold ? doFold : noFold;
|
|
var lines = fold(query).split(/\r|\n\r?/);
|
|
search: for (var line = start.line, ch = start.ch, first = doc.firstLine() - 1 + lines.length; line >= first; line--, ch = -1) {
|
|
var orig = doc.getLine(line);
|
|
if (ch > -1) orig = orig.slice(0, ch);
|
|
var string = fold(orig);
|
|
if (lines.length == 1) {
|
|
var found = string.lastIndexOf(lines[0]);
|
|
if (found == -1) continue search;
|
|
return {
|
|
from: Pos(line, adjustPos(orig, string, found, fold)),
|
|
to: Pos(line, adjustPos(orig, string, found + lines[0].length, fold))
|
|
};
|
|
} else {
|
|
var lastLine = lines[lines.length - 1];
|
|
if (string.slice(0, lastLine.length) != lastLine) continue search;
|
|
for (var i = 1, start = line - lines.length + 1; i < lines.length - 1; i++) if (fold(doc.getLine(start + i)) != lines[i]) continue search;
|
|
var top = doc.getLine(line + 1 - lines.length), topString = fold(top);
|
|
if (topString.slice(topString.length - lines[0].length) != lines[0]) continue search;
|
|
return {
|
|
from: Pos(line + 1 - lines.length, adjustPos(top, topString, top.length - lines[0].length, fold)),
|
|
to: Pos(line, adjustPos(orig, string, lastLine.length, fold))
|
|
};
|
|
}
|
|
}
|
|
}
|
|
function SearchCursor(doc, query, pos, options) {
|
|
this.atOccurrence = false;
|
|
this.afterEmptyMatch = false;
|
|
this.doc = doc;
|
|
pos = pos ? doc.clipPos(pos) : Pos(0, 0);
|
|
this.pos = {
|
|
from: pos,
|
|
to: pos
|
|
};
|
|
var caseFold;
|
|
if (typeof options == "object") caseFold = options.caseFold;
|
|
else {
|
|
caseFold = options;
|
|
options = null;
|
|
}
|
|
if (typeof query == "string") {
|
|
if (caseFold == null) caseFold = false;
|
|
this.matches = function(reverse, pos$1) {
|
|
return (reverse ? searchStringBackward : searchStringForward)(doc, query, pos$1, caseFold);
|
|
};
|
|
} else {
|
|
query = ensureFlags(query, "gm");
|
|
if (!options || options.multiline !== false) this.matches = function(reverse, pos$1) {
|
|
return (reverse ? searchRegexpBackwardMultiline : searchRegexpForwardMultiline)(doc, query, pos$1);
|
|
};
|
|
else this.matches = function(reverse, pos$1) {
|
|
return (reverse ? searchRegexpBackward : searchRegexpForward)(doc, query, pos$1);
|
|
};
|
|
}
|
|
}
|
|
SearchCursor.prototype = {
|
|
findNext: function() {
|
|
return this.find(false);
|
|
},
|
|
findPrevious: function() {
|
|
return this.find(true);
|
|
},
|
|
find: function(reverse) {
|
|
var head = this.doc.clipPos(reverse ? this.pos.from : this.pos.to);
|
|
if (this.afterEmptyMatch && this.atOccurrence) {
|
|
head = Pos(head.line, head.ch);
|
|
if (reverse) {
|
|
head.ch--;
|
|
if (head.ch < 0) {
|
|
head.line--;
|
|
head.ch = (this.doc.getLine(head.line) || "").length;
|
|
}
|
|
} else {
|
|
head.ch++;
|
|
if (head.ch > (this.doc.getLine(head.line) || "").length) {
|
|
head.ch = 0;
|
|
head.line++;
|
|
}
|
|
}
|
|
if (CodeMirror$1.cmpPos(head, this.doc.clipPos(head)) != 0) return this.atOccurrence = false;
|
|
}
|
|
var result = this.matches(reverse, head);
|
|
this.afterEmptyMatch = result && CodeMirror$1.cmpPos(result.from, result.to) == 0;
|
|
if (result) {
|
|
this.pos = result;
|
|
this.atOccurrence = true;
|
|
return this.pos.match || true;
|
|
} else {
|
|
var end = Pos(reverse ? this.doc.firstLine() : this.doc.lastLine() + 1, 0);
|
|
this.pos = {
|
|
from: end,
|
|
to: end
|
|
};
|
|
return this.atOccurrence = false;
|
|
}
|
|
},
|
|
from: function() {
|
|
if (this.atOccurrence) return this.pos.from;
|
|
},
|
|
to: function() {
|
|
if (this.atOccurrence) return this.pos.to;
|
|
},
|
|
replace: function(newText, origin) {
|
|
if (!this.atOccurrence) return;
|
|
var lines = CodeMirror$1.splitLines(newText);
|
|
this.doc.replaceRange(lines, this.pos.from, this.pos.to, origin);
|
|
this.pos.to = Pos(this.pos.from.line + lines.length - 1, lines[lines.length - 1].length + (lines.length == 1 ? this.pos.from.ch : 0));
|
|
}
|
|
};
|
|
CodeMirror$1.defineExtension("getSearchCursor", function(query, pos, caseFold) {
|
|
return new SearchCursor(this.doc, query, pos, caseFold);
|
|
});
|
|
CodeMirror$1.defineDocExtension("getSearchCursor", function(query, pos, caseFold) {
|
|
return new SearchCursor(this, query, pos, caseFold);
|
|
});
|
|
CodeMirror$1.defineExtension("selectMatches", function(query, caseFold) {
|
|
var ranges = [];
|
|
var cur = this.getSearchCursor(query, this.getCursor("from"), caseFold);
|
|
while (cur.findNext()) {
|
|
if (CodeMirror$1.cmpPos(cur.to(), this.getCursor("to")) > 0) break;
|
|
ranges.push({
|
|
anchor: cur.from(),
|
|
head: cur.to()
|
|
});
|
|
}
|
|
if (ranges.length) this.setSelections(ranges, 0);
|
|
});
|
|
});
|
|
});
|
|
var require_search = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror(), require_searchcursor(), require_dialog());
|
|
else if (typeof define == "function" && define.amd) define([
|
|
"../../lib/codemirror",
|
|
"./searchcursor",
|
|
"../dialog/dialog"
|
|
], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineOption("search", { bottom: false });
|
|
function searchOverlay(query, caseInsensitive) {
|
|
if (typeof query == "string") query = new RegExp(query.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g, "\\$&"), caseInsensitive ? "gi" : "g");
|
|
else if (!query.global) query = new RegExp(query.source, query.ignoreCase ? "gi" : "g");
|
|
return { token: function(stream) {
|
|
query.lastIndex = stream.pos;
|
|
var match = query.exec(stream.string);
|
|
if (match && match.index == stream.pos) {
|
|
stream.pos += match[0].length || 1;
|
|
return "searching";
|
|
} else if (match) stream.pos = match.index;
|
|
else stream.skipToEnd();
|
|
} };
|
|
}
|
|
function SearchState() {
|
|
this.posFrom = this.posTo = this.lastQuery = this.query = null;
|
|
this.overlay = null;
|
|
}
|
|
function getSearchState(cm) {
|
|
return cm.state.search || (cm.state.search = new SearchState());
|
|
}
|
|
function queryCaseInsensitive(query) {
|
|
return typeof query == "string" && query == query.toLowerCase();
|
|
}
|
|
function getSearchCursor(cm, query, pos) {
|
|
return cm.getSearchCursor(query, pos, {
|
|
caseFold: queryCaseInsensitive(query),
|
|
multiline: true
|
|
});
|
|
}
|
|
function persistentDialog(cm, text, deflt, onEnter, onKeyDown) {
|
|
cm.openDialog(text, onEnter, {
|
|
value: deflt,
|
|
selectValueOnOpen: true,
|
|
closeOnEnter: false,
|
|
onClose: function() {
|
|
clearSearch(cm);
|
|
},
|
|
onKeyDown,
|
|
bottom: cm.options.search.bottom
|
|
});
|
|
}
|
|
function dialog(cm, text, shortText, deflt, f) {
|
|
if (cm.openDialog) cm.openDialog(text, f, {
|
|
value: deflt,
|
|
selectValueOnOpen: true,
|
|
bottom: cm.options.search.bottom
|
|
});
|
|
else f(prompt(shortText, deflt));
|
|
}
|
|
function confirmDialog(cm, text, shortText, fs) {
|
|
if (cm.openConfirm) cm.openConfirm(text, fs);
|
|
else if (confirm(shortText)) fs[0]();
|
|
}
|
|
function parseString(string) {
|
|
return string.replace(/\\([nrt\\])/g, function(match, ch) {
|
|
if (ch == "n") return "\n";
|
|
if (ch == "r") return "\r";
|
|
if (ch == "t") return " ";
|
|
if (ch == "\\") return "\\";
|
|
return match;
|
|
});
|
|
}
|
|
function parseQuery(query) {
|
|
var isRE = query.match(/^\/(.*)\/([a-z]*)$/);
|
|
if (isRE) try {
|
|
query = new RegExp(isRE[1], isRE[2].indexOf("i") == -1 ? "" : "i");
|
|
} catch (e) {}
|
|
else query = parseString(query);
|
|
if (typeof query == "string" ? query == "" : query.test("")) query = /x^/;
|
|
return query;
|
|
}
|
|
function startSearch(cm, state, query) {
|
|
state.queryText = query;
|
|
state.query = parseQuery(query);
|
|
cm.removeOverlay(state.overlay, queryCaseInsensitive(state.query));
|
|
state.overlay = searchOverlay(state.query, queryCaseInsensitive(state.query));
|
|
cm.addOverlay(state.overlay);
|
|
if (cm.showMatchesOnScrollbar) {
|
|
if (state.annotate) {
|
|
state.annotate.clear();
|
|
state.annotate = null;
|
|
}
|
|
state.annotate = cm.showMatchesOnScrollbar(state.query, queryCaseInsensitive(state.query));
|
|
}
|
|
}
|
|
function doSearch(cm, rev, persistent, immediate) {
|
|
var state = getSearchState(cm);
|
|
if (state.query) return findNext(cm, rev);
|
|
var q = cm.getSelection() || state.lastQuery;
|
|
if (q instanceof RegExp && q.source == "x^") q = null;
|
|
if (persistent && cm.openDialog) {
|
|
var hiding = null;
|
|
var searchNext = function(query, event) {
|
|
CodeMirror$1.e_stop(event);
|
|
if (!query) return;
|
|
if (query != state.queryText) {
|
|
startSearch(cm, state, query);
|
|
state.posFrom = state.posTo = cm.getCursor();
|
|
}
|
|
if (hiding) hiding.style.opacity = 1;
|
|
findNext(cm, event.shiftKey, function(_, to) {
|
|
var dialog$1;
|
|
if (to.line < 3 && document.querySelector && (dialog$1 = cm.display.wrapper.querySelector(".CodeMirror-dialog")) && dialog$1.getBoundingClientRect().bottom - 4 > cm.cursorCoords(to, "window").top) (hiding = dialog$1).style.opacity = .4;
|
|
});
|
|
};
|
|
persistentDialog(cm, getQueryDialog(cm), q, searchNext, function(event, query) {
|
|
var keyName = CodeMirror$1.keyName(event);
|
|
var extra = cm.getOption("extraKeys"), cmd = extra && extra[keyName] || CodeMirror$1.keyMap[cm.getOption("keyMap")][keyName];
|
|
if (cmd == "findNext" || cmd == "findPrev" || cmd == "findPersistentNext" || cmd == "findPersistentPrev") {
|
|
CodeMirror$1.e_stop(event);
|
|
startSearch(cm, getSearchState(cm), query);
|
|
cm.execCommand(cmd);
|
|
} else if (cmd == "find" || cmd == "findPersistent") {
|
|
CodeMirror$1.e_stop(event);
|
|
searchNext(query, event);
|
|
}
|
|
});
|
|
if (immediate && q) {
|
|
startSearch(cm, state, q);
|
|
findNext(cm, rev);
|
|
}
|
|
} else dialog(cm, getQueryDialog(cm), "Search for:", q, function(query) {
|
|
if (query && !state.query) cm.operation(function() {
|
|
startSearch(cm, state, query);
|
|
state.posFrom = state.posTo = cm.getCursor();
|
|
findNext(cm, rev);
|
|
});
|
|
});
|
|
}
|
|
function findNext(cm, rev, callback) {
|
|
cm.operation(function() {
|
|
var state = getSearchState(cm);
|
|
var cursor = getSearchCursor(cm, state.query, rev ? state.posFrom : state.posTo);
|
|
if (!cursor.find(rev)) {
|
|
cursor = getSearchCursor(cm, state.query, rev ? CodeMirror$1.Pos(cm.lastLine()) : CodeMirror$1.Pos(cm.firstLine(), 0));
|
|
if (!cursor.find(rev)) return;
|
|
}
|
|
cm.setSelection(cursor.from(), cursor.to());
|
|
cm.scrollIntoView({
|
|
from: cursor.from(),
|
|
to: cursor.to()
|
|
}, 20);
|
|
state.posFrom = cursor.from();
|
|
state.posTo = cursor.to();
|
|
if (callback) callback(cursor.from(), cursor.to());
|
|
});
|
|
}
|
|
function clearSearch(cm) {
|
|
cm.operation(function() {
|
|
var state = getSearchState(cm);
|
|
state.lastQuery = state.query;
|
|
if (!state.query) return;
|
|
state.query = state.queryText = null;
|
|
cm.removeOverlay(state.overlay);
|
|
if (state.annotate) {
|
|
state.annotate.clear();
|
|
state.annotate = null;
|
|
}
|
|
});
|
|
}
|
|
function el(tag, attrs) {
|
|
var element = tag ? document.createElement(tag) : document.createDocumentFragment();
|
|
for (var key in attrs) element[key] = attrs[key];
|
|
for (var i = 2; i < arguments.length; i++) {
|
|
var child = arguments[i];
|
|
element.appendChild(typeof child == "string" ? document.createTextNode(child) : child);
|
|
}
|
|
return element;
|
|
}
|
|
function getQueryDialog(cm) {
|
|
var label = el("label", { className: "CodeMirror-search-label" }, cm.phrase("Search:"), el("input", {
|
|
type: "text",
|
|
"style": "width: 10em",
|
|
className: "CodeMirror-search-field",
|
|
id: "CodeMirror-search-field"
|
|
}));
|
|
label.setAttribute("for", "CodeMirror-search-field");
|
|
return el("", null, label, " ", el("span", {
|
|
style: "color: #666",
|
|
className: "CodeMirror-search-hint"
|
|
}, cm.phrase("(Use /re/ syntax for regexp search)")));
|
|
}
|
|
function getReplaceQueryDialog(cm) {
|
|
return el("", null, " ", el("input", {
|
|
type: "text",
|
|
"style": "width: 10em",
|
|
className: "CodeMirror-search-field"
|
|
}), " ", el("span", {
|
|
style: "color: #666",
|
|
className: "CodeMirror-search-hint"
|
|
}, cm.phrase("(Use /re/ syntax for regexp search)")));
|
|
}
|
|
function getReplacementQueryDialog(cm) {
|
|
return el("", null, el("span", { className: "CodeMirror-search-label" }, cm.phrase("With:")), " ", el("input", {
|
|
type: "text",
|
|
"style": "width: 10em",
|
|
className: "CodeMirror-search-field"
|
|
}));
|
|
}
|
|
function getDoReplaceConfirm(cm) {
|
|
return el("", null, el("span", { className: "CodeMirror-search-label" }, cm.phrase("Replace?")), " ", el("button", {}, cm.phrase("Yes")), " ", el("button", {}, cm.phrase("No")), " ", el("button", {}, cm.phrase("All")), " ", el("button", {}, cm.phrase("Stop")));
|
|
}
|
|
function replaceAll(cm, query, text) {
|
|
cm.operation(function() {
|
|
for (var cursor = getSearchCursor(cm, query); cursor.findNext();) if (typeof query != "string") {
|
|
var match = cm.getRange(cursor.from(), cursor.to()).match(query);
|
|
cursor.replace(text.replace(/\$(\d)/g, function(_, i) {
|
|
return match[i];
|
|
}));
|
|
} else cursor.replace(text);
|
|
});
|
|
}
|
|
function replace(cm, all) {
|
|
if (cm.getOption("readOnly")) return;
|
|
var query = cm.getSelection() || getSearchState(cm).lastQuery;
|
|
var dialogText = all ? cm.phrase("Replace all:") : cm.phrase("Replace:");
|
|
var fragment = el("", null, el("span", { className: "CodeMirror-search-label" }, dialogText), getReplaceQueryDialog(cm));
|
|
dialog(cm, fragment, dialogText, query, function(query$1) {
|
|
if (!query$1) return;
|
|
query$1 = parseQuery(query$1);
|
|
dialog(cm, getReplacementQueryDialog(cm), cm.phrase("Replace with:"), "", function(text) {
|
|
text = parseString(text);
|
|
if (all) replaceAll(cm, query$1, text);
|
|
else {
|
|
clearSearch(cm);
|
|
var cursor = getSearchCursor(cm, query$1, cm.getCursor("from"));
|
|
var advance = function() {
|
|
var start = cursor.from(), match;
|
|
if (!(match = cursor.findNext())) {
|
|
cursor = getSearchCursor(cm, query$1);
|
|
if (!(match = cursor.findNext()) || start && cursor.from().line == start.line && cursor.from().ch == start.ch) return;
|
|
}
|
|
cm.setSelection(cursor.from(), cursor.to());
|
|
cm.scrollIntoView({
|
|
from: cursor.from(),
|
|
to: cursor.to()
|
|
});
|
|
confirmDialog(cm, getDoReplaceConfirm(cm), cm.phrase("Replace?"), [
|
|
function() {
|
|
doReplace(match);
|
|
},
|
|
advance,
|
|
function() {
|
|
replaceAll(cm, query$1, text);
|
|
}
|
|
]);
|
|
};
|
|
var doReplace = function(match) {
|
|
cursor.replace(typeof query$1 == "string" ? text : text.replace(/\$(\d)/g, function(_, i) {
|
|
return match[i];
|
|
}));
|
|
advance();
|
|
};
|
|
advance();
|
|
}
|
|
});
|
|
});
|
|
}
|
|
CodeMirror$1.commands.find = function(cm) {
|
|
clearSearch(cm);
|
|
doSearch(cm);
|
|
};
|
|
CodeMirror$1.commands.findPersistent = function(cm) {
|
|
clearSearch(cm);
|
|
doSearch(cm, false, true);
|
|
};
|
|
CodeMirror$1.commands.findPersistentNext = function(cm) {
|
|
doSearch(cm, false, true, true);
|
|
};
|
|
CodeMirror$1.commands.findPersistentPrev = function(cm) {
|
|
doSearch(cm, true, true, true);
|
|
};
|
|
CodeMirror$1.commands.findNext = doSearch;
|
|
CodeMirror$1.commands.findPrev = function(cm) {
|
|
doSearch(cm, true);
|
|
};
|
|
CodeMirror$1.commands.clearSearch = clearSearch;
|
|
CodeMirror$1.commands.replace = replace;
|
|
CodeMirror$1.commands.replaceAll = function(cm) {
|
|
replace(cm, true);
|
|
};
|
|
});
|
|
});
|
|
var require_css = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineMode("css", function(config, parserConfig) {
|
|
var inline = parserConfig.inline;
|
|
if (!parserConfig.propertyKeywords) parserConfig = CodeMirror$1.resolveMode("text/css");
|
|
var indentUnit = config.indentUnit, tokenHooks = parserConfig.tokenHooks, documentTypes$1 = parserConfig.documentTypes || {}, mediaTypes$1 = parserConfig.mediaTypes || {}, mediaFeatures$1 = parserConfig.mediaFeatures || {}, mediaValueKeywords$1 = parserConfig.mediaValueKeywords || {}, propertyKeywords$1 = parserConfig.propertyKeywords || {}, nonStandardPropertyKeywords$1 = parserConfig.nonStandardPropertyKeywords || {}, fontProperties$1 = parserConfig.fontProperties || {}, counterDescriptors$1 = parserConfig.counterDescriptors || {}, colorKeywords$1 = parserConfig.colorKeywords || {}, valueKeywords$1 = parserConfig.valueKeywords || {}, allowNested = parserConfig.allowNested, lineComment = parserConfig.lineComment, supportsAtComponent = parserConfig.supportsAtComponent === true, highlightNonStandardPropertyKeywords = config.highlightNonStandardPropertyKeywords !== false;
|
|
var type, override;
|
|
function ret(style, tp) {
|
|
type = tp;
|
|
return style;
|
|
}
|
|
function tokenBase(stream, state) {
|
|
var ch = stream.next();
|
|
if (tokenHooks[ch]) {
|
|
var result = tokenHooks[ch](stream, state);
|
|
if (result !== false) return result;
|
|
}
|
|
if (ch == "@") {
|
|
stream.eatWhile(/[\w\\\-]/);
|
|
return ret("def", stream.current());
|
|
} else if (ch == "=" || (ch == "~" || ch == "|") && stream.eat("=")) return ret(null, "compare");
|
|
else if (ch == "\"" || ch == "'") {
|
|
state.tokenize = tokenString(ch);
|
|
return state.tokenize(stream, state);
|
|
} else if (ch == "#") {
|
|
stream.eatWhile(/[\w\\\-]/);
|
|
return ret("atom", "hash");
|
|
} else if (ch == "!") {
|
|
stream.match(/^\s*\w*/);
|
|
return ret("keyword", "important");
|
|
} else if (/\d/.test(ch) || ch == "." && stream.eat(/\d/)) {
|
|
stream.eatWhile(/[\w.%]/);
|
|
return ret("number", "unit");
|
|
} else if (ch === "-") {
|
|
if (/[\d.]/.test(stream.peek())) {
|
|
stream.eatWhile(/[\w.%]/);
|
|
return ret("number", "unit");
|
|
} else if (stream.match(/^-[\w\\\-]*/)) {
|
|
stream.eatWhile(/[\w\\\-]/);
|
|
if (stream.match(/^\s*:/, false)) return ret("variable-2", "variable-definition");
|
|
return ret("variable-2", "variable");
|
|
} else if (stream.match(/^\w+-/)) return ret("meta", "meta");
|
|
} else if (/[,+>*\/]/.test(ch)) return ret(null, "select-op");
|
|
else if (ch == "." && stream.match(/^-?[_a-z][_a-z0-9-]*/i)) return ret("qualifier", "qualifier");
|
|
else if (/[:;{}\[\]\(\)]/.test(ch)) return ret(null, ch);
|
|
else if (stream.match(/^[\w-.]+(?=\()/)) {
|
|
if (/^(url(-prefix)?|domain|regexp)$/i.test(stream.current())) state.tokenize = tokenParenthesized;
|
|
return ret("variable callee", "variable");
|
|
} else if (/[\w\\\-]/.test(ch)) {
|
|
stream.eatWhile(/[\w\\\-]/);
|
|
return ret("property", "word");
|
|
} else return ret(null, null);
|
|
}
|
|
function tokenString(quote) {
|
|
return function(stream, state) {
|
|
var escaped = false, ch;
|
|
while ((ch = stream.next()) != null) {
|
|
if (ch == quote && !escaped) {
|
|
if (quote == ")") stream.backUp(1);
|
|
break;
|
|
}
|
|
escaped = !escaped && ch == "\\";
|
|
}
|
|
if (ch == quote || !escaped && quote != ")") state.tokenize = null;
|
|
return ret("string", "string");
|
|
};
|
|
}
|
|
function tokenParenthesized(stream, state) {
|
|
stream.next();
|
|
if (!stream.match(/^\s*[\"\')]/, false)) state.tokenize = tokenString(")");
|
|
else state.tokenize = null;
|
|
return ret(null, "(");
|
|
}
|
|
function Context(type$1, indent, prev) {
|
|
this.type = type$1;
|
|
this.indent = indent;
|
|
this.prev = prev;
|
|
}
|
|
function pushContext(state, stream, type$1, indent) {
|
|
state.context = new Context(type$1, stream.indentation() + (indent === false ? 0 : indentUnit), state.context);
|
|
return type$1;
|
|
}
|
|
function popContext(state) {
|
|
if (state.context.prev) state.context = state.context.prev;
|
|
return state.context.type;
|
|
}
|
|
function pass(type$1, stream, state) {
|
|
return states[state.context.type](type$1, stream, state);
|
|
}
|
|
function popAndPass(type$1, stream, state, n) {
|
|
for (var i = n || 1; i > 0; i--) state.context = state.context.prev;
|
|
return pass(type$1, stream, state);
|
|
}
|
|
function wordAsValue(stream) {
|
|
var word = stream.current().toLowerCase();
|
|
if (valueKeywords$1.hasOwnProperty(word)) override = "atom";
|
|
else if (colorKeywords$1.hasOwnProperty(word)) override = "keyword";
|
|
else override = "variable";
|
|
}
|
|
var states = {};
|
|
states.top = function(type$1, stream, state) {
|
|
if (type$1 == "{") return pushContext(state, stream, "block");
|
|
else if (type$1 == "}" && state.context.prev) return popContext(state);
|
|
else if (supportsAtComponent && /@component/i.test(type$1)) return pushContext(state, stream, "atComponentBlock");
|
|
else if (/^@(-moz-)?document$/i.test(type$1)) return pushContext(state, stream, "documentTypes");
|
|
else if (/^@(media|supports|(-moz-)?document|import)$/i.test(type$1)) return pushContext(state, stream, "atBlock");
|
|
else if (/^@(font-face|counter-style)/i.test(type$1)) {
|
|
state.stateArg = type$1;
|
|
return "restricted_atBlock_before";
|
|
} else if (/^@(-(moz|ms|o|webkit)-)?keyframes$/i.test(type$1)) return "keyframes";
|
|
else if (type$1 && type$1.charAt(0) == "@") return pushContext(state, stream, "at");
|
|
else if (type$1 == "hash") override = "builtin";
|
|
else if (type$1 == "word") override = "tag";
|
|
else if (type$1 == "variable-definition") return "maybeprop";
|
|
else if (type$1 == "interpolation") return pushContext(state, stream, "interpolation");
|
|
else if (type$1 == ":") return "pseudo";
|
|
else if (allowNested && type$1 == "(") return pushContext(state, stream, "parens");
|
|
return state.context.type;
|
|
};
|
|
states.block = function(type$1, stream, state) {
|
|
if (type$1 == "word") {
|
|
var word = stream.current().toLowerCase();
|
|
if (propertyKeywords$1.hasOwnProperty(word)) {
|
|
override = "property";
|
|
return "maybeprop";
|
|
} else if (nonStandardPropertyKeywords$1.hasOwnProperty(word)) {
|
|
override = highlightNonStandardPropertyKeywords ? "string-2" : "property";
|
|
return "maybeprop";
|
|
} else if (allowNested) {
|
|
override = stream.match(/^\s*:(?:\s|$)/, false) ? "property" : "tag";
|
|
return "block";
|
|
} else {
|
|
override += " error";
|
|
return "maybeprop";
|
|
}
|
|
} else if (type$1 == "meta") return "block";
|
|
else if (!allowNested && (type$1 == "hash" || type$1 == "qualifier")) {
|
|
override = "error";
|
|
return "block";
|
|
} else return states.top(type$1, stream, state);
|
|
};
|
|
states.maybeprop = function(type$1, stream, state) {
|
|
if (type$1 == ":") return pushContext(state, stream, "prop");
|
|
return pass(type$1, stream, state);
|
|
};
|
|
states.prop = function(type$1, stream, state) {
|
|
if (type$1 == ";") return popContext(state);
|
|
if (type$1 == "{" && allowNested) return pushContext(state, stream, "propBlock");
|
|
if (type$1 == "}" || type$1 == "{") return popAndPass(type$1, stream, state);
|
|
if (type$1 == "(") return pushContext(state, stream, "parens");
|
|
if (type$1 == "hash" && !/^#([0-9a-fA-F]{3,4}|[0-9a-fA-F]{6}|[0-9a-fA-F]{8})$/.test(stream.current())) override += " error";
|
|
else if (type$1 == "word") wordAsValue(stream);
|
|
else if (type$1 == "interpolation") return pushContext(state, stream, "interpolation");
|
|
return "prop";
|
|
};
|
|
states.propBlock = function(type$1, _stream, state) {
|
|
if (type$1 == "}") return popContext(state);
|
|
if (type$1 == "word") {
|
|
override = "property";
|
|
return "maybeprop";
|
|
}
|
|
return state.context.type;
|
|
};
|
|
states.parens = function(type$1, stream, state) {
|
|
if (type$1 == "{" || type$1 == "}") return popAndPass(type$1, stream, state);
|
|
if (type$1 == ")") return popContext(state);
|
|
if (type$1 == "(") return pushContext(state, stream, "parens");
|
|
if (type$1 == "interpolation") return pushContext(state, stream, "interpolation");
|
|
if (type$1 == "word") wordAsValue(stream);
|
|
return "parens";
|
|
};
|
|
states.pseudo = function(type$1, stream, state) {
|
|
if (type$1 == "meta") return "pseudo";
|
|
if (type$1 == "word") {
|
|
override = "variable-3";
|
|
return state.context.type;
|
|
}
|
|
return pass(type$1, stream, state);
|
|
};
|
|
states.documentTypes = function(type$1, stream, state) {
|
|
if (type$1 == "word" && documentTypes$1.hasOwnProperty(stream.current())) {
|
|
override = "tag";
|
|
return state.context.type;
|
|
} else return states.atBlock(type$1, stream, state);
|
|
};
|
|
states.atBlock = function(type$1, stream, state) {
|
|
if (type$1 == "(") return pushContext(state, stream, "atBlock_parens");
|
|
if (type$1 == "}" || type$1 == ";") return popAndPass(type$1, stream, state);
|
|
if (type$1 == "{") return popContext(state) && pushContext(state, stream, allowNested ? "block" : "top");
|
|
if (type$1 == "interpolation") return pushContext(state, stream, "interpolation");
|
|
if (type$1 == "word") {
|
|
var word = stream.current().toLowerCase();
|
|
if (word == "only" || word == "not" || word == "and" || word == "or") override = "keyword";
|
|
else if (mediaTypes$1.hasOwnProperty(word)) override = "attribute";
|
|
else if (mediaFeatures$1.hasOwnProperty(word)) override = "property";
|
|
else if (mediaValueKeywords$1.hasOwnProperty(word)) override = "keyword";
|
|
else if (propertyKeywords$1.hasOwnProperty(word)) override = "property";
|
|
else if (nonStandardPropertyKeywords$1.hasOwnProperty(word)) override = highlightNonStandardPropertyKeywords ? "string-2" : "property";
|
|
else if (valueKeywords$1.hasOwnProperty(word)) override = "atom";
|
|
else if (colorKeywords$1.hasOwnProperty(word)) override = "keyword";
|
|
else override = "error";
|
|
}
|
|
return state.context.type;
|
|
};
|
|
states.atComponentBlock = function(type$1, stream, state) {
|
|
if (type$1 == "}") return popAndPass(type$1, stream, state);
|
|
if (type$1 == "{") return popContext(state) && pushContext(state, stream, allowNested ? "block" : "top", false);
|
|
if (type$1 == "word") override = "error";
|
|
return state.context.type;
|
|
};
|
|
states.atBlock_parens = function(type$1, stream, state) {
|
|
if (type$1 == ")") return popContext(state);
|
|
if (type$1 == "{" || type$1 == "}") return popAndPass(type$1, stream, state, 2);
|
|
return states.atBlock(type$1, stream, state);
|
|
};
|
|
states.restricted_atBlock_before = function(type$1, stream, state) {
|
|
if (type$1 == "{") return pushContext(state, stream, "restricted_atBlock");
|
|
if (type$1 == "word" && state.stateArg == "@counter-style") {
|
|
override = "variable";
|
|
return "restricted_atBlock_before";
|
|
}
|
|
return pass(type$1, stream, state);
|
|
};
|
|
states.restricted_atBlock = function(type$1, stream, state) {
|
|
if (type$1 == "}") {
|
|
state.stateArg = null;
|
|
return popContext(state);
|
|
}
|
|
if (type$1 == "word") {
|
|
if (state.stateArg == "@font-face" && !fontProperties$1.hasOwnProperty(stream.current().toLowerCase()) || state.stateArg == "@counter-style" && !counterDescriptors$1.hasOwnProperty(stream.current().toLowerCase())) override = "error";
|
|
else override = "property";
|
|
return "maybeprop";
|
|
}
|
|
return "restricted_atBlock";
|
|
};
|
|
states.keyframes = function(type$1, stream, state) {
|
|
if (type$1 == "word") {
|
|
override = "variable";
|
|
return "keyframes";
|
|
}
|
|
if (type$1 == "{") return pushContext(state, stream, "top");
|
|
return pass(type$1, stream, state);
|
|
};
|
|
states.at = function(type$1, stream, state) {
|
|
if (type$1 == ";") return popContext(state);
|
|
if (type$1 == "{" || type$1 == "}") return popAndPass(type$1, stream, state);
|
|
if (type$1 == "word") override = "tag";
|
|
else if (type$1 == "hash") override = "builtin";
|
|
return "at";
|
|
};
|
|
states.interpolation = function(type$1, stream, state) {
|
|
if (type$1 == "}") return popContext(state);
|
|
if (type$1 == "{" || type$1 == ";") return popAndPass(type$1, stream, state);
|
|
if (type$1 == "word") override = "variable";
|
|
else if (type$1 != "variable" && type$1 != "(" && type$1 != ")") override = "error";
|
|
return "interpolation";
|
|
};
|
|
return {
|
|
startState: function(base) {
|
|
return {
|
|
tokenize: null,
|
|
state: inline ? "block" : "top",
|
|
stateArg: null,
|
|
context: new Context(inline ? "block" : "top", base || 0, null)
|
|
};
|
|
},
|
|
token: function(stream, state) {
|
|
if (!state.tokenize && stream.eatSpace()) return null;
|
|
var style = (state.tokenize || tokenBase)(stream, state);
|
|
if (style && typeof style == "object") {
|
|
type = style[1];
|
|
style = style[0];
|
|
}
|
|
override = style;
|
|
if (type != "comment") state.state = states[state.state](type, stream, state);
|
|
return override;
|
|
},
|
|
indent: function(state, textAfter) {
|
|
var cx = state.context, ch = textAfter && textAfter.charAt(0);
|
|
var indent = cx.indent;
|
|
if (cx.type == "prop" && (ch == "}" || ch == ")")) cx = cx.prev;
|
|
if (cx.prev) {
|
|
if (ch == "}" && (cx.type == "block" || cx.type == "top" || cx.type == "interpolation" || cx.type == "restricted_atBlock")) {
|
|
cx = cx.prev;
|
|
indent = cx.indent;
|
|
} else if (ch == ")" && (cx.type == "parens" || cx.type == "atBlock_parens") || ch == "{" && (cx.type == "at" || cx.type == "atBlock")) indent = Math.max(0, cx.indent - indentUnit);
|
|
}
|
|
return indent;
|
|
},
|
|
electricChars: "}",
|
|
blockCommentStart: "/*",
|
|
blockCommentEnd: "*/",
|
|
blockCommentContinue: " * ",
|
|
lineComment,
|
|
fold: "brace"
|
|
};
|
|
});
|
|
function keySet(array) {
|
|
var keys = {};
|
|
for (var i = 0; i < array.length; ++i) keys[array[i].toLowerCase()] = true;
|
|
return keys;
|
|
}
|
|
var documentTypes_ = [
|
|
"domain",
|
|
"regexp",
|
|
"url",
|
|
"url-prefix"
|
|
], documentTypes = keySet(documentTypes_);
|
|
var mediaTypes_ = [
|
|
"all",
|
|
"aural",
|
|
"braille",
|
|
"handheld",
|
|
"print",
|
|
"projection",
|
|
"screen",
|
|
"tty",
|
|
"tv",
|
|
"embossed"
|
|
], mediaTypes = keySet(mediaTypes_);
|
|
var mediaFeatures_ = [
|
|
"width",
|
|
"min-width",
|
|
"max-width",
|
|
"height",
|
|
"min-height",
|
|
"max-height",
|
|
"device-width",
|
|
"min-device-width",
|
|
"max-device-width",
|
|
"device-height",
|
|
"min-device-height",
|
|
"max-device-height",
|
|
"aspect-ratio",
|
|
"min-aspect-ratio",
|
|
"max-aspect-ratio",
|
|
"device-aspect-ratio",
|
|
"min-device-aspect-ratio",
|
|
"max-device-aspect-ratio",
|
|
"color",
|
|
"min-color",
|
|
"max-color",
|
|
"color-index",
|
|
"min-color-index",
|
|
"max-color-index",
|
|
"monochrome",
|
|
"min-monochrome",
|
|
"max-monochrome",
|
|
"resolution",
|
|
"min-resolution",
|
|
"max-resolution",
|
|
"scan",
|
|
"grid",
|
|
"orientation",
|
|
"device-pixel-ratio",
|
|
"min-device-pixel-ratio",
|
|
"max-device-pixel-ratio",
|
|
"pointer",
|
|
"any-pointer",
|
|
"hover",
|
|
"any-hover",
|
|
"prefers-color-scheme",
|
|
"dynamic-range",
|
|
"video-dynamic-range"
|
|
], mediaFeatures = keySet(mediaFeatures_);
|
|
var mediaValueKeywords_ = [
|
|
"landscape",
|
|
"portrait",
|
|
"none",
|
|
"coarse",
|
|
"fine",
|
|
"on-demand",
|
|
"hover",
|
|
"interlace",
|
|
"progressive",
|
|
"dark",
|
|
"light",
|
|
"standard",
|
|
"high"
|
|
], mediaValueKeywords = keySet(mediaValueKeywords_);
|
|
var propertyKeywords_ = [
|
|
"align-content",
|
|
"align-items",
|
|
"align-self",
|
|
"alignment-adjust",
|
|
"alignment-baseline",
|
|
"all",
|
|
"anchor-point",
|
|
"animation",
|
|
"animation-delay",
|
|
"animation-direction",
|
|
"animation-duration",
|
|
"animation-fill-mode",
|
|
"animation-iteration-count",
|
|
"animation-name",
|
|
"animation-play-state",
|
|
"animation-timing-function",
|
|
"appearance",
|
|
"azimuth",
|
|
"backdrop-filter",
|
|
"backface-visibility",
|
|
"background",
|
|
"background-attachment",
|
|
"background-blend-mode",
|
|
"background-clip",
|
|
"background-color",
|
|
"background-image",
|
|
"background-origin",
|
|
"background-position",
|
|
"background-position-x",
|
|
"background-position-y",
|
|
"background-repeat",
|
|
"background-size",
|
|
"baseline-shift",
|
|
"binding",
|
|
"bleed",
|
|
"block-size",
|
|
"bookmark-label",
|
|
"bookmark-level",
|
|
"bookmark-state",
|
|
"bookmark-target",
|
|
"border",
|
|
"border-bottom",
|
|
"border-bottom-color",
|
|
"border-bottom-left-radius",
|
|
"border-bottom-right-radius",
|
|
"border-bottom-style",
|
|
"border-bottom-width",
|
|
"border-collapse",
|
|
"border-color",
|
|
"border-image",
|
|
"border-image-outset",
|
|
"border-image-repeat",
|
|
"border-image-slice",
|
|
"border-image-source",
|
|
"border-image-width",
|
|
"border-left",
|
|
"border-left-color",
|
|
"border-left-style",
|
|
"border-left-width",
|
|
"border-radius",
|
|
"border-right",
|
|
"border-right-color",
|
|
"border-right-style",
|
|
"border-right-width",
|
|
"border-spacing",
|
|
"border-style",
|
|
"border-top",
|
|
"border-top-color",
|
|
"border-top-left-radius",
|
|
"border-top-right-radius",
|
|
"border-top-style",
|
|
"border-top-width",
|
|
"border-width",
|
|
"bottom",
|
|
"box-decoration-break",
|
|
"box-shadow",
|
|
"box-sizing",
|
|
"break-after",
|
|
"break-before",
|
|
"break-inside",
|
|
"caption-side",
|
|
"caret-color",
|
|
"clear",
|
|
"clip",
|
|
"color",
|
|
"color-profile",
|
|
"column-count",
|
|
"column-fill",
|
|
"column-gap",
|
|
"column-rule",
|
|
"column-rule-color",
|
|
"column-rule-style",
|
|
"column-rule-width",
|
|
"column-span",
|
|
"column-width",
|
|
"columns",
|
|
"contain",
|
|
"content",
|
|
"counter-increment",
|
|
"counter-reset",
|
|
"crop",
|
|
"cue",
|
|
"cue-after",
|
|
"cue-before",
|
|
"cursor",
|
|
"direction",
|
|
"display",
|
|
"dominant-baseline",
|
|
"drop-initial-after-adjust",
|
|
"drop-initial-after-align",
|
|
"drop-initial-before-adjust",
|
|
"drop-initial-before-align",
|
|
"drop-initial-size",
|
|
"drop-initial-value",
|
|
"elevation",
|
|
"empty-cells",
|
|
"fit",
|
|
"fit-content",
|
|
"fit-position",
|
|
"flex",
|
|
"flex-basis",
|
|
"flex-direction",
|
|
"flex-flow",
|
|
"flex-grow",
|
|
"flex-shrink",
|
|
"flex-wrap",
|
|
"float",
|
|
"float-offset",
|
|
"flow-from",
|
|
"flow-into",
|
|
"font",
|
|
"font-family",
|
|
"font-feature-settings",
|
|
"font-kerning",
|
|
"font-language-override",
|
|
"font-optical-sizing",
|
|
"font-size",
|
|
"font-size-adjust",
|
|
"font-stretch",
|
|
"font-style",
|
|
"font-synthesis",
|
|
"font-variant",
|
|
"font-variant-alternates",
|
|
"font-variant-caps",
|
|
"font-variant-east-asian",
|
|
"font-variant-ligatures",
|
|
"font-variant-numeric",
|
|
"font-variant-position",
|
|
"font-variation-settings",
|
|
"font-weight",
|
|
"gap",
|
|
"grid",
|
|
"grid-area",
|
|
"grid-auto-columns",
|
|
"grid-auto-flow",
|
|
"grid-auto-rows",
|
|
"grid-column",
|
|
"grid-column-end",
|
|
"grid-column-gap",
|
|
"grid-column-start",
|
|
"grid-gap",
|
|
"grid-row",
|
|
"grid-row-end",
|
|
"grid-row-gap",
|
|
"grid-row-start",
|
|
"grid-template",
|
|
"grid-template-areas",
|
|
"grid-template-columns",
|
|
"grid-template-rows",
|
|
"hanging-punctuation",
|
|
"height",
|
|
"hyphens",
|
|
"icon",
|
|
"image-orientation",
|
|
"image-rendering",
|
|
"image-resolution",
|
|
"inline-box-align",
|
|
"inset",
|
|
"inset-block",
|
|
"inset-block-end",
|
|
"inset-block-start",
|
|
"inset-inline",
|
|
"inset-inline-end",
|
|
"inset-inline-start",
|
|
"isolation",
|
|
"justify-content",
|
|
"justify-items",
|
|
"justify-self",
|
|
"left",
|
|
"letter-spacing",
|
|
"line-break",
|
|
"line-height",
|
|
"line-height-step",
|
|
"line-stacking",
|
|
"line-stacking-ruby",
|
|
"line-stacking-shift",
|
|
"line-stacking-strategy",
|
|
"list-style",
|
|
"list-style-image",
|
|
"list-style-position",
|
|
"list-style-type",
|
|
"margin",
|
|
"margin-bottom",
|
|
"margin-left",
|
|
"margin-right",
|
|
"margin-top",
|
|
"marks",
|
|
"marquee-direction",
|
|
"marquee-loop",
|
|
"marquee-play-count",
|
|
"marquee-speed",
|
|
"marquee-style",
|
|
"mask-clip",
|
|
"mask-composite",
|
|
"mask-image",
|
|
"mask-mode",
|
|
"mask-origin",
|
|
"mask-position",
|
|
"mask-repeat",
|
|
"mask-size",
|
|
"mask-type",
|
|
"max-block-size",
|
|
"max-height",
|
|
"max-inline-size",
|
|
"max-width",
|
|
"min-block-size",
|
|
"min-height",
|
|
"min-inline-size",
|
|
"min-width",
|
|
"mix-blend-mode",
|
|
"move-to",
|
|
"nav-down",
|
|
"nav-index",
|
|
"nav-left",
|
|
"nav-right",
|
|
"nav-up",
|
|
"object-fit",
|
|
"object-position",
|
|
"offset",
|
|
"offset-anchor",
|
|
"offset-distance",
|
|
"offset-path",
|
|
"offset-position",
|
|
"offset-rotate",
|
|
"opacity",
|
|
"order",
|
|
"orphans",
|
|
"outline",
|
|
"outline-color",
|
|
"outline-offset",
|
|
"outline-style",
|
|
"outline-width",
|
|
"overflow",
|
|
"overflow-style",
|
|
"overflow-wrap",
|
|
"overflow-x",
|
|
"overflow-y",
|
|
"padding",
|
|
"padding-bottom",
|
|
"padding-left",
|
|
"padding-right",
|
|
"padding-top",
|
|
"page",
|
|
"page-break-after",
|
|
"page-break-before",
|
|
"page-break-inside",
|
|
"page-policy",
|
|
"pause",
|
|
"pause-after",
|
|
"pause-before",
|
|
"perspective",
|
|
"perspective-origin",
|
|
"pitch",
|
|
"pitch-range",
|
|
"place-content",
|
|
"place-items",
|
|
"place-self",
|
|
"play-during",
|
|
"position",
|
|
"presentation-level",
|
|
"punctuation-trim",
|
|
"quotes",
|
|
"region-break-after",
|
|
"region-break-before",
|
|
"region-break-inside",
|
|
"region-fragment",
|
|
"rendering-intent",
|
|
"resize",
|
|
"rest",
|
|
"rest-after",
|
|
"rest-before",
|
|
"richness",
|
|
"right",
|
|
"rotate",
|
|
"rotation",
|
|
"rotation-point",
|
|
"row-gap",
|
|
"ruby-align",
|
|
"ruby-overhang",
|
|
"ruby-position",
|
|
"ruby-span",
|
|
"scale",
|
|
"scroll-behavior",
|
|
"scroll-margin",
|
|
"scroll-margin-block",
|
|
"scroll-margin-block-end",
|
|
"scroll-margin-block-start",
|
|
"scroll-margin-bottom",
|
|
"scroll-margin-inline",
|
|
"scroll-margin-inline-end",
|
|
"scroll-margin-inline-start",
|
|
"scroll-margin-left",
|
|
"scroll-margin-right",
|
|
"scroll-margin-top",
|
|
"scroll-padding",
|
|
"scroll-padding-block",
|
|
"scroll-padding-block-end",
|
|
"scroll-padding-block-start",
|
|
"scroll-padding-bottom",
|
|
"scroll-padding-inline",
|
|
"scroll-padding-inline-end",
|
|
"scroll-padding-inline-start",
|
|
"scroll-padding-left",
|
|
"scroll-padding-right",
|
|
"scroll-padding-top",
|
|
"scroll-snap-align",
|
|
"scroll-snap-type",
|
|
"shape-image-threshold",
|
|
"shape-inside",
|
|
"shape-margin",
|
|
"shape-outside",
|
|
"size",
|
|
"speak",
|
|
"speak-as",
|
|
"speak-header",
|
|
"speak-numeral",
|
|
"speak-punctuation",
|
|
"speech-rate",
|
|
"stress",
|
|
"string-set",
|
|
"tab-size",
|
|
"table-layout",
|
|
"target",
|
|
"target-name",
|
|
"target-new",
|
|
"target-position",
|
|
"text-align",
|
|
"text-align-last",
|
|
"text-combine-upright",
|
|
"text-decoration",
|
|
"text-decoration-color",
|
|
"text-decoration-line",
|
|
"text-decoration-skip",
|
|
"text-decoration-skip-ink",
|
|
"text-decoration-style",
|
|
"text-emphasis",
|
|
"text-emphasis-color",
|
|
"text-emphasis-position",
|
|
"text-emphasis-style",
|
|
"text-height",
|
|
"text-indent",
|
|
"text-justify",
|
|
"text-orientation",
|
|
"text-outline",
|
|
"text-overflow",
|
|
"text-rendering",
|
|
"text-shadow",
|
|
"text-size-adjust",
|
|
"text-space-collapse",
|
|
"text-transform",
|
|
"text-underline-position",
|
|
"text-wrap",
|
|
"top",
|
|
"touch-action",
|
|
"transform",
|
|
"transform-origin",
|
|
"transform-style",
|
|
"transition",
|
|
"transition-delay",
|
|
"transition-duration",
|
|
"transition-property",
|
|
"transition-timing-function",
|
|
"translate",
|
|
"unicode-bidi",
|
|
"user-select",
|
|
"vertical-align",
|
|
"visibility",
|
|
"voice-balance",
|
|
"voice-duration",
|
|
"voice-family",
|
|
"voice-pitch",
|
|
"voice-range",
|
|
"voice-rate",
|
|
"voice-stress",
|
|
"voice-volume",
|
|
"volume",
|
|
"white-space",
|
|
"widows",
|
|
"width",
|
|
"will-change",
|
|
"word-break",
|
|
"word-spacing",
|
|
"word-wrap",
|
|
"writing-mode",
|
|
"z-index",
|
|
"clip-path",
|
|
"clip-rule",
|
|
"mask",
|
|
"enable-background",
|
|
"filter",
|
|
"flood-color",
|
|
"flood-opacity",
|
|
"lighting-color",
|
|
"stop-color",
|
|
"stop-opacity",
|
|
"pointer-events",
|
|
"color-interpolation",
|
|
"color-interpolation-filters",
|
|
"color-rendering",
|
|
"fill",
|
|
"fill-opacity",
|
|
"fill-rule",
|
|
"image-rendering",
|
|
"marker",
|
|
"marker-end",
|
|
"marker-mid",
|
|
"marker-start",
|
|
"paint-order",
|
|
"shape-rendering",
|
|
"stroke",
|
|
"stroke-dasharray",
|
|
"stroke-dashoffset",
|
|
"stroke-linecap",
|
|
"stroke-linejoin",
|
|
"stroke-miterlimit",
|
|
"stroke-opacity",
|
|
"stroke-width",
|
|
"text-rendering",
|
|
"baseline-shift",
|
|
"dominant-baseline",
|
|
"glyph-orientation-horizontal",
|
|
"glyph-orientation-vertical",
|
|
"text-anchor",
|
|
"writing-mode"
|
|
], propertyKeywords = keySet(propertyKeywords_);
|
|
var nonStandardPropertyKeywords_ = [
|
|
"accent-color",
|
|
"aspect-ratio",
|
|
"border-block",
|
|
"border-block-color",
|
|
"border-block-end",
|
|
"border-block-end-color",
|
|
"border-block-end-style",
|
|
"border-block-end-width",
|
|
"border-block-start",
|
|
"border-block-start-color",
|
|
"border-block-start-style",
|
|
"border-block-start-width",
|
|
"border-block-style",
|
|
"border-block-width",
|
|
"border-inline",
|
|
"border-inline-color",
|
|
"border-inline-end",
|
|
"border-inline-end-color",
|
|
"border-inline-end-style",
|
|
"border-inline-end-width",
|
|
"border-inline-start",
|
|
"border-inline-start-color",
|
|
"border-inline-start-style",
|
|
"border-inline-start-width",
|
|
"border-inline-style",
|
|
"border-inline-width",
|
|
"content-visibility",
|
|
"margin-block",
|
|
"margin-block-end",
|
|
"margin-block-start",
|
|
"margin-inline",
|
|
"margin-inline-end",
|
|
"margin-inline-start",
|
|
"overflow-anchor",
|
|
"overscroll-behavior",
|
|
"padding-block",
|
|
"padding-block-end",
|
|
"padding-block-start",
|
|
"padding-inline",
|
|
"padding-inline-end",
|
|
"padding-inline-start",
|
|
"scroll-snap-stop",
|
|
"scrollbar-3d-light-color",
|
|
"scrollbar-arrow-color",
|
|
"scrollbar-base-color",
|
|
"scrollbar-dark-shadow-color",
|
|
"scrollbar-face-color",
|
|
"scrollbar-highlight-color",
|
|
"scrollbar-shadow-color",
|
|
"scrollbar-track-color",
|
|
"searchfield-cancel-button",
|
|
"searchfield-decoration",
|
|
"searchfield-results-button",
|
|
"searchfield-results-decoration",
|
|
"shape-inside",
|
|
"zoom"
|
|
], nonStandardPropertyKeywords = keySet(nonStandardPropertyKeywords_);
|
|
var fontProperties_ = [
|
|
"font-display",
|
|
"font-family",
|
|
"src",
|
|
"unicode-range",
|
|
"font-variant",
|
|
"font-feature-settings",
|
|
"font-stretch",
|
|
"font-weight",
|
|
"font-style"
|
|
], fontProperties = keySet(fontProperties_);
|
|
var counterDescriptors_ = [
|
|
"additive-symbols",
|
|
"fallback",
|
|
"negative",
|
|
"pad",
|
|
"prefix",
|
|
"range",
|
|
"speak-as",
|
|
"suffix",
|
|
"symbols",
|
|
"system"
|
|
], counterDescriptors = keySet(counterDescriptors_);
|
|
var colorKeywords_ = [
|
|
"aliceblue",
|
|
"antiquewhite",
|
|
"aqua",
|
|
"aquamarine",
|
|
"azure",
|
|
"beige",
|
|
"bisque",
|
|
"black",
|
|
"blanchedalmond",
|
|
"blue",
|
|
"blueviolet",
|
|
"brown",
|
|
"burlywood",
|
|
"cadetblue",
|
|
"chartreuse",
|
|
"chocolate",
|
|
"coral",
|
|
"cornflowerblue",
|
|
"cornsilk",
|
|
"crimson",
|
|
"cyan",
|
|
"darkblue",
|
|
"darkcyan",
|
|
"darkgoldenrod",
|
|
"darkgray",
|
|
"darkgreen",
|
|
"darkgrey",
|
|
"darkkhaki",
|
|
"darkmagenta",
|
|
"darkolivegreen",
|
|
"darkorange",
|
|
"darkorchid",
|
|
"darkred",
|
|
"darksalmon",
|
|
"darkseagreen",
|
|
"darkslateblue",
|
|
"darkslategray",
|
|
"darkslategrey",
|
|
"darkturquoise",
|
|
"darkviolet",
|
|
"deeppink",
|
|
"deepskyblue",
|
|
"dimgray",
|
|
"dimgrey",
|
|
"dodgerblue",
|
|
"firebrick",
|
|
"floralwhite",
|
|
"forestgreen",
|
|
"fuchsia",
|
|
"gainsboro",
|
|
"ghostwhite",
|
|
"gold",
|
|
"goldenrod",
|
|
"gray",
|
|
"grey",
|
|
"green",
|
|
"greenyellow",
|
|
"honeydew",
|
|
"hotpink",
|
|
"indianred",
|
|
"indigo",
|
|
"ivory",
|
|
"khaki",
|
|
"lavender",
|
|
"lavenderblush",
|
|
"lawngreen",
|
|
"lemonchiffon",
|
|
"lightblue",
|
|
"lightcoral",
|
|
"lightcyan",
|
|
"lightgoldenrodyellow",
|
|
"lightgray",
|
|
"lightgreen",
|
|
"lightgrey",
|
|
"lightpink",
|
|
"lightsalmon",
|
|
"lightseagreen",
|
|
"lightskyblue",
|
|
"lightslategray",
|
|
"lightslategrey",
|
|
"lightsteelblue",
|
|
"lightyellow",
|
|
"lime",
|
|
"limegreen",
|
|
"linen",
|
|
"magenta",
|
|
"maroon",
|
|
"mediumaquamarine",
|
|
"mediumblue",
|
|
"mediumorchid",
|
|
"mediumpurple",
|
|
"mediumseagreen",
|
|
"mediumslateblue",
|
|
"mediumspringgreen",
|
|
"mediumturquoise",
|
|
"mediumvioletred",
|
|
"midnightblue",
|
|
"mintcream",
|
|
"mistyrose",
|
|
"moccasin",
|
|
"navajowhite",
|
|
"navy",
|
|
"oldlace",
|
|
"olive",
|
|
"olivedrab",
|
|
"orange",
|
|
"orangered",
|
|
"orchid",
|
|
"palegoldenrod",
|
|
"palegreen",
|
|
"paleturquoise",
|
|
"palevioletred",
|
|
"papayawhip",
|
|
"peachpuff",
|
|
"peru",
|
|
"pink",
|
|
"plum",
|
|
"powderblue",
|
|
"purple",
|
|
"rebeccapurple",
|
|
"red",
|
|
"rosybrown",
|
|
"royalblue",
|
|
"saddlebrown",
|
|
"salmon",
|
|
"sandybrown",
|
|
"seagreen",
|
|
"seashell",
|
|
"sienna",
|
|
"silver",
|
|
"skyblue",
|
|
"slateblue",
|
|
"slategray",
|
|
"slategrey",
|
|
"snow",
|
|
"springgreen",
|
|
"steelblue",
|
|
"tan",
|
|
"teal",
|
|
"thistle",
|
|
"tomato",
|
|
"turquoise",
|
|
"violet",
|
|
"wheat",
|
|
"white",
|
|
"whitesmoke",
|
|
"yellow",
|
|
"yellowgreen"
|
|
], colorKeywords = keySet(colorKeywords_);
|
|
var valueKeywords_ = [
|
|
"above",
|
|
"absolute",
|
|
"activeborder",
|
|
"additive",
|
|
"activecaption",
|
|
"afar",
|
|
"after-white-space",
|
|
"ahead",
|
|
"alias",
|
|
"all",
|
|
"all-scroll",
|
|
"alphabetic",
|
|
"alternate",
|
|
"always",
|
|
"amharic",
|
|
"amharic-abegede",
|
|
"antialiased",
|
|
"appworkspace",
|
|
"arabic-indic",
|
|
"armenian",
|
|
"asterisks",
|
|
"attr",
|
|
"auto",
|
|
"auto-flow",
|
|
"avoid",
|
|
"avoid-column",
|
|
"avoid-page",
|
|
"avoid-region",
|
|
"axis-pan",
|
|
"background",
|
|
"backwards",
|
|
"baseline",
|
|
"below",
|
|
"bidi-override",
|
|
"binary",
|
|
"bengali",
|
|
"blink",
|
|
"block",
|
|
"block-axis",
|
|
"blur",
|
|
"bold",
|
|
"bolder",
|
|
"border",
|
|
"border-box",
|
|
"both",
|
|
"bottom",
|
|
"break",
|
|
"break-all",
|
|
"break-word",
|
|
"brightness",
|
|
"bullets",
|
|
"button",
|
|
"buttonface",
|
|
"buttonhighlight",
|
|
"buttonshadow",
|
|
"buttontext",
|
|
"calc",
|
|
"cambodian",
|
|
"capitalize",
|
|
"caps-lock-indicator",
|
|
"caption",
|
|
"captiontext",
|
|
"caret",
|
|
"cell",
|
|
"center",
|
|
"checkbox",
|
|
"circle",
|
|
"cjk-decimal",
|
|
"cjk-earthly-branch",
|
|
"cjk-heavenly-stem",
|
|
"cjk-ideographic",
|
|
"clear",
|
|
"clip",
|
|
"close-quote",
|
|
"col-resize",
|
|
"collapse",
|
|
"color",
|
|
"color-burn",
|
|
"color-dodge",
|
|
"column",
|
|
"column-reverse",
|
|
"compact",
|
|
"condensed",
|
|
"conic-gradient",
|
|
"contain",
|
|
"content",
|
|
"contents",
|
|
"content-box",
|
|
"context-menu",
|
|
"continuous",
|
|
"contrast",
|
|
"copy",
|
|
"counter",
|
|
"counters",
|
|
"cover",
|
|
"crop",
|
|
"cross",
|
|
"crosshair",
|
|
"cubic-bezier",
|
|
"currentcolor",
|
|
"cursive",
|
|
"cyclic",
|
|
"darken",
|
|
"dashed",
|
|
"decimal",
|
|
"decimal-leading-zero",
|
|
"default",
|
|
"default-button",
|
|
"dense",
|
|
"destination-atop",
|
|
"destination-in",
|
|
"destination-out",
|
|
"destination-over",
|
|
"devanagari",
|
|
"difference",
|
|
"disc",
|
|
"discard",
|
|
"disclosure-closed",
|
|
"disclosure-open",
|
|
"document",
|
|
"dot-dash",
|
|
"dot-dot-dash",
|
|
"dotted",
|
|
"double",
|
|
"down",
|
|
"drop-shadow",
|
|
"e-resize",
|
|
"ease",
|
|
"ease-in",
|
|
"ease-in-out",
|
|
"ease-out",
|
|
"element",
|
|
"ellipse",
|
|
"ellipsis",
|
|
"embed",
|
|
"end",
|
|
"ethiopic",
|
|
"ethiopic-abegede",
|
|
"ethiopic-abegede-am-et",
|
|
"ethiopic-abegede-gez",
|
|
"ethiopic-abegede-ti-er",
|
|
"ethiopic-abegede-ti-et",
|
|
"ethiopic-halehame-aa-er",
|
|
"ethiopic-halehame-aa-et",
|
|
"ethiopic-halehame-am-et",
|
|
"ethiopic-halehame-gez",
|
|
"ethiopic-halehame-om-et",
|
|
"ethiopic-halehame-sid-et",
|
|
"ethiopic-halehame-so-et",
|
|
"ethiopic-halehame-ti-er",
|
|
"ethiopic-halehame-ti-et",
|
|
"ethiopic-halehame-tig",
|
|
"ethiopic-numeric",
|
|
"ew-resize",
|
|
"exclusion",
|
|
"expanded",
|
|
"extends",
|
|
"extra-condensed",
|
|
"extra-expanded",
|
|
"fantasy",
|
|
"fast",
|
|
"fill",
|
|
"fill-box",
|
|
"fixed",
|
|
"flat",
|
|
"flex",
|
|
"flex-end",
|
|
"flex-start",
|
|
"footnotes",
|
|
"forwards",
|
|
"from",
|
|
"geometricPrecision",
|
|
"georgian",
|
|
"grayscale",
|
|
"graytext",
|
|
"grid",
|
|
"groove",
|
|
"gujarati",
|
|
"gurmukhi",
|
|
"hand",
|
|
"hangul",
|
|
"hangul-consonant",
|
|
"hard-light",
|
|
"hebrew",
|
|
"help",
|
|
"hidden",
|
|
"hide",
|
|
"higher",
|
|
"highlight",
|
|
"highlighttext",
|
|
"hiragana",
|
|
"hiragana-iroha",
|
|
"horizontal",
|
|
"hsl",
|
|
"hsla",
|
|
"hue",
|
|
"hue-rotate",
|
|
"icon",
|
|
"ignore",
|
|
"inactiveborder",
|
|
"inactivecaption",
|
|
"inactivecaptiontext",
|
|
"infinite",
|
|
"infobackground",
|
|
"infotext",
|
|
"inherit",
|
|
"initial",
|
|
"inline",
|
|
"inline-axis",
|
|
"inline-block",
|
|
"inline-flex",
|
|
"inline-grid",
|
|
"inline-table",
|
|
"inset",
|
|
"inside",
|
|
"intrinsic",
|
|
"invert",
|
|
"italic",
|
|
"japanese-formal",
|
|
"japanese-informal",
|
|
"justify",
|
|
"kannada",
|
|
"katakana",
|
|
"katakana-iroha",
|
|
"keep-all",
|
|
"khmer",
|
|
"korean-hangul-formal",
|
|
"korean-hanja-formal",
|
|
"korean-hanja-informal",
|
|
"landscape",
|
|
"lao",
|
|
"large",
|
|
"larger",
|
|
"left",
|
|
"level",
|
|
"lighter",
|
|
"lighten",
|
|
"line-through",
|
|
"linear",
|
|
"linear-gradient",
|
|
"lines",
|
|
"list-item",
|
|
"listbox",
|
|
"listitem",
|
|
"local",
|
|
"logical",
|
|
"loud",
|
|
"lower",
|
|
"lower-alpha",
|
|
"lower-armenian",
|
|
"lower-greek",
|
|
"lower-hexadecimal",
|
|
"lower-latin",
|
|
"lower-norwegian",
|
|
"lower-roman",
|
|
"lowercase",
|
|
"ltr",
|
|
"luminosity",
|
|
"malayalam",
|
|
"manipulation",
|
|
"match",
|
|
"matrix",
|
|
"matrix3d",
|
|
"media-play-button",
|
|
"media-slider",
|
|
"media-sliderthumb",
|
|
"media-volume-slider",
|
|
"media-volume-sliderthumb",
|
|
"medium",
|
|
"menu",
|
|
"menulist",
|
|
"menulist-button",
|
|
"menutext",
|
|
"message-box",
|
|
"middle",
|
|
"min-intrinsic",
|
|
"mix",
|
|
"mongolian",
|
|
"monospace",
|
|
"move",
|
|
"multiple",
|
|
"multiple_mask_images",
|
|
"multiply",
|
|
"myanmar",
|
|
"n-resize",
|
|
"narrower",
|
|
"ne-resize",
|
|
"nesw-resize",
|
|
"no-close-quote",
|
|
"no-drop",
|
|
"no-open-quote",
|
|
"no-repeat",
|
|
"none",
|
|
"normal",
|
|
"not-allowed",
|
|
"nowrap",
|
|
"ns-resize",
|
|
"numbers",
|
|
"numeric",
|
|
"nw-resize",
|
|
"nwse-resize",
|
|
"oblique",
|
|
"octal",
|
|
"opacity",
|
|
"open-quote",
|
|
"optimizeLegibility",
|
|
"optimizeSpeed",
|
|
"oriya",
|
|
"oromo",
|
|
"outset",
|
|
"outside",
|
|
"outside-shape",
|
|
"overlay",
|
|
"overline",
|
|
"padding",
|
|
"padding-box",
|
|
"painted",
|
|
"page",
|
|
"paused",
|
|
"persian",
|
|
"perspective",
|
|
"pinch-zoom",
|
|
"plus-darker",
|
|
"plus-lighter",
|
|
"pointer",
|
|
"polygon",
|
|
"portrait",
|
|
"pre",
|
|
"pre-line",
|
|
"pre-wrap",
|
|
"preserve-3d",
|
|
"progress",
|
|
"push-button",
|
|
"radial-gradient",
|
|
"radio",
|
|
"read-only",
|
|
"read-write",
|
|
"read-write-plaintext-only",
|
|
"rectangle",
|
|
"region",
|
|
"relative",
|
|
"repeat",
|
|
"repeating-linear-gradient",
|
|
"repeating-radial-gradient",
|
|
"repeating-conic-gradient",
|
|
"repeat-x",
|
|
"repeat-y",
|
|
"reset",
|
|
"reverse",
|
|
"rgb",
|
|
"rgba",
|
|
"ridge",
|
|
"right",
|
|
"rotate",
|
|
"rotate3d",
|
|
"rotateX",
|
|
"rotateY",
|
|
"rotateZ",
|
|
"round",
|
|
"row",
|
|
"row-resize",
|
|
"row-reverse",
|
|
"rtl",
|
|
"run-in",
|
|
"running",
|
|
"s-resize",
|
|
"sans-serif",
|
|
"saturate",
|
|
"saturation",
|
|
"scale",
|
|
"scale3d",
|
|
"scaleX",
|
|
"scaleY",
|
|
"scaleZ",
|
|
"screen",
|
|
"scroll",
|
|
"scrollbar",
|
|
"scroll-position",
|
|
"se-resize",
|
|
"searchfield",
|
|
"searchfield-cancel-button",
|
|
"searchfield-decoration",
|
|
"searchfield-results-button",
|
|
"searchfield-results-decoration",
|
|
"self-start",
|
|
"self-end",
|
|
"semi-condensed",
|
|
"semi-expanded",
|
|
"separate",
|
|
"sepia",
|
|
"serif",
|
|
"show",
|
|
"sidama",
|
|
"simp-chinese-formal",
|
|
"simp-chinese-informal",
|
|
"single",
|
|
"skew",
|
|
"skewX",
|
|
"skewY",
|
|
"skip-white-space",
|
|
"slide",
|
|
"slider-horizontal",
|
|
"slider-vertical",
|
|
"sliderthumb-horizontal",
|
|
"sliderthumb-vertical",
|
|
"slow",
|
|
"small",
|
|
"small-caps",
|
|
"small-caption",
|
|
"smaller",
|
|
"soft-light",
|
|
"solid",
|
|
"somali",
|
|
"source-atop",
|
|
"source-in",
|
|
"source-out",
|
|
"source-over",
|
|
"space",
|
|
"space-around",
|
|
"space-between",
|
|
"space-evenly",
|
|
"spell-out",
|
|
"square",
|
|
"square-button",
|
|
"start",
|
|
"static",
|
|
"status-bar",
|
|
"stretch",
|
|
"stroke",
|
|
"stroke-box",
|
|
"sub",
|
|
"subpixel-antialiased",
|
|
"svg_masks",
|
|
"super",
|
|
"sw-resize",
|
|
"symbolic",
|
|
"symbols",
|
|
"system-ui",
|
|
"table",
|
|
"table-caption",
|
|
"table-cell",
|
|
"table-column",
|
|
"table-column-group",
|
|
"table-footer-group",
|
|
"table-header-group",
|
|
"table-row",
|
|
"table-row-group",
|
|
"tamil",
|
|
"telugu",
|
|
"text",
|
|
"text-bottom",
|
|
"text-top",
|
|
"textarea",
|
|
"textfield",
|
|
"thai",
|
|
"thick",
|
|
"thin",
|
|
"threeddarkshadow",
|
|
"threedface",
|
|
"threedhighlight",
|
|
"threedlightshadow",
|
|
"threedshadow",
|
|
"tibetan",
|
|
"tigre",
|
|
"tigrinya-er",
|
|
"tigrinya-er-abegede",
|
|
"tigrinya-et",
|
|
"tigrinya-et-abegede",
|
|
"to",
|
|
"top",
|
|
"trad-chinese-formal",
|
|
"trad-chinese-informal",
|
|
"transform",
|
|
"translate",
|
|
"translate3d",
|
|
"translateX",
|
|
"translateY",
|
|
"translateZ",
|
|
"transparent",
|
|
"ultra-condensed",
|
|
"ultra-expanded",
|
|
"underline",
|
|
"unidirectional-pan",
|
|
"unset",
|
|
"up",
|
|
"upper-alpha",
|
|
"upper-armenian",
|
|
"upper-greek",
|
|
"upper-hexadecimal",
|
|
"upper-latin",
|
|
"upper-norwegian",
|
|
"upper-roman",
|
|
"uppercase",
|
|
"urdu",
|
|
"url",
|
|
"var",
|
|
"vertical",
|
|
"vertical-text",
|
|
"view-box",
|
|
"visible",
|
|
"visibleFill",
|
|
"visiblePainted",
|
|
"visibleStroke",
|
|
"visual",
|
|
"w-resize",
|
|
"wait",
|
|
"wave",
|
|
"wider",
|
|
"window",
|
|
"windowframe",
|
|
"windowtext",
|
|
"words",
|
|
"wrap",
|
|
"wrap-reverse",
|
|
"x-large",
|
|
"x-small",
|
|
"xor",
|
|
"xx-large",
|
|
"xx-small"
|
|
], valueKeywords = keySet(valueKeywords_);
|
|
var allWords = documentTypes_.concat(mediaTypes_).concat(mediaFeatures_).concat(mediaValueKeywords_).concat(propertyKeywords_).concat(nonStandardPropertyKeywords_).concat(colorKeywords_).concat(valueKeywords_);
|
|
CodeMirror$1.registerHelper("hintWords", "css", allWords);
|
|
function tokenCComment(stream, state) {
|
|
var maybeEnd = false, ch;
|
|
while ((ch = stream.next()) != null) {
|
|
if (maybeEnd && ch == "/") {
|
|
state.tokenize = null;
|
|
break;
|
|
}
|
|
maybeEnd = ch == "*";
|
|
}
|
|
return ["comment", "comment"];
|
|
}
|
|
CodeMirror$1.defineMIME("text/css", {
|
|
documentTypes,
|
|
mediaTypes,
|
|
mediaFeatures,
|
|
mediaValueKeywords,
|
|
propertyKeywords,
|
|
nonStandardPropertyKeywords,
|
|
fontProperties,
|
|
counterDescriptors,
|
|
colorKeywords,
|
|
valueKeywords,
|
|
tokenHooks: { "/": function(stream, state) {
|
|
if (!stream.eat("*")) return false;
|
|
state.tokenize = tokenCComment;
|
|
return tokenCComment(stream, state);
|
|
} },
|
|
name: "css"
|
|
});
|
|
CodeMirror$1.defineMIME("text/x-scss", {
|
|
mediaTypes,
|
|
mediaFeatures,
|
|
mediaValueKeywords,
|
|
propertyKeywords,
|
|
nonStandardPropertyKeywords,
|
|
colorKeywords,
|
|
valueKeywords,
|
|
fontProperties,
|
|
allowNested: true,
|
|
lineComment: "//",
|
|
tokenHooks: {
|
|
"/": function(stream, state) {
|
|
if (stream.eat("/")) {
|
|
stream.skipToEnd();
|
|
return ["comment", "comment"];
|
|
} else if (stream.eat("*")) {
|
|
state.tokenize = tokenCComment;
|
|
return tokenCComment(stream, state);
|
|
} else return ["operator", "operator"];
|
|
},
|
|
":": function(stream) {
|
|
if (stream.match(/^\s*\{/, false)) return [null, null];
|
|
return false;
|
|
},
|
|
"$": function(stream) {
|
|
stream.match(/^[\w-]+/);
|
|
if (stream.match(/^\s*:/, false)) return ["variable-2", "variable-definition"];
|
|
return ["variable-2", "variable"];
|
|
},
|
|
"#": function(stream) {
|
|
if (!stream.eat("{")) return false;
|
|
return [null, "interpolation"];
|
|
}
|
|
},
|
|
name: "css",
|
|
helperType: "scss"
|
|
});
|
|
CodeMirror$1.defineMIME("text/x-less", {
|
|
mediaTypes,
|
|
mediaFeatures,
|
|
mediaValueKeywords,
|
|
propertyKeywords,
|
|
nonStandardPropertyKeywords,
|
|
colorKeywords,
|
|
valueKeywords,
|
|
fontProperties,
|
|
allowNested: true,
|
|
lineComment: "//",
|
|
tokenHooks: {
|
|
"/": function(stream, state) {
|
|
if (stream.eat("/")) {
|
|
stream.skipToEnd();
|
|
return ["comment", "comment"];
|
|
} else if (stream.eat("*")) {
|
|
state.tokenize = tokenCComment;
|
|
return tokenCComment(stream, state);
|
|
} else return ["operator", "operator"];
|
|
},
|
|
"@": function(stream) {
|
|
if (stream.eat("{")) return [null, "interpolation"];
|
|
if (stream.match(/^(charset|document|font-face|import|(-(moz|ms|o|webkit)-)?keyframes|media|namespace|page|supports)\b/i, false)) return false;
|
|
stream.eatWhile(/[\w\\\-]/);
|
|
if (stream.match(/^\s*:/, false)) return ["variable-2", "variable-definition"];
|
|
return ["variable-2", "variable"];
|
|
},
|
|
"&": function() {
|
|
return ["atom", "atom"];
|
|
}
|
|
},
|
|
name: "css",
|
|
helperType: "less"
|
|
});
|
|
CodeMirror$1.defineMIME("text/x-gss", {
|
|
documentTypes,
|
|
mediaTypes,
|
|
mediaFeatures,
|
|
propertyKeywords,
|
|
nonStandardPropertyKeywords,
|
|
fontProperties,
|
|
counterDescriptors,
|
|
colorKeywords,
|
|
valueKeywords,
|
|
supportsAtComponent: true,
|
|
tokenHooks: { "/": function(stream, state) {
|
|
if (!stream.eat("*")) return false;
|
|
state.tokenize = tokenCComment;
|
|
return tokenCComment(stream, state);
|
|
} },
|
|
name: "css",
|
|
helperType: "gss"
|
|
});
|
|
});
|
|
});
|
|
var require_simple = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineSimpleMode = function(name, states) {
|
|
CodeMirror$1.defineMode(name, function(config) {
|
|
return CodeMirror$1.simpleMode(config, states);
|
|
});
|
|
};
|
|
CodeMirror$1.simpleMode = function(config, states) {
|
|
ensureState(states, "start");
|
|
var states_ = {}, meta = states.meta || {}, hasIndentation = false;
|
|
for (var state in states) if (state != meta && states.hasOwnProperty(state)) {
|
|
var list = states_[state] = [], orig = states[state];
|
|
for (var i = 0; i < orig.length; i++) {
|
|
var data = orig[i];
|
|
list.push(new Rule(data, states));
|
|
if (data.indent || data.dedent) hasIndentation = true;
|
|
}
|
|
}
|
|
var mode = {
|
|
startState: function() {
|
|
return {
|
|
state: "start",
|
|
pending: null,
|
|
local: null,
|
|
localState: null,
|
|
indent: hasIndentation ? [] : null
|
|
};
|
|
},
|
|
copyState: function(state$1) {
|
|
var s = {
|
|
state: state$1.state,
|
|
pending: state$1.pending,
|
|
local: state$1.local,
|
|
localState: null,
|
|
indent: state$1.indent && state$1.indent.slice(0)
|
|
};
|
|
if (state$1.localState) s.localState = CodeMirror$1.copyState(state$1.local.mode, state$1.localState);
|
|
if (state$1.stack) s.stack = state$1.stack.slice(0);
|
|
for (var pers = state$1.persistentStates; pers; pers = pers.next) s.persistentStates = {
|
|
mode: pers.mode,
|
|
spec: pers.spec,
|
|
state: pers.state == state$1.localState ? s.localState : CodeMirror$1.copyState(pers.mode, pers.state),
|
|
next: s.persistentStates
|
|
};
|
|
return s;
|
|
},
|
|
token: tokenFunction(states_, config),
|
|
innerMode: function(state$1) {
|
|
return state$1.local && {
|
|
mode: state$1.local.mode,
|
|
state: state$1.localState
|
|
};
|
|
},
|
|
indent: indentFunction(states_, meta)
|
|
};
|
|
if (meta) {
|
|
for (var prop in meta) if (meta.hasOwnProperty(prop)) mode[prop] = meta[prop];
|
|
}
|
|
return mode;
|
|
};
|
|
function ensureState(states, name) {
|
|
if (!states.hasOwnProperty(name)) throw new Error("Undefined state " + name + " in simple mode");
|
|
}
|
|
function toRegex(val, caret) {
|
|
if (!val) return /(?:)/;
|
|
var flags = "";
|
|
if (val instanceof RegExp) {
|
|
if (val.ignoreCase) flags = "i";
|
|
if (val.unicode) flags += "u";
|
|
val = val.source;
|
|
} else val = String(val);
|
|
return new RegExp((caret === false ? "" : "^") + "(?:" + val + ")", flags);
|
|
}
|
|
function asToken(val) {
|
|
if (!val) return null;
|
|
if (val.apply) return val;
|
|
if (typeof val == "string") return val.replace(/\./g, " ");
|
|
var result = [];
|
|
for (var i = 0; i < val.length; i++) result.push(val[i] && val[i].replace(/\./g, " "));
|
|
return result;
|
|
}
|
|
function Rule(data, states) {
|
|
if (data.next || data.push) ensureState(states, data.next || data.push);
|
|
this.regex = toRegex(data.regex);
|
|
this.token = asToken(data.token);
|
|
this.data = data;
|
|
}
|
|
function tokenFunction(states, config) {
|
|
return function(stream, state) {
|
|
if (state.pending) {
|
|
var pend = state.pending.shift();
|
|
if (state.pending.length == 0) state.pending = null;
|
|
stream.pos += pend.text.length;
|
|
return pend.token;
|
|
}
|
|
if (state.local) if (state.local.end && stream.match(state.local.end)) {
|
|
var tok = state.local.endToken || null;
|
|
state.local = state.localState = null;
|
|
return tok;
|
|
} else {
|
|
var tok = state.local.mode.token(stream, state.localState), m;
|
|
if (state.local.endScan && (m = state.local.endScan.exec(stream.current()))) stream.pos = stream.start + m.index;
|
|
return tok;
|
|
}
|
|
var curState = states[state.state];
|
|
for (var i = 0; i < curState.length; i++) {
|
|
var rule = curState[i];
|
|
var matches = (!rule.data.sol || stream.sol()) && stream.match(rule.regex);
|
|
if (matches) {
|
|
if (rule.data.next) state.state = rule.data.next;
|
|
else if (rule.data.push) {
|
|
(state.stack || (state.stack = [])).push(state.state);
|
|
state.state = rule.data.push;
|
|
} else if (rule.data.pop && state.stack && state.stack.length) state.state = state.stack.pop();
|
|
if (rule.data.mode) enterLocalMode(config, state, rule.data.mode, rule.token);
|
|
if (rule.data.indent) state.indent.push(stream.indentation() + config.indentUnit);
|
|
if (rule.data.dedent) state.indent.pop();
|
|
var token = rule.token;
|
|
if (token && token.apply) token = token(matches);
|
|
if (matches.length > 2 && rule.token && typeof rule.token != "string") {
|
|
for (var j = 2; j < matches.length; j++) if (matches[j]) (state.pending || (state.pending = [])).push({
|
|
text: matches[j],
|
|
token: rule.token[j - 1]
|
|
});
|
|
stream.backUp(matches[0].length - (matches[1] ? matches[1].length : 0));
|
|
return token[0];
|
|
} else if (token && token.join) return token[0];
|
|
else return token;
|
|
}
|
|
}
|
|
stream.next();
|
|
return null;
|
|
};
|
|
}
|
|
function cmp(a, b) {
|
|
if (a === b) return true;
|
|
if (!a || typeof a != "object" || !b || typeof b != "object") return false;
|
|
var props = 0;
|
|
for (var prop in a) if (a.hasOwnProperty(prop)) {
|
|
if (!b.hasOwnProperty(prop) || !cmp(a[prop], b[prop])) return false;
|
|
props++;
|
|
}
|
|
for (var prop in b) if (b.hasOwnProperty(prop)) props--;
|
|
return props == 0;
|
|
}
|
|
function enterLocalMode(config, state, spec, token) {
|
|
var pers;
|
|
if (spec.persistent) {
|
|
for (var p = state.persistentStates; p && !pers; p = p.next) if (spec.spec ? cmp(spec.spec, p.spec) : spec.mode == p.mode) pers = p;
|
|
}
|
|
var mode = pers ? pers.mode : spec.mode || CodeMirror$1.getMode(config, spec.spec);
|
|
var lState = pers ? pers.state : CodeMirror$1.startState(mode);
|
|
if (spec.persistent && !pers) state.persistentStates = {
|
|
mode,
|
|
spec: spec.spec,
|
|
state: lState,
|
|
next: state.persistentStates
|
|
};
|
|
state.localState = lState;
|
|
state.local = {
|
|
mode,
|
|
end: spec.end && toRegex(spec.end),
|
|
endScan: spec.end && spec.forceEnd !== false && toRegex(spec.end, false),
|
|
endToken: token && token.join ? token[token.length - 1] : token
|
|
};
|
|
}
|
|
function indexOf(val, arr) {
|
|
for (var i = 0; i < arr.length; i++) if (arr[i] === val) return true;
|
|
}
|
|
function indentFunction(states, meta) {
|
|
return function(state, textAfter, line) {
|
|
if (state.local && state.local.mode.indent) return state.local.mode.indent(state.localState, textAfter, line);
|
|
if (state.indent == null || state.local || meta.dontIndentStates && indexOf(state.state, meta.dontIndentStates) > -1) return CodeMirror$1.Pass;
|
|
var pos = state.indent.length - 1, rules = states[state.state];
|
|
scan: for (;;) {
|
|
for (var i = 0; i < rules.length; i++) {
|
|
var rule = rules[i];
|
|
if (rule.data.dedent && rule.data.dedentIfLineStart !== false) {
|
|
var m = rule.regex.exec(textAfter);
|
|
if (m && m[0]) {
|
|
pos--;
|
|
if (rule.next || rule.push) rules = states[rule.next || rule.push];
|
|
textAfter = textAfter.slice(m[0].length);
|
|
continue scan;
|
|
}
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
return pos < 0 ? 0 : state.indent[pos];
|
|
};
|
|
}
|
|
});
|
|
});
|
|
var require_multiplex = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.multiplexingMode = function(outer) {
|
|
var others = Array.prototype.slice.call(arguments, 1);
|
|
function indexOf(string, pattern, from, returnEnd) {
|
|
if (typeof pattern == "string") {
|
|
var found = string.indexOf(pattern, from);
|
|
return returnEnd && found > -1 ? found + pattern.length : found;
|
|
}
|
|
var m = pattern.exec(from ? string.slice(from) : string);
|
|
return m ? m.index + from + (returnEnd ? m[0].length : 0) : -1;
|
|
}
|
|
return {
|
|
startState: function() {
|
|
return {
|
|
outer: CodeMirror$1.startState(outer),
|
|
innerActive: null,
|
|
inner: null,
|
|
startingInner: false
|
|
};
|
|
},
|
|
copyState: function(state) {
|
|
return {
|
|
outer: CodeMirror$1.copyState(outer, state.outer),
|
|
innerActive: state.innerActive,
|
|
inner: state.innerActive && CodeMirror$1.copyState(state.innerActive.mode, state.inner),
|
|
startingInner: state.startingInner
|
|
};
|
|
},
|
|
token: function(stream, state) {
|
|
if (!state.innerActive) {
|
|
var cutOff = Infinity, oldContent = stream.string;
|
|
for (var i = 0; i < others.length; ++i) {
|
|
var other = others[i];
|
|
var found = indexOf(oldContent, other.open, stream.pos);
|
|
if (found == stream.pos) {
|
|
if (!other.parseDelimiters) stream.match(other.open);
|
|
state.startingInner = !!other.parseDelimiters;
|
|
state.innerActive = other;
|
|
var outerIndent = 0;
|
|
if (outer.indent) {
|
|
var possibleOuterIndent = outer.indent(state.outer, "", "");
|
|
if (possibleOuterIndent !== CodeMirror$1.Pass) outerIndent = possibleOuterIndent;
|
|
}
|
|
state.inner = CodeMirror$1.startState(other.mode, outerIndent);
|
|
return other.delimStyle && other.delimStyle + " " + other.delimStyle + "-open";
|
|
} else if (found != -1 && found < cutOff) cutOff = found;
|
|
}
|
|
if (cutOff != Infinity) stream.string = oldContent.slice(0, cutOff);
|
|
var outerToken = outer.token(stream, state.outer);
|
|
if (cutOff != Infinity) stream.string = oldContent;
|
|
return outerToken;
|
|
} else {
|
|
var curInner = state.innerActive, oldContent = stream.string;
|
|
if (!curInner.close && stream.sol()) {
|
|
state.innerActive = state.inner = null;
|
|
return this.token(stream, state);
|
|
}
|
|
var found = curInner.close && !state.startingInner ? indexOf(oldContent, curInner.close, stream.pos, curInner.parseDelimiters) : -1;
|
|
if (found == stream.pos && !curInner.parseDelimiters) {
|
|
stream.match(curInner.close);
|
|
state.innerActive = state.inner = null;
|
|
return curInner.delimStyle && curInner.delimStyle + " " + curInner.delimStyle + "-close";
|
|
}
|
|
if (found > -1) stream.string = oldContent.slice(0, found);
|
|
var innerToken = curInner.mode.token(stream, state.inner);
|
|
if (found > -1) stream.string = oldContent;
|
|
else if (stream.pos > stream.start) state.startingInner = false;
|
|
if (found == stream.pos && curInner.parseDelimiters) state.innerActive = state.inner = null;
|
|
if (curInner.innerStyle) if (innerToken) innerToken = innerToken + " " + curInner.innerStyle;
|
|
else innerToken = curInner.innerStyle;
|
|
return innerToken;
|
|
}
|
|
},
|
|
indent: function(state, textAfter, line) {
|
|
var mode = state.innerActive ? state.innerActive.mode : outer;
|
|
if (!mode.indent) return CodeMirror$1.Pass;
|
|
return mode.indent(state.innerActive ? state.inner : state.outer, textAfter, line);
|
|
},
|
|
blankLine: function(state) {
|
|
var mode = state.innerActive ? state.innerActive.mode : outer;
|
|
if (mode.blankLine) mode.blankLine(state.innerActive ? state.inner : state.outer);
|
|
if (!state.innerActive) for (var i = 0; i < others.length; ++i) {
|
|
var other = others[i];
|
|
if (other.open === "\n") {
|
|
state.innerActive = other;
|
|
state.inner = CodeMirror$1.startState(other.mode, mode.indent ? mode.indent(state.outer, "", "") : 0);
|
|
}
|
|
}
|
|
else if (state.innerActive.close === "\n") state.innerActive = state.inner = null;
|
|
},
|
|
electricChars: outer.electricChars,
|
|
innerMode: function(state) {
|
|
return state.inner ? {
|
|
state: state.inner,
|
|
mode: state.innerActive.mode
|
|
} : {
|
|
state: state.outer,
|
|
mode: outer
|
|
};
|
|
}
|
|
};
|
|
};
|
|
});
|
|
});
|
|
var require_handlebars = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror(), require_simple(), require_multiplex());
|
|
else if (typeof define == "function" && define.amd) define([
|
|
"../../lib/codemirror",
|
|
"../../addon/mode/simple",
|
|
"../../addon/mode/multiplex"
|
|
], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineSimpleMode("handlebars-tags", {
|
|
start: [
|
|
{
|
|
regex: /\{\{\{/,
|
|
push: "handlebars_raw",
|
|
token: "tag"
|
|
},
|
|
{
|
|
regex: /\{\{!--/,
|
|
push: "dash_comment",
|
|
token: "comment"
|
|
},
|
|
{
|
|
regex: /\{\{!/,
|
|
push: "comment",
|
|
token: "comment"
|
|
},
|
|
{
|
|
regex: /\{\{/,
|
|
push: "handlebars",
|
|
token: "tag"
|
|
}
|
|
],
|
|
handlebars_raw: [{
|
|
regex: /\}\}\}/,
|
|
pop: true,
|
|
token: "tag"
|
|
}],
|
|
handlebars: [
|
|
{
|
|
regex: /\}\}/,
|
|
pop: true,
|
|
token: "tag"
|
|
},
|
|
{
|
|
regex: /"(?:[^\\"]|\\.)*"?/,
|
|
token: "string"
|
|
},
|
|
{
|
|
regex: /'(?:[^\\']|\\.)*'?/,
|
|
token: "string"
|
|
},
|
|
{
|
|
regex: />|[#\/]([A-Za-z_]\w*)/,
|
|
token: "keyword"
|
|
},
|
|
{
|
|
regex: /(?:else|this)\b/,
|
|
token: "keyword"
|
|
},
|
|
{
|
|
regex: /\d+/i,
|
|
token: "number"
|
|
},
|
|
{
|
|
regex: /=|~|@|true|false/,
|
|
token: "atom"
|
|
},
|
|
{
|
|
regex: /(?:\.\.\/)*(?:[A-Za-z_][\w\.]*)+/,
|
|
token: "variable-2"
|
|
}
|
|
],
|
|
dash_comment: [{
|
|
regex: /--\}\}/,
|
|
pop: true,
|
|
token: "comment"
|
|
}, {
|
|
regex: /./,
|
|
token: "comment"
|
|
}],
|
|
comment: [{
|
|
regex: /\}\}/,
|
|
pop: true,
|
|
token: "comment"
|
|
}, {
|
|
regex: /./,
|
|
token: "comment"
|
|
}],
|
|
meta: {
|
|
blockCommentStart: "{{--",
|
|
blockCommentEnd: "--}}"
|
|
}
|
|
});
|
|
CodeMirror$1.defineMode("handlebars", function(config, parserConfig) {
|
|
var handlebars = CodeMirror$1.getMode(config, "handlebars-tags");
|
|
if (!parserConfig || !parserConfig.base) return handlebars;
|
|
return CodeMirror$1.multiplexingMode(CodeMirror$1.getMode(config, parserConfig.base), {
|
|
open: "{{",
|
|
close: /\}\}\}?/,
|
|
mode: handlebars,
|
|
parseDelimiters: true
|
|
});
|
|
});
|
|
CodeMirror$1.defineMIME("text/x-handlebars-template", "handlebars");
|
|
});
|
|
});
|
|
var require_xml = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
var htmlConfig = {
|
|
autoSelfClosers: {
|
|
"area": true,
|
|
"base": true,
|
|
"br": true,
|
|
"col": true,
|
|
"command": true,
|
|
"embed": true,
|
|
"frame": true,
|
|
"hr": true,
|
|
"img": true,
|
|
"input": true,
|
|
"keygen": true,
|
|
"link": true,
|
|
"meta": true,
|
|
"param": true,
|
|
"source": true,
|
|
"track": true,
|
|
"wbr": true,
|
|
"menuitem": true
|
|
},
|
|
implicitlyClosed: {
|
|
"dd": true,
|
|
"li": true,
|
|
"optgroup": true,
|
|
"option": true,
|
|
"p": true,
|
|
"rp": true,
|
|
"rt": true,
|
|
"tbody": true,
|
|
"td": true,
|
|
"tfoot": true,
|
|
"th": true,
|
|
"tr": true
|
|
},
|
|
contextGrabbers: {
|
|
"dd": {
|
|
"dd": true,
|
|
"dt": true
|
|
},
|
|
"dt": {
|
|
"dd": true,
|
|
"dt": true
|
|
},
|
|
"li": { "li": true },
|
|
"option": {
|
|
"option": true,
|
|
"optgroup": true
|
|
},
|
|
"optgroup": { "optgroup": true },
|
|
"p": {
|
|
"address": true,
|
|
"article": true,
|
|
"aside": true,
|
|
"blockquote": true,
|
|
"dir": true,
|
|
"div": true,
|
|
"dl": true,
|
|
"fieldset": true,
|
|
"footer": true,
|
|
"form": true,
|
|
"h1": true,
|
|
"h2": true,
|
|
"h3": true,
|
|
"h4": true,
|
|
"h5": true,
|
|
"h6": true,
|
|
"header": true,
|
|
"hgroup": true,
|
|
"hr": true,
|
|
"menu": true,
|
|
"nav": true,
|
|
"ol": true,
|
|
"p": true,
|
|
"pre": true,
|
|
"section": true,
|
|
"table": true,
|
|
"ul": true
|
|
},
|
|
"rp": {
|
|
"rp": true,
|
|
"rt": true
|
|
},
|
|
"rt": {
|
|
"rp": true,
|
|
"rt": true
|
|
},
|
|
"tbody": {
|
|
"tbody": true,
|
|
"tfoot": true
|
|
},
|
|
"td": {
|
|
"td": true,
|
|
"th": true
|
|
},
|
|
"tfoot": { "tbody": true },
|
|
"th": {
|
|
"td": true,
|
|
"th": true
|
|
},
|
|
"thead": {
|
|
"tbody": true,
|
|
"tfoot": true
|
|
},
|
|
"tr": { "tr": true }
|
|
},
|
|
doNotIndent: { "pre": true },
|
|
allowUnquoted: true,
|
|
allowMissing: true,
|
|
caseFold: true
|
|
};
|
|
var xmlConfig = {
|
|
autoSelfClosers: {},
|
|
implicitlyClosed: {},
|
|
contextGrabbers: {},
|
|
doNotIndent: {},
|
|
allowUnquoted: false,
|
|
allowMissing: false,
|
|
allowMissingTagName: false,
|
|
caseFold: false
|
|
};
|
|
CodeMirror$1.defineMode("xml", function(editorConf, config_) {
|
|
var indentUnit = editorConf.indentUnit;
|
|
var config = {};
|
|
var defaults = config_.htmlMode ? htmlConfig : xmlConfig;
|
|
for (var prop in defaults) config[prop] = defaults[prop];
|
|
for (var prop in config_) config[prop] = config_[prop];
|
|
var type, setStyle;
|
|
function inText(stream, state) {
|
|
function chain(parser) {
|
|
state.tokenize = parser;
|
|
return parser(stream, state);
|
|
}
|
|
var ch = stream.next();
|
|
if (ch == "<") if (stream.eat("!")) if (stream.eat("[")) if (stream.match("CDATA[")) return chain(inBlock("atom", "]]>"));
|
|
else return null;
|
|
else if (stream.match("--")) return chain(inBlock("comment", "-->"));
|
|
else if (stream.match("DOCTYPE", true, true)) {
|
|
stream.eatWhile(/[\w\._\-]/);
|
|
return chain(doctype(1));
|
|
} else return null;
|
|
else if (stream.eat("?")) {
|
|
stream.eatWhile(/[\w\._\-]/);
|
|
state.tokenize = inBlock("meta", "?>");
|
|
return "meta";
|
|
} else {
|
|
type = stream.eat("/") ? "closeTag" : "openTag";
|
|
state.tokenize = inTag;
|
|
return "tag bracket";
|
|
}
|
|
else if (ch == "&") {
|
|
var ok;
|
|
if (stream.eat("#")) if (stream.eat("x")) ok = stream.eatWhile(/[a-fA-F\d]/) && stream.eat(";");
|
|
else ok = stream.eatWhile(/[\d]/) && stream.eat(";");
|
|
else ok = stream.eatWhile(/[\w\.\-:]/) && stream.eat(";");
|
|
return ok ? "atom" : "error";
|
|
} else {
|
|
stream.eatWhile(/[^&<]/);
|
|
return null;
|
|
}
|
|
}
|
|
inText.isInText = true;
|
|
function inTag(stream, state) {
|
|
var ch = stream.next();
|
|
if (ch == ">" || ch == "/" && stream.eat(">")) {
|
|
state.tokenize = inText;
|
|
type = ch == ">" ? "endTag" : "selfcloseTag";
|
|
return "tag bracket";
|
|
} else if (ch == "=") {
|
|
type = "equals";
|
|
return null;
|
|
} else if (ch == "<") {
|
|
state.tokenize = inText;
|
|
state.state = baseState;
|
|
state.tagName = state.tagStart = null;
|
|
var next = state.tokenize(stream, state);
|
|
return next ? next + " tag error" : "tag error";
|
|
} else if (/[\'\"]/.test(ch)) {
|
|
state.tokenize = inAttribute(ch);
|
|
state.stringStartCol = stream.column();
|
|
return state.tokenize(stream, state);
|
|
} else {
|
|
stream.match(/^[^\s\u00a0=<>\"\']*[^\s\u00a0=<>\"\'\/]/);
|
|
return "word";
|
|
}
|
|
}
|
|
function inAttribute(quote) {
|
|
var closure = function(stream, state) {
|
|
while (!stream.eol()) if (stream.next() == quote) {
|
|
state.tokenize = inTag;
|
|
break;
|
|
}
|
|
return "string";
|
|
};
|
|
closure.isInAttribute = true;
|
|
return closure;
|
|
}
|
|
function inBlock(style, terminator) {
|
|
return function(stream, state) {
|
|
while (!stream.eol()) {
|
|
if (stream.match(terminator)) {
|
|
state.tokenize = inText;
|
|
break;
|
|
}
|
|
stream.next();
|
|
}
|
|
return style;
|
|
};
|
|
}
|
|
function doctype(depth) {
|
|
return function(stream, state) {
|
|
var ch;
|
|
while ((ch = stream.next()) != null) if (ch == "<") {
|
|
state.tokenize = doctype(depth + 1);
|
|
return state.tokenize(stream, state);
|
|
} else if (ch == ">") if (depth == 1) {
|
|
state.tokenize = inText;
|
|
break;
|
|
} else {
|
|
state.tokenize = doctype(depth - 1);
|
|
return state.tokenize(stream, state);
|
|
}
|
|
return "meta";
|
|
};
|
|
}
|
|
function lower(tagName) {
|
|
return tagName && tagName.toLowerCase();
|
|
}
|
|
function Context(state, tagName, startOfLine) {
|
|
this.prev = state.context;
|
|
this.tagName = tagName || "";
|
|
this.indent = state.indented;
|
|
this.startOfLine = startOfLine;
|
|
if (config.doNotIndent.hasOwnProperty(tagName) || state.context && state.context.noIndent) this.noIndent = true;
|
|
}
|
|
function popContext(state) {
|
|
if (state.context) state.context = state.context.prev;
|
|
}
|
|
function maybePopContext(state, nextTagName) {
|
|
var parentTagName;
|
|
while (true) {
|
|
if (!state.context) return;
|
|
parentTagName = state.context.tagName;
|
|
if (!config.contextGrabbers.hasOwnProperty(lower(parentTagName)) || !config.contextGrabbers[lower(parentTagName)].hasOwnProperty(lower(nextTagName))) return;
|
|
popContext(state);
|
|
}
|
|
}
|
|
function baseState(type$1, stream, state) {
|
|
if (type$1 == "openTag") {
|
|
state.tagStart = stream.column();
|
|
return tagNameState;
|
|
} else if (type$1 == "closeTag") return closeTagNameState;
|
|
else return baseState;
|
|
}
|
|
function tagNameState(type$1, stream, state) {
|
|
if (type$1 == "word") {
|
|
state.tagName = stream.current();
|
|
setStyle = "tag";
|
|
return attrState;
|
|
} else if (config.allowMissingTagName && type$1 == "endTag") {
|
|
setStyle = "tag bracket";
|
|
return attrState(type$1, stream, state);
|
|
} else {
|
|
setStyle = "error";
|
|
return tagNameState;
|
|
}
|
|
}
|
|
function closeTagNameState(type$1, stream, state) {
|
|
if (type$1 == "word") {
|
|
var tagName = stream.current();
|
|
if (state.context && state.context.tagName != tagName && config.implicitlyClosed.hasOwnProperty(lower(state.context.tagName))) popContext(state);
|
|
if (state.context && state.context.tagName == tagName || config.matchClosing === false) {
|
|
setStyle = "tag";
|
|
return closeState;
|
|
} else {
|
|
setStyle = "tag error";
|
|
return closeStateErr;
|
|
}
|
|
} else if (config.allowMissingTagName && type$1 == "endTag") {
|
|
setStyle = "tag bracket";
|
|
return closeState(type$1, stream, state);
|
|
} else {
|
|
setStyle = "error";
|
|
return closeStateErr;
|
|
}
|
|
}
|
|
function closeState(type$1, _stream, state) {
|
|
if (type$1 != "endTag") {
|
|
setStyle = "error";
|
|
return closeState;
|
|
}
|
|
popContext(state);
|
|
return baseState;
|
|
}
|
|
function closeStateErr(type$1, stream, state) {
|
|
setStyle = "error";
|
|
return closeState(type$1, stream, state);
|
|
}
|
|
function attrState(type$1, _stream, state) {
|
|
if (type$1 == "word") {
|
|
setStyle = "attribute";
|
|
return attrEqState;
|
|
} else if (type$1 == "endTag" || type$1 == "selfcloseTag") {
|
|
var tagName = state.tagName, tagStart = state.tagStart;
|
|
state.tagName = state.tagStart = null;
|
|
if (type$1 == "selfcloseTag" || config.autoSelfClosers.hasOwnProperty(lower(tagName))) maybePopContext(state, tagName);
|
|
else {
|
|
maybePopContext(state, tagName);
|
|
state.context = new Context(state, tagName, tagStart == state.indented);
|
|
}
|
|
return baseState;
|
|
}
|
|
setStyle = "error";
|
|
return attrState;
|
|
}
|
|
function attrEqState(type$1, stream, state) {
|
|
if (type$1 == "equals") return attrValueState;
|
|
if (!config.allowMissing) setStyle = "error";
|
|
return attrState(type$1, stream, state);
|
|
}
|
|
function attrValueState(type$1, stream, state) {
|
|
if (type$1 == "string") return attrContinuedState;
|
|
if (type$1 == "word" && config.allowUnquoted) {
|
|
setStyle = "string";
|
|
return attrState;
|
|
}
|
|
setStyle = "error";
|
|
return attrState(type$1, stream, state);
|
|
}
|
|
function attrContinuedState(type$1, stream, state) {
|
|
if (type$1 == "string") return attrContinuedState;
|
|
return attrState(type$1, stream, state);
|
|
}
|
|
return {
|
|
startState: function(baseIndent) {
|
|
var state = {
|
|
tokenize: inText,
|
|
state: baseState,
|
|
indented: baseIndent || 0,
|
|
tagName: null,
|
|
tagStart: null,
|
|
context: null
|
|
};
|
|
if (baseIndent != null) state.baseIndent = baseIndent;
|
|
return state;
|
|
},
|
|
token: function(stream, state) {
|
|
if (!state.tagName && stream.sol()) state.indented = stream.indentation();
|
|
if (stream.eatSpace()) return null;
|
|
type = null;
|
|
var style = state.tokenize(stream, state);
|
|
if ((style || type) && style != "comment") {
|
|
setStyle = null;
|
|
state.state = state.state(type || style, stream, state);
|
|
if (setStyle) style = setStyle == "error" ? style + " error" : setStyle;
|
|
}
|
|
return style;
|
|
},
|
|
indent: function(state, textAfter, fullLine) {
|
|
var context = state.context;
|
|
if (state.tokenize.isInAttribute) if (state.tagStart == state.indented) return state.stringStartCol + 1;
|
|
else return state.indented + indentUnit;
|
|
if (context && context.noIndent) return CodeMirror$1.Pass;
|
|
if (state.tokenize != inTag && state.tokenize != inText) return fullLine ? fullLine.match(/^(\s*)/)[0].length : 0;
|
|
if (state.tagName) if (config.multilineTagIndentPastTag !== false) return state.tagStart + state.tagName.length + 2;
|
|
else return state.tagStart + indentUnit * (config.multilineTagIndentFactor || 1);
|
|
if (config.alignCDATA && /<!\[CDATA\[/.test(textAfter)) return 0;
|
|
var tagAfter = textAfter && /^<(\/)?([\w_:\.-]*)/.exec(textAfter);
|
|
if (tagAfter && tagAfter[1]) while (context) if (context.tagName == tagAfter[2]) {
|
|
context = context.prev;
|
|
break;
|
|
} else if (config.implicitlyClosed.hasOwnProperty(lower(context.tagName))) context = context.prev;
|
|
else break;
|
|
else if (tagAfter) while (context) {
|
|
var grabbers = config.contextGrabbers[lower(context.tagName)];
|
|
if (grabbers && grabbers.hasOwnProperty(lower(tagAfter[2]))) context = context.prev;
|
|
else break;
|
|
}
|
|
while (context && context.prev && !context.startOfLine) context = context.prev;
|
|
if (context) return context.indent + indentUnit;
|
|
else return state.baseIndent || 0;
|
|
},
|
|
electricInput: /<\/[\s\w:]+>$/,
|
|
blockCommentStart: "<!--",
|
|
blockCommentEnd: "-->",
|
|
configuration: config.htmlMode ? "html" : "xml",
|
|
helperType: config.htmlMode ? "html" : "xml",
|
|
skipAttribute: function(state) {
|
|
if (state.state == attrValueState) state.state = attrState;
|
|
},
|
|
xmlCurrentTag: function(state) {
|
|
return state.tagName ? {
|
|
name: state.tagName,
|
|
close: state.type == "closeTag"
|
|
} : null;
|
|
},
|
|
xmlCurrentContext: function(state) {
|
|
var context = [];
|
|
for (var cx = state.context; cx; cx = cx.prev) context.push(cx.tagName);
|
|
return context.reverse();
|
|
}
|
|
};
|
|
});
|
|
CodeMirror$1.defineMIME("text/xml", "xml");
|
|
CodeMirror$1.defineMIME("application/xml", "xml");
|
|
if (!CodeMirror$1.mimeModes.hasOwnProperty("text/html")) CodeMirror$1.defineMIME("text/html", {
|
|
name: "xml",
|
|
htmlMode: true
|
|
});
|
|
});
|
|
});
|
|
var require_javascript = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineMode("javascript", function(config, parserConfig) {
|
|
var indentUnit = config.indentUnit;
|
|
var statementIndent = parserConfig.statementIndent;
|
|
var jsonldMode = parserConfig.jsonld;
|
|
var jsonMode = parserConfig.json || jsonldMode;
|
|
var trackScope = parserConfig.trackScope !== false;
|
|
var isTS = parserConfig.typescript;
|
|
var wordRE = parserConfig.wordCharacters || /[\w$\xa1-\uffff]/;
|
|
var keywords = function() {
|
|
function kw(type$1) {
|
|
return {
|
|
type: type$1,
|
|
style: "keyword"
|
|
};
|
|
}
|
|
var A = kw("keyword a"), B = kw("keyword b"), C = kw("keyword c"), D = kw("keyword d");
|
|
var operator = kw("operator"), atom = {
|
|
type: "atom",
|
|
style: "atom"
|
|
};
|
|
return {
|
|
"if": kw("if"),
|
|
"while": A,
|
|
"with": A,
|
|
"else": B,
|
|
"do": B,
|
|
"try": B,
|
|
"finally": B,
|
|
"return": D,
|
|
"break": D,
|
|
"continue": D,
|
|
"new": kw("new"),
|
|
"delete": C,
|
|
"void": C,
|
|
"throw": C,
|
|
"debugger": kw("debugger"),
|
|
"var": kw("var"),
|
|
"const": kw("var"),
|
|
"let": kw("var"),
|
|
"function": kw("function"),
|
|
"catch": kw("catch"),
|
|
"for": kw("for"),
|
|
"switch": kw("switch"),
|
|
"case": kw("case"),
|
|
"default": kw("default"),
|
|
"in": operator,
|
|
"typeof": operator,
|
|
"instanceof": operator,
|
|
"true": atom,
|
|
"false": atom,
|
|
"null": atom,
|
|
"undefined": atom,
|
|
"NaN": atom,
|
|
"Infinity": atom,
|
|
"this": kw("this"),
|
|
"class": kw("class"),
|
|
"super": kw("atom"),
|
|
"yield": C,
|
|
"export": kw("export"),
|
|
"import": kw("import"),
|
|
"extends": C,
|
|
"await": C
|
|
};
|
|
}();
|
|
var isOperatorChar = /[+\-*&%=<>!?|~^@]/;
|
|
var isJsonldKeyword = /^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)"/;
|
|
function readRegexp(stream) {
|
|
var escaped = false, next, inSet = false;
|
|
while ((next = stream.next()) != null) {
|
|
if (!escaped) {
|
|
if (next == "/" && !inSet) return;
|
|
if (next == "[") inSet = true;
|
|
else if (inSet && next == "]") inSet = false;
|
|
}
|
|
escaped = !escaped && next == "\\";
|
|
}
|
|
}
|
|
var type, content;
|
|
function ret(tp, style, cont$1) {
|
|
type = tp;
|
|
content = cont$1;
|
|
return style;
|
|
}
|
|
function tokenBase(stream, state) {
|
|
var ch = stream.next();
|
|
if (ch == "\"" || ch == "'") {
|
|
state.tokenize = tokenString(ch);
|
|
return state.tokenize(stream, state);
|
|
} else if (ch == "." && stream.match(/^\d[\d_]*(?:[eE][+\-]?[\d_]+)?/)) return ret("number", "number");
|
|
else if (ch == "." && stream.match("..")) return ret("spread", "meta");
|
|
else if (/[\[\]{}\(\),;\:\.]/.test(ch)) return ret(ch);
|
|
else if (ch == "=" && stream.eat(">")) return ret("=>", "operator");
|
|
else if (ch == "0" && stream.match(/^(?:x[\dA-Fa-f_]+|o[0-7_]+|b[01_]+)n?/)) return ret("number", "number");
|
|
else if (/\d/.test(ch)) {
|
|
stream.match(/^[\d_]*(?:n|(?:\.[\d_]*)?(?:[eE][+\-]?[\d_]+)?)?/);
|
|
return ret("number", "number");
|
|
} else if (ch == "/") if (stream.eat("*")) {
|
|
state.tokenize = tokenComment;
|
|
return tokenComment(stream, state);
|
|
} else if (stream.eat("/")) {
|
|
stream.skipToEnd();
|
|
return ret("comment", "comment");
|
|
} else if (expressionAllowed(stream, state, 1)) {
|
|
readRegexp(stream);
|
|
stream.match(/^\b(([gimyus])(?![gimyus]*\2))+\b/);
|
|
return ret("regexp", "string-2");
|
|
} else {
|
|
stream.eat("=");
|
|
return ret("operator", "operator", stream.current());
|
|
}
|
|
else if (ch == "`") {
|
|
state.tokenize = tokenQuasi;
|
|
return tokenQuasi(stream, state);
|
|
} else if (ch == "#" && stream.peek() == "!") {
|
|
stream.skipToEnd();
|
|
return ret("meta", "meta");
|
|
} else if (ch == "#" && stream.eatWhile(wordRE)) return ret("variable", "property");
|
|
else if (ch == "<" && stream.match("!--") || ch == "-" && stream.match("->") && !/\S/.test(stream.string.slice(0, stream.start))) {
|
|
stream.skipToEnd();
|
|
return ret("comment", "comment");
|
|
} else if (isOperatorChar.test(ch)) {
|
|
if (ch != ">" || !state.lexical || state.lexical.type != ">") {
|
|
if (stream.eat("=")) {
|
|
if (ch == "!" || ch == "=") stream.eat("=");
|
|
} else if (/[<>*+\-|&?]/.test(ch)) {
|
|
stream.eat(ch);
|
|
if (ch == ">") stream.eat(ch);
|
|
}
|
|
}
|
|
if (ch == "?" && stream.eat(".")) return ret(".");
|
|
return ret("operator", "operator", stream.current());
|
|
} else if (wordRE.test(ch)) {
|
|
stream.eatWhile(wordRE);
|
|
var word = stream.current();
|
|
if (state.lastType != ".") {
|
|
if (keywords.propertyIsEnumerable(word)) {
|
|
var kw = keywords[word];
|
|
return ret(kw.type, kw.style, word);
|
|
}
|
|
if (word == "async" && stream.match(/^(\s|\/\*([^*]|\*(?!\/))*?\*\/)*[\[\(\w]/, false)) return ret("async", "keyword", word);
|
|
}
|
|
return ret("variable", "variable", word);
|
|
}
|
|
}
|
|
function tokenString(quote) {
|
|
return function(stream, state) {
|
|
var escaped = false, next;
|
|
if (jsonldMode && stream.peek() == "@" && stream.match(isJsonldKeyword)) {
|
|
state.tokenize = tokenBase;
|
|
return ret("jsonld-keyword", "meta");
|
|
}
|
|
while ((next = stream.next()) != null) {
|
|
if (next == quote && !escaped) break;
|
|
escaped = !escaped && next == "\\";
|
|
}
|
|
if (!escaped) state.tokenize = tokenBase;
|
|
return ret("string", "string");
|
|
};
|
|
}
|
|
function tokenComment(stream, state) {
|
|
var maybeEnd = false, ch;
|
|
while (ch = stream.next()) {
|
|
if (ch == "/" && maybeEnd) {
|
|
state.tokenize = tokenBase;
|
|
break;
|
|
}
|
|
maybeEnd = ch == "*";
|
|
}
|
|
return ret("comment", "comment");
|
|
}
|
|
function tokenQuasi(stream, state) {
|
|
var escaped = false, next;
|
|
while ((next = stream.next()) != null) {
|
|
if (!escaped && (next == "`" || next == "$" && stream.eat("{"))) {
|
|
state.tokenize = tokenBase;
|
|
break;
|
|
}
|
|
escaped = !escaped && next == "\\";
|
|
}
|
|
return ret("quasi", "string-2", stream.current());
|
|
}
|
|
var brackets = "([{}])";
|
|
function findFatArrow(stream, state) {
|
|
if (state.fatArrowAt) state.fatArrowAt = null;
|
|
var arrow = stream.string.indexOf("=>", stream.start);
|
|
if (arrow < 0) return;
|
|
if (isTS) {
|
|
var m = /:\s*(?:\w+(?:<[^>]*>|\[\])?|\{[^}]*\})\s*$/.exec(stream.string.slice(stream.start, arrow));
|
|
if (m) arrow = m.index;
|
|
}
|
|
var depth = 0, sawSomething = false;
|
|
for (var pos = arrow - 1; pos >= 0; --pos) {
|
|
var ch = stream.string.charAt(pos);
|
|
var bracket = brackets.indexOf(ch);
|
|
if (bracket >= 0 && bracket < 3) {
|
|
if (!depth) {
|
|
++pos;
|
|
break;
|
|
}
|
|
if (--depth == 0) {
|
|
if (ch == "(") sawSomething = true;
|
|
break;
|
|
}
|
|
} else if (bracket >= 3 && bracket < 6) ++depth;
|
|
else if (wordRE.test(ch)) sawSomething = true;
|
|
else if (/["'\/`]/.test(ch)) for (;; --pos) {
|
|
if (pos == 0) return;
|
|
var next = stream.string.charAt(pos - 1);
|
|
if (next == ch && stream.string.charAt(pos - 2) != "\\") {
|
|
pos--;
|
|
break;
|
|
}
|
|
}
|
|
else if (sawSomething && !depth) {
|
|
++pos;
|
|
break;
|
|
}
|
|
}
|
|
if (sawSomething && !depth) state.fatArrowAt = pos;
|
|
}
|
|
var atomicTypes = {
|
|
"atom": true,
|
|
"number": true,
|
|
"variable": true,
|
|
"string": true,
|
|
"regexp": true,
|
|
"this": true,
|
|
"import": true,
|
|
"jsonld-keyword": true
|
|
};
|
|
function JSLexical(indented, column, type$1, align, prev, info) {
|
|
this.indented = indented;
|
|
this.column = column;
|
|
this.type = type$1;
|
|
this.prev = prev;
|
|
this.info = info;
|
|
if (align != null) this.align = align;
|
|
}
|
|
function inScope(state, varname) {
|
|
if (!trackScope) return false;
|
|
for (var v = state.localVars; v; v = v.next) if (v.name == varname) return true;
|
|
for (var cx$1 = state.context; cx$1; cx$1 = cx$1.prev) for (var v = cx$1.vars; v; v = v.next) if (v.name == varname) return true;
|
|
}
|
|
function parseJS(state, style, type$1, content$1, stream) {
|
|
var cc = state.cc;
|
|
cx.state = state;
|
|
cx.stream = stream;
|
|
cx.marked = null, cx.cc = cc;
|
|
cx.style = style;
|
|
if (!state.lexical.hasOwnProperty("align")) state.lexical.align = true;
|
|
while (true) {
|
|
var combinator = cc.length ? cc.pop() : jsonMode ? expression : statement;
|
|
if (combinator(type$1, content$1)) {
|
|
while (cc.length && cc[cc.length - 1].lex) cc.pop()();
|
|
if (cx.marked) return cx.marked;
|
|
if (type$1 == "variable" && inScope(state, content$1)) return "variable-2";
|
|
return style;
|
|
}
|
|
}
|
|
}
|
|
var cx = {
|
|
state: null,
|
|
column: null,
|
|
marked: null,
|
|
cc: null
|
|
};
|
|
function pass() {
|
|
for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]);
|
|
}
|
|
function cont() {
|
|
pass.apply(null, arguments);
|
|
return true;
|
|
}
|
|
function inList(name, list) {
|
|
for (var v = list; v; v = v.next) if (v.name == name) return true;
|
|
return false;
|
|
}
|
|
function register(varname) {
|
|
var state = cx.state;
|
|
cx.marked = "def";
|
|
if (!trackScope) return;
|
|
if (state.context) {
|
|
if (state.lexical.info == "var" && state.context && state.context.block) {
|
|
var newContext = registerVarScoped(varname, state.context);
|
|
if (newContext != null) {
|
|
state.context = newContext;
|
|
return;
|
|
}
|
|
} else if (!inList(varname, state.localVars)) {
|
|
state.localVars = new Var(varname, state.localVars);
|
|
return;
|
|
}
|
|
}
|
|
if (parserConfig.globalVars && !inList(varname, state.globalVars)) state.globalVars = new Var(varname, state.globalVars);
|
|
}
|
|
function registerVarScoped(varname, context) {
|
|
if (!context) return null;
|
|
else if (context.block) {
|
|
var inner = registerVarScoped(varname, context.prev);
|
|
if (!inner) return null;
|
|
if (inner == context.prev) return context;
|
|
return new Context(inner, context.vars, true);
|
|
} else if (inList(varname, context.vars)) return context;
|
|
else return new Context(context.prev, new Var(varname, context.vars), false);
|
|
}
|
|
function isModifier(name) {
|
|
return name == "public" || name == "private" || name == "protected" || name == "abstract" || name == "readonly";
|
|
}
|
|
function Context(prev, vars, block$1) {
|
|
this.prev = prev;
|
|
this.vars = vars;
|
|
this.block = block$1;
|
|
}
|
|
function Var(name, next) {
|
|
this.name = name;
|
|
this.next = next;
|
|
}
|
|
var defaultVars = new Var("this", new Var("arguments", null));
|
|
function pushcontext() {
|
|
cx.state.context = new Context(cx.state.context, cx.state.localVars, false);
|
|
cx.state.localVars = defaultVars;
|
|
}
|
|
function pushblockcontext() {
|
|
cx.state.context = new Context(cx.state.context, cx.state.localVars, true);
|
|
cx.state.localVars = null;
|
|
}
|
|
pushcontext.lex = pushblockcontext.lex = true;
|
|
function popcontext() {
|
|
cx.state.localVars = cx.state.context.vars;
|
|
cx.state.context = cx.state.context.prev;
|
|
}
|
|
popcontext.lex = true;
|
|
function pushlex(type$1, info) {
|
|
var result = function() {
|
|
var state = cx.state, indent = state.indented;
|
|
if (state.lexical.type == "stat") indent = state.lexical.indented;
|
|
else for (var outer = state.lexical; outer && outer.type == ")" && outer.align; outer = outer.prev) indent = outer.indented;
|
|
state.lexical = new JSLexical(indent, cx.stream.column(), type$1, null, state.lexical, info);
|
|
};
|
|
result.lex = true;
|
|
return result;
|
|
}
|
|
function poplex() {
|
|
var state = cx.state;
|
|
if (state.lexical.prev) {
|
|
if (state.lexical.type == ")") state.indented = state.lexical.indented;
|
|
state.lexical = state.lexical.prev;
|
|
}
|
|
}
|
|
poplex.lex = true;
|
|
function expect(wanted) {
|
|
function exp(type$1) {
|
|
if (type$1 == wanted) return cont();
|
|
else if (wanted == ";" || type$1 == "}" || type$1 == ")" || type$1 == "]") return pass();
|
|
else return cont(exp);
|
|
}
|
|
return exp;
|
|
}
|
|
function statement(type$1, value) {
|
|
if (type$1 == "var") return cont(pushlex("vardef", value), vardef, expect(";"), poplex);
|
|
if (type$1 == "keyword a") return cont(pushlex("form"), parenExpr, statement, poplex);
|
|
if (type$1 == "keyword b") return cont(pushlex("form"), statement, poplex);
|
|
if (type$1 == "keyword d") return cx.stream.match(/^\s*$/, false) ? cont() : cont(pushlex("stat"), maybeexpression, expect(";"), poplex);
|
|
if (type$1 == "debugger") return cont(expect(";"));
|
|
if (type$1 == "{") return cont(pushlex("}"), pushblockcontext, block, poplex, popcontext);
|
|
if (type$1 == ";") return cont();
|
|
if (type$1 == "if") {
|
|
if (cx.state.lexical.info == "else" && cx.state.cc[cx.state.cc.length - 1] == poplex) cx.state.cc.pop()();
|
|
return cont(pushlex("form"), parenExpr, statement, poplex, maybeelse);
|
|
}
|
|
if (type$1 == "function") return cont(functiondef);
|
|
if (type$1 == "for") return cont(pushlex("form"), pushblockcontext, forspec, statement, popcontext, poplex);
|
|
if (type$1 == "class" || isTS && value == "interface") {
|
|
cx.marked = "keyword";
|
|
return cont(pushlex("form", type$1 == "class" ? type$1 : value), className, poplex);
|
|
}
|
|
if (type$1 == "variable") if (isTS && value == "declare") {
|
|
cx.marked = "keyword";
|
|
return cont(statement);
|
|
} else if (isTS && (value == "module" || value == "enum" || value == "type") && cx.stream.match(/^\s*\w/, false)) {
|
|
cx.marked = "keyword";
|
|
if (value == "enum") return cont(enumdef);
|
|
else if (value == "type") return cont(typename, expect("operator"), typeexpr, expect(";"));
|
|
else return cont(pushlex("form"), pattern, expect("{"), pushlex("}"), block, poplex, poplex);
|
|
} else if (isTS && value == "namespace") {
|
|
cx.marked = "keyword";
|
|
return cont(pushlex("form"), expression, statement, poplex);
|
|
} else if (isTS && value == "abstract") {
|
|
cx.marked = "keyword";
|
|
return cont(statement);
|
|
} else return cont(pushlex("stat"), maybelabel);
|
|
if (type$1 == "switch") return cont(pushlex("form"), parenExpr, expect("{"), pushlex("}", "switch"), pushblockcontext, block, poplex, poplex, popcontext);
|
|
if (type$1 == "case") return cont(expression, expect(":"));
|
|
if (type$1 == "default") return cont(expect(":"));
|
|
if (type$1 == "catch") return cont(pushlex("form"), pushcontext, maybeCatchBinding, statement, poplex, popcontext);
|
|
if (type$1 == "export") return cont(pushlex("stat"), afterExport, poplex);
|
|
if (type$1 == "import") return cont(pushlex("stat"), afterImport, poplex);
|
|
if (type$1 == "async") return cont(statement);
|
|
if (value == "@") return cont(expression, statement);
|
|
return pass(pushlex("stat"), expression, expect(";"), poplex);
|
|
}
|
|
function maybeCatchBinding(type$1) {
|
|
if (type$1 == "(") return cont(funarg, expect(")"));
|
|
}
|
|
function expression(type$1, value) {
|
|
return expressionInner(type$1, value, false);
|
|
}
|
|
function expressionNoComma(type$1, value) {
|
|
return expressionInner(type$1, value, true);
|
|
}
|
|
function parenExpr(type$1) {
|
|
if (type$1 != "(") return pass();
|
|
return cont(pushlex(")"), maybeexpression, expect(")"), poplex);
|
|
}
|
|
function expressionInner(type$1, value, noComma) {
|
|
if (cx.state.fatArrowAt == cx.stream.start) {
|
|
var body = noComma ? arrowBodyNoComma : arrowBody;
|
|
if (type$1 == "(") return cont(pushcontext, pushlex(")"), commasep(funarg, ")"), poplex, expect("=>"), body, popcontext);
|
|
else if (type$1 == "variable") return pass(pushcontext, pattern, expect("=>"), body, popcontext);
|
|
}
|
|
var maybeop = noComma ? maybeoperatorNoComma : maybeoperatorComma;
|
|
if (atomicTypes.hasOwnProperty(type$1)) return cont(maybeop);
|
|
if (type$1 == "function") return cont(functiondef, maybeop);
|
|
if (type$1 == "class" || isTS && value == "interface") {
|
|
cx.marked = "keyword";
|
|
return cont(pushlex("form"), classExpression, poplex);
|
|
}
|
|
if (type$1 == "keyword c" || type$1 == "async") return cont(noComma ? expressionNoComma : expression);
|
|
if (type$1 == "(") return cont(pushlex(")"), maybeexpression, expect(")"), poplex, maybeop);
|
|
if (type$1 == "operator" || type$1 == "spread") return cont(noComma ? expressionNoComma : expression);
|
|
if (type$1 == "[") return cont(pushlex("]"), arrayLiteral, poplex, maybeop);
|
|
if (type$1 == "{") return contCommasep(objprop, "}", null, maybeop);
|
|
if (type$1 == "quasi") return pass(quasi, maybeop);
|
|
if (type$1 == "new") return cont(maybeTarget(noComma));
|
|
return cont();
|
|
}
|
|
function maybeexpression(type$1) {
|
|
if (type$1.match(/[;\}\)\],]/)) return pass();
|
|
return pass(expression);
|
|
}
|
|
function maybeoperatorComma(type$1, value) {
|
|
if (type$1 == ",") return cont(maybeexpression);
|
|
return maybeoperatorNoComma(type$1, value, false);
|
|
}
|
|
function maybeoperatorNoComma(type$1, value, noComma) {
|
|
var me = noComma == false ? maybeoperatorComma : maybeoperatorNoComma;
|
|
var expr = noComma == false ? expression : expressionNoComma;
|
|
if (type$1 == "=>") return cont(pushcontext, noComma ? arrowBodyNoComma : arrowBody, popcontext);
|
|
if (type$1 == "operator") {
|
|
if (/\+\+|--/.test(value) || isTS && value == "!") return cont(me);
|
|
if (isTS && value == "<" && cx.stream.match(/^([^<>]|<[^<>]*>)*>\s*\(/, false)) return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, me);
|
|
if (value == "?") return cont(expression, expect(":"), expr);
|
|
return cont(expr);
|
|
}
|
|
if (type$1 == "quasi") return pass(quasi, me);
|
|
if (type$1 == ";") return;
|
|
if (type$1 == "(") return contCommasep(expressionNoComma, ")", "call", me);
|
|
if (type$1 == ".") return cont(property, me);
|
|
if (type$1 == "[") return cont(pushlex("]"), maybeexpression, expect("]"), poplex, me);
|
|
if (isTS && value == "as") {
|
|
cx.marked = "keyword";
|
|
return cont(typeexpr, me);
|
|
}
|
|
if (type$1 == "regexp") {
|
|
cx.state.lastType = cx.marked = "operator";
|
|
cx.stream.backUp(cx.stream.pos - cx.stream.start - 1);
|
|
return cont(expr);
|
|
}
|
|
}
|
|
function quasi(type$1, value) {
|
|
if (type$1 != "quasi") return pass();
|
|
if (value.slice(value.length - 2) != "\${") return cont(quasi);
|
|
return cont(maybeexpression, continueQuasi);
|
|
}
|
|
function continueQuasi(type$1) {
|
|
if (type$1 == "}") {
|
|
cx.marked = "string-2";
|
|
cx.state.tokenize = tokenQuasi;
|
|
return cont(quasi);
|
|
}
|
|
}
|
|
function arrowBody(type$1) {
|
|
findFatArrow(cx.stream, cx.state);
|
|
return pass(type$1 == "{" ? statement : expression);
|
|
}
|
|
function arrowBodyNoComma(type$1) {
|
|
findFatArrow(cx.stream, cx.state);
|
|
return pass(type$1 == "{" ? statement : expressionNoComma);
|
|
}
|
|
function maybeTarget(noComma) {
|
|
return function(type$1) {
|
|
if (type$1 == ".") return cont(noComma ? targetNoComma : target);
|
|
else if (type$1 == "variable" && isTS) return cont(maybeTypeArgs, noComma ? maybeoperatorNoComma : maybeoperatorComma);
|
|
else return pass(noComma ? expressionNoComma : expression);
|
|
};
|
|
}
|
|
function target(_, value) {
|
|
if (value == "target") {
|
|
cx.marked = "keyword";
|
|
return cont(maybeoperatorComma);
|
|
}
|
|
}
|
|
function targetNoComma(_, value) {
|
|
if (value == "target") {
|
|
cx.marked = "keyword";
|
|
return cont(maybeoperatorNoComma);
|
|
}
|
|
}
|
|
function maybelabel(type$1) {
|
|
if (type$1 == ":") return cont(poplex, statement);
|
|
return pass(maybeoperatorComma, expect(";"), poplex);
|
|
}
|
|
function property(type$1) {
|
|
if (type$1 == "variable") {
|
|
cx.marked = "property";
|
|
return cont();
|
|
}
|
|
}
|
|
function objprop(type$1, value) {
|
|
if (type$1 == "async") {
|
|
cx.marked = "property";
|
|
return cont(objprop);
|
|
} else if (type$1 == "variable" || cx.style == "keyword") {
|
|
cx.marked = "property";
|
|
if (value == "get" || value == "set") return cont(getterSetter);
|
|
var m;
|
|
if (isTS && cx.state.fatArrowAt == cx.stream.start && (m = cx.stream.match(/^\s*:\s*/, false))) cx.state.fatArrowAt = cx.stream.pos + m[0].length;
|
|
return cont(afterprop);
|
|
} else if (type$1 == "number" || type$1 == "string") {
|
|
cx.marked = jsonldMode ? "property" : cx.style + " property";
|
|
return cont(afterprop);
|
|
} else if (type$1 == "jsonld-keyword") return cont(afterprop);
|
|
else if (isTS && isModifier(value)) {
|
|
cx.marked = "keyword";
|
|
return cont(objprop);
|
|
} else if (type$1 == "[") return cont(expression, maybetype, expect("]"), afterprop);
|
|
else if (type$1 == "spread") return cont(expressionNoComma, afterprop);
|
|
else if (value == "*") {
|
|
cx.marked = "keyword";
|
|
return cont(objprop);
|
|
} else if (type$1 == ":") return pass(afterprop);
|
|
}
|
|
function getterSetter(type$1) {
|
|
if (type$1 != "variable") return pass(afterprop);
|
|
cx.marked = "property";
|
|
return cont(functiondef);
|
|
}
|
|
function afterprop(type$1) {
|
|
if (type$1 == ":") return cont(expressionNoComma);
|
|
if (type$1 == "(") return pass(functiondef);
|
|
}
|
|
function commasep(what, end, sep) {
|
|
function proceed(type$1, value) {
|
|
if (sep ? sep.indexOf(type$1) > -1 : type$1 == ",") {
|
|
var lex = cx.state.lexical;
|
|
if (lex.info == "call") lex.pos = (lex.pos || 0) + 1;
|
|
return cont(function(type$2, value$1) {
|
|
if (type$2 == end || value$1 == end) return pass();
|
|
return pass(what);
|
|
}, proceed);
|
|
}
|
|
if (type$1 == end || value == end) return cont();
|
|
if (sep && sep.indexOf(";") > -1) return pass(what);
|
|
return cont(expect(end));
|
|
}
|
|
return function(type$1, value) {
|
|
if (type$1 == end || value == end) return cont();
|
|
return pass(what, proceed);
|
|
};
|
|
}
|
|
function contCommasep(what, end, info) {
|
|
for (var i = 3; i < arguments.length; i++) cx.cc.push(arguments[i]);
|
|
return cont(pushlex(end, info), commasep(what, end), poplex);
|
|
}
|
|
function block(type$1) {
|
|
if (type$1 == "}") return cont();
|
|
return pass(statement, block);
|
|
}
|
|
function maybetype(type$1, value) {
|
|
if (isTS) {
|
|
if (type$1 == ":") return cont(typeexpr);
|
|
if (value == "?") return cont(maybetype);
|
|
}
|
|
}
|
|
function maybetypeOrIn(type$1, value) {
|
|
if (isTS && (type$1 == ":" || value == "in")) return cont(typeexpr);
|
|
}
|
|
function mayberettype(type$1) {
|
|
if (isTS && type$1 == ":") if (cx.stream.match(/^\s*\w+\s+is\b/, false)) return cont(expression, isKW, typeexpr);
|
|
else return cont(typeexpr);
|
|
}
|
|
function isKW(_, value) {
|
|
if (value == "is") {
|
|
cx.marked = "keyword";
|
|
return cont();
|
|
}
|
|
}
|
|
function typeexpr(type$1, value) {
|
|
if (value == "keyof" || value == "typeof" || value == "infer" || value == "readonly") {
|
|
cx.marked = "keyword";
|
|
return cont(value == "typeof" ? expressionNoComma : typeexpr);
|
|
}
|
|
if (type$1 == "variable" || value == "void") {
|
|
cx.marked = "type";
|
|
return cont(afterType);
|
|
}
|
|
if (value == "|" || value == "&") return cont(typeexpr);
|
|
if (type$1 == "string" || type$1 == "number" || type$1 == "atom") return cont(afterType);
|
|
if (type$1 == "[") return cont(pushlex("]"), commasep(typeexpr, "]", ","), poplex, afterType);
|
|
if (type$1 == "{") return cont(pushlex("}"), typeprops, poplex, afterType);
|
|
if (type$1 == "(") return cont(commasep(typearg, ")"), maybeReturnType, afterType);
|
|
if (type$1 == "<") return cont(commasep(typeexpr, ">"), typeexpr);
|
|
if (type$1 == "quasi") return pass(quasiType, afterType);
|
|
}
|
|
function maybeReturnType(type$1) {
|
|
if (type$1 == "=>") return cont(typeexpr);
|
|
}
|
|
function typeprops(type$1) {
|
|
if (type$1.match(/[\}\)\]]/)) return cont();
|
|
if (type$1 == "," || type$1 == ";") return cont(typeprops);
|
|
return pass(typeprop, typeprops);
|
|
}
|
|
function typeprop(type$1, value) {
|
|
if (type$1 == "variable" || cx.style == "keyword") {
|
|
cx.marked = "property";
|
|
return cont(typeprop);
|
|
} else if (value == "?" || type$1 == "number" || type$1 == "string") return cont(typeprop);
|
|
else if (type$1 == ":") return cont(typeexpr);
|
|
else if (type$1 == "[") return cont(expect("variable"), maybetypeOrIn, expect("]"), typeprop);
|
|
else if (type$1 == "(") return pass(functiondecl, typeprop);
|
|
else if (!type$1.match(/[;\}\)\],]/)) return cont();
|
|
}
|
|
function quasiType(type$1, value) {
|
|
if (type$1 != "quasi") return pass();
|
|
if (value.slice(value.length - 2) != "\${") return cont(quasiType);
|
|
return cont(typeexpr, continueQuasiType);
|
|
}
|
|
function continueQuasiType(type$1) {
|
|
if (type$1 == "}") {
|
|
cx.marked = "string-2";
|
|
cx.state.tokenize = tokenQuasi;
|
|
return cont(quasiType);
|
|
}
|
|
}
|
|
function typearg(type$1, value) {
|
|
if (type$1 == "variable" && cx.stream.match(/^\s*[?:]/, false) || value == "?") return cont(typearg);
|
|
if (type$1 == ":") return cont(typeexpr);
|
|
if (type$1 == "spread") return cont(typearg);
|
|
return pass(typeexpr);
|
|
}
|
|
function afterType(type$1, value) {
|
|
if (value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, afterType);
|
|
if (value == "|" || type$1 == "." || value == "&") return cont(typeexpr);
|
|
if (type$1 == "[") return cont(typeexpr, expect("]"), afterType);
|
|
if (value == "extends" || value == "implements") {
|
|
cx.marked = "keyword";
|
|
return cont(typeexpr);
|
|
}
|
|
if (value == "?") return cont(typeexpr, expect(":"), typeexpr);
|
|
}
|
|
function maybeTypeArgs(_, value) {
|
|
if (value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, afterType);
|
|
}
|
|
function typeparam() {
|
|
return pass(typeexpr, maybeTypeDefault);
|
|
}
|
|
function maybeTypeDefault(_, value) {
|
|
if (value == "=") return cont(typeexpr);
|
|
}
|
|
function vardef(_, value) {
|
|
if (value == "enum") {
|
|
cx.marked = "keyword";
|
|
return cont(enumdef);
|
|
}
|
|
return pass(pattern, maybetype, maybeAssign, vardefCont);
|
|
}
|
|
function pattern(type$1, value) {
|
|
if (isTS && isModifier(value)) {
|
|
cx.marked = "keyword";
|
|
return cont(pattern);
|
|
}
|
|
if (type$1 == "variable") {
|
|
register(value);
|
|
return cont();
|
|
}
|
|
if (type$1 == "spread") return cont(pattern);
|
|
if (type$1 == "[") return contCommasep(eltpattern, "]");
|
|
if (type$1 == "{") return contCommasep(proppattern, "}");
|
|
}
|
|
function proppattern(type$1, value) {
|
|
if (type$1 == "variable" && !cx.stream.match(/^\s*:/, false)) {
|
|
register(value);
|
|
return cont(maybeAssign);
|
|
}
|
|
if (type$1 == "variable") cx.marked = "property";
|
|
if (type$1 == "spread") return cont(pattern);
|
|
if (type$1 == "}") return pass();
|
|
if (type$1 == "[") return cont(expression, expect("]"), expect(":"), proppattern);
|
|
return cont(expect(":"), pattern, maybeAssign);
|
|
}
|
|
function eltpattern() {
|
|
return pass(pattern, maybeAssign);
|
|
}
|
|
function maybeAssign(_type, value) {
|
|
if (value == "=") return cont(expressionNoComma);
|
|
}
|
|
function vardefCont(type$1) {
|
|
if (type$1 == ",") return cont(vardef);
|
|
}
|
|
function maybeelse(type$1, value) {
|
|
if (type$1 == "keyword b" && value == "else") return cont(pushlex("form", "else"), statement, poplex);
|
|
}
|
|
function forspec(type$1, value) {
|
|
if (value == "await") return cont(forspec);
|
|
if (type$1 == "(") return cont(pushlex(")"), forspec1, poplex);
|
|
}
|
|
function forspec1(type$1) {
|
|
if (type$1 == "var") return cont(vardef, forspec2);
|
|
if (type$1 == "variable") return cont(forspec2);
|
|
return pass(forspec2);
|
|
}
|
|
function forspec2(type$1, value) {
|
|
if (type$1 == ")") return cont();
|
|
if (type$1 == ";") return cont(forspec2);
|
|
if (value == "in" || value == "of") {
|
|
cx.marked = "keyword";
|
|
return cont(expression, forspec2);
|
|
}
|
|
return pass(expression, forspec2);
|
|
}
|
|
function functiondef(type$1, value) {
|
|
if (value == "*") {
|
|
cx.marked = "keyword";
|
|
return cont(functiondef);
|
|
}
|
|
if (type$1 == "variable") {
|
|
register(value);
|
|
return cont(functiondef);
|
|
}
|
|
if (type$1 == "(") return cont(pushcontext, pushlex(")"), commasep(funarg, ")"), poplex, mayberettype, statement, popcontext);
|
|
if (isTS && value == "<") return cont(pushlex(">"), commasep(typeparam, ">"), poplex, functiondef);
|
|
}
|
|
function functiondecl(type$1, value) {
|
|
if (value == "*") {
|
|
cx.marked = "keyword";
|
|
return cont(functiondecl);
|
|
}
|
|
if (type$1 == "variable") {
|
|
register(value);
|
|
return cont(functiondecl);
|
|
}
|
|
if (type$1 == "(") return cont(pushcontext, pushlex(")"), commasep(funarg, ")"), poplex, mayberettype, popcontext);
|
|
if (isTS && value == "<") return cont(pushlex(">"), commasep(typeparam, ">"), poplex, functiondecl);
|
|
}
|
|
function typename(type$1, value) {
|
|
if (type$1 == "keyword" || type$1 == "variable") {
|
|
cx.marked = "type";
|
|
return cont(typename);
|
|
} else if (value == "<") return cont(pushlex(">"), commasep(typeparam, ">"), poplex);
|
|
}
|
|
function funarg(type$1, value) {
|
|
if (value == "@") cont(expression, funarg);
|
|
if (type$1 == "spread") return cont(funarg);
|
|
if (isTS && isModifier(value)) {
|
|
cx.marked = "keyword";
|
|
return cont(funarg);
|
|
}
|
|
if (isTS && type$1 == "this") return cont(maybetype, maybeAssign);
|
|
return pass(pattern, maybetype, maybeAssign);
|
|
}
|
|
function classExpression(type$1, value) {
|
|
if (type$1 == "variable") return className(type$1, value);
|
|
return classNameAfter(type$1, value);
|
|
}
|
|
function className(type$1, value) {
|
|
if (type$1 == "variable") {
|
|
register(value);
|
|
return cont(classNameAfter);
|
|
}
|
|
}
|
|
function classNameAfter(type$1, value) {
|
|
if (value == "<") return cont(pushlex(">"), commasep(typeparam, ">"), poplex, classNameAfter);
|
|
if (value == "extends" || value == "implements" || isTS && type$1 == ",") {
|
|
if (value == "implements") cx.marked = "keyword";
|
|
return cont(isTS ? typeexpr : expression, classNameAfter);
|
|
}
|
|
if (type$1 == "{") return cont(pushlex("}"), classBody, poplex);
|
|
}
|
|
function classBody(type$1, value) {
|
|
if (type$1 == "async" || type$1 == "variable" && (value == "static" || value == "get" || value == "set" || isTS && isModifier(value)) && cx.stream.match(/^\s+#?[\w$\xa1-\uffff]/, false)) {
|
|
cx.marked = "keyword";
|
|
return cont(classBody);
|
|
}
|
|
if (type$1 == "variable" || cx.style == "keyword") {
|
|
cx.marked = "property";
|
|
return cont(classfield, classBody);
|
|
}
|
|
if (type$1 == "number" || type$1 == "string") return cont(classfield, classBody);
|
|
if (type$1 == "[") return cont(expression, maybetype, expect("]"), classfield, classBody);
|
|
if (value == "*") {
|
|
cx.marked = "keyword";
|
|
return cont(classBody);
|
|
}
|
|
if (isTS && type$1 == "(") return pass(functiondecl, classBody);
|
|
if (type$1 == ";" || type$1 == ",") return cont(classBody);
|
|
if (type$1 == "}") return cont();
|
|
if (value == "@") return cont(expression, classBody);
|
|
}
|
|
function classfield(type$1, value) {
|
|
if (value == "!") return cont(classfield);
|
|
if (value == "?") return cont(classfield);
|
|
if (type$1 == ":") return cont(typeexpr, maybeAssign);
|
|
if (value == "=") return cont(expressionNoComma);
|
|
var context = cx.state.lexical.prev, isInterface = context && context.info == "interface";
|
|
return pass(isInterface ? functiondecl : functiondef);
|
|
}
|
|
function afterExport(type$1, value) {
|
|
if (value == "*") {
|
|
cx.marked = "keyword";
|
|
return cont(maybeFrom, expect(";"));
|
|
}
|
|
if (value == "default") {
|
|
cx.marked = "keyword";
|
|
return cont(expression, expect(";"));
|
|
}
|
|
if (type$1 == "{") return cont(commasep(exportField, "}"), maybeFrom, expect(";"));
|
|
return pass(statement);
|
|
}
|
|
function exportField(type$1, value) {
|
|
if (value == "as") {
|
|
cx.marked = "keyword";
|
|
return cont(expect("variable"));
|
|
}
|
|
if (type$1 == "variable") return pass(expressionNoComma, exportField);
|
|
}
|
|
function afterImport(type$1) {
|
|
if (type$1 == "string") return cont();
|
|
if (type$1 == "(") return pass(expression);
|
|
if (type$1 == ".") return pass(maybeoperatorComma);
|
|
return pass(importSpec, maybeMoreImports, maybeFrom);
|
|
}
|
|
function importSpec(type$1, value) {
|
|
if (type$1 == "{") return contCommasep(importSpec, "}");
|
|
if (type$1 == "variable") register(value);
|
|
if (value == "*") cx.marked = "keyword";
|
|
return cont(maybeAs);
|
|
}
|
|
function maybeMoreImports(type$1) {
|
|
if (type$1 == ",") return cont(importSpec, maybeMoreImports);
|
|
}
|
|
function maybeAs(_type, value) {
|
|
if (value == "as") {
|
|
cx.marked = "keyword";
|
|
return cont(importSpec);
|
|
}
|
|
}
|
|
function maybeFrom(_type, value) {
|
|
if (value == "from") {
|
|
cx.marked = "keyword";
|
|
return cont(expression);
|
|
}
|
|
}
|
|
function arrayLiteral(type$1) {
|
|
if (type$1 == "]") return cont();
|
|
return pass(commasep(expressionNoComma, "]"));
|
|
}
|
|
function enumdef() {
|
|
return pass(pushlex("form"), pattern, expect("{"), pushlex("}"), commasep(enummember, "}"), poplex, poplex);
|
|
}
|
|
function enummember() {
|
|
return pass(pattern, maybeAssign);
|
|
}
|
|
function isContinuedStatement(state, textAfter) {
|
|
return state.lastType == "operator" || state.lastType == "," || isOperatorChar.test(textAfter.charAt(0)) || /[,.]/.test(textAfter.charAt(0));
|
|
}
|
|
function expressionAllowed(stream, state, backUp) {
|
|
return state.tokenize == tokenBase && /^(?:operator|sof|keyword [bcd]|case|new|export|default|spread|[\[{}\(,;:]|=>)$/.test(state.lastType) || state.lastType == "quasi" && /\{\s*$/.test(stream.string.slice(0, stream.pos - (backUp || 0)));
|
|
}
|
|
return {
|
|
startState: function(basecolumn) {
|
|
var state = {
|
|
tokenize: tokenBase,
|
|
lastType: "sof",
|
|
cc: [],
|
|
lexical: new JSLexical((basecolumn || 0) - indentUnit, 0, "block", false),
|
|
localVars: parserConfig.localVars,
|
|
context: parserConfig.localVars && new Context(null, null, false),
|
|
indented: basecolumn || 0
|
|
};
|
|
if (parserConfig.globalVars && typeof parserConfig.globalVars == "object") state.globalVars = parserConfig.globalVars;
|
|
return state;
|
|
},
|
|
token: function(stream, state) {
|
|
if (stream.sol()) {
|
|
if (!state.lexical.hasOwnProperty("align")) state.lexical.align = false;
|
|
state.indented = stream.indentation();
|
|
findFatArrow(stream, state);
|
|
}
|
|
if (state.tokenize != tokenComment && stream.eatSpace()) return null;
|
|
var style = state.tokenize(stream, state);
|
|
if (type == "comment") return style;
|
|
state.lastType = type == "operator" && (content == "++" || content == "--") ? "incdec" : type;
|
|
return parseJS(state, style, type, content, stream);
|
|
},
|
|
indent: function(state, textAfter) {
|
|
if (state.tokenize == tokenComment || state.tokenize == tokenQuasi) return CodeMirror$1.Pass;
|
|
if (state.tokenize != tokenBase) return 0;
|
|
var firstChar = textAfter && textAfter.charAt(0), lexical = state.lexical, top;
|
|
if (!/^\s*else\b/.test(textAfter)) for (var i = state.cc.length - 1; i >= 0; --i) {
|
|
var c = state.cc[i];
|
|
if (c == poplex) lexical = lexical.prev;
|
|
else if (c != maybeelse && c != popcontext) break;
|
|
}
|
|
while ((lexical.type == "stat" || lexical.type == "form") && (firstChar == "}" || (top = state.cc[state.cc.length - 1]) && (top == maybeoperatorComma || top == maybeoperatorNoComma) && !/^[,\.=+\-*:?[\(]/.test(textAfter))) lexical = lexical.prev;
|
|
if (statementIndent && lexical.type == ")" && lexical.prev.type == "stat") lexical = lexical.prev;
|
|
var type$1 = lexical.type, closing = firstChar == type$1;
|
|
if (type$1 == "vardef") return lexical.indented + (state.lastType == "operator" || state.lastType == "," ? lexical.info.length + 1 : 0);
|
|
else if (type$1 == "form" && firstChar == "{") return lexical.indented;
|
|
else if (type$1 == "form") return lexical.indented + indentUnit;
|
|
else if (type$1 == "stat") return lexical.indented + (isContinuedStatement(state, textAfter) ? statementIndent || indentUnit : 0);
|
|
else if (lexical.info == "switch" && !closing && parserConfig.doubleIndentSwitch != false) return lexical.indented + (/^(?:case|default)\b/.test(textAfter) ? indentUnit : 2 * indentUnit);
|
|
else if (lexical.align) return lexical.column + (closing ? 0 : 1);
|
|
else return lexical.indented + (closing ? 0 : indentUnit);
|
|
},
|
|
electricInput: /^\s*(?:case .*?:|default:|\{|\})$/,
|
|
blockCommentStart: jsonMode ? null : "/*",
|
|
blockCommentEnd: jsonMode ? null : "*/",
|
|
blockCommentContinue: jsonMode ? null : " * ",
|
|
lineComment: jsonMode ? null : "//",
|
|
fold: "brace",
|
|
closeBrackets: "()[]{}''\"\"``",
|
|
helperType: jsonMode ? "json" : "javascript",
|
|
jsonldMode,
|
|
jsonMode,
|
|
expressionAllowed,
|
|
skipExpression: function(state) {
|
|
parseJS(state, "atom", "atom", "true", new CodeMirror$1.StringStream("", 2, null));
|
|
}
|
|
};
|
|
});
|
|
CodeMirror$1.registerHelper("wordChars", "javascript", /[\w$]/);
|
|
CodeMirror$1.defineMIME("text/javascript", "javascript");
|
|
CodeMirror$1.defineMIME("text/ecmascript", "javascript");
|
|
CodeMirror$1.defineMIME("application/javascript", "javascript");
|
|
CodeMirror$1.defineMIME("application/x-javascript", "javascript");
|
|
CodeMirror$1.defineMIME("application/ecmascript", "javascript");
|
|
CodeMirror$1.defineMIME("application/json", {
|
|
name: "javascript",
|
|
json: true
|
|
});
|
|
CodeMirror$1.defineMIME("application/x-json", {
|
|
name: "javascript",
|
|
json: true
|
|
});
|
|
CodeMirror$1.defineMIME("application/manifest+json", {
|
|
name: "javascript",
|
|
json: true
|
|
});
|
|
CodeMirror$1.defineMIME("application/ld+json", {
|
|
name: "javascript",
|
|
jsonld: true
|
|
});
|
|
CodeMirror$1.defineMIME("text/typescript", {
|
|
name: "javascript",
|
|
typescript: true
|
|
});
|
|
CodeMirror$1.defineMIME("application/typescript", {
|
|
name: "javascript",
|
|
typescript: true
|
|
});
|
|
});
|
|
});
|
|
var require_htmlmixed = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror(), require_xml(), require_javascript(), require_css());
|
|
else if (typeof define == "function" && define.amd) define([
|
|
"../../lib/codemirror",
|
|
"../xml/xml",
|
|
"../javascript/javascript",
|
|
"../css/css"
|
|
], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
var defaultTags = {
|
|
script: [
|
|
[
|
|
"lang",
|
|
/(javascript|babel)/i,
|
|
"javascript"
|
|
],
|
|
[
|
|
"type",
|
|
/^(?:text|application)\/(?:x-)?(?:java|ecma)script$|^module$|^$/i,
|
|
"javascript"
|
|
],
|
|
[
|
|
"type",
|
|
/./,
|
|
"text/plain"
|
|
],
|
|
[
|
|
null,
|
|
null,
|
|
"javascript"
|
|
]
|
|
],
|
|
style: [
|
|
[
|
|
"lang",
|
|
/^css$/i,
|
|
"css"
|
|
],
|
|
[
|
|
"type",
|
|
/^(text\/)?(x-)?(stylesheet|css)$/i,
|
|
"css"
|
|
],
|
|
[
|
|
"type",
|
|
/./,
|
|
"text/plain"
|
|
],
|
|
[
|
|
null,
|
|
null,
|
|
"css"
|
|
]
|
|
]
|
|
};
|
|
function maybeBackup(stream, pat, style) {
|
|
var cur = stream.current(), close = cur.search(pat);
|
|
if (close > -1) stream.backUp(cur.length - close);
|
|
else if (cur.match(/<\/?$/)) {
|
|
stream.backUp(cur.length);
|
|
if (!stream.match(pat, false)) stream.match(cur);
|
|
}
|
|
return style;
|
|
}
|
|
var attrRegexpCache = {};
|
|
function getAttrRegexp(attr) {
|
|
var regexp = attrRegexpCache[attr];
|
|
if (regexp) return regexp;
|
|
return attrRegexpCache[attr] = new RegExp("\\s+" + attr + "\\s*=\\s*('|\")?([^'\"]+)('|\")?\\s*");
|
|
}
|
|
function getAttrValue(text, attr) {
|
|
var match = text.match(getAttrRegexp(attr));
|
|
return match ? /^\s*(.*?)\s*$/.exec(match[2])[1] : "";
|
|
}
|
|
function getTagRegexp(tagName, anchored) {
|
|
return new RegExp((anchored ? "^" : "") + "</\\s*" + tagName + "\\s*>", "i");
|
|
}
|
|
function addTags(from, to) {
|
|
for (var tag in from) {
|
|
var dest = to[tag] || (to[tag] = []);
|
|
var source = from[tag];
|
|
for (var i = source.length - 1; i >= 0; i--) dest.unshift(source[i]);
|
|
}
|
|
}
|
|
function findMatchingMode(tagInfo, tagText) {
|
|
for (var i = 0; i < tagInfo.length; i++) {
|
|
var spec = tagInfo[i];
|
|
if (!spec[0] || spec[1].test(getAttrValue(tagText, spec[0]))) return spec[2];
|
|
}
|
|
}
|
|
CodeMirror$1.defineMode("htmlmixed", function(config, parserConfig) {
|
|
var htmlMode = CodeMirror$1.getMode(config, {
|
|
name: "xml",
|
|
htmlMode: true,
|
|
multilineTagIndentFactor: parserConfig.multilineTagIndentFactor,
|
|
multilineTagIndentPastTag: parserConfig.multilineTagIndentPastTag,
|
|
allowMissingTagName: parserConfig.allowMissingTagName
|
|
});
|
|
var tags = {};
|
|
var configTags = parserConfig && parserConfig.tags, configScript = parserConfig && parserConfig.scriptTypes;
|
|
addTags(defaultTags, tags);
|
|
if (configTags) addTags(configTags, tags);
|
|
if (configScript) for (var i = configScript.length - 1; i >= 0; i--) tags.script.unshift([
|
|
"type",
|
|
configScript[i].matches,
|
|
configScript[i].mode
|
|
]);
|
|
function html(stream, state) {
|
|
var style = htmlMode.token(stream, state.htmlState), tag = /\btag\b/.test(style), tagName;
|
|
if (tag && !/[<>\s\/]/.test(stream.current()) && (tagName = state.htmlState.tagName && state.htmlState.tagName.toLowerCase()) && tags.hasOwnProperty(tagName)) state.inTag = tagName + " ";
|
|
else if (state.inTag && tag && />$/.test(stream.current())) {
|
|
var inTag = /^([\S]+) (.*)/.exec(state.inTag);
|
|
state.inTag = null;
|
|
var modeSpec = stream.current() == ">" && findMatchingMode(tags[inTag[1]], inTag[2]);
|
|
var mode = CodeMirror$1.getMode(config, modeSpec);
|
|
var endTagA = getTagRegexp(inTag[1], true), endTag = getTagRegexp(inTag[1], false);
|
|
state.token = function(stream$1, state$1) {
|
|
if (stream$1.match(endTagA, false)) {
|
|
state$1.token = html;
|
|
state$1.localState = state$1.localMode = null;
|
|
return null;
|
|
}
|
|
return maybeBackup(stream$1, endTag, state$1.localMode.token(stream$1, state$1.localState));
|
|
};
|
|
state.localMode = mode;
|
|
state.localState = CodeMirror$1.startState(mode, htmlMode.indent(state.htmlState, "", ""));
|
|
} else if (state.inTag) {
|
|
state.inTag += stream.current();
|
|
if (stream.eol()) state.inTag += " ";
|
|
}
|
|
return style;
|
|
}
|
|
return {
|
|
startState: function() {
|
|
var state = CodeMirror$1.startState(htmlMode);
|
|
return {
|
|
token: html,
|
|
inTag: null,
|
|
localMode: null,
|
|
localState: null,
|
|
htmlState: state
|
|
};
|
|
},
|
|
copyState: function(state) {
|
|
var local;
|
|
if (state.localState) local = CodeMirror$1.copyState(state.localMode, state.localState);
|
|
return {
|
|
token: state.token,
|
|
inTag: state.inTag,
|
|
localMode: state.localMode,
|
|
localState: local,
|
|
htmlState: CodeMirror$1.copyState(htmlMode, state.htmlState)
|
|
};
|
|
},
|
|
token: function(stream, state) {
|
|
return state.token(stream, state);
|
|
},
|
|
indent: function(state, textAfter, line) {
|
|
if (!state.localMode || /^\s*<\//.test(textAfter)) return htmlMode.indent(state.htmlState, textAfter, line);
|
|
else if (state.localMode.indent) return state.localMode.indent(state.localState, textAfter, line);
|
|
else return CodeMirror$1.Pass;
|
|
},
|
|
innerMode: function(state) {
|
|
return {
|
|
state: state.localState || state.htmlState,
|
|
mode: state.localMode || htmlMode
|
|
};
|
|
}
|
|
};
|
|
}, "xml", "javascript", "css");
|
|
CodeMirror$1.defineMIME("text/html", "htmlmixed");
|
|
});
|
|
});
|
|
var require_meta = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.modeInfo = [
|
|
{
|
|
name: "APL",
|
|
mime: "text/apl",
|
|
mode: "apl",
|
|
ext: ["dyalog", "apl"]
|
|
},
|
|
{
|
|
name: "PGP",
|
|
mimes: [
|
|
"application/pgp",
|
|
"application/pgp-encrypted",
|
|
"application/pgp-keys",
|
|
"application/pgp-signature"
|
|
],
|
|
mode: "asciiarmor",
|
|
ext: [
|
|
"asc",
|
|
"pgp",
|
|
"sig"
|
|
]
|
|
},
|
|
{
|
|
name: "ASN.1",
|
|
mime: "text/x-ttcn-asn",
|
|
mode: "asn.1",
|
|
ext: ["asn", "asn1"]
|
|
},
|
|
{
|
|
name: "Asterisk",
|
|
mime: "text/x-asterisk",
|
|
mode: "asterisk",
|
|
file: /^extensions\.conf$/i
|
|
},
|
|
{
|
|
name: "Brainfuck",
|
|
mime: "text/x-brainfuck",
|
|
mode: "brainfuck",
|
|
ext: ["b", "bf"]
|
|
},
|
|
{
|
|
name: "C",
|
|
mime: "text/x-csrc",
|
|
mode: "clike",
|
|
ext: [
|
|
"c",
|
|
"h",
|
|
"ino"
|
|
]
|
|
},
|
|
{
|
|
name: "C++",
|
|
mime: "text/x-c++src",
|
|
mode: "clike",
|
|
ext: [
|
|
"cpp",
|
|
"c++",
|
|
"cc",
|
|
"cxx",
|
|
"hpp",
|
|
"h++",
|
|
"hh",
|
|
"hxx"
|
|
],
|
|
alias: ["cpp"]
|
|
},
|
|
{
|
|
name: "Cobol",
|
|
mime: "text/x-cobol",
|
|
mode: "cobol",
|
|
ext: [
|
|
"cob",
|
|
"cpy",
|
|
"cbl"
|
|
]
|
|
},
|
|
{
|
|
name: "C#",
|
|
mime: "text/x-csharp",
|
|
mode: "clike",
|
|
ext: ["cs"],
|
|
alias: ["csharp", "cs"]
|
|
},
|
|
{
|
|
name: "Clojure",
|
|
mime: "text/x-clojure",
|
|
mode: "clojure",
|
|
ext: [
|
|
"clj",
|
|
"cljc",
|
|
"cljx"
|
|
]
|
|
},
|
|
{
|
|
name: "ClojureScript",
|
|
mime: "text/x-clojurescript",
|
|
mode: "clojure",
|
|
ext: ["cljs"]
|
|
},
|
|
{
|
|
name: "Closure Stylesheets (GSS)",
|
|
mime: "text/x-gss",
|
|
mode: "css",
|
|
ext: ["gss"]
|
|
},
|
|
{
|
|
name: "CMake",
|
|
mime: "text/x-cmake",
|
|
mode: "cmake",
|
|
ext: ["cmake", "cmake.in"],
|
|
file: /^CMakeLists\.txt$/
|
|
},
|
|
{
|
|
name: "CoffeeScript",
|
|
mimes: [
|
|
"application/vnd.coffeescript",
|
|
"text/coffeescript",
|
|
"text/x-coffeescript"
|
|
],
|
|
mode: "coffeescript",
|
|
ext: ["coffee"],
|
|
alias: ["coffee", "coffee-script"]
|
|
},
|
|
{
|
|
name: "Common Lisp",
|
|
mime: "text/x-common-lisp",
|
|
mode: "commonlisp",
|
|
ext: [
|
|
"cl",
|
|
"lisp",
|
|
"el"
|
|
],
|
|
alias: ["lisp"]
|
|
},
|
|
{
|
|
name: "Cypher",
|
|
mime: "application/x-cypher-query",
|
|
mode: "cypher",
|
|
ext: ["cyp", "cypher"]
|
|
},
|
|
{
|
|
name: "Cython",
|
|
mime: "text/x-cython",
|
|
mode: "python",
|
|
ext: [
|
|
"pyx",
|
|
"pxd",
|
|
"pxi"
|
|
]
|
|
},
|
|
{
|
|
name: "Crystal",
|
|
mime: "text/x-crystal",
|
|
mode: "crystal",
|
|
ext: ["cr"]
|
|
},
|
|
{
|
|
name: "CSS",
|
|
mime: "text/css",
|
|
mode: "css",
|
|
ext: ["css"]
|
|
},
|
|
{
|
|
name: "CQL",
|
|
mime: "text/x-cassandra",
|
|
mode: "sql",
|
|
ext: ["cql"]
|
|
},
|
|
{
|
|
name: "D",
|
|
mime: "text/x-d",
|
|
mode: "d",
|
|
ext: ["d"]
|
|
},
|
|
{
|
|
name: "Dart",
|
|
mimes: ["application/dart", "text/x-dart"],
|
|
mode: "dart",
|
|
ext: ["dart"]
|
|
},
|
|
{
|
|
name: "diff",
|
|
mime: "text/x-diff",
|
|
mode: "diff",
|
|
ext: ["diff", "patch"]
|
|
},
|
|
{
|
|
name: "Django",
|
|
mime: "text/x-django",
|
|
mode: "django"
|
|
},
|
|
{
|
|
name: "Dockerfile",
|
|
mime: "text/x-dockerfile",
|
|
mode: "dockerfile",
|
|
file: /^Dockerfile$/
|
|
},
|
|
{
|
|
name: "DTD",
|
|
mime: "application/xml-dtd",
|
|
mode: "dtd",
|
|
ext: ["dtd"]
|
|
},
|
|
{
|
|
name: "Dylan",
|
|
mime: "text/x-dylan",
|
|
mode: "dylan",
|
|
ext: [
|
|
"dylan",
|
|
"dyl",
|
|
"intr"
|
|
]
|
|
},
|
|
{
|
|
name: "EBNF",
|
|
mime: "text/x-ebnf",
|
|
mode: "ebnf"
|
|
},
|
|
{
|
|
name: "ECL",
|
|
mime: "text/x-ecl",
|
|
mode: "ecl",
|
|
ext: ["ecl"]
|
|
},
|
|
{
|
|
name: "edn",
|
|
mime: "application/edn",
|
|
mode: "clojure",
|
|
ext: ["edn"]
|
|
},
|
|
{
|
|
name: "Eiffel",
|
|
mime: "text/x-eiffel",
|
|
mode: "eiffel",
|
|
ext: ["e"]
|
|
},
|
|
{
|
|
name: "Elm",
|
|
mime: "text/x-elm",
|
|
mode: "elm",
|
|
ext: ["elm"]
|
|
},
|
|
{
|
|
name: "Embedded JavaScript",
|
|
mime: "application/x-ejs",
|
|
mode: "htmlembedded",
|
|
ext: ["ejs"]
|
|
},
|
|
{
|
|
name: "Embedded Ruby",
|
|
mime: "application/x-erb",
|
|
mode: "htmlembedded",
|
|
ext: ["erb"]
|
|
},
|
|
{
|
|
name: "Erlang",
|
|
mime: "text/x-erlang",
|
|
mode: "erlang",
|
|
ext: ["erl"]
|
|
},
|
|
{
|
|
name: "Esper",
|
|
mime: "text/x-esper",
|
|
mode: "sql"
|
|
},
|
|
{
|
|
name: "Factor",
|
|
mime: "text/x-factor",
|
|
mode: "factor",
|
|
ext: ["factor"]
|
|
},
|
|
{
|
|
name: "FCL",
|
|
mime: "text/x-fcl",
|
|
mode: "fcl"
|
|
},
|
|
{
|
|
name: "Forth",
|
|
mime: "text/x-forth",
|
|
mode: "forth",
|
|
ext: [
|
|
"forth",
|
|
"fth",
|
|
"4th"
|
|
]
|
|
},
|
|
{
|
|
name: "Fortran",
|
|
mime: "text/x-fortran",
|
|
mode: "fortran",
|
|
ext: [
|
|
"f",
|
|
"for",
|
|
"f77",
|
|
"f90",
|
|
"f95"
|
|
]
|
|
},
|
|
{
|
|
name: "F#",
|
|
mime: "text/x-fsharp",
|
|
mode: "mllike",
|
|
ext: ["fs"],
|
|
alias: ["fsharp"]
|
|
},
|
|
{
|
|
name: "Gas",
|
|
mime: "text/x-gas",
|
|
mode: "gas",
|
|
ext: ["s"]
|
|
},
|
|
{
|
|
name: "Gherkin",
|
|
mime: "text/x-feature",
|
|
mode: "gherkin",
|
|
ext: ["feature"]
|
|
},
|
|
{
|
|
name: "GitHub Flavored Markdown",
|
|
mime: "text/x-gfm",
|
|
mode: "gfm",
|
|
file: /^(readme|contributing|history)\.md$/i
|
|
},
|
|
{
|
|
name: "Go",
|
|
mime: "text/x-go",
|
|
mode: "go",
|
|
ext: ["go"]
|
|
},
|
|
{
|
|
name: "Groovy",
|
|
mime: "text/x-groovy",
|
|
mode: "groovy",
|
|
ext: ["groovy", "gradle"],
|
|
file: /^Jenkinsfile$/
|
|
},
|
|
{
|
|
name: "HAML",
|
|
mime: "text/x-haml",
|
|
mode: "haml",
|
|
ext: ["haml"]
|
|
},
|
|
{
|
|
name: "Haskell",
|
|
mime: "text/x-haskell",
|
|
mode: "haskell",
|
|
ext: ["hs"]
|
|
},
|
|
{
|
|
name: "Haskell (Literate)",
|
|
mime: "text/x-literate-haskell",
|
|
mode: "haskell-literate",
|
|
ext: ["lhs"]
|
|
},
|
|
{
|
|
name: "Haxe",
|
|
mime: "text/x-haxe",
|
|
mode: "haxe",
|
|
ext: ["hx"]
|
|
},
|
|
{
|
|
name: "HXML",
|
|
mime: "text/x-hxml",
|
|
mode: "haxe",
|
|
ext: ["hxml"]
|
|
},
|
|
{
|
|
name: "ASP.NET",
|
|
mime: "application/x-aspx",
|
|
mode: "htmlembedded",
|
|
ext: ["aspx"],
|
|
alias: ["asp", "aspx"]
|
|
},
|
|
{
|
|
name: "HTML",
|
|
mime: "text/html",
|
|
mode: "htmlmixed",
|
|
ext: [
|
|
"html",
|
|
"htm",
|
|
"handlebars",
|
|
"hbs"
|
|
],
|
|
alias: ["xhtml"]
|
|
},
|
|
{
|
|
name: "HTTP",
|
|
mime: "message/http",
|
|
mode: "http"
|
|
},
|
|
{
|
|
name: "IDL",
|
|
mime: "text/x-idl",
|
|
mode: "idl",
|
|
ext: ["pro"]
|
|
},
|
|
{
|
|
name: "Pug",
|
|
mime: "text/x-pug",
|
|
mode: "pug",
|
|
ext: ["jade", "pug"],
|
|
alias: ["jade"]
|
|
},
|
|
{
|
|
name: "Java",
|
|
mime: "text/x-java",
|
|
mode: "clike",
|
|
ext: ["java"]
|
|
},
|
|
{
|
|
name: "Java Server Pages",
|
|
mime: "application/x-jsp",
|
|
mode: "htmlembedded",
|
|
ext: ["jsp"],
|
|
alias: ["jsp"]
|
|
},
|
|
{
|
|
name: "JavaScript",
|
|
mimes: [
|
|
"text/javascript",
|
|
"text/ecmascript",
|
|
"application/javascript",
|
|
"application/x-javascript",
|
|
"application/ecmascript"
|
|
],
|
|
mode: "javascript",
|
|
ext: ["js"],
|
|
alias: [
|
|
"ecmascript",
|
|
"js",
|
|
"node"
|
|
]
|
|
},
|
|
{
|
|
name: "JSON",
|
|
mimes: ["application/json", "application/x-json"],
|
|
mode: "javascript",
|
|
ext: ["json", "map"],
|
|
alias: ["json5"]
|
|
},
|
|
{
|
|
name: "JSON-LD",
|
|
mime: "application/ld+json",
|
|
mode: "javascript",
|
|
ext: ["jsonld"],
|
|
alias: ["jsonld"]
|
|
},
|
|
{
|
|
name: "JSX",
|
|
mime: "text/jsx",
|
|
mode: "jsx",
|
|
ext: ["jsx"]
|
|
},
|
|
{
|
|
name: "Jinja2",
|
|
mime: "text/jinja2",
|
|
mode: "jinja2",
|
|
ext: [
|
|
"j2",
|
|
"jinja",
|
|
"jinja2"
|
|
]
|
|
},
|
|
{
|
|
name: "Julia",
|
|
mime: "text/x-julia",
|
|
mode: "julia",
|
|
ext: ["jl"],
|
|
alias: ["jl"]
|
|
},
|
|
{
|
|
name: "Kotlin",
|
|
mime: "text/x-kotlin",
|
|
mode: "clike",
|
|
ext: ["kt"]
|
|
},
|
|
{
|
|
name: "LESS",
|
|
mime: "text/x-less",
|
|
mode: "css",
|
|
ext: ["less"]
|
|
},
|
|
{
|
|
name: "LiveScript",
|
|
mime: "text/x-livescript",
|
|
mode: "livescript",
|
|
ext: ["ls"],
|
|
alias: ["ls"]
|
|
},
|
|
{
|
|
name: "Lua",
|
|
mime: "text/x-lua",
|
|
mode: "lua",
|
|
ext: ["lua"]
|
|
},
|
|
{
|
|
name: "Markdown",
|
|
mime: "text/x-markdown",
|
|
mode: "markdown",
|
|
ext: [
|
|
"markdown",
|
|
"md",
|
|
"mkd"
|
|
]
|
|
},
|
|
{
|
|
name: "mIRC",
|
|
mime: "text/mirc",
|
|
mode: "mirc"
|
|
},
|
|
{
|
|
name: "MariaDB SQL",
|
|
mime: "text/x-mariadb",
|
|
mode: "sql"
|
|
},
|
|
{
|
|
name: "Mathematica",
|
|
mime: "text/x-mathematica",
|
|
mode: "mathematica",
|
|
ext: [
|
|
"m",
|
|
"nb",
|
|
"wl",
|
|
"wls"
|
|
]
|
|
},
|
|
{
|
|
name: "Modelica",
|
|
mime: "text/x-modelica",
|
|
mode: "modelica",
|
|
ext: ["mo"]
|
|
},
|
|
{
|
|
name: "MUMPS",
|
|
mime: "text/x-mumps",
|
|
mode: "mumps",
|
|
ext: ["mps"]
|
|
},
|
|
{
|
|
name: "MS SQL",
|
|
mime: "text/x-mssql",
|
|
mode: "sql"
|
|
},
|
|
{
|
|
name: "mbox",
|
|
mime: "application/mbox",
|
|
mode: "mbox",
|
|
ext: ["mbox"]
|
|
},
|
|
{
|
|
name: "MySQL",
|
|
mime: "text/x-mysql",
|
|
mode: "sql"
|
|
},
|
|
{
|
|
name: "Nginx",
|
|
mime: "text/x-nginx-conf",
|
|
mode: "nginx",
|
|
file: /nginx.*\.conf$/i
|
|
},
|
|
{
|
|
name: "NSIS",
|
|
mime: "text/x-nsis",
|
|
mode: "nsis",
|
|
ext: ["nsh", "nsi"]
|
|
},
|
|
{
|
|
name: "NTriples",
|
|
mimes: [
|
|
"application/n-triples",
|
|
"application/n-quads",
|
|
"text/n-triples"
|
|
],
|
|
mode: "ntriples",
|
|
ext: ["nt", "nq"]
|
|
},
|
|
{
|
|
name: "Objective-C",
|
|
mime: "text/x-objectivec",
|
|
mode: "clike",
|
|
ext: ["m"],
|
|
alias: ["objective-c", "objc"]
|
|
},
|
|
{
|
|
name: "Objective-C++",
|
|
mime: "text/x-objectivec++",
|
|
mode: "clike",
|
|
ext: ["mm"],
|
|
alias: ["objective-c++", "objc++"]
|
|
},
|
|
{
|
|
name: "OCaml",
|
|
mime: "text/x-ocaml",
|
|
mode: "mllike",
|
|
ext: [
|
|
"ml",
|
|
"mli",
|
|
"mll",
|
|
"mly"
|
|
]
|
|
},
|
|
{
|
|
name: "Octave",
|
|
mime: "text/x-octave",
|
|
mode: "octave",
|
|
ext: ["m"]
|
|
},
|
|
{
|
|
name: "Oz",
|
|
mime: "text/x-oz",
|
|
mode: "oz",
|
|
ext: ["oz"]
|
|
},
|
|
{
|
|
name: "Pascal",
|
|
mime: "text/x-pascal",
|
|
mode: "pascal",
|
|
ext: ["p", "pas"]
|
|
},
|
|
{
|
|
name: "PEG.js",
|
|
mime: "null",
|
|
mode: "pegjs",
|
|
ext: ["jsonld"]
|
|
},
|
|
{
|
|
name: "Perl",
|
|
mime: "text/x-perl",
|
|
mode: "perl",
|
|
ext: ["pl", "pm"]
|
|
},
|
|
{
|
|
name: "PHP",
|
|
mimes: [
|
|
"text/x-php",
|
|
"application/x-httpd-php",
|
|
"application/x-httpd-php-open"
|
|
],
|
|
mode: "php",
|
|
ext: [
|
|
"php",
|
|
"php3",
|
|
"php4",
|
|
"php5",
|
|
"php7",
|
|
"phtml"
|
|
]
|
|
},
|
|
{
|
|
name: "Pig",
|
|
mime: "text/x-pig",
|
|
mode: "pig",
|
|
ext: ["pig"]
|
|
},
|
|
{
|
|
name: "Plain Text",
|
|
mime: "text/plain",
|
|
mode: "null",
|
|
ext: [
|
|
"txt",
|
|
"text",
|
|
"conf",
|
|
"def",
|
|
"list",
|
|
"log"
|
|
]
|
|
},
|
|
{
|
|
name: "PLSQL",
|
|
mime: "text/x-plsql",
|
|
mode: "sql",
|
|
ext: ["pls"]
|
|
},
|
|
{
|
|
name: "PostgreSQL",
|
|
mime: "text/x-pgsql",
|
|
mode: "sql"
|
|
},
|
|
{
|
|
name: "PowerShell",
|
|
mime: "application/x-powershell",
|
|
mode: "powershell",
|
|
ext: [
|
|
"ps1",
|
|
"psd1",
|
|
"psm1"
|
|
]
|
|
},
|
|
{
|
|
name: "Properties files",
|
|
mime: "text/x-properties",
|
|
mode: "properties",
|
|
ext: [
|
|
"properties",
|
|
"ini",
|
|
"in"
|
|
],
|
|
alias: ["ini", "properties"]
|
|
},
|
|
{
|
|
name: "ProtoBuf",
|
|
mime: "text/x-protobuf",
|
|
mode: "protobuf",
|
|
ext: ["proto"]
|
|
},
|
|
{
|
|
name: "Python",
|
|
mime: "text/x-python",
|
|
mode: "python",
|
|
ext: [
|
|
"BUILD",
|
|
"bzl",
|
|
"py",
|
|
"pyw"
|
|
],
|
|
file: /^(BUCK|BUILD)$/
|
|
},
|
|
{
|
|
name: "Puppet",
|
|
mime: "text/x-puppet",
|
|
mode: "puppet",
|
|
ext: ["pp"]
|
|
},
|
|
{
|
|
name: "Q",
|
|
mime: "text/x-q",
|
|
mode: "q",
|
|
ext: ["q"]
|
|
},
|
|
{
|
|
name: "R",
|
|
mime: "text/x-rsrc",
|
|
mode: "r",
|
|
ext: ["r", "R"],
|
|
alias: ["rscript"]
|
|
},
|
|
{
|
|
name: "reStructuredText",
|
|
mime: "text/x-rst",
|
|
mode: "rst",
|
|
ext: ["rst"],
|
|
alias: ["rst"]
|
|
},
|
|
{
|
|
name: "RPM Changes",
|
|
mime: "text/x-rpm-changes",
|
|
mode: "rpm"
|
|
},
|
|
{
|
|
name: "RPM Spec",
|
|
mime: "text/x-rpm-spec",
|
|
mode: "rpm",
|
|
ext: ["spec"]
|
|
},
|
|
{
|
|
name: "Ruby",
|
|
mime: "text/x-ruby",
|
|
mode: "ruby",
|
|
ext: ["rb"],
|
|
alias: [
|
|
"jruby",
|
|
"macruby",
|
|
"rake",
|
|
"rb",
|
|
"rbx"
|
|
]
|
|
},
|
|
{
|
|
name: "Rust",
|
|
mime: "text/x-rustsrc",
|
|
mode: "rust",
|
|
ext: ["rs"]
|
|
},
|
|
{
|
|
name: "SAS",
|
|
mime: "text/x-sas",
|
|
mode: "sas",
|
|
ext: ["sas"]
|
|
},
|
|
{
|
|
name: "Sass",
|
|
mime: "text/x-sass",
|
|
mode: "sass",
|
|
ext: ["sass"]
|
|
},
|
|
{
|
|
name: "Scala",
|
|
mime: "text/x-scala",
|
|
mode: "clike",
|
|
ext: ["scala"]
|
|
},
|
|
{
|
|
name: "Scheme",
|
|
mime: "text/x-scheme",
|
|
mode: "scheme",
|
|
ext: ["scm", "ss"]
|
|
},
|
|
{
|
|
name: "SCSS",
|
|
mime: "text/x-scss",
|
|
mode: "css",
|
|
ext: ["scss"]
|
|
},
|
|
{
|
|
name: "Shell",
|
|
mimes: ["text/x-sh", "application/x-sh"],
|
|
mode: "shell",
|
|
ext: [
|
|
"sh",
|
|
"ksh",
|
|
"bash"
|
|
],
|
|
alias: [
|
|
"bash",
|
|
"sh",
|
|
"zsh"
|
|
],
|
|
file: /^PKGBUILD$/
|
|
},
|
|
{
|
|
name: "Sieve",
|
|
mime: "application/sieve",
|
|
mode: "sieve",
|
|
ext: ["siv", "sieve"]
|
|
},
|
|
{
|
|
name: "Slim",
|
|
mimes: ["text/x-slim", "application/x-slim"],
|
|
mode: "slim",
|
|
ext: ["slim"]
|
|
},
|
|
{
|
|
name: "Smalltalk",
|
|
mime: "text/x-stsrc",
|
|
mode: "smalltalk",
|
|
ext: ["st"]
|
|
},
|
|
{
|
|
name: "Smarty",
|
|
mime: "text/x-smarty",
|
|
mode: "smarty",
|
|
ext: ["tpl"]
|
|
},
|
|
{
|
|
name: "Solr",
|
|
mime: "text/x-solr",
|
|
mode: "solr"
|
|
},
|
|
{
|
|
name: "SML",
|
|
mime: "text/x-sml",
|
|
mode: "mllike",
|
|
ext: [
|
|
"sml",
|
|
"sig",
|
|
"fun",
|
|
"smackspec"
|
|
]
|
|
},
|
|
{
|
|
name: "Soy",
|
|
mime: "text/x-soy",
|
|
mode: "soy",
|
|
ext: ["soy"],
|
|
alias: ["closure template"]
|
|
},
|
|
{
|
|
name: "SPARQL",
|
|
mime: "application/sparql-query",
|
|
mode: "sparql",
|
|
ext: ["rq", "sparql"],
|
|
alias: ["sparul"]
|
|
},
|
|
{
|
|
name: "Spreadsheet",
|
|
mime: "text/x-spreadsheet",
|
|
mode: "spreadsheet",
|
|
alias: ["excel", "formula"]
|
|
},
|
|
{
|
|
name: "SQL",
|
|
mime: "text/x-sql",
|
|
mode: "sql",
|
|
ext: ["sql"]
|
|
},
|
|
{
|
|
name: "SQLite",
|
|
mime: "text/x-sqlite",
|
|
mode: "sql"
|
|
},
|
|
{
|
|
name: "Squirrel",
|
|
mime: "text/x-squirrel",
|
|
mode: "clike",
|
|
ext: ["nut"]
|
|
},
|
|
{
|
|
name: "Stylus",
|
|
mime: "text/x-styl",
|
|
mode: "stylus",
|
|
ext: ["styl"]
|
|
},
|
|
{
|
|
name: "Swift",
|
|
mime: "text/x-swift",
|
|
mode: "swift",
|
|
ext: ["swift"]
|
|
},
|
|
{
|
|
name: "sTeX",
|
|
mime: "text/x-stex",
|
|
mode: "stex"
|
|
},
|
|
{
|
|
name: "LaTeX",
|
|
mime: "text/x-latex",
|
|
mode: "stex",
|
|
ext: [
|
|
"text",
|
|
"ltx",
|
|
"tex"
|
|
],
|
|
alias: ["tex"]
|
|
},
|
|
{
|
|
name: "SystemVerilog",
|
|
mime: "text/x-systemverilog",
|
|
mode: "verilog",
|
|
ext: [
|
|
"v",
|
|
"sv",
|
|
"svh"
|
|
]
|
|
},
|
|
{
|
|
name: "Tcl",
|
|
mime: "text/x-tcl",
|
|
mode: "tcl",
|
|
ext: ["tcl"]
|
|
},
|
|
{
|
|
name: "Textile",
|
|
mime: "text/x-textile",
|
|
mode: "textile",
|
|
ext: ["textile"]
|
|
},
|
|
{
|
|
name: "TiddlyWiki",
|
|
mime: "text/x-tiddlywiki",
|
|
mode: "tiddlywiki"
|
|
},
|
|
{
|
|
name: "Tiki wiki",
|
|
mime: "text/tiki",
|
|
mode: "tiki"
|
|
},
|
|
{
|
|
name: "TOML",
|
|
mime: "text/x-toml",
|
|
mode: "toml",
|
|
ext: ["toml"]
|
|
},
|
|
{
|
|
name: "Tornado",
|
|
mime: "text/x-tornado",
|
|
mode: "tornado"
|
|
},
|
|
{
|
|
name: "troff",
|
|
mime: "text/troff",
|
|
mode: "troff",
|
|
ext: [
|
|
"1",
|
|
"2",
|
|
"3",
|
|
"4",
|
|
"5",
|
|
"6",
|
|
"7",
|
|
"8",
|
|
"9"
|
|
]
|
|
},
|
|
{
|
|
name: "TTCN",
|
|
mime: "text/x-ttcn",
|
|
mode: "ttcn",
|
|
ext: [
|
|
"ttcn",
|
|
"ttcn3",
|
|
"ttcnpp"
|
|
]
|
|
},
|
|
{
|
|
name: "TTCN_CFG",
|
|
mime: "text/x-ttcn-cfg",
|
|
mode: "ttcn-cfg",
|
|
ext: ["cfg"]
|
|
},
|
|
{
|
|
name: "Turtle",
|
|
mime: "text/turtle",
|
|
mode: "turtle",
|
|
ext: ["ttl"]
|
|
},
|
|
{
|
|
name: "TypeScript",
|
|
mime: "application/typescript",
|
|
mode: "javascript",
|
|
ext: ["ts"],
|
|
alias: ["ts"]
|
|
},
|
|
{
|
|
name: "TypeScript-JSX",
|
|
mime: "text/typescript-jsx",
|
|
mode: "jsx",
|
|
ext: ["tsx"],
|
|
alias: ["tsx"]
|
|
},
|
|
{
|
|
name: "Twig",
|
|
mime: "text/x-twig",
|
|
mode: "twig"
|
|
},
|
|
{
|
|
name: "Web IDL",
|
|
mime: "text/x-webidl",
|
|
mode: "webidl",
|
|
ext: ["webidl"]
|
|
},
|
|
{
|
|
name: "VB.NET",
|
|
mime: "text/x-vb",
|
|
mode: "vb",
|
|
ext: ["vb"]
|
|
},
|
|
{
|
|
name: "VBScript",
|
|
mime: "text/vbscript",
|
|
mode: "vbscript",
|
|
ext: ["vbs"]
|
|
},
|
|
{
|
|
name: "Velocity",
|
|
mime: "text/velocity",
|
|
mode: "velocity",
|
|
ext: ["vtl"]
|
|
},
|
|
{
|
|
name: "Verilog",
|
|
mime: "text/x-verilog",
|
|
mode: "verilog",
|
|
ext: ["v"]
|
|
},
|
|
{
|
|
name: "VHDL",
|
|
mime: "text/x-vhdl",
|
|
mode: "vhdl",
|
|
ext: ["vhd", "vhdl"]
|
|
},
|
|
{
|
|
name: "Vue.js Component",
|
|
mimes: ["script/x-vue", "text/x-vue"],
|
|
mode: "vue",
|
|
ext: ["vue"]
|
|
},
|
|
{
|
|
name: "XML",
|
|
mimes: ["application/xml", "text/xml"],
|
|
mode: "xml",
|
|
ext: [
|
|
"xml",
|
|
"xsl",
|
|
"xsd",
|
|
"svg"
|
|
],
|
|
alias: [
|
|
"rss",
|
|
"wsdl",
|
|
"xsd"
|
|
]
|
|
},
|
|
{
|
|
name: "XQuery",
|
|
mime: "application/xquery",
|
|
mode: "xquery",
|
|
ext: ["xy", "xquery"]
|
|
},
|
|
{
|
|
name: "Yacas",
|
|
mime: "text/x-yacas",
|
|
mode: "yacas",
|
|
ext: ["ys"]
|
|
},
|
|
{
|
|
name: "YAML",
|
|
mimes: ["text/x-yaml", "text/yaml"],
|
|
mode: "yaml",
|
|
ext: ["yaml", "yml"],
|
|
alias: ["yml"]
|
|
},
|
|
{
|
|
name: "Z80",
|
|
mime: "text/x-z80",
|
|
mode: "z80",
|
|
ext: ["z80"]
|
|
},
|
|
{
|
|
name: "mscgen",
|
|
mime: "text/x-mscgen",
|
|
mode: "mscgen",
|
|
ext: [
|
|
"mscgen",
|
|
"mscin",
|
|
"msc"
|
|
]
|
|
},
|
|
{
|
|
name: "xu",
|
|
mime: "text/x-xu",
|
|
mode: "mscgen",
|
|
ext: ["xu"]
|
|
},
|
|
{
|
|
name: "msgenny",
|
|
mime: "text/x-msgenny",
|
|
mode: "mscgen",
|
|
ext: ["msgenny"]
|
|
},
|
|
{
|
|
name: "WebAssembly",
|
|
mime: "text/webassembly",
|
|
mode: "wast",
|
|
ext: ["wat", "wast"]
|
|
}
|
|
];
|
|
for (var i = 0; i < CodeMirror$1.modeInfo.length; i++) {
|
|
var info = CodeMirror$1.modeInfo[i];
|
|
if (info.mimes) info.mime = info.mimes[0];
|
|
}
|
|
CodeMirror$1.findModeByMIME = function(mime) {
|
|
mime = mime.toLowerCase();
|
|
for (var i$1 = 0; i$1 < CodeMirror$1.modeInfo.length; i$1++) {
|
|
var info$1 = CodeMirror$1.modeInfo[i$1];
|
|
if (info$1.mime == mime) return info$1;
|
|
if (info$1.mimes) {
|
|
for (var j = 0; j < info$1.mimes.length; j++) if (info$1.mimes[j] == mime) return info$1;
|
|
}
|
|
}
|
|
if (/\+xml$/.test(mime)) return CodeMirror$1.findModeByMIME("application/xml");
|
|
if (/\+json$/.test(mime)) return CodeMirror$1.findModeByMIME("application/json");
|
|
};
|
|
CodeMirror$1.findModeByExtension = function(ext) {
|
|
ext = ext.toLowerCase();
|
|
for (var i$1 = 0; i$1 < CodeMirror$1.modeInfo.length; i$1++) {
|
|
var info$1 = CodeMirror$1.modeInfo[i$1];
|
|
if (info$1.ext) {
|
|
for (var j = 0; j < info$1.ext.length; j++) if (info$1.ext[j] == ext) return info$1;
|
|
}
|
|
}
|
|
};
|
|
CodeMirror$1.findModeByFileName = function(filename) {
|
|
for (var i$1 = 0; i$1 < CodeMirror$1.modeInfo.length; i$1++) {
|
|
var info$1 = CodeMirror$1.modeInfo[i$1];
|
|
if (info$1.file && info$1.file.test(filename)) return info$1;
|
|
}
|
|
var dot = filename.lastIndexOf(".");
|
|
var ext = dot > -1 && filename.substring(dot + 1, filename.length);
|
|
if (ext) return CodeMirror$1.findModeByExtension(ext);
|
|
};
|
|
CodeMirror$1.findModeByName = function(name) {
|
|
name = name.toLowerCase();
|
|
for (var i$1 = 0; i$1 < CodeMirror$1.modeInfo.length; i$1++) {
|
|
var info$1 = CodeMirror$1.modeInfo[i$1];
|
|
if (info$1.name.toLowerCase() == name) return info$1;
|
|
if (info$1.alias) {
|
|
for (var j = 0; j < info$1.alias.length; j++) if (info$1.alias[j].toLowerCase() == name) return info$1;
|
|
}
|
|
}
|
|
};
|
|
});
|
|
});
|
|
var require_markdown = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror(), require_xml(), require_meta());
|
|
else if (typeof define == "function" && define.amd) define([
|
|
"../../lib/codemirror",
|
|
"../xml/xml",
|
|
"../meta"
|
|
], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineMode("markdown", function(cmCfg, modeCfg) {
|
|
var htmlMode = CodeMirror$1.getMode(cmCfg, "text/html");
|
|
var htmlModeMissing = htmlMode.name == "null";
|
|
function getMode(name) {
|
|
if (CodeMirror$1.findModeByName) {
|
|
var found = CodeMirror$1.findModeByName(name);
|
|
if (found) name = found.mime || found.mimes[0];
|
|
}
|
|
var mode$1 = CodeMirror$1.getMode(cmCfg, name);
|
|
return mode$1.name == "null" ? null : mode$1;
|
|
}
|
|
if (modeCfg.highlightFormatting === void 0) modeCfg.highlightFormatting = false;
|
|
if (modeCfg.maxBlockquoteDepth === void 0) modeCfg.maxBlockquoteDepth = 0;
|
|
if (modeCfg.taskLists === void 0) modeCfg.taskLists = false;
|
|
if (modeCfg.strikethrough === void 0) modeCfg.strikethrough = false;
|
|
if (modeCfg.emoji === void 0) modeCfg.emoji = false;
|
|
if (modeCfg.fencedCodeBlockHighlighting === void 0) modeCfg.fencedCodeBlockHighlighting = true;
|
|
if (modeCfg.fencedCodeBlockDefaultMode === void 0) modeCfg.fencedCodeBlockDefaultMode = "text/plain";
|
|
if (modeCfg.xml === void 0) modeCfg.xml = true;
|
|
if (modeCfg.tokenTypeOverrides === void 0) modeCfg.tokenTypeOverrides = {};
|
|
var tokenTypes = {
|
|
header: "header",
|
|
code: "comment",
|
|
quote: "quote",
|
|
list1: "variable-2",
|
|
list2: "variable-3",
|
|
list3: "keyword",
|
|
hr: "hr",
|
|
image: "image",
|
|
imageAltText: "image-alt-text",
|
|
imageMarker: "image-marker",
|
|
formatting: "formatting",
|
|
linkInline: "link",
|
|
linkEmail: "link",
|
|
linkText: "link",
|
|
linkHref: "string",
|
|
em: "em",
|
|
strong: "strong",
|
|
strikethrough: "strikethrough",
|
|
emoji: "builtin"
|
|
};
|
|
for (var tokenType in tokenTypes) if (tokenTypes.hasOwnProperty(tokenType) && modeCfg.tokenTypeOverrides[tokenType]) tokenTypes[tokenType] = modeCfg.tokenTypeOverrides[tokenType];
|
|
var hrRE = /^([*\-_])(?:\s*\1){2,}\s*$/, listRE = /^(?:[*\-+]|^[0-9]+([.)]))\s+/, taskListRE = /^\[(x| )\](?=\s)/i, atxHeaderRE = modeCfg.allowAtxHeaderWithoutSpace ? /^(#+)/ : /^(#+)(?: |$)/, setextHeaderRE = /^ {0,3}(?:\={1,}|-{2,})\s*$/, textRE = /^[^#!\[\]*_\\<>` "'(~:]+/, fencedCodeRE = /^(~~~+|```+)[ \t]*([\w\/+#-]*)[^\n`]*$/, linkDefRE = /^\s*\[[^\]]+?\]:.*$/, punctuation = /[!"#$%&'()*+,\-.\/:;<=>?@\[\\\]^_`{|}~\xA1\xA7\xAB\xB6\xB7\xBB\xBF\u037E\u0387\u055A-\u055F\u0589\u058A\u05BE\u05C0\u05C3\u05C6\u05F3\u05F4\u0609\u060A\u060C\u060D\u061B\u061E\u061F\u066A-\u066D\u06D4\u0700-\u070D\u07F7-\u07F9\u0830-\u083E\u085E\u0964\u0965\u0970\u0AF0\u0DF4\u0E4F\u0E5A\u0E5B\u0F04-\u0F12\u0F14\u0F3A-\u0F3D\u0F85\u0FD0-\u0FD4\u0FD9\u0FDA\u104A-\u104F\u10FB\u1360-\u1368\u1400\u166D\u166E\u169B\u169C\u16EB-\u16ED\u1735\u1736\u17D4-\u17D6\u17D8-\u17DA\u1800-\u180A\u1944\u1945\u1A1E\u1A1F\u1AA0-\u1AA6\u1AA8-\u1AAD\u1B5A-\u1B60\u1BFC-\u1BFF\u1C3B-\u1C3F\u1C7E\u1C7F\u1CC0-\u1CC7\u1CD3\u2010-\u2027\u2030-\u2043\u2045-\u2051\u2053-\u205E\u207D\u207E\u208D\u208E\u2308-\u230B\u2329\u232A\u2768-\u2775\u27C5\u27C6\u27E6-\u27EF\u2983-\u2998\u29D8-\u29DB\u29FC\u29FD\u2CF9-\u2CFC\u2CFE\u2CFF\u2D70\u2E00-\u2E2E\u2E30-\u2E42\u3001-\u3003\u3008-\u3011\u3014-\u301F\u3030\u303D\u30A0\u30FB\uA4FE\uA4FF\uA60D-\uA60F\uA673\uA67E\uA6F2-\uA6F7\uA874-\uA877\uA8CE\uA8CF\uA8F8-\uA8FA\uA8FC\uA92E\uA92F\uA95F\uA9C1-\uA9CD\uA9DE\uA9DF\uAA5C-\uAA5F\uAADE\uAADF\uAAF0\uAAF1\uABEB\uFD3E\uFD3F\uFE10-\uFE19\uFE30-\uFE52\uFE54-\uFE61\uFE63\uFE68\uFE6A\uFE6B\uFF01-\uFF03\uFF05-\uFF0A\uFF0C-\uFF0F\uFF1A\uFF1B\uFF1F\uFF20\uFF3B-\uFF3D\uFF3F\uFF5B\uFF5D\uFF5F-\uFF65]|\uD800[\uDD00-\uDD02\uDF9F\uDFD0]|\uD801\uDD6F|\uD802[\uDC57\uDD1F\uDD3F\uDE50-\uDE58\uDE7F\uDEF0-\uDEF6\uDF39-\uDF3F\uDF99-\uDF9C]|\uD804[\uDC47-\uDC4D\uDCBB\uDCBC\uDCBE-\uDCC1\uDD40-\uDD43\uDD74\uDD75\uDDC5-\uDDC9\uDDCD\uDDDB\uDDDD-\uDDDF\uDE38-\uDE3D\uDEA9]|\uD805[\uDCC6\uDDC1-\uDDD7\uDE41-\uDE43\uDF3C-\uDF3E]|\uD809[\uDC70-\uDC74]|\uD81A[\uDE6E\uDE6F\uDEF5\uDF37-\uDF3B\uDF44]|\uD82F\uDC9F|\uD836[\uDE87-\uDE8B]/, expandedTab = " ";
|
|
function switchInline(stream, state, f) {
|
|
state.f = state.inline = f;
|
|
return f(stream, state);
|
|
}
|
|
function switchBlock(stream, state, f) {
|
|
state.f = state.block = f;
|
|
return f(stream, state);
|
|
}
|
|
function lineIsEmpty(line) {
|
|
return !line || !/\S/.test(line.string);
|
|
}
|
|
function blankLine(state) {
|
|
state.linkTitle = false;
|
|
state.linkHref = false;
|
|
state.linkText = false;
|
|
state.em = false;
|
|
state.strong = false;
|
|
state.strikethrough = false;
|
|
state.quote = 0;
|
|
state.indentedCode = false;
|
|
if (state.f == htmlBlock) {
|
|
var exit = htmlModeMissing;
|
|
if (!exit) {
|
|
var inner = CodeMirror$1.innerMode(htmlMode, state.htmlState);
|
|
exit = inner.mode.name == "xml" && inner.state.tagStart === null && !inner.state.context && inner.state.tokenize.isInText;
|
|
}
|
|
if (exit) {
|
|
state.f = inlineNormal;
|
|
state.block = blockNormal;
|
|
state.htmlState = null;
|
|
}
|
|
}
|
|
state.trailingSpace = 0;
|
|
state.trailingSpaceNewLine = false;
|
|
state.prevLine = state.thisLine;
|
|
state.thisLine = { stream: null };
|
|
return null;
|
|
}
|
|
function blockNormal(stream, state) {
|
|
var firstTokenOnLine = stream.column() === state.indentation;
|
|
var prevLineLineIsEmpty = lineIsEmpty(state.prevLine.stream);
|
|
var prevLineIsIndentedCode = state.indentedCode;
|
|
var prevLineIsHr = state.prevLine.hr;
|
|
var prevLineIsList = state.list !== false;
|
|
var maxNonCodeIndentation = (state.listStack[state.listStack.length - 1] || 0) + 3;
|
|
state.indentedCode = false;
|
|
var lineIndentation = state.indentation;
|
|
if (state.indentationDiff === null) {
|
|
state.indentationDiff = state.indentation;
|
|
if (prevLineIsList) {
|
|
state.list = null;
|
|
while (lineIndentation < state.listStack[state.listStack.length - 1]) {
|
|
state.listStack.pop();
|
|
if (state.listStack.length) state.indentation = state.listStack[state.listStack.length - 1];
|
|
else state.list = false;
|
|
}
|
|
if (state.list !== false) state.indentationDiff = lineIndentation - state.listStack[state.listStack.length - 1];
|
|
}
|
|
}
|
|
var allowsInlineContinuation = !prevLineLineIsEmpty && !prevLineIsHr && !state.prevLine.header && (!prevLineIsList || !prevLineIsIndentedCode) && !state.prevLine.fencedCodeEnd;
|
|
var isHr = (state.list === false || prevLineIsHr || prevLineLineIsEmpty) && state.indentation <= maxNonCodeIndentation && stream.match(hrRE);
|
|
var match = null;
|
|
if (state.indentationDiff >= 4 && (prevLineIsIndentedCode || state.prevLine.fencedCodeEnd || state.prevLine.header || prevLineLineIsEmpty)) {
|
|
stream.skipToEnd();
|
|
state.indentedCode = true;
|
|
return tokenTypes.code;
|
|
} else if (stream.eatSpace()) return null;
|
|
else if (firstTokenOnLine && state.indentation <= maxNonCodeIndentation && (match = stream.match(atxHeaderRE)) && match[1].length <= 6) {
|
|
state.quote = 0;
|
|
state.header = match[1].length;
|
|
state.thisLine.header = true;
|
|
if (modeCfg.highlightFormatting) state.formatting = "header";
|
|
state.f = state.inline;
|
|
return getType(state);
|
|
} else if (state.indentation <= maxNonCodeIndentation && stream.eat(">")) {
|
|
state.quote = firstTokenOnLine ? 1 : state.quote + 1;
|
|
if (modeCfg.highlightFormatting) state.formatting = "quote";
|
|
stream.eatSpace();
|
|
return getType(state);
|
|
} else if (!isHr && !state.setext && firstTokenOnLine && state.indentation <= maxNonCodeIndentation && (match = stream.match(listRE))) {
|
|
var listType = match[1] ? "ol" : "ul";
|
|
state.indentation = lineIndentation + stream.current().length;
|
|
state.list = true;
|
|
state.quote = 0;
|
|
state.listStack.push(state.indentation);
|
|
state.em = false;
|
|
state.strong = false;
|
|
state.code = false;
|
|
state.strikethrough = false;
|
|
if (modeCfg.taskLists && stream.match(taskListRE, false)) state.taskList = true;
|
|
state.f = state.inline;
|
|
if (modeCfg.highlightFormatting) state.formatting = ["list", "list-" + listType];
|
|
return getType(state);
|
|
} else if (firstTokenOnLine && state.indentation <= maxNonCodeIndentation && (match = stream.match(fencedCodeRE, true))) {
|
|
state.quote = 0;
|
|
state.fencedEndRE = new RegExp(match[1] + "+ *$");
|
|
state.localMode = modeCfg.fencedCodeBlockHighlighting && getMode(match[2] || modeCfg.fencedCodeBlockDefaultMode);
|
|
if (state.localMode) state.localState = CodeMirror$1.startState(state.localMode);
|
|
state.f = state.block = local;
|
|
if (modeCfg.highlightFormatting) state.formatting = "code-block";
|
|
state.code = -1;
|
|
return getType(state);
|
|
} else if (state.setext || (!allowsInlineContinuation || !prevLineIsList) && !state.quote && state.list === false && !state.code && !isHr && !linkDefRE.test(stream.string) && (match = stream.lookAhead(1)) && (match = match.match(setextHeaderRE))) {
|
|
if (!state.setext) {
|
|
state.header = match[0].charAt(0) == "=" ? 1 : 2;
|
|
state.setext = state.header;
|
|
} else {
|
|
state.header = state.setext;
|
|
state.setext = 0;
|
|
stream.skipToEnd();
|
|
if (modeCfg.highlightFormatting) state.formatting = "header";
|
|
}
|
|
state.thisLine.header = true;
|
|
state.f = state.inline;
|
|
return getType(state);
|
|
} else if (isHr) {
|
|
stream.skipToEnd();
|
|
state.hr = true;
|
|
state.thisLine.hr = true;
|
|
return tokenTypes.hr;
|
|
} else if (stream.peek() === "[") return switchInline(stream, state, footnoteLink);
|
|
return switchInline(stream, state, state.inline);
|
|
}
|
|
function htmlBlock(stream, state) {
|
|
var style = htmlMode.token(stream, state.htmlState);
|
|
if (!htmlModeMissing) {
|
|
var inner = CodeMirror$1.innerMode(htmlMode, state.htmlState);
|
|
if (inner.mode.name == "xml" && inner.state.tagStart === null && !inner.state.context && inner.state.tokenize.isInText || state.md_inside && stream.current().indexOf(">") > -1) {
|
|
state.f = inlineNormal;
|
|
state.block = blockNormal;
|
|
state.htmlState = null;
|
|
}
|
|
}
|
|
return style;
|
|
}
|
|
function local(stream, state) {
|
|
var currListInd = state.listStack[state.listStack.length - 1] || 0;
|
|
var hasExitedList = state.indentation < currListInd;
|
|
var maxFencedEndInd = currListInd + 3;
|
|
if (state.fencedEndRE && state.indentation <= maxFencedEndInd && (hasExitedList || stream.match(state.fencedEndRE))) {
|
|
if (modeCfg.highlightFormatting) state.formatting = "code-block";
|
|
var returnType;
|
|
if (!hasExitedList) returnType = getType(state);
|
|
state.localMode = state.localState = null;
|
|
state.block = blockNormal;
|
|
state.f = inlineNormal;
|
|
state.fencedEndRE = null;
|
|
state.code = 0;
|
|
state.thisLine.fencedCodeEnd = true;
|
|
if (hasExitedList) return switchBlock(stream, state, state.block);
|
|
return returnType;
|
|
} else if (state.localMode) return state.localMode.token(stream, state.localState);
|
|
else {
|
|
stream.skipToEnd();
|
|
return tokenTypes.code;
|
|
}
|
|
}
|
|
function getType(state) {
|
|
var styles = [];
|
|
if (state.formatting) {
|
|
styles.push(tokenTypes.formatting);
|
|
if (typeof state.formatting === "string") state.formatting = [state.formatting];
|
|
for (var i = 0; i < state.formatting.length; i++) {
|
|
styles.push(tokenTypes.formatting + "-" + state.formatting[i]);
|
|
if (state.formatting[i] === "header") styles.push(tokenTypes.formatting + "-" + state.formatting[i] + "-" + state.header);
|
|
if (state.formatting[i] === "quote") if (!modeCfg.maxBlockquoteDepth || modeCfg.maxBlockquoteDepth >= state.quote) styles.push(tokenTypes.formatting + "-" + state.formatting[i] + "-" + state.quote);
|
|
else styles.push("error");
|
|
}
|
|
}
|
|
if (state.taskOpen) {
|
|
styles.push("meta");
|
|
return styles.length ? styles.join(" ") : null;
|
|
}
|
|
if (state.taskClosed) {
|
|
styles.push("property");
|
|
return styles.length ? styles.join(" ") : null;
|
|
}
|
|
if (state.linkHref) styles.push(tokenTypes.linkHref, "url");
|
|
else {
|
|
if (state.strong) styles.push(tokenTypes.strong);
|
|
if (state.em) styles.push(tokenTypes.em);
|
|
if (state.strikethrough) styles.push(tokenTypes.strikethrough);
|
|
if (state.emoji) styles.push(tokenTypes.emoji);
|
|
if (state.linkText) styles.push(tokenTypes.linkText);
|
|
if (state.code) styles.push(tokenTypes.code);
|
|
if (state.image) styles.push(tokenTypes.image);
|
|
if (state.imageAltText) styles.push(tokenTypes.imageAltText, "link");
|
|
if (state.imageMarker) styles.push(tokenTypes.imageMarker);
|
|
}
|
|
if (state.header) styles.push(tokenTypes.header, tokenTypes.header + "-" + state.header);
|
|
if (state.quote) {
|
|
styles.push(tokenTypes.quote);
|
|
if (!modeCfg.maxBlockquoteDepth || modeCfg.maxBlockquoteDepth >= state.quote) styles.push(tokenTypes.quote + "-" + state.quote);
|
|
else styles.push(tokenTypes.quote + "-" + modeCfg.maxBlockquoteDepth);
|
|
}
|
|
if (state.list !== false) {
|
|
var listMod = (state.listStack.length - 1) % 3;
|
|
if (!listMod) styles.push(tokenTypes.list1);
|
|
else if (listMod === 1) styles.push(tokenTypes.list2);
|
|
else styles.push(tokenTypes.list3);
|
|
}
|
|
if (state.trailingSpaceNewLine) styles.push("trailing-space-new-line");
|
|
else if (state.trailingSpace) styles.push("trailing-space-" + (state.trailingSpace % 2 ? "a" : "b"));
|
|
return styles.length ? styles.join(" ") : null;
|
|
}
|
|
function handleText(stream, state) {
|
|
if (stream.match(textRE, true)) return getType(state);
|
|
return void 0;
|
|
}
|
|
function inlineNormal(stream, state) {
|
|
var style = state.text(stream, state);
|
|
if (typeof style !== "undefined") return style;
|
|
if (state.list) {
|
|
state.list = null;
|
|
return getType(state);
|
|
}
|
|
if (state.taskList) {
|
|
var taskOpen = stream.match(taskListRE, true)[1] === " ";
|
|
if (taskOpen) state.taskOpen = true;
|
|
else state.taskClosed = true;
|
|
if (modeCfg.highlightFormatting) state.formatting = "task";
|
|
state.taskList = false;
|
|
return getType(state);
|
|
}
|
|
state.taskOpen = false;
|
|
state.taskClosed = false;
|
|
if (state.header && stream.match(/^#+$/, true)) {
|
|
if (modeCfg.highlightFormatting) state.formatting = "header";
|
|
return getType(state);
|
|
}
|
|
var ch = stream.next();
|
|
if (state.linkTitle) {
|
|
state.linkTitle = false;
|
|
var matchCh = ch;
|
|
if (ch === "(") matchCh = ")";
|
|
matchCh = (matchCh + "").replace(/([.?*+^\[\]\\(){}|-])/g, "\\$1");
|
|
var regex = "^\\s*(?:[^" + matchCh + "\\\\]+|\\\\\\\\|\\\\.)" + matchCh;
|
|
if (stream.match(new RegExp(regex), true)) return tokenTypes.linkHref;
|
|
}
|
|
if (ch === "`") {
|
|
var previousFormatting = state.formatting;
|
|
if (modeCfg.highlightFormatting) state.formatting = "code";
|
|
stream.eatWhile("`");
|
|
var count = stream.current().length;
|
|
if (state.code == 0 && (!state.quote || count == 1)) {
|
|
state.code = count;
|
|
return getType(state);
|
|
} else if (count == state.code) {
|
|
var t = getType(state);
|
|
state.code = 0;
|
|
return t;
|
|
} else {
|
|
state.formatting = previousFormatting;
|
|
return getType(state);
|
|
}
|
|
} else if (state.code) return getType(state);
|
|
if (ch === "\\") {
|
|
stream.next();
|
|
if (modeCfg.highlightFormatting) {
|
|
var type = getType(state);
|
|
var formattingEscape = tokenTypes.formatting + "-escape";
|
|
return type ? type + " " + formattingEscape : formattingEscape;
|
|
}
|
|
}
|
|
if (ch === "!" && stream.match(/\[[^\]]*\] ?(?:\(|\[)/, false)) {
|
|
state.imageMarker = true;
|
|
state.image = true;
|
|
if (modeCfg.highlightFormatting) state.formatting = "image";
|
|
return getType(state);
|
|
}
|
|
if (ch === "[" && state.imageMarker && stream.match(/[^\]]*\](\(.*?\)| ?\[.*?\])/, false)) {
|
|
state.imageMarker = false;
|
|
state.imageAltText = true;
|
|
if (modeCfg.highlightFormatting) state.formatting = "image";
|
|
return getType(state);
|
|
}
|
|
if (ch === "]" && state.imageAltText) {
|
|
if (modeCfg.highlightFormatting) state.formatting = "image";
|
|
var type = getType(state);
|
|
state.imageAltText = false;
|
|
state.image = false;
|
|
state.inline = state.f = linkHref;
|
|
return type;
|
|
}
|
|
if (ch === "[" && !state.image) {
|
|
if (state.linkText && stream.match(/^.*?\]/)) return getType(state);
|
|
state.linkText = true;
|
|
if (modeCfg.highlightFormatting) state.formatting = "link";
|
|
return getType(state);
|
|
}
|
|
if (ch === "]" && state.linkText) {
|
|
if (modeCfg.highlightFormatting) state.formatting = "link";
|
|
var type = getType(state);
|
|
state.linkText = false;
|
|
state.inline = state.f = stream.match(/\(.*?\)| ?\[.*?\]/, false) ? linkHref : inlineNormal;
|
|
return type;
|
|
}
|
|
if (ch === "<" && stream.match(/^(https?|ftps?):\/\/(?:[^\\>]|\\.)+>/, false)) {
|
|
state.f = state.inline = linkInline;
|
|
if (modeCfg.highlightFormatting) state.formatting = "link";
|
|
var type = getType(state);
|
|
if (type) type += " ";
|
|
else type = "";
|
|
return type + tokenTypes.linkInline;
|
|
}
|
|
if (ch === "<" && stream.match(/^[^> \\]+@(?:[^\\>]|\\.)+>/, false)) {
|
|
state.f = state.inline = linkInline;
|
|
if (modeCfg.highlightFormatting) state.formatting = "link";
|
|
var type = getType(state);
|
|
if (type) type += " ";
|
|
else type = "";
|
|
return type + tokenTypes.linkEmail;
|
|
}
|
|
if (modeCfg.xml && ch === "<" && stream.match(/^(!--|\?|!\[CDATA\[|[a-z][a-z0-9-]*(?:\s+[a-z_:.\-]+(?:\s*=\s*[^>]+)?)*\s*(?:>|$))/i, false)) {
|
|
var end = stream.string.indexOf(">", stream.pos);
|
|
if (end != -1) {
|
|
var atts = stream.string.substring(stream.start, end);
|
|
if (/markdown\s*=\s*('|"){0,1}1('|"){0,1}/.test(atts)) state.md_inside = true;
|
|
}
|
|
stream.backUp(1);
|
|
state.htmlState = CodeMirror$1.startState(htmlMode);
|
|
return switchBlock(stream, state, htmlBlock);
|
|
}
|
|
if (modeCfg.xml && ch === "<" && stream.match(/^\/\w*?>/)) {
|
|
state.md_inside = false;
|
|
return "tag";
|
|
} else if (ch === "*" || ch === "_") {
|
|
var len = 1, before = stream.pos == 1 ? " " : stream.string.charAt(stream.pos - 2);
|
|
while (len < 3 && stream.eat(ch)) len++;
|
|
var after = stream.peek() || " ";
|
|
var leftFlanking = !/\s/.test(after) && (!punctuation.test(after) || /\s/.test(before) || punctuation.test(before));
|
|
var rightFlanking = !/\s/.test(before) && (!punctuation.test(before) || /\s/.test(after) || punctuation.test(after));
|
|
var setEm = null, setStrong = null;
|
|
if (len % 2) {
|
|
if (!state.em && leftFlanking && (ch === "*" || !rightFlanking || punctuation.test(before))) setEm = true;
|
|
else if (state.em == ch && rightFlanking && (ch === "*" || !leftFlanking || punctuation.test(after))) setEm = false;
|
|
}
|
|
if (len > 1) {
|
|
if (!state.strong && leftFlanking && (ch === "*" || !rightFlanking || punctuation.test(before))) setStrong = true;
|
|
else if (state.strong == ch && rightFlanking && (ch === "*" || !leftFlanking || punctuation.test(after))) setStrong = false;
|
|
}
|
|
if (setStrong != null || setEm != null) {
|
|
if (modeCfg.highlightFormatting) state.formatting = setEm == null ? "strong" : setStrong == null ? "em" : "strong em";
|
|
if (setEm === true) state.em = ch;
|
|
if (setStrong === true) state.strong = ch;
|
|
var t = getType(state);
|
|
if (setEm === false) state.em = false;
|
|
if (setStrong === false) state.strong = false;
|
|
return t;
|
|
}
|
|
} else if (ch === " ") {
|
|
if (stream.eat("*") || stream.eat("_")) if (stream.peek() === " ") return getType(state);
|
|
else stream.backUp(1);
|
|
}
|
|
if (modeCfg.strikethrough) {
|
|
if (ch === "~" && stream.eatWhile(ch)) {
|
|
if (state.strikethrough) {
|
|
if (modeCfg.highlightFormatting) state.formatting = "strikethrough";
|
|
var t = getType(state);
|
|
state.strikethrough = false;
|
|
return t;
|
|
} else if (stream.match(/^[^\s]/, false)) {
|
|
state.strikethrough = true;
|
|
if (modeCfg.highlightFormatting) state.formatting = "strikethrough";
|
|
return getType(state);
|
|
}
|
|
} else if (ch === " ") {
|
|
if (stream.match("~~", true)) if (stream.peek() === " ") return getType(state);
|
|
else stream.backUp(2);
|
|
}
|
|
}
|
|
if (modeCfg.emoji && ch === ":" && stream.match(/^(?:[a-z_\d+][a-z_\d+-]*|\-[a-z_\d+][a-z_\d+-]*):/)) {
|
|
state.emoji = true;
|
|
if (modeCfg.highlightFormatting) state.formatting = "emoji";
|
|
var retType = getType(state);
|
|
state.emoji = false;
|
|
return retType;
|
|
}
|
|
if (ch === " ") {
|
|
if (stream.match(/^ +$/, false)) state.trailingSpace++;
|
|
else if (state.trailingSpace) state.trailingSpaceNewLine = true;
|
|
}
|
|
return getType(state);
|
|
}
|
|
function linkInline(stream, state) {
|
|
var ch = stream.next();
|
|
if (ch === ">") {
|
|
state.f = state.inline = inlineNormal;
|
|
if (modeCfg.highlightFormatting) state.formatting = "link";
|
|
var type = getType(state);
|
|
if (type) type += " ";
|
|
else type = "";
|
|
return type + tokenTypes.linkInline;
|
|
}
|
|
stream.match(/^[^>]+/, true);
|
|
return tokenTypes.linkInline;
|
|
}
|
|
function linkHref(stream, state) {
|
|
if (stream.eatSpace()) return null;
|
|
var ch = stream.next();
|
|
if (ch === "(" || ch === "[") {
|
|
state.f = state.inline = getLinkHrefInside(ch === "(" ? ")" : "]");
|
|
if (modeCfg.highlightFormatting) state.formatting = "link-string";
|
|
state.linkHref = true;
|
|
return getType(state);
|
|
}
|
|
return "error";
|
|
}
|
|
var linkRE = {
|
|
")": /^(?:[^\\\(\)]|\\.|\((?:[^\\\(\)]|\\.)*\))*?(?=\))/,
|
|
"]": /^(?:[^\\\[\]]|\\.|\[(?:[^\\\[\]]|\\.)*\])*?(?=\])/
|
|
};
|
|
function getLinkHrefInside(endChar) {
|
|
return function(stream, state) {
|
|
var ch = stream.next();
|
|
if (ch === endChar) {
|
|
state.f = state.inline = inlineNormal;
|
|
if (modeCfg.highlightFormatting) state.formatting = "link-string";
|
|
var returnState = getType(state);
|
|
state.linkHref = false;
|
|
return returnState;
|
|
}
|
|
stream.match(linkRE[endChar]);
|
|
state.linkHref = true;
|
|
return getType(state);
|
|
};
|
|
}
|
|
function footnoteLink(stream, state) {
|
|
if (stream.match(/^([^\]\\]|\\.)*\]:/, false)) {
|
|
state.f = footnoteLinkInside;
|
|
stream.next();
|
|
if (modeCfg.highlightFormatting) state.formatting = "link";
|
|
state.linkText = true;
|
|
return getType(state);
|
|
}
|
|
return switchInline(stream, state, inlineNormal);
|
|
}
|
|
function footnoteLinkInside(stream, state) {
|
|
if (stream.match("]:", true)) {
|
|
state.f = state.inline = footnoteUrl;
|
|
if (modeCfg.highlightFormatting) state.formatting = "link";
|
|
var returnType = getType(state);
|
|
state.linkText = false;
|
|
return returnType;
|
|
}
|
|
stream.match(/^([^\]\\]|\\.)+/, true);
|
|
return tokenTypes.linkText;
|
|
}
|
|
function footnoteUrl(stream, state) {
|
|
if (stream.eatSpace()) return null;
|
|
stream.match(/^[^\s]+/, true);
|
|
if (stream.peek() === void 0) state.linkTitle = true;
|
|
else stream.match(/^(?:\s+(?:"(?:[^"\\]|\\.)+"|'(?:[^'\\]|\\.)+'|\((?:[^)\\]|\\.)+\)))?/, true);
|
|
state.f = state.inline = inlineNormal;
|
|
return tokenTypes.linkHref + " url";
|
|
}
|
|
var mode = {
|
|
startState: function() {
|
|
return {
|
|
f: blockNormal,
|
|
prevLine: { stream: null },
|
|
thisLine: { stream: null },
|
|
block: blockNormal,
|
|
htmlState: null,
|
|
indentation: 0,
|
|
inline: inlineNormal,
|
|
text: handleText,
|
|
formatting: false,
|
|
linkText: false,
|
|
linkHref: false,
|
|
linkTitle: false,
|
|
code: 0,
|
|
em: false,
|
|
strong: false,
|
|
header: 0,
|
|
setext: 0,
|
|
hr: false,
|
|
taskList: false,
|
|
list: false,
|
|
listStack: [],
|
|
quote: 0,
|
|
trailingSpace: 0,
|
|
trailingSpaceNewLine: false,
|
|
strikethrough: false,
|
|
emoji: false,
|
|
fencedEndRE: null
|
|
};
|
|
},
|
|
copyState: function(s) {
|
|
return {
|
|
f: s.f,
|
|
prevLine: s.prevLine,
|
|
thisLine: s.thisLine,
|
|
block: s.block,
|
|
htmlState: s.htmlState && CodeMirror$1.copyState(htmlMode, s.htmlState),
|
|
indentation: s.indentation,
|
|
localMode: s.localMode,
|
|
localState: s.localMode ? CodeMirror$1.copyState(s.localMode, s.localState) : null,
|
|
inline: s.inline,
|
|
text: s.text,
|
|
formatting: false,
|
|
linkText: s.linkText,
|
|
linkTitle: s.linkTitle,
|
|
linkHref: s.linkHref,
|
|
code: s.code,
|
|
em: s.em,
|
|
strong: s.strong,
|
|
strikethrough: s.strikethrough,
|
|
emoji: s.emoji,
|
|
header: s.header,
|
|
setext: s.setext,
|
|
hr: s.hr,
|
|
taskList: s.taskList,
|
|
list: s.list,
|
|
listStack: s.listStack.slice(0),
|
|
quote: s.quote,
|
|
indentedCode: s.indentedCode,
|
|
trailingSpace: s.trailingSpace,
|
|
trailingSpaceNewLine: s.trailingSpaceNewLine,
|
|
md_inside: s.md_inside,
|
|
fencedEndRE: s.fencedEndRE
|
|
};
|
|
},
|
|
token: function(stream, state) {
|
|
state.formatting = false;
|
|
if (stream != state.thisLine.stream) {
|
|
state.header = 0;
|
|
state.hr = false;
|
|
if (stream.match(/^\s*$/, true)) {
|
|
blankLine(state);
|
|
return null;
|
|
}
|
|
state.prevLine = state.thisLine;
|
|
state.thisLine = { stream };
|
|
state.taskList = false;
|
|
state.trailingSpace = 0;
|
|
state.trailingSpaceNewLine = false;
|
|
if (!state.localState) {
|
|
state.f = state.block;
|
|
if (state.f != htmlBlock) {
|
|
var indentation = stream.match(/^\s*/, true)[0].replace(/\t/g, expandedTab).length;
|
|
state.indentation = indentation;
|
|
state.indentationDiff = null;
|
|
if (indentation > 0) return null;
|
|
}
|
|
}
|
|
}
|
|
return state.f(stream, state);
|
|
},
|
|
innerMode: function(state) {
|
|
if (state.block == htmlBlock) return {
|
|
state: state.htmlState,
|
|
mode: htmlMode
|
|
};
|
|
if (state.localState) return {
|
|
state: state.localState,
|
|
mode: state.localMode
|
|
};
|
|
return {
|
|
state,
|
|
mode
|
|
};
|
|
},
|
|
indent: function(state, textAfter, line) {
|
|
if (state.block == htmlBlock && htmlMode.indent) return htmlMode.indent(state.htmlState, textAfter, line);
|
|
if (state.localState && state.localMode.indent) return state.localMode.indent(state.localState, textAfter, line);
|
|
return CodeMirror$1.Pass;
|
|
},
|
|
blankLine,
|
|
getType,
|
|
blockCommentStart: "<!--",
|
|
blockCommentEnd: "-->",
|
|
closeBrackets: "()[]{}''\"\"``",
|
|
fold: "markdown"
|
|
};
|
|
return mode;
|
|
}, "xml");
|
|
CodeMirror$1.defineMIME("text/markdown", "markdown");
|
|
CodeMirror$1.defineMIME("text/x-markdown", "markdown");
|
|
});
|
|
});
|
|
var require_pug = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror(), require_javascript(), require_css(), require_htmlmixed());
|
|
else if (typeof define == "function" && define.amd) define([
|
|
"../../lib/codemirror",
|
|
"../javascript/javascript",
|
|
"../css/css",
|
|
"../htmlmixed/htmlmixed"
|
|
], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineMode("pug", function(config) {
|
|
var KEYWORD = "keyword";
|
|
var DOCTYPE = "meta";
|
|
var ID = "builtin";
|
|
var CLASS = "qualifier";
|
|
var ATTRS_NEST = {
|
|
"{": "}",
|
|
"(": ")",
|
|
"[": "]"
|
|
};
|
|
var jsMode = CodeMirror$1.getMode(config, "javascript");
|
|
function State() {
|
|
this.javaScriptLine = false;
|
|
this.javaScriptLineExcludesColon = false;
|
|
this.javaScriptArguments = false;
|
|
this.javaScriptArgumentsDepth = 0;
|
|
this.isInterpolating = false;
|
|
this.interpolationNesting = 0;
|
|
this.jsState = CodeMirror$1.startState(jsMode);
|
|
this.restOfLine = "";
|
|
this.isIncludeFiltered = false;
|
|
this.isEach = false;
|
|
this.lastTag = "";
|
|
this.scriptType = "";
|
|
this.isAttrs = false;
|
|
this.attrsNest = [];
|
|
this.inAttributeName = true;
|
|
this.attributeIsType = false;
|
|
this.attrValue = "";
|
|
this.indentOf = Infinity;
|
|
this.indentToken = "";
|
|
this.innerMode = null;
|
|
this.innerState = null;
|
|
this.innerModeForLine = false;
|
|
}
|
|
/**
|
|
* Safely copy a state
|
|
*
|
|
* @return {State}
|
|
*/
|
|
State.prototype.copy = function() {
|
|
var res = new State();
|
|
res.javaScriptLine = this.javaScriptLine;
|
|
res.javaScriptLineExcludesColon = this.javaScriptLineExcludesColon;
|
|
res.javaScriptArguments = this.javaScriptArguments;
|
|
res.javaScriptArgumentsDepth = this.javaScriptArgumentsDepth;
|
|
res.isInterpolating = this.isInterpolating;
|
|
res.interpolationNesting = this.interpolationNesting;
|
|
res.jsState = CodeMirror$1.copyState(jsMode, this.jsState);
|
|
res.innerMode = this.innerMode;
|
|
if (this.innerMode && this.innerState) res.innerState = CodeMirror$1.copyState(this.innerMode, this.innerState);
|
|
res.restOfLine = this.restOfLine;
|
|
res.isIncludeFiltered = this.isIncludeFiltered;
|
|
res.isEach = this.isEach;
|
|
res.lastTag = this.lastTag;
|
|
res.scriptType = this.scriptType;
|
|
res.isAttrs = this.isAttrs;
|
|
res.attrsNest = this.attrsNest.slice();
|
|
res.inAttributeName = this.inAttributeName;
|
|
res.attributeIsType = this.attributeIsType;
|
|
res.attrValue = this.attrValue;
|
|
res.indentOf = this.indentOf;
|
|
res.indentToken = this.indentToken;
|
|
res.innerModeForLine = this.innerModeForLine;
|
|
return res;
|
|
};
|
|
function javaScript(stream, state) {
|
|
if (stream.sol()) {
|
|
state.javaScriptLine = false;
|
|
state.javaScriptLineExcludesColon = false;
|
|
}
|
|
if (state.javaScriptLine) {
|
|
if (state.javaScriptLineExcludesColon && stream.peek() === ":") {
|
|
state.javaScriptLine = false;
|
|
state.javaScriptLineExcludesColon = false;
|
|
return;
|
|
}
|
|
var tok = jsMode.token(stream, state.jsState);
|
|
if (stream.eol()) state.javaScriptLine = false;
|
|
return tok || true;
|
|
}
|
|
}
|
|
function javaScriptArguments(stream, state) {
|
|
if (state.javaScriptArguments) {
|
|
if (state.javaScriptArgumentsDepth === 0 && stream.peek() !== "(") {
|
|
state.javaScriptArguments = false;
|
|
return;
|
|
}
|
|
if (stream.peek() === "(") state.javaScriptArgumentsDepth++;
|
|
else if (stream.peek() === ")") state.javaScriptArgumentsDepth--;
|
|
if (state.javaScriptArgumentsDepth === 0) {
|
|
state.javaScriptArguments = false;
|
|
return;
|
|
}
|
|
var tok = jsMode.token(stream, state.jsState);
|
|
return tok || true;
|
|
}
|
|
}
|
|
function yieldStatement(stream) {
|
|
if (stream.match(/^yield\b/)) return "keyword";
|
|
}
|
|
function doctype(stream) {
|
|
if (stream.match(/^(?:doctype) *([^\n]+)?/)) return DOCTYPE;
|
|
}
|
|
function interpolation(stream, state) {
|
|
if (stream.match("#{")) {
|
|
state.isInterpolating = true;
|
|
state.interpolationNesting = 0;
|
|
return "punctuation";
|
|
}
|
|
}
|
|
function interpolationContinued(stream, state) {
|
|
if (state.isInterpolating) {
|
|
if (stream.peek() === "}") {
|
|
state.interpolationNesting--;
|
|
if (state.interpolationNesting < 0) {
|
|
stream.next();
|
|
state.isInterpolating = false;
|
|
return "punctuation";
|
|
}
|
|
} else if (stream.peek() === "{") state.interpolationNesting++;
|
|
return jsMode.token(stream, state.jsState) || true;
|
|
}
|
|
}
|
|
function caseStatement(stream, state) {
|
|
if (stream.match(/^case\b/)) {
|
|
state.javaScriptLine = true;
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function when(stream, state) {
|
|
if (stream.match(/^when\b/)) {
|
|
state.javaScriptLine = true;
|
|
state.javaScriptLineExcludesColon = true;
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function defaultStatement(stream) {
|
|
if (stream.match(/^default\b/)) return KEYWORD;
|
|
}
|
|
function extendsStatement(stream, state) {
|
|
if (stream.match(/^extends?\b/)) {
|
|
state.restOfLine = "string";
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function append(stream, state) {
|
|
if (stream.match(/^append\b/)) {
|
|
state.restOfLine = "variable";
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function prepend(stream, state) {
|
|
if (stream.match(/^prepend\b/)) {
|
|
state.restOfLine = "variable";
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function block(stream, state) {
|
|
if (stream.match(/^block\b *(?:(prepend|append)\b)?/)) {
|
|
state.restOfLine = "variable";
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function include(stream, state) {
|
|
if (stream.match(/^include\b/)) {
|
|
state.restOfLine = "string";
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function includeFiltered(stream, state) {
|
|
if (stream.match(/^include:([a-zA-Z0-9\-]+)/, false) && stream.match("include")) {
|
|
state.isIncludeFiltered = true;
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function includeFilteredContinued(stream, state) {
|
|
if (state.isIncludeFiltered) {
|
|
var tok = filter(stream, state);
|
|
state.isIncludeFiltered = false;
|
|
state.restOfLine = "string";
|
|
return tok;
|
|
}
|
|
}
|
|
function mixin(stream, state) {
|
|
if (stream.match(/^mixin\b/)) {
|
|
state.javaScriptLine = true;
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function call(stream, state) {
|
|
if (stream.match(/^\+([-\w]+)/)) {
|
|
if (!stream.match(/^\( *[-\w]+ *=/, false)) {
|
|
state.javaScriptArguments = true;
|
|
state.javaScriptArgumentsDepth = 0;
|
|
}
|
|
return "variable";
|
|
}
|
|
if (stream.match("+#{", false)) {
|
|
stream.next();
|
|
state.mixinCallAfter = true;
|
|
return interpolation(stream, state);
|
|
}
|
|
}
|
|
function callArguments(stream, state) {
|
|
if (state.mixinCallAfter) {
|
|
state.mixinCallAfter = false;
|
|
if (!stream.match(/^\( *[-\w]+ *=/, false)) {
|
|
state.javaScriptArguments = true;
|
|
state.javaScriptArgumentsDepth = 0;
|
|
}
|
|
return true;
|
|
}
|
|
}
|
|
function conditional(stream, state) {
|
|
if (stream.match(/^(if|unless|else if|else)\b/)) {
|
|
state.javaScriptLine = true;
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function each(stream, state) {
|
|
if (stream.match(/^(- *)?(each|for)\b/)) {
|
|
state.isEach = true;
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function eachContinued(stream, state) {
|
|
if (state.isEach) {
|
|
if (stream.match(/^ in\b/)) {
|
|
state.javaScriptLine = true;
|
|
state.isEach = false;
|
|
return KEYWORD;
|
|
} else if (stream.sol() || stream.eol()) state.isEach = false;
|
|
else if (stream.next()) {
|
|
while (!stream.match(/^ in\b/, false) && stream.next());
|
|
return "variable";
|
|
}
|
|
}
|
|
}
|
|
function whileStatement(stream, state) {
|
|
if (stream.match(/^while\b/)) {
|
|
state.javaScriptLine = true;
|
|
return KEYWORD;
|
|
}
|
|
}
|
|
function tag(stream, state) {
|
|
var captures;
|
|
if (captures = stream.match(/^(\w(?:[-:\w]*\w)?)\/?/)) {
|
|
state.lastTag = captures[1].toLowerCase();
|
|
if (state.lastTag === "script") state.scriptType = "application/javascript";
|
|
return "tag";
|
|
}
|
|
}
|
|
function filter(stream, state) {
|
|
if (stream.match(/^:([\w\-]+)/)) {
|
|
var innerMode$1;
|
|
if (config && config.innerModes) innerMode$1 = config.innerModes(stream.current().substring(1));
|
|
if (!innerMode$1) innerMode$1 = stream.current().substring(1);
|
|
if (typeof innerMode$1 === "string") innerMode$1 = CodeMirror$1.getMode(config, innerMode$1);
|
|
setInnerMode(stream, state, innerMode$1);
|
|
return "atom";
|
|
}
|
|
}
|
|
function code(stream, state) {
|
|
if (stream.match(/^(!?=|-)/)) {
|
|
state.javaScriptLine = true;
|
|
return "punctuation";
|
|
}
|
|
}
|
|
function id(stream) {
|
|
if (stream.match(/^#([\w-]+)/)) return ID;
|
|
}
|
|
function className(stream) {
|
|
if (stream.match(/^\.([\w-]+)/)) return CLASS;
|
|
}
|
|
function attrs(stream, state) {
|
|
if (stream.peek() == "(") {
|
|
stream.next();
|
|
state.isAttrs = true;
|
|
state.attrsNest = [];
|
|
state.inAttributeName = true;
|
|
state.attrValue = "";
|
|
state.attributeIsType = false;
|
|
return "punctuation";
|
|
}
|
|
}
|
|
function attrsContinued(stream, state) {
|
|
if (state.isAttrs) {
|
|
if (ATTRS_NEST[stream.peek()]) state.attrsNest.push(ATTRS_NEST[stream.peek()]);
|
|
if (state.attrsNest[state.attrsNest.length - 1] === stream.peek()) state.attrsNest.pop();
|
|
else if (stream.eat(")")) {
|
|
state.isAttrs = false;
|
|
return "punctuation";
|
|
}
|
|
if (state.inAttributeName && stream.match(/^[^=,\)!]+/)) {
|
|
if (stream.peek() === "=" || stream.peek() === "!") {
|
|
state.inAttributeName = false;
|
|
state.jsState = CodeMirror$1.startState(jsMode);
|
|
if (state.lastTag === "script" && stream.current().trim().toLowerCase() === "type") state.attributeIsType = true;
|
|
else state.attributeIsType = false;
|
|
}
|
|
return "attribute";
|
|
}
|
|
var tok = jsMode.token(stream, state.jsState);
|
|
if (state.attributeIsType && tok === "string") state.scriptType = stream.current().toString();
|
|
if (state.attrsNest.length === 0 && (tok === "string" || tok === "variable" || tok === "keyword")) try {
|
|
Function("", "var x " + state.attrValue.replace(/,\s*$/, "").replace(/^!/, ""));
|
|
state.inAttributeName = true;
|
|
state.attrValue = "";
|
|
stream.backUp(stream.current().length);
|
|
return attrsContinued(stream, state);
|
|
} catch (ex) {}
|
|
state.attrValue += stream.current();
|
|
return tok || true;
|
|
}
|
|
}
|
|
function attributesBlock(stream, state) {
|
|
if (stream.match(/^&attributes\b/)) {
|
|
state.javaScriptArguments = true;
|
|
state.javaScriptArgumentsDepth = 0;
|
|
return "keyword";
|
|
}
|
|
}
|
|
function indent(stream) {
|
|
if (stream.sol() && stream.eatSpace()) return "indent";
|
|
}
|
|
function comment(stream, state) {
|
|
if (stream.match(/^ *\/\/(-)?([^\n]*)/)) {
|
|
state.indentOf = stream.indentation();
|
|
state.indentToken = "comment";
|
|
return "comment";
|
|
}
|
|
}
|
|
function colon(stream) {
|
|
if (stream.match(/^: */)) return "colon";
|
|
}
|
|
function text(stream, state) {
|
|
if (stream.match(/^(?:\| ?| )([^\n]+)/)) return "string";
|
|
if (stream.match(/^(<[^\n]*)/, false)) {
|
|
setInnerMode(stream, state, "htmlmixed");
|
|
state.innerModeForLine = true;
|
|
return innerMode(stream, state, true);
|
|
}
|
|
}
|
|
function dot(stream, state) {
|
|
if (stream.eat(".")) {
|
|
var innerMode$1 = null;
|
|
if (state.lastTag === "script" && state.scriptType.toLowerCase().indexOf("javascript") != -1) innerMode$1 = state.scriptType.toLowerCase().replace(/"|'/g, "");
|
|
else if (state.lastTag === "style") innerMode$1 = "css";
|
|
setInnerMode(stream, state, innerMode$1);
|
|
return "dot";
|
|
}
|
|
}
|
|
function fail(stream) {
|
|
stream.next();
|
|
return null;
|
|
}
|
|
function setInnerMode(stream, state, mode) {
|
|
mode = CodeMirror$1.mimeModes[mode] || mode;
|
|
mode = config.innerModes ? config.innerModes(mode) || mode : mode;
|
|
mode = CodeMirror$1.mimeModes[mode] || mode;
|
|
mode = CodeMirror$1.getMode(config, mode);
|
|
state.indentOf = stream.indentation();
|
|
if (mode && mode.name !== "null") state.innerMode = mode;
|
|
else state.indentToken = "string";
|
|
}
|
|
function innerMode(stream, state, force) {
|
|
if (stream.indentation() > state.indentOf || state.innerModeForLine && !stream.sol() || force) if (state.innerMode) {
|
|
if (!state.innerState) state.innerState = state.innerMode.startState ? CodeMirror$1.startState(state.innerMode, stream.indentation()) : {};
|
|
return stream.hideFirstChars(state.indentOf + 2, function() {
|
|
return state.innerMode.token(stream, state.innerState) || true;
|
|
});
|
|
} else {
|
|
stream.skipToEnd();
|
|
return state.indentToken;
|
|
}
|
|
else if (stream.sol()) {
|
|
state.indentOf = Infinity;
|
|
state.indentToken = null;
|
|
state.innerMode = null;
|
|
state.innerState = null;
|
|
}
|
|
}
|
|
function restOfLine(stream, state) {
|
|
if (stream.sol()) state.restOfLine = "";
|
|
if (state.restOfLine) {
|
|
stream.skipToEnd();
|
|
var tok = state.restOfLine;
|
|
state.restOfLine = "";
|
|
return tok;
|
|
}
|
|
}
|
|
function startState() {
|
|
return new State();
|
|
}
|
|
function copyState(state) {
|
|
return state.copy();
|
|
}
|
|
/**
|
|
* Get the next token in the stream
|
|
*
|
|
* @param {Stream} stream
|
|
* @param {State} state
|
|
*/
|
|
function nextToken(stream, state) {
|
|
var tok = innerMode(stream, state) || restOfLine(stream, state) || interpolationContinued(stream, state) || includeFilteredContinued(stream, state) || eachContinued(stream, state) || attrsContinued(stream, state) || javaScript(stream, state) || javaScriptArguments(stream, state) || callArguments(stream, state) || yieldStatement(stream) || doctype(stream) || interpolation(stream, state) || caseStatement(stream, state) || when(stream, state) || defaultStatement(stream) || extendsStatement(stream, state) || append(stream, state) || prepend(stream, state) || block(stream, state) || include(stream, state) || includeFiltered(stream, state) || mixin(stream, state) || call(stream, state) || conditional(stream, state) || each(stream, state) || whileStatement(stream, state) || tag(stream, state) || filter(stream, state) || code(stream, state) || id(stream) || className(stream) || attrs(stream, state) || attributesBlock(stream, state) || indent(stream) || text(stream, state) || comment(stream, state) || colon(stream) || dot(stream, state) || fail(stream);
|
|
return tok === true ? null : tok;
|
|
}
|
|
return {
|
|
startState,
|
|
copyState,
|
|
token: nextToken
|
|
};
|
|
}, "javascript", "css", "htmlmixed");
|
|
CodeMirror$1.defineMIME("text/x-pug", "pug");
|
|
CodeMirror$1.defineMIME("text/x-jade", "pug");
|
|
});
|
|
});
|
|
var require_sass = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror(), require_css());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror", "../css/css"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineMode("sass", function(config) {
|
|
var cssMode = CodeMirror$1.mimeModes["text/css"];
|
|
var propertyKeywords = cssMode.propertyKeywords || {}, colorKeywords = cssMode.colorKeywords || {}, valueKeywords = cssMode.valueKeywords || {}, fontProperties = cssMode.fontProperties || {};
|
|
function tokenRegexp(words) {
|
|
return new RegExp("^" + words.join("|"));
|
|
}
|
|
var keywords = [
|
|
"true",
|
|
"false",
|
|
"null",
|
|
"auto"
|
|
];
|
|
var keywordsRegexp = new RegExp("^" + keywords.join("|"));
|
|
var operators = [
|
|
"\\(",
|
|
"\\)",
|
|
"=",
|
|
">",
|
|
"<",
|
|
"==",
|
|
">=",
|
|
"<=",
|
|
"\\+",
|
|
"-",
|
|
"\\!=",
|
|
"/",
|
|
"\\*",
|
|
"%",
|
|
"and",
|
|
"or",
|
|
"not",
|
|
";",
|
|
"\\{",
|
|
"\\}",
|
|
":"
|
|
];
|
|
var opRegexp = tokenRegexp(operators);
|
|
var pseudoElementsRegexp = /^::?[a-zA-Z_][\w\-]*/;
|
|
var word;
|
|
function isEndLine(stream) {
|
|
return !stream.peek() || stream.match(/\s+$/, false);
|
|
}
|
|
function urlTokens(stream, state) {
|
|
var ch = stream.peek();
|
|
if (ch === ")") {
|
|
stream.next();
|
|
state.tokenizer = tokenBase;
|
|
return "operator";
|
|
} else if (ch === "(") {
|
|
stream.next();
|
|
stream.eatSpace();
|
|
return "operator";
|
|
} else if (ch === "'" || ch === "\"") {
|
|
state.tokenizer = buildStringTokenizer(stream.next());
|
|
return "string";
|
|
} else {
|
|
state.tokenizer = buildStringTokenizer(")", false);
|
|
return "string";
|
|
}
|
|
}
|
|
function comment(indentation, multiLine) {
|
|
return function(stream, state) {
|
|
if (stream.sol() && stream.indentation() <= indentation) {
|
|
state.tokenizer = tokenBase;
|
|
return tokenBase(stream, state);
|
|
}
|
|
if (multiLine && stream.skipTo("*/")) {
|
|
stream.next();
|
|
stream.next();
|
|
state.tokenizer = tokenBase;
|
|
} else stream.skipToEnd();
|
|
return "comment";
|
|
};
|
|
}
|
|
function buildStringTokenizer(quote, greedy) {
|
|
if (greedy == null) greedy = true;
|
|
function stringTokenizer(stream, state) {
|
|
var nextChar = stream.next();
|
|
var peekChar = stream.peek();
|
|
var previousChar = stream.string.charAt(stream.pos - 2);
|
|
var endingString = nextChar !== "\\" && peekChar === quote || nextChar === quote && previousChar !== "\\";
|
|
if (endingString) {
|
|
if (nextChar !== quote && greedy) stream.next();
|
|
if (isEndLine(stream)) state.cursorHalf = 0;
|
|
state.tokenizer = tokenBase;
|
|
return "string";
|
|
} else if (nextChar === "#" && peekChar === "{") {
|
|
state.tokenizer = buildInterpolationTokenizer(stringTokenizer);
|
|
stream.next();
|
|
return "operator";
|
|
} else return "string";
|
|
}
|
|
return stringTokenizer;
|
|
}
|
|
function buildInterpolationTokenizer(currentTokenizer) {
|
|
return function(stream, state) {
|
|
if (stream.peek() === "}") {
|
|
stream.next();
|
|
state.tokenizer = currentTokenizer;
|
|
return "operator";
|
|
} else return tokenBase(stream, state);
|
|
};
|
|
}
|
|
function indent(state) {
|
|
if (state.indentCount == 0) {
|
|
state.indentCount++;
|
|
var lastScopeOffset = state.scopes[0].offset;
|
|
var currentOffset = lastScopeOffset + config.indentUnit;
|
|
state.scopes.unshift({ offset: currentOffset });
|
|
}
|
|
}
|
|
function dedent(state) {
|
|
if (state.scopes.length == 1) return;
|
|
state.scopes.shift();
|
|
}
|
|
function tokenBase(stream, state) {
|
|
var ch = stream.peek();
|
|
if (stream.match("/*")) {
|
|
state.tokenizer = comment(stream.indentation(), true);
|
|
return state.tokenizer(stream, state);
|
|
}
|
|
if (stream.match("//")) {
|
|
state.tokenizer = comment(stream.indentation(), false);
|
|
return state.tokenizer(stream, state);
|
|
}
|
|
if (stream.match("#{")) {
|
|
state.tokenizer = buildInterpolationTokenizer(tokenBase);
|
|
return "operator";
|
|
}
|
|
if (ch === "\"" || ch === "'") {
|
|
stream.next();
|
|
state.tokenizer = buildStringTokenizer(ch);
|
|
return "string";
|
|
}
|
|
if (!state.cursorHalf) {
|
|
if (ch === "-") {
|
|
if (stream.match(/^-\w+-/)) return "meta";
|
|
}
|
|
if (ch === ".") {
|
|
stream.next();
|
|
if (stream.match(/^[\w-]+/)) {
|
|
indent(state);
|
|
return "qualifier";
|
|
} else if (stream.peek() === "#") {
|
|
indent(state);
|
|
return "tag";
|
|
}
|
|
}
|
|
if (ch === "#") {
|
|
stream.next();
|
|
if (stream.match(/^[\w-]+/)) {
|
|
indent(state);
|
|
return "builtin";
|
|
}
|
|
if (stream.peek() === "#") {
|
|
indent(state);
|
|
return "tag";
|
|
}
|
|
}
|
|
if (ch === "$") {
|
|
stream.next();
|
|
stream.eatWhile(/[\w-]/);
|
|
return "variable-2";
|
|
}
|
|
if (stream.match(/^-?[0-9\.]+/)) return "number";
|
|
if (stream.match(/^(px|em|in)\b/)) return "unit";
|
|
if (stream.match(keywordsRegexp)) return "keyword";
|
|
if (stream.match(/^url/) && stream.peek() === "(") {
|
|
state.tokenizer = urlTokens;
|
|
return "atom";
|
|
}
|
|
if (ch === "=") {
|
|
if (stream.match(/^=[\w-]+/)) {
|
|
indent(state);
|
|
return "meta";
|
|
}
|
|
}
|
|
if (ch === "+") {
|
|
if (stream.match(/^\+[\w-]+/)) return "variable-3";
|
|
}
|
|
if (ch === "@") {
|
|
if (stream.match("@extend")) {
|
|
if (!stream.match(/\s*[\w]/)) dedent(state);
|
|
}
|
|
}
|
|
if (stream.match(/^@(else if|if|media|else|for|each|while|mixin|function)/)) {
|
|
indent(state);
|
|
return "def";
|
|
}
|
|
if (ch === "@") {
|
|
stream.next();
|
|
stream.eatWhile(/[\w-]/);
|
|
return "def";
|
|
}
|
|
if (stream.eatWhile(/[\w-]/)) if (stream.match(/ *: *[\w-\+\$#!\("']/, false)) {
|
|
word = stream.current().toLowerCase();
|
|
var prop = state.prevProp + "-" + word;
|
|
if (propertyKeywords.hasOwnProperty(prop)) return "property";
|
|
else if (propertyKeywords.hasOwnProperty(word)) {
|
|
state.prevProp = word;
|
|
return "property";
|
|
} else if (fontProperties.hasOwnProperty(word)) return "property";
|
|
return "tag";
|
|
} else if (stream.match(/ *:/, false)) {
|
|
indent(state);
|
|
state.cursorHalf = 1;
|
|
state.prevProp = stream.current().toLowerCase();
|
|
return "property";
|
|
} else if (stream.match(/ *,/, false)) return "tag";
|
|
else {
|
|
indent(state);
|
|
return "tag";
|
|
}
|
|
if (ch === ":") {
|
|
if (stream.match(pseudoElementsRegexp)) return "variable-3";
|
|
stream.next();
|
|
state.cursorHalf = 1;
|
|
return "operator";
|
|
}
|
|
} else {
|
|
if (ch === "#") {
|
|
stream.next();
|
|
if (stream.match(/[0-9a-fA-F]{6}|[0-9a-fA-F]{3}/)) {
|
|
if (isEndLine(stream)) state.cursorHalf = 0;
|
|
return "number";
|
|
}
|
|
}
|
|
if (stream.match(/^-?[0-9\.]+/)) {
|
|
if (isEndLine(stream)) state.cursorHalf = 0;
|
|
return "number";
|
|
}
|
|
if (stream.match(/^(px|em|in)\b/)) {
|
|
if (isEndLine(stream)) state.cursorHalf = 0;
|
|
return "unit";
|
|
}
|
|
if (stream.match(keywordsRegexp)) {
|
|
if (isEndLine(stream)) state.cursorHalf = 0;
|
|
return "keyword";
|
|
}
|
|
if (stream.match(/^url/) && stream.peek() === "(") {
|
|
state.tokenizer = urlTokens;
|
|
if (isEndLine(stream)) state.cursorHalf = 0;
|
|
return "atom";
|
|
}
|
|
if (ch === "$") {
|
|
stream.next();
|
|
stream.eatWhile(/[\w-]/);
|
|
if (isEndLine(stream)) state.cursorHalf = 0;
|
|
return "variable-2";
|
|
}
|
|
if (ch === "!") {
|
|
stream.next();
|
|
state.cursorHalf = 0;
|
|
return stream.match(/^[\w]+/) ? "keyword" : "operator";
|
|
}
|
|
if (stream.match(opRegexp)) {
|
|
if (isEndLine(stream)) state.cursorHalf = 0;
|
|
return "operator";
|
|
}
|
|
if (stream.eatWhile(/[\w-]/)) {
|
|
if (isEndLine(stream)) state.cursorHalf = 0;
|
|
word = stream.current().toLowerCase();
|
|
if (valueKeywords.hasOwnProperty(word)) return "atom";
|
|
else if (colorKeywords.hasOwnProperty(word)) return "keyword";
|
|
else if (propertyKeywords.hasOwnProperty(word)) {
|
|
state.prevProp = stream.current().toLowerCase();
|
|
return "property";
|
|
} else return "tag";
|
|
}
|
|
if (isEndLine(stream)) {
|
|
state.cursorHalf = 0;
|
|
return null;
|
|
}
|
|
}
|
|
if (stream.match(opRegexp)) return "operator";
|
|
stream.next();
|
|
return null;
|
|
}
|
|
function tokenLexer(stream, state) {
|
|
if (stream.sol()) state.indentCount = 0;
|
|
var style = state.tokenizer(stream, state);
|
|
var current = stream.current();
|
|
if (current === "@return" || current === "}") dedent(state);
|
|
if (style !== null) {
|
|
var startOfToken = stream.pos - current.length;
|
|
var withCurrentIndent = startOfToken + config.indentUnit * state.indentCount;
|
|
var newScopes = [];
|
|
for (var i = 0; i < state.scopes.length; i++) {
|
|
var scope = state.scopes[i];
|
|
if (scope.offset <= withCurrentIndent) newScopes.push(scope);
|
|
}
|
|
state.scopes = newScopes;
|
|
}
|
|
return style;
|
|
}
|
|
return {
|
|
startState: function() {
|
|
return {
|
|
tokenizer: tokenBase,
|
|
scopes: [{
|
|
offset: 0,
|
|
type: "sass"
|
|
}],
|
|
indentCount: 0,
|
|
cursorHalf: 0,
|
|
definedVars: [],
|
|
definedMixins: []
|
|
};
|
|
},
|
|
token: function(stream, state) {
|
|
var style = tokenLexer(stream, state);
|
|
state.lastToken = {
|
|
style,
|
|
content: stream.current()
|
|
};
|
|
return style;
|
|
},
|
|
indent: function(state) {
|
|
return state.scopes[0].offset;
|
|
},
|
|
blockCommentStart: "/*",
|
|
blockCommentEnd: "*/",
|
|
lineComment: "//",
|
|
fold: "indent"
|
|
};
|
|
}, "css");
|
|
CodeMirror$1.defineMIME("text/x-sass", "sass");
|
|
});
|
|
});
|
|
var require_overlay = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.overlayMode = function(base, overlay, combine) {
|
|
return {
|
|
startState: function() {
|
|
return {
|
|
base: CodeMirror$1.startState(base),
|
|
overlay: CodeMirror$1.startState(overlay),
|
|
basePos: 0,
|
|
baseCur: null,
|
|
overlayPos: 0,
|
|
overlayCur: null,
|
|
streamSeen: null
|
|
};
|
|
},
|
|
copyState: function(state) {
|
|
return {
|
|
base: CodeMirror$1.copyState(base, state.base),
|
|
overlay: CodeMirror$1.copyState(overlay, state.overlay),
|
|
basePos: state.basePos,
|
|
baseCur: null,
|
|
overlayPos: state.overlayPos,
|
|
overlayCur: null
|
|
};
|
|
},
|
|
token: function(stream, state) {
|
|
if (stream != state.streamSeen || Math.min(state.basePos, state.overlayPos) < stream.start) {
|
|
state.streamSeen = stream;
|
|
state.basePos = state.overlayPos = stream.start;
|
|
}
|
|
if (stream.start == state.basePos) {
|
|
state.baseCur = base.token(stream, state.base);
|
|
state.basePos = stream.pos;
|
|
}
|
|
if (stream.start == state.overlayPos) {
|
|
stream.pos = stream.start;
|
|
state.overlayCur = overlay.token(stream, state.overlay);
|
|
state.overlayPos = stream.pos;
|
|
}
|
|
stream.pos = Math.min(state.basePos, state.overlayPos);
|
|
if (state.overlayCur == null) return state.baseCur;
|
|
else if (state.baseCur != null && state.overlay.combineTokens || combine && state.overlay.combineTokens == null) return state.baseCur + " " + state.overlayCur;
|
|
else return state.overlayCur;
|
|
},
|
|
indent: base.indent && function(state, textAfter, line) {
|
|
return base.indent(state.base, textAfter, line);
|
|
},
|
|
electricChars: base.electricChars,
|
|
innerMode: function(state) {
|
|
return {
|
|
state: state.base,
|
|
mode: base
|
|
};
|
|
},
|
|
blankLine: function(state) {
|
|
var baseToken, overlayToken;
|
|
if (base.blankLine) baseToken = base.blankLine(state.base);
|
|
if (overlay.blankLine) overlayToken = overlay.blankLine(state.overlay);
|
|
return overlayToken == null ? baseToken : combine && baseToken != null ? baseToken + " " + overlayToken : overlayToken;
|
|
}
|
|
};
|
|
};
|
|
});
|
|
});
|
|
var require_coffeescript = __commonJSMin((exports, module) => {
|
|
/**
|
|
* Link to the project's GitHub page:
|
|
* https://github.com/pickhardt/coffeescript-codemirror-mode
|
|
*/
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineMode("coffeescript", function(conf, parserConf) {
|
|
var ERRORCLASS = "error";
|
|
function wordRegexp(words) {
|
|
return new RegExp("^((" + words.join(")|(") + "))\\b");
|
|
}
|
|
var operators = /^(?:->|=>|\+[+=]?|-[\-=]?|\*[\*=]?|\/[\/=]?|[=!]=|<[><]?=?|>>?=?|%=?|&=?|\|=?|\^=?|\~|!|\?|(or|and|\|\||&&|\?)=)/;
|
|
var delimiters = /^(?:[()\[\]{},:`=;]|\.\.?\.?)/;
|
|
var identifiers = /^[_A-Za-z$][_A-Za-z$0-9]*/;
|
|
var atProp = /^@[_A-Za-z$][_A-Za-z$0-9]*/;
|
|
var wordOperators = wordRegexp([
|
|
"and",
|
|
"or",
|
|
"not",
|
|
"is",
|
|
"isnt",
|
|
"in",
|
|
"instanceof",
|
|
"typeof"
|
|
]);
|
|
var indentKeywords = [
|
|
"for",
|
|
"while",
|
|
"loop",
|
|
"if",
|
|
"unless",
|
|
"else",
|
|
"switch",
|
|
"try",
|
|
"catch",
|
|
"finally",
|
|
"class"
|
|
];
|
|
var commonKeywords = [
|
|
"break",
|
|
"by",
|
|
"continue",
|
|
"debugger",
|
|
"delete",
|
|
"do",
|
|
"in",
|
|
"of",
|
|
"new",
|
|
"return",
|
|
"then",
|
|
"this",
|
|
"@",
|
|
"throw",
|
|
"when",
|
|
"until",
|
|
"extends"
|
|
];
|
|
var keywords = wordRegexp(indentKeywords.concat(commonKeywords));
|
|
indentKeywords = wordRegexp(indentKeywords);
|
|
var stringPrefixes = /^('{3}|\"{3}|['\"])/;
|
|
var regexPrefixes = /^(\/{3}|\/)/;
|
|
var commonConstants = [
|
|
"Infinity",
|
|
"NaN",
|
|
"undefined",
|
|
"null",
|
|
"true",
|
|
"false",
|
|
"on",
|
|
"off",
|
|
"yes",
|
|
"no"
|
|
];
|
|
var constants = wordRegexp(commonConstants);
|
|
function tokenBase(stream, state) {
|
|
if (stream.sol()) {
|
|
if (state.scope.align === null) state.scope.align = false;
|
|
var scopeOffset = state.scope.offset;
|
|
if (stream.eatSpace()) {
|
|
var lineOffset = stream.indentation();
|
|
if (lineOffset > scopeOffset && state.scope.type == "coffee") return "indent";
|
|
else if (lineOffset < scopeOffset) return "dedent";
|
|
return null;
|
|
} else if (scopeOffset > 0) dedent(stream, state);
|
|
}
|
|
if (stream.eatSpace()) return null;
|
|
var ch = stream.peek();
|
|
if (stream.match("####")) {
|
|
stream.skipToEnd();
|
|
return "comment";
|
|
}
|
|
if (stream.match("###")) {
|
|
state.tokenize = longComment;
|
|
return state.tokenize(stream, state);
|
|
}
|
|
if (ch === "#") {
|
|
stream.skipToEnd();
|
|
return "comment";
|
|
}
|
|
if (stream.match(/^-?[0-9\.]/, false)) {
|
|
var floatLiteral = false;
|
|
if (stream.match(/^-?\d*\.\d+(e[\+\-]?\d+)?/i)) floatLiteral = true;
|
|
if (stream.match(/^-?\d+\.\d*/)) floatLiteral = true;
|
|
if (stream.match(/^-?\.\d+/)) floatLiteral = true;
|
|
if (floatLiteral) {
|
|
if (stream.peek() == ".") stream.backUp(1);
|
|
return "number";
|
|
}
|
|
var intLiteral = false;
|
|
if (stream.match(/^-?0x[0-9a-f]+/i)) intLiteral = true;
|
|
if (stream.match(/^-?[1-9]\d*(e[\+\-]?\d+)?/)) intLiteral = true;
|
|
if (stream.match(/^-?0(?![\dx])/i)) intLiteral = true;
|
|
if (intLiteral) return "number";
|
|
}
|
|
if (stream.match(stringPrefixes)) {
|
|
state.tokenize = tokenFactory(stream.current(), false, "string");
|
|
return state.tokenize(stream, state);
|
|
}
|
|
if (stream.match(regexPrefixes)) if (stream.current() != "/" || stream.match(/^.*\//, false)) {
|
|
state.tokenize = tokenFactory(stream.current(), true, "string-2");
|
|
return state.tokenize(stream, state);
|
|
} else stream.backUp(1);
|
|
if (stream.match(operators) || stream.match(wordOperators)) return "operator";
|
|
if (stream.match(delimiters)) return "punctuation";
|
|
if (stream.match(constants)) return "atom";
|
|
if (stream.match(atProp) || state.prop && stream.match(identifiers)) return "property";
|
|
if (stream.match(keywords)) return "keyword";
|
|
if (stream.match(identifiers)) return "variable";
|
|
stream.next();
|
|
return ERRORCLASS;
|
|
}
|
|
function tokenFactory(delimiter, singleline, outclass) {
|
|
return function(stream, state) {
|
|
while (!stream.eol()) {
|
|
stream.eatWhile(/[^'"\/\\]/);
|
|
if (stream.eat("\\")) {
|
|
stream.next();
|
|
if (singleline && stream.eol()) return outclass;
|
|
} else if (stream.match(delimiter)) {
|
|
state.tokenize = tokenBase;
|
|
return outclass;
|
|
} else stream.eat(/['"\/]/);
|
|
}
|
|
if (singleline) if (parserConf.singleLineStringErrors) outclass = ERRORCLASS;
|
|
else state.tokenize = tokenBase;
|
|
return outclass;
|
|
};
|
|
}
|
|
function longComment(stream, state) {
|
|
while (!stream.eol()) {
|
|
stream.eatWhile(/[^#]/);
|
|
if (stream.match("###")) {
|
|
state.tokenize = tokenBase;
|
|
break;
|
|
}
|
|
stream.eatWhile("#");
|
|
}
|
|
return "comment";
|
|
}
|
|
function indent(stream, state, type) {
|
|
type = type || "coffee";
|
|
var offset = 0, align = false, alignOffset = null;
|
|
for (var scope = state.scope; scope; scope = scope.prev) if (scope.type === "coffee" || scope.type == "}") {
|
|
offset = scope.offset + conf.indentUnit;
|
|
break;
|
|
}
|
|
if (type !== "coffee") {
|
|
align = null;
|
|
alignOffset = stream.column() + stream.current().length;
|
|
} else if (state.scope.align) state.scope.align = false;
|
|
state.scope = {
|
|
offset,
|
|
type,
|
|
prev: state.scope,
|
|
align,
|
|
alignOffset
|
|
};
|
|
}
|
|
function dedent(stream, state) {
|
|
if (!state.scope.prev) return;
|
|
if (state.scope.type === "coffee") {
|
|
var _indent = stream.indentation();
|
|
var matched = false;
|
|
for (var scope = state.scope; scope; scope = scope.prev) if (_indent === scope.offset) {
|
|
matched = true;
|
|
break;
|
|
}
|
|
if (!matched) return true;
|
|
while (state.scope.prev && state.scope.offset !== _indent) state.scope = state.scope.prev;
|
|
return false;
|
|
} else {
|
|
state.scope = state.scope.prev;
|
|
return false;
|
|
}
|
|
}
|
|
function tokenLexer(stream, state) {
|
|
var style = state.tokenize(stream, state);
|
|
var current = stream.current();
|
|
if (current === "return") state.dedent = true;
|
|
if ((current === "->" || current === "=>") && stream.eol() || style === "indent") indent(stream, state);
|
|
var delimiter_index = "[({".indexOf(current);
|
|
if (delimiter_index !== -1) indent(stream, state, "])}".slice(delimiter_index, delimiter_index + 1));
|
|
if (indentKeywords.exec(current)) indent(stream, state);
|
|
if (current == "then") dedent(stream, state);
|
|
if (style === "dedent") {
|
|
if (dedent(stream, state)) return ERRORCLASS;
|
|
}
|
|
delimiter_index = "])}".indexOf(current);
|
|
if (delimiter_index !== -1) {
|
|
while (state.scope.type == "coffee" && state.scope.prev) state.scope = state.scope.prev;
|
|
if (state.scope.type == current) state.scope = state.scope.prev;
|
|
}
|
|
if (state.dedent && stream.eol()) {
|
|
if (state.scope.type == "coffee" && state.scope.prev) state.scope = state.scope.prev;
|
|
state.dedent = false;
|
|
}
|
|
return style;
|
|
}
|
|
var external = {
|
|
startState: function(basecolumn) {
|
|
return {
|
|
tokenize: tokenBase,
|
|
scope: {
|
|
offset: basecolumn || 0,
|
|
type: "coffee",
|
|
prev: null,
|
|
align: false
|
|
},
|
|
prop: false,
|
|
dedent: 0
|
|
};
|
|
},
|
|
token: function(stream, state) {
|
|
var fillAlign = state.scope.align === null && state.scope;
|
|
if (fillAlign && stream.sol()) fillAlign.align = false;
|
|
var style = tokenLexer(stream, state);
|
|
if (style && style != "comment") {
|
|
if (fillAlign) fillAlign.align = true;
|
|
state.prop = style == "punctuation" && stream.current() == ".";
|
|
}
|
|
return style;
|
|
},
|
|
indent: function(state, text) {
|
|
if (state.tokenize != tokenBase) return 0;
|
|
var scope = state.scope;
|
|
var closer = text && "])}".indexOf(text.charAt(0)) > -1;
|
|
if (closer) while (scope.type == "coffee" && scope.prev) scope = scope.prev;
|
|
var closes = closer && scope.type === text.charAt(0);
|
|
if (scope.align) return scope.alignOffset - (closes ? 1 : 0);
|
|
else return (closes ? scope.prev : scope).offset;
|
|
},
|
|
lineComment: "#",
|
|
fold: "indent"
|
|
};
|
|
return external;
|
|
});
|
|
CodeMirror$1.defineMIME("application/vnd.coffeescript", "coffeescript");
|
|
CodeMirror$1.defineMIME("text/x-coffeescript", "coffeescript");
|
|
CodeMirror$1.defineMIME("text/coffeescript", "coffeescript");
|
|
});
|
|
});
|
|
var require_stylus = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") mod(require_codemirror());
|
|
else if (typeof define == "function" && define.amd) define(["../../lib/codemirror"], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
"use strict";
|
|
CodeMirror$1.defineMode("stylus", function(config) {
|
|
var indentUnit = config.indentUnit, indentUnitString = "", tagKeywords = keySet(tagKeywords_), tagVariablesRegexp = /^(a|b|i|s|col|em)$/i, propertyKeywords = keySet(propertyKeywords_), nonStandardPropertyKeywords = keySet(nonStandardPropertyKeywords_), valueKeywords = keySet(valueKeywords_), colorKeywords = keySet(colorKeywords_), documentTypes = keySet(documentTypes_), documentTypesRegexp = wordRegexp(documentTypes_), mediaFeatures = keySet(mediaFeatures_), mediaTypes = keySet(mediaTypes_), fontProperties = keySet(fontProperties_), operatorsRegexp = /^\s*([.]{2,3}|&&|\|\||\*\*|[?!=:]?=|[-+*\/%<>]=?|\?:|\~)/, wordOperatorKeywordsRegexp = wordRegexp(wordOperatorKeywords_), blockKeywords = keySet(blockKeywords_), vendorPrefixesRegexp = new RegExp(/^\-(moz|ms|o|webkit)-/i), commonAtoms = keySet(commonAtoms_), firstWordMatch = "", states = {}, ch, style, type, override;
|
|
while (indentUnitString.length < indentUnit) indentUnitString += " ";
|
|
/**
|
|
* Tokenizers
|
|
*/
|
|
function tokenBase(stream, state) {
|
|
firstWordMatch = stream.string.match(/(^[\w-]+\s*=\s*$)|(^\s*[\w-]+\s*=\s*[\w-])|(^\s*(\.|#|@|\$|\&|\[|\d|\+|::?|\{|\>|~|\/)?\s*[\w-]*([a-z0-9-]|\*|\/\*)(\(|,)?)/);
|
|
state.context.line.firstWord = firstWordMatch ? firstWordMatch[0].replace(/^\s*/, "") : "";
|
|
state.context.line.indent = stream.indentation();
|
|
ch = stream.peek();
|
|
if (stream.match("//")) {
|
|
stream.skipToEnd();
|
|
return ["comment", "comment"];
|
|
}
|
|
if (stream.match("/*")) {
|
|
state.tokenize = tokenCComment;
|
|
return tokenCComment(stream, state);
|
|
}
|
|
if (ch == "\"" || ch == "'") {
|
|
stream.next();
|
|
state.tokenize = tokenString(ch);
|
|
return state.tokenize(stream, state);
|
|
}
|
|
if (ch == "@") {
|
|
stream.next();
|
|
stream.eatWhile(/[\w\\-]/);
|
|
return ["def", stream.current()];
|
|
}
|
|
if (ch == "#") {
|
|
stream.next();
|
|
if (stream.match(/^[0-9a-f]{3}([0-9a-f]([0-9a-f]{2}){0,2})?\b(?!-)/i)) return ["atom", "atom"];
|
|
if (stream.match(/^[a-z][\w-]*/i)) return ["builtin", "hash"];
|
|
}
|
|
if (stream.match(vendorPrefixesRegexp)) return ["meta", "vendor-prefixes"];
|
|
if (stream.match(/^-?[0-9]?\.?[0-9]/)) {
|
|
stream.eatWhile(/[a-z%]/i);
|
|
return ["number", "unit"];
|
|
}
|
|
if (ch == "!") {
|
|
stream.next();
|
|
return [stream.match(/^(important|optional)/i) ? "keyword" : "operator", "important"];
|
|
}
|
|
if (ch == "." && stream.match(/^\.[a-z][\w-]*/i)) return ["qualifier", "qualifier"];
|
|
if (stream.match(documentTypesRegexp)) {
|
|
if (stream.peek() == "(") state.tokenize = tokenParenthesized;
|
|
return ["property", "word"];
|
|
}
|
|
if (stream.match(/^[a-z][\w-]*\(/i)) {
|
|
stream.backUp(1);
|
|
return ["keyword", "mixin"];
|
|
}
|
|
if (stream.match(/^(\+|-)[a-z][\w-]*\(/i)) {
|
|
stream.backUp(1);
|
|
return ["keyword", "block-mixin"];
|
|
}
|
|
if (stream.string.match(/^\s*&/) && stream.match(/^[-_]+[a-z][\w-]*/)) return ["qualifier", "qualifier"];
|
|
if (stream.match(/^(\/|&)(-|_|:|\.|#|[a-z])/)) {
|
|
stream.backUp(1);
|
|
return ["variable-3", "reference"];
|
|
}
|
|
if (stream.match(/^&{1}\s*$/)) return ["variable-3", "reference"];
|
|
if (stream.match(wordOperatorKeywordsRegexp)) return ["operator", "operator"];
|
|
if (stream.match(/^\$?[-_]*[a-z0-9]+[\w-]*/i)) {
|
|
if (stream.match(/^(\.|\[)[\w-\'\"\]]+/i, false)) {
|
|
if (!wordIsTag(stream.current())) {
|
|
stream.match(".");
|
|
return ["variable-2", "variable-name"];
|
|
}
|
|
}
|
|
return ["variable-2", "word"];
|
|
}
|
|
if (stream.match(operatorsRegexp)) return ["operator", stream.current()];
|
|
if (/[:;,{}\[\]\(\)]/.test(ch)) {
|
|
stream.next();
|
|
return [null, ch];
|
|
}
|
|
stream.next();
|
|
return [null, null];
|
|
}
|
|
/**
|
|
* Token comment
|
|
*/
|
|
function tokenCComment(stream, state) {
|
|
var maybeEnd = false, ch$1;
|
|
while ((ch$1 = stream.next()) != null) {
|
|
if (maybeEnd && ch$1 == "/") {
|
|
state.tokenize = null;
|
|
break;
|
|
}
|
|
maybeEnd = ch$1 == "*";
|
|
}
|
|
return ["comment", "comment"];
|
|
}
|
|
/**
|
|
* Token string
|
|
*/
|
|
function tokenString(quote) {
|
|
return function(stream, state) {
|
|
var escaped = false, ch$1;
|
|
while ((ch$1 = stream.next()) != null) {
|
|
if (ch$1 == quote && !escaped) {
|
|
if (quote == ")") stream.backUp(1);
|
|
break;
|
|
}
|
|
escaped = !escaped && ch$1 == "\\";
|
|
}
|
|
if (ch$1 == quote || !escaped && quote != ")") state.tokenize = null;
|
|
return ["string", "string"];
|
|
};
|
|
}
|
|
/**
|
|
* Token parenthesized
|
|
*/
|
|
function tokenParenthesized(stream, state) {
|
|
stream.next();
|
|
if (!stream.match(/\s*[\"\')]/, false)) state.tokenize = tokenString(")");
|
|
else state.tokenize = null;
|
|
return [null, "("];
|
|
}
|
|
/**
|
|
* Context management
|
|
*/
|
|
function Context(type$1, indent, prev, line) {
|
|
this.type = type$1;
|
|
this.indent = indent;
|
|
this.prev = prev;
|
|
this.line = line || {
|
|
firstWord: "",
|
|
indent: 0
|
|
};
|
|
}
|
|
function pushContext(state, stream, type$1, indent) {
|
|
indent = indent >= 0 ? indent : indentUnit;
|
|
state.context = new Context(type$1, stream.indentation() + indent, state.context);
|
|
return type$1;
|
|
}
|
|
function popContext(state, currentIndent) {
|
|
var contextIndent = state.context.indent - indentUnit;
|
|
currentIndent = currentIndent || false;
|
|
state.context = state.context.prev;
|
|
if (currentIndent) state.context.indent = contextIndent;
|
|
return state.context.type;
|
|
}
|
|
function pass(type$1, stream, state) {
|
|
return states[state.context.type](type$1, stream, state);
|
|
}
|
|
function popAndPass(type$1, stream, state, n) {
|
|
for (var i = n || 1; i > 0; i--) state.context = state.context.prev;
|
|
return pass(type$1, stream, state);
|
|
}
|
|
/**
|
|
* Parser
|
|
*/
|
|
function wordIsTag(word) {
|
|
return word.toLowerCase() in tagKeywords;
|
|
}
|
|
function wordIsProperty(word) {
|
|
word = word.toLowerCase();
|
|
return word in propertyKeywords || word in fontProperties;
|
|
}
|
|
function wordIsBlock(word) {
|
|
return word.toLowerCase() in blockKeywords;
|
|
}
|
|
function wordIsVendorPrefix(word) {
|
|
return word.toLowerCase().match(vendorPrefixesRegexp);
|
|
}
|
|
function wordAsValue(word) {
|
|
var wordLC = word.toLowerCase();
|
|
var override$1 = "variable-2";
|
|
if (wordIsTag(word)) override$1 = "tag";
|
|
else if (wordIsBlock(word)) override$1 = "block-keyword";
|
|
else if (wordIsProperty(word)) override$1 = "property";
|
|
else if (wordLC in valueKeywords || wordLC in commonAtoms) override$1 = "atom";
|
|
else if (wordLC == "return" || wordLC in colorKeywords) override$1 = "keyword";
|
|
else if (word.match(/^[A-Z]/)) override$1 = "string";
|
|
return override$1;
|
|
}
|
|
function typeIsBlock(type$1, stream) {
|
|
return endOfLine(stream) && (type$1 == "{" || type$1 == "]" || type$1 == "hash" || type$1 == "qualifier") || type$1 == "block-mixin";
|
|
}
|
|
function typeIsInterpolation(type$1, stream) {
|
|
return type$1 == "{" && stream.match(/^\s*\$?[\w-]+/i, false);
|
|
}
|
|
function typeIsPseudo(type$1, stream) {
|
|
return type$1 == ":" && stream.match(/^[a-z-]+/, false);
|
|
}
|
|
function startOfLine(stream) {
|
|
return stream.sol() || stream.string.match(new RegExp("^\\s*" + escapeRegExp(stream.current())));
|
|
}
|
|
function endOfLine(stream) {
|
|
return stream.eol() || stream.match(/^\s*$/, false);
|
|
}
|
|
function firstWordOfLine(line) {
|
|
var re = /^\s*[-_]*[a-z0-9]+[\w-]*/i;
|
|
var result = typeof line == "string" ? line.match(re) : line.string.match(re);
|
|
return result ? result[0].replace(/^\s*/, "") : "";
|
|
}
|
|
/**
|
|
* Block
|
|
*/
|
|
states.block = function(type$1, stream, state) {
|
|
if (type$1 == "comment" && startOfLine(stream) || type$1 == "," && endOfLine(stream) || type$1 == "mixin") return pushContext(state, stream, "block", 0);
|
|
if (typeIsInterpolation(type$1, stream)) return pushContext(state, stream, "interpolation");
|
|
if (endOfLine(stream) && type$1 == "]") {
|
|
if (!/^\s*(\.|#|:|\[|\*|&)/.test(stream.string) && !wordIsTag(firstWordOfLine(stream))) return pushContext(state, stream, "block", 0);
|
|
}
|
|
if (typeIsBlock(type$1, stream)) return pushContext(state, stream, "block");
|
|
if (type$1 == "}" && endOfLine(stream)) return pushContext(state, stream, "block", 0);
|
|
if (type$1 == "variable-name") if (stream.string.match(/^\s?\$[\w-\.\[\]\'\"]+$/) || wordIsBlock(firstWordOfLine(stream))) return pushContext(state, stream, "variableName");
|
|
else return pushContext(state, stream, "variableName", 0);
|
|
if (type$1 == "=") {
|
|
if (!endOfLine(stream) && !wordIsBlock(firstWordOfLine(stream))) return pushContext(state, stream, "block", 0);
|
|
return pushContext(state, stream, "block");
|
|
}
|
|
if (type$1 == "*") {
|
|
if (endOfLine(stream) || stream.match(/\s*(,|\.|#|\[|:|{)/, false)) {
|
|
override = "tag";
|
|
return pushContext(state, stream, "block");
|
|
}
|
|
}
|
|
if (typeIsPseudo(type$1, stream)) return pushContext(state, stream, "pseudo");
|
|
if (/@(font-face|media|supports|(-moz-)?document)/.test(type$1)) return pushContext(state, stream, endOfLine(stream) ? "block" : "atBlock");
|
|
if (/@(-(moz|ms|o|webkit)-)?keyframes$/.test(type$1)) return pushContext(state, stream, "keyframes");
|
|
if (/@extends?/.test(type$1)) return pushContext(state, stream, "extend", 0);
|
|
if (type$1 && type$1.charAt(0) == "@") {
|
|
if (stream.indentation() > 0 && wordIsProperty(stream.current().slice(1))) {
|
|
override = "variable-2";
|
|
return "block";
|
|
}
|
|
if (/(@import|@require|@charset)/.test(type$1)) return pushContext(state, stream, "block", 0);
|
|
return pushContext(state, stream, "block");
|
|
}
|
|
if (type$1 == "reference" && endOfLine(stream)) return pushContext(state, stream, "block");
|
|
if (type$1 == "(") return pushContext(state, stream, "parens");
|
|
if (type$1 == "vendor-prefixes") return pushContext(state, stream, "vendorPrefixes");
|
|
if (type$1 == "word") {
|
|
var word = stream.current();
|
|
override = wordAsValue(word);
|
|
if (override == "property") if (startOfLine(stream)) return pushContext(state, stream, "block", 0);
|
|
else {
|
|
override = "atom";
|
|
return "block";
|
|
}
|
|
if (override == "tag") {
|
|
if (/embed|menu|pre|progress|sub|table/.test(word)) {
|
|
if (wordIsProperty(firstWordOfLine(stream))) {
|
|
override = "atom";
|
|
return "block";
|
|
}
|
|
}
|
|
if (stream.string.match(new RegExp("\\[\\s*" + word + "|" + word + "\\s*\\]"))) {
|
|
override = "atom";
|
|
return "block";
|
|
}
|
|
if (tagVariablesRegexp.test(word)) {
|
|
if (startOfLine(stream) && stream.string.match(/=/) || !startOfLine(stream) && !stream.string.match(/^(\s*\.|#|\&|\[|\/|>|\*)/) && !wordIsTag(firstWordOfLine(stream))) {
|
|
override = "variable-2";
|
|
if (wordIsBlock(firstWordOfLine(stream))) return "block";
|
|
return pushContext(state, stream, "block", 0);
|
|
}
|
|
}
|
|
if (endOfLine(stream)) return pushContext(state, stream, "block");
|
|
}
|
|
if (override == "block-keyword") {
|
|
override = "keyword";
|
|
if (stream.current(/(if|unless)/) && !startOfLine(stream)) return "block";
|
|
return pushContext(state, stream, "block");
|
|
}
|
|
if (word == "return") return pushContext(state, stream, "block", 0);
|
|
if (override == "variable-2" && stream.string.match(/^\s?\$[\w-\.\[\]\'\"]+$/)) return pushContext(state, stream, "block");
|
|
}
|
|
return state.context.type;
|
|
};
|
|
/**
|
|
* Parens
|
|
*/
|
|
states.parens = function(type$1, stream, state) {
|
|
if (type$1 == "(") return pushContext(state, stream, "parens");
|
|
if (type$1 == ")") {
|
|
if (state.context.prev.type == "parens") return popContext(state);
|
|
if (stream.string.match(/^[a-z][\w-]*\(/i) && endOfLine(stream) || wordIsBlock(firstWordOfLine(stream)) || /(\.|#|:|\[|\*|&|>|~|\+|\/)/.test(firstWordOfLine(stream)) || !stream.string.match(/^-?[a-z][\w-\.\[\]\'\"]*\s*=/) && wordIsTag(firstWordOfLine(stream))) return pushContext(state, stream, "block");
|
|
if (stream.string.match(/^[\$-]?[a-z][\w-\.\[\]\'\"]*\s*=/) || stream.string.match(/^\s*(\(|\)|[0-9])/) || stream.string.match(/^\s+[a-z][\w-]*\(/i) || stream.string.match(/^\s+[\$-]?[a-z]/i)) return pushContext(state, stream, "block", 0);
|
|
if (endOfLine(stream)) return pushContext(state, stream, "block");
|
|
else return pushContext(state, stream, "block", 0);
|
|
}
|
|
if (type$1 && type$1.charAt(0) == "@" && wordIsProperty(stream.current().slice(1))) override = "variable-2";
|
|
if (type$1 == "word") {
|
|
var word = stream.current();
|
|
override = wordAsValue(word);
|
|
if (override == "tag" && tagVariablesRegexp.test(word)) override = "variable-2";
|
|
if (override == "property" || word == "to") override = "atom";
|
|
}
|
|
if (type$1 == "variable-name") return pushContext(state, stream, "variableName");
|
|
if (typeIsPseudo(type$1, stream)) return pushContext(state, stream, "pseudo");
|
|
return state.context.type;
|
|
};
|
|
/**
|
|
* Vendor prefixes
|
|
*/
|
|
states.vendorPrefixes = function(type$1, stream, state) {
|
|
if (type$1 == "word") {
|
|
override = "property";
|
|
return pushContext(state, stream, "block", 0);
|
|
}
|
|
return popContext(state);
|
|
};
|
|
/**
|
|
* Pseudo
|
|
*/
|
|
states.pseudo = function(type$1, stream, state) {
|
|
if (!wordIsProperty(firstWordOfLine(stream.string))) {
|
|
stream.match(/^[a-z-]+/);
|
|
override = "variable-3";
|
|
if (endOfLine(stream)) return pushContext(state, stream, "block");
|
|
return popContext(state);
|
|
}
|
|
return popAndPass(type$1, stream, state);
|
|
};
|
|
/**
|
|
* atBlock
|
|
*/
|
|
states.atBlock = function(type$1, stream, state) {
|
|
if (type$1 == "(") return pushContext(state, stream, "atBlock_parens");
|
|
if (typeIsBlock(type$1, stream)) return pushContext(state, stream, "block");
|
|
if (typeIsInterpolation(type$1, stream)) return pushContext(state, stream, "interpolation");
|
|
if (type$1 == "word") {
|
|
var word = stream.current().toLowerCase();
|
|
if (/^(only|not|and|or)$/.test(word)) override = "keyword";
|
|
else if (documentTypes.hasOwnProperty(word)) override = "tag";
|
|
else if (mediaTypes.hasOwnProperty(word)) override = "attribute";
|
|
else if (mediaFeatures.hasOwnProperty(word)) override = "property";
|
|
else if (nonStandardPropertyKeywords.hasOwnProperty(word)) override = "string-2";
|
|
else override = wordAsValue(stream.current());
|
|
if (override == "tag" && endOfLine(stream)) return pushContext(state, stream, "block");
|
|
}
|
|
if (type$1 == "operator" && /^(not|and|or)$/.test(stream.current())) override = "keyword";
|
|
return state.context.type;
|
|
};
|
|
states.atBlock_parens = function(type$1, stream, state) {
|
|
if (type$1 == "{" || type$1 == "}") return state.context.type;
|
|
if (type$1 == ")") if (endOfLine(stream)) return pushContext(state, stream, "block");
|
|
else return pushContext(state, stream, "atBlock");
|
|
if (type$1 == "word") {
|
|
var word = stream.current().toLowerCase();
|
|
override = wordAsValue(word);
|
|
if (/^(max|min)/.test(word)) override = "property";
|
|
if (override == "tag") tagVariablesRegexp.test(word) ? override = "variable-2" : override = "atom";
|
|
return state.context.type;
|
|
}
|
|
return states.atBlock(type$1, stream, state);
|
|
};
|
|
/**
|
|
* Keyframes
|
|
*/
|
|
states.keyframes = function(type$1, stream, state) {
|
|
if (stream.indentation() == "0" && (type$1 == "}" && startOfLine(stream) || type$1 == "]" || type$1 == "hash" || type$1 == "qualifier" || wordIsTag(stream.current()))) return popAndPass(type$1, stream, state);
|
|
if (type$1 == "{") return pushContext(state, stream, "keyframes");
|
|
if (type$1 == "}") if (startOfLine(stream)) return popContext(state, true);
|
|
else return pushContext(state, stream, "keyframes");
|
|
if (type$1 == "unit" && /^[0-9]+\%$/.test(stream.current())) return pushContext(state, stream, "keyframes");
|
|
if (type$1 == "word") {
|
|
override = wordAsValue(stream.current());
|
|
if (override == "block-keyword") {
|
|
override = "keyword";
|
|
return pushContext(state, stream, "keyframes");
|
|
}
|
|
}
|
|
if (/@(font-face|media|supports|(-moz-)?document)/.test(type$1)) return pushContext(state, stream, endOfLine(stream) ? "block" : "atBlock");
|
|
if (type$1 == "mixin") return pushContext(state, stream, "block", 0);
|
|
return state.context.type;
|
|
};
|
|
/**
|
|
* Interpolation
|
|
*/
|
|
states.interpolation = function(type$1, stream, state) {
|
|
if (type$1 == "{") popContext(state) && pushContext(state, stream, "block");
|
|
if (type$1 == "}") {
|
|
if (stream.string.match(/^\s*(\.|#|:|\[|\*|&|>|~|\+|\/)/i) || stream.string.match(/^\s*[a-z]/i) && wordIsTag(firstWordOfLine(stream))) return pushContext(state, stream, "block");
|
|
if (!stream.string.match(/^(\{|\s*\&)/) || stream.match(/\s*[\w-]/, false)) return pushContext(state, stream, "block", 0);
|
|
return pushContext(state, stream, "block");
|
|
}
|
|
if (type$1 == "variable-name") return pushContext(state, stream, "variableName", 0);
|
|
if (type$1 == "word") {
|
|
override = wordAsValue(stream.current());
|
|
if (override == "tag") override = "atom";
|
|
}
|
|
return state.context.type;
|
|
};
|
|
/**
|
|
* Extend/s
|
|
*/
|
|
states.extend = function(type$1, stream, state) {
|
|
if (type$1 == "[" || type$1 == "=") return "extend";
|
|
if (type$1 == "]") return popContext(state);
|
|
if (type$1 == "word") {
|
|
override = wordAsValue(stream.current());
|
|
return "extend";
|
|
}
|
|
return popContext(state);
|
|
};
|
|
/**
|
|
* Variable name
|
|
*/
|
|
states.variableName = function(type$1, stream, state) {
|
|
if (type$1 == "string" || type$1 == "[" || type$1 == "]" || stream.current().match(/^(\.|\$)/)) {
|
|
if (stream.current().match(/^\.[\w-]+/i)) override = "variable-2";
|
|
return "variableName";
|
|
}
|
|
return popAndPass(type$1, stream, state);
|
|
};
|
|
return {
|
|
startState: function(base) {
|
|
return {
|
|
tokenize: null,
|
|
state: "block",
|
|
context: new Context("block", base || 0, null)
|
|
};
|
|
},
|
|
token: function(stream, state) {
|
|
if (!state.tokenize && stream.eatSpace()) return null;
|
|
style = (state.tokenize || tokenBase)(stream, state);
|
|
if (style && typeof style == "object") {
|
|
type = style[1];
|
|
style = style[0];
|
|
}
|
|
override = style;
|
|
state.state = states[state.state](type, stream, state);
|
|
return override;
|
|
},
|
|
indent: function(state, textAfter, line) {
|
|
var cx = state.context, ch$1 = textAfter && textAfter.charAt(0), indent = cx.indent, lineFirstWord = firstWordOfLine(textAfter), lineIndent = line.match(/^\s*/)[0].replace(/\t/g, indentUnitString).length, prevLineFirstWord = state.context.prev ? state.context.prev.line.firstWord : "", prevLineIndent = state.context.prev ? state.context.prev.line.indent : lineIndent;
|
|
if (cx.prev && (ch$1 == "}" && (cx.type == "block" || cx.type == "atBlock" || cx.type == "keyframes") || ch$1 == ")" && (cx.type == "parens" || cx.type == "atBlock_parens") || ch$1 == "{" && cx.type == "at")) indent = cx.indent - indentUnit;
|
|
else if (!/(\})/.test(ch$1)) {
|
|
if (/@|\$|\d/.test(ch$1) || /^\{/.test(textAfter) || /^\s*\/(\/|\*)/.test(textAfter) || /^\s*\/\*/.test(prevLineFirstWord) || /^\s*[\w-\.\[\]\'\"]+\s*(\?|:|\+)?=/i.test(textAfter) || /^(\+|-)?[a-z][\w-]*\(/i.test(textAfter) || /^return/.test(textAfter) || wordIsBlock(lineFirstWord)) indent = lineIndent;
|
|
else if (/(\.|#|:|\[|\*|&|>|~|\+|\/)/.test(ch$1) || wordIsTag(lineFirstWord)) if (/\,\s*$/.test(prevLineFirstWord)) indent = prevLineIndent;
|
|
else if (/^\s+/.test(line) && (/(\.|#|:|\[|\*|&|>|~|\+|\/)/.test(prevLineFirstWord) || wordIsTag(prevLineFirstWord))) indent = lineIndent <= prevLineIndent ? prevLineIndent : prevLineIndent + indentUnit;
|
|
else indent = lineIndent;
|
|
else if (!/,\s*$/.test(line) && (wordIsVendorPrefix(lineFirstWord) || wordIsProperty(lineFirstWord))) if (wordIsBlock(prevLineFirstWord)) indent = lineIndent <= prevLineIndent ? prevLineIndent : prevLineIndent + indentUnit;
|
|
else if (/^\{/.test(prevLineFirstWord)) indent = lineIndent <= prevLineIndent ? lineIndent : prevLineIndent + indentUnit;
|
|
else if (wordIsVendorPrefix(prevLineFirstWord) || wordIsProperty(prevLineFirstWord)) indent = lineIndent >= prevLineIndent ? prevLineIndent : lineIndent;
|
|
else if (/^(\.|#|:|\[|\*|&|@|\+|\-|>|~|\/)/.test(prevLineFirstWord) || /=\s*$/.test(prevLineFirstWord) || wordIsTag(prevLineFirstWord) || /^\$[\w-\.\[\]\'\"]/.test(prevLineFirstWord)) indent = prevLineIndent + indentUnit;
|
|
else indent = lineIndent;
|
|
}
|
|
return indent;
|
|
},
|
|
electricChars: "}",
|
|
blockCommentStart: "/*",
|
|
blockCommentEnd: "*/",
|
|
blockCommentContinue: " * ",
|
|
lineComment: "//",
|
|
fold: "indent"
|
|
};
|
|
});
|
|
var tagKeywords_ = [
|
|
"a",
|
|
"abbr",
|
|
"address",
|
|
"area",
|
|
"article",
|
|
"aside",
|
|
"audio",
|
|
"b",
|
|
"base",
|
|
"bdi",
|
|
"bdo",
|
|
"bgsound",
|
|
"blockquote",
|
|
"body",
|
|
"br",
|
|
"button",
|
|
"canvas",
|
|
"caption",
|
|
"cite",
|
|
"code",
|
|
"col",
|
|
"colgroup",
|
|
"data",
|
|
"datalist",
|
|
"dd",
|
|
"del",
|
|
"details",
|
|
"dfn",
|
|
"div",
|
|
"dl",
|
|
"dt",
|
|
"em",
|
|
"embed",
|
|
"fieldset",
|
|
"figcaption",
|
|
"figure",
|
|
"footer",
|
|
"form",
|
|
"h1",
|
|
"h2",
|
|
"h3",
|
|
"h4",
|
|
"h5",
|
|
"h6",
|
|
"head",
|
|
"header",
|
|
"hgroup",
|
|
"hr",
|
|
"html",
|
|
"i",
|
|
"iframe",
|
|
"img",
|
|
"input",
|
|
"ins",
|
|
"kbd",
|
|
"keygen",
|
|
"label",
|
|
"legend",
|
|
"li",
|
|
"link",
|
|
"main",
|
|
"map",
|
|
"mark",
|
|
"marquee",
|
|
"menu",
|
|
"menuitem",
|
|
"meta",
|
|
"meter",
|
|
"nav",
|
|
"nobr",
|
|
"noframes",
|
|
"noscript",
|
|
"object",
|
|
"ol",
|
|
"optgroup",
|
|
"option",
|
|
"output",
|
|
"p",
|
|
"param",
|
|
"pre",
|
|
"progress",
|
|
"q",
|
|
"rp",
|
|
"rt",
|
|
"ruby",
|
|
"s",
|
|
"samp",
|
|
"script",
|
|
"section",
|
|
"select",
|
|
"small",
|
|
"source",
|
|
"span",
|
|
"strong",
|
|
"style",
|
|
"sub",
|
|
"summary",
|
|
"sup",
|
|
"table",
|
|
"tbody",
|
|
"td",
|
|
"textarea",
|
|
"tfoot",
|
|
"th",
|
|
"thead",
|
|
"time",
|
|
"tr",
|
|
"track",
|
|
"u",
|
|
"ul",
|
|
"var",
|
|
"video"
|
|
];
|
|
var documentTypes_ = [
|
|
"domain",
|
|
"regexp",
|
|
"url-prefix",
|
|
"url"
|
|
];
|
|
var mediaTypes_ = [
|
|
"all",
|
|
"aural",
|
|
"braille",
|
|
"handheld",
|
|
"print",
|
|
"projection",
|
|
"screen",
|
|
"tty",
|
|
"tv",
|
|
"embossed"
|
|
];
|
|
var mediaFeatures_ = [
|
|
"width",
|
|
"min-width",
|
|
"max-width",
|
|
"height",
|
|
"min-height",
|
|
"max-height",
|
|
"device-width",
|
|
"min-device-width",
|
|
"max-device-width",
|
|
"device-height",
|
|
"min-device-height",
|
|
"max-device-height",
|
|
"aspect-ratio",
|
|
"min-aspect-ratio",
|
|
"max-aspect-ratio",
|
|
"device-aspect-ratio",
|
|
"min-device-aspect-ratio",
|
|
"max-device-aspect-ratio",
|
|
"color",
|
|
"min-color",
|
|
"max-color",
|
|
"color-index",
|
|
"min-color-index",
|
|
"max-color-index",
|
|
"monochrome",
|
|
"min-monochrome",
|
|
"max-monochrome",
|
|
"resolution",
|
|
"min-resolution",
|
|
"max-resolution",
|
|
"scan",
|
|
"grid",
|
|
"dynamic-range",
|
|
"video-dynamic-range"
|
|
];
|
|
var propertyKeywords_ = [
|
|
"align-content",
|
|
"align-items",
|
|
"align-self",
|
|
"alignment-adjust",
|
|
"alignment-baseline",
|
|
"anchor-point",
|
|
"animation",
|
|
"animation-delay",
|
|
"animation-direction",
|
|
"animation-duration",
|
|
"animation-fill-mode",
|
|
"animation-iteration-count",
|
|
"animation-name",
|
|
"animation-play-state",
|
|
"animation-timing-function",
|
|
"appearance",
|
|
"azimuth",
|
|
"backface-visibility",
|
|
"background",
|
|
"background-attachment",
|
|
"background-clip",
|
|
"background-color",
|
|
"background-image",
|
|
"background-origin",
|
|
"background-position",
|
|
"background-repeat",
|
|
"background-size",
|
|
"baseline-shift",
|
|
"binding",
|
|
"bleed",
|
|
"bookmark-label",
|
|
"bookmark-level",
|
|
"bookmark-state",
|
|
"bookmark-target",
|
|
"border",
|
|
"border-bottom",
|
|
"border-bottom-color",
|
|
"border-bottom-left-radius",
|
|
"border-bottom-right-radius",
|
|
"border-bottom-style",
|
|
"border-bottom-width",
|
|
"border-collapse",
|
|
"border-color",
|
|
"border-image",
|
|
"border-image-outset",
|
|
"border-image-repeat",
|
|
"border-image-slice",
|
|
"border-image-source",
|
|
"border-image-width",
|
|
"border-left",
|
|
"border-left-color",
|
|
"border-left-style",
|
|
"border-left-width",
|
|
"border-radius",
|
|
"border-right",
|
|
"border-right-color",
|
|
"border-right-style",
|
|
"border-right-width",
|
|
"border-spacing",
|
|
"border-style",
|
|
"border-top",
|
|
"border-top-color",
|
|
"border-top-left-radius",
|
|
"border-top-right-radius",
|
|
"border-top-style",
|
|
"border-top-width",
|
|
"border-width",
|
|
"bottom",
|
|
"box-decoration-break",
|
|
"box-shadow",
|
|
"box-sizing",
|
|
"break-after",
|
|
"break-before",
|
|
"break-inside",
|
|
"caption-side",
|
|
"clear",
|
|
"clip",
|
|
"color",
|
|
"color-profile",
|
|
"column-count",
|
|
"column-fill",
|
|
"column-gap",
|
|
"column-rule",
|
|
"column-rule-color",
|
|
"column-rule-style",
|
|
"column-rule-width",
|
|
"column-span",
|
|
"column-width",
|
|
"columns",
|
|
"content",
|
|
"counter-increment",
|
|
"counter-reset",
|
|
"crop",
|
|
"cue",
|
|
"cue-after",
|
|
"cue-before",
|
|
"cursor",
|
|
"direction",
|
|
"display",
|
|
"dominant-baseline",
|
|
"drop-initial-after-adjust",
|
|
"drop-initial-after-align",
|
|
"drop-initial-before-adjust",
|
|
"drop-initial-before-align",
|
|
"drop-initial-size",
|
|
"drop-initial-value",
|
|
"elevation",
|
|
"empty-cells",
|
|
"fit",
|
|
"fit-position",
|
|
"flex",
|
|
"flex-basis",
|
|
"flex-direction",
|
|
"flex-flow",
|
|
"flex-grow",
|
|
"flex-shrink",
|
|
"flex-wrap",
|
|
"float",
|
|
"float-offset",
|
|
"flow-from",
|
|
"flow-into",
|
|
"font",
|
|
"font-feature-settings",
|
|
"font-family",
|
|
"font-kerning",
|
|
"font-language-override",
|
|
"font-size",
|
|
"font-size-adjust",
|
|
"font-stretch",
|
|
"font-style",
|
|
"font-synthesis",
|
|
"font-variant",
|
|
"font-variant-alternates",
|
|
"font-variant-caps",
|
|
"font-variant-east-asian",
|
|
"font-variant-ligatures",
|
|
"font-variant-numeric",
|
|
"font-variant-position",
|
|
"font-weight",
|
|
"grid",
|
|
"grid-area",
|
|
"grid-auto-columns",
|
|
"grid-auto-flow",
|
|
"grid-auto-position",
|
|
"grid-auto-rows",
|
|
"grid-column",
|
|
"grid-column-end",
|
|
"grid-column-start",
|
|
"grid-row",
|
|
"grid-row-end",
|
|
"grid-row-start",
|
|
"grid-template",
|
|
"grid-template-areas",
|
|
"grid-template-columns",
|
|
"grid-template-rows",
|
|
"hanging-punctuation",
|
|
"height",
|
|
"hyphens",
|
|
"icon",
|
|
"image-orientation",
|
|
"image-rendering",
|
|
"image-resolution",
|
|
"inline-box-align",
|
|
"justify-content",
|
|
"left",
|
|
"letter-spacing",
|
|
"line-break",
|
|
"line-height",
|
|
"line-stacking",
|
|
"line-stacking-ruby",
|
|
"line-stacking-shift",
|
|
"line-stacking-strategy",
|
|
"list-style",
|
|
"list-style-image",
|
|
"list-style-position",
|
|
"list-style-type",
|
|
"margin",
|
|
"margin-bottom",
|
|
"margin-left",
|
|
"margin-right",
|
|
"margin-top",
|
|
"marker-offset",
|
|
"marks",
|
|
"marquee-direction",
|
|
"marquee-loop",
|
|
"marquee-play-count",
|
|
"marquee-speed",
|
|
"marquee-style",
|
|
"max-height",
|
|
"max-width",
|
|
"min-height",
|
|
"min-width",
|
|
"move-to",
|
|
"nav-down",
|
|
"nav-index",
|
|
"nav-left",
|
|
"nav-right",
|
|
"nav-up",
|
|
"object-fit",
|
|
"object-position",
|
|
"opacity",
|
|
"order",
|
|
"orphans",
|
|
"outline",
|
|
"outline-color",
|
|
"outline-offset",
|
|
"outline-style",
|
|
"outline-width",
|
|
"overflow",
|
|
"overflow-style",
|
|
"overflow-wrap",
|
|
"overflow-x",
|
|
"overflow-y",
|
|
"padding",
|
|
"padding-bottom",
|
|
"padding-left",
|
|
"padding-right",
|
|
"padding-top",
|
|
"page",
|
|
"page-break-after",
|
|
"page-break-before",
|
|
"page-break-inside",
|
|
"page-policy",
|
|
"pause",
|
|
"pause-after",
|
|
"pause-before",
|
|
"perspective",
|
|
"perspective-origin",
|
|
"pitch",
|
|
"pitch-range",
|
|
"play-during",
|
|
"position",
|
|
"presentation-level",
|
|
"punctuation-trim",
|
|
"quotes",
|
|
"region-break-after",
|
|
"region-break-before",
|
|
"region-break-inside",
|
|
"region-fragment",
|
|
"rendering-intent",
|
|
"resize",
|
|
"rest",
|
|
"rest-after",
|
|
"rest-before",
|
|
"richness",
|
|
"right",
|
|
"rotation",
|
|
"rotation-point",
|
|
"ruby-align",
|
|
"ruby-overhang",
|
|
"ruby-position",
|
|
"ruby-span",
|
|
"shape-image-threshold",
|
|
"shape-inside",
|
|
"shape-margin",
|
|
"shape-outside",
|
|
"size",
|
|
"speak",
|
|
"speak-as",
|
|
"speak-header",
|
|
"speak-numeral",
|
|
"speak-punctuation",
|
|
"speech-rate",
|
|
"stress",
|
|
"string-set",
|
|
"tab-size",
|
|
"table-layout",
|
|
"target",
|
|
"target-name",
|
|
"target-new",
|
|
"target-position",
|
|
"text-align",
|
|
"text-align-last",
|
|
"text-decoration",
|
|
"text-decoration-color",
|
|
"text-decoration-line",
|
|
"text-decoration-skip",
|
|
"text-decoration-style",
|
|
"text-emphasis",
|
|
"text-emphasis-color",
|
|
"text-emphasis-position",
|
|
"text-emphasis-style",
|
|
"text-height",
|
|
"text-indent",
|
|
"text-justify",
|
|
"text-outline",
|
|
"text-overflow",
|
|
"text-shadow",
|
|
"text-size-adjust",
|
|
"text-space-collapse",
|
|
"text-transform",
|
|
"text-underline-position",
|
|
"text-wrap",
|
|
"top",
|
|
"transform",
|
|
"transform-origin",
|
|
"transform-style",
|
|
"transition",
|
|
"transition-delay",
|
|
"transition-duration",
|
|
"transition-property",
|
|
"transition-timing-function",
|
|
"unicode-bidi",
|
|
"vertical-align",
|
|
"visibility",
|
|
"voice-balance",
|
|
"voice-duration",
|
|
"voice-family",
|
|
"voice-pitch",
|
|
"voice-range",
|
|
"voice-rate",
|
|
"voice-stress",
|
|
"voice-volume",
|
|
"volume",
|
|
"white-space",
|
|
"widows",
|
|
"width",
|
|
"will-change",
|
|
"word-break",
|
|
"word-spacing",
|
|
"word-wrap",
|
|
"z-index",
|
|
"clip-path",
|
|
"clip-rule",
|
|
"mask",
|
|
"enable-background",
|
|
"filter",
|
|
"flood-color",
|
|
"flood-opacity",
|
|
"lighting-color",
|
|
"stop-color",
|
|
"stop-opacity",
|
|
"pointer-events",
|
|
"color-interpolation",
|
|
"color-interpolation-filters",
|
|
"color-rendering",
|
|
"fill",
|
|
"fill-opacity",
|
|
"fill-rule",
|
|
"image-rendering",
|
|
"marker",
|
|
"marker-end",
|
|
"marker-mid",
|
|
"marker-start",
|
|
"shape-rendering",
|
|
"stroke",
|
|
"stroke-dasharray",
|
|
"stroke-dashoffset",
|
|
"stroke-linecap",
|
|
"stroke-linejoin",
|
|
"stroke-miterlimit",
|
|
"stroke-opacity",
|
|
"stroke-width",
|
|
"text-rendering",
|
|
"baseline-shift",
|
|
"dominant-baseline",
|
|
"glyph-orientation-horizontal",
|
|
"glyph-orientation-vertical",
|
|
"text-anchor",
|
|
"writing-mode",
|
|
"font-smoothing",
|
|
"osx-font-smoothing"
|
|
];
|
|
var nonStandardPropertyKeywords_ = [
|
|
"scrollbar-arrow-color",
|
|
"scrollbar-base-color",
|
|
"scrollbar-dark-shadow-color",
|
|
"scrollbar-face-color",
|
|
"scrollbar-highlight-color",
|
|
"scrollbar-shadow-color",
|
|
"scrollbar-3d-light-color",
|
|
"scrollbar-track-color",
|
|
"shape-inside",
|
|
"searchfield-cancel-button",
|
|
"searchfield-decoration",
|
|
"searchfield-results-button",
|
|
"searchfield-results-decoration",
|
|
"zoom"
|
|
];
|
|
var fontProperties_ = [
|
|
"font-family",
|
|
"src",
|
|
"unicode-range",
|
|
"font-variant",
|
|
"font-feature-settings",
|
|
"font-stretch",
|
|
"font-weight",
|
|
"font-style"
|
|
];
|
|
var colorKeywords_ = [
|
|
"aliceblue",
|
|
"antiquewhite",
|
|
"aqua",
|
|
"aquamarine",
|
|
"azure",
|
|
"beige",
|
|
"bisque",
|
|
"black",
|
|
"blanchedalmond",
|
|
"blue",
|
|
"blueviolet",
|
|
"brown",
|
|
"burlywood",
|
|
"cadetblue",
|
|
"chartreuse",
|
|
"chocolate",
|
|
"coral",
|
|
"cornflowerblue",
|
|
"cornsilk",
|
|
"crimson",
|
|
"cyan",
|
|
"darkblue",
|
|
"darkcyan",
|
|
"darkgoldenrod",
|
|
"darkgray",
|
|
"darkgreen",
|
|
"darkkhaki",
|
|
"darkmagenta",
|
|
"darkolivegreen",
|
|
"darkorange",
|
|
"darkorchid",
|
|
"darkred",
|
|
"darksalmon",
|
|
"darkseagreen",
|
|
"darkslateblue",
|
|
"darkslategray",
|
|
"darkturquoise",
|
|
"darkviolet",
|
|
"deeppink",
|
|
"deepskyblue",
|
|
"dimgray",
|
|
"dodgerblue",
|
|
"firebrick",
|
|
"floralwhite",
|
|
"forestgreen",
|
|
"fuchsia",
|
|
"gainsboro",
|
|
"ghostwhite",
|
|
"gold",
|
|
"goldenrod",
|
|
"gray",
|
|
"grey",
|
|
"green",
|
|
"greenyellow",
|
|
"honeydew",
|
|
"hotpink",
|
|
"indianred",
|
|
"indigo",
|
|
"ivory",
|
|
"khaki",
|
|
"lavender",
|
|
"lavenderblush",
|
|
"lawngreen",
|
|
"lemonchiffon",
|
|
"lightblue",
|
|
"lightcoral",
|
|
"lightcyan",
|
|
"lightgoldenrodyellow",
|
|
"lightgray",
|
|
"lightgreen",
|
|
"lightpink",
|
|
"lightsalmon",
|
|
"lightseagreen",
|
|
"lightskyblue",
|
|
"lightslategray",
|
|
"lightsteelblue",
|
|
"lightyellow",
|
|
"lime",
|
|
"limegreen",
|
|
"linen",
|
|
"magenta",
|
|
"maroon",
|
|
"mediumaquamarine",
|
|
"mediumblue",
|
|
"mediumorchid",
|
|
"mediumpurple",
|
|
"mediumseagreen",
|
|
"mediumslateblue",
|
|
"mediumspringgreen",
|
|
"mediumturquoise",
|
|
"mediumvioletred",
|
|
"midnightblue",
|
|
"mintcream",
|
|
"mistyrose",
|
|
"moccasin",
|
|
"navajowhite",
|
|
"navy",
|
|
"oldlace",
|
|
"olive",
|
|
"olivedrab",
|
|
"orange",
|
|
"orangered",
|
|
"orchid",
|
|
"palegoldenrod",
|
|
"palegreen",
|
|
"paleturquoise",
|
|
"palevioletred",
|
|
"papayawhip",
|
|
"peachpuff",
|
|
"peru",
|
|
"pink",
|
|
"plum",
|
|
"powderblue",
|
|
"purple",
|
|
"rebeccapurple",
|
|
"red",
|
|
"rosybrown",
|
|
"royalblue",
|
|
"saddlebrown",
|
|
"salmon",
|
|
"sandybrown",
|
|
"seagreen",
|
|
"seashell",
|
|
"sienna",
|
|
"silver",
|
|
"skyblue",
|
|
"slateblue",
|
|
"slategray",
|
|
"snow",
|
|
"springgreen",
|
|
"steelblue",
|
|
"tan",
|
|
"teal",
|
|
"thistle",
|
|
"tomato",
|
|
"turquoise",
|
|
"violet",
|
|
"wheat",
|
|
"white",
|
|
"whitesmoke",
|
|
"yellow",
|
|
"yellowgreen"
|
|
];
|
|
var valueKeywords_ = [
|
|
"above",
|
|
"absolute",
|
|
"activeborder",
|
|
"additive",
|
|
"activecaption",
|
|
"afar",
|
|
"after-white-space",
|
|
"ahead",
|
|
"alias",
|
|
"all",
|
|
"all-scroll",
|
|
"alphabetic",
|
|
"alternate",
|
|
"always",
|
|
"amharic",
|
|
"amharic-abegede",
|
|
"antialiased",
|
|
"appworkspace",
|
|
"arabic-indic",
|
|
"armenian",
|
|
"asterisks",
|
|
"attr",
|
|
"auto",
|
|
"avoid",
|
|
"avoid-column",
|
|
"avoid-page",
|
|
"avoid-region",
|
|
"background",
|
|
"backwards",
|
|
"baseline",
|
|
"below",
|
|
"bidi-override",
|
|
"binary",
|
|
"bengali",
|
|
"blink",
|
|
"block",
|
|
"block-axis",
|
|
"bold",
|
|
"bolder",
|
|
"border",
|
|
"border-box",
|
|
"both",
|
|
"bottom",
|
|
"break",
|
|
"break-all",
|
|
"break-word",
|
|
"bullets",
|
|
"button",
|
|
"buttonface",
|
|
"buttonhighlight",
|
|
"buttonshadow",
|
|
"buttontext",
|
|
"calc",
|
|
"cambodian",
|
|
"capitalize",
|
|
"caps-lock-indicator",
|
|
"caption",
|
|
"captiontext",
|
|
"caret",
|
|
"cell",
|
|
"center",
|
|
"checkbox",
|
|
"circle",
|
|
"cjk-decimal",
|
|
"cjk-earthly-branch",
|
|
"cjk-heavenly-stem",
|
|
"cjk-ideographic",
|
|
"clear",
|
|
"clip",
|
|
"close-quote",
|
|
"col-resize",
|
|
"collapse",
|
|
"column",
|
|
"compact",
|
|
"condensed",
|
|
"conic-gradient",
|
|
"contain",
|
|
"content",
|
|
"contents",
|
|
"content-box",
|
|
"context-menu",
|
|
"continuous",
|
|
"copy",
|
|
"counter",
|
|
"counters",
|
|
"cover",
|
|
"crop",
|
|
"cross",
|
|
"crosshair",
|
|
"currentcolor",
|
|
"cursive",
|
|
"cyclic",
|
|
"dashed",
|
|
"decimal",
|
|
"decimal-leading-zero",
|
|
"default",
|
|
"default-button",
|
|
"destination-atop",
|
|
"destination-in",
|
|
"destination-out",
|
|
"destination-over",
|
|
"devanagari",
|
|
"disc",
|
|
"discard",
|
|
"disclosure-closed",
|
|
"disclosure-open",
|
|
"document",
|
|
"dot-dash",
|
|
"dot-dot-dash",
|
|
"dotted",
|
|
"double",
|
|
"down",
|
|
"e-resize",
|
|
"ease",
|
|
"ease-in",
|
|
"ease-in-out",
|
|
"ease-out",
|
|
"element",
|
|
"ellipse",
|
|
"ellipsis",
|
|
"embed",
|
|
"end",
|
|
"ethiopic",
|
|
"ethiopic-abegede",
|
|
"ethiopic-abegede-am-et",
|
|
"ethiopic-abegede-gez",
|
|
"ethiopic-abegede-ti-er",
|
|
"ethiopic-abegede-ti-et",
|
|
"ethiopic-halehame-aa-er",
|
|
"ethiopic-halehame-aa-et",
|
|
"ethiopic-halehame-am-et",
|
|
"ethiopic-halehame-gez",
|
|
"ethiopic-halehame-om-et",
|
|
"ethiopic-halehame-sid-et",
|
|
"ethiopic-halehame-so-et",
|
|
"ethiopic-halehame-ti-er",
|
|
"ethiopic-halehame-ti-et",
|
|
"ethiopic-halehame-tig",
|
|
"ethiopic-numeric",
|
|
"ew-resize",
|
|
"expanded",
|
|
"extends",
|
|
"extra-condensed",
|
|
"extra-expanded",
|
|
"fantasy",
|
|
"fast",
|
|
"fill",
|
|
"fixed",
|
|
"flat",
|
|
"flex",
|
|
"footnotes",
|
|
"forwards",
|
|
"from",
|
|
"geometricPrecision",
|
|
"georgian",
|
|
"graytext",
|
|
"groove",
|
|
"gujarati",
|
|
"gurmukhi",
|
|
"hand",
|
|
"hangul",
|
|
"hangul-consonant",
|
|
"hebrew",
|
|
"help",
|
|
"hidden",
|
|
"hide",
|
|
"high",
|
|
"higher",
|
|
"highlight",
|
|
"highlighttext",
|
|
"hiragana",
|
|
"hiragana-iroha",
|
|
"horizontal",
|
|
"hsl",
|
|
"hsla",
|
|
"icon",
|
|
"ignore",
|
|
"inactiveborder",
|
|
"inactivecaption",
|
|
"inactivecaptiontext",
|
|
"infinite",
|
|
"infobackground",
|
|
"infotext",
|
|
"inherit",
|
|
"initial",
|
|
"inline",
|
|
"inline-axis",
|
|
"inline-block",
|
|
"inline-flex",
|
|
"inline-table",
|
|
"inset",
|
|
"inside",
|
|
"intrinsic",
|
|
"invert",
|
|
"italic",
|
|
"japanese-formal",
|
|
"japanese-informal",
|
|
"justify",
|
|
"kannada",
|
|
"katakana",
|
|
"katakana-iroha",
|
|
"keep-all",
|
|
"khmer",
|
|
"korean-hangul-formal",
|
|
"korean-hanja-formal",
|
|
"korean-hanja-informal",
|
|
"landscape",
|
|
"lao",
|
|
"large",
|
|
"larger",
|
|
"left",
|
|
"level",
|
|
"lighter",
|
|
"line-through",
|
|
"linear",
|
|
"linear-gradient",
|
|
"lines",
|
|
"list-item",
|
|
"listbox",
|
|
"listitem",
|
|
"local",
|
|
"logical",
|
|
"loud",
|
|
"lower",
|
|
"lower-alpha",
|
|
"lower-armenian",
|
|
"lower-greek",
|
|
"lower-hexadecimal",
|
|
"lower-latin",
|
|
"lower-norwegian",
|
|
"lower-roman",
|
|
"lowercase",
|
|
"ltr",
|
|
"malayalam",
|
|
"match",
|
|
"matrix",
|
|
"matrix3d",
|
|
"media-play-button",
|
|
"media-slider",
|
|
"media-sliderthumb",
|
|
"media-volume-slider",
|
|
"media-volume-sliderthumb",
|
|
"medium",
|
|
"menu",
|
|
"menulist",
|
|
"menulist-button",
|
|
"menutext",
|
|
"message-box",
|
|
"middle",
|
|
"min-intrinsic",
|
|
"mix",
|
|
"mongolian",
|
|
"monospace",
|
|
"move",
|
|
"multiple",
|
|
"myanmar",
|
|
"n-resize",
|
|
"narrower",
|
|
"ne-resize",
|
|
"nesw-resize",
|
|
"no-close-quote",
|
|
"no-drop",
|
|
"no-open-quote",
|
|
"no-repeat",
|
|
"none",
|
|
"normal",
|
|
"not-allowed",
|
|
"nowrap",
|
|
"ns-resize",
|
|
"numbers",
|
|
"numeric",
|
|
"nw-resize",
|
|
"nwse-resize",
|
|
"oblique",
|
|
"octal",
|
|
"open-quote",
|
|
"optimizeLegibility",
|
|
"optimizeSpeed",
|
|
"oriya",
|
|
"oromo",
|
|
"outset",
|
|
"outside",
|
|
"outside-shape",
|
|
"overlay",
|
|
"overline",
|
|
"padding",
|
|
"padding-box",
|
|
"painted",
|
|
"page",
|
|
"paused",
|
|
"persian",
|
|
"perspective",
|
|
"plus-darker",
|
|
"plus-lighter",
|
|
"pointer",
|
|
"polygon",
|
|
"portrait",
|
|
"pre",
|
|
"pre-line",
|
|
"pre-wrap",
|
|
"preserve-3d",
|
|
"progress",
|
|
"push-button",
|
|
"radial-gradient",
|
|
"radio",
|
|
"read-only",
|
|
"read-write",
|
|
"read-write-plaintext-only",
|
|
"rectangle",
|
|
"region",
|
|
"relative",
|
|
"repeat",
|
|
"repeating-linear-gradient",
|
|
"repeating-radial-gradient",
|
|
"repeating-conic-gradient",
|
|
"repeat-x",
|
|
"repeat-y",
|
|
"reset",
|
|
"reverse",
|
|
"rgb",
|
|
"rgba",
|
|
"ridge",
|
|
"right",
|
|
"rotate",
|
|
"rotate3d",
|
|
"rotateX",
|
|
"rotateY",
|
|
"rotateZ",
|
|
"round",
|
|
"row-resize",
|
|
"rtl",
|
|
"run-in",
|
|
"running",
|
|
"s-resize",
|
|
"sans-serif",
|
|
"scale",
|
|
"scale3d",
|
|
"scaleX",
|
|
"scaleY",
|
|
"scaleZ",
|
|
"scroll",
|
|
"scrollbar",
|
|
"scroll-position",
|
|
"se-resize",
|
|
"searchfield",
|
|
"searchfield-cancel-button",
|
|
"searchfield-decoration",
|
|
"searchfield-results-button",
|
|
"searchfield-results-decoration",
|
|
"semi-condensed",
|
|
"semi-expanded",
|
|
"separate",
|
|
"serif",
|
|
"show",
|
|
"sidama",
|
|
"simp-chinese-formal",
|
|
"simp-chinese-informal",
|
|
"single",
|
|
"skew",
|
|
"skewX",
|
|
"skewY",
|
|
"skip-white-space",
|
|
"slide",
|
|
"slider-horizontal",
|
|
"slider-vertical",
|
|
"sliderthumb-horizontal",
|
|
"sliderthumb-vertical",
|
|
"slow",
|
|
"small",
|
|
"small-caps",
|
|
"small-caption",
|
|
"smaller",
|
|
"solid",
|
|
"somali",
|
|
"source-atop",
|
|
"source-in",
|
|
"source-out",
|
|
"source-over",
|
|
"space",
|
|
"spell-out",
|
|
"square",
|
|
"square-button",
|
|
"standard",
|
|
"start",
|
|
"static",
|
|
"status-bar",
|
|
"stretch",
|
|
"stroke",
|
|
"sub",
|
|
"subpixel-antialiased",
|
|
"super",
|
|
"sw-resize",
|
|
"symbolic",
|
|
"symbols",
|
|
"table",
|
|
"table-caption",
|
|
"table-cell",
|
|
"table-column",
|
|
"table-column-group",
|
|
"table-footer-group",
|
|
"table-header-group",
|
|
"table-row",
|
|
"table-row-group",
|
|
"tamil",
|
|
"telugu",
|
|
"text",
|
|
"text-bottom",
|
|
"text-top",
|
|
"textarea",
|
|
"textfield",
|
|
"thai",
|
|
"thick",
|
|
"thin",
|
|
"threeddarkshadow",
|
|
"threedface",
|
|
"threedhighlight",
|
|
"threedlightshadow",
|
|
"threedshadow",
|
|
"tibetan",
|
|
"tigre",
|
|
"tigrinya-er",
|
|
"tigrinya-er-abegede",
|
|
"tigrinya-et",
|
|
"tigrinya-et-abegede",
|
|
"to",
|
|
"top",
|
|
"trad-chinese-formal",
|
|
"trad-chinese-informal",
|
|
"translate",
|
|
"translate3d",
|
|
"translateX",
|
|
"translateY",
|
|
"translateZ",
|
|
"transparent",
|
|
"ultra-condensed",
|
|
"ultra-expanded",
|
|
"underline",
|
|
"up",
|
|
"upper-alpha",
|
|
"upper-armenian",
|
|
"upper-greek",
|
|
"upper-hexadecimal",
|
|
"upper-latin",
|
|
"upper-norwegian",
|
|
"upper-roman",
|
|
"uppercase",
|
|
"urdu",
|
|
"url",
|
|
"var",
|
|
"vertical",
|
|
"vertical-text",
|
|
"visible",
|
|
"visibleFill",
|
|
"visiblePainted",
|
|
"visibleStroke",
|
|
"visual",
|
|
"w-resize",
|
|
"wait",
|
|
"wave",
|
|
"wider",
|
|
"window",
|
|
"windowframe",
|
|
"windowtext",
|
|
"words",
|
|
"x-large",
|
|
"x-small",
|
|
"xor",
|
|
"xx-large",
|
|
"xx-small",
|
|
"bicubic",
|
|
"optimizespeed",
|
|
"grayscale",
|
|
"row",
|
|
"row-reverse",
|
|
"wrap",
|
|
"wrap-reverse",
|
|
"column-reverse",
|
|
"flex-start",
|
|
"flex-end",
|
|
"space-between",
|
|
"space-around",
|
|
"unset"
|
|
];
|
|
var wordOperatorKeywords_ = [
|
|
"in",
|
|
"and",
|
|
"or",
|
|
"not",
|
|
"is not",
|
|
"is a",
|
|
"is",
|
|
"isnt",
|
|
"defined",
|
|
"if unless"
|
|
], blockKeywords_ = [
|
|
"for",
|
|
"if",
|
|
"else",
|
|
"unless",
|
|
"from",
|
|
"to"
|
|
], commonAtoms_ = [
|
|
"null",
|
|
"true",
|
|
"false",
|
|
"href",
|
|
"title",
|
|
"type",
|
|
"not-allowed",
|
|
"readonly",
|
|
"disabled"
|
|
], commonDef_ = [
|
|
"@font-face",
|
|
"@keyframes",
|
|
"@media",
|
|
"@viewport",
|
|
"@page",
|
|
"@host",
|
|
"@supports",
|
|
"@block",
|
|
"@css"
|
|
];
|
|
var hintWords = tagKeywords_.concat(documentTypes_, mediaTypes_, mediaFeatures_, propertyKeywords_, nonStandardPropertyKeywords_, colorKeywords_, valueKeywords_, fontProperties_, wordOperatorKeywords_, blockKeywords_, commonAtoms_, commonDef_);
|
|
function wordRegexp(words) {
|
|
words = words.sort(function(a, b) {
|
|
return b > a;
|
|
});
|
|
return new RegExp("^((" + words.join(")|(") + "))\\b");
|
|
}
|
|
function keySet(array) {
|
|
var keys = {};
|
|
for (var i = 0; i < array.length; ++i) keys[array[i]] = true;
|
|
return keys;
|
|
}
|
|
function escapeRegExp(text) {
|
|
return text.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&");
|
|
}
|
|
CodeMirror$1.registerHelper("hintWords", "stylus", hintWords);
|
|
CodeMirror$1.defineMIME("text/x-styl", "stylus");
|
|
});
|
|
});
|
|
var require_vue = __commonJSMin((exports, module) => {
|
|
(function(mod) {
|
|
"use strict";
|
|
if (typeof exports === "object" && typeof module === "object") mod(require_codemirror(), require_overlay(), require_xml(), require_javascript(), require_coffeescript(), require_css(), require_sass(), require_stylus(), require_pug(), require_handlebars());
|
|
else if (typeof define === "function" && define.amd) define([
|
|
"../../lib/codemirror",
|
|
"../../addon/mode/overlay",
|
|
"../xml/xml",
|
|
"../javascript/javascript",
|
|
"../coffeescript/coffeescript",
|
|
"../css/css",
|
|
"../sass/sass",
|
|
"../stylus/stylus",
|
|
"../pug/pug",
|
|
"../handlebars/handlebars"
|
|
], mod);
|
|
else mod(CodeMirror);
|
|
})(function(CodeMirror$1) {
|
|
var tagLanguages = {
|
|
script: [
|
|
[
|
|
"lang",
|
|
/coffee(script)?/,
|
|
"coffeescript"
|
|
],
|
|
[
|
|
"type",
|
|
/^(?:text|application)\/(?:x-)?coffee(?:script)?$/,
|
|
"coffeescript"
|
|
],
|
|
[
|
|
"lang",
|
|
/^babel$/,
|
|
"javascript"
|
|
],
|
|
[
|
|
"type",
|
|
/^text\/babel$/,
|
|
"javascript"
|
|
],
|
|
[
|
|
"type",
|
|
/^text\/ecmascript-\d+$/,
|
|
"javascript"
|
|
]
|
|
],
|
|
style: [
|
|
[
|
|
"lang",
|
|
/^stylus$/i,
|
|
"stylus"
|
|
],
|
|
[
|
|
"lang",
|
|
/^sass$/i,
|
|
"sass"
|
|
],
|
|
[
|
|
"lang",
|
|
/^less$/i,
|
|
"text/x-less"
|
|
],
|
|
[
|
|
"lang",
|
|
/^scss$/i,
|
|
"text/x-scss"
|
|
],
|
|
[
|
|
"type",
|
|
/^(text\/)?(x-)?styl(us)?$/i,
|
|
"stylus"
|
|
],
|
|
[
|
|
"type",
|
|
/^text\/sass/i,
|
|
"sass"
|
|
],
|
|
[
|
|
"type",
|
|
/^(text\/)?(x-)?scss$/i,
|
|
"text/x-scss"
|
|
],
|
|
[
|
|
"type",
|
|
/^(text\/)?(x-)?less$/i,
|
|
"text/x-less"
|
|
]
|
|
],
|
|
template: [
|
|
[
|
|
"lang",
|
|
/^vue-template$/i,
|
|
"vue"
|
|
],
|
|
[
|
|
"lang",
|
|
/^pug$/i,
|
|
"pug"
|
|
],
|
|
[
|
|
"lang",
|
|
/^handlebars$/i,
|
|
"handlebars"
|
|
],
|
|
[
|
|
"type",
|
|
/^(text\/)?(x-)?pug$/i,
|
|
"pug"
|
|
],
|
|
[
|
|
"type",
|
|
/^text\/x-handlebars-template$/i,
|
|
"handlebars"
|
|
],
|
|
[
|
|
null,
|
|
null,
|
|
"vue-template"
|
|
]
|
|
]
|
|
};
|
|
CodeMirror$1.defineMode("vue-template", function(config, parserConfig) {
|
|
var mustacheOverlay = { token: function(stream) {
|
|
if (stream.match(/^\{\{.*?\}\}/)) return "meta mustache";
|
|
while (stream.next() && !stream.match("{{", false));
|
|
return null;
|
|
} };
|
|
return CodeMirror$1.overlayMode(CodeMirror$1.getMode(config, parserConfig.backdrop || "text/html"), mustacheOverlay);
|
|
});
|
|
CodeMirror$1.defineMode("vue", function(config) {
|
|
return CodeMirror$1.getMode(config, {
|
|
name: "htmlmixed",
|
|
tags: tagLanguages
|
|
});
|
|
}, "htmlmixed", "xml", "javascript", "coffeescript", "css", "sass", "stylus", "pug", "handlebars");
|
|
CodeMirror$1.defineMIME("script/x-vue", "vue");
|
|
CodeMirror$1.defineMIME("text/x-vue", "vue");
|
|
});
|
|
});
|
|
function useCodeMirror(container, input, options = {}) {
|
|
const cm = (0, import_codemirror.default)(container.value, {
|
|
theme: "vars",
|
|
value: input.value,
|
|
...options
|
|
});
|
|
let skip = false;
|
|
cm.on("change", () => {
|
|
if (skip) {
|
|
skip = false;
|
|
return;
|
|
}
|
|
input.value = cm.getValue();
|
|
});
|
|
watch(input, (v) => {
|
|
if (v !== cm.getValue()) {
|
|
skip = true;
|
|
const selections = cm.listSelections();
|
|
cm.replaceRange(v, cm.posFromIndex(0), cm.posFromIndex(Number.POSITIVE_INFINITY));
|
|
cm.setSelections(selections);
|
|
cm.scrollTo(0, 0);
|
|
}
|
|
}, { immediate: true });
|
|
return cm;
|
|
}
|
|
function syncEditorScrolls(primary, target) {
|
|
const pInfo = primary.getScrollInfo();
|
|
const tInfo = target.getScrollInfo();
|
|
let x = (tInfo.width - tInfo.clientWidth) / (pInfo.width - pInfo.clientWidth) * pInfo.left;
|
|
let y = (tInfo.height - tInfo.clientHeight) / (pInfo.height - pInfo.clientHeight) * pInfo.top;
|
|
x = Number.isNaN(x) ? 0 : x;
|
|
y = Number.isNaN(y) ? 0 : y;
|
|
target.scrollTo(x, y);
|
|
}
|
|
function syncScrollListeners(cm1, cm2) {
|
|
let activeCm = 1;
|
|
cm1.getWrapperElement().addEventListener("mouseenter", () => {
|
|
activeCm = 1;
|
|
});
|
|
cm2.getWrapperElement().addEventListener("mouseenter", () => {
|
|
activeCm = 2;
|
|
});
|
|
cm1.on("scroll", (editor) => {
|
|
if (activeCm === 1) syncEditorScrolls(editor, cm2);
|
|
});
|
|
cm1.on("scrollCursorIntoView", (editor) => syncEditorScrolls(editor, cm2));
|
|
cm2.on("scroll", (editor) => {
|
|
if (activeCm === 2) syncEditorScrolls(editor, cm1);
|
|
});
|
|
cm2.on("scrollCursorIntoView", (editor) => syncEditorScrolls(editor, cm1));
|
|
}
|
|
/**
|
|
* @license
|
|
* Copyright 2019 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
const proxyMarker = Symbol("Comlink.proxy");
|
|
const createEndpoint = Symbol("Comlink.endpoint");
|
|
const releaseProxy = Symbol("Comlink.releaseProxy");
|
|
const finalizer = Symbol("Comlink.finalizer");
|
|
const throwMarker = Symbol("Comlink.thrown");
|
|
const isObject = (val) => typeof val === "object" && val !== null || typeof val === "function";
|
|
/**
|
|
* Internal transfer handle to handle objects marked to proxy.
|
|
*/
|
|
const proxyTransferHandler = {
|
|
canHandle: (val) => isObject(val) && val[proxyMarker],
|
|
serialize(obj) {
|
|
const { port1, port2 } = new MessageChannel();
|
|
expose(obj, port1);
|
|
return [port2, [port2]];
|
|
},
|
|
deserialize(port) {
|
|
port.start();
|
|
return wrap(port);
|
|
}
|
|
};
|
|
/**
|
|
* Internal transfer handler to handle thrown exceptions.
|
|
*/
|
|
const throwTransferHandler = {
|
|
canHandle: (value) => isObject(value) && throwMarker in value,
|
|
serialize({ value }) {
|
|
let serialized;
|
|
if (value instanceof Error) serialized = {
|
|
isError: true,
|
|
value: {
|
|
message: value.message,
|
|
name: value.name,
|
|
stack: value.stack
|
|
}
|
|
};
|
|
else serialized = {
|
|
isError: false,
|
|
value
|
|
};
|
|
return [serialized, []];
|
|
},
|
|
deserialize(serialized) {
|
|
if (serialized.isError) throw Object.assign(new Error(serialized.value.message), serialized.value);
|
|
throw serialized.value;
|
|
}
|
|
};
|
|
/**
|
|
* Allows customizing the serialization of certain values.
|
|
*/
|
|
const transferHandlers = new Map([["proxy", proxyTransferHandler], ["throw", throwTransferHandler]]);
|
|
function isAllowedOrigin(allowedOrigins, origin) {
|
|
for (const allowedOrigin of allowedOrigins) {
|
|
if (origin === allowedOrigin || allowedOrigin === "*") return true;
|
|
if (allowedOrigin instanceof RegExp && allowedOrigin.test(origin)) return true;
|
|
}
|
|
return false;
|
|
}
|
|
function expose(obj, ep = globalThis, allowedOrigins = ["*"]) {
|
|
ep.addEventListener("message", function callback(ev) {
|
|
if (!ev || !ev.data) return;
|
|
if (!isAllowedOrigin(allowedOrigins, ev.origin)) {
|
|
console.warn(`Invalid origin '${ev.origin}' for comlink proxy`);
|
|
return;
|
|
}
|
|
const { id, type, path } = Object.assign({ path: [] }, ev.data);
|
|
const argumentList = (ev.data.argumentList || []).map(fromWireValue);
|
|
let returnValue;
|
|
try {
|
|
const parent = path.slice(0, -1).reduce((obj$1, prop) => obj$1[prop], obj);
|
|
const rawValue = path.reduce((obj$1, prop) => obj$1[prop], obj);
|
|
switch (type) {
|
|
case "GET":
|
|
returnValue = rawValue;
|
|
break;
|
|
case "SET":
|
|
{
|
|
parent[path.slice(-1)[0]] = fromWireValue(ev.data.value);
|
|
returnValue = true;
|
|
}
|
|
break;
|
|
case "APPLY":
|
|
returnValue = rawValue.apply(parent, argumentList);
|
|
break;
|
|
case "CONSTRUCT":
|
|
{
|
|
const value = new rawValue(...argumentList);
|
|
returnValue = proxy(value);
|
|
}
|
|
break;
|
|
case "ENDPOINT":
|
|
{
|
|
const { port1, port2 } = new MessageChannel();
|
|
expose(obj, port2);
|
|
returnValue = transfer(port1, [port1]);
|
|
}
|
|
break;
|
|
case "RELEASE":
|
|
returnValue = void 0;
|
|
break;
|
|
default: return;
|
|
}
|
|
} catch (value) {
|
|
returnValue = {
|
|
value,
|
|
[throwMarker]: 0
|
|
};
|
|
}
|
|
Promise.resolve(returnValue).catch((value) => {
|
|
return {
|
|
value,
|
|
[throwMarker]: 0
|
|
};
|
|
}).then((returnValue$1) => {
|
|
const [wireValue, transferables] = toWireValue(returnValue$1);
|
|
ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);
|
|
if (type === "RELEASE") {
|
|
ep.removeEventListener("message", callback);
|
|
closeEndPoint(ep);
|
|
if (finalizer in obj && typeof obj[finalizer] === "function") obj[finalizer]();
|
|
}
|
|
}).catch((error) => {
|
|
const [wireValue, transferables] = toWireValue({
|
|
value: new TypeError("Unserializable return value"),
|
|
[throwMarker]: 0
|
|
});
|
|
ep.postMessage(Object.assign(Object.assign({}, wireValue), { id }), transferables);
|
|
});
|
|
});
|
|
if (ep.start) ep.start();
|
|
}
|
|
function isMessagePort(endpoint) {
|
|
return endpoint.constructor.name === "MessagePort";
|
|
}
|
|
function closeEndPoint(endpoint) {
|
|
if (isMessagePort(endpoint)) endpoint.close();
|
|
}
|
|
function wrap(ep, target) {
|
|
const pendingListeners = new Map();
|
|
ep.addEventListener("message", function handleMessage(ev) {
|
|
const { data } = ev;
|
|
if (!data || !data.id) return;
|
|
const resolver = pendingListeners.get(data.id);
|
|
if (!resolver) return;
|
|
try {
|
|
resolver(data);
|
|
} finally {
|
|
pendingListeners.delete(data.id);
|
|
}
|
|
});
|
|
return createProxy(ep, pendingListeners, [], target);
|
|
}
|
|
function throwIfProxyReleased(isReleased) {
|
|
if (isReleased) throw new Error("Proxy has been released and is not useable");
|
|
}
|
|
function releaseEndpoint(ep) {
|
|
return requestResponseMessage(ep, new Map(), { type: "RELEASE" }).then(() => {
|
|
closeEndPoint(ep);
|
|
});
|
|
}
|
|
const proxyCounter = new WeakMap();
|
|
const proxyFinalizers = "FinalizationRegistry" in globalThis && new FinalizationRegistry((ep) => {
|
|
const newCount = (proxyCounter.get(ep) || 0) - 1;
|
|
proxyCounter.set(ep, newCount);
|
|
if (newCount === 0) releaseEndpoint(ep);
|
|
});
|
|
function registerProxy(proxy$1, ep) {
|
|
const newCount = (proxyCounter.get(ep) || 0) + 1;
|
|
proxyCounter.set(ep, newCount);
|
|
if (proxyFinalizers) proxyFinalizers.register(proxy$1, ep, proxy$1);
|
|
}
|
|
function unregisterProxy(proxy$1) {
|
|
if (proxyFinalizers) proxyFinalizers.unregister(proxy$1);
|
|
}
|
|
function createProxy(ep, pendingListeners, path = [], target = function() {}) {
|
|
let isProxyReleased = false;
|
|
const proxy$1 = new Proxy(target, {
|
|
get(_target, prop) {
|
|
throwIfProxyReleased(isProxyReleased);
|
|
if (prop === releaseProxy) return () => {
|
|
unregisterProxy(proxy$1);
|
|
releaseEndpoint(ep);
|
|
pendingListeners.clear();
|
|
isProxyReleased = true;
|
|
};
|
|
if (prop === "then") {
|
|
if (path.length === 0) return { then: () => proxy$1 };
|
|
const r = requestResponseMessage(ep, pendingListeners, {
|
|
type: "GET",
|
|
path: path.map((p) => p.toString())
|
|
}).then(fromWireValue);
|
|
return r.then.bind(r);
|
|
}
|
|
return createProxy(ep, pendingListeners, [...path, prop]);
|
|
},
|
|
set(_target, prop, rawValue) {
|
|
throwIfProxyReleased(isProxyReleased);
|
|
const [value, transferables] = toWireValue(rawValue);
|
|
return requestResponseMessage(ep, pendingListeners, {
|
|
type: "SET",
|
|
path: [...path, prop].map((p) => p.toString()),
|
|
value
|
|
}, transferables).then(fromWireValue);
|
|
},
|
|
apply(_target, _thisArg, rawArgumentList) {
|
|
throwIfProxyReleased(isProxyReleased);
|
|
const last = path[path.length - 1];
|
|
if (last === createEndpoint) return requestResponseMessage(ep, pendingListeners, { type: "ENDPOINT" }).then(fromWireValue);
|
|
if (last === "bind") return createProxy(ep, pendingListeners, path.slice(0, -1));
|
|
const [argumentList, transferables] = processArguments(rawArgumentList);
|
|
return requestResponseMessage(ep, pendingListeners, {
|
|
type: "APPLY",
|
|
path: path.map((p) => p.toString()),
|
|
argumentList
|
|
}, transferables).then(fromWireValue);
|
|
},
|
|
construct(_target, rawArgumentList) {
|
|
throwIfProxyReleased(isProxyReleased);
|
|
const [argumentList, transferables] = processArguments(rawArgumentList);
|
|
return requestResponseMessage(ep, pendingListeners, {
|
|
type: "CONSTRUCT",
|
|
path: path.map((p) => p.toString()),
|
|
argumentList
|
|
}, transferables).then(fromWireValue);
|
|
}
|
|
});
|
|
registerProxy(proxy$1, ep);
|
|
return proxy$1;
|
|
}
|
|
function myFlat(arr) {
|
|
return Array.prototype.concat.apply([], arr);
|
|
}
|
|
function processArguments(argumentList) {
|
|
const processed = argumentList.map(toWireValue);
|
|
return [processed.map((v) => v[0]), myFlat(processed.map((v) => v[1]))];
|
|
}
|
|
const transferCache = new WeakMap();
|
|
function transfer(obj, transfers) {
|
|
transferCache.set(obj, transfers);
|
|
return obj;
|
|
}
|
|
function proxy(obj) {
|
|
return Object.assign(obj, { [proxyMarker]: true });
|
|
}
|
|
function toWireValue(value) {
|
|
for (const [name, handler] of transferHandlers) if (handler.canHandle(value)) {
|
|
const [serializedValue, transferables] = handler.serialize(value);
|
|
return [{
|
|
type: "HANDLER",
|
|
name,
|
|
value: serializedValue
|
|
}, transferables];
|
|
}
|
|
return [{
|
|
type: "RAW",
|
|
value
|
|
}, transferCache.get(value) || []];
|
|
}
|
|
function fromWireValue(value) {
|
|
switch (value.type) {
|
|
case "HANDLER": return transferHandlers.get(value.name).deserialize(value.value);
|
|
case "RAW": return value.value;
|
|
}
|
|
}
|
|
function requestResponseMessage(ep, pendingListeners, msg, transfers) {
|
|
return new Promise((resolve) => {
|
|
const id = generateUUID();
|
|
pendingListeners.set(id, resolve);
|
|
if (ep.start) ep.start();
|
|
ep.postMessage(Object.assign({ id }, msg), transfers);
|
|
});
|
|
}
|
|
function generateUUID() {
|
|
return new Array(4).fill(0).map(() => Math.floor(Math.random() * Number.MAX_SAFE_INTEGER).toString(16)).join("-");
|
|
}
|
|
let diffWorker;
|
|
async function calculateDiffWithWorker(left, right) {
|
|
if (!diffWorker) diffWorker = wrap(new Worker(new URL(
|
|
/* @vite-ignore */
|
|
"" + new URL("diff.worker-CMaeQEBs.js", import.meta.url).href,
|
|
"" + import.meta.url
|
|
), { type: "module" }));
|
|
const result = await diffWorker.calculateDiff(left, right);
|
|
return result;
|
|
}
|
|
var DiffEditor_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
__name: "DiffEditor",
|
|
props: {
|
|
from: {},
|
|
to: {},
|
|
oneColumn: { type: Boolean },
|
|
diff: { type: Boolean }
|
|
},
|
|
setup(__props) {
|
|
const props = __props;
|
|
const options = useOptionsStore();
|
|
const { from, to } = toRefs(props);
|
|
const fromEl = useTemplateRef("fromEl");
|
|
const toEl = useTemplateRef("toEl");
|
|
let cm1;
|
|
let cm2;
|
|
onMounted(() => {
|
|
cm1 = useCodeMirror(fromEl, from, {
|
|
mode: "javascript",
|
|
readOnly: true,
|
|
lineNumbers: true
|
|
});
|
|
cm2 = useCodeMirror(toEl, to, {
|
|
mode: "javascript",
|
|
readOnly: true,
|
|
lineNumbers: true
|
|
});
|
|
syncScrollListeners(cm1, cm2);
|
|
watchEffect(() => {
|
|
cm1.setOption("lineWrapping", options.view.lineWrapping);
|
|
cm2.setOption("lineWrapping", options.view.lineWrapping);
|
|
});
|
|
watchEffect(async () => {
|
|
cm1.getWrapperElement().style.display = props.oneColumn ? "none" : "";
|
|
if (!props.oneColumn) {
|
|
await nextTick();
|
|
cm1.refresh();
|
|
syncEditorScrolls(cm2, cm1);
|
|
}
|
|
});
|
|
watchEffect(async () => {
|
|
const l = from.value;
|
|
const r = to.value;
|
|
const diffEnabled = props.diff;
|
|
cm1.setOption("mode", guessMode(l));
|
|
cm2.setOption("mode", guessMode(r));
|
|
await nextTick();
|
|
cm1.startOperation();
|
|
cm2.startOperation();
|
|
cm1.getAllMarks().forEach((i) => i.clear());
|
|
cm2.getAllMarks().forEach((i) => i.clear());
|
|
for (let i = 0; i < cm1.lineCount() + 2; i++) cm1.removeLineClass(i, "background", "diff-removed");
|
|
for (let i = 0; i < cm2.lineCount() + 2; i++) cm2.removeLineClass(i, "background", "diff-added");
|
|
if (diffEnabled && from.value) {
|
|
const changes = await calculateDiffWithWorker(l, r);
|
|
const addedLines = new Set();
|
|
const removedLines = new Set();
|
|
let indexL = 0;
|
|
let indexR = 0;
|
|
changes.forEach(([type, change]) => {
|
|
if (type === 1) {
|
|
const start = cm2.posFromIndex(indexR);
|
|
indexR += change.length;
|
|
const end = cm2.posFromIndex(indexR);
|
|
cm2.markText(start, end, { className: "diff-added-inline" });
|
|
for (let i = start.line; i <= end.line; i++) addedLines.add(i);
|
|
} else if (type === -1) {
|
|
const start = cm1.posFromIndex(indexL);
|
|
indexL += change.length;
|
|
const end = cm1.posFromIndex(indexL);
|
|
cm1.markText(start, end, { className: "diff-removed-inline" });
|
|
for (let i = start.line; i <= end.line; i++) removedLines.add(i);
|
|
} else {
|
|
indexL += change.length;
|
|
indexR += change.length;
|
|
}
|
|
});
|
|
Array.from(removedLines).forEach((i) => cm1.addLineClass(i, "background", "diff-removed"));
|
|
Array.from(addedLines).forEach((i) => cm2.addLineClass(i, "background", "diff-added"));
|
|
}
|
|
cm1.endOperation();
|
|
cm2.endOperation();
|
|
});
|
|
});
|
|
const leftPanelSize = computed(() => {
|
|
return props.oneColumn ? 0 : options.view.panelSizeDiff;
|
|
});
|
|
function onUpdate(size) {
|
|
cm1?.refresh();
|
|
cm2?.refresh();
|
|
if (props.oneColumn) return;
|
|
options.view.panelSizeDiff = size;
|
|
}
|
|
return (_ctx, _cache) => {
|
|
return openBlock(), createBlock(unref(Pe), { onResize: _cache[0] || (_cache[0] = ($event) => onUpdate($event.prevPane.size)) }, {
|
|
default: withCtx(() => [withDirectives(createVNode(unref(ge), {
|
|
"min-size": "10",
|
|
size: unref(leftPanelSize)
|
|
}, {
|
|
default: withCtx(() => [createBaseVNode("div", {
|
|
ref_key: "fromEl",
|
|
ref: fromEl,
|
|
class: "h-inherit"
|
|
}, null, 512)]),
|
|
_: 1
|
|
}, 8, ["size"]), [[vShow, !_ctx.oneColumn]]), createVNode(unref(ge), {
|
|
"min-size": "10",
|
|
size: 100 - unref(leftPanelSize)
|
|
}, {
|
|
default: withCtx(() => [createBaseVNode("div", {
|
|
ref_key: "toEl",
|
|
ref: toEl,
|
|
class: "h-inherit"
|
|
}, null, 512)]),
|
|
_: 1
|
|
}, 8, ["size"])]),
|
|
_: 1
|
|
});
|
|
};
|
|
}
|
|
});
|
|
var DiffEditor_default = DiffEditor_vue_vue_type_script_setup_true_lang_default;
|
|
const _hoisted_1$2 = {
|
|
"fw-600": "",
|
|
"dark:fw-unset": ""
|
|
};
|
|
const _hoisted_2$2 = {
|
|
op72: "",
|
|
"dark:op50": ""
|
|
};
|
|
const _hoisted_3$2 = {
|
|
key: 0,
|
|
op72: "",
|
|
"dark:op50": ""
|
|
};
|
|
var FilepathItem_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
__name: "FilepathItem",
|
|
props: {
|
|
filepath: {},
|
|
line: {},
|
|
column: {}
|
|
},
|
|
setup(__props) {
|
|
const props = __props;
|
|
async function openInEditor() {
|
|
await fetch(`/__open-in-editor?file=${encodeURI(props.filepath)}:${props.line}:${props.column}`);
|
|
}
|
|
const display = computed(() => {
|
|
const path = props.filepath.replace(/\\/g, "/");
|
|
if (props.filepath.includes("/node_modules/")) {
|
|
const match = path.match(/.*\/node_modules\/(@[^/]+\/[^/]+|[^/]+)(\/.*)?$/);
|
|
if (match) return [match[1], match[2]];
|
|
}
|
|
return [path];
|
|
});
|
|
return (_ctx, _cache) => {
|
|
return openBlock(), createElementBlock("button", {
|
|
flex: "~",
|
|
hover: "underline",
|
|
onClick: openInEditor
|
|
}, [
|
|
createBaseVNode("span", _hoisted_1$2, toDisplayString(unref(display)[0]), 1),
|
|
createBaseVNode("span", _hoisted_2$2, toDisplayString(unref(display)[1]), 1),
|
|
props.line != null && props.column != null ? (openBlock(), createElementBlock("span", _hoisted_3$2, ":" + toDisplayString(props.line) + ":" + toDisplayString(props.column), 1)) : createCommentVNode("", true)
|
|
]);
|
|
};
|
|
}
|
|
});
|
|
var FilepathItem_default = FilepathItem_vue_vue_type_script_setup_true_lang_default;
|
|
const _hoisted_1$1 = {
|
|
"of-auto": "",
|
|
p4: "",
|
|
"font-mono": "",
|
|
flex: "~ col gap-4"
|
|
};
|
|
const _hoisted_2$1 = {
|
|
"text-sm": "",
|
|
"status-red": ""
|
|
};
|
|
const _hoisted_3$1 = {
|
|
class: "text-xs",
|
|
mt2: "",
|
|
grid: "~ cols-[max-content_1fr] gap-x-4 gap-y-1",
|
|
"font-mono": ""
|
|
};
|
|
const _hoisted_4$1 = {
|
|
"text-right": "",
|
|
op72: "",
|
|
"dark:op50": ""
|
|
};
|
|
const _hoisted_5$1 = { "ws-nowrap": "" };
|
|
var ErrorDisplay_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
__name: "ErrorDisplay",
|
|
props: { error: {} },
|
|
setup(__props) {
|
|
function normalizeFilename(filename) {
|
|
return (filename || "").replace(/^async\s+/, "").replace(/^file:\/\//, "");
|
|
}
|
|
return (_ctx, _cache) => {
|
|
const _component_FilepathItem = FilepathItem_default;
|
|
return openBlock(), createElementBlock("div", _hoisted_1$1, [
|
|
_cache[0] || (_cache[0] = createBaseVNode("div", {
|
|
"text-xl": "",
|
|
"status-red": "",
|
|
flex: "~ gap-2 items-center"
|
|
}, [createBaseVNode("div", { "i-carbon:warning-square": "" }), createTextVNode(" Error ")], -1)),
|
|
createBaseVNode("pre", _hoisted_2$1, toDisplayString(_ctx.error.message), 1),
|
|
_cache[1] || (_cache[1] = createBaseVNode("div", {
|
|
border: "t main",
|
|
"h-1px": "",
|
|
"w-full": ""
|
|
}, null, -1)),
|
|
createBaseVNode("div", _hoisted_3$1, [(openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.error.stack, (item, idx) => {
|
|
return openBlock(), createElementBlock(Fragment, { key: idx }, [createBaseVNode("div", _hoisted_4$1, toDisplayString(item.functionName || `(anonymous)`), 1), createBaseVNode("div", _hoisted_5$1, [createVNode(_component_FilepathItem, {
|
|
filepath: normalizeFilename(item.fileName),
|
|
line: item.lineNumber,
|
|
column: item.columnNumber
|
|
}, null, 8, [
|
|
"filepath",
|
|
"line",
|
|
"column"
|
|
])])], 64);
|
|
}), 128))])
|
|
]);
|
|
};
|
|
}
|
|
});
|
|
var ErrorDisplay_default = ErrorDisplay_vue_vue_type_script_setup_true_lang_default;
|
|
const _queue = /* @__PURE__ */ new WeakMap();
|
|
function useRouteQuery(name, defaultValue, options = {}) {
|
|
const { mode = "replace", route = useRoute(), router = useRouter(), transform } = options;
|
|
let transformGet = (value) => value;
|
|
let transformSet = (value) => value;
|
|
if (typeof transform === "function") transformGet = transform;
|
|
else if (transform) {
|
|
if (transform.get) transformGet = transform.get;
|
|
if (transform.set) transformSet = transform.set;
|
|
}
|
|
if (!_queue.has(router)) _queue.set(router, /* @__PURE__ */ new Map());
|
|
const _queriesQueue = _queue.get(router);
|
|
let query = route.query[name];
|
|
tryOnScopeDispose(() => {
|
|
query = void 0;
|
|
});
|
|
let _trigger;
|
|
const proxy$1 = customRef((track, trigger) => {
|
|
_trigger = trigger;
|
|
return {
|
|
get() {
|
|
track();
|
|
return transformGet(query !== void 0 ? query : toValue(defaultValue));
|
|
},
|
|
set(v) {
|
|
v = transformSet(v);
|
|
if (query === v) return;
|
|
query = v === toValue(defaultValue) ? void 0 : v;
|
|
_queriesQueue.set(name, v === toValue(defaultValue) ? void 0 : v);
|
|
trigger();
|
|
nextTick(() => {
|
|
if (_queriesQueue.size === 0) return;
|
|
const newQueries = Object.fromEntries(_queriesQueue.entries());
|
|
_queriesQueue.clear();
|
|
const { params, query: query2, hash } = route;
|
|
router[toValue(mode)]({
|
|
params,
|
|
query: {
|
|
...query2,
|
|
...newQueries
|
|
},
|
|
hash
|
|
});
|
|
});
|
|
}
|
|
};
|
|
});
|
|
watch(() => route.query[name], (v) => {
|
|
if (query === transformGet(v)) return;
|
|
query = v;
|
|
_trigger();
|
|
}, { flush: "sync" });
|
|
return proxy$1;
|
|
}
|
|
const _hoisted_1 = {
|
|
title: "Dependencies",
|
|
flex: "~ gap-2 items-center",
|
|
"icon-btn": "",
|
|
"text-lg": ""
|
|
};
|
|
const _hoisted_2 = { "line-height-1em": "" };
|
|
const _hoisted_3 = {
|
|
"max-h-400": "",
|
|
"max-w-200": "",
|
|
"of-auto": ""
|
|
};
|
|
const _hoisted_4 = {
|
|
title: "Importers",
|
|
flex: "~ gap-2 items-center",
|
|
"icon-btn": "",
|
|
"text-lg": ""
|
|
};
|
|
const _hoisted_5 = { "line-height-1em": "" };
|
|
const _hoisted_6 = {
|
|
"max-h-400": "",
|
|
"max-w-200": "",
|
|
"of-auto": ""
|
|
};
|
|
const _hoisted_7 = ["title", "disabled"];
|
|
const _hoisted_8 = {
|
|
key: 0,
|
|
"i-carbon-side-panel-open": ""
|
|
};
|
|
const _hoisted_9 = {
|
|
key: 1,
|
|
"i-carbon-side-panel-close": ""
|
|
};
|
|
const _hoisted_10 = {
|
|
key: 0,
|
|
flex: "~ col gap-2 items-center justify-center",
|
|
"h-full": ""
|
|
};
|
|
const _hoisted_11 = {
|
|
flex: "~ gap2 items-center",
|
|
p2: "",
|
|
"tracking-widest": "",
|
|
class: "op75 dark:op50"
|
|
};
|
|
const _hoisted_12 = {
|
|
"flex-auto": "",
|
|
"text-center": "",
|
|
"text-sm": "",
|
|
uppercase: ""
|
|
};
|
|
const _hoisted_13 = ["onClick"];
|
|
const _hoisted_14 = {
|
|
"h-full": "",
|
|
"of-auto": ""
|
|
};
|
|
var module_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
__name: "module",
|
|
async setup(__props) {
|
|
let __temp, __restore;
|
|
function getModuleId(fullPath) {
|
|
if (!fullPath) return void 0;
|
|
return new URL(fullPath, "http://localhost").searchParams.get("id") || void 0;
|
|
}
|
|
const options = useOptionsStore();
|
|
const payload = usePayloadStore();
|
|
const route = useRoute();
|
|
const id = computed(() => getModuleId(route.fullPath));
|
|
const info = ref(id.value ? ([__temp, __restore] = withAsyncContext(() => rpc.getModuleTransformInfo(payload.query, id.value)), __temp = await __temp, __restore(), __temp) : void 0);
|
|
const mod = computed(() => payload.modules.find((m) => m.id === id.value));
|
|
const index = useRouteQuery("index");
|
|
const currentIndex = computed(() => (index.value != null ? +index.value : null) ?? (info.value?.transforms.length || 1) - 1);
|
|
const deps = computed(() => {
|
|
return mod.value?.deps.map((dep) => payload.modules.find((m) => m.id === dep)).filter(Boolean);
|
|
});
|
|
const importers = computed(() => {
|
|
return mod.value?.importers.map((dep) => payload.modules.find((m) => m.id === dep)).filter(Boolean);
|
|
});
|
|
const transforms = computed(() => {
|
|
const trs = info.value?.transforms;
|
|
if (!trs) return void 0;
|
|
let load = false;
|
|
return trs.map((tr, index$1) => ({
|
|
...tr,
|
|
noChange: !!tr.result && index$1 > 0 && tr.result === trs[index$1 - 1]?.result,
|
|
load: tr.result && (load ? false : load = true),
|
|
index: index$1
|
|
}));
|
|
});
|
|
const filteredTransforms = computed(() => transforms.value?.filter((tr) => options.view.showBailout || tr.result));
|
|
async function refetch(clear = false) {
|
|
if (id.value) info.value = await rpc.getModuleTransformInfo(payload.query, id.value, clear);
|
|
}
|
|
onModuleUpdated.on(async () => {
|
|
await refetch(false);
|
|
});
|
|
watch(() => [id.value, payload.query], () => refetch(false), { deep: true });
|
|
const lastTransform = computed(() => transforms.value?.slice(0, currentIndex.value).reverse().find((tr) => tr.result));
|
|
const currentTransform = computed(() => transforms.value?.find((tr) => tr.index === currentIndex.value));
|
|
const from = computed(() => lastTransform.value?.result || "");
|
|
const to = computed(() => currentTransform.value?.result || from.value);
|
|
const sourcemaps = computed(() => {
|
|
let sourcemaps$1 = currentTransform.value?.sourcemaps;
|
|
if (!sourcemaps$1) return void 0;
|
|
if (typeof sourcemaps$1 === "string") sourcemaps$1 = safeJsonParse(sourcemaps$1);
|
|
if (!sourcemaps$1?.mappings) return;
|
|
if (sourcemaps$1 && !sourcemaps$1.sourcesContent?.filter(Boolean)?.length) sourcemaps$1.sourcesContent = [from.value];
|
|
if (sourcemaps$1 && !sourcemaps$1.sources?.filter(Boolean)?.length) sourcemaps$1.sources = ["index.js"];
|
|
return JSON.stringify(sourcemaps$1);
|
|
});
|
|
getHot().then((hot) => {
|
|
if (hot) hot.on("vite-plugin-inspect:update", ({ ids }) => {
|
|
if (id.value && ids.includes(id.value)) refetch();
|
|
});
|
|
});
|
|
return (_ctx, _cache) => {
|
|
const _component_RouterLink = resolveComponent("RouterLink");
|
|
const _component_ModuleId = ModuleId_default;
|
|
const _component_QuerySelector = QuerySelector_default;
|
|
const _component_ModuleList = ModuleList_default;
|
|
const _component_NavBar = NavBar_default;
|
|
const _component_Badge = Badge_default;
|
|
const _component_PluginName = PluginName_default;
|
|
const _component_DurationDisplay = DurationDisplay_default;
|
|
const _component_ErrorDisplay = ErrorDisplay_default;
|
|
const _component_DiffEditor = DiffEditor_default;
|
|
const _component_Container = Container_default;
|
|
return openBlock(), createElementBlock(Fragment, null, [createVNode(_component_NavBar, null, {
|
|
default: withCtx(() => [
|
|
createVNode(_component_RouterLink, {
|
|
"my-auto": "",
|
|
"icon-btn": "",
|
|
"outline-none": "",
|
|
to: "/"
|
|
}, {
|
|
default: withCtx(() => [..._cache[8] || (_cache[8] = [createBaseVNode("div", { "i-carbon-arrow-left": "" }, null, -1)])]),
|
|
_: 1
|
|
}),
|
|
unref(id) ? (openBlock(), createBlock(_component_ModuleId, {
|
|
key: 0,
|
|
id: unref(id)
|
|
}, null, 8, ["id"])) : createCommentVNode("", true),
|
|
_cache[13] || (_cache[13] = createBaseVNode("div", { "flex-auto": "" }, null, -1)),
|
|
createVNode(_component_QuerySelector),
|
|
unref(deps)?.length || unref(importers)?.length ? (openBlock(), createElementBlock(Fragment, { key: 1 }, [
|
|
_cache[11] || (_cache[11] = createBaseVNode("div", {
|
|
mx1: "",
|
|
"h-full": "",
|
|
"w-0": "",
|
|
border: "r main"
|
|
}, null, -1)),
|
|
unref(deps)?.length ? (openBlock(), createBlock(unref(kt), { key: 0 }, {
|
|
popper: withCtx(() => [createBaseVNode("div", _hoisted_3, [createVNode(_component_ModuleList, { modules: unref(deps) }, null, 8, ["modules"])])]),
|
|
default: withCtx(() => [createBaseVNode("button", _hoisted_1, [_cache[9] || (_cache[9] = createBaseVNode("span", { "i-carbon-downstream": "" }, null, -1)), createBaseVNode("span", _hoisted_2, toDisplayString(unref(deps).length), 1)])]),
|
|
_: 1
|
|
})) : createCommentVNode("", true),
|
|
unref(importers)?.length ? (openBlock(), createBlock(unref(kt), { key: 1 }, {
|
|
popper: withCtx(() => [createBaseVNode("div", _hoisted_6, [createVNode(_component_ModuleList, { modules: unref(importers) }, null, 8, ["modules"])])]),
|
|
default: withCtx(() => [createBaseVNode("button", _hoisted_4, [_cache[10] || (_cache[10] = createBaseVNode("span", { "i-carbon-upstream": "" }, null, -1)), createBaseVNode("span", _hoisted_5, toDisplayString(unref(importers).length), 1)])]),
|
|
_: 1
|
|
})) : createCommentVNode("", true)
|
|
], 64)) : createCommentVNode("", true),
|
|
_cache[14] || (_cache[14] = createBaseVNode("div", {
|
|
mx1: "",
|
|
"h-full": "",
|
|
"w-0": "",
|
|
border: "r main"
|
|
}, null, -1)),
|
|
createBaseVNode("button", {
|
|
"icon-btn": "",
|
|
"text-lg": "",
|
|
title: unref(sourcemaps) ? "Inspect sourcemaps" : "Sourcemap is not available",
|
|
disabled: !unref(sourcemaps),
|
|
onClick: _cache[0] || (_cache[0] = ($event) => unref(inspectSourcemaps)({
|
|
code: unref(to),
|
|
sourcemaps: unref(sourcemaps)
|
|
}))
|
|
}, [createBaseVNode("span", {
|
|
"i-carbon-choropleth-map": "",
|
|
block: "",
|
|
class: normalizeClass(unref(sourcemaps) ? "opacity-100" : "opacity-25")
|
|
}, null, 2)], 8, _hoisted_7),
|
|
createBaseVNode("button", {
|
|
"icon-btn": "",
|
|
"text-lg": "",
|
|
title: "Line Wrapping",
|
|
onClick: _cache[1] || (_cache[1] = ($event) => unref(options).view.lineWrapping = !unref(options).view.lineWrapping)
|
|
}, [createBaseVNode("span", {
|
|
"i-carbon-text-wrap": "",
|
|
class: normalizeClass(unref(options).view.lineWrapping ? "opacity-100" : "opacity-25")
|
|
}, null, 2)]),
|
|
createBaseVNode("button", {
|
|
"icon-btn": "",
|
|
"text-lg": "",
|
|
title: "Toggle one column",
|
|
onClick: _cache[2] || (_cache[2] = ($event) => unref(options).view.showOneColumn = !unref(options).view.showOneColumn)
|
|
}, [unref(options).view.showOneColumn ? (openBlock(), createElementBlock("span", _hoisted_8)) : (openBlock(), createElementBlock("span", _hoisted_9))]),
|
|
createBaseVNode("button", {
|
|
class: "icon-btn text-lg",
|
|
title: "Toggle Diff",
|
|
onClick: _cache[3] || (_cache[3] = ($event) => unref(options).view.diff = !unref(options).view.diff)
|
|
}, [createBaseVNode("span", {
|
|
"i-carbon-compare": "",
|
|
class: normalizeClass(unref(options).view.diff ? "opacity-100" : "opacity-25")
|
|
}, null, 2)]),
|
|
!unref(payload).isStatic ? (openBlock(), createElementBlock("button", {
|
|
key: 2,
|
|
class: "icon-btn text-lg",
|
|
title: "Refetch",
|
|
onClick: _cache[4] || (_cache[4] = ($event) => refetch(true))
|
|
}, [..._cache[12] || (_cache[12] = [createBaseVNode("span", { "i-carbon-renew": "" }, null, -1)])])) : createCommentVNode("", true)
|
|
]),
|
|
_: 1
|
|
}), !unref(info)?.transforms.length ? (openBlock(), createElementBlock("div", _hoisted_10, [createBaseVNode("div", null, [
|
|
_cache[15] || (_cache[15] = createTextVNode("No transform data for this module in the ", -1)),
|
|
createVNode(_component_Badge, {
|
|
text: unref(payload).query.env,
|
|
size: "none",
|
|
px1: "",
|
|
"py0.5": "",
|
|
"line-height-1em": ""
|
|
}, null, 8, ["text"]),
|
|
_cache[16] || (_cache[16] = createTextVNode(" env", -1))
|
|
]), !unref(isStaticMode) ? (openBlock(), createElementBlock("button", {
|
|
key: 0,
|
|
rounded: "",
|
|
"bg-teal5": "",
|
|
px2: "",
|
|
py1: "",
|
|
"text-white": "",
|
|
onClick: _cache[5] || (_cache[5] = ($event) => refetch(true))
|
|
}, " Request the module ")) : createCommentVNode("", true)])) : unref(info) && unref(filteredTransforms) ? (openBlock(), createBlock(_component_Container, {
|
|
key: 1,
|
|
flex: "",
|
|
"overflow-hidden": ""
|
|
}, {
|
|
default: withCtx(() => [createVNode(unref(Pe), {
|
|
"h-full": "",
|
|
"of-hidden": "",
|
|
onResize: _cache[7] || (_cache[7] = ($event) => unref(options).view.panelSizeModule = $event.prevPane.size)
|
|
}, {
|
|
default: withCtx(() => [createVNode(unref(ge), {
|
|
size: unref(options).view.panelSizeModule,
|
|
"min-size": "10",
|
|
flex: "~ col",
|
|
"overflow-y-auto": ""
|
|
}, {
|
|
default: withCtx(() => [
|
|
createBaseVNode("div", _hoisted_11, [createBaseVNode("span", _hoisted_12, toDisplayString(unref(payload).query.env) + " TRANSFORM STACK", 1), createBaseVNode("button", {
|
|
class: "icon-btn",
|
|
title: "Toggle bailout plugins",
|
|
onClick: _cache[6] || (_cache[6] = ($event) => unref(options).view.showBailout = !unref(options).view.showBailout)
|
|
}, [createBaseVNode("div", { class: normalizeClass(unref(options).view.showBailout ? "opacity-100 i-carbon-view" : "opacity-75 i-carbon-view-off") }, null, 2)])]),
|
|
_cache[18] || (_cache[18] = createBaseVNode("div", { border: "b main" }, null, -1)),
|
|
(openBlock(true), createElementBlock(Fragment, null, renderList(unref(filteredTransforms), (tr) => {
|
|
return openBlock(), createElementBlock("button", {
|
|
key: tr.index,
|
|
border: "b main",
|
|
flex: "~ gap-1 wrap",
|
|
"items-center": "",
|
|
"px-2": "",
|
|
"py-2": "",
|
|
"text-left": "",
|
|
"text-xs": "",
|
|
"font-mono": "",
|
|
class: normalizeClass(unref(currentIndex) === tr.index ? "bg-active" : tr.noChange || !tr.result ? "op75 saturate-50" : ""),
|
|
onClick: ($event) => index.value = tr.index.toString()
|
|
}, [
|
|
createBaseVNode("span", { class: normalizeClass(unref(currentIndex) !== tr.index && (tr.noChange || !tr.result) ? "" : "fw-600") }, [createVNode(_component_PluginName, { name: tr.name }, null, 8, ["name"])], 2),
|
|
!tr.result ? (openBlock(), createBlock(_component_Badge, {
|
|
key: 0,
|
|
text: "bailout",
|
|
"saturate-0": ""
|
|
})) : tr.noChange ? (openBlock(), createBlock(_component_Badge, {
|
|
key: 1,
|
|
text: "no change",
|
|
color: 20
|
|
})) : createCommentVNode("", true),
|
|
tr.load ? (openBlock(), createBlock(_component_Badge, {
|
|
key: 2,
|
|
text: "load"
|
|
})) : createCommentVNode("", true),
|
|
tr.order && tr.order !== "normal" ? (openBlock(), createBlock(_component_Badge, {
|
|
key: 3,
|
|
title: tr.order.includes("-") ? `Using object hooks ${tr.order}` : tr.order,
|
|
text: tr.order
|
|
}, null, 8, ["title", "text"])) : createCommentVNode("", true),
|
|
tr.error ? (openBlock(), createBlock(_component_Badge, {
|
|
key: 4,
|
|
text: "error"
|
|
}, {
|
|
default: withCtx(() => [_cache[17] || (_cache[17] = createBaseVNode("span", { "flex-auto": "" }, null, -1)), createVNode(_component_DurationDisplay, { duration: tr.end - tr.start }, null, 8, ["duration"])]),
|
|
_: 2
|
|
}, 1024)) : createCommentVNode("", true)
|
|
], 10, _hoisted_13);
|
|
}), 128))
|
|
]),
|
|
_: 1
|
|
}, 8, ["size"]), createVNode(unref(ge), { "min-size": "5" }, {
|
|
default: withCtx(() => [createBaseVNode("div", _hoisted_14, [unref(currentTransform)?.error ? (openBlock(), createBlock(_component_ErrorDisplay, {
|
|
key: `error-${unref(id)}`,
|
|
error: unref(currentTransform).error
|
|
}, null, 8, ["error"])) : (openBlock(), createBlock(_component_DiffEditor, {
|
|
key: 1,
|
|
"one-column": unref(options).view.showOneColumn || !!unref(currentTransform)?.error,
|
|
diff: unref(options).view.diff && !unref(currentTransform)?.error,
|
|
from: unref(from),
|
|
to: unref(to)
|
|
}, null, 8, [
|
|
"one-column",
|
|
"diff",
|
|
"from",
|
|
"to"
|
|
]))])]),
|
|
_: 1
|
|
})]),
|
|
_: 1
|
|
})]),
|
|
_: 1
|
|
})) : createCommentVNode("", true)], 64);
|
|
};
|
|
}
|
|
});
|
|
var module_default = module_vue_vue_type_script_setup_true_lang_default;
|
|
export { module_default as default };
|