Commit 88abfa1
authored
Validate target source paths before compilation with clearer errors (#16338)
### What does this PR try to resolve?
Closes #10173
This PR adds early validation of target source paths with clearer error
messages.
For context, I tried to solve this issue before ( #16329 ) but ended up
making an oversight, I would recommend reading
[this](#10173 (comment))
to understand the issues faced in resolving this.
### So what changed in this PR?
- Root `Target` `Units` are validated early on in the compilation
pipeline when the `BuildContext` is generated
[here](https://github.com/rust-lang/cargo/blob/e0dd406b88933e82136bbc9073e06d029db8da45/src/cargo/ops/cargo_compile/mod.rs#L177).
This is right after command line arguments/manifest targets are parsed
and just before the build tasks are spawned.
- **Cases that are covered by this PR:**
- If the target path is invalid and points to nothing.
- If the target path is valid, but is a directory (not a file)
- If the target path is a valid directory with a `main.rs`/`lib.rs`
depending on the Target kind: In this case a `help:` message is emitted.
Doing this also means that Cargo validates each root target's path that
is requested to be compiled before spawning any build tasks.
This PR enforces the invariant: No compilation occurs before validating
every required target's source path.
I'm not sure if this should be expected behaviour and I'd love to hear
from others on this.File tree
2 files changed
+554
-1
lines changed- src/cargo/ops/cargo_compile
- tests/testsuite
2 files changed
+554
-1
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
60 | 60 | | |
61 | 61 | | |
62 | 62 | | |
63 | | - | |
| 63 | + | |
64 | 64 | | |
65 | 65 | | |
66 | 66 | | |
| |||
535 | 535 | | |
536 | 536 | | |
537 | 537 | | |
| 538 | + | |
| 539 | + | |
| 540 | + | |
| 541 | + | |
| 542 | + | |
| 543 | + | |
| 544 | + | |
| 545 | + | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
538 | 559 | | |
539 | 560 | | |
540 | 561 | | |
| |||
602 | 623 | | |
603 | 624 | | |
604 | 625 | | |
| 626 | + | |
| 627 | + | |
| 628 | + | |
| 629 | + | |
| 630 | + | |
| 631 | + | |
| 632 | + | |
| 633 | + | |
| 634 | + | |
| 635 | + | |
| 636 | + | |
| 637 | + | |
| 638 | + | |
| 639 | + | |
| 640 | + | |
| 641 | + | |
| 642 | + | |
| 643 | + | |
| 644 | + | |
| 645 | + | |
| 646 | + | |
| 647 | + | |
| 648 | + | |
| 649 | + | |
| 650 | + | |
| 651 | + | |
| 652 | + | |
| 653 | + | |
| 654 | + | |
| 655 | + | |
| 656 | + | |
| 657 | + | |
| 658 | + | |
| 659 | + | |
| 660 | + | |
| 661 | + | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
| 694 | + | |
| 695 | + | |
| 696 | + | |
| 697 | + | |
| 698 | + | |
| 699 | + | |
| 700 | + | |
| 701 | + | |
| 702 | + | |
| 703 | + | |
| 704 | + | |
| 705 | + | |
| 706 | + | |
| 707 | + | |
| 708 | + | |
| 709 | + | |
| 710 | + | |
| 711 | + | |
| 712 | + | |
| 713 | + | |
| 714 | + | |
| 715 | + | |
| 716 | + | |
| 717 | + | |
| 718 | + | |
| 719 | + | |
| 720 | + | |
| 721 | + | |
| 722 | + | |
| 723 | + | |
| 724 | + | |
605 | 725 | | |
606 | 726 | | |
607 | 727 | | |
| |||
0 commit comments