较少文件的语法验证器

时间:2015-06-23 11:11:01

标签: javascript node.js npm less antlr

我需要一个较少文件的验证器。我需要在语法级别验证一个较少的文件。

我无法让验证程序遵循依赖关系或检测是否声明了mixin。这是我真正的问题。

我发现很多较少的处理器都会失败,因为该文件具有我在此过程中无法提供的依赖性。

npm包将是完美的。

1 个答案:

答案 0 :(得分:2)

最后,我决定使用antlr4

步骤:

  • 在计算机中安装antlr或添加到部署过程
  • 获取您的语言的语法(已经完成的工作少)
  • 获取npm包来处理语法
  • 在您的应用中使用

配置为:

$ cd /usr/local/lib
$ sudo curl -O http://www.antlr.org/download/antlr-4.5-complete.jar
$ export CLASSPATH=".:/usr/local/lib/antlr-4.5-complete.jar:$CLASSPATH"
$ alias antlr4='java -jar /usr/local/lib/antlr-4.5-complete.jar'
$ alias grun='java org.antlr.v4.runtime.misc.TestRig

此信息直接来自网页。

现在您可以从https://github.com/antlr/grammars-v4

获取语法

此时您可以generate the javascript version of your grammar

就我而言,我创建了一个目录,我下载了文件并编写了所有测试内容:

antlr4 -Dlanguage=JavaScript LessParser.g4
antlr4 -Dlanguage=JavaScript LessLexer.g4

此过程会生成您将使用的javascript文件,但您需要使用antlr lib在节点程序中使用此文件。

npm link antlr4

Ant现在开始编码:

var antlr4 = require('antlr4/index');
var MyGrammarLexer = require('./LessLexer.js');
var MyGrammarParser = require('./LessParser.js');
var input = "html{ .hey(); color: @light-blue; background:#333}";
var chars = new antlr4.InputStream(input);
var lexer = new MyGrammarLexer.LessLexer(chars);
var tokens  = new antlr4.CommonTokenStream(lexer);
var parser = new MyGrammarParser.LessParser(tokens);
parser.buildParseTrees = true;


var ErrorListener = antlr4.error.ErrorListener;
function CustomErrorListener() {
   ErrorListener.call(this);
   return this;
}

CustomErrorListener.prototype = Object.create(ErrorListener.prototype);
CustomErrorListener.prototype.constructor = CustomErrorListener;
CustomErrorListener.prototype.syntaxError = function(recognizer, offendingSymbol, line, column, msg, e) {
    throw ('throw a simple exception');
};

parser.addErrorListener(new CustomErrorListener());

try{
  var tree = parser.stylesheet();
} catch (e){
  console.log('I catch you!!!')
}

此代码中的重要部分是函数lessLexer,lessParser和parser.stylesheet();每种语法都不同。最后一个很难知道,但这是你要验证的语法点。在我的例子中,我得到文件LessParser.g4,你在定义中的语法中有不同的节点:

parser grammar LessParser;

options { tokenVocab=LessLexer; }

stylesheet
  : statement*
  ;

statement
  : importDeclaration
  | ruleset
  | variableDeclaration ';'
  | mixinDefinition
  ;

variableName
  : AT variableName
  | AT Identifier
  ;

commandStatement
  : (expression+) mathStatement?
  ;

mathCharacter
  : TIMES | PLUS | DIV | MINUS | PERC
  ;

在这种情况下,您可以像样式表,语句,变量名...

一样验证字符串

最后一个有趣的点是错误验证,我用它来阻止第一个错误的验证,我的情况很简单,但你可以改进这一点