Codemirror:自己的模块关键字

时间:2015-10-02 08:18:10

标签: javascript regex codemirror codemirror-modes

我尝试编写我的owm模块,用于我们自己的codemirror脚本语言。我知道我挂在我们的关键字上。

我有这个测试代码:

Window(EditWin, SELECT_MULTIPLE, NO_SIZE, 310, 87, 500, 60, T("Sitzungsdatum", "Session date"))
{
     Prompt(SessionDatePmt, 11, 4, T("Sitzungsdatum", "Session date"))
     Date(SessionDate, 175, 4, 88)

     Button(SystemDateAsSessionDateBtn, 290, 3, 190, 10, T("Übernehme Systemdatum", "Get system date"))
     [ SELECT: SystemObject Call(SystemDate) PutObject(, SessionDate) ]
}

我们的一些关键字是:

  • 窗口
  • SELECT_MULTIPLE
  • NO_SIZE
  • 提示
  • 日期
  • 按钮
  • 选择
  • SYSTEMOBJECT
  • 呼叫
  • PutObject

对于我的正则表达式,我使用一个名为cons的数组,包含所有关键字。

然后我加入所有这样的阵列:

var keywordRegex = new RegExp("\\b(("+cons.join(")|(")+"))\\b");

直到那里一切正常。我得到的正则表达式在普通的javascript match()中有效。我甚至使用jQuery获取了我的网站文本,而不是使用正则表达式,得到了我想要的内容。

但是,当我这样做时:

if (stream.match(keywordRegex)) return 'keyword';

在Codemirror中,SessionDate的日期也匹配。

这是我的整个Codemirror模式:

(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";
    CodeMirror.defineMode("testmode", function() {
        var cons = ['Window', 'SELECT_MULTIPLE', 'NO_SIZE', 'PROMPT', 'Date', 'Button', 'Select', 'SystemObject', 'Call', 'PutObject'];
        var keywordRegex = new RegExp("\\b(("+cons.join(")|(")+"))\\b");
        var numLiteral = /(-|\+)?([0-9]+(\.[0-9]*)?|0x[0-9a-f]+)/;
        return {
            token: function(stream, state) {
                if (stream.match(/^('([^']|\\.)*'?|"([^"]|\\.)*"?)/))
                    return "string";


                if (stream.match(keywordRegex)) return 'keyword';
                if (stream.match(/({|})/)) return "bracket";
                if (stream.match(numLiteral)) return "number";
                if (stream.match(/(->)/)) return "arrow";


                stream.next();
                return null;
            },
            startState: function() {
              return {
                pair: false,
                pairStart: false,
                keyCol: 0,
                inlinePairs: 0,
                inlineList: 0,
                literal: false,
                escaped: false
              };
            }
        };
    });

    CodeMirror.defineMIME("application/testmode", "testmode");
});

编辑:

根据要求,这里有一名工作人员:

http://plnkr.co/edit/bPyuJd?p=preview

在那里你可以看到,我没有关键字“SessionDate”,但由于关键字“Date”,“SessionDate”的“Date”也会突出显示。

1 个答案:

答案 0 :(得分:2)

我似乎找到了解决问题的方法。有no support for anchors in Code Mirror

  

^正则表达式标记无法正常工作    这个上下文是因为JavaScript的RegExp的局限性    API。)

因此,对于字符串条件的开头和中间字符串位置使用2个正则表达式,对于字符串起始位置,使用stream.sol()检查位置:

var keywordRegex = new RegExp("("+cons.join("|")+")(?=\\W)");
var midkeywordRegex = new RegExp("\\W("+cons.join("|")+")(?=\\W)");

...

if (stream.sol() && stream.match(/('([^']|\\.)*'?|"([^"]|\\.)*"?)/))
    return "iv-string";

if (stream.sol() && stream.match(keywordRegex)) return 'keyword';
if (stream.match(midkeywordRegex)) return 'keyword';

请参阅Updated plunker