diff options
| author | Li Jin <dragon-fly@qq.com> | 2020-09-11 14:55:22 +0800 |
|---|---|---|
| committer | Li Jin <dragon-fly@qq.com> | 2020-09-11 14:55:22 +0800 |
| commit | dfd4e3b2b2abc0137d26ed3df303a398741bb6a0 (patch) | |
| tree | 59a1690ad02d56d3f303f6ac1dea9e5d6cdc8f20 /src/MoonP | |
| parent | eba73a696c65932534fd5aefbe2ca4c7260c0fb6 (diff) | |
| download | yuescript-dfd4e3b2b2abc0137d26ed3df303a398741bb6a0.tar.gz yuescript-dfd4e3b2b2abc0137d26ed3df303a398741bb6a0.tar.bz2 yuescript-dfd4e3b2b2abc0137d26ed3df303a398741bb6a0.zip | |
add implicit objects support while writing tables.
Diffstat (limited to 'src/MoonP')
| -rw-r--r-- | src/MoonP/moon_ast.h | 8 | ||||
| -rw-r--r-- | src/MoonP/moon_compiler.cpp | 7 | ||||
| -rw-r--r-- | src/MoonP/moon_parser.cpp | 10 | ||||
| -rw-r--r-- | src/MoonP/moon_parser.h | 1 |
4 files changed, 20 insertions, 6 deletions
diff --git a/src/MoonP/moon_ast.h b/src/MoonP/moon_ast.h index 91d7614..16f7801 100644 --- a/src/MoonP/moon_ast.h +++ b/src/MoonP/moon_ast.h | |||
| @@ -527,9 +527,15 @@ AST_NODE(TableLit) | |||
| 527 | AST_MEMBER(TableLit, &sep, &values) | 527 | AST_MEMBER(TableLit, &sep, &values) |
| 528 | AST_END(TableLit) | 528 | AST_END(TableLit) |
| 529 | 529 | ||
| 530 | AST_NODE(TableBlockIndent) | ||
| 531 | ast_ptr<true, Seperator_t> sep; | ||
| 532 | ast_sel_list<false, variable_pair_t, normal_pair_t, TableBlockIndent_t> values; | ||
| 533 | AST_MEMBER(TableBlockIndent, &sep, &values) | ||
| 534 | AST_END(TableBlockIndent) | ||
| 535 | |||
| 530 | AST_NODE(TableBlock) | 536 | AST_NODE(TableBlock) |
| 531 | ast_ptr<true, Seperator_t> sep; | 537 | ast_ptr<true, Seperator_t> sep; |
| 532 | ast_sel_list<false, variable_pair_t, normal_pair_t> values; | 538 | ast_sel_list<false, variable_pair_t, normal_pair_t, TableBlockIndent_t> values; |
| 533 | AST_MEMBER(TableBlock, &sep, &values) | 539 | AST_MEMBER(TableBlock, &sep, &values) |
| 534 | AST_END(TableBlock) | 540 | AST_END(TableBlock) |
| 535 | 541 | ||
diff --git a/src/MoonP/moon_compiler.cpp b/src/MoonP/moon_compiler.cpp index 2f16fff..406b412 100644 --- a/src/MoonP/moon_compiler.cpp +++ b/src/MoonP/moon_compiler.cpp | |||
| @@ -49,7 +49,7 @@ inline std::string s(std::string_view sv) { | |||
| 49 | } | 49 | } |
| 50 | 50 | ||
| 51 | const std::string_view version() { | 51 | const std::string_view version() { |
| 52 | return "0.4.10"sv; | 52 | return "0.4.12"sv; |
| 53 | } | 53 | } |
| 54 | 54 | ||
| 55 | // name of table stored in lua registry | 55 | // name of table stored in lua registry |
| @@ -4608,6 +4608,7 @@ private: | |||
| 4608 | case id<Exp_t>(): transformExp(static_cast<Exp_t*>(pair), temp, ExpUsage::Closure); break; | 4608 | case id<Exp_t>(): transformExp(static_cast<Exp_t*>(pair), temp, ExpUsage::Closure); break; |
| 4609 | case id<variable_pair_t>(): transform_variable_pair(static_cast<variable_pair_t*>(pair), temp); break; | 4609 | case id<variable_pair_t>(): transform_variable_pair(static_cast<variable_pair_t*>(pair), temp); break; |
| 4610 | case id<normal_pair_t>(): transform_normal_pair(static_cast<normal_pair_t*>(pair), temp); break; | 4610 | case id<normal_pair_t>(): transform_normal_pair(static_cast<normal_pair_t*>(pair), temp); break; |
| 4611 | case id<TableBlockIndent_t>(): transformTableBlockIndent(static_cast<TableBlockIndent_t*>(pair), temp); break; | ||
| 4611 | default: assert(false); break; | 4612 | default: assert(false); break; |
| 4612 | } | 4613 | } |
| 4613 | temp.back() = indent() + temp.back() + (pair == pairs.back() ? Empty : s(","sv)) + nll(pair); | 4614 | temp.back() = indent() + temp.back() + (pair == pairs.back() ? Empty : s(","sv)) + nll(pair); |
| @@ -4728,6 +4729,10 @@ private: | |||
| 4728 | addToScope(varName); | 4729 | addToScope(varName); |
| 4729 | } | 4730 | } |
| 4730 | 4731 | ||
| 4732 | void transformTableBlockIndent(TableBlockIndent_t* table, str_list& out) { | ||
| 4733 | transformTable(table, table->values.objects(), out); | ||
| 4734 | } | ||
| 4735 | |||
| 4731 | void transformTableBlock(TableBlock_t* table, str_list& out) { | 4736 | void transformTableBlock(TableBlock_t* table, str_list& out) { |
| 4732 | transformTable(table, table->values.objects(), out); | 4737 | transformTable(table, table->values.objects(), out); |
| 4733 | } | 4738 | } |
diff --git a/src/MoonP/moon_parser.cpp b/src/MoonP/moon_parser.cpp index a13a779..53a6b8f 100644 --- a/src/MoonP/moon_parser.cpp +++ b/src/MoonP/moon_parser.cpp | |||
| @@ -430,12 +430,14 @@ MoonParser::MoonParser() { | |||
| 430 | Space | 430 | Space |
| 431 | ); | 431 | ); |
| 432 | 432 | ||
| 433 | TableBlockInner = Seperator >> KeyValueLine >> *(+(SpaceBreak) >> KeyValueLine); | 433 | TableBlockInner = Seperator >> KeyValueLine >> *(+SpaceBreak >> KeyValueLine); |
| 434 | TableBlock = +(SpaceBreak) >> Advance >> ensure(TableBlockInner, PopIndent); | 434 | TableBlock = +SpaceBreak >> Advance >> ensure(TableBlockInner, PopIndent); |
| 435 | TableBlockIndent = sym('#') >> Seperator >> KeyValueList >> -sym(',') >> | ||
| 436 | -(+SpaceBreak >> Advance >> ensure(KeyValueList >> -sym(',') >> *(+SpaceBreak >> KeyValueLine), PopIndent)); | ||
| 435 | 437 | ||
| 436 | class_member_list = Seperator >> KeyValue >> *(sym(',') >> KeyValue); | 438 | class_member_list = Seperator >> KeyValue >> *(sym(',') >> KeyValue); |
| 437 | ClassLine = CheckIndent >> (class_member_list | Statement) >> -sym(','); | 439 | ClassLine = CheckIndent >> (class_member_list | Statement) >> -sym(','); |
| 438 | ClassBlock = +(SpaceBreak) >> Advance >>Seperator >> ClassLine >> *(+(SpaceBreak) >> ClassLine) >> PopIndent; | 440 | ClassBlock = +SpaceBreak >> Advance >> Seperator >> ClassLine >> *(+SpaceBreak >> ClassLine) >> PopIndent; |
| 439 | 441 | ||
| 440 | ClassDecl = | 442 | ClassDecl = |
| 441 | key("class") >> not_(expr(':')) >> | 443 | key("class") >> not_(expr(':')) >> |
| @@ -489,7 +491,7 @@ MoonParser::MoonParser() { | |||
| 489 | }); | 491 | }); |
| 490 | 492 | ||
| 491 | KeyValueList = KeyValue >> *(sym(',') >> KeyValue); | 493 | KeyValueList = KeyValue >> *(sym(',') >> KeyValue); |
| 492 | KeyValueLine = CheckIndent >> KeyValueList >> -sym(','); | 494 | KeyValueLine = CheckIndent >> (KeyValueList >> -sym(',') | TableBlockIndent); |
| 493 | 495 | ||
| 494 | FnArgDef = (Variable | SelfName) >> -(sym('=') >> Space >> Exp); | 496 | FnArgDef = (Variable | SelfName) >> -(sym('=') >> Space >> Exp); |
| 495 | 497 | ||
diff --git a/src/MoonP/moon_parser.h b/src/MoonP/moon_parser.h index c6a03f8..6b7f224 100644 --- a/src/MoonP/moon_parser.h +++ b/src/MoonP/moon_parser.h | |||
| @@ -264,6 +264,7 @@ private: | |||
| 264 | AST_RULE(existential_op) | 264 | AST_RULE(existential_op) |
| 265 | AST_RULE(TableLit) | 265 | AST_RULE(TableLit) |
| 266 | AST_RULE(TableBlock) | 266 | AST_RULE(TableBlock) |
| 267 | AST_RULE(TableBlockIndent) | ||
| 267 | AST_RULE(class_member_list) | 268 | AST_RULE(class_member_list) |
| 268 | AST_RULE(ClassBlock) | 269 | AST_RULE(ClassBlock) |
| 269 | AST_RULE(ClassDecl) | 270 | AST_RULE(ClassDecl) |
