背景

Modelica语言是一种统一面向对象的系统建模语言

官方文档中明确写明了语法规范

在附录的第一章词法,第二章语法都完整的罗列的语言规范,对于Antlr适配特别好

  1. 只需要把[]修改为Antlr的问号'?'
  2. 把{}修改为'*'
  3. 把双引号修改为单引号
  4. 标蓝色的字符串常量增加单引号
  5. 中横线修改为下划线
  6. 增加rule尾部的结束分号
  7. 有些地方的=更换为冒号:

Antlr g4文件如下

grammar Modelica;

stored_definition
:( 'within' ( name )? ';' )? ( ( 'final' )? class_definition ';' )*; class_definition :
( 'encapsulated' )? class_prefixes class_specifier; class_prefixes :
( 'partial' )?
( 'class'
| 'model'
| ( 'operator' )? 'record'
| 'block'
| ( 'expandable' )? 'connector'
| 'type'
| 'package'
| ( 'pure' | 'impure' )? ( 'operator' )? 'function'
| 'operator'
);
class_specifier :
long_class_specifier | short_class_specifier | der_class_specifier;
long_class_specifier :
IDENT description_string composition 'end' IDENT
| 'extends' IDENT ( class_modification )? description_string composition
'end' IDENT;
short_class_specifier :
IDENT '=' base_prefix type_specifier ( array_subscripts )?
( class_modification )? description
| IDENT '=' 'enumeration' '(' ( ( enum_list )? | ':' ) ')' description;
der_class_specifier :
IDENT '=' 'der' '(' type_specifier ' ,' IDENT ( ' ,' IDENT )* ')' description;
base_prefix :
( 'input' | 'output' )?;
enum_list :
enumeration_literal ( ',' enumeration_literal )*;
enumeration_literal :
IDENT description;
composition :
element_list
( 'public' element_list
| 'protected' element_list
| equation_section
| algorithm_section
)*
( 'external' ( language_specification )?
( external_function_call )? ( annotation_clause )? ';' )?
( annotation_clause ';' )?;
language_specification :
STRING;
external_function_call :
( component_reference '=' )?
IDENT '(' ( expression_list )? ') ';
element_list :
( element ';' )*;
element :
import_clause
| extends_clause
| ( 'redeclare' )?
( 'final' )?
( 'inner' )? ( 'outer' )?
( class_definition
| component_clause
| 'replaceable' ( class_definition | component_clause )
( constraining_clause description )?
);
import_clause :
'import'
( IDENT '=' name
| name ( '.*' | '.' ( '*' | '(' import_list ')*' ) )?
)
description;
import_list :
IDENT ( ' ,' IDENT )*; extends_clause :
'extends' type_specifier ( class_modification )? ( annotation_clause )?;
constraining_clause :
'constrainedby' type_specifier ( class_modification )?; component_clause :
type_prefix type_specifier ( array_subscripts )? component_list;
type_prefix :
( 'flow' | 'stream' )?
( 'discrete' | 'parameter' | 'constant' )?
( 'input' | 'output' )?;
component_list :
component_declaration ( ' ,' component_declaration )*;
component_declaration :
declaration ( condition_attribute )? description;
condition_attribute :
'if' expression;
declaration :
IDENT ( array_subscripts )? ( modification )?;
modification :
class_modification ( '=' expression )?
| '=' expression
| ':=' expression;
class_modification :
'(' ( argument_list )? ') ';
argument_list :
argument ( ' ,' argument )*;
argument :
element_modification_or_replaceable
| element_redeclaration;
element_modification_or_replaceable :
( 'each' )? ( 'final' )? ( element_modification | element_replaceable );
element_modification :
name ( modification )? description_string;
element_redeclaration :
'redeclare' ( 'each' )? ( 'final' )?
( short_class_definition | component_clause1 | element_replaceable );
element_replaceable :
'replaceable' ( short_class_definition | component_clause1 )
( constraining_clause )?;
component_clause1 :
type_prefix type_specifier component_declaration1;
component_declaration1 :
declaration description;
short_class_definition :
class_prefixes short_class_specifier; equation_section :
( 'initial' )? equation ( equation ';' )*;
algorithm_section :
( 'initial' )? 'algorithm' ( statement ';' )*;
equation :
( simple_expression '=' expression
| if_equation
| for_equation
| connect_clause
| when_equation
| component_reference function_call_args
)
description;
statement :
( component_reference ( ':=' expression | function_call_args )
| '(' output_expression_list ') ' ':='
component_reference function_call_args
| 'break'
| 'return'
| if_statement
| for_statement
| while_statement
| when_statement
)
description;
if_equation :
'if' expression 'then'
( equation ';' )*
( 'elseif' expression 'then'
( equation ';' )*
)*
( 'else'
( equation ';' )*
)?
'end' 'if';
if_statement :
'if' expression 'then'
( statement ';' )*
( 'elseif' expression 'then'
( statement ';' )*
)*
( 'else'
( statement ';' )*
)?
'end' 'if';
for_equation :
'for' for_indices 'loop'
( equation ';' )*
'end' 'for';
for_statement :
'for' for_indices 'loop'
( statement ';' )*
'end' 'for';
for_indices :
for_index ( ' ,' for_index )*;
for_index :
IDENT ( 'in' expression )?;
while_statement :
'while' expression 'loop'
( statement ';' )*
'end' 'while';
when_equation :
'when' expression 'then'
( equation ';' )*
( 'elsewhen' expression 'then'
( equation ';' )*
)*
'end' 'when';
when_statement :
'when' expression 'then'
( statement ';' )*
( 'elsewhen' expression 'then'
( statement ';' )*
)*
'end' 'when';
connect_clause :
'connect' '(' component_reference ' ,' component_reference ') '; expression :
simple_expression
| 'if' expression 'then' expression
( 'elseif' expression 'then' expression )*
'else' expression;
simple_expression :
logical_expression ( ':' logical_expression ( ':' logical_expression )? )?;
logical_expression :
logical_term ( 'or' logical_term )*;
logical_term :
logical_factor ( 'and' logical_factor )*;
logical_factor :
( 'not' )? relation;
relation :
arithmetic_expression ( relational_operator arithmetic_expression )?;
relational_operator :
' <' | ' <=' | ' >' | ' >=' | '==' | ' < >';
arithmetic_expression :
( add_operator )? term ( add_operator term )*;
add_operator :
'+' | '-' | '.+' | '.-';
term :
factor ( mul_operator factor )*;
mul_operator :
'*' | '/' | '.*' | './';
factor :
primary ( ('^' | '.^') primary )?;
primary :
UNSIGNED_NUMBER
| STRING
| 'false'
| 'true'
| ( component_reference | 'der' | 'initial' | 'pure' ) function_call_args
| component_reference
| '(' output_expression_list ') '
| '(' expression_list ( ';' expression_list )* ')?'
| '(' array_arguments ')*'
| 'end';
UNSIGNED_NUMBER :
UNSIGNED_INTEGER | UNSIGNED_REAL;
type_specifier :
('.')? name;
name :
IDENT ( '.' IDENT )*;
component_reference :
( '.' )? IDENT ( array_subscripts )? ( '.' IDENT ( array_subscripts )? )*;
function_call_args :
'(' ( function_arguments )? ') ';
function_arguments :
expression ( ' ,' function_arguments_non_first | 'for' for_indices )?
| function_partial_application ( ' ,' function_arguments_non_first )?
| named_arguments;
function_arguments_non_first :
function_argument ( ' ,' function_arguments_non_first )?
| named_arguments;
array_arguments :
expression ( ' ,' array_arguments_non_first | 'for' for_indices )?;
array_arguments_non_first :
expression ( ' ,' array_arguments_non_first )?;
named_arguments : named_argument ( ' ,' named_arguments )?;
named_argument : IDENT '=' function_argument;
function_argument :
function_partial_application | expression;
function_partial_application :
'function' type_specifier '(' ( named_arguments )? ') ';
output_expression_list :
( expression )? ( ' ,' ( expression )? )*;
expression_list :
expression ( ' ,' expression )*;
array_subscripts :
'(' subscript ( ' ,' subscript )* ')?';
subscript :
':' | expression;
description :
description_string ( annotation_clause )?;
description_string :
( STRING ( '+' STRING )* )?;
annotation_clause :
'annotation' class_modification; IDENT : NONDIGIT ( DIGIT | NONDIGIT )* | Q_IDENT;
Q_IDENT : '\'' ( Q_CHAR | S_ESCAPE )* '\'';
NONDIGIT : '_' | 'a' .. 'z' | 'A' .. 'Z';
STRING : '"' ( S_CHAR | S_ESCAPE )* '"';
S_CHAR : ~ ["\\] ;
Q_CHAR : NONDIGIT | DIGIT | '!' | '#' | '$' | '%' | '&' | '(' | ')' | '*' | '+' | ',' | '-' | '.' | '/' | ':' | ';' | '<' | '>' | '=' | '?' | '@' | '[' | ']' | '^' | '{' | '}' | '|' | '~' | ' ' | '"';
S_ESCAPE : '\’' | '\"' | '\?' | '\\'
| '\a' | '\b' | '\f' | '\n' | '\r' | '\t' | '\v';
DIGIT : '0' | '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9';
UNSIGNED_INTEGER : DIGIT ( DIGIT )*;
UNSIGNED_REAL :
UNSIGNED_INTEGER '.' ( UNSIGNED_INTEGER )?
| UNSIGNED_INTEGER ( '.' ( UNSIGNED_INTEGER )? )?
( 'e' | 'E' ) ( '+' | '-' )? UNSIGNED_INTEGER
| '.' UNSIGNED_INTEGER ( ( 'e' | 'E' ) ( '+' | '-' )? UNSIGNED_INTEGER )?;

基于Antlr的Modelica3.5语言解析的更多相关文章

  1. atitit.java解析sql语言解析器解释器的实现

    atitit.java解析sql语言解析器解释器的实现 1. 解析sql的本质:实现一个4gl dsl编程语言的编译器 1 2. 解析sql的主要的流程,词法分析,而后进行语法分析,语义分析,构建sq ...

  2. java环境中基于jvm的两大语言:scala,groovy

    一.java环境中基于jvm的两大语言:scala,groovy 可以在java项目里混编这两种语言: scala:静态语言,多范式语言,糅合了面向对象.面向过程:可以与java和net互操作:融汇了 ...

  3. 基于简单sql语句的sql解析原理及在大数据中的应用

    基于简单sql语句的sql解析原理及在大数据中的应用 李万鸿 老百姓呼吁打土豪分田地.共同富裕,总有一天会实现. 全面了解你所不知道的外星人和宇宙真想:http://pan.baidu.com/s/1 ...

  4. 快速开发框架,及库存管理系统,基于easyui框架和C#语言MVC、EntityFrameWork、T4模板技术。

    快速开发框架,及库存管理系统,基于easyui框架和C#语言MVC.EntityFrameWork.T4模板技术. 产品界面如下图所示: 源码结构: 开放全部源码,如有需要请联系,QQ:1107141 ...

  5. C语言解析WAV音频文件

    C语言解析WAV音频文件 代码地址: Github : https://github.com/CasterWx/c-wave-master 目录 前言 了解WAV音频文件 什么是二进制文件 WAV的二 ...

  6. 基于openstack stable queens版本阅读解析

    基于openstack stable queens版本阅读解析 基于 centos7.5 的linux系统 架构 如下所示,为cinder的官方架构说明: 这里写图片描述 各个组件介绍如下: - DB ...

  7. 基于.NET环境,C#语言 实现 TCP NAT

    基于.NET平台和C#语言实现TCP NAT穿越        1.<C# WinForm 跨线程访问控件(实用简洁写法)>       2.<基于.NET环境,C#语言 实现 TC ...

  8. 基于 Asp.Net的 Comet 技术解析

    Comet技术原理 来自维基百科:Comet是一种用于web的技术,能使服务器能实时地将更新的信息传送到客户端,而无须客户端发出请求,目前有两种实现方式,长轮询和iframe流. 简单的说是一种基于现 ...

  9. VBA中使用JavaScript脚本语言解析JSON数据

    JSON:JavaScript 对象表示法(JavaScript Object Notation) 和xml相似,都是文本形式(保存在文本文件中或字符串等形式),比如: jsstr = {" ...

  10. cJSON_json包的C语言解析库

    cJSON库描述 CJSON是一个用于解析JSON包的C语言库,库文件为cJSON.c和cJSON.h, 所有的实现都在这两个文件中.原作者的地址cJSON. JSON包的解析 例如有一个JSON的数 ...

随机推荐

  1. JZOJ 3566. 【GDKOI2014】阶乘

    题目 求十进制 \(n!\) 在 \(m\) 进制下末尾 \(0\) 的个数 分析 签到题 只要看 \(n!\) 有多少个 \(m\) 的倍数就好了 考虑分解 \(m\) 的质因子 然后根号计算每个因 ...

  2. Spring依赖注入问题

    记录一下最近复习的Spirng依赖注入问题 主要介绍两个注入方式 也是用的最多的 1.构造方法注入 2.Setter注入. 参考文档:https://blog.csdn.net/weixin_5541 ...

  3. 跳板攻击之:MSF portfwd 端口转发与端口映射

    跳板攻击之:MSF portfwd 端口转发与端口映射 郑重声明: 本笔记编写目的只用于安全知识提升,并与更多人共享安全知识,切勿使用笔记中的技术进行违法活动,利用笔记中的技术造成的后果与作者本人无关 ...

  4. PG统计信息和系统表

    一.PG统计信息概述 pg的统计信息主要分为两种: 第一类统计信息是是负载指标"统计信息"(Monitoring stats),通过stat collector进程进行实时采集更新 ...

  5. SVN提交到服务器退回至指定版本(撤销操作)

    一.撤销已提交内容如果不小心把修改错误的文件提交到服务器上去了 可对其进行复原(指定单个文件撤销) 解决方法: 查看修改的日志 查看错误提交的文件 可以查看到这个文件改了什么 复原此版本作出的修改 然 ...

  6. ES6的总结的一些数组、字符串方法

    1.数组的方法 unshift() 数组头部添加内容 push() 数组尾部添加内容 pop() 数组尾部删除内容 shift() 数组头部删除内容 sort() 数组排序 a-b 升序 b-a 降序 ...

  7. 【23期】请你谈谈关于IO同步、异步、阻塞、非阻塞的区别

    同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到底有什么区别? 这个问题其实不同的人给 ...

  8. 浅谈 web3

     web3--互联网的未来? web3,很多人觉得是个骗局,是在割韭菜.   因为大部分介绍 web3 的文章都离不开 NFT.数字货币.区块链.比特币.以太坊.元宇宙等概念,玄之又玄,脱离我们的生活 ...

  9. ORA-06502: PL/SQL: numeric or value error: character string buffer too small

    oracle执行报错 ORA-06502: PL/SQL: numeric or value error: character string buffer too small ORA-06512: a ...

  10. md工具

    C:\Users\XJ\AppData\Roaming\Typora 删掉后重新打开就可以使用了,之前做的配置都失效了,需要重新配置:允许折叠大纲,图片存储方式. 把自动检测更新给关闭