Raymond Hill
7 years ago
No known key found for this signature in database
GPG Key ID: 25E1490B761470C2
17 changed files with 12057 additions and 399 deletions
-
4src/about.html
-
29src/css/codemirror.css
-
3src/css/dashboard-common.css
-
161src/css/user-rules.css
-
179src/js/matrix.js
-
38src/js/messaging.js
-
507src/js/user-rules.js
-
21src/lib/codemirror/LICENSE
-
35src/lib/codemirror/README.md
-
119src/lib/codemirror/addon/merge/merge.css
-
1002src/lib/codemirror/addon/merge/merge.js
-
72src/lib/codemirror/addon/selection/active-line.js
-
346src/lib/codemirror/lib/codemirror.css
-
9660src/lib/codemirror/lib/codemirror.js
-
34src/lib/diff/README.md
-
207src/lib/diff/swatinem_diff.js
-
41src/user-rules.html
@ -0,0 +1,29 @@ |
|||||
|
.codeMirrorContainer { |
||||
|
font-size: 12px; |
||||
|
line-height: 1.25; |
||||
|
overflow: hidden; |
||||
|
position: relative; |
||||
|
} |
||||
|
.CodeMirror { |
||||
|
border: 1px solid #ddd; |
||||
|
box-sizing: border-box; |
||||
|
flex-grow: 1; |
||||
|
height: 100%; |
||||
|
width: 100%; |
||||
|
} |
||||
|
|
||||
|
/* For when panels are used */ |
||||
|
.codeMirrorContainer > div:not([class^="CodeMirror"]) { |
||||
|
display: flex; |
||||
|
flex-direction: column; |
||||
|
height: 100%; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-l-deleted { |
||||
|
background-image: none; |
||||
|
font-weight: bold; |
||||
|
} |
||||
|
.CodeMirror-merge-l-inserted { |
||||
|
background-image: none; |
||||
|
font-weight: bold; |
||||
|
} |
@ -0,0 +1,21 @@ |
|||||
|
MIT License |
||||
|
|
||||
|
Copyright (C) 2017 by Marijn Haverbeke <marijnh@gmail.com> and others |
||||
|
|
||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy |
||||
|
of this software and associated documentation files (the "Software"), to deal |
||||
|
in the Software without restriction, including without limitation the rights |
||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
||||
|
copies of the Software, and to permit persons to whom the Software is |
||||
|
furnished to do so, subject to the following conditions: |
||||
|
|
||||
|
The above copyright notice and this permission notice shall be included in |
||||
|
all copies or substantial portions of the Software. |
||||
|
|
||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
||||
|
THE SOFTWARE. |
@ -0,0 +1,35 @@ |
|||||
|
# CodeMirror |
||||
|
[![Build Status](https://travis-ci.org/codemirror/CodeMirror.svg)](https://travis-ci.org/codemirror/CodeMirror) |
||||
|
[![NPM version](https://img.shields.io/npm/v/codemirror.svg)](https://www.npmjs.org/package/codemirror) |
||||
|
[![Join the chat at https://gitter.im/codemirror/CodeMirror](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/codemirror/CodeMirror) |
||||
|
[Funding status: ![maintainer happiness](https://marijnhaverbeke.nl/fund/status_s.png?again)](https://marijnhaverbeke.nl/fund/) |
||||
|
|
||||
|
CodeMirror is a versatile text editor implemented in JavaScript for |
||||
|
the browser. It is specialized for editing code, and comes with over |
||||
|
100 language modes and various addons that implement more advanced |
||||
|
editing functionality. Every language comes with fully-featured code |
||||
|
and syntax highlighting to help with reading and editing complex code. |
||||
|
|
||||
|
A rich programming API and a CSS theming system are available for |
||||
|
customizing CodeMirror to fit your application, and extending it with |
||||
|
new functionality. |
||||
|
|
||||
|
You can find more information (and the |
||||
|
[manual](http://codemirror.net/doc/manual.html)) on the [project |
||||
|
page](http://codemirror.net). For questions and discussion, use the |
||||
|
[discussion forum](https://discuss.codemirror.net/). |
||||
|
|
||||
|
See |
||||
|
[CONTRIBUTING.md](https://github.com/codemirror/CodeMirror/blob/master/CONTRIBUTING.md) |
||||
|
for contributing guidelines. |
||||
|
|
||||
|
The CodeMirror community aims to be welcoming to everybody. We use the |
||||
|
[Contributor Covenant |
||||
|
(1.1)](http://contributor-covenant.org/version/1/1/0/) as our code of |
||||
|
conduct. |
||||
|
|
||||
|
### Quickstart |
||||
|
|
||||
|
To build the project, make sure you have Node.js installed (at least version 6) |
||||
|
and then `npm install`. To run, just open `index.html` in your |
||||
|
browser (you don't need to run a webserver). Run the tests with `npm test`. |
@ -0,0 +1,119 @@ |
|||||
|
.CodeMirror-merge { |
||||
|
position: relative; |
||||
|
border: 1px solid #ddd; |
||||
|
white-space: pre; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge, .CodeMirror-merge .CodeMirror { |
||||
|
height: 350px; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-2pane .CodeMirror-merge-pane { width: 47%; } |
||||
|
.CodeMirror-merge-2pane .CodeMirror-merge-gap { width: 6%; } |
||||
|
.CodeMirror-merge-3pane .CodeMirror-merge-pane { width: 31%; } |
||||
|
.CodeMirror-merge-3pane .CodeMirror-merge-gap { width: 3.5%; } |
||||
|
|
||||
|
.CodeMirror-merge-pane { |
||||
|
display: inline-block; |
||||
|
white-space: normal; |
||||
|
vertical-align: top; |
||||
|
} |
||||
|
.CodeMirror-merge-pane-rightmost { |
||||
|
position: absolute; |
||||
|
right: 0px; |
||||
|
z-index: 1; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-gap { |
||||
|
z-index: 2; |
||||
|
display: inline-block; |
||||
|
height: 100%; |
||||
|
-moz-box-sizing: border-box; |
||||
|
box-sizing: border-box; |
||||
|
overflow: hidden; |
||||
|
border-left: 1px solid #ddd; |
||||
|
border-right: 1px solid #ddd; |
||||
|
position: relative; |
||||
|
background: #f8f8f8; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-scrolllock-wrap { |
||||
|
position: absolute; |
||||
|
bottom: 0; left: 50%; |
||||
|
} |
||||
|
.CodeMirror-merge-scrolllock { |
||||
|
position: relative; |
||||
|
left: -50%; |
||||
|
cursor: pointer; |
||||
|
color: #555; |
||||
|
line-height: 1; |
||||
|
} |
||||
|
.CodeMirror-merge-scrolllock:after { |
||||
|
content: "\21db\00a0\00a0\21da"; |
||||
|
} |
||||
|
.CodeMirror-merge-scrolllock.CodeMirror-merge-scrolllock-enabled:after { |
||||
|
content: "\21db\21da"; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-copybuttons-left, .CodeMirror-merge-copybuttons-right { |
||||
|
position: absolute; |
||||
|
left: 0; top: 0; |
||||
|
right: 0; bottom: 0; |
||||
|
line-height: 1; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-copy { |
||||
|
position: absolute; |
||||
|
cursor: pointer; |
||||
|
color: #44c; |
||||
|
z-index: 3; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-copy-reverse { |
||||
|
position: absolute; |
||||
|
cursor: pointer; |
||||
|
color: #44c; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-copybuttons-left .CodeMirror-merge-copy { left: 2px; } |
||||
|
.CodeMirror-merge-copybuttons-right .CodeMirror-merge-copy { right: 2px; } |
||||
|
|
||||
|
.CodeMirror-merge-r-inserted, .CodeMirror-merge-l-inserted { |
||||
|
background-image: url(); |
||||
|
background-position: bottom left; |
||||
|
background-repeat: repeat-x; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-r-deleted, .CodeMirror-merge-l-deleted { |
||||
|
background-image: url(); |
||||
|
background-position: bottom left; |
||||
|
background-repeat: repeat-x; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-merge-r-chunk { background: #ffffe0; } |
||||
|
.CodeMirror-merge-r-chunk-start { border-top: 1px solid #ee8; } |
||||
|
.CodeMirror-merge-r-chunk-end { border-bottom: 1px solid #ee8; } |
||||
|
.CodeMirror-merge-r-connect { fill: #ffffe0; stroke: #ee8; stroke-width: 1px; } |
||||
|
|
||||
|
.CodeMirror-merge-l-chunk { background: #eef; } |
||||
|
.CodeMirror-merge-l-chunk-start { border-top: 1px solid #88e; } |
||||
|
.CodeMirror-merge-l-chunk-end { border-bottom: 1px solid #88e; } |
||||
|
.CodeMirror-merge-l-connect { fill: #eef; stroke: #88e; stroke-width: 1px; } |
||||
|
|
||||
|
.CodeMirror-merge-l-chunk.CodeMirror-merge-r-chunk { background: #dfd; } |
||||
|
.CodeMirror-merge-l-chunk-start.CodeMirror-merge-r-chunk-start { border-top: 1px solid #4e4; } |
||||
|
.CodeMirror-merge-l-chunk-end.CodeMirror-merge-r-chunk-end { border-bottom: 1px solid #4e4; } |
||||
|
|
||||
|
.CodeMirror-merge-collapsed-widget:before { |
||||
|
content: "(...)"; |
||||
|
} |
||||
|
.CodeMirror-merge-collapsed-widget { |
||||
|
cursor: pointer; |
||||
|
color: #88b; |
||||
|
background: #eef; |
||||
|
border: 1px solid #ddf; |
||||
|
font-size: 90%; |
||||
|
padding: 0 3px; |
||||
|
border-radius: 4px; |
||||
|
} |
||||
|
.CodeMirror-merge-collapsed-line .CodeMirror-gutter-elt { display: none; } |
1002
src/lib/codemirror/addon/merge/merge.js
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -0,0 +1,72 @@ |
|||||
|
// CodeMirror, copyright (c) by Marijn Haverbeke and others
|
||||
|
// Distributed under an MIT license: http://codemirror.net/LICENSE
|
||||
|
|
||||
|
(function(mod) { |
||||
|
if (typeof exports == "object" && typeof module == "object") // CommonJS
|
||||
|
mod(require("../../lib/codemirror")); |
||||
|
else if (typeof define == "function" && define.amd) // AMD
|
||||
|
define(["../../lib/codemirror"], mod); |
||||
|
else // Plain browser env
|
||||
|
mod(CodeMirror); |
||||
|
})(function(CodeMirror) { |
||||
|
"use strict"; |
||||
|
var WRAP_CLASS = "CodeMirror-activeline"; |
||||
|
var BACK_CLASS = "CodeMirror-activeline-background"; |
||||
|
var GUTT_CLASS = "CodeMirror-activeline-gutter"; |
||||
|
|
||||
|
CodeMirror.defineOption("styleActiveLine", false, function(cm, val, old) { |
||||
|
var prev = old == CodeMirror.Init ? false : old; |
||||
|
if (val == prev) return |
||||
|
if (prev) { |
||||
|
cm.off("beforeSelectionChange", selectionChange); |
||||
|
clearActiveLines(cm); |
||||
|
delete cm.state.activeLines; |
||||
|
} |
||||
|
if (val) { |
||||
|
cm.state.activeLines = []; |
||||
|
updateActiveLines(cm, cm.listSelections()); |
||||
|
cm.on("beforeSelectionChange", selectionChange); |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
function clearActiveLines(cm) { |
||||
|
for (var i = 0; i < cm.state.activeLines.length; i++) { |
||||
|
cm.removeLineClass(cm.state.activeLines[i], "wrap", WRAP_CLASS); |
||||
|
cm.removeLineClass(cm.state.activeLines[i], "background", BACK_CLASS); |
||||
|
cm.removeLineClass(cm.state.activeLines[i], "gutter", GUTT_CLASS); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
function sameArray(a, b) { |
||||
|
if (a.length != b.length) return false; |
||||
|
for (var i = 0; i < a.length; i++) |
||||
|
if (a[i] != b[i]) return false; |
||||
|
return true; |
||||
|
} |
||||
|
|
||||
|
function updateActiveLines(cm, ranges) { |
||||
|
var active = []; |
||||
|
for (var i = 0; i < ranges.length; i++) { |
||||
|
var range = ranges[i]; |
||||
|
var option = cm.getOption("styleActiveLine"); |
||||
|
if (typeof option == "object" && option.nonEmpty ? range.anchor.line != range.head.line : !range.empty()) |
||||
|
continue |
||||
|
var line = cm.getLineHandleVisualStart(range.head.line); |
||||
|
if (active[active.length - 1] != line) active.push(line); |
||||
|
} |
||||
|
if (sameArray(cm.state.activeLines, active)) return; |
||||
|
cm.operation(function() { |
||||
|
clearActiveLines(cm); |
||||
|
for (var i = 0; i < active.length; i++) { |
||||
|
cm.addLineClass(active[i], "wrap", WRAP_CLASS); |
||||
|
cm.addLineClass(active[i], "background", BACK_CLASS); |
||||
|
cm.addLineClass(active[i], "gutter", GUTT_CLASS); |
||||
|
} |
||||
|
cm.state.activeLines = active; |
||||
|
}); |
||||
|
} |
||||
|
|
||||
|
function selectionChange(cm, sel) { |
||||
|
updateActiveLines(cm, sel.ranges); |
||||
|
} |
||||
|
}); |
@ -0,0 +1,346 @@ |
|||||
|
/* BASICS */ |
||||
|
|
||||
|
.CodeMirror { |
||||
|
/* Set height, width, borders, and global font properties here */ |
||||
|
font-family: monospace; |
||||
|
height: 300px; |
||||
|
color: black; |
||||
|
direction: ltr; |
||||
|
} |
||||
|
|
||||
|
/* PADDING */ |
||||
|
|
||||
|
.CodeMirror-lines { |
||||
|
padding: 4px 0; /* Vertical padding around content */ |
||||
|
} |
||||
|
.CodeMirror pre { |
||||
|
padding: 0 4px; /* Horizontal padding of content */ |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler { |
||||
|
background-color: white; /* The little square between H and V scrollbars */ |
||||
|
} |
||||
|
|
||||
|
/* GUTTER */ |
||||
|
|
||||
|
.CodeMirror-gutters { |
||||
|
border-right: 1px solid #ddd; |
||||
|
background-color: #f7f7f7; |
||||
|
white-space: nowrap; |
||||
|
} |
||||
|
.CodeMirror-linenumbers {} |
||||
|
.CodeMirror-linenumber { |
||||
|
padding: 0 3px 0 5px; |
||||
|
min-width: 20px; |
||||
|
text-align: right; |
||||
|
color: #999; |
||||
|
white-space: nowrap; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-guttermarker { color: black; } |
||||
|
.CodeMirror-guttermarker-subtle { color: #999; } |
||||
|
|
||||
|
/* CURSOR */ |
||||
|
|
||||
|
.CodeMirror-cursor { |
||||
|
border-left: 1px solid black; |
||||
|
border-right: none; |
||||
|
width: 0; |
||||
|
} |
||||
|
/* Shown when moving in bi-directional text */ |
||||
|
.CodeMirror div.CodeMirror-secondarycursor { |
||||
|
border-left: 1px solid silver; |
||||
|
} |
||||
|
.cm-fat-cursor .CodeMirror-cursor { |
||||
|
width: auto; |
||||
|
border: 0 !important; |
||||
|
background: #7e7; |
||||
|
} |
||||
|
.cm-fat-cursor div.CodeMirror-cursors { |
||||
|
z-index: 1; |
||||
|
} |
||||
|
.cm-fat-cursor-mark { |
||||
|
background-color: rgba(20, 255, 20, 0.5); |
||||
|
-webkit-animation: blink 1.06s steps(1) infinite; |
||||
|
-moz-animation: blink 1.06s steps(1) infinite; |
||||
|
animation: blink 1.06s steps(1) infinite; |
||||
|
} |
||||
|
.cm-animate-fat-cursor { |
||||
|
width: auto; |
||||
|
border: 0; |
||||
|
-webkit-animation: blink 1.06s steps(1) infinite; |
||||
|
-moz-animation: blink 1.06s steps(1) infinite; |
||||
|
animation: blink 1.06s steps(1) infinite; |
||||
|
background-color: #7e7; |
||||
|
} |
||||
|
@-moz-keyframes blink { |
||||
|
0% {} |
||||
|
50% { background-color: transparent; } |
||||
|
100% {} |
||||
|
} |
||||
|
@-webkit-keyframes blink { |
||||
|
0% {} |
||||
|
50% { background-color: transparent; } |
||||
|
100% {} |
||||
|
} |
||||
|
@keyframes blink { |
||||
|
0% {} |
||||
|
50% { background-color: transparent; } |
||||
|
100% {} |
||||
|
} |
||||
|
|
||||
|
/* Can style cursor different in overwrite (non-insert) mode */ |
||||
|
.CodeMirror-overwrite .CodeMirror-cursor {} |
||||
|
|
||||
|
.cm-tab { display: inline-block; text-decoration: inherit; } |
||||
|
|
||||
|
.CodeMirror-rulers { |
||||
|
position: absolute; |
||||
|
left: 0; right: 0; top: -50px; bottom: -20px; |
||||
|
overflow: hidden; |
||||
|
} |
||||
|
.CodeMirror-ruler { |
||||
|
border-left: 1px solid #ccc; |
||||
|
top: 0; bottom: 0; |
||||
|
position: absolute; |
||||
|
} |
||||
|
|
||||
|
/* DEFAULT THEME */ |
||||
|
|
||||
|
.cm-s-default .cm-header {color: blue;} |
||||
|
.cm-s-default .cm-quote {color: #090;} |
||||
|
.cm-negative {color: #d44;} |
||||
|
.cm-positive {color: #292;} |
||||
|
.cm-header, .cm-strong {font-weight: bold;} |
||||
|
.cm-em {font-style: italic;} |
||||
|
.cm-link {text-decoration: underline;} |
||||
|
.cm-strikethrough {text-decoration: line-through;} |
||||
|
|
||||
|
.cm-s-default .cm-keyword {color: #708;} |
||||
|
.cm-s-default .cm-atom {color: #219;} |
||||
|
.cm-s-default .cm-number {color: #164;} |
||||
|
.cm-s-default .cm-def {color: #00f;} |
||||
|
.cm-s-default .cm-variable, |
||||
|
.cm-s-default .cm-punctuation, |
||||
|
.cm-s-default .cm-property, |
||||
|
.cm-s-default .cm-operator {} |
||||
|
.cm-s-default .cm-variable-2 {color: #05a;} |
||||
|
.cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;} |
||||
|
.cm-s-default .cm-comment {color: #a50;} |
||||
|
.cm-s-default .cm-string {color: #a11;} |
||||
|
.cm-s-default .cm-string-2 {color: #f50;} |
||||
|
.cm-s-default .cm-meta {color: #555;} |
||||
|
.cm-s-default .cm-qualifier {color: #555;} |
||||
|
.cm-s-default .cm-builtin {color: #30a;} |
||||
|
.cm-s-default .cm-bracket {color: #997;} |
||||
|
.cm-s-default .cm-tag {color: #170;} |
||||
|
.cm-s-default .cm-attribute {color: #00c;} |
||||
|
.cm-s-default .cm-hr {color: #999;} |
||||
|
.cm-s-default .cm-link {color: #00c;} |
||||
|
|
||||
|
.cm-s-default .cm-error {color: #f00;} |
||||
|
.cm-invalidchar {color: #f00;} |
||||
|
|
||||
|
.CodeMirror-composing { border-bottom: 2px solid; } |
||||
|
|
||||
|
/* Default styles for common addons */ |
||||
|
|
||||
|
div.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;} |
||||
|
div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;} |
||||
|
.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); } |
||||
|
.CodeMirror-activeline-background {background: #e8f2ff;} |
||||
|
|
||||
|
/* STOP */ |
||||
|
|
||||
|
/* The rest of this file contains styles related to the mechanics of |
||||
|
the editor. You probably shouldn't touch them. */ |
||||
|
|
||||
|
.CodeMirror { |
||||
|
position: relative; |
||||
|
overflow: hidden; |
||||
|
background: white; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-scroll { |
||||
|
overflow: scroll !important; /* Things will break if this is overridden */ |
||||
|
/* 30px is the magic margin used to hide the element's real scrollbars */ |
||||
|
/* See overflow: hidden in .CodeMirror */ |
||||
|
margin-bottom: -30px; margin-right: -30px; |
||||
|
padding-bottom: 30px; |
||||
|
height: 100%; |
||||
|
outline: none; /* Prevent dragging from highlighting the element */ |
||||
|
position: relative; |
||||
|
} |
||||
|
.CodeMirror-sizer { |
||||
|
position: relative; |
||||
|
border-right: 30px solid transparent; |
||||
|
} |
||||
|
|
||||
|
/* The fake, visible scrollbars. Used to force redraw during scrolling |
||||
|
before actual scrolling happens, thus preventing shaking and |
||||
|
flickering artifacts. */ |
||||
|
.CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler { |
||||
|
position: absolute; |
||||
|
z-index: 6; |
||||
|
display: none; |
||||
|
} |
||||
|
.CodeMirror-vscrollbar { |
||||
|
right: 0; top: 0; |
||||
|
overflow-x: hidden; |
||||
|
overflow-y: scroll; |
||||
|
} |
||||
|
.CodeMirror-hscrollbar { |
||||
|
bottom: 0; left: 0; |
||||
|
overflow-y: hidden; |
||||
|
overflow-x: scroll; |
||||
|
} |
||||
|
.CodeMirror-scrollbar-filler { |
||||
|
right: 0; bottom: 0; |
||||
|
} |
||||
|
.CodeMirror-gutter-filler { |
||||
|
left: 0; bottom: 0; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-gutters { |
||||
|
position: absolute; left: 0; top: 0; |
||||
|
min-height: 100%; |
||||
|
z-index: 3; |
||||
|
} |
||||
|
.CodeMirror-gutter { |
||||
|
white-space: normal; |
||||
|
height: 100%; |
||||
|
display: inline-block; |
||||
|
vertical-align: top; |
||||
|
margin-bottom: -30px; |
||||
|
} |
||||
|
.CodeMirror-gutter-wrapper { |
||||
|
position: absolute; |
||||
|
z-index: 4; |
||||
|
background: none !important; |
||||
|
border: none !important; |
||||
|
} |
||||
|
.CodeMirror-gutter-background { |
||||
|
position: absolute; |
||||
|
top: 0; bottom: 0; |
||||
|
z-index: 4; |
||||
|
} |
||||
|
.CodeMirror-gutter-elt { |
||||
|
position: absolute; |
||||
|
cursor: default; |
||||
|
z-index: 4; |
||||
|
} |
||||
|
.CodeMirror-gutter-wrapper ::selection { background-color: transparent } |
||||
|
.CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent } |
||||
|
|
||||
|
.CodeMirror-lines { |
||||
|
cursor: text; |
||||
|
min-height: 1px; /* prevents collapsing before first draw */ |
||||
|
} |
||||
|
.CodeMirror pre { |
||||
|
/* Reset some styles that the rest of the page might have set */ |
||||
|
-moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; |
||||
|
border-width: 0; |
||||
|
background: transparent; |
||||
|
font-family: inherit; |
||||
|
font-size: inherit; |
||||
|
margin: 0; |
||||
|
white-space: pre; |
||||
|
word-wrap: normal; |
||||
|
line-height: inherit; |
||||
|
color: inherit; |
||||
|
z-index: 2; |
||||
|
position: relative; |
||||
|
overflow: visible; |
||||
|
-webkit-tap-highlight-color: transparent; |
||||
|
-webkit-font-variant-ligatures: contextual; |
||||
|
font-variant-ligatures: contextual; |
||||
|
} |
||||
|
.CodeMirror-wrap pre { |
||||
|
word-wrap: break-word; |
||||
|
white-space: pre-wrap; |
||||
|
word-break: normal; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-linebackground { |
||||
|
position: absolute; |
||||
|
left: 0; right: 0; top: 0; bottom: 0; |
||||
|
z-index: 0; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-linewidget { |
||||
|
position: relative; |
||||
|
z-index: 2; |
||||
|
padding: 0.1px; /* Force widget margins to stay inside of the container */ |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-widget {} |
||||
|
|
||||
|
.CodeMirror-rtl pre { direction: rtl; } |
||||
|
|
||||
|
.CodeMirror-code { |
||||
|
outline: none; |
||||
|
} |
||||
|
|
||||
|
/* Force content-box sizing for the elements where we expect it */ |
||||
|
.CodeMirror-scroll, |
||||
|
.CodeMirror-sizer, |
||||
|
.CodeMirror-gutter, |
||||
|
.CodeMirror-gutters, |
||||
|
.CodeMirror-linenumber { |
||||
|
-moz-box-sizing: content-box; |
||||
|
box-sizing: content-box; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-measure { |
||||
|
position: absolute; |
||||
|
width: 100%; |
||||
|
height: 0; |
||||
|
overflow: hidden; |
||||
|
visibility: hidden; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-cursor { |
||||
|
position: absolute; |
||||
|
pointer-events: none; |
||||
|
} |
||||
|
.CodeMirror-measure pre { position: static; } |
||||
|
|
||||
|
div.CodeMirror-cursors { |
||||
|
visibility: hidden; |
||||
|
position: relative; |
||||
|
z-index: 3; |
||||
|
} |
||||
|
div.CodeMirror-dragcursors { |
||||
|
visibility: visible; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-focused div.CodeMirror-cursors { |
||||
|
visibility: visible; |
||||
|
} |
||||
|
|
||||
|
.CodeMirror-selected { background: #d9d9d9; } |
||||
|
.CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; } |
||||
|
.CodeMirror-crosshair { cursor: crosshair; } |
||||
|
.CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; } |
||||
|
.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; } |
||||
|
|
||||
|
.cm-searching { |
||||
|
background-color: #ffa; |
||||
|
background-color: rgba(255, 255, 0, .4); |
||||
|
} |
||||
|
|
||||
|
/* Used to force a border model for a node */ |
||||
|
.cm-force-border { padding-right: .1px; } |
||||
|
|
||||
|
@media print { |
||||
|
/* Hide the cursor when printing */ |
||||
|
.CodeMirror div.CodeMirror-cursors { |
||||
|
visibility: hidden; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/* See issue #2901 */ |
||||
|
.cm-tab-wrap-hack:after { content: ''; } |
||||
|
|
||||
|
/* Help users use markselection to safely style text background */ |
||||
|
span.CodeMirror-selectedtext { background: none; } |
9660
src/lib/codemirror/lib/codemirror.js
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -0,0 +1,34 @@ |
|||||
|
# diff |
||||
|
|
||||
|
implementation of myers diff algorithm |
||||
|
|
||||
|
[![Build Status](https://travis-ci.org/Swatinem/diff.png?branch=master)](https://travis-ci.org/Swatinem/diff) |
||||
|
[![Coverage Status](https://coveralls.io/repos/Swatinem/diff/badge.png?branch=master)](https://coveralls.io/r/Swatinem/diff) |
||||
|
[![Dependency Status](https://gemnasium.com/Swatinem/diff.png)](https://gemnasium.com/Swatinem/diff) |
||||
|
|
||||
|
|
||||
|
This uses the [*An O(ND) Difference Algorithm and Its Variations*](http://www.xmailserver.org/diff2.pdf) |
||||
|
Also see http://simplygenius.net/Article/DiffTutorial2 and |
||||
|
http://www.mathertel.de/Diff/ViewSrc.aspx for more inspiration |
||||
|
|
||||
|
## Installation |
||||
|
|
||||
|
$ npm install diff |
||||
|
$ component install Swatinem/diff |
||||
|
|
||||
|
## Usage |
||||
|
|
||||
|
### diff(a, b, [eql(a, b)]) |
||||
|
|
||||
|
Given two arrays (or array-likes, such as strings) `a` and `b` and an optional |
||||
|
equal function `eql`, this will return an array with the following operations: |
||||
|
* *nop* the element is in both arrays |
||||
|
* *ins* the element is only in array `b` and will be inserted |
||||
|
* *del* the element in only in array `a` and will be removed |
||||
|
* *rep* the element from `a` will be replaced by the element from `b`. |
||||
|
This is essentially the same as a del+ins |
||||
|
|
||||
|
## License |
||||
|
|
||||
|
LGPLv3 |
||||
|
|
@ -0,0 +1,207 @@ |
|||||
|
/******************************************************************************* |
||||
|
|
||||
|
Key portions of code below was borrowed from: |
||||
|
https://github.com/Swatinem/diff
|
||||
|
|
||||
|
License is LGPL3 (thanks!) as per: |
||||
|
https://github.com/Swatinem/diff/blob/b58391504759/README.md
|
||||
|
|
||||
|
I chose to pick this implementation over |
||||
|
https://github.com/google/diff-match-patch as suggested by CodeMirror
|
||||
|
because: |
||||
|
|
||||
|
- Code is clean and simple to read -- useful when unfamiliar with the diff |
||||
|
algorithm, this makes changing the code easier if/when needed. |
||||
|
|
||||
|
- Smaller -- diff_match_patch comes with an extended API most of which is |
||||
|
of no use to the current project. |
||||
|
- diff_match_patch uncompressed: 74.7 KB |
||||
|
- Swatinem's diff uncompressed: 3.66 KB |
||||
|
|
||||
|
- I can easily adapt Swatinem's diff to deal with arrays of strings, which |
||||
|
is best suited for the current project -- it natively work with arrays. |
||||
|
|
||||
|
I removed portions of code which are of no use for the current project. |
||||
|
|
||||
|
I modified the diff script generator (Diff.prototype.editscript) since I |
||||
|
need to generate a script which is compatible with the output of the |
||||
|
diff_match_patch, as expected by CodeMirror. |
||||
|
|
||||
|
**/ |
||||
|
|
||||
|
'use strict'; |
||||
|
|
||||
|
(function(context) { |
||||
|
|
||||
|
// CodeMirror expect these globals:
|
||||
|
context.DIFF_INSERT = 1; |
||||
|
context.DIFF_DELETE = -1; |
||||
|
context.DIFF_EQUAL = 0; |
||||
|
context.diff_match_patch = function(){}; |
||||
|
|
||||
|
context.diff_match_patch.prototype.diff_main = function(a, b) { |
||||
|
if ( a === b ) { return [ [ 0, a ] ]; } |
||||
|
var aa = a.match(/\n|[^\n]+\n?/g) || []; |
||||
|
var bb = b.match(/\n|[^\n]+\n?/g) || []; |
||||
|
var d = new Diff(aa, bb, eqlDefault); |
||||
|
return d.editscript(); |
||||
|
}; |
||||
|
|
||||
|
function eqlDefault(a, b) { return a === b; } |
||||
|
|
||||
|
function Diff(a, b, eql) { |
||||
|
this.a = a; |
||||
|
this.b = b; |
||||
|
this.eql = eql; |
||||
|
|
||||
|
this.moda = Array.apply(null, new Array(a.length)).map(true.valueOf, false); |
||||
|
this.modb = Array.apply(null, new Array(b.length)).map(true.valueOf, false); |
||||
|
|
||||
|
// just to save some allocations:
|
||||
|
this.down = {}; |
||||
|
this.up = {}; |
||||
|
|
||||
|
this.lcs(0, a.length, 0, b.length); |
||||
|
} |
||||
|
|
||||
|
Diff.prototype.editscript = function Diff_editscript() { |
||||
|
var moda = this.moda, modb = this.modb; |
||||
|
var astart = 0, aend = moda.length; |
||||
|
var bstart = 0, bend = modb.length; |
||||
|
var result = []; |
||||
|
while (astart < aend || bstart < bend) { |
||||
|
if (astart < aend && bstart < bend) { |
||||
|
if (!moda[astart] && !modb[bstart]) { |
||||
|
result.push([ 0, this.a[astart] ]); |
||||
|
astart++; bstart++; |
||||
|
continue; |
||||
|
} else if (moda[astart] && modb[bstart]) { |
||||
|
result.push([ -1, this.a[astart] ]); |
||||
|
result.push([ 1, this.b[bstart] ]); |
||||
|
astart++; bstart++; |
||||
|
continue; |
||||
|
} |
||||
|
} |
||||
|
if (astart < aend && (bstart >= bend || moda[astart])) { |
||||
|
result.push([ -1, this.a[astart] ]); |
||||
|
astart++; |
||||
|
} |
||||
|
if (bstart < bend && (astart >= aend || modb[bstart])) { |
||||
|
result.push([ 1, this.b[bstart] ]); |
||||
|
bstart++; |
||||
|
} |
||||
|
} |
||||
|
return result; |
||||
|
}; |
||||
|
|
||||
|
Diff.prototype.lcs = function Diff_lcs(astart, aend, bstart, bend) { |
||||
|
var a = this.a, b = this.b, eql = this.eql; |
||||
|
// separate common head
|
||||
|
while (astart < aend && bstart < bend && eql(a[astart], b[bstart])) { |
||||
|
astart++; bstart++; |
||||
|
} |
||||
|
// separate common tail
|
||||
|
while (astart < aend && bstart < bend && eql(a[aend - 1], b[bend - 1])) { |
||||
|
aend--; bend--; |
||||
|
} |
||||
|
|
||||
|
if (astart === aend) { |
||||
|
// only insertions
|
||||
|
while (bstart < bend) { |
||||
|
this.modb[bstart] = true; |
||||
|
bstart++; |
||||
|
} |
||||
|
} else if (bend === bstart) { |
||||
|
// only deletions
|
||||
|
while (astart < aend) { |
||||
|
this.moda[astart] = true; |
||||
|
astart++; |
||||
|
} |
||||
|
} else { |
||||
|
var snake = this.snake(astart, aend, bstart, bend); |
||||
|
|
||||
|
this.lcs(astart, snake.x, bstart, snake.y); |
||||
|
this.lcs(snake.u, aend, snake.v, bend); |
||||
|
} |
||||
|
}; |
||||
|
|
||||
|
Diff.prototype.snake = function Diff_snake(astart, aend, bstart, bend) { |
||||
|
var a = this.a, b = this.b, eql = this.eql; |
||||
|
|
||||
|
var N = aend - astart, |
||||
|
M = bend - bstart; |
||||
|
|
||||
|
var kdown = astart - bstart; |
||||
|
var kup = aend - bend; |
||||
|
|
||||
|
var delta = N - M; |
||||
|
var deltaOdd = delta & 1; |
||||
|
|
||||
|
var down = this.down; |
||||
|
down[kdown + 1] = astart; |
||||
|
var up = this.up; |
||||
|
up[kup - 1] = aend; |
||||
|
|
||||
|
var Dmax = (N + M + 1) / 2; |
||||
|
for (var D = 0; D <= Dmax; D++) { |
||||
|
var k, x, y; |
||||
|
// forward path
|
||||
|
for (k = kdown - D; k <= kdown + D; k += 2) { |
||||
|
if (k === kdown - D) { |
||||
|
x = down[k + 1]; // down
|
||||
|
} else { |
||||
|
x = down[k - 1] + 1; // right
|
||||
|
if ((k < kdown + D) && (down[k + 1] >= x)) { |
||||
|
x = down[k + 1]; // down
|
||||
|
} |
||||
|
} |
||||
|
y = x - k; |
||||
|
|
||||
|
while (x < aend && y < bend && eql(a[x], b[y])) { |
||||
|
x++; y++; // diagonal
|
||||
|
} |
||||
|
down[k] = x; |
||||
|
|
||||
|
if (deltaOdd && (kup - D < k) && (k < kup + D) && |
||||
|
up[k] <= down[k]) { |
||||
|
return { |
||||
|
x: down[k], |
||||
|
y: down[k] - k, |
||||
|
u: up[k], |
||||
|
v: up[k] - k, |
||||
|
}; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
// reverse path
|
||||
|
for (k = kup - D; k <= kup + D; k += 2) { |
||||
|
if (k === kup + D) { |
||||
|
x = up[k - 1]; // up
|
||||
|
} else { |
||||
|
x = up[k + 1] - 1; // left
|
||||
|
if ((k > kup - D) && (up[k - 1] < x)) { |
||||
|
x = up[k - 1]; // up
|
||||
|
} |
||||
|
} |
||||
|
y = x - k; |
||||
|
|
||||
|
while (x > astart && y > bstart && eql(a[x - 1], b[y - 1])) { |
||||
|
x--; y--; // diagonal
|
||||
|
} |
||||
|
up[k] = x; |
||||
|
|
||||
|
if (!deltaOdd && (kdown - D <= k) && (k <= kdown + D) && |
||||
|
up[k] <= down[k]) { |
||||
|
return { |
||||
|
x: down[k], |
||||
|
y: down[k] - k, |
||||
|
u: up[k], |
||||
|
v: up[k] - k, |
||||
|
}; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
}; |
||||
|
|
||||
|
return Diff; |
||||
|
})(self); |
Write
Preview
Loading…
Cancel
Save
Reference in new issue