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

cargo vendor loses some nonempty directories #15080

Open
dtolnay opened this issue Jan 18, 2025 · 5 comments
Open

cargo vendor loses some nonempty directories #15080

dtolnay opened this issue Jan 18, 2025 · 5 comments
Labels
C-bug Category: bug Command-vendor S-needs-design Status: Needs someone to work further on the design for the feature or fix. NOT YET accepted.

Comments

@dtolnay
Copy link
Member

dtolnay commented Jan 18, 2025

Problem

For example, this one: https://docs.rs/crate/bat/0.25.0/source/src/syntax_mapping/builtins/macos/

Steps

Confirm this directory exists in the published crate, as shown in the docs.rs link above.

$ curl -L https://crates.io/api/v1/crates/bat/0.25.0/download -o bat-0.25.0.crate

$ tar tf bat-0.25.0.crate bat-0.25.0/src/syntax_mapping/builtins/macos
bat-0.25.0/src/syntax_mapping/builtins/macos/.gitkeep

Now let's try vendoring.

# Cargo.toml
[package]
name = "repro-cargo"
edition = "2021"

[dependencies]
bat = "=0.25.0"
$ cargo vendor

$ ls vendor/bat/src/syntax_mapping/builtins/
bsd-family  common  linux  README.md  unix-family

"macos" is not there.

In bat-0.25.0's case, this actually breaks the crate (when built on macos from vendored sources).

error: failed to run custom build command for `bat v0.25.0`

Caused by:
  process didn't exit successfully: `target/debug/build/bat-126fec914d2804b6/build-script-main` (exit status: 1)
  --- stdout
  cargo:rerun-if-changed=build/
  cargo:rerun-if-changed=src/syntax_mapping/builtins/

  --- stderr
  Error: IO error for operation on src/syntax_mapping/builtins/macos: No such file or directory (os error 2)

  Caused by:
      No such file or directory (os error 2)

Possible Solution(s)

No response

Notes

No response

Version

cargo 1.86.0-nightly (088d49608 2025-01-10)
release: 1.86.0-nightly
commit-hash: 088d496082726091024f1689c124a0c3dccbd775
commit-date: 2025-01-10
host: x86_64-unknown-linux-gnu
libgit2: 1.9.0 (sys:0.20.0 vendored)
libcurl: 8.9.0-DEV (sys:0.4.74+curl-8.9.0 vendored ssl:OpenSSL/1.1.1w)
ssl: OpenSSL 1.1.1w  11 Sep 2023
os: Ubuntu 24.4.0 (noble) [64-bit]
@dtolnay dtolnay added C-bug Category: bug S-triage Status: This issue is waiting on initial triage. labels Jan 18, 2025
@weihanglo
Copy link
Member

It is because of this:

If the package is not in a git repository, all “hidden” files starting with a dot will be skipped

And cargo vendor reuses PathSource::list_files which applies the same rules, hence the bug.

@weihanglo weihanglo added S-needs-design Status: Needs someone to work further on the design for the feature or fix. NOT YET accepted. Command-vendor and removed S-triage Status: This issue is waiting on initial triage. labels Jan 18, 2025
@ehuss
Copy link
Contributor

ehuss commented Jan 18, 2025

Thanks for the report!

We have a number of cargo vendor issues related to it not replicating the contents of the .crate file because it essentially re-computes the list of files. Because the .crate file is no longer in a git repository, that logic changes (in this case, skipping hidden fiels). #14034 (comment) contains some notes about this (there are several other issues as well, though I don't see any mentioning this particular case).

I don't recall if there are any updates since #12509 (comment) about trying to change that.

@ehuss
Copy link
Contributor

ehuss commented Jan 18, 2025

In the short term, if I had to guess, adding the hidden files explicitly to the package.include list might help (but it is too late for me to test that).

@dtolnay
Copy link
Member Author

dtolnay commented Jan 18, 2025

if I had to guess, adding the hidden files explicitly to the package.include list might help

From what I think is an equivalent experiment1, I think it doesn't. Here is what I tried:

Neither crate ended up vendoring .gitignore from the published crate.

Footnotes

  1. .gitignore follows the same logic as .gitkeep?

@ehuss
Copy link
Contributor

ehuss commented Jan 20, 2025

.gitignore is specially handled here where we explicitly exclude it from the vendor output due to bad interactions with git otherwise.

Other filenames like .gitkeep or .foo should work.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
C-bug Category: bug Command-vendor S-needs-design Status: Needs someone to work further on the design for the feature or fix. NOT YET accepted.
Projects
None yet
Development

No branches or pull requests

3 participants