Simulink代码生成(十四)——tlc语言常规操作
一、tlc语言常用关键字
- %%为注释
- %为内容
- createrecord为关键字,创建的方式类似rtw形式
- warning可以打印字符,%<>可以进行变量替换
- addtorecord为关键字,可以追加内容
- mergerecord为关键字,可以合并两个RECORD,但是含有相同的域的情况下,只会显示之前RECORD的内容,看例子
- copyrecord为关键字,可以将一个RECORD复制给另一个,注意要先声明,否则会报错
- undef为关键字,可以将RECORD或者其内容进行删除。
- with和endwith为关键字,可以通过这对关键字,进行RECORD内容的访问,结合undef可以删除域等操作。
%%create
%createrecord RECORD{Name "Men";Age 31;SUBRECORD{NO 1}}
%warning %<RECORD>
%createrecord RECORD1{Name "Women";Age 29}
%warning %<RECORD1>
%%add
%addtorecord RECORD Gender "Male"
%addtorecord RECORD.SUBRECORD Gender "Male"
%warning %<RECORD>
%addtorecord RECORD1 Line 10
%warning %<RECORD1>
%%merge 如果相同的域,则只会显示之前的
%mergerecord RECORD RECORD1
%warning %<RECORD>
%%copy
%createrecord RECORD2{}
%copyrecord RECORD2 RECORD1
%warning RECORD = %<RECORD>;RECORD1 = %<RECORD1>;RECORD2 = %<RECORD2>
%%delete 可以通过with访问域,然后删除内容,一定要带endwith
%%undef RECORD2
%%warning RECORD = %<RECORD>;RECORD1 = %<RECORD1>;RECORD2 = %<RECORD2>
%with RECORD1
%undef Name
%endwith
%with RECORD.SUBRECORD
%undef NO
%endwith
%warning RECORD = %<RECORD>;RECORD1 = %<RECORD1>;RECORD2 = %<RECORD2>
输出结果:
Warning: File: course.tlc Line: 3 Column: 2
{ Age 31; Name "Men"; SUBRECORD { NO 1 } }
Warning: File: course.tlc Line: 5 Column: 2
{ Age 29; Name "Women" }
Warning: File: course.tlc Line: 10 Column: 2
{ Age 31; Gender "Male"; Name "Men"; SUBRECORD { Gender "Male"; NO 1 } }
Warning: File: course.tlc Line: 12 Column: 2
{ Age 29; Line 10; Name "Women" }
Warning: File: course.tlc Line: 17 Column: 2
{ Age 31; Gender "Male"; Line 10; Name "Men"; SUBRECORD { Gender "Male"; NO 1 } }
Warning: File: course.tlc Line: 22 Column: 2
RECORD = { Age 31; Gender "Male"; Line 10; Name "Men"; SUBRECORD { Gender "Male"; NO 1 } };RECORD1 = { Age 29; Line 10; Name "Women" };RECORD2 = { Age 29; Line 10; Name "Women" }
Warning: File: course.tlc Line: 35 Column: 2
RECORD = { Age 31; Gender "Male"; Line 10; Name "Men"; SUBRECORD { Gender "Male" } };RECORD1 = { Age 29; Line 10 };RECORD2 = { Age 29; Line 10; Name "Women" }
>>