-
Notifications
You must be signed in to change notification settings - Fork 229
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
Add a shallow-clone option for git packages #3556
Comments
This is a private package right? And the issue is that it's large, thus, the git-dependency with full clone takes up a lot of space and bandwidth. So is to correct that the possible solutions might be:
I'm curious, if you have multiple Dart SDKs installed. How shallow clones affect the PUB_CACHE and how will an old Dart SDK interact with it? Also how do git shallow clones actually work? How shallow are they? What does the depth mean, and when is that sensible? Are they supported by all git versions, or will we need feature detection? Should we migrate to only use shallow clones? Or is full clones still sensible in some scenarios. Sorry, for the dumb questions, I'm not fully versed in all details of modern git. And anything that changes layout in |
Hi @jonasfj , I think most of your questions are valid. I am not sure the following options you suggested below will resolve the issue because we will still need to pull a large history of our repository.
About this question:
The project using an older version of Dart will use the same version of the package cached in PUB_CACHE. The only difference between the mirror cloned and shallow cloned version is that the shallow cloned package will have a small history or commits than the mirror clone. This how the depth option works:
It basically allow us to pull a specific number of commit instead of fetching the entire git repository history.
Basically the idea is to make a mirror clone when the shallow-clone option is not provided i.e we make mirror clone the default strategy for fetching git packages and only make a git shallow clone when the shallow-clone option is provided. |
I get that, my question is if it's better to always make a shallow clone. |
Would certainly alleviate concerns about having a huge git history. |
I am not sure if it is best to always make a shallow clone but I think it will be good to have an option to make a shallow clone when making a mirror clone becomes infeasible. |
Any update on this? |
Reading this: https://github.blog/2020-12-21-get-up-to-speed-with-partial-clone-and-shallow-clone/ made me think that partial blob-less clones or maybe even partial tree-less clones might work well for pub. That would save a lot of bandwidth, while working well with how eg. github is serving repos. I guess there is still a lot of questions to answer before attempting this.
|
We have the same issue where we have a couple of private dependencies hosted on GitHub, and one of them has a huge history, which makes pub get slow. It would be great if we had a shallow clone option. If I'm not mistaken, the way git source dependencies are currently cloned involves cloning the repository with the entire history and then checking out the specific ref. Would there be any issues if we cloned with the ref using --depth 1? I know that's a stupid question—it has been discussed above—but I need assistance in identifying the test cases if I propose this solution as an optional parameter. |
As I understand it, |
I looked a bit into how go is doing it. We can probably learn something! Instead of running clone, they do a and fetches HEADs and tags with --depth=1 Maybe that is the right way to go. Combined with #3806 ... |
At my company we are currently combining unity with flutter through https://pub.dev/packages/flutter_unity_widget and we host the unity widget dependency on a git repo. It gets big really quickly and we have to keep deleting tags.
I would like to submit a PR that allows a user to notify Pub to make a shallow clone of a Git repository instead of a mirror clone of the remote repository.
For example a user could use the following command:
dart pub add http --git-url=https://github.com/my/http.git --git-ref=tmpfixes --git-shallow-clone=true
or inside the pubspec.yaml file
There is also the possibility of specifying the depth of the shallow clone like so, instead of passing a boolean flag:
dart pub add http --git-url=https://github.com/my/http.git --git-ref=tmpfixes --git-shallow-clone=1
or inside the pubspec.yaml file
There is a similar issue here: #2686.
The text was updated successfully, but these errors were encountered: