Git 客户端,采用 C# 编写。
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

146 lines
4.3 KiB

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO;
namespace GitUI
{
public partial class MergePatch : Form
{
public MergePatch()
{
InitializeComponent();
EnableButtons();
}
public void SetPatchFile(string name)
{
PatchFile.Text = name;
}
private void EnableButtons()
{
if (Directory.Exists(GitCommands.Settings.WorkingDir + ".git\\rebase-apply\\"))
{
BrowsePatch.Enabled = false;
Apply.Enabled = false;
PatchFile.ReadOnly = true;
AddFiles.Enabled = true;
Resolved.Enabled = true;
Mergetool.Enabled = true;
Skip.Enabled = true;
Abort.Enabled = true;
}
else
{
BrowsePatch.Enabled = true;
Apply.Enabled = true;
PatchFile.ReadOnly = false;
AddFiles.Enabled = false;
Resolved.Enabled = false;
Mergetool.Enabled = false;
Skip.Enabled = false;
Abort.Enabled = false;
}
}
private void textBox1_TextChanged(object sender, EventArgs e)
{
}
private string SelectPatchFile(string initialDirectory)
{
OpenFileDialog dialog = new OpenFileDialog();
dialog.Filter =
"Patch file (*.Patch)|*.Patch";
dialog.InitialDirectory = initialDirectory;
dialog.Title = "Select patch file";
return (dialog.ShowDialog() == DialogResult.OK) ? dialog.FileName : PatchFile.Text;
}
private void button1_Click(object sender, EventArgs e)
{
PatchFile.Text = SelectPatchFile(@".");
}
private void Apply_Click(object sender, EventArgs e)
{
if (string.IsNullOrEmpty(PatchFile.Text))
{
MessageBox.Show("Please select a patch file");
return;
}
string result = GitCommands.GitCommands.Patch(PatchFile.Text);
Output.Text = result;
if (result.Contains("Patch failed"))
{
}
EnableButtons();
}
private void Mergetool_Click(object sender, EventArgs e)
{
GitCommands.GitCommands.RunRealCmd(GitCommands.Settings.GitDir + "git.exe", "mergetool --tool=kdiff3");
if (MessageBox.Show("Resolved all conflicts? Run resolved?", "Conflicts solved", MessageBoxButtons.YesNo) == DialogResult.Yes)
{
Output.Text += "\n";
Output.Text += GitCommands.GitCommands.Resolved();
EnableButtons();
}
}
private void Skip_Click(object sender, EventArgs e)
{
Output.Text += "\n";
Output.Text += GitCommands.GitCommands.Skip();
EnableButtons();
}
private void button1_Click_1(object sender, EventArgs e)
{
Output.Text += "\n";
Output.Text += GitCommands.GitCommands.Resolved();
EnableButtons();
}
private void Abort_Click(object sender, EventArgs e)
{
Output.Text += "\n";
Output.Text += GitCommands.GitCommands.Abort();
EnableButtons();
}
private void AddFiles_Click(object sender, EventArgs e)
{
FormAddFiles form = new FormAddFiles();
form.ShowDialog();
}
private void MergePatch_Load(object sender, EventArgs e)
{
}
private void MergePatch_FormClosing(object sender, FormClosingEventArgs e)
{
if (Directory.Exists(GitCommands.Settings.WorkingDir + ".git\\rebase-apply\\"))
{
if (MessageBox.Show("You are in the middle of a patch apply. You need to resolve, skip or abort this patch.\nAre you sure to exit now?", "Exit", MessageBoxButtons.YesNo) == DialogResult.Yes)
{
e.Cancel = true;
}
}
}
}
}