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

Let cargo use libgit2 to retrieve the cargo package index #32

Closed
1 task
mcdonnnj opened this issue Aug 18, 2022 · 0 comments
Closed
1 task

Let cargo use libgit2 to retrieve the cargo package index #32

mcdonnnj opened this issue Aug 18, 2022 · 0 comments

Comments

@mcdonnnj
Copy link
Member

💡 Summary

The default behavior for cargo is to use the libgit2 library for git operations. This includes retrieving the cargo package index from GitHub. We are currently overriding this behavior to use the git command-line interface instead.

Motivation and context

On non-x86 32-bit systems (linux/arm/v6, linux/arm/v7, and linux/ppc64le) cargo is failing during package index retrieval with the following error: no REF_DELTA found, cannot inject object; class=Indexer (15). This seems to source from libgit2 per this code. No error is observed when forcing cargo to use the git CLI instead. I am unsure if a newer version of libgit2 would resolve this issue but it is observed in the latest version available for the Docker image we are using as our base (python:3.10.5-alpin3.16).

Implementation notes

Test against newer versions of cargo when they become available to see if the following modification can be removed:

Acceptance criteria

  • Without changing the default behavior of cargo Docker images will successfully build on the mentioned platforms.
mcdonnnj added a commit that referenced this issue Aug 28, 2024
In the move from Alpine Linux 3.17 to 3.18 we also moved from Cargo
1.64.0 to 1.71.1. This takes us past 1.68, which introduced sparse
registries, and 1.70, which made `sparse` the default protocol to use
with crates.io (the default registry). This resolves #38, and based on
testing it also resolves #32.
mcdonnnj added a commit that referenced this issue Aug 29, 2024
In the move from Alpine Linux 3.17 to 3.18 we also moved from Cargo
1.64.0 to 1.71.1. This takes us past 1.68, which introduced sparse
registries, and 1.70, which made `sparse` the default protocol to use
with crates.io (the default registry). This resolves #38, and based on
testing it also resolves #32.
mcdonnnj added a commit that referenced this issue Oct 7, 2024
In the move from Alpine Linux 3.17 to 3.18 we also moved from Cargo
1.64.0 to 1.71.1. This takes us past 1.68, which introduced sparse
registries, and 1.70, which made `sparse` the default protocol to use
with crates.io (the default registry). This resolves #38, and based on
testing it also resolves #32.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant