HansPeterGit 1.0.4

dotnet add package HansPeterGit --version 1.0.4                
NuGet\Install-Package HansPeterGit -Version 1.0.4                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="HansPeterGit" Version="1.0.4" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add HansPeterGit --version 1.0.4                
#r "nuget: HansPeterGit, 1.0.4"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install HansPeterGit as a Cake Addin
#addin nuget:?package=HansPeterGit&version=1.0.4

// Install HansPeterGit as a Cake Tool
#tool nuget:?package=HansPeterGit&version=1.0.4                

HansPeterGit

NuGet License Build Status

Maintainability Rating Reliability Rating Security Rating Bugs Vulnerabilities Coverage

GIT interface for .NET

This repository contains a cross-platform interface to the git CLI (aka git.exe/git).

The project aim is to get rid of the stale library libgit2sharp and provide an easy interface to interact with the git cli.

Dependencies

An installed version of git should be accessible via path or can be defined via the GitOptions.PathToGit property.

Install

Add the NuGet package HansPeterGit to any project supporting .NET Standard 2.0 or higher.

> dotnet add package HansPeterGit

Usage

Clone a repository

GitRepository.Clone() can download a remote repository to the local file system, same as the git clone command.

GitRepository.Clone("https://github.com/twenzel/HansPeterGit.git", @"D:\TestSample");

Create a local repository

The GitRepository.Init() method can create a new Git repository in the specified path, equivalent to the git init command.

var repos = new GitRepository(@"D:\TestSample");
repos.Init();

Get status

Using the GetStatus() method to retrieve the repositories current status.

var repos = new GitRepository(@"D:\TestSample");
var status = repos.GetStatus();

Console.WriteLine($"Current branch: {status.Branch}");
Console.WriteLine($"Current commit: {status.Commit}");

if (status.IsDirty)
{
    var newfile = status.Added.First();
}

var fileInfo = status["src/newFile.json"];

Get branches

Using the GetBranches() method to retrieve the local branches of the current repository.

var repos = new GitRepository(@"D:\TestSample");
var status = repos.GetBranches();

Console.WriteLine("Branches:");
foreach (var branch in branches)
{
    Console.WriteLine($"{branch.Name}");
}

To retrieve the remote branches use the GetBranches(bool) method with the value "true" ("false" will retrieve the local branches).

var repos = new GitRepository(@"D:\TestSample");
var status = repos.GetBranches(true);

Console.WriteLine("Remote branches:");
foreach (var branch in branches)
{
    Console.WriteLine($"{branch.Name}");
}

To retrieve only branch names please use the GetBranchNames(bool) method.

Staging/Restore

To stage the current work tree use any of the Stage/Add/Restore methods.

repos.StageAll();

// Stage file
repos.Add("src/newFile.json");

// Discard changes in working directory
repos.Restore("src/newFile.json");

// Unstage file
repos.Unstage("src/newFile.json");

Commit changes

The Commit() method can be used to commit the current changes.

var commit = repos.Commit("Fix calculation bug");

// with dedicated author
repos.Commit("Fix calculation bug", new Author("Some name", "bugfixer@test.com"));

Push changes

To push changes from the local repository please use the Push() methods.

repos.Push();

// with dedicated remove name
repos.Push("origin", "main");

// with setting an upstream
repos.PushWithUpstream("origin", "main");

Others

There are already some other methods but not all commands are wrapped/implemented yet. Please feel free to create an issue or contribute.

For any other git command you can use the generic ExecuteCommand method.

var result = repos.ExecuteCommand("revert");

Authentication

Sometimes the remote repository requires an authentication (e.g. GitHub, Azure DevOps). In order to clone or push the repository you can define an authentication.

var options = new GitOptions(workingDirectory);
options.Authentication = new BasicAuthentication("pat", "myuserpat"); 

var repository = GitRepository.Clone("https://dev.azure.com/yourOrgName/yourProject/_git/yourRepository", options);

Beside BasicAuthentication an BearerAuthentication is also already build-in. You can implement your own authentication by implementing the IAuthentication interface. The build-in authentication implementation uses the '-c http.extraheader' argument of the git cli to provide the credentials.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.4 51 1/7/2025
1.0.3 41 1/7/2025
1.0.2 44 1/7/2025
0.1.12 162 1/22/2024
0.1.10 412 9/12/2022
0.1.9 431 7/20/2022
0.1.8 411 7/20/2022
0.1.7 399 7/20/2022
0.1.6 416 7/20/2022
0.1.3 408 7/19/2022
0.1.2 398 7/19/2022