Ligantes do nó para o projeto LibGit2.
Estável ([email protected]): 0.28.3
Visite slack.libgit2.org para se inscrever e junte -se a nós no #NodeGit.
Tyler Ang-Wanek @twwanek com a ajuda de toneladas de contribuintes incríveis!
Tim Branyen @TBranyen, John Haley @Johnsey81, Max Korp @maxkorp, Steve Smith @OrderedList, Michael Robinson @Codeofinterest e Nick Kallen @NK
http://www.nodegit.org/
O NodeGit funcionará na maioria dos sistemas prontos para uso sem dependências nativas.
npm install nodegitSe você receber erros sobre libstdc ++, que geralmente é experimentado ao criar no travis-ci, poderá corrigir isso atualizando para o mais recente libstdc ++-4.9.
Em Ubuntu:
sudo add-apt-repository ppa:ubuntu-toolchain-r/test
sudo apt-get update
sudo apt-get install libstdc++-4.9-devEm Travis:
addons :
apt :
sources :
- ubuntu-toolchain-r-test
packages :
- libstdc++-4.9-devEm Circleci:
dependencies :
pre :
- sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test
- sudo apt-get update
- sudo apt-get install -y libstdc++-4.9-devSe você receber erros sobre o LifeCyclescripts Pré-Instalação/Instalação, provavelmente sente falta de libsl-dev no Ubuntu:
sudo apt-get install libssl-dev
Você precisará das seguintes bibliotecas instaladas em sua máquina Linux:
Ao construir localmente, você também precisará de pacotes de desenvolvimento para Kerberos e PCRE, para que ambos os utilitários estejam presentes em sua máquina:
Se você ainda estiver encontrando problemas durante a instalação, experimente o edifício a partir das instruções de origem.
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 ( "=" ) + "nn" ) ;
// Show the entire file.
console . log ( String ( blob ) ) ;
} )
. catch ( function ( err ) { console . log ( err ) ; } ) ; 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 ( ) ;
} ) ; Para mais exemplos, verifique os examples/ pasta.
Você precisará construir localmente antes de executar os testes. Veja acima.
npm test