mirror of
https://github.com/sourcegit-scm/sourcegit.git
synced 2025-01-11 23:57:21 -08:00
121 lines
4.3 KiB
C#
121 lines
4.3 KiB
C#
using System.Collections.Generic;
|
|
using System.Threading.Tasks;
|
|
using System.Windows;
|
|
using System.Windows.Controls;
|
|
|
|
namespace SourceGit.UI {
|
|
|
|
/// <summary>
|
|
/// Git pull
|
|
/// </summary>
|
|
public partial class Pull : UserControl {
|
|
private Git.Repository repo = null;
|
|
private string preferRemote = null;
|
|
private string preferBranch = null;
|
|
|
|
/// <summary>
|
|
/// Constructor
|
|
/// </summary>
|
|
/// <param name="opened">Opened repository</param>
|
|
/// <param name="preferRemoteBranch">Prefered remote branch.</param>
|
|
public Pull(Git.Repository opened, string preferRemoteBranch) {
|
|
repo = opened;
|
|
InitializeComponent();
|
|
SetContent(preferRemoteBranch);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Display git pull dialog.
|
|
/// </summary>
|
|
/// <param name="opened">Opened repository</param>
|
|
/// <param name="preferRemoteBranch">Prefered remote branch</param>
|
|
public static void Show(Git.Repository opened, string preferRemoteBranch = null) {
|
|
var popup = App.Launcher.GetPopupManager(opened);
|
|
popup?.Show(new Pull(opened, preferRemoteBranch));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Set content.
|
|
/// </summary>
|
|
private void SetContent(string prefered) {
|
|
var branches = repo.Branches();
|
|
var remotes = new List<string>();
|
|
var current = null as Git.Branch;
|
|
|
|
foreach (var b in branches) {
|
|
if (b.IsLocal) {
|
|
if (b.IsCurrent) current = b;
|
|
} else {
|
|
if (!remotes.Contains(b.Remote)) remotes.Add(b.Remote);
|
|
}
|
|
}
|
|
|
|
if (!string.IsNullOrEmpty(prefered)) {
|
|
preferRemote = prefered.Substring(0, prefered.IndexOf('/'));
|
|
preferBranch = prefered;
|
|
} else if (current != null && !string.IsNullOrEmpty(current.Upstream)) {
|
|
var upstream = current.Upstream.Substring("refs/remotes/".Length);
|
|
preferRemote = upstream.Substring(0, upstream.IndexOf('/'));
|
|
preferBranch = upstream;
|
|
}
|
|
|
|
txtInto.Content = current.Name;
|
|
combRemotes.ItemsSource = remotes;
|
|
combRemotes.SelectedItem = preferRemote;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Start pull
|
|
/// </summary>
|
|
/// <param name="sender"></param>
|
|
/// <param name="e"></param>
|
|
private async void Start(object sender, RoutedEventArgs e) {
|
|
var remote = combRemotes.SelectedItem as string;
|
|
var branch = combBranches.SelectedItem as string;
|
|
var rebase = chkRebase.IsChecked == true;
|
|
var autoStash = chkAutoStash.IsChecked == true;
|
|
|
|
if (remote == null || branch == null) return;
|
|
|
|
var popup = App.Launcher.GetPopupManager(repo);
|
|
popup?.Lock();
|
|
await Task.Run(() => repo.Pull(remote, branch.Substring(branch.IndexOf('/')+1), msg => popup?.UpdateStatus(msg), rebase, autoStash));
|
|
popup?.Close(true);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Cancel.
|
|
/// </summary>
|
|
/// <param name="sender"></param>
|
|
/// <param name="e"></param>
|
|
private void Cancel(object sender, RoutedEventArgs e) {
|
|
App.Launcher.GetPopupManager(repo)?.Close();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Remote selection changed event.
|
|
/// </summary>
|
|
/// <param name="sender"></param>
|
|
/// <param name="e"></param>
|
|
private void RemotesSelectionChanged(object sender, SelectionChangedEventArgs e) {
|
|
if (e.AddedItems.Count != 1) return;
|
|
|
|
var remote = e.AddedItems[0] as string;
|
|
var allBranches = repo.Branches();
|
|
var branches = new List<string>();
|
|
|
|
foreach (var b in allBranches) {
|
|
if (!b.IsLocal && b.Remote == remote) {
|
|
branches.Add(b.Name);
|
|
}
|
|
}
|
|
|
|
combBranches.ItemsSource = branches;
|
|
if (remote == preferRemote && preferBranch != null) {
|
|
combBranches.SelectedItem = preferBranch;
|
|
} else {
|
|
combBranches.SelectedIndex = 0;
|
|
}
|
|
}
|
|
}
|
|
}
|