2010-05-03 00:04:39 +00:00
|
|
|
|
// SparkleShare, an instant update workflow to Git.
|
|
|
|
|
// Copyright (C) 2010 Hylke Bons <hylkebons@gmail.com>
|
|
|
|
|
//
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
// (at your option) any later version.
|
|
|
|
|
//
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
|
//
|
|
|
|
|
// You should have received a copy of the GNU General Public License
|
2010-07-22 21:10:38 +00:00
|
|
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
2010-06-01 22:51:43 +00:00
|
|
|
|
using Mono.Unix;
|
2010-05-03 00:04:39 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Diagnostics;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Text.RegularExpressions;
|
|
|
|
|
using System.Timers;
|
|
|
|
|
|
2010-08-02 15:42:42 +00:00
|
|
|
|
namespace SparkleLib {
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
2010-08-12 23:27:28 +00:00
|
|
|
|
public class SparkleRepo {
|
2010-06-10 21:44:58 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
private Process Process;
|
2010-08-22 13:28:04 +00:00
|
|
|
|
private Timer RemoteTimer;
|
|
|
|
|
private Timer LocalTimer;
|
2010-05-03 00:04:39 +00:00
|
|
|
|
private FileSystemWatcher Watcher;
|
2010-07-30 09:57:33 +00:00
|
|
|
|
private bool HasChanged;
|
2010-06-14 09:42:04 +00:00
|
|
|
|
private DateTime LastChange;
|
2010-07-03 19:37:43 +00:00
|
|
|
|
private System.Object ChangeLock = new System.Object();
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
|
|
|
|
public string Name;
|
|
|
|
|
public string Domain;
|
2010-08-14 20:02:00 +00:00
|
|
|
|
public string Description;
|
2010-05-03 00:04:39 +00:00
|
|
|
|
public string LocalPath;
|
|
|
|
|
public string RemoteOriginUrl;
|
|
|
|
|
public string CurrentHash;
|
|
|
|
|
public string UserEmail;
|
|
|
|
|
public string UserName;
|
|
|
|
|
|
2010-07-20 23:01:09 +00:00
|
|
|
|
public delegate void AddedEventHandler (object o, SparkleEventArgs args);
|
2010-07-21 23:17:20 +00:00
|
|
|
|
public delegate void CommitedEventHandler (object o, SparkleEventArgs args);
|
2010-07-24 12:32:05 +00:00
|
|
|
|
public delegate void PushingStartedEventHandler (object o, SparkleEventArgs args);
|
|
|
|
|
public delegate void PushingFinishedEventHandler (object o, SparkleEventArgs args);
|
2010-07-22 21:10:38 +00:00
|
|
|
|
public delegate void FetchingStartedEventHandler (object o, SparkleEventArgs args);
|
|
|
|
|
public delegate void FetchingFinishedEventHandler (object o, SparkleEventArgs args);
|
2010-07-24 12:32:05 +00:00
|
|
|
|
public delegate void NewCommitEventHandler (object o, NewCommitArgs args);
|
2010-07-24 14:03:58 +00:00
|
|
|
|
public delegate void ConflictDetectedEventHandler (object o, SparkleEventArgs args);
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
public event AddedEventHandler Added;
|
|
|
|
|
public event CommitedEventHandler Commited;
|
|
|
|
|
public event PushingStartedEventHandler PushingStarted;
|
|
|
|
|
public event PushingFinishedEventHandler PushingFinished;
|
|
|
|
|
public event FetchingStartedEventHandler FetchingStarted;
|
|
|
|
|
public event FetchingFinishedEventHandler FetchingFinished;
|
|
|
|
|
public event NewCommitEventHandler NewCommit;
|
|
|
|
|
public event ConflictDetectedEventHandler ConflictDetected;
|
2010-07-20 23:01:09 +00:00
|
|
|
|
|
2010-06-15 00:08:35 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
public SparkleRepo (string path)
|
2010-06-15 00:08:35 +00:00
|
|
|
|
{
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
2010-07-31 19:13:01 +00:00
|
|
|
|
if (!Directory.Exists (path))
|
|
|
|
|
Directory.CreateDirectory (path);
|
2010-07-29 13:47:09 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
LocalPath = path;
|
|
|
|
|
Name = Path.GetFileName (LocalPath);
|
|
|
|
|
|
2010-07-27 13:49:48 +00:00
|
|
|
|
Process = new Process () {
|
|
|
|
|
EnableRaisingEvents = true
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
Process.StartInfo.FileName = "git";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
Process.StartInfo.RedirectStandardOutput = true;
|
|
|
|
|
Process.StartInfo.UseShellExecute = false;
|
2010-07-20 21:21:37 +00:00
|
|
|
|
Process.StartInfo.WorkingDirectory = LocalPath;
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
UserName = GetUserName ();
|
|
|
|
|
UserEmail = GetUserEmail ();
|
|
|
|
|
RemoteOriginUrl = GetRemoteOriginUrl ();
|
|
|
|
|
CurrentHash = GetCurrentHash ();
|
|
|
|
|
Domain = GetDomain (RemoteOriginUrl);
|
2010-08-14 20:02:00 +00:00
|
|
|
|
Description = GetDescription ();
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
2010-08-08 19:16:48 +00:00
|
|
|
|
if (CurrentHash == null)
|
|
|
|
|
CreateInitialCommit ();
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-07-30 09:57:33 +00:00
|
|
|
|
HasChanged = false;
|
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
// Watch the repository's folder
|
2010-07-20 21:21:37 +00:00
|
|
|
|
Watcher = new FileSystemWatcher (LocalPath) {
|
|
|
|
|
IncludeSubdirectories = true,
|
|
|
|
|
EnableRaisingEvents = true,
|
|
|
|
|
Filter = "*"
|
|
|
|
|
};
|
|
|
|
|
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Watcher.Changed += new FileSystemEventHandler (OnFileActivity);
|
|
|
|
|
Watcher.Created += new FileSystemEventHandler (OnFileActivity);
|
|
|
|
|
Watcher.Deleted += new FileSystemEventHandler (OnFileActivity);
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-07-24 21:31:24 +00:00
|
|
|
|
// Fetch remote changes every minute
|
2010-08-22 13:28:04 +00:00
|
|
|
|
RemoteTimer = new Timer () {
|
2010-08-22 13:30:17 +00:00
|
|
|
|
Interval = 60000
|
2010-07-20 21:21:37 +00:00
|
|
|
|
};
|
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
RemoteTimer.Elapsed += delegate {
|
|
|
|
|
CheckForRemoteChanges ();
|
2010-05-03 00:04:39 +00:00
|
|
|
|
};
|
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
// Keep a Local that checks if there are changes and
|
2010-07-20 21:21:37 +00:00
|
|
|
|
// whether they have settled
|
2010-08-22 13:28:04 +00:00
|
|
|
|
LocalTimer = new Timer () {
|
2010-07-20 21:21:37 +00:00
|
|
|
|
Interval = 4000
|
|
|
|
|
};
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
LocalTimer.Elapsed += delegate (object o, ElapsedEventArgs args) {
|
2010-07-20 21:21:37 +00:00
|
|
|
|
CheckForChanges ();
|
2010-05-29 14:18:38 +00:00
|
|
|
|
};
|
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
RemoteTimer.Start ();
|
|
|
|
|
LocalTimer.Start ();
|
2010-06-14 09:42:04 +00:00
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
// Add everything that changed
|
2010-08-08 14:45:28 +00:00
|
|
|
|
// since SparkleShare was stopped
|
2010-06-16 13:42:11 +00:00
|
|
|
|
AddCommitAndPush ();
|
2010-05-29 12:43:28 +00:00
|
|
|
|
|
2010-08-08 19:16:48 +00:00
|
|
|
|
if (CurrentHash == null)
|
|
|
|
|
CurrentHash = GetCurrentHash ();
|
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Idling...");
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
private void CheckForRemoteChanges ()
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Checking for remote changes...");
|
|
|
|
|
|
|
|
|
|
Process process = new Process () {
|
|
|
|
|
EnableRaisingEvents = true
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
process.StartInfo.FileName = "git";
|
|
|
|
|
process.StartInfo.RedirectStandardOutput = true;
|
|
|
|
|
process.StartInfo.UseShellExecute = false;
|
|
|
|
|
process.StartInfo.WorkingDirectory = LocalPath;
|
|
|
|
|
process.StartInfo.Arguments = "ls-remote origin master";
|
|
|
|
|
process.Start ();
|
|
|
|
|
|
|
|
|
|
process.Exited += delegate {
|
2010-08-23 08:42:34 +00:00
|
|
|
|
|
|
|
|
|
if (process.ExitCode != 0)
|
|
|
|
|
return;
|
2010-08-22 13:28:04 +00:00
|
|
|
|
|
2010-08-23 08:42:34 +00:00
|
|
|
|
string remote_hash = process.StandardOutput.ReadToEnd ();
|
2010-08-22 13:28:04 +00:00
|
|
|
|
|
|
|
|
|
if (!remote_hash.StartsWith (CurrentHash)) {
|
|
|
|
|
|
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Remote changes found.");
|
|
|
|
|
Fetch ();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
private void CheckForChanges ()
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
lock (ChangeLock) {
|
|
|
|
|
|
|
|
|
|
if (HasChanged) {
|
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Local", "[" + Name + "] Changes found, checking if settled.");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
|
|
|
|
DateTime now = DateTime.UtcNow;
|
|
|
|
|
TimeSpan changed = new TimeSpan (now.Ticks - LastChange.Ticks);
|
|
|
|
|
|
|
|
|
|
if (changed.TotalMilliseconds > 5000) {
|
|
|
|
|
HasChanged = false;
|
2010-08-22 13:28:04 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Local", "[" + Name + "] Changes have settled, adding files...");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
AddCommitAndPush ();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
// Starts a time Local when something changes
|
2010-06-16 23:16:50 +00:00
|
|
|
|
private void OnFileActivity (object o, FileSystemEventArgs args)
|
2010-06-15 00:08:35 +00:00
|
|
|
|
{
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
WatcherChangeTypes wct = args.ChangeType;
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-06-04 19:45:42 +00:00
|
|
|
|
if (!ShouldIgnore (args.Name)) {
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-06-15 00:08:35 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Event", "[" + Name + "] " + wct.ToString () + " '" + args.Name + "'");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
RemoteTimer.Stop ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
|
|
|
|
lock (ChangeLock) {
|
2010-07-24 14:03:58 +00:00
|
|
|
|
|
2010-07-03 19:37:43 +00:00
|
|
|
|
LastChange = DateTime.UtcNow;
|
|
|
|
|
HasChanged = true;
|
2010-07-24 14:03:58 +00:00
|
|
|
|
|
2010-07-03 19:37:43 +00:00
|
|
|
|
}
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-06-16 13:42:11 +00:00
|
|
|
|
// When there are changes we generally want to Add, Commit and Push
|
2010-07-20 21:21:37 +00:00
|
|
|
|
// so this method does them all with appropriate timers, etc. switched off
|
2010-06-16 13:42:11 +00:00
|
|
|
|
public void AddCommitAndPush ()
|
2010-06-15 00:08:35 +00:00
|
|
|
|
{
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-03 19:37:43 +00:00
|
|
|
|
try {
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
LocalTimer.Stop ();
|
|
|
|
|
RemoteTimer.Stop ();
|
2010-07-03 19:37:43 +00:00
|
|
|
|
|
|
|
|
|
Add ();
|
2010-07-24 14:03:58 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
string message = FormatCommitMessage ();
|
|
|
|
|
|
|
|
|
|
if (!message.Equals ("")) {
|
2010-07-24 14:03:58 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
Commit (message);
|
2010-08-22 13:28:04 +00:00
|
|
|
|
CheckForRemoteChanges ();
|
2010-07-03 19:37:43 +00:00
|
|
|
|
Push ();
|
2010-07-24 14:03:58 +00:00
|
|
|
|
|
2010-07-03 19:37:43 +00:00
|
|
|
|
}
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
|
|
|
|
} finally {
|
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
RemoteTimer.Start ();
|
|
|
|
|
LocalTimer.Start ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
2010-06-20 21:05:11 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
|
|
|
|
|
2010-06-16 13:42:11 +00:00
|
|
|
|
// Stages the made changes
|
|
|
|
|
private void Add ()
|
2010-06-15 00:08:35 +00:00
|
|
|
|
{
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-06-04 19:45:42 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Staging changes...");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
Process.StartInfo.Arguments = "add --all";
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-05-10 23:21:56 +00:00
|
|
|
|
Process.WaitForExit ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-06-04 19:45:42 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Changes staged.");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
SparkleEventArgs args = new SparkleEventArgs ("Added");
|
|
|
|
|
|
2010-07-20 23:01:09 +00:00
|
|
|
|
if (Added != null)
|
|
|
|
|
Added (this, args);
|
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
// Commits the made changes
|
2010-07-24 14:03:58 +00:00
|
|
|
|
public void Commit (string message)
|
2010-06-15 00:08:35 +00:00
|
|
|
|
{
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Commit", "[" + Name + "] " + message);
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
Process.StartInfo.Arguments = "commit -m \"" + message + "\"";
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-05-10 23:21:56 +00:00
|
|
|
|
Process.WaitForExit ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
SparkleEventArgs args = new SparkleEventArgs ("Commited");
|
2010-07-24 14:03:58 +00:00
|
|
|
|
args.Message = message;
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
|
|
|
|
if (Commited != null)
|
2010-07-24 14:03:58 +00:00
|
|
|
|
Commited (this, args);
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-24 21:31:24 +00:00
|
|
|
|
// Fetches changes from the remote repository
|
2010-06-15 00:08:35 +00:00
|
|
|
|
public void Fetch ()
|
|
|
|
|
{
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
RemoteTimer.Stop ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
Process process = new Process () {
|
|
|
|
|
EnableRaisingEvents = true
|
|
|
|
|
};
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
process.StartInfo.FileName = "git";
|
|
|
|
|
process.StartInfo.RedirectStandardOutput = true;
|
|
|
|
|
process.StartInfo.UseShellExecute = false;
|
|
|
|
|
process.StartInfo.WorkingDirectory = LocalPath;
|
2010-07-22 21:10:38 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
SparkleEventArgs args;
|
|
|
|
|
args = new SparkleEventArgs ("FetchingStarted");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
if (FetchingStarted != null)
|
|
|
|
|
FetchingStarted (this, args);
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Fetching changes...");
|
2010-07-27 11:00:01 +00:00
|
|
|
|
|
2010-08-14 10:22:49 +00:00
|
|
|
|
process.StartInfo.Arguments = "fetch -v origin master";
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
process.Start ();
|
2010-08-05 10:40:12 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
process.Exited += delegate {
|
2010-08-05 10:40:12 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Changes fetched.");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
args = new SparkleEventArgs ("FetchingFinished");
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
if (FetchingFinished != null)
|
|
|
|
|
FetchingFinished (this, args);
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
Rebase ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
RemoteTimer.Start ();
|
|
|
|
|
|
|
|
|
|
CurrentHash = GetCurrentHash ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-05 21:46:48 +00:00
|
|
|
|
};
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
// Merges the fetched changes
|
2010-06-15 00:08:35 +00:00
|
|
|
|
public void Rebase ()
|
|
|
|
|
{
|
2010-05-23 18:03:05 +00:00
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
Add ();
|
2010-08-11 22:53:32 +00:00
|
|
|
|
|
2010-05-23 13:14:24 +00:00
|
|
|
|
Watcher.EnableRaisingEvents = false;
|
2010-05-23 18:03:05 +00:00
|
|
|
|
|
2010-06-04 19:45:42 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Rebasing changes...");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-14 10:22:49 +00:00
|
|
|
|
Process.StartInfo.Arguments = "rebase -v FETCH_HEAD";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
Process.WaitForExit ();
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-06-04 19:45:42 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Changes rebased.");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
|
|
|
|
string output = Process.StandardOutput.ReadToEnd ().Trim ();
|
2010-05-23 17:40:35 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (!output.Contains ("up to date")) {
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (output.Contains ("Failed to merge")) {
|
2010-05-23 17:40:35 +00:00
|
|
|
|
|
2010-06-15 00:08:35 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Resolving conflict...");
|
2010-05-23 17:40:35 +00:00
|
|
|
|
|
|
|
|
|
Process.StartInfo.Arguments = "status";
|
|
|
|
|
Process.WaitForExit ();
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
output = Process.StandardOutput.ReadToEnd ().Trim ();
|
|
|
|
|
string [] lines = Regex.Split (output, "\n");
|
2010-05-23 17:57:18 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
foreach (string line in lines) {
|
2010-05-23 17:40:35 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (line.Contains ("needs merge")) {
|
2010-05-23 17:40:35 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
string problem_file_name = line.Substring (line.IndexOf (": needs merge"));
|
2010-05-23 17:40:35 +00:00
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
Process.StartInfo.Arguments = "checkout --ours " + problem_file_name;
|
2010-05-23 17:40:35 +00:00
|
|
|
|
Process.WaitForExit ();
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-05-23 17:40:35 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
string timestamp = DateTime.Now.ToString ("H:mm d MMM yyyy");
|
2010-06-04 19:45:42 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
File.Move (problem_file_name, problem_file_name + " (" + UserName + ", " + timestamp + ")");
|
2010-05-23 17:40:35 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
Process.StartInfo.Arguments = "checkout --theirs " + problem_file_name;
|
2010-05-23 17:40:35 +00:00
|
|
|
|
Process.WaitForExit ();
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-05-23 17:40:35 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
SparkleEventArgs args = new SparkleEventArgs ("ConflictDetected");
|
2010-06-12 17:03:15 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
if (ConflictDetected != null)
|
|
|
|
|
ConflictDetected (this, args);
|
2010-06-12 17:03:15 +00:00
|
|
|
|
|
2010-05-23 17:40:35 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Add ();
|
|
|
|
|
|
2010-05-29 14:37:07 +00:00
|
|
|
|
Process.StartInfo.Arguments = "rebase --continue";
|
2010-05-23 17:40:35 +00:00
|
|
|
|
Process.WaitForExit ();
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-06-15 00:08:35 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Conflict resolved.");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-05-23 17:40:35 +00:00
|
|
|
|
Push ();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
// Get the last commiter
|
|
|
|
|
Process.StartInfo.Arguments = "log --format=\"%an\" -1";
|
|
|
|
|
Process.Start ();
|
|
|
|
|
string author = Process.StandardOutput.ReadToEnd ().Trim ();
|
|
|
|
|
|
2010-05-16 22:26:34 +00:00
|
|
|
|
// Get the last committer e-mail
|
2010-05-03 00:04:39 +00:00
|
|
|
|
Process.StartInfo.Arguments = "log --format=\"%ae\" -1";
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-07-24 12:32:05 +00:00
|
|
|
|
string email = Process.StandardOutput.ReadToEnd ().Trim ();
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
|
|
|
|
// Get the last commit message
|
|
|
|
|
Process.StartInfo.Arguments = "log --format=\"%s\" -1";
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-07-24 12:32:05 +00:00
|
|
|
|
string message = Process.StandardOutput.ReadToEnd ().Trim ();
|
2010-06-15 23:10:08 +00:00
|
|
|
|
|
2010-08-19 20:13:45 +00:00
|
|
|
|
NewCommitArgs new_commit_args = new NewCommitArgs (author, email, message, Name);
|
2010-06-15 23:10:08 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
if (NewCommit != null)
|
2010-07-24 14:03:58 +00:00
|
|
|
|
NewCommit (this, new_commit_args);
|
2010-05-23 13:14:24 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-05-23 13:14:24 +00:00
|
|
|
|
Watcher.EnableRaisingEvents = true;
|
2010-07-20 21:21:37 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Idling...");
|
2010-05-08 20:06:59 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
// Pushes the changes to the remote repo
|
2010-06-15 00:08:35 +00:00
|
|
|
|
public void Push ()
|
|
|
|
|
{
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
SparkleEventArgs args = new SparkleEventArgs ("PushingStarted");
|
|
|
|
|
|
|
|
|
|
if (PushingStarted != null)
|
|
|
|
|
PushingStarted (this, args);
|
|
|
|
|
|
2010-06-04 19:45:42 +00:00
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Pushing changes...");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-08 19:16:48 +00:00
|
|
|
|
Process.StartInfo.Arguments = "push origin master";
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-05-03 00:04:39 +00:00
|
|
|
|
Process.WaitForExit ();
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
Process.Exited += delegate {
|
|
|
|
|
|
|
|
|
|
SparkleHelpers.DebugInfo ("Git", "[" + Name + "] Changes pushed.");
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
args = new SparkleEventArgs ("PushingFinished");
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
if (PushingFinished != null)
|
|
|
|
|
PushingFinished (this, args);
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
};
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-08-08 14:45:28 +00:00
|
|
|
|
public void Stop ()
|
|
|
|
|
{
|
|
|
|
|
|
2010-08-22 13:28:04 +00:00
|
|
|
|
RemoteTimer.Stop ();
|
|
|
|
|
LocalTimer.Stop ();
|
2010-08-08 14:45:28 +00:00
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
// Ignores repos, dotfiles, swap files and the like.
|
2010-08-08 14:45:28 +00:00
|
|
|
|
private bool ShouldIgnore (string file_name)
|
|
|
|
|
{
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-24 21:31:24 +00:00
|
|
|
|
if (file_name [0].Equals (".") ||
|
2010-07-20 21:21:37 +00:00
|
|
|
|
file_name.Contains (".lock") ||
|
|
|
|
|
file_name.Contains (".git") ||
|
|
|
|
|
file_name.Contains ("/.") ||
|
|
|
|
|
Directory.Exists (LocalPath + file_name)) {
|
|
|
|
|
|
|
|
|
|
return true; // Yes, ignore it.
|
|
|
|
|
|
|
|
|
|
} else if (file_name.Length > 3 &&
|
|
|
|
|
file_name.Substring (file_name.Length - 4).Equals (".swp")) {
|
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
return true; // Yes, ignore it.
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
2010-07-20 21:21:37 +00:00
|
|
|
|
|
2010-07-24 21:31:24 +00:00
|
|
|
|
// Gets the domain name of a given URL
|
2010-07-21 23:17:20 +00:00
|
|
|
|
public string GetDomain (string url)
|
|
|
|
|
{
|
|
|
|
|
|
2010-08-08 19:16:48 +00:00
|
|
|
|
if (RemoteOriginUrl.Equals (""))
|
|
|
|
|
return "";
|
|
|
|
|
|
2010-07-24 21:31:24 +00:00
|
|
|
|
string domain = url.Substring (RemoteOriginUrl.IndexOf ("@") + 1);
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
|
|
|
|
if (domain.IndexOf (":") > -1)
|
|
|
|
|
domain = domain.Substring (0, domain.IndexOf (":"));
|
|
|
|
|
else
|
|
|
|
|
domain = domain.Substring (0, domain.IndexOf ("/"));
|
|
|
|
|
|
|
|
|
|
return domain;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-08-14 20:02:00 +00:00
|
|
|
|
// Gets the repository's description
|
|
|
|
|
public string GetDescription ()
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
string description_file_path = SparkleHelpers.CombineMore (LocalPath, ".git", "description");
|
|
|
|
|
|
|
|
|
|
if (!File.Exists (description_file_path))
|
|
|
|
|
return null;
|
|
|
|
|
|
|
|
|
|
StreamReader reader = new StreamReader (description_file_path);
|
|
|
|
|
string description = reader.ReadToEnd ();
|
|
|
|
|
reader.Close ();
|
|
|
|
|
|
|
|
|
|
if (description.StartsWith ("Unnamed"))
|
|
|
|
|
description = null;
|
|
|
|
|
|
|
|
|
|
return description;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
// Gets hash of the current commit
|
|
|
|
|
public string GetCurrentHash ()
|
|
|
|
|
{
|
|
|
|
|
|
2010-08-08 19:16:48 +00:00
|
|
|
|
Process process = new Process () {
|
|
|
|
|
EnableRaisingEvents = true
|
|
|
|
|
};
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
|
|
|
|
process.StartInfo.RedirectStandardOutput = true;
|
2010-08-08 19:16:48 +00:00
|
|
|
|
process.StartInfo.UseShellExecute = false;
|
|
|
|
|
process.StartInfo.FileName = "git";
|
|
|
|
|
process.StartInfo.WorkingDirectory = LocalPath;
|
|
|
|
|
process.StartInfo.Arguments = "rev-list --max-count=1 HEAD";
|
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
process.Start ();
|
2010-08-08 19:16:48 +00:00
|
|
|
|
process.WaitForExit ();
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
2010-08-08 19:16:48 +00:00
|
|
|
|
string current_hash = process.StandardOutput.ReadToEnd ().Trim ();
|
|
|
|
|
|
|
|
|
|
if (process.ExitCode != 0)
|
|
|
|
|
return null;
|
|
|
|
|
else
|
|
|
|
|
return current_hash;
|
2010-07-21 23:17:20 +00:00
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Gets the user's name, example: "User Name"
|
|
|
|
|
public string GetUserName ()
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
string user_name;
|
|
|
|
|
|
|
|
|
|
Process process = new Process ();
|
|
|
|
|
process.StartInfo.RedirectStandardOutput = true;
|
|
|
|
|
process.StartInfo.UseShellExecute = false;
|
|
|
|
|
process.StartInfo.FileName = "git";
|
2010-08-02 20:19:22 +00:00
|
|
|
|
process.StartInfo.WorkingDirectory = LocalPath;
|
2010-07-21 23:17:20 +00:00
|
|
|
|
process.StartInfo.Arguments = "config --get user.name";
|
|
|
|
|
process.Start ();
|
|
|
|
|
|
|
|
|
|
user_name = process.StandardOutput.ReadToEnd ().Trim ();
|
|
|
|
|
|
|
|
|
|
if (user_name.Equals ("")) {
|
|
|
|
|
|
|
|
|
|
UnixUserInfo unix_user_info = new UnixUserInfo (UnixEnvironment.UserName);
|
|
|
|
|
|
|
|
|
|
if (unix_user_info.RealName.Equals (""))
|
2010-08-15 14:41:47 +00:00
|
|
|
|
user_name = "Mysterious Stranger";
|
2010-07-21 23:17:20 +00:00
|
|
|
|
else
|
|
|
|
|
user_name = unix_user_info.RealName;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return user_name;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Gets the user's email, example: "person@gnome.org"
|
|
|
|
|
public string GetUserEmail ()
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
string user_email;
|
|
|
|
|
|
|
|
|
|
Process process = new Process ();
|
|
|
|
|
process.StartInfo.UseShellExecute = false;
|
|
|
|
|
process.StartInfo.RedirectStandardOutput = true;
|
|
|
|
|
process.StartInfo.FileName = "git";
|
2010-08-02 20:19:22 +00:00
|
|
|
|
process.StartInfo.WorkingDirectory = LocalPath;
|
2010-07-21 23:17:20 +00:00
|
|
|
|
process.StartInfo.Arguments = "config --get user.email";
|
|
|
|
|
process.Start ();
|
2010-08-15 14:41:47 +00:00
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
user_email = process.StandardOutput.ReadToEnd ().Trim ();
|
|
|
|
|
|
2010-08-15 14:41:47 +00:00
|
|
|
|
if (user_email.Equals (""))
|
|
|
|
|
user_email = "Unknown Email";
|
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
return user_email;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-08-08 19:16:48 +00:00
|
|
|
|
// Create a first commit in case the user has cloned
|
|
|
|
|
// an empty repository
|
|
|
|
|
private void CreateInitialCommit ()
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
TextWriter writer = new StreamWriter (Path.Combine (LocalPath, "SparkleShare.txt"));
|
|
|
|
|
writer.WriteLine (":)");
|
|
|
|
|
writer.Close ();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-07-21 23:17:20 +00:00
|
|
|
|
// Gets the url of the remote repo, example: "ssh://git@git.gnome.org/project"
|
|
|
|
|
public string GetRemoteOriginUrl ()
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
string remote_origin_url;
|
|
|
|
|
|
|
|
|
|
Process process = new Process ();
|
|
|
|
|
process.StartInfo.UseShellExecute = false;
|
|
|
|
|
process.StartInfo.RedirectStandardOutput = true;
|
|
|
|
|
process.StartInfo.FileName = "git";
|
2010-08-02 20:19:22 +00:00
|
|
|
|
process.StartInfo.WorkingDirectory = LocalPath;
|
2010-07-21 23:17:20 +00:00
|
|
|
|
process.StartInfo.Arguments = "config --get remote.origin.url";
|
|
|
|
|
process.Start ();
|
|
|
|
|
|
|
|
|
|
remote_origin_url = process.StandardOutput.ReadToEnd ().Trim ();
|
|
|
|
|
|
|
|
|
|
return remote_origin_url;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2010-08-26 08:52:49 +00:00
|
|
|
|
// TODO: this is ugly. refactor.
|
2010-05-03 00:04:39 +00:00
|
|
|
|
// Creates a pretty commit message based on what has changed
|
2010-06-16 23:16:50 +00:00
|
|
|
|
private string FormatCommitMessage ()
|
2010-06-15 00:08:35 +00:00
|
|
|
|
{
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
|
|
|
|
bool DoneAddCommit = false;
|
|
|
|
|
bool DoneEditCommit = false;
|
|
|
|
|
bool DoneRenameCommit = false;
|
|
|
|
|
bool DoneDeleteCommit = false;
|
|
|
|
|
int FilesAdded = 0;
|
|
|
|
|
int FilesEdited = 0;
|
|
|
|
|
int FilesRenamed = 0;
|
|
|
|
|
int FilesDeleted = 0;
|
|
|
|
|
|
|
|
|
|
Process.StartInfo.Arguments = "status";
|
2010-05-31 19:24:42 +00:00
|
|
|
|
Process.Start ();
|
2010-08-26 08:52:49 +00:00
|
|
|
|
string output = Process.StandardOutput.ReadToEnd ();
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
2010-08-26 08:52:49 +00:00
|
|
|
|
foreach (string line in Regex.Split (output, "\n")) {
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (line.IndexOf ("new file:") > -1)
|
2010-05-03 00:04:39 +00:00
|
|
|
|
FilesAdded++;
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (line.IndexOf ("modified:") > -1)
|
2010-05-03 00:04:39 +00:00
|
|
|
|
FilesEdited++;
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (line.IndexOf ("renamed:") > -1)
|
2010-05-03 00:04:39 +00:00
|
|
|
|
FilesRenamed++;
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (line.IndexOf ("deleted:") > -1)
|
2010-05-03 00:04:39 +00:00
|
|
|
|
FilesDeleted++;
|
|
|
|
|
}
|
|
|
|
|
|
2010-08-26 08:52:49 +00:00
|
|
|
|
foreach (string line in Regex.Split (output, "\n")) {
|
2010-05-03 00:04:39 +00:00
|
|
|
|
|
|
|
|
|
// Format message for when files are added,
|
|
|
|
|
// example: "added 'file' and 3 more."
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (line.IndexOf ("new file:") > -1 && !DoneAddCommit) {
|
2010-05-03 00:04:39 +00:00
|
|
|
|
DoneAddCommit = true;
|
|
|
|
|
if (FilesAdded > 1)
|
|
|
|
|
return "added ‘" +
|
2010-07-20 21:21:37 +00:00
|
|
|
|
line.Replace ("#\tnew file:", "").Trim () +
|
2010-06-17 19:34:11 +00:00
|
|
|
|
"’\nand " + (FilesAdded - 1) + " more.";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
else
|
|
|
|
|
return "added ‘" +
|
2010-07-20 21:21:37 +00:00
|
|
|
|
line.Replace ("#\tnew file:", "").Trim () + "’.";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Format message for when files are edited,
|
|
|
|
|
// example: "edited 'file'."
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (line.IndexOf ("modified:") > -1 && !DoneEditCommit) {
|
2010-05-03 00:04:39 +00:00
|
|
|
|
DoneEditCommit = true;
|
|
|
|
|
if (FilesEdited > 1)
|
|
|
|
|
return "edited ‘" +
|
2010-07-20 21:21:37 +00:00
|
|
|
|
line.Replace ("#\tmodified:", "").Trim () +
|
2010-06-17 19:34:11 +00:00
|
|
|
|
"’\nand " + (FilesEdited - 1) + " more.";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
else
|
|
|
|
|
return "edited ‘" +
|
2010-07-20 21:21:37 +00:00
|
|
|
|
line.Replace ("#\tmodified:", "").Trim () + "’.";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Format message for when files are edited,
|
|
|
|
|
// example: "deleted 'file'."
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (line.IndexOf ("deleted:") > -1 && !DoneDeleteCommit) {
|
2010-05-03 00:04:39 +00:00
|
|
|
|
DoneDeleteCommit = true;
|
|
|
|
|
if (FilesDeleted > 1)
|
|
|
|
|
return "deleted ‘" +
|
2010-07-20 21:21:37 +00:00
|
|
|
|
line.Replace ("#\tdeleted:", "").Trim () +
|
2010-06-17 19:34:11 +00:00
|
|
|
|
"’\nand " + (FilesDeleted - 1) + " more.";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
else
|
|
|
|
|
return "deleted ‘" +
|
2010-07-20 21:21:37 +00:00
|
|
|
|
line.Replace ("#\tdeleted:", "").Trim () + "’.";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Format message for when files are renamed,
|
|
|
|
|
// example: "renamed 'file' to 'new name'."
|
2010-07-20 21:21:37 +00:00
|
|
|
|
if (line.IndexOf ("renamed:") > -1 && !DoneRenameCommit) {
|
2010-05-03 00:04:39 +00:00
|
|
|
|
DoneDeleteCommit = true;
|
|
|
|
|
if (FilesRenamed > 1)
|
|
|
|
|
return "renamed ‘" +
|
2010-07-20 21:21:37 +00:00
|
|
|
|
line.Replace ("#\trenamed:", "").Trim ().Replace
|
2010-06-15 00:08:35 +00:00
|
|
|
|
(" -> ", "’ to ‘") + "’ and " + (FilesDeleted - 1) +
|
|
|
|
|
" more.";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
else
|
|
|
|
|
return "renamed ‘" +
|
2010-07-20 21:21:37 +00:00
|
|
|
|
line.Replace ("#\trenamed:", "").Trim ().Replace
|
2010-06-15 00:08:35 +00:00
|
|
|
|
(" -> ", "’ to ‘") + "’.";
|
2010-05-03 00:04:39 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Nothing happened:
|
|
|
|
|
return "";
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2010-07-24 21:31:24 +00:00
|
|
|
|
// Arguments for most events
|
2010-07-21 19:39:28 +00:00
|
|
|
|
public class SparkleEventArgs : System.EventArgs {
|
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
public string Type;
|
2010-07-21 19:39:28 +00:00
|
|
|
|
public string Message;
|
2010-07-20 23:01:09 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
public SparkleEventArgs (string type)
|
2010-07-21 19:39:28 +00:00
|
|
|
|
{
|
2010-07-24 21:31:24 +00:00
|
|
|
|
|
2010-07-24 14:03:58 +00:00
|
|
|
|
Type = type;
|
2010-07-24 21:31:24 +00:00
|
|
|
|
|
2010-07-21 19:39:28 +00:00
|
|
|
|
}
|
2010-07-20 23:01:09 +00:00
|
|
|
|
|
2010-07-21 19:39:28 +00:00
|
|
|
|
}
|
2010-07-20 23:01:09 +00:00
|
|
|
|
|
|
|
|
|
|
2010-07-24 21:31:24 +00:00
|
|
|
|
// Arguments for the NewCommit event
|
2010-07-24 12:32:05 +00:00
|
|
|
|
public class NewCommitArgs : System.EventArgs {
|
|
|
|
|
|
|
|
|
|
public string Author;
|
|
|
|
|
public string Email;
|
|
|
|
|
public string Message;
|
2010-08-19 20:13:45 +00:00
|
|
|
|
public string RepositoryName;
|
2010-07-20 23:01:09 +00:00
|
|
|
|
|
2010-08-19 20:13:45 +00:00
|
|
|
|
public NewCommitArgs (string author, string email, string message, string repository_name)
|
2010-07-24 12:32:05 +00:00
|
|
|
|
{
|
2010-07-24 21:31:24 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
Author = author;
|
|
|
|
|
Email = email;
|
|
|
|
|
Message = message;
|
2010-08-19 20:13:45 +00:00
|
|
|
|
RepositoryName = repository_name;
|
2010-07-24 21:31:24 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
}
|
2010-07-20 23:01:09 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
}
|
2010-07-20 23:01:09 +00:00
|
|
|
|
|
2010-07-24 12:32:05 +00:00
|
|
|
|
}
|