using System.Collections.Generic; using System.Threading.Tasks; namespace SourceGit.ViewModels { public class CherryPick : Popup { public List Targets { get; private set; } public bool IsMergeCommit { get; private set; } public List ParentsForMergeCommit { get; private set; } public int MainlineForMergeCommit { get; set; } public bool AppendSourceToMessage { get; set; } public bool AutoCommit { get; set; } public CherryPick(Repository repo, List targets) { _repo = repo; Targets = targets; IsMergeCommit = false; ParentsForMergeCommit = []; MainlineForMergeCommit = 0; AppendSourceToMessage = true; AutoCommit = true; View = new Views.CherryPick() { DataContext = this }; } public CherryPick(Repository repo, Models.Commit merge, List parents) { _repo = repo; Targets = [merge]; IsMergeCommit = true; ParentsForMergeCommit = parents; MainlineForMergeCommit = 0; AppendSourceToMessage = true; AutoCommit = true; View = new Views.CherryPick() { DataContext = this }; } public override Task Sure() { _repo.SetWatcherEnabled(false); ProgressDescription = $"Cherry-Pick commit(s) ..."; return Task.Run(() => { if (IsMergeCommit) { new Commands.CherryPick( _repo.FullPath, Targets[0].SHA, !AutoCommit, AppendSourceToMessage, $"-m {MainlineForMergeCommit + 1}").Exec(); } else { new Commands.CherryPick( _repo.FullPath, string.Join(' ', Targets.ConvertAll(c => c.SHA)), !AutoCommit, AppendSourceToMessage, string.Empty).Exec(); } CallUIThread(() => _repo.SetWatcherEnabled(true)); return true; }); } private readonly Repository _repo = null; } }