Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nodegit/nodegit
Native Node bindings to Git.
https://github.com/nodegit/nodegit
c-plus-plus electron git javascript js libgit2 linux macos mit node nodegit nodejs windows
Last synced: 6 days ago
JSON representation
Native Node bindings to Git.
- Host: GitHub
- URL: https://github.com/nodegit/nodegit
- Owner: nodegit
- License: mit
- Created: 2011-02-18T16:42:46.000Z (almost 14 years ago)
- Default Branch: master
- Last Pushed: 2024-08-21T08:47:35.000Z (5 months ago)
- Last Synced: 2024-10-29T11:21:52.878Z (3 months ago)
- Topics: c-plus-plus, electron, git, javascript, js, libgit2, linux, macos, mit, node, nodegit, nodejs, windows
- Language: JavaScript
- Homepage: https://www.nodegit.org/
- Size: 50.6 MB
- Stars: 5,651
- Watchers: 75
- Forks: 692
- Open Issues: 375
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-nodejs-cn - nodegit - 原生 Node 封装的 Git 工具 (包 / 其他)
- awesome-nodejs - nodegit - Node bindings to the libgit2 project. ![](https://img.shields.io/github/stars/nodegit/nodegit.svg?style=social&label=Star) (Repository / Git)
- awesome-github-repos - nodegit/nodegit - Native Node bindings to Git. (JavaScript)
- awesome-nodejs - nodegit - Native bindings to Git. (Packages / Miscellaneous)
- awesome-nodejs - nodegit - Native Node bindings to Git. - ★ 3742 (Miscellaneous)
- awesome-node - nodegit - Native bindings to Git. (Packages / Miscellaneous)
- awesome-nodejs-cn - nodegit - node本地绑定Git. (目录 / 其他)
- awesome-nodejs - nodegit - 是 [libgit2](https://libgit2.org/) 的 Node.js 绑定版本 (Uncategorized / Uncategorized)
- jimsghstars - nodegit/nodegit - Native Node bindings to Git. (JavaScript)
- awesome-star-libs - nodegit / nodegit
- awesome-web - nodegit
- awesome-nodejs-cn - nodegit - **star:5672** 到Git的本机绑定 ![star > 2000][Awesome] (包 / 杂项)
README
# NodeGit
> Node bindings to the [libgit2](http://libgit2.github.com/) project.
[![Actions Status](https://github.com/nodegit/nodegit/workflows/Testing/badge.svg)](https://github.com/nodegit/nodegit/actions)
**Stable ([email protected]): 0.28.3**
## Have a problem? Come chat with us! ##
Visit [slack.libgit2.org](http://slack.libgit2.org/) to sign up, then join us in #nodegit.
## Maintained by ##
Tyler Ang-Wanek [@twwanek](http://twitter.com/twwanek) with help from tons of
[awesome contributors](https://github.com/nodegit/nodegit/contributors)!### Alumni Maintainers ###
Tim Branyen [@tbranyen](http://twitter.com/tbranyen),
John Haley [@johnhaley81](http://twitter.com/johnhaley81),
Max Korp [@maxkorp](http://twitter.com/MaximilianoKorp),
Steve Smith [@orderedlist](https://twitter.com/orderedlist),
Michael Robinson [@codeofinterest](http://twitter.com/codeofinterest), and
Nick Kallen [@nk](http://twitter.com/nk)## API Documentation. ##
[http://www.nodegit.org/](http://www.nodegit.org/)
## Getting started. ##
NodeGit will work on most systems out-of-the-box without any native
dependencies.``` bash
npm install nodegit
```If you receive errors about libstdc++, which are commonly experienced when
building on Travis-CI, you can fix this by upgrading to the latest
libstdc++-4.9.In Ubuntu:
``` sh
sudo add-apt-repository ppa:ubuntu-toolchain-r/test
sudo apt-get update
sudo apt-get install libstdc++-4.9-dev
```In Travis:
``` yaml
addons:
apt:
sources:
- ubuntu-toolchain-r-test
packages:
- libstdc++-4.9-dev
```In CircleCI:
``` yaml
dependencies:
pre:
- sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test
- sudo apt-get update
- sudo apt-get install -y libstdc++-4.9-dev
```If you receive errors about *lifecycleScripts* preinstall/install you probably miss *libssl-dev*
In Ubuntu:
```
sudo apt-get install libssl-dev
```You will need the following libraries installed on your linux machine:
- libpcre
- libpcreposix
- libkrb5
- libk5crypto
- libcom_errWhen building locally, you will also need development packages for kerberos and pcre, so both of these utilities must be present on your machine:
- pcre-config
- krb5-configIf you are still encountering problems while installing, you should try the
[Building from source](http://www.nodegit.org/guides/install/from-source/)
instructions.## API examples. ##
### Cloning a repository and reading a file: ###
``` javascript
var Git = require("nodegit");// Clone a given repository into the `./tmp` folder.
Git.Clone("https://github.com/nodegit/nodegit", "./tmp")
// Look up this known commit.
.then(function(repo) {
// Use a known commit sha from this repository.
return repo.getCommit("59b20b8d5c6ff8d09518454d4dd8b7b30f095ab5");
})
// Look up a specific file within that commit.
.then(function(commit) {
return commit.getEntry("README.md");
})
// Get the blob contents from the file.
.then(function(entry) {
// Patch the blob to contain a reference to the entry.
return entry.getBlob().then(function(blob) {
blob.entry = entry;
return blob;
});
})
// Display information about the blob.
.then(function(blob) {
// Show the path, sha, and filesize in bytes.
console.log(blob.entry.path() + blob.entry.sha() + blob.rawsize() + "b");// Show a spacer.
console.log(Array(72).join("=") + "\n\n");// Show the entire file.
console.log(String(blob));
})
.catch(function(err) { console.log(err); });```
### Emulating git log: ###
``` javascript
var Git = require("nodegit");// Open the repository directory.
Git.Repository.open("tmp")
// Open the master branch.
.then(function(repo) {
return repo.getMasterCommit();
})
// Display information about commits on master.
.then(function(firstCommitOnMaster) {
// Create a new history event emitter.
var history = firstCommitOnMaster.history();// Create a counter to only show up to 9 entries.
var count = 0;// Listen for commit events from the history.
history.on("commit", function(commit) {
// Disregard commits past 9.
if (++count >= 9) {
return;
}// Show the commit sha.
console.log("commit " + commit.sha());// Store the author object.
var author = commit.author();// Display author information.
console.log("Author:\t" + author.name() + " <" + author.email() + ">");// Show the commit date.
console.log("Date:\t" + commit.date());// Give some space and show the message.
console.log("\n " + commit.message());
});// Start emitting events.
history.start();
});
```For more examples, check the `examples/` folder.
## Unit tests. ##
You will need to build locally before running the tests. See above.
``` bash
npm test
```