Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Rich-Harris/degit
Straightforward project scaffolding
https://github.com/Rich-Harris/degit
Last synced: 3 months ago
JSON representation
Straightforward project scaffolding
- Host: GitHub
- URL: https://github.com/Rich-Harris/degit
- Owner: Rich-Harris
- License: mit
- Created: 2017-07-31T17:44:38.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-01-27T07:20:31.000Z (12 months ago)
- Last Synced: 2024-04-14T11:59:00.729Z (9 months ago)
- Language: JavaScript
- Size: 681 KB
- Stars: 6,625
- Watchers: 34
- Forks: 227
- Open Issues: 87
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome - Rich-Harris/degit - Straightforward project scaffolding (JavaScript)
- awesome-nodejs - degit - Degit makes copies of git repositories. Straightforward project scaffolding. ![](https://img.shields.io/github/stars/Rich-Harris/degit.svg?style=social&label=Star) (Repository / Git)
- awesome-web-cn - degit - 用于下载 git 仓库,相比于单纯的 git 命令,他下载速度更快,而且不会有.git 文件夹,可以用于脚手架中下载代码模版 (Uncategorized / Uncategorized)
- awesome-ccamel - Rich-Harris/degit - Straightforward project scaffolding (JavaScript)
- awesome-github-repos - Rich-Harris/degit - Straightforward project scaffolding (JavaScript)
- awesome-list - degit - Harris | 3274 | (JavaScript)
- awesome - degit - `git clone && rm -fr .git` (Developer Experience (DX))
- awesome-fe-resources - degit
- awesome-starred - Rich-Harris/degit - Straightforward project scaffolding (others)
README
# degit — straightforward project scaffolding
[![Travis CI build status](https://badgen.net/travis/Rich-Harris/degit/master)](https://travis-ci.org/Rich-Harris/degit)
[![AppVeyor build status](https://badgen.net/appveyor/ci/Rich-Harris/degit/master)](https://ci.appveyor.com/project/Rich-Harris/degit/branch/master)
[![Known Vulnerabilities](https://snyk.io/test/npm/degit/badge.svg)](https://snyk.io/test/npm/degit)
[![install size](https://badgen.net/packagephobia/install/degit)](https://packagephobia.now.sh/result?p=degit)
[![npm package version](https://badgen.net/npm/v/degit)](https://npm.im/degit)
[![Contributor Covenant](https://img.shields.io/badge/Contributor%20Covenant-v1.4%20adopted-ff69b4.svg)](CODE_OF_CONDUCT.md)
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg)](http://makeapullrequest.com)**degit** makes copies of git repositories. When you run `degit some-user/some-repo`, it will find the latest commit on https://github.com/some-user/some-repo and download the associated tar file to `~/.degit/some-user/some-repo/commithash.tar.gz` if it doesn't already exist locally. (This is much quicker than using `git clone`, because you're not downloading the entire git history.)
_Requires Node 8 or above, because `async` and `await` are the cat's pyjamas_
## Installation
```bash
npm install -g degit
```## Usage
### Basics
The simplest use of degit is to download the master branch of a repo from GitHub to the current working directory:
```bash
degit user/repo# these commands are equivalent
degit github:user/repo
degit [email protected]:user/repo
degit https://github.com/user/repo
```Or you can download from GitLab and BitBucket:
```bash
# download from GitLab
degit gitlab:user/repo
degit [email protected]:user/repo
degit https://gitlab.com/user/repo# download from BitBucket
degit bitbucket:user/repo
degit [email protected]:user/repo
degit https://bitbucket.org/user/repo# download from Sourcehut
degit git.sr.ht/user/repo
degit [email protected]:user/repo
degit https://git.sr.ht/user/repo
```### Specify a tag, branch or commit
The default branch is `master`.
```bash
degit user/repo#dev # branch
degit user/repo#v1.2.3 # release tag
degit user/repo#1234abcd # commit hash
````### Create a new folder for the project
If the second argument is omitted, the repo will be cloned to the current directory.
```bash
degit user/repo my-new-project
```### Specify a subdirectory
To clone a specific subdirectory instead of the entire repo, just add it to the argument:
```bash
degit user/repo/subdirectory
```### HTTPS proxying
If you have an `https_proxy` environment variable, Degit will use it.
### Private repositories
Private repos can be cloned by specifying `--mode=git` (the default is `tar`). In this mode, Degit will use `git` under the hood. It's much slower than fetching a tarball, which is why it's not the default.
Note: this clones over SSH, not HTTPS.
### See all options
```bash
degit --help
```## Not supported
- Private repositories
Pull requests are very welcome!
## Wait, isn't this just `git clone --depth 1`?
A few salient differences:
- If you `git clone`, you get a `.git` folder that pertains to the project template, rather than your project. You can easily forget to re-init the repository, and end up confusing yourself
- Caching and offline support (if you already have a `.tar.gz` file for a specific commit, you don't need to fetch it again).
- Less to type (`degit user/repo` instead of `git clone --depth 1 [email protected]:user/repo`)
- Composability via [actions](#actions)
- Future capabilities — [interactive mode](https://github.com/Rich-Harris/degit/issues/4), [friendly onboarding and postinstall scripts](https://github.com/Rich-Harris/degit/issues/6)## JavaScript API
You can also use degit inside a Node script:
```js
const degit = require('degit');const emitter = degit('user/repo', {
cache: true,
force: true,
verbose: true,
});emitter.on('info', info => {
console.log(info.message);
});emitter.clone('path/to/dest').then(() => {
console.log('done');
});
```## Actions
You can manipulate repositories after they have been cloned with _actions_, specified in a `degit.json` file that lives at the top level of the working directory. Currently, there are two actions — `clone` and `remove`. Additional actions may be added in future.
### clone
```json
// degit.json
[
{
"action": "clone",
"src": "user/another-repo"
}
]
```This will clone `user/another-repo`, preserving the contents of the existing working directory. This allows you to, say, add a new README.md or starter file to a repo that you do not control. The cloned repo can contain its own `degit.json` actions.
### remove
```json
// degit.json
[
{
"action": "remove",
"files": ["LICENSE"]
}
]
```Remove a file at the specified path.
## See also
- [zel](https://github.com/vutran/zel) by [Vu Tran](https://twitter.com/tranvu)
- [gittar](https://github.com/lukeed/gittar) by [Luke Edwards](https://twitter.com/lukeed05)## License
[MIT](LICENSE.md).