-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
Provide a json output format of cargo package --list
#11666
Comments
Related to #11597, but cc @weihanglo |
Thanks for the proposal! Although this doesn't sound too hard to implement, we should still make sure that we have thought of different workarounds and designs before moving on. For workarounds, off the top of my head there are at least two:
The second one is definitely a feasible option I feel like. For the design of this proposal, I'd like to know apart from the issue from |
For me, this isn't specifically about the readme, but more generally about allowing an external to create a
|
We can't if there are path dependencies without a |
### What does this PR try to resolve? This adds a special case for checking source files are symlinks and have been modified when under a VCS control This is required because those paths may link to a file outside the current package root, but still under the git workdir, affecting the final packaged `.crate` file. ### How should we test and review this PR? Pretty similar to #14966, as a part of #14967. This may have potential performance issue. If a package contains thousands of symlinks, Cargo will fire `git status` for each of them. Not sure if we want to do anything proactively now. The introduction of the `PathEntry` struct gives us more room for storing file metadata to satisfiy use cases in the future. For instances, * Knowing a source file is a symlink and resolving it when packaging on Windows * #5664 * #14965 * Knowing more about a file's metadata (e.g. permission bits from Git) * #4413 * #8006 * Provide richer information for `cargo package --list`, for example JSON output mode * #11666 * #13331 * #13953
Problem
Currently
cargo package --list
outputs filenames line by line, it works fine normally. But whenCargo.toml
contains metadata that uses relative path to point to parent directory, there is no way to get that information. For examplereadme = "../README.md
:cargo package --list
outputsinstead of
It makes sense because it's the filesystem layout in the
.crate
file, but for downstream tooling like maturin it doesn't know that theREADMD.md
is actually coming from../README.md
, which causes PyO3/maturin#1431Proposed Solution
Add a json output format, for example
cargo package --list=json
outputs something likeas proposed by @konstin in PyO3/maturin#1442 (comment)
Notes
No response
The text was updated successfully, but these errors were encountered: