using System; namespace SourceGit.Commands { /// /// 推送 /// public class Push : Command { private Action handler = null; public Push(string repo, string local, string remote, string remoteBranch, bool withTags, bool force, bool track, Action onProgress) { Cwd = repo; TraitErrorAsOutput = true; handler = onProgress; var sshKey = new Config(repo).Get($"remote.{remote}.sshkey"); if (!string.IsNullOrEmpty(sshKey)) { Args = $"-c core.sshCommand=\"ssh -i '{sshKey}'\" "; } else { Args = "-c credential.helper=manager "; } Args += "push --progress --verbose "; if (withTags) Args += "--tags "; if (track) Args += "-u "; if (force) Args += "--force-with-lease "; Args += $"{remote} {local}:{remoteBranch}"; } public Push(string repo, string remote, string branch) { Cwd = repo; var sshKey = new Config(repo).Get($"remote.{remote}.sshkey"); if (!string.IsNullOrEmpty(sshKey)) { Args = $"-c core.sshCommand=\"ssh -i '{sshKey}'\" "; } else { Args = "-c credential.helper=manager "; } Args += $"push {remote} --delete {branch}"; } public Push(string repo, string remote, string tag, bool isDelete) { Cwd = repo; var sshKey = new Config(repo).Get($"remote.{remote}.sshkey"); if (!string.IsNullOrEmpty(sshKey)) { Args = $"-c core.sshCommand=\"ssh -i '{sshKey}'\" "; } else { Args = "-c credential.helper=manager "; } Args += "push "; if (isDelete) Args += "--delete "; Args += $"{remote} refs/tags/{tag}"; } public override void OnReadline(string line) { handler?.Invoke(line); } } }