mirror of
https://github.com/sourcegit-scm/sourcegit
synced 2025-05-23 05:05:00 +00:00

Merge deleting branch and tag on remote into `SourceGit.Commands.Push(repo, remote, refname, isDelete)` Signed-off-by: leo <longshuang@msn.cn>
49 lines
1.4 KiB
C#
49 lines
1.4 KiB
C#
using System;
|
|
|
|
namespace SourceGit.Commands
|
|
{
|
|
public class Push : Command
|
|
{
|
|
public Push(string repo, string local, string remote, string remoteBranch, bool withTags, bool checkSubmodules, bool track, bool force, Action<string> onProgress)
|
|
{
|
|
_outputHandler = onProgress;
|
|
|
|
WorkingDirectory = repo;
|
|
Context = repo;
|
|
TraitErrorAsOutput = true;
|
|
SSHKey = new Config(repo).Get($"remote.{remote}.sshkey");
|
|
Args = "push --progress --verbose ";
|
|
|
|
if (withTags)
|
|
Args += "--tags ";
|
|
if (checkSubmodules)
|
|
Args += "--recurse-submodules=check ";
|
|
if (track)
|
|
Args += "-u ";
|
|
if (force)
|
|
Args += "--force-with-lease ";
|
|
|
|
Args += $"{remote} {local}:{remoteBranch}";
|
|
}
|
|
|
|
public Push(string repo, string remote, string refname, bool isDelete)
|
|
{
|
|
WorkingDirectory = repo;
|
|
Context = repo;
|
|
SSHKey = new Config(repo).Get($"remote.{remote}.sshkey");
|
|
Args = "push ";
|
|
|
|
if (isDelete)
|
|
Args += "--delete ";
|
|
|
|
Args += $"{remote} {refname}";
|
|
}
|
|
|
|
protected override void OnReadline(string line)
|
|
{
|
|
_outputHandler?.Invoke(line);
|
|
}
|
|
|
|
private readonly Action<string> _outputHandler = null;
|
|
}
|
|
}
|