diff options
| author | Wu Cheng-Han | 2016-01-17 14:28:04 -0600 | 
|---|---|---|
| committer | Wu Cheng-Han | 2016-01-17 14:28:04 -0600 | 
| commit | eaa8ccaccb1091820d0a8d1223996a6dd057347d (patch) | |
| tree | 6b4aaa3b3d1a2fed68147510142663222533775a /public/vendor/codemirror/mode/clike | |
| parent | ce65e58096d57ace02723d11a125673f9d48c293 (diff) | |
Upgrade CodeMirror to 5.10.1 and now support fullscreen, jump-to-line in editor
Diffstat (limited to 'public/vendor/codemirror/mode/clike')
| -rw-r--r--[-rwxr-xr-x] | public/vendor/codemirror/mode/clike/clike.js | 245 | ||||
| -rw-r--r--[-rwxr-xr-x] | public/vendor/codemirror/mode/clike/index.html | 111 | ||||
| -rw-r--r--[-rwxr-xr-x] | public/vendor/codemirror/mode/clike/scala.html | 0 | ||||
| -rw-r--r--[-rwxr-xr-x] | public/vendor/codemirror/mode/clike/test.js | 18 | 
4 files changed, 341 insertions, 33 deletions
| diff --git a/public/vendor/codemirror/mode/clike/clike.js b/public/vendor/codemirror/mode/clike/clike.js index f1a7e7a9..4f5c0cf3 100755..100644 --- a/public/vendor/codemirror/mode/clike/clike.js +++ b/public/vendor/codemirror/mode/clike/clike.js @@ -25,8 +25,12 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {        multiLineStrings = parserConfig.multiLineStrings,        indentStatements = parserConfig.indentStatements !== false,        indentSwitch = parserConfig.indentSwitch !== false, -      namespaceSeparator = parserConfig.namespaceSeparator; -  var isOperatorChar = /[+\-*&%=<>!?|\/]/; +      namespaceSeparator = parserConfig.namespaceSeparator, +      isPunctuationChar = parserConfig.isPunctuationChar || /[\[\]{}\(\),;\:\.]/, +      numberStart = parserConfig.numberStart || /[\d\.]/, +      number = parserConfig.number || /^(?:0x[a-f\d]+|0b[01]+|(?:\d+\.?\d*|\.\d+)(?:e[-+]?\d+)?)(u|ll?|l|f)?/i, +      isOperatorChar = parserConfig.isOperatorChar || /[+\-*&%=<>!?|\/]/, +      endStatement = parserConfig.endStatement || /^[;:,]$/;    var curPunc, isDefKeyword; @@ -40,13 +44,14 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {        state.tokenize = tokenString(ch);        return state.tokenize(stream, state);      } -    if (/[\[\]{}\(\),;\:\.]/.test(ch)) { +    if (isPunctuationChar.test(ch)) {        curPunc = ch;        return null;      } -    if (/\d/.test(ch)) { -      stream.eatWhile(/[\w\.]/); -      return "number"; +    if (numberStart.test(ch)) { +      stream.backUp(1) +      if (stream.match(number)) return "number" +      stream.next()      }      if (ch == "/") {        if (stream.eat("*")) { @@ -67,17 +72,17 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {        stream.eatWhile(/[\w\$_\xa1-\uffff]/);      var cur = stream.current(); -    if (keywords.propertyIsEnumerable(cur)) { -      if (blockKeywords.propertyIsEnumerable(cur)) curPunc = "newstatement"; -      if (defKeywords.propertyIsEnumerable(cur)) isDefKeyword = true; +    if (contains(keywords, cur)) { +      if (contains(blockKeywords, cur)) curPunc = "newstatement"; +      if (contains(defKeywords, cur)) isDefKeyword = true;        return "keyword";      } -    if (types.propertyIsEnumerable(cur)) return "variable-3"; -    if (builtin.propertyIsEnumerable(cur)) { -      if (blockKeywords.propertyIsEnumerable(cur)) curPunc = "newstatement"; +    if (contains(types, cur)) return "variable-3"; +    if (contains(builtin, cur)) { +      if (contains(blockKeywords, cur)) curPunc = "newstatement";        return "builtin";      } -    if (atoms.propertyIsEnumerable(cur)) return "atom"; +    if (contains(atoms, cur)) return "atom";      return "variable";    } @@ -168,8 +173,7 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {        if (style == "comment" || style == "meta") return style;        if (ctx.align == null) ctx.align = true; -      if ((curPunc == ";" || curPunc == ":" || curPunc == ",")) -        while (isStatement(state.context.type)) popContext(state); +      if (endStatement.test(curPunc)) while (isStatement(state.context.type)) popContext(state);        else if (curPunc == "{") pushContext(state, stream.column(), "}");        else if (curPunc == "[") pushContext(state, stream.column(), "]");        else if (curPunc == "(") pushContext(state, stream.column(), ")"); @@ -212,8 +216,16 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {        if (state.tokenize != tokenBase && state.tokenize != null) return CodeMirror.Pass;        var ctx = state.context, firstChar = textAfter && textAfter.charAt(0);        if (isStatement(ctx.type) && firstChar == "}") ctx = ctx.prev; +      if (hooks.indent) { +        var hook = hooks.indent(state, ctx, textAfter); +        if (typeof hook == "number") return hook +      }        var closing = firstChar == ctx.type;        var switchBlock = ctx.prev && ctx.prev.type == "switchstatement"; +      if (parserConfig.allmanIndentation && /[{(]/.test(firstChar)) { +        while (ctx.type != "top" && ctx.type != "}") ctx = ctx.prev +        return ctx.indented +      }        if (isStatement(ctx.type))          return ctx.indented + (firstChar == "{" ? 0 : statementIndentUnit);        if (ctx.align && (!dontAlignCalls || ctx.type != ")")) @@ -238,27 +250,30 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {      for (var i = 0; i < words.length; ++i) obj[words[i]] = true;      return obj;    } +  function contains(words, word) { +    if (typeof words === "function") { +      return words(word); +    } else { +      return words.propertyIsEnumerable(word); +    } +  }    var cKeywords = "auto if break case register continue return default do sizeof " + -    "static else struct switch extern typedef float union for " + -    "goto while enum const volatile"; +    "static else struct switch extern typedef union for goto while enum const volatile";    var cTypes = "int long char short double float unsigned signed void size_t ptrdiff_t";    function cppHook(stream, state) { -    if (!state.startOfLine) return false; -    for (;;) { -      if (stream.skipTo("\\")) { -        stream.next(); -        if (stream.eol()) { -          state.tokenize = cppHook; -          break; -        } -      } else { -        stream.skipToEnd(); -        state.tokenize = null; -        break; +    if (!state.startOfLine) return false +    for (var ch, next = null; ch = stream.peek();) { +      if (ch == "\\" && stream.match(/^.$/)) { +        next = cppHook +        break +      } else if (ch == "/" && stream.match(/^\/[\/\*]/, false)) { +        break        } +      stream.next()      } -    return "meta"; +    state.tokenize = next +    return "meta"    }    function pointerHook(_stream, state) { @@ -266,6 +281,11 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {      return false;    } +  function cpp14Literal(stream) { +    stream.eatWhile(/[\w\.']/); +    return "number"; +  } +    function cpp11StringHook(stream, state) {      stream.backUp(1);      // Raw strings. @@ -373,6 +393,16 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {        "U": cpp11StringHook,        "L": cpp11StringHook,        "R": cpp11StringHook, +      "0": cpp14Literal, +      "1": cpp14Literal, +      "2": cpp14Literal, +      "3": cpp14Literal, +      "4": cpp14Literal, +      "5": cpp14Literal, +      "6": cpp14Literal, +      "7": cpp14Literal, +      "8": cpp14Literal, +      "9": cpp14Literal,        token: function(stream, state, style) {          if (style == "variable" && stream.peek() == "(" &&              (state.prevToken == ";" || state.prevToken == null || @@ -398,6 +428,7 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {      defKeywords: words("class interface package enum"),      typeFirstDefinitions: true,      atoms: words("true false null"), +    endStatement: /^[;:]$/,      hooks: {        "@": function(stream) {          stream.eatWhile(/[\w\$_]/); @@ -453,7 +484,7 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {      keywords: words(        /* scala */ -      "abstract case catch class def do else extends false final finally for forSome if " + +      "abstract case catch class def do else extends final finally for forSome if " +        "implicit import lazy match new null object override package private protected return " +        "sealed super this throw trait try type val var while with yield _ : = => <- <: " +        "<% >: # @ " + @@ -501,6 +532,59 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {      modeProps: {closeBrackets: {triples: '"'}}    }); +  function tokenKotlinString(tripleString){ +    return function (stream, state) { +      var escaped = false, next, end = false; +      while (!stream.eol()) { +        if (!tripleString && !escaped && stream.match('"') ) {end = true; break;} +        if (tripleString && stream.match('"""')) {end = true; break;} +        next = stream.next(); +        if(!escaped && next == "$" && stream.match('{')) +          stream.skipTo("}"); +        escaped = !escaped && next == "\\" && !tripleString; +      } +      if (end || !tripleString) +        state.tokenize = null; +      return "string"; +    } +  } + +  def("text/x-kotlin", { +    name: "clike", +    keywords: words( +      /*keywords*/ +      "package as typealias class interface this super val " + +      "var fun for is in This throw return " + +      "break continue object if else while do try when !in !is as? " + + +      /*soft keywords*/ +      "file import where by get set abstract enum open inner override private public internal " + +      "protected catch finally out final vararg reified dynamic companion constructor init " + +      "sealed field property receiver param sparam lateinit data inline noinline tailrec " + +      "external annotation crossinline const operator infix" +    ), +    types: words( +      /* package java.lang */ +      "Boolean Byte Character CharSequence Class ClassLoader Cloneable Comparable " + +      "Compiler Double Exception Float Integer Long Math Number Object Package Pair Process " + +      "Runtime Runnable SecurityManager Short StackTraceElement StrictMath String " + +      "StringBuffer System Thread ThreadGroup ThreadLocal Throwable Triple Void" +    ), +    intendSwitch: false, +    indentStatements: false, +    multiLineStrings: true, +    blockKeywords: words("catch class do else finally for if where try while enum"), +    defKeywords: words("class val var object package interface fun"), +    atoms: words("true false null this"), +    hooks: { +      '"': function(stream, state) { +        state.tokenize = tokenKotlinString(stream.match('""')); +        return state.tokenize(stream, state); +      } +    }, +    modeProps: {closeBrackets: {triples: '"'}} +  }); +    def(["x-shader/x-vertex", "x-shader/x-fragment"], {      name: "clike",      keywords: words("sampler1D sampler2D sampler3D samplerCube " + @@ -583,9 +667,106 @@ CodeMirror.defineMode("clike", function(config, parserConfig) {          stream.eatWhile(/[\w\$]/);          return "keyword";        }, -      "#": cppHook +      "#": cppHook, +      indent: function(_state, ctx, textAfter) { +        if (ctx.type == "statement" && /^@\w/.test(textAfter)) return ctx.indented +      }      },      modeProps: {fold: "brace"}    }); +  def("text/x-squirrel", { +    name: "clike", +    keywords: words("base break clone continue const default delete enum extends function in class" + +                    " foreach local resume return this throw typeof yield constructor instanceof static"), +    types: words(cTypes), +    blockKeywords: words("case catch class else for foreach if switch try while"), +    defKeywords: words("function local class"), +    typeFirstDefinitions: true, +    atoms: words("true false null"), +    hooks: {"#": cppHook}, +    modeProps: {fold: ["brace", "include"]} +  }); + +  // Ceylon Strings need to deal with interpolation +  var stringTokenizer = null; +  function tokenCeylonString(type) { +    return function(stream, state) { +      var escaped = false, next, end = false; +      while (!stream.eol()) { +        if (!escaped && stream.match('"') && +              (type == "single" || stream.match('""'))) { +          end = true; +          break; +        } +        if (!escaped && stream.match('``')) { +          stringTokenizer = tokenCeylonString(type); +          end = true; +          break; +        } +        next = stream.next(); +        escaped = type == "single" && !escaped && next == "\\"; +      } +      if (end) +          state.tokenize = null; +      return "string"; +    } +  } + +  def("text/x-ceylon", { +    name: "clike", +    keywords: words("abstracts alias assembly assert assign break case catch class continue dynamic else" + +                    " exists extends finally for function given if import in interface is let module new" + +                    " nonempty object of out outer package return satisfies super switch then this throw" + +                    " try value void while"), +    types: function(word) { +        // In Ceylon all identifiers that start with an uppercase are types +        var first = word.charAt(0); +        return (first === first.toUpperCase() && first !== first.toLowerCase()); +    }, +    blockKeywords: words("case catch class dynamic else finally for function if interface module new object switch try while"), +    defKeywords: words("class dynamic function interface module object package value"), +    builtin: words("abstract actual aliased annotation by default deprecated doc final formal late license" + +                   " native optional sealed see serializable shared suppressWarnings tagged throws variable"), +    isPunctuationChar: /[\[\]{}\(\),;\:\.`]/, +    isOperatorChar: /[+\-*&%=<>!?|^~:\/]/, +    numberStart: /[\d#$]/, +    number: /^(?:#[\da-fA-F_]+|\$[01_]+|[\d_]+[kMGTPmunpf]?|[\d_]+\.[\d_]+(?:[eE][-+]?\d+|[kMGTPmunpf]|)|)/i, +    multiLineStrings: true, +    typeFirstDefinitions: true, +    atoms: words("true false null larger smaller equal empty finished"), +    indentSwitch: false, +    styleDefs: false, +    hooks: { +      "@": function(stream) { +        stream.eatWhile(/[\w\$_]/); +        return "meta"; +      }, +      '"': function(stream, state) { +          state.tokenize = tokenCeylonString(stream.match('""') ? "triple" : "single"); +          return state.tokenize(stream, state); +        }, +      '`': function(stream, state) { +          if (!stringTokenizer || !stream.match('`')) return false; +          state.tokenize = stringTokenizer; +          stringTokenizer = null; +          return state.tokenize(stream, state); +        }, +      "'": function(stream) { +        stream.eatWhile(/[\w\$_\xa1-\uffff]/); +        return "atom"; +      }, +      token: function(_stream, state, style) { +          if ((style == "variable" || style == "variable-3") && +              state.prevToken == ".") { +            return "variable-2"; +          } +        } +    }, +    modeProps: { +        fold: ["brace", "import"], +        closeBrackets: {triples: '"'} +    } +  }); +  }); diff --git a/public/vendor/codemirror/mode/clike/index.html b/public/vendor/codemirror/mode/clike/index.html index 8b386d22..45c670ae 100755..100644 --- a/public/vendor/codemirror/mode/clike/index.html +++ b/public/vendor/codemirror/mode/clike/index.html @@ -206,6 +206,103 @@ object FilterTest extends App {  }  </textarea></div> +<h2>Kotlin mode</h2> + +<div><textarea id="kotlin-code"> +package org.wasabi.http + +import java.util.concurrent.Executors +import java.net.InetSocketAddress +import org.wasabi.app.AppConfiguration +import io.netty.bootstrap.ServerBootstrap +import io.netty.channel.nio.NioEventLoopGroup +import io.netty.channel.socket.nio.NioServerSocketChannel +import org.wasabi.app.AppServer + +public class HttpServer(private val appServer: AppServer) { + +    val bootstrap: ServerBootstrap +    val primaryGroup: NioEventLoopGroup +    val workerGroup:  NioEventLoopGroup + +    init { +        // Define worker groups +        primaryGroup = NioEventLoopGroup() +        workerGroup = NioEventLoopGroup() + +        // Initialize bootstrap of server +        bootstrap = ServerBootstrap() + +        bootstrap.group(primaryGroup, workerGroup) +        bootstrap.channel(javaClass<NioServerSocketChannel>()) +        bootstrap.childHandler(NettyPipelineInitializer(appServer)) +    } + +    public fun start(wait: Boolean = true) { +        val channel = bootstrap.bind(appServer.configuration.port)?.sync()?.channel() + +        if (wait) { +            channel?.closeFuture()?.sync() +        } +    } + +    public fun stop() { +        // Shutdown all event loops +        primaryGroup.shutdownGracefully() +        workerGroup.shutdownGracefully() + +        // Wait till all threads are terminated +        primaryGroup.terminationFuture().sync() +        workerGroup.terminationFuture().sync() +    } +} +</textarea></div> + +<h2>Ceylon mode</h2> + +<div><textarea id="ceylon-code"> +"Produces the [[stream|Iterable]] that results from repeated + application of the given [[function|next]] to the given + [[first]] element of the stream, until the function first + returns [[finished]]. If the given function never returns  + `finished`, the resulting stream is infinite. + + For example: + +     loop(0)(2.plus).takeWhile(10.largerThan) + + produces the stream `{ 0, 2, 4, 6, 8 }`." +tagged("Streams") +shared {Element+} loop<Element>( +        "The first element of the resulting stream." +        Element first)( +        "The function that produces the next element of the +         stream, given the current element. The function may +         return [[finished]] to indicate the end of the  +         stream." +        Element|Finished next(Element element)) +    => let (start = first) +    object satisfies {Element+} { +        first => start; +        empty => false; +        function nextElement(Element element) +                => next(element); +        iterator() +                => object satisfies Iterator<Element> { +            variable Element|Finished current = start; +            shared actual Element|Finished next() { +                if (!is Finished result = current) { +                    current = nextElement(result); +                    return result; +                } +                else { +                    return finished; +                } +            } +        }; +    }; +</textarea></div> +      <script>        var cEditor = CodeMirror.fromTextArea(document.getElementById("c-code"), {          lineNumbers: true, @@ -232,6 +329,16 @@ object FilterTest extends App {          matchBrackets: true,          mode: "text/x-scala"        }); +      var kotlinEditor = CodeMirror.fromTextArea(document.getElementById("kotlin-code"), { +          lineNumbers: true, +          matchBrackets: true, +          mode: "text/x-kotlin" +      }); +      var ceylonEditor = CodeMirror.fromTextArea(document.getElementById("ceylon-code"), { +          lineNumbers: true, +          matchBrackets: true, +          mode: "text/x-ceylon" +      });        var mac = CodeMirror.keyMap.default == CodeMirror.keyMap.macDefault;        CodeMirror.keyMap.default[(mac ? "Cmd" : "Ctrl") + "-Space"] = "autocomplete";      </script> @@ -247,5 +354,7 @@ object FilterTest extends App {      (Java), <code>text/x-csharp</code> (C#),      <code>text/x-objectivec</code> (Objective-C),      <code>text/x-scala</code> (Scala), <code>text/x-vertex</code> -    and <code>x-shader/x-fragment</code> (shader programs).</p> +    <code>x-shader/x-fragment</code> (shader programs), +    <code>text/x-squirrel</code> (Squirrel) and +    <code>text/x-ceylon</code> (Ceylon)</p>  </article> diff --git a/public/vendor/codemirror/mode/clike/scala.html b/public/vendor/codemirror/mode/clike/scala.html index aa04cf0f..aa04cf0f 100755..100644 --- a/public/vendor/codemirror/mode/clike/scala.html +++ b/public/vendor/codemirror/mode/clike/scala.html diff --git a/public/vendor/codemirror/mode/clike/test.js b/public/vendor/codemirror/mode/clike/test.js index 79b006de..c2600326 100755..100644 --- a/public/vendor/codemirror/mode/clike/test.js +++ b/public/vendor/codemirror/mode/clike/test.js @@ -30,4 +30,22 @@       "  [keyword for] (;;)",       "    [variable x][operator ++];",       "[keyword return];"); + +  MT("preprocessor", +     "[meta #define FOO 3]", +     "[variable-3 int] [variable foo];", +     "[meta #define BAR\\]", +     "[meta 4]", +     "[variable-3 unsigned] [variable-3 int] [variable bar] [operator =] [number 8];", +     "[meta #include <baz> ][comment // comment]") + + +  var mode_cpp = CodeMirror.getMode({indentUnit: 2}, "text/x-c++src"); +  function MTCPP(name) { test.mode(name, mode_cpp, Array.prototype.slice.call(arguments, 1)); } + +  MTCPP("cpp14_literal", +    "[number 10'000];", +    "[number 0b10'000];", +    "[number 0x10'000];", +    "[string '100000'];");  })(); | 
