Commit 4c34e4b
committed
Diagnose and recover from bad module selectors
Specifically, from module selectors at incorrect locations. This is done through a couple of mechanisms:
• The various `expect(…)` methods consume a module selector as unexpected syntax.
• Various identifier-parsing productions now pre-parse an invalid module selector and convert it to unexpected syntax. In some cases this involves adjusting matching `can`/`at` methods to consume otherwise-invalid module selectors.
• The previously-introduced `attach(_:to:)` mechanism is now used in more places.
This makes all test cases inherited from the Swift tests pass, except for the `import` syntax which I’m a little iffy on.1 parent 97513d6 commit 4c34e4b
File tree
11 files changed
+132
-75
lines changed- Sources/SwiftParser
- Tests/SwiftParserTest/translated
11 files changed
+132
-75
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
741 | 741 | | |
742 | 742 | | |
743 | 743 | | |
744 | | - | |
| 744 | + | |
745 | 745 | | |
746 | 746 | | |
747 | 747 | | |
748 | 748 | | |
749 | 749 | | |
750 | 750 | | |
751 | 751 | | |
752 | | - | |
| 752 | + | |
| 753 | + | |
753 | 754 | | |
754 | 755 | | |
755 | 756 | | |
| |||
759 | 760 | | |
760 | 761 | | |
761 | 762 | | |
762 | | - | |
| 763 | + | |
763 | 764 | | |
764 | 765 | | |
765 | 766 | | |
766 | 767 | | |
767 | 768 | | |
768 | 769 | | |
769 | 770 | | |
770 | | - | |
| 771 | + | |
| 772 | + | |
771 | 773 | | |
772 | 774 | | |
773 | 775 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
355 | 355 | | |
356 | 356 | | |
357 | 357 | | |
358 | | - | |
| 358 | + | |
359 | 359 | | |
360 | 360 | | |
361 | 361 | | |
362 | 362 | | |
| 363 | + | |
363 | 364 | | |
364 | 365 | | |
365 | 366 | | |
| |||
427 | 428 | | |
428 | 429 | | |
429 | 430 | | |
430 | | - | |
| 431 | + | |
431 | 432 | | |
432 | 433 | | |
433 | 434 | | |
| 435 | + | |
434 | 436 | | |
435 | 437 | | |
436 | 438 | | |
| |||
1232 | 1234 | | |
1233 | 1235 | | |
1234 | 1236 | | |
1235 | | - | |
| 1237 | + | |
1236 | 1238 | | |
1237 | 1239 | | |
1238 | 1240 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1899 | 1899 | | |
1900 | 1900 | | |
1901 | 1901 | | |
1902 | | - | |
1903 | | - | |
1904 | | - | |
1905 | | - | |
1906 | | - | |
1907 | | - | |
1908 | | - | |
1909 | | - | |
| 1902 | + | |
1910 | 1903 | | |
1911 | 1904 | | |
1912 | 1905 | | |
| |||
2031 | 2024 | | |
2032 | 2025 | | |
2033 | 2026 | | |
2034 | | - | |
| 2027 | + | |
2035 | 2028 | | |
2036 | 2029 | | |
2037 | 2030 | | |
| |||
2114 | 2107 | | |
2115 | 2108 | | |
2116 | 2109 | | |
2117 | | - | |
| 2110 | + | |
2118 | 2111 | | |
2119 | | - | |
2120 | 2112 | | |
2121 | 2113 | | |
2122 | 2114 | | |
| |||
2616 | 2608 | | |
2617 | 2609 | | |
2618 | 2610 | | |
| 2611 | + | |
2619 | 2612 | | |
2620 | 2613 | | |
2621 | 2614 | | |
| |||
2632 | 2625 | | |
2633 | 2626 | | |
2634 | 2627 | | |
| 2628 | + | |
2635 | 2629 | | |
2636 | 2630 | | |
2637 | 2631 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
21 | 26 | | |
22 | | - | |
| 27 | + | |
23 | 28 | | |
24 | | - | |
| 29 | + | |
25 | 30 | | |
26 | | - | |
| 31 | + | |
27 | 32 | | |
28 | 33 | | |
29 | 34 | | |
30 | 35 | | |
| 36 | + | |
31 | 37 | | |
32 | | - | |
| 38 | + | |
33 | 39 | | |
34 | 40 | | |
35 | 41 | | |
36 | | - | |
| 42 | + | |
37 | 43 | | |
38 | 44 | | |
39 | 45 | | |
40 | 46 | | |
41 | | - | |
| 47 | + | |
42 | 48 | | |
43 | | - | |
| 49 | + | |
44 | 50 | | |
45 | 51 | | |
46 | 52 | | |
| |||
405 | 411 | | |
406 | 412 | | |
407 | 413 | | |
408 | | - | |
| 414 | + | |
409 | 415 | | |
410 | 416 | | |
411 | 417 | | |
| |||
526 | 532 | | |
527 | 533 | | |
528 | 534 | | |
| 535 | + | |
529 | 536 | | |
530 | 537 | | |
531 | 538 | | |
| |||
543 | 550 | | |
544 | 551 | | |
545 | 552 | | |
546 | | - | |
| 553 | + | |
547 | 554 | | |
548 | 555 | | |
549 | 556 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
298 | 298 | | |
299 | 299 | | |
300 | 300 | | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
301 | 307 | | |
302 | 308 | | |
303 | 309 | | |
304 | 310 | | |
305 | | - | |
| 311 | + | |
| 312 | + | |
306 | 313 | | |
307 | 314 | | |
308 | 315 | | |
309 | 316 | | |
310 | | - | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
311 | 326 | | |
312 | 327 | | |
313 | 328 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
560 | 560 | | |
561 | 561 | | |
562 | 562 | | |
| 563 | + | |
563 | 564 | | |
564 | 565 | | |
565 | 566 | | |
566 | 567 | | |
| 568 | + | |
567 | 569 | | |
568 | | - | |
| 570 | + | |
569 | 571 | | |
570 | 572 | | |
571 | 573 | | |
572 | 574 | | |
573 | | - | |
| 575 | + | |
574 | 576 | | |
575 | | - | |
| 577 | + | |
576 | 578 | | |
577 | 579 | | |
578 | 580 | | |
| |||
581 | 583 | | |
582 | 584 | | |
583 | 585 | | |
| 586 | + | |
| 587 | + | |
584 | 588 | | |
585 | 589 | | |
586 | 590 | | |
| |||
599 | 603 | | |
600 | 604 | | |
601 | 605 | | |
| 606 | + | |
| 607 | + | |
602 | 608 | | |
603 | 609 | | |
604 | 610 | | |
| |||
619 | 625 | | |
620 | 626 | | |
621 | 627 | | |
| 628 | + | |
| 629 | + | |
622 | 630 | | |
623 | 631 | | |
624 | 632 | | |
| |||
633 | 641 | | |
634 | 642 | | |
635 | 643 | | |
| 644 | + | |
| 645 | + | |
| 646 | + | |
| 647 | + | |
| 648 | + | |
| 649 | + | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
636 | 653 | | |
637 | 654 | | |
638 | 655 | | |
| |||
652 | 669 | | |
653 | 670 | | |
654 | 671 | | |
| 672 | + | |
| 673 | + | |
655 | 674 | | |
656 | 675 | | |
657 | 676 | | |
658 | 677 | | |
659 | 678 | | |
660 | 679 | | |
| 680 | + | |
| 681 | + | |
661 | 682 | | |
662 | 683 | | |
663 | 684 | | |
| |||
691 | 712 | | |
692 | 713 | | |
693 | 714 | | |
| 715 | + | |
| 716 | + | |
694 | 717 | | |
695 | 718 | | |
696 | 719 | | |
697 | 720 | | |
698 | 721 | | |
| 722 | + | |
| 723 | + | |
699 | 724 | | |
700 | | - | |
| 725 | + | |
701 | 726 | | |
702 | 727 | | |
703 | | - | |
| 728 | + | |
704 | 729 | | |
705 | 730 | | |
706 | 731 | | |
707 | 732 | | |
708 | 733 | | |
709 | 734 | | |
710 | 735 | | |
711 | | - | |
| 736 | + | |
712 | 737 | | |
713 | 738 | | |
714 | 739 | | |
715 | | - | |
| 740 | + | |
716 | 741 | | |
717 | 742 | | |
718 | 743 | | |
719 | 744 | | |
720 | 745 | | |
721 | | - | |
| 746 | + | |
722 | 747 | | |
723 | 748 | | |
724 | 749 | | |
| |||
727 | 752 | | |
728 | 753 | | |
729 | 754 | | |
730 | | - | |
| 755 | + | |
731 | 756 | | |
732 | 757 | | |
733 | 758 | | |
734 | 759 | | |
735 | | - | |
| 760 | + | |
736 | 761 | | |
737 | 762 | | |
738 | 763 | | |
| |||
0 commit comments