Files
sourcegit/src/ViewModels/DeleteBranch.cs
leo 40765826ce code_review: PR #1492
- Remove all synchronous method in commands
- `Command.ReadToEndAsync` now is protected method
- Rename `ResultAsync` to `GetResultAsync`
- Call `ConfigureAwait(false)` when there's no context

Signed-off-by: leo <longshuang@msn.cn>
2025-07-03 17:30:06 +08:00

79 lines
2.3 KiB
C#

using System.Threading.Tasks;
namespace SourceGit.ViewModels
{
public class DeleteBranch : Popup
{
public Models.Branch Target
{
get;
}
public Models.Branch TrackingRemoteBranch
{
get;
}
public string DeleteTrackingRemoteTip
{
get;
private set;
}
public bool AlsoDeleteTrackingRemote
{
get => _alsoDeleteTrackingRemote;
set => SetProperty(ref _alsoDeleteTrackingRemote, value);
}
public DeleteBranch(Repository repo, Models.Branch branch)
{
_repo = repo;
Target = branch;
if (branch.IsLocal && !string.IsNullOrEmpty(branch.Upstream))
{
TrackingRemoteBranch = repo.Branches.Find(x => x.FullName == branch.Upstream);
if (TrackingRemoteBranch != null)
DeleteTrackingRemoteTip = App.Text("DeleteBranch.WithTrackingRemote", TrackingRemoteBranch.FriendlyName);
}
}
public override async Task<bool> Sure()
{
_repo.SetWatcherEnabled(false);
ProgressDescription = "Deleting branch...";
var log = _repo.CreateLog("Delete Branch");
Use(log);
if (Target.IsLocal)
{
await Commands.Branch
.DeleteLocalAsync(_repo.FullPath, Target.Name, log)
.ConfigureAwait(false);
if (_alsoDeleteTrackingRemote && TrackingRemoteBranch != null)
await Commands.Branch
.DeleteRemoteAsync(_repo.FullPath, TrackingRemoteBranch.Remote, TrackingRemoteBranch.Name, log)
.ConfigureAwait(false);
}
else
{
await Commands.Branch
.DeleteRemoteAsync(_repo.FullPath, Target.Remote, Target.Name, log)
.ConfigureAwait(false);
}
log.Complete();
_repo.MarkBranchesDirtyManually();
_repo.SetWatcherEnabled(true);
return true;
}
private readonly Repository _repo = null;
private bool _alsoDeleteTrackingRemote = false;
}
}