OLD | NEW |
---|---|
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 1472 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1483 | 1483 |
1484 enum ParserFlag { | 1484 enum ParserFlag { |
1485 kAllowLazy, | 1485 kAllowLazy, |
1486 kAllowNatives, | 1486 kAllowNatives, |
1487 kAllowHarmonyFunctionSent, | 1487 kAllowHarmonyFunctionSent, |
1488 kAllowHarmonyRestrictiveDeclarations, | 1488 kAllowHarmonyRestrictiveDeclarations, |
1489 kAllowHarmonyForIn, | 1489 kAllowHarmonyForIn, |
1490 kAllowHarmonyAsyncAwait, | 1490 kAllowHarmonyAsyncAwait, |
1491 kAllowHarmonyRestrictiveGenerators, | 1491 kAllowHarmonyRestrictiveGenerators, |
1492 kAllowHarmonyTrailingCommas, | 1492 kAllowHarmonyTrailingCommas, |
1493 kAllowHarmonyClassFields, | |
1493 }; | 1494 }; |
1494 | 1495 |
1495 enum ParserSyncTestResult { | 1496 enum ParserSyncTestResult { |
1496 kSuccessOrError, | 1497 kSuccessOrError, |
1497 kSuccess, | 1498 kSuccess, |
1498 kError | 1499 kError |
1499 }; | 1500 }; |
1500 | 1501 |
1501 template <typename Traits> | 1502 template <typename Traits> |
1502 void SetParserFlags(i::ParserBase<Traits>* parser, | 1503 void SetParserFlags(i::ParserBase<Traits>* parser, |
1503 i::EnumSet<ParserFlag> flags) { | 1504 i::EnumSet<ParserFlag> flags) { |
1504 parser->set_allow_lazy(flags.Contains(kAllowLazy)); | 1505 parser->set_allow_lazy(flags.Contains(kAllowLazy)); |
1505 parser->set_allow_natives(flags.Contains(kAllowNatives)); | 1506 parser->set_allow_natives(flags.Contains(kAllowNatives)); |
1506 parser->set_allow_harmony_function_sent( | 1507 parser->set_allow_harmony_function_sent( |
1507 flags.Contains(kAllowHarmonyFunctionSent)); | 1508 flags.Contains(kAllowHarmonyFunctionSent)); |
1508 parser->set_allow_harmony_restrictive_declarations( | 1509 parser->set_allow_harmony_restrictive_declarations( |
1509 flags.Contains(kAllowHarmonyRestrictiveDeclarations)); | 1510 flags.Contains(kAllowHarmonyRestrictiveDeclarations)); |
1510 parser->set_allow_harmony_for_in(flags.Contains(kAllowHarmonyForIn)); | 1511 parser->set_allow_harmony_for_in(flags.Contains(kAllowHarmonyForIn)); |
1511 parser->set_allow_harmony_async_await( | 1512 parser->set_allow_harmony_async_await( |
1512 flags.Contains(kAllowHarmonyAsyncAwait)); | 1513 flags.Contains(kAllowHarmonyAsyncAwait)); |
1513 parser->set_allow_harmony_restrictive_generators( | 1514 parser->set_allow_harmony_restrictive_generators( |
1514 flags.Contains(kAllowHarmonyRestrictiveGenerators)); | 1515 flags.Contains(kAllowHarmonyRestrictiveGenerators)); |
1515 parser->set_allow_harmony_trailing_commas( | 1516 parser->set_allow_harmony_trailing_commas( |
1516 flags.Contains(kAllowHarmonyTrailingCommas)); | 1517 flags.Contains(kAllowHarmonyTrailingCommas)); |
1518 parser->set_allow_harmony_class_fields( | |
1519 flags.Contains(kAllowHarmonyClassFields)); | |
1517 } | 1520 } |
1518 | 1521 |
1519 | 1522 |
1520 void TestParserSyncWithFlags(i::Handle<i::String> source, | 1523 void TestParserSyncWithFlags(i::Handle<i::String> source, |
1521 i::EnumSet<ParserFlag> flags, | 1524 i::EnumSet<ParserFlag> flags, |
1522 ParserSyncTestResult result, | 1525 ParserSyncTestResult result, |
1523 bool is_module = false, | 1526 bool is_module = false, |
1524 bool test_preparser = true) { | 1527 bool test_preparser = true) { |
1525 i::Isolate* isolate = CcTest::i_isolate(); | 1528 i::Isolate* isolate = CcTest::i_isolate(); |
1526 i::Factory* factory = isolate->factory(); | 1529 i::Factory* factory = isolate->factory(); |
(...skipping 3035 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
4562 "while", | 4565 "while", |
4563 "do", | 4566 "do", |
4564 "try", | 4567 "try", |
4565 "catch", | 4568 "catch", |
4566 "finally", | 4569 "finally", |
4567 NULL}; | 4570 NULL}; |
4568 | 4571 |
4569 RunParserSyncTest(context_data, name_data, kSuccess); | 4572 RunParserSyncTest(context_data, name_data, kSuccess); |
4570 } | 4573 } |
4571 | 4574 |
4575 TEST(ClassFieldsNoErrors) { | |
4576 // clang-format off | |
4577 // Tests proposed class fields syntax. | |
4578 const char* context_data[][2] = {{"(class {", "});"}, | |
4579 {"(class extends Base {", "});"}, | |
4580 {"class C {", "}"}, | |
4581 {"class C extends Base {", "}"}, | |
4582 {NULL, NULL}}; | |
4583 const char* class_body_data[] = { | |
4584 // Basic syntax | |
4585 "a = 0;", | |
4586 "a = 0; b", | |
4587 "a = 0; b(){}", | |
4588 "a = 0; *b(){}", | |
4589 "a = 0; ['b'](){}", | |
4590 "a;", | |
4591 "a; b;", | |
4592 "a; b(){}", | |
4593 "a; *b(){}", | |
4594 "a; ['b'](){}", | |
4595 "['a'] = 0;", | |
4596 "['a'] = 0; b", | |
4597 "['a'] = 0; b(){}", | |
4598 "['a'] = 0; *b(){}", | |
4599 "['a'] = 0; ['b'](){}", | |
4600 "['a'];", | |
4601 "['a']; b;", | |
4602 "['a']; b(){}", | |
4603 "['a']; *b(){}", | |
4604 "['a']; ['b'](){}", | |
4605 | |
4606 "0 = 0;", | |
4607 "0;", | |
4608 "'a' = 0;", | |
4609 "'a';", | |
4610 | |
4611 "static a = 0;", | |
4612 "static a;", | |
4613 "static ['a'] = 0", | |
4614 "static ['a']", | |
4615 "static 0 = 0;", | |
4616 "static 0;", | |
4617 "static 'a' = 0;", | |
4618 "static 'a';", | |
4619 | |
4620 // ASI | |
4621 "a = 0\n", | |
4622 "a = 0\n b", | |
4623 "a = 0\n b(){}", | |
4624 "a\n", | |
4625 "a\n b\n", | |
4626 "a\n b(){}", | |
4627 "a\n *b(){}", | |
4628 "a\n ['b'](){}", | |
4629 "['a'] = 0\n", | |
4630 "['a'] = 0\n b", | |
4631 "['a'] = 0\n b(){}", | |
4632 "['a']\n", | |
4633 "['a']\n b\n", | |
4634 "['a']\n b(){}", | |
4635 "['a']\n *b(){}", | |
4636 "['a']\n ['b'](){}", | |
4637 | |
4638 // ASI edge cases | |
4639 "a\n get", | |
4640 "get\n *a(){}", | |
4641 "a\n static", | |
4642 NULL | |
4643 }; | |
4644 // clang-format on | |
4645 | |
4646 static const ParserFlag without_async[] = {kAllowHarmonyClassFields}; | |
4647 RunParserSyncTest(context_data, class_body_data, kSuccess, NULL, 0, | |
4648 without_async, arraysize(without_async)); | |
4649 | |
4650 // clang-format off | |
4651 const char* async_data[] = { | |
4652 "async;", | |
4653 "async = 0;", | |
4654 "static async;" | |
4655 "async", | |
4656 "async = 0", | |
4657 "static async", | |
4658 "async\n a(){}", // a field named async, and a method named a. | |
4659 "async\n a", | |
Dan Ehrenberg
2016/09/06 23:55:59
How about some fields called await?
bakkot
2016/09/07 19:30:12
Done.
| |
4660 NULL | |
4661 }; | |
4662 // clang-format on | |
4663 | |
4664 static const ParserFlag with_async[] = {kAllowHarmonyClassFields, | |
4665 kAllowHarmonyAsyncAwait}; | |
4666 RunParserSyncTest(context_data, async_data, kSuccess, NULL, 0, with_async, | |
4667 arraysize(with_async)); | |
4668 } | |
4669 | |
4670 TEST(ClassFieldsErrors) { | |
4671 // clang-format off | |
4672 // Tests proposed class fields syntax. | |
4673 const char* context_data[][2] = {{"(class {", "});"}, | |
4674 {"(class extends Base {", "});"}, | |
4675 {"class C {", "}"}, | |
4676 {"class C extends Base {", "}"}, | |
4677 {NULL, NULL}}; | |
4678 const char* class_body_data[] = { | |
4679 "a : 0", | |
4680 "a =", | |
4681 "*a = 0", | |
4682 "*a", | |
4683 "get a", | |
4684 "a : 0;", | |
4685 "a =;", | |
4686 "*a = 0;", | |
4687 "*a;", | |
4688 "get a;", | |
4689 | |
4690 // ASI requires a linebreak | |
4691 "a b", | |
4692 "a = 0 b", | |
4693 | |
4694 // ASI requires that the next token is not part of any legal production | |
4695 "a = 0\n *b(){}", | |
4696 "a = 0\n ['b'](){}", | |
4697 "get\n a", | |
Dan Ehrenberg
2016/09/06 23:55:59
How about some fields called yield?
bakkot
2016/09/07 19:30:12
Done. Though these are just property names, and ca
| |
4698 NULL | |
4699 }; | |
4700 // clang-format on | |
4701 | |
4702 static const ParserFlag without_async[] = {kAllowHarmonyClassFields}; | |
4703 RunParserSyncTest(context_data, class_body_data, kError, NULL, 0, | |
4704 without_async, arraysize(without_async)); | |
4705 | |
4706 // clang-format off | |
4707 const char* async_data[] = { | |
4708 "async a = 0", | |
4709 "async a", | |
4710 NULL | |
4711 }; | |
4712 // clang-format on | |
4713 | |
4714 static const ParserFlag with_async[] = {kAllowHarmonyClassFields, | |
4715 kAllowHarmonyAsyncAwait}; | |
4716 RunParserSyncTest(context_data, async_data, kError, NULL, 0, with_async, | |
4717 arraysize(with_async)); | |
4718 } | |
4572 | 4719 |
4573 TEST(ClassExpressionErrors) { | 4720 TEST(ClassExpressionErrors) { |
4574 const char* context_data[][2] = {{"(", ");"}, | 4721 const char* context_data[][2] = {{"(", ");"}, |
4575 {"var C = ", ";"}, | 4722 {"var C = ", ";"}, |
4576 {"bar, ", ";"}, | 4723 {"bar, ", ";"}, |
4577 {NULL, NULL}}; | 4724 {NULL, NULL}}; |
4578 const char* class_data[] = { | 4725 const char* class_data[] = { |
4579 "class", | 4726 "class", |
4580 "class name", | 4727 "class name", |
4581 "class name extends", | 4728 "class name extends", |
(...skipping 3741 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
8323 "(a,);", | 8470 "(a,);", |
8324 "(a,b,c,);", | 8471 "(a,b,c,);", |
8325 NULL | 8472 NULL |
8326 }; | 8473 }; |
8327 // clang-format on | 8474 // clang-format on |
8328 | 8475 |
8329 static const ParserFlag always_flags[] = {kAllowHarmonyTrailingCommas}; | 8476 static const ParserFlag always_flags[] = {kAllowHarmonyTrailingCommas}; |
8330 RunParserSyncTest(context_data, data, kError, NULL, 0, always_flags, | 8477 RunParserSyncTest(context_data, data, kError, NULL, 0, always_flags, |
8331 arraysize(always_flags)); | 8478 arraysize(always_flags)); |
8332 } | 8479 } |
OLD | NEW |