forked from libgit2/libgit2sharp
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathReflogCollection.cs
More file actions
133 lines (116 loc) · 5.31 KB
/
ReflogCollection.cs
File metadata and controls
133 lines (116 loc) · 5.31 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
using System;
using System.Collections;
using System.Collections.Generic;
using System.Diagnostics;
using System.Globalization;
using System.Linq;
using LibGit2Sharp.Core;
using LibGit2Sharp.Core.Handles;
namespace LibGit2Sharp
{
/// <summary>
/// The <see cref="ReflogCollection"/> is the reflog of a given <see cref="Reference"/>, as a enumerable of <see cref="ReflogEntry"/>.
/// Reflog is a mechanism to record when the tip of a <see cref="Branch"/> is updated.
/// </summary>
[DebuggerDisplay("{DebuggerDisplay,nq}")]
public class ReflogCollection : IEnumerable<ReflogEntry>
{
internal readonly Repository repo;
private readonly string canonicalName;
/// <summary>
/// Needed for mocking purposes.
/// </summary>
protected ReflogCollection()
{ }
/// <summary>
/// Initializes a new instance of the <see cref="ReflogCollection"/> class.
/// </summary>
/// <param name="repo">The repo.</param>
/// <param name="canonicalName">the canonical name of the <see cref="Reference"/> to retrieve reflog entries on.</param>
internal ReflogCollection(Repository repo, string canonicalName)
{
Ensure.ArgumentNotNullOrEmptyString(canonicalName, "canonicalName");
Ensure.ArgumentNotNull(repo, "repo");
if (!repo.Refs.IsValidName(canonicalName))
{
throw new InvalidSpecificationException(
string.Format("The given reference name '{0}' is not valid", canonicalName));
}
this.repo = repo;
this.canonicalName = canonicalName;
}
#region Implementation of IEnumerable
/// <summary>
/// Returns an enumerator that iterates through the collection.
/// <para>
/// The enumerator returns the <see cref="ReflogEntry"/> by descending order (last reflog entry is returned first).
/// </para>
/// </summary>
/// <returns>An <see cref="IEnumerator{T}"/> object that can be used to iterate through the collection.</returns>
public IEnumerator<ReflogEntry> GetEnumerator()
{
var entries = new List<ReflogEntry>();
using (ReflogSafeHandle reflog = Proxy.git_reflog_read(repo.Handle, canonicalName))
{
var entriesCount = Proxy.git_reflog_entrycount(reflog);
for (int i = 0; i < entriesCount; i++)
{
ReflogEntrySafeHandle handle = Proxy.git_reflog_entry_byindex(reflog, i);
entries.Add(new ReflogEntry(handle));
}
}
return entries.GetEnumerator();
}
/// <summary>
/// Returns an enumerator that iterates through the collection.
/// </summary>
/// <returns>An <see cref="IEnumerator"/> object that can be used to iterate through the collection.</returns>
IEnumerator IEnumerable.GetEnumerator()
{
return GetEnumerator();
}
#endregion
private string DebuggerDisplay
{
get
{
return string.Format(CultureInfo.InvariantCulture,
"Count = {0}", this.Count());
}
}
/// <summary>
/// Add a new <see cref="ReflogEntry"/> to the current <see cref="ReflogCollection"/>. It will be created as first item of the collection
/// The native reflog object will be saved right after inserting the entry.
/// </summary>
/// <param name="target">the <see cref="ObjectId"/> of the new target the <see cref="Reference"/> will point out to.</param>
/// <param name="reflogMessage">the message associated with the new <see cref="ReflogEntry"/>.</param>
/// <param name="committer"><see cref="Signature"/> of the comitter.</param>
internal virtual void Append(ObjectId target, string reflogMessage, Signature committer)
{
var logAllRefUpdates = repo.Config.GetValueOrDefault<bool>("core.logAllRefUpdates", false);
if (!logAllRefUpdates)
{
return;
}
using (ReflogSafeHandle reflog = Proxy.git_reflog_read(repo.Handle, canonicalName))
{
string prettifiedMessage = Proxy.git_message_prettify(reflogMessage);
Proxy.git_reflog_append(reflog, target, committer, prettifiedMessage);
}
}
/// <summary>
/// Add a new <see cref="ReflogEntry"/> to the current <see cref="ReflogCollection"/>. It will be created as first item of the collection
/// The native reflog object will be saved right after inserting the entry.
/// <para>
/// The <see cref="Signature"/> will be built from the current Git configuration.
/// </para>
/// </summary>
/// <param name="target">the <see cref="ObjectId"/> of the new target the <see cref="Reference"/> will point out to.</param>
/// <param name="reflogMessage">the message associated with the new <see cref="ReflogEntry"/>.</param>
internal void Append(ObjectId target, string reflogMessage)
{
Signature author = repo.Config.BuildSignature(DateTimeOffset.Now, false);
Append(target, reflogMessage, author);
}
}
}