Skip to content

Commit

Permalink
Fix for #2496:
Browse files Browse the repository at this point in the history
- Changed Susan syntax for arrays from Type[:] to array<Type>.


git-svn-id: https://openmodelica.org/svn/OpenModelica/trunk@18371 f25d12d1-65f4-0310-ae8a-bbce733d8d8e
  • Loading branch information
perost committed Dec 2, 2013
1 parent 7e83e90 commit 1529a80
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 42 deletions.
2 changes: 1 addition & 1 deletion Compiler/Template/SimCodeTV.mo
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@ package builtin

function arrayList
replaceable type TypeVar subtypeof Any;
input TypeVar[:] arr;
input array<TypeVar> arr;
output list<TypeVar> lst;
end arrayList;

Expand Down
54 changes: 13 additions & 41 deletions Compiler/Template/TplParser.mo
Original file line number Diff line number Diff line change
Expand Up @@ -1324,11 +1324,7 @@ algorithm
end matchcontinue;
end unqualImportPostfix;

/*
//optional, may fail
typeSig:
typeSig_base:base typeSig_array(base):ts => ts
*/
public function typeSig
input list<String> inChars;
input LineInfo inLineInfo;
Expand All @@ -1341,13 +1337,12 @@ algorithm
local
list<String> chars;
LineInfo linfo;
TplAbsyn.TypeSignature baseTS, ts;
TplAbsyn.TypeSignature ts;

case (chars, linfo)
equation
(chars, linfo, baseTS) = typeSig_base(chars, linfo);
(chars, linfo, ts) = typeSig_base(chars, linfo);
(chars, linfo) = interleave(chars, linfo);
(chars, linfo, ts) = typeSig_array(chars, linfo, baseTS);
then (chars, linfo, ts);

end match;
Expand Down Expand Up @@ -1389,6 +1384,8 @@ typeSig_base:
|
'tuple' '<' typeSig:ts typeSig_restList:restLst '>' => TUPLE_TYPE(ts::restLst)
|
'array' '<' typeSig:tof '>' => ARRAY_TYPE(tof)
|
pathIdent:pid => NAMED_TYPE(pid) // +specializations for String, Integer, .... => STRING_TYPE(), ...
*/
public function typeSig_base
Expand Down Expand Up @@ -1436,6 +1433,15 @@ algorithm
(chars, linfo) = interleaveExpectChar(chars, linfo, ">");
then (chars, linfo, TplAbsyn.TUPLE_TYPE(tof::restLst));

case ("a"::"r"::"r"::"a"::"y" :: chars, linfo)
equation
afterKeyword(chars);
(chars, linfo) = interleaveExpectChar(chars, linfo, "<");
(chars, linfo) = interleave(chars, linfo);
(chars, linfo, tof) = typeSigNoOpt(chars, linfo);
(chars, linfo) = interleaveExpectChar(chars, linfo, ">");
then (chars, linfo, TplAbsyn.ARRAY_TYPE(tof));

case (chars, linfo)
equation
(chars, linfo, pid) = pathIdent(chars, linfo);
Expand All @@ -1445,40 +1451,6 @@ algorithm
end matchcontinue;
end typeSig_base;

/*
typeSig_array(base):
'[' ':' ']' typeSig_array(ARRAY_TYPE(base)):ts => ts
|
_ => base
*/
public function typeSig_array
input list<String> inChars;
input LineInfo inLineInfo;
input TplAbsyn.TypeSignature inBaseTypeSignature;

output list<String> outChars;
output LineInfo outLineInfo;
output TplAbsyn.TypeSignature outTypeSignature;
algorithm
(outChars, outLineInfo, outTypeSignature) := matchcontinue (inChars, inLineInfo, inBaseTypeSignature)
local
list<String> chars;
LineInfo linfo;
TplAbsyn.TypeSignature ts, baseTS;

case ("[" :: chars, linfo, baseTS)
equation
(chars, linfo) = interleaveExpectChar(chars, linfo, ":");
(chars, linfo) = interleaveExpectChar(chars, linfo, "]");
(chars, linfo) = interleave(chars, linfo);
(chars, linfo, ts) = typeSig_array(chars, linfo, TplAbsyn.ARRAY_TYPE(baseTS));
then (chars, linfo, ts);

case (chars, linfo, baseTS) then (chars, linfo, baseTS);

end matchcontinue;
end typeSig_array;

/*
typeSig_restList:
',' typeSig:ts typeSig_restList:restLst => ts::restLst
Expand Down

0 comments on commit 1529a80

Please sign in to comment.