Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add cargo pkgid support for cargo-script #14961

Open
wants to merge 7 commits into
base: master
Choose a base branch
from

Conversation

Rustin170506
Copy link
Member

@Rustin170506 Rustin170506 commented Dec 19, 2024

What does this PR try to resolve?

close #14831

In this PR, we added the cargo pkgid support for the cargo-script.

For the package itself:

cargo pkgid --manifest-path foo.rs
path+file:///my-project/foo.rs/foo#0.86.0

For its dependence:

cargo pkgid --manifest-path foo.rs -p sqlx
registry+https://github.com/rust-lang/crates.io-index#[email protected]

How should we test and review this PR?

I have updated the unit tests and also added more test cases for it.

Additional information

None

@rustbot
Copy link
Collaborator

rustbot commented Dec 19, 2024

r? @epage

rustbot has assigned @epage.
They will have a look at your PR within the next two weeks and either review your PR or reassign to another reviewer.

Use r? to explicitly pick a reviewer

@rustbot rustbot added A-cli Area: Command-line interface, option parsing, etc. Command-pkgid S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Dec 19, 2024
@epage
Copy link
Contributor

epage commented Dec 19, 2024

Another test we'll need is that we error when a cargo script is specified as a dependency which might become possible with this change.

@Rustin170506 Rustin170506 force-pushed the rustin-patch-pkgid branch 2 times, most recently from 3022d26 to 44ded93 Compare December 19, 2024 15:12
@Rustin170506
Copy link
Member Author

Rustin170506 commented Dec 19, 2024

Another test we'll need is that we error when a cargo script is specified as a dependency which might become possible with this change.

Do you mean by cargo pkgid --manifest-path foo.rs -p foo?

@epage
Copy link
Contributor

epage commented Dec 19, 2024

I mean

[package]
name = "foo"

[dependencies]
bar.path = "bar.rs"

@rustbot

This comment has been minimized.

@Rustin170506
Copy link
Member Author

@epage dedc674 (#14961)

I just did a really rough commit to prove the idea here. It seems to work. But the code is totally messed up.

I want to check two things with you before I move forward and improve the code.

  1. Can you take a grlance at the implementation, I think we have to change the SourceId and PackageIdSpec. I just want to check if I am on the right track.
  2. I am a little hesitant that should we include the filename or just mark it is embedded. Since from the RFC, we don't allow users to specify the name at all, it seems the information is enough to construct the filename. But I also believe that including the full name would be easier to use and expand in the future. So I am not sure what is your thought.

@epage
Copy link
Contributor

epage commented Dec 31, 2024

I am a little hesitant that should we include the filename or just mark it is embedded. Since from the RFC, we don't allow users to specify the name at all, it seems the information is enough to construct the filename. B

The RFC says package.name is defaulted but users can set it.

package.name cannot be mapped unambiguously back to a file name because we sanitize it

let name = sanitize_name(file_stem.as_ref());

/// Ensure the package name matches the validation from `ops::cargo_new::check_name`
fn sanitize_name(name: &str) -> String {
let placeholder = if name.contains('_') {
'_'
} else {
// Since embedded manifests only support `[[bin]]`s, prefer arrow-case as that is the
// more common convention for CLIs
'-'
};
let mut name = PackageName::sanitize(name, placeholder).into_inner();
loop {
if restricted_names::is_keyword(&name) {
name.push(placeholder);
} else if restricted_names::is_conflicting_artifact_name(&name) {
// Being an embedded manifest, we always assume it is a `[[bin]]`
name.push(placeholder);
} else if name == "test" {
name.push(placeholder);
} else if restricted_names::is_windows_reserved(&name) {
// Go ahead and be consistent across platforms
name.push(placeholder);
} else {
break;
}
}
name
}

@epage
Copy link
Contributor

epage commented Dec 31, 2024

Can you take a grlance at the implementation, I think we have to change the SourceId and PackageIdSpec. I just want to check if I am on the right track.

    // FIXME: It should be `path+[ROOTURL]/foo#[email protected]`.
    p.cargo("-Zscript pkgid --manifest-path script.rs")
        .masquerade_as_nightly_cargo(&["script"])
        .with_stdout_data(str![[r#"
path+[ROOTURL]/foo#[email protected]
"#]])

this should instead be

    // FIXME: It should be `path+[ROOTURL]/foo/script.rs#0.0.0`.
    p.cargo("-Zscript pkgid --manifest-path script.rs")
        .masquerade_as_nightly_cargo(&["script"])
        .with_stdout_data(str![[r#"
path+[ROOTURL]/foo/script.rs#0.0.0
"#]])

according to #14831 (comment)

Switching to that scheme should simplify the code, not requiring updates to PackageIdSpec, PackageId, or SourceId struct fields, only functions

@Rustin170506
Copy link
Member Author

The RFC says package.name is defaulted but users can set it.

Oh, I misunderstood package.name = <slugified file stem>. I thought it always used the file name.

package.name cannot be mapped unambiguously back to a file name because we sanitize it

Yes. Got it.

@Rustin170506
Copy link
Member Author

Rustin170506 commented Jan 2, 2025

this should instead be

    // FIXME: It should be `path+[ROOTURL]/foo/script.rs#0.0.0`.
    p.cargo("-Zscript pkgid --manifest-path script.rs")
        .masquerade_as_nightly_cargo(&["script"])
        .with_stdout_data(str![[r#"
path+[ROOTURL]/foo/script.rs#0.0.0
"#]])

according to #14831 (comment)

Switching to that scheme should simplify the code, not requiring updates to PackageIdSpec, PackageId, or SourceId struct fields, only functions

So I guess if the package name is foo, then we have:

path+[ROOTURL]/foo/script.rs#foo@0.0.0

@epage
Copy link
Contributor

epage commented Jan 2, 2025

So I guess if the package name is foo, then we have:

path+[ROOTURL]/foo/script.rs#foo@0.0.0

If the user explicitly overrode it, yes

@Rustin170506 Rustin170506 force-pushed the rustin-patch-pkgid branch 2 times, most recently from c10754e to 6659d5f Compare January 2, 2025 15:16
src/cargo/core/workspace.rs Outdated Show resolved Hide resolved
@Rustin170506 Rustin170506 force-pushed the rustin-patch-pkgid branch 2 times, most recently from d10f797 to fc25d9d Compare January 2, 2025 15:18
@Rustin170506 Rustin170506 changed the title NOT READY FOR REVIEW : feat: add cargo pkgid support for cargo-script feat: add cargo pkgid support for cargo-script Jan 2, 2025
@Rustin170506 Rustin170506 force-pushed the rustin-patch-pkgid branch 3 times, most recently from 749889c to 82cbacd Compare January 9, 2025 15:20
@Rustin170506 Rustin170506 marked this pull request as ready for review January 9, 2025 17:04
@Rustin170506 Rustin170506 marked this pull request as draft January 10, 2025 15:28
@Rustin170506 Rustin170506 force-pushed the rustin-patch-pkgid branch 2 times, most recently from e98e69a to 6982520 Compare January 11, 2025 15:26
@Rustin170506 Rustin170506 force-pushed the rustin-patch-pkgid branch 2 times, most recently from 497943e to b62a3bc Compare January 11, 2025 16:31
Copy link
Member Author

@Rustin170506 Rustin170506 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🔢 Self-check (PR reviewed by myself and ready for feedback.)

@@ -124,6 +124,9 @@ impl<'gctx> PathSource<'gctx> {
}

fn read_package(&self) -> CargoResult<Package> {
if crate::util::toml::is_embedded(&self.path) {
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not sure if this is the best place to check this. Maybe we should move it to where we create the source ID?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

imo this feels too spooky as this function is not directly tied to dependencies.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Then I guess we should do the check when we read the manifest file.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Or the dependency resolution phase. Maybe do it when resolving dependencies makes more sense.

@Rustin170506 Rustin170506 marked this pull request as ready for review January 15, 2025 15:36
@Rustin170506 Rustin170506 requested a review from epage January 15, 2025 15:36
Comment on lines +274 to 277
ws.packages
.packages
.insert(ws.current_manifest.clone(), package);
ws.target_dir = if let Some(dir) = target_dir {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does this reformatting belong on the previous commit?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oops. I squashed it into the wrong commit.

@@ -1370,6 +1370,47 @@ registry+https://github.com/rust-lang/crates.io-index#[email protected]
.run();
}

#[cargo_test(nightly, reason = "edition2024 hasn't hit stable yet")]
fn script_as_dep() {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a reason this test wasn't added before the feature commit?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just want to make sure it already has an error for it. The feature is just to improve the error message.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-cli Area: Command-line interface, option parsing, etc. A-manifest Area: Cargo.toml issues A-workspaces Area: workspaces Command-install Command-pkgid Command-uninstall S-waiting-on-review Status: Awaiting review from the assignee but also interested parties.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add cargo pkgid for cargo-script
3 participants