Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

git-fastclone

Package Overview
Dependencies
Maintainers
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

git-fastclone

  • 1.5.1
  • Rubygems
  • Socket score

Version published
Maintainers
2
Created
Source

git-fastclone

Twitter: @longboardcat13 License Build Status Gem Version

git-fastclone is git clone --recursive on steroids.

Why fastclone?

Doing lots of repeated checkouts on a specific machine?

Repository1st Fastclone2nd Fastclonegit clonecp -R
angular.js8s3s6s0.5s
bootstrap26s3s11s0.2s
gradle25s9s19s6.2s
linux4m 53s1m 6s3m 51s29s
react.js18s3s8s0.5s
tensorflow19s4s8s1.5s

Above times captured using time without verbose mode.

What does it do?

It creates a reference repo with git clone --mirror in /var/tmp/git-fastclone/reference for each repository and git submodule linked in the main repo. You can control where it puts these by changing the REFERENCE_REPO_DIR environment variable.

It aggressively updates these mirrors from origin and then clones from the mirrors into the directory of your choosing. It always works recursively and multithreaded to get your checkout up as fast as possible.

Detailed explanation here.

Usage

gem install git-fastclone
git fastclone [options] <git-repo-url>

-b, --branch BRANCH              Checkout this branch rather than the default
-v, --verbose                    Verbose mode
    --print_git_errors           Print git output if a command fails
-c, --color                      Display colored output
    --config CONFIG              Git config applied to the cloned repo
    --lock-timeout N             Timeout in seconds to acquire a lock on any reference repo.
            Default is 0 which waits indefinitely.
    --pre-clone-hook command     An optional command that should be invoked before cloning mirror repo

Change the default REFERENCE_REPO_DIR environment variable if necessary.

Cygwin users need to add ~/bin to PATH.

Hooks

  • pre-clone-hook is invoked right before cloning a new mirror repo, which gives a change to prepopulate git's mirror from a different source. The hook is invoked with given arguments:
  1. cloning repo url
  2. path to the repo mirror location
  3. attempt number, 0-indexed

How to test?

Manual testing:

ruby -Ilib bin/git-fastclone <git url>

Compatible with Travis and Kochiku.

Contributing

If you would like to contribute to git-fastclone, you can fork the repository and send us pull requests.

When submitting code, please make every effort to follow existing conventions and style in order to keep the code as readable as possible.

Before accepting any pull requests, we need you to sign an Individual Contributor Agreement (Google form).

Once landed, please reach out to any owner listed in https://rubygems.org/gems/git-fastclone and ask them to help publish the new version.

Acknowledgements

License

Copyright 2015 Square Inc.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

FAQs

Package last updated on 18 Mar 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc