From 5e57c0b3f18e878670688cb9a853c531defa9036 Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Thu, 21 Nov 2024 23:58:49 -0500 Subject: [PATCH 01/11] Use SafeHandle as base class --- LibGit2Sharp/Core/Handles/Libgit2Object.cs | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/LibGit2Sharp/Core/Handles/Libgit2Object.cs b/LibGit2Sharp/Core/Handles/Libgit2Object.cs index a96d99e10..29cebe14e 100644 --- a/LibGit2Sharp/Core/Handles/Libgit2Object.cs +++ b/LibGit2Sharp/Core/Handles/Libgit2Object.cs @@ -18,7 +18,7 @@ //#define LEAKS_TRACKING using System; -using Microsoft.Win32.SafeHandles; +using System.Runtime.InteropServices; #if LEAKS_IDENTIFYING namespace LibGit2Sharp.Core @@ -83,7 +83,7 @@ namespace LibGit2Sharp.Core.Handles using System.Globalization; #endif - internal unsafe abstract class Libgit2Object : SafeHandleZeroOrMinusOneIsInvalid + internal unsafe abstract class Libgit2Object : SafeHandle { #if LEAKS_TRACKING private readonly string trace; @@ -96,7 +96,7 @@ internal unsafe Libgit2Object(void* ptr, bool owned) } internal unsafe Libgit2Object(IntPtr ptr, bool owned) - : base(owned) + : base(IntPtr.Zero, owned) { SetHandle(ptr); @@ -108,12 +108,14 @@ internal unsafe Libgit2Object(IntPtr ptr, bool owned) #endif } + public override bool IsInvalid => handle == IntPtr.Zero; + internal IntPtr AsIntPtr() => DangerousGetHandle(); protected override void Dispose(bool disposing) { #if LEAKS_IDENTIFYING - bool leaked = !disposing && DangerousGetHandle() != IntPtr.Zero; + bool leaked = !disposing && !IsInvalid; if (leaked) { From cf31b8f317f9de3067d495083b40728b20753cc6 Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Fri, 22 Nov 2024 00:00:00 -0500 Subject: [PATCH 02/11] Use handle directly in ReleaseHandle --- LibGit2Sharp/Core/Handles/Objects.cs | 50 ++++++++++++++-------------- LibGit2Sharp/Core/Handles/Objects.tt | 2 +- 2 files changed, 26 insertions(+), 26 deletions(-) diff --git a/LibGit2Sharp/Core/Handles/Objects.cs b/LibGit2Sharp/Core/Handles/Objects.cs index ddca49bee..18b79b616 100644 --- a/LibGit2Sharp/Core/Handles/Objects.cs +++ b/LibGit2Sharp/Core/Handles/Objects.cs @@ -18,7 +18,7 @@ internal TreeEntryHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_tree_entry_free((git_tree_entry*)AsIntPtr()); + NativeMethods.git_tree_entry_free((git_tree_entry*)handle); return true; } @@ -43,7 +43,7 @@ internal ReferenceHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_reference_free((git_reference*)AsIntPtr()); + NativeMethods.git_reference_free((git_reference*)handle); return true; } @@ -68,7 +68,7 @@ internal RepositoryHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_repository_free((git_repository*)AsIntPtr()); + NativeMethods.git_repository_free((git_repository*)handle); return true; } @@ -93,7 +93,7 @@ internal SignatureHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_signature_free((git_signature*)AsIntPtr()); + NativeMethods.git_signature_free((git_signature*)handle); return true; } @@ -118,7 +118,7 @@ internal StatusListHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_status_list_free((git_status_list*)AsIntPtr()); + NativeMethods.git_status_list_free((git_status_list*)handle); return true; } @@ -143,7 +143,7 @@ internal BlameHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_blame_free((git_blame*)AsIntPtr()); + NativeMethods.git_blame_free((git_blame*)handle); return true; } @@ -168,7 +168,7 @@ internal DiffHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_diff_free((git_diff*)AsIntPtr()); + NativeMethods.git_diff_free((git_diff*)handle); return true; } @@ -193,7 +193,7 @@ internal PatchHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_patch_free((git_patch*)AsIntPtr()); + NativeMethods.git_patch_free((git_patch*)handle); return true; } @@ -218,7 +218,7 @@ internal ConfigurationHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_config_free((git_config*)AsIntPtr()); + NativeMethods.git_config_free((git_config*)handle); return true; } @@ -243,7 +243,7 @@ internal ConflictIteratorHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_index_conflict_iterator_free((git_index_conflict_iterator*)AsIntPtr()); + NativeMethods.git_index_conflict_iterator_free((git_index_conflict_iterator*)handle); return true; } @@ -268,7 +268,7 @@ internal IndexHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_index_free((git_index*)AsIntPtr()); + NativeMethods.git_index_free((git_index*)handle); return true; } @@ -293,7 +293,7 @@ internal ReflogHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_reflog_free((git_reflog*)AsIntPtr()); + NativeMethods.git_reflog_free((git_reflog*)handle); return true; } @@ -318,7 +318,7 @@ internal TreeBuilderHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_treebuilder_free((git_treebuilder*)AsIntPtr()); + NativeMethods.git_treebuilder_free((git_treebuilder*)handle); return true; } @@ -343,7 +343,7 @@ internal PackBuilderHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_packbuilder_free((git_packbuilder*)AsIntPtr()); + NativeMethods.git_packbuilder_free((git_packbuilder*)handle); return true; } @@ -368,7 +368,7 @@ internal NoteHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_note_free((git_note*)AsIntPtr()); + NativeMethods.git_note_free((git_note*)handle); return true; } @@ -393,7 +393,7 @@ internal DescribeResultHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_describe_result_free((git_describe_result*)AsIntPtr()); + NativeMethods.git_describe_result_free((git_describe_result*)handle); return true; } @@ -418,7 +418,7 @@ internal SubmoduleHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_submodule_free((git_submodule*)AsIntPtr()); + NativeMethods.git_submodule_free((git_submodule*)handle); return true; } @@ -443,7 +443,7 @@ internal AnnotatedCommitHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_annotated_commit_free((git_annotated_commit*)AsIntPtr()); + NativeMethods.git_annotated_commit_free((git_annotated_commit*)handle); return true; } @@ -468,7 +468,7 @@ internal ObjectDatabaseHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_odb_free((git_odb*)AsIntPtr()); + NativeMethods.git_odb_free((git_odb*)handle); return true; } @@ -493,7 +493,7 @@ internal RevWalkerHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_revwalk_free((git_revwalk*)AsIntPtr()); + NativeMethods.git_revwalk_free((git_revwalk*)handle); return true; } @@ -518,7 +518,7 @@ internal RemoteHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_remote_free((git_remote*)AsIntPtr()); + NativeMethods.git_remote_free((git_remote*)handle); return true; } @@ -543,7 +543,7 @@ internal ObjectHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_object_free((git_object*)AsIntPtr()); + NativeMethods.git_object_free((git_object*)handle); return true; } @@ -568,7 +568,7 @@ internal RebaseHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_rebase_free((git_rebase*)AsIntPtr()); + NativeMethods.git_rebase_free((git_rebase*)handle); return true; } @@ -593,7 +593,7 @@ internal OdbStreamHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_odb_stream_free((git_odb_stream*)AsIntPtr()); + NativeMethods.git_odb_stream_free((git_odb_stream*)handle); return true; } @@ -618,7 +618,7 @@ internal WorktreeHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_worktree_free((git_worktree*)AsIntPtr()); + NativeMethods.git_worktree_free((git_worktree*)handle); return true; } diff --git a/LibGit2Sharp/Core/Handles/Objects.tt b/LibGit2Sharp/Core/Handles/Objects.tt index e522bd859..7202fa819 100644 --- a/LibGit2Sharp/Core/Handles/Objects.tt +++ b/LibGit2Sharp/Core/Handles/Objects.tt @@ -84,7 +84,7 @@ for (var i = 0; i < cNames.Length; i++) protected override bool ReleaseHandle() { - NativeMethods.<#= cNames[i] #>_free((<#= cNames[i] #>*)AsIntPtr()); + NativeMethods.<#= cNames[i] #>_free((<#= cNames[i] #>*)handle); return true; } From e6180f6f62e3b79583041a5aa3a3d5cc05d3a5fb Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Fri, 22 Nov 2024 00:32:26 -0500 Subject: [PATCH 03/11] Remove AsIntPtr --- LibGit2Sharp/Core/Handles/Libgit2Object.cs | 2 - LibGit2Sharp/Core/Handles/Objects.cs | 50 +++++++++++----------- LibGit2Sharp/Core/Handles/Objects.tt | 2 +- LibGit2Sharp/Core/NativeMethods.cs | 16 +++---- LibGit2Sharp/Core/Proxy.cs | 18 ++++---- LibGit2Sharp/Reference.cs | 6 --- 6 files changed, 43 insertions(+), 51 deletions(-) diff --git a/LibGit2Sharp/Core/Handles/Libgit2Object.cs b/LibGit2Sharp/Core/Handles/Libgit2Object.cs index 29cebe14e..e912d2137 100644 --- a/LibGit2Sharp/Core/Handles/Libgit2Object.cs +++ b/LibGit2Sharp/Core/Handles/Libgit2Object.cs @@ -110,8 +110,6 @@ internal unsafe Libgit2Object(IntPtr ptr, bool owned) public override bool IsInvalid => handle == IntPtr.Zero; - internal IntPtr AsIntPtr() => DangerousGetHandle(); - protected override void Dispose(bool disposing) { #if LEAKS_IDENTIFYING diff --git a/LibGit2Sharp/Core/Handles/Objects.cs b/LibGit2Sharp/Core/Handles/Objects.cs index 18b79b616..6ae208a7c 100644 --- a/LibGit2Sharp/Core/Handles/Objects.cs +++ b/LibGit2Sharp/Core/Handles/Objects.cs @@ -25,7 +25,7 @@ protected override bool ReleaseHandle() public static implicit operator git_tree_entry*(TreeEntryHandle handle) { - return (git_tree_entry*)handle.AsIntPtr(); + return (git_tree_entry*)handle.DangerousGetHandle(); } } @@ -50,7 +50,7 @@ protected override bool ReleaseHandle() public static implicit operator git_reference*(ReferenceHandle handle) { - return (git_reference*)handle.AsIntPtr(); + return (git_reference*)handle.DangerousGetHandle(); } } @@ -75,7 +75,7 @@ protected override bool ReleaseHandle() public static implicit operator git_repository*(RepositoryHandle handle) { - return (git_repository*)handle.AsIntPtr(); + return (git_repository*)handle.DangerousGetHandle(); } } @@ -100,7 +100,7 @@ protected override bool ReleaseHandle() public static implicit operator git_signature*(SignatureHandle handle) { - return (git_signature*)handle.AsIntPtr(); + return (git_signature*)handle.DangerousGetHandle(); } } @@ -125,7 +125,7 @@ protected override bool ReleaseHandle() public static implicit operator git_status_list*(StatusListHandle handle) { - return (git_status_list*)handle.AsIntPtr(); + return (git_status_list*)handle.DangerousGetHandle(); } } @@ -150,7 +150,7 @@ protected override bool ReleaseHandle() public static implicit operator git_blame*(BlameHandle handle) { - return (git_blame*)handle.AsIntPtr(); + return (git_blame*)handle.DangerousGetHandle(); } } @@ -175,7 +175,7 @@ protected override bool ReleaseHandle() public static implicit operator git_diff*(DiffHandle handle) { - return (git_diff*)handle.AsIntPtr(); + return (git_diff*)handle.DangerousGetHandle(); } } @@ -200,7 +200,7 @@ protected override bool ReleaseHandle() public static implicit operator git_patch*(PatchHandle handle) { - return (git_patch*)handle.AsIntPtr(); + return (git_patch*)handle.DangerousGetHandle(); } } @@ -225,7 +225,7 @@ protected override bool ReleaseHandle() public static implicit operator git_config*(ConfigurationHandle handle) { - return (git_config*)handle.AsIntPtr(); + return (git_config*)handle.DangerousGetHandle(); } } @@ -250,7 +250,7 @@ protected override bool ReleaseHandle() public static implicit operator git_index_conflict_iterator*(ConflictIteratorHandle handle) { - return (git_index_conflict_iterator*)handle.AsIntPtr(); + return (git_index_conflict_iterator*)handle.DangerousGetHandle(); } } @@ -275,7 +275,7 @@ protected override bool ReleaseHandle() public static implicit operator git_index*(IndexHandle handle) { - return (git_index*)handle.AsIntPtr(); + return (git_index*)handle.DangerousGetHandle(); } } @@ -300,7 +300,7 @@ protected override bool ReleaseHandle() public static implicit operator git_reflog*(ReflogHandle handle) { - return (git_reflog*)handle.AsIntPtr(); + return (git_reflog*)handle.DangerousGetHandle(); } } @@ -325,7 +325,7 @@ protected override bool ReleaseHandle() public static implicit operator git_treebuilder*(TreeBuilderHandle handle) { - return (git_treebuilder*)handle.AsIntPtr(); + return (git_treebuilder*)handle.DangerousGetHandle(); } } @@ -350,7 +350,7 @@ protected override bool ReleaseHandle() public static implicit operator git_packbuilder*(PackBuilderHandle handle) { - return (git_packbuilder*)handle.AsIntPtr(); + return (git_packbuilder*)handle.DangerousGetHandle(); } } @@ -375,7 +375,7 @@ protected override bool ReleaseHandle() public static implicit operator git_note*(NoteHandle handle) { - return (git_note*)handle.AsIntPtr(); + return (git_note*)handle.DangerousGetHandle(); } } @@ -400,7 +400,7 @@ protected override bool ReleaseHandle() public static implicit operator git_describe_result*(DescribeResultHandle handle) { - return (git_describe_result*)handle.AsIntPtr(); + return (git_describe_result*)handle.DangerousGetHandle(); } } @@ -425,7 +425,7 @@ protected override bool ReleaseHandle() public static implicit operator git_submodule*(SubmoduleHandle handle) { - return (git_submodule*)handle.AsIntPtr(); + return (git_submodule*)handle.DangerousGetHandle(); } } @@ -450,7 +450,7 @@ protected override bool ReleaseHandle() public static implicit operator git_annotated_commit*(AnnotatedCommitHandle handle) { - return (git_annotated_commit*)handle.AsIntPtr(); + return (git_annotated_commit*)handle.DangerousGetHandle(); } } @@ -475,7 +475,7 @@ protected override bool ReleaseHandle() public static implicit operator git_odb*(ObjectDatabaseHandle handle) { - return (git_odb*)handle.AsIntPtr(); + return (git_odb*)handle.DangerousGetHandle(); } } @@ -500,7 +500,7 @@ protected override bool ReleaseHandle() public static implicit operator git_revwalk*(RevWalkerHandle handle) { - return (git_revwalk*)handle.AsIntPtr(); + return (git_revwalk*)handle.DangerousGetHandle(); } } @@ -525,7 +525,7 @@ protected override bool ReleaseHandle() public static implicit operator git_remote*(RemoteHandle handle) { - return (git_remote*)handle.AsIntPtr(); + return (git_remote*)handle.DangerousGetHandle(); } } @@ -550,7 +550,7 @@ protected override bool ReleaseHandle() public static implicit operator git_object*(ObjectHandle handle) { - return (git_object*)handle.AsIntPtr(); + return (git_object*)handle.DangerousGetHandle(); } } @@ -575,7 +575,7 @@ protected override bool ReleaseHandle() public static implicit operator git_rebase*(RebaseHandle handle) { - return (git_rebase*)handle.AsIntPtr(); + return (git_rebase*)handle.DangerousGetHandle(); } } @@ -600,7 +600,7 @@ protected override bool ReleaseHandle() public static implicit operator git_odb_stream*(OdbStreamHandle handle) { - return (git_odb_stream*)handle.AsIntPtr(); + return (git_odb_stream*)handle.DangerousGetHandle(); } } @@ -625,7 +625,7 @@ protected override bool ReleaseHandle() public static implicit operator git_worktree*(WorktreeHandle handle) { - return (git_worktree*)handle.AsIntPtr(); + return (git_worktree*)handle.DangerousGetHandle(); } } diff --git a/LibGit2Sharp/Core/Handles/Objects.tt b/LibGit2Sharp/Core/Handles/Objects.tt index 7202fa819..2b7bfbab4 100644 --- a/LibGit2Sharp/Core/Handles/Objects.tt +++ b/LibGit2Sharp/Core/Handles/Objects.tt @@ -91,7 +91,7 @@ for (var i = 0; i < cNames.Length; i++) public static implicit operator <#= cNames[i] #>*(<#= csNames[i] #> handle) { - return (<#= cNames[i] #>*)handle.AsIntPtr(); + return (<#= cNames[i] #>*)handle.DangerousGetHandle(); } } diff --git a/LibGit2Sharp/Core/NativeMethods.cs b/LibGit2Sharp/Core/NativeMethods.cs index cbb850b16..e4bd7567a 100644 --- a/LibGit2Sharp/Core/NativeMethods.cs +++ b/LibGit2Sharp/Core/NativeMethods.cs @@ -256,7 +256,7 @@ internal static extern void git_branch_iterator_free( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_branch_iterator_new( out IntPtr iter_out, - IntPtr repo, + RepositoryHandle repo, GitBranchType branch_type); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -562,7 +562,7 @@ internal static extern unsafe int git_config_foreach( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_config_iterator_glob_new( out IntPtr iter, - IntPtr cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string regexp); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -1248,7 +1248,7 @@ internal static extern unsafe int git_reference_lookup( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_reference_name(git_reference* reference); + internal static extern unsafe string git_reference_name(ReferenceHandle reference); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_remove( @@ -1285,7 +1285,7 @@ internal static extern unsafe int git_reference_symbolic_set_target( internal static extern unsafe string git_reference_symbolic_target(git_reference* reference); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe GitReferenceType git_reference_type(git_reference* reference); + internal static extern unsafe GitReferenceType git_reference_type(ReferenceHandle reference); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_ensure_log( @@ -1545,10 +1545,10 @@ internal static extern unsafe int git_repository_fetchhead_foreach( internal static extern unsafe void git_repository_free(git_repository* repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern int git_repository_head_detached(IntPtr repo); + internal static extern int git_repository_head_detached(RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern int git_repository_head_unborn(IntPtr repo); + internal static extern int git_repository_head_unborn(RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_ident( @@ -1566,10 +1566,10 @@ internal static extern unsafe int git_repository_init_ext( GitRepositoryInitOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern int git_repository_is_bare(IntPtr handle); + internal static extern int git_repository_is_bare(RepositoryHandle handle); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern int git_repository_is_shallow(IntPtr repo); + internal static extern int git_repository_is_shallow(RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_state_cleanup(git_repository* repo); diff --git a/LibGit2Sharp/Core/Proxy.cs b/LibGit2Sharp/Core/Proxy.cs index 83d35e22c..4215f403a 100644 --- a/LibGit2Sharp/Core/Proxy.cs +++ b/LibGit2Sharp/Core/Proxy.cs @@ -131,7 +131,7 @@ public static unsafe void git_branch_delete(ReferenceHandle reference) public static IEnumerable git_branch_iterator(Repository repo, GitBranchType branchType) { IntPtr iter; - var res = NativeMethods.git_branch_iterator_new(out iter, repo.Handle.AsIntPtr(), branchType); + var res = NativeMethods.git_branch_iterator_new(out iter, repo.Handle, branchType); Ensure.ZeroResult(res); try @@ -345,7 +345,7 @@ public static unsafe string git_commit_create_buffer( try { handles = parents.Select(c => Proxy.git_object_lookup(c.repo.Handle, c.Id, GitObjectType.Commit)).ToArray(); - var ptrs = handles.Select(p => p.AsIntPtr()).ToArray(); + var ptrs = handles.Select(p => p.DangerousGetHandle()).ToArray(); int res; fixed (IntPtr* objs = ptrs) { @@ -624,7 +624,7 @@ public static IEnumerable> git_config_iterator_glob( string regexp) { IntPtr iter; - var res = NativeMethods.git_config_iterator_glob_new(out iter, config.AsIntPtr(), regexp); + var res = NativeMethods.git_config_iterator_glob_new(out iter, config, regexp); Ensure.ZeroResult(res); try { @@ -1302,7 +1302,7 @@ public static unsafe ObjectId git_annotated_commit_id(AnnotatedCommitHandle merg public static unsafe void git_merge(RepositoryHandle repo, AnnotatedCommitHandle[] heads, GitMergeOpts mergeOptions, GitCheckoutOpts checkoutOptions, out bool earlyStop) { - IntPtr[] their_heads = heads.Select(head => head.AsIntPtr()).ToArray(); + IntPtr[] their_heads = heads.Select(head => head.DangerousGetHandle()).ToArray(); int res = NativeMethods.git_merge(repo, their_heads, @@ -1327,7 +1327,7 @@ public static unsafe void git_merge_analysis( out GitMergeAnalysis analysis_out, out GitMergePreference preference_out) { - IntPtr[] their_heads = heads.Select(head => head.AsIntPtr()).ToArray(); + IntPtr[] their_heads = heads.Select(head => head.DangerousGetHandle()).ToArray(); int res = NativeMethods.git_merge_analysis(out analysis_out, out preference_out, @@ -1955,7 +1955,7 @@ public static unsafe ReferenceHandle git_reference_lookup(RepositoryHandle repo, return new ReferenceHandle(handle, true); } - public static unsafe string git_reference_name(git_reference* reference) + public static unsafe string git_reference_name(ReferenceHandle reference) { return NativeMethods.git_reference_name(reference); } @@ -2011,7 +2011,7 @@ public static unsafe string git_reference_symbolic_target(git_reference* referen return NativeMethods.git_reference_symbolic_target(reference); } - public static unsafe GitReferenceType git_reference_type(git_reference* reference) + public static unsafe GitReferenceType git_reference_type(ReferenceHandle reference) { return NativeMethods.git_reference_type(reference); } @@ -3822,9 +3822,9 @@ private static ICollection git_foreach( return result; } - private static unsafe bool RepositoryStateChecker(RepositoryHandle repo, Func checker) + private static unsafe bool RepositoryStateChecker(RepositoryHandle repo, Func checker) { - int res = checker(repo.AsIntPtr()); + int res = checker(repo); Ensure.BooleanResult(res); return (res == 1); diff --git a/LibGit2Sharp/Reference.cs b/LibGit2Sharp/Reference.cs index 9a86195d1..0f69a93ae 100644 --- a/LibGit2Sharp/Reference.cs +++ b/LibGit2Sharp/Reference.cs @@ -32,13 +32,7 @@ private protected Reference(IRepository repo, string canonicalName, string targe this.targetIdentifier = targetIdentifier; } - // This overload lets public-facing methods avoid having to use the pointers directly internal static unsafe T BuildFromPtr(ReferenceHandle handle, Repository repo) where T : Reference - { - return BuildFromPtr((git_reference*)handle.AsIntPtr(), repo); - } - - internal static unsafe T BuildFromPtr(git_reference* handle, Repository repo) where T : Reference { GitReferenceType type = Proxy.git_reference_type(handle); string name = Proxy.git_reference_name(handle); From 3efe59b701adf142c2b58d88dd20ae4200a9fe4c Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Fri, 22 Nov 2024 23:22:02 -0500 Subject: [PATCH 04/11] WIP --- LibGit2Sharp/Core/Handles/Objects.cs | 125 --------------------------- LibGit2Sharp/Core/Handles/Objects.tt | 5 -- LibGit2Sharp/Core/NativeMethods.cs | 18 ++-- LibGit2Sharp/Core/Proxy.cs | 14 +-- 4 files changed, 16 insertions(+), 146 deletions(-) diff --git a/LibGit2Sharp/Core/Handles/Objects.cs b/LibGit2Sharp/Core/Handles/Objects.cs index 6ae208a7c..513a43030 100644 --- a/LibGit2Sharp/Core/Handles/Objects.cs +++ b/LibGit2Sharp/Core/Handles/Objects.cs @@ -22,11 +22,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_tree_entry*(TreeEntryHandle handle) - { - return (git_tree_entry*)handle.DangerousGetHandle(); - } } internal unsafe class ReferenceHandle : Libgit2Object @@ -47,11 +42,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_reference*(ReferenceHandle handle) - { - return (git_reference*)handle.DangerousGetHandle(); - } } internal unsafe class RepositoryHandle : Libgit2Object @@ -72,11 +62,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_repository*(RepositoryHandle handle) - { - return (git_repository*)handle.DangerousGetHandle(); - } } internal unsafe class SignatureHandle : Libgit2Object @@ -97,11 +82,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_signature*(SignatureHandle handle) - { - return (git_signature*)handle.DangerousGetHandle(); - } } internal unsafe class StatusListHandle : Libgit2Object @@ -122,11 +102,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_status_list*(StatusListHandle handle) - { - return (git_status_list*)handle.DangerousGetHandle(); - } } internal unsafe class BlameHandle : Libgit2Object @@ -147,11 +122,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_blame*(BlameHandle handle) - { - return (git_blame*)handle.DangerousGetHandle(); - } } internal unsafe class DiffHandle : Libgit2Object @@ -172,11 +142,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_diff*(DiffHandle handle) - { - return (git_diff*)handle.DangerousGetHandle(); - } } internal unsafe class PatchHandle : Libgit2Object @@ -197,11 +162,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_patch*(PatchHandle handle) - { - return (git_patch*)handle.DangerousGetHandle(); - } } internal unsafe class ConfigurationHandle : Libgit2Object @@ -222,11 +182,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_config*(ConfigurationHandle handle) - { - return (git_config*)handle.DangerousGetHandle(); - } } internal unsafe class ConflictIteratorHandle : Libgit2Object @@ -247,11 +202,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_index_conflict_iterator*(ConflictIteratorHandle handle) - { - return (git_index_conflict_iterator*)handle.DangerousGetHandle(); - } } internal unsafe class IndexHandle : Libgit2Object @@ -272,11 +222,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_index*(IndexHandle handle) - { - return (git_index*)handle.DangerousGetHandle(); - } } internal unsafe class ReflogHandle : Libgit2Object @@ -297,11 +242,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_reflog*(ReflogHandle handle) - { - return (git_reflog*)handle.DangerousGetHandle(); - } } internal unsafe class TreeBuilderHandle : Libgit2Object @@ -322,11 +262,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_treebuilder*(TreeBuilderHandle handle) - { - return (git_treebuilder*)handle.DangerousGetHandle(); - } } internal unsafe class PackBuilderHandle : Libgit2Object @@ -347,11 +282,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_packbuilder*(PackBuilderHandle handle) - { - return (git_packbuilder*)handle.DangerousGetHandle(); - } } internal unsafe class NoteHandle : Libgit2Object @@ -372,11 +302,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_note*(NoteHandle handle) - { - return (git_note*)handle.DangerousGetHandle(); - } } internal unsafe class DescribeResultHandle : Libgit2Object @@ -397,11 +322,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_describe_result*(DescribeResultHandle handle) - { - return (git_describe_result*)handle.DangerousGetHandle(); - } } internal unsafe class SubmoduleHandle : Libgit2Object @@ -422,11 +342,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_submodule*(SubmoduleHandle handle) - { - return (git_submodule*)handle.DangerousGetHandle(); - } } internal unsafe class AnnotatedCommitHandle : Libgit2Object @@ -447,11 +362,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_annotated_commit*(AnnotatedCommitHandle handle) - { - return (git_annotated_commit*)handle.DangerousGetHandle(); - } } internal unsafe class ObjectDatabaseHandle : Libgit2Object @@ -472,11 +382,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_odb*(ObjectDatabaseHandle handle) - { - return (git_odb*)handle.DangerousGetHandle(); - } } internal unsafe class RevWalkerHandle : Libgit2Object @@ -497,11 +402,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_revwalk*(RevWalkerHandle handle) - { - return (git_revwalk*)handle.DangerousGetHandle(); - } } internal unsafe class RemoteHandle : Libgit2Object @@ -522,11 +422,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_remote*(RemoteHandle handle) - { - return (git_remote*)handle.DangerousGetHandle(); - } } internal unsafe class ObjectHandle : Libgit2Object @@ -547,11 +442,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_object*(ObjectHandle handle) - { - return (git_object*)handle.DangerousGetHandle(); - } } internal unsafe class RebaseHandle : Libgit2Object @@ -572,11 +462,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_rebase*(RebaseHandle handle) - { - return (git_rebase*)handle.DangerousGetHandle(); - } } internal unsafe class OdbStreamHandle : Libgit2Object @@ -597,11 +482,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_odb_stream*(OdbStreamHandle handle) - { - return (git_odb_stream*)handle.DangerousGetHandle(); - } } internal unsafe class WorktreeHandle : Libgit2Object @@ -622,11 +502,6 @@ protected override bool ReleaseHandle() return true; } - - public static implicit operator git_worktree*(WorktreeHandle handle) - { - return (git_worktree*)handle.DangerousGetHandle(); - } } } diff --git a/LibGit2Sharp/Core/Handles/Objects.tt b/LibGit2Sharp/Core/Handles/Objects.tt index 2b7bfbab4..5ec365c7e 100644 --- a/LibGit2Sharp/Core/Handles/Objects.tt +++ b/LibGit2Sharp/Core/Handles/Objects.tt @@ -88,11 +88,6 @@ for (var i = 0; i < cNames.Length; i++) return true; } - - public static implicit operator <#= cNames[i] #>*(<#= csNames[i] #> handle) - { - return (<#= cNames[i] #>*)handle.DangerousGetHandle(); - } } <# diff --git a/LibGit2Sharp/Core/NativeMethods.cs b/LibGit2Sharp/Core/NativeMethods.cs index e4bd7567a..53231bf7e 100644 --- a/LibGit2Sharp/Core/NativeMethods.cs +++ b/LibGit2Sharp/Core/NativeMethods.cs @@ -179,7 +179,7 @@ internal static extern int git_error_set_str( internal static extern void git_error_set_oom(); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe uint git_blame_get_hunk_count(git_blame* blame); + internal static extern unsafe uint git_blame_get_hunk_count(BlameHandle blame); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_blame_hunk* git_blame_get_hunk_byindex( @@ -453,7 +453,7 @@ internal static extern unsafe int git_config_delete_entry( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_config_lock(out IntPtr txn, git_config* config); + internal static extern unsafe int git_config_lock(out IntPtr txn, ConfigurationHandle config); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_delete_multivar( @@ -1256,7 +1256,7 @@ internal static extern unsafe int git_reference_remove( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_oid* git_reference_target(git_reference* reference); + internal static extern unsafe git_oid* git_reference_target(ReferenceHandle reference); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_rename( @@ -1282,7 +1282,7 @@ internal static extern unsafe int git_reference_symbolic_set_target( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_reference_symbolic_target(git_reference* reference); + internal static extern unsafe string git_reference_symbolic_target(ReferenceHandle reference); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe GitReferenceType git_reference_type(ReferenceHandle reference); @@ -2000,7 +2000,7 @@ internal static extern int git_transport_unregister( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string prefix); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe uint git_tree_entry_filemode(git_tree_entry* entry); + internal static extern unsafe uint git_tree_entry_filemode(TreeEntryHandle entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_tree_entry* git_tree_entry_byindex(git_object* tree, UIntPtr idx); @@ -2015,17 +2015,17 @@ internal static extern unsafe int git_tree_entry_bypath( internal static extern unsafe void git_tree_entry_free(git_tree_entry* treeEntry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_oid* git_tree_entry_id(git_tree_entry* entry); + internal static extern unsafe git_oid* git_tree_entry_id(TreeEntryHandle entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_tree_entry_name(git_tree_entry* entry); + internal static extern unsafe string git_tree_entry_name(TreeEntryHandle entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe GitObjectType git_tree_entry_type(git_tree_entry* entry); + internal static extern unsafe GitObjectType git_tree_entry_type(TreeEntryHandle entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe UIntPtr git_tree_entrycount(git_object* tree); + internal static extern unsafe UIntPtr git_tree_entrycount(ObjectHandle tree); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_treebuilder_new(out git_treebuilder* builder, git_repository* repo, IntPtr src); diff --git a/LibGit2Sharp/Core/Proxy.cs b/LibGit2Sharp/Core/Proxy.cs index 4215f403a..5ff6df3a8 100644 --- a/LibGit2Sharp/Core/Proxy.cs +++ b/LibGit2Sharp/Core/Proxy.cs @@ -656,7 +656,7 @@ public static unsafe ConfigurationHandle git_config_snapshot(ConfigurationHandle return new ConfigurationHandle(handle, true); } - public static unsafe IntPtr git_config_lock(git_config* config) + public static unsafe IntPtr git_config_lock(ConfigurationHandle config) { IntPtr txn; int res = NativeMethods.git_config_lock(out txn, config); @@ -1966,7 +1966,7 @@ public static unsafe void git_reference_remove(RepositoryHandle repo, string nam Ensure.ZeroResult(res); } - public static unsafe ObjectId git_reference_target(git_reference* reference) + public static unsafe ObjectId git_reference_target(ReferenceHandle reference) { return ObjectId.BuildFromPtr(NativeMethods.git_reference_target(reference)); } @@ -2006,7 +2006,7 @@ public static unsafe ReferenceHandle git_reference_symbolic_set_target(Reference return new ReferenceHandle(ref_out, true); } - public static unsafe string git_reference_symbolic_target(git_reference* reference) + public static unsafe string git_reference_symbolic_target(ReferenceHandle reference) { return NativeMethods.git_reference_symbolic_target(reference); } @@ -3249,7 +3249,7 @@ public static int git_transport_smart_credentials(out IntPtr cred, IntPtr transp #region git_tree_ - public static unsafe Mode git_tree_entry_attributes(git_tree_entry* entry) + public static unsafe Mode git_tree_entry_attributes(TreeEntryHandle entry) { return (Mode)NativeMethods.git_tree_entry_filemode(entry); } @@ -3283,17 +3283,17 @@ public static unsafe TreeEntryHandle git_tree_entry_bypath(RepositoryHandle repo } } - public static unsafe ObjectId git_tree_entry_id(git_tree_entry* entry) + public static unsafe ObjectId git_tree_entry_id(TreeEntryHandle entry) { return ObjectId.BuildFromPtr(NativeMethods.git_tree_entry_id(entry)); } - public static unsafe string git_tree_entry_name(git_tree_entry* entry) + public static unsafe string git_tree_entry_name(TreeEntryHandle entry) { return NativeMethods.git_tree_entry_name(entry); } - public static unsafe GitObjectType git_tree_entry_type(git_tree_entry* entry) + public static unsafe GitObjectType git_tree_entry_type(TreeEntryHandle entry) { return NativeMethods.git_tree_entry_type(entry); } From bd5fb50d26af566777a1e199769273f2f72f075f Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Fri, 22 Nov 2024 23:41:23 -0500 Subject: [PATCH 05/11] WIP --- LibGit2Sharp/Core/GitFilter.cs | 3 +- LibGit2Sharp/Core/Handles/Objects.cs | 175 +------ LibGit2Sharp/Core/Handles/Objects.tt | 7 +- LibGit2Sharp/Core/NativeMethods.cs | 694 +++++++++++++-------------- LibGit2Sharp/Core/Opaques.cs | 32 -- LibGit2Sharp/Core/Proxy.cs | 118 ++--- 6 files changed, 434 insertions(+), 595 deletions(-) delete mode 100644 LibGit2Sharp/Core/Opaques.cs diff --git a/LibGit2Sharp/Core/GitFilter.cs b/LibGit2Sharp/Core/GitFilter.cs index 72fa2f763..0b393b0ab 100644 --- a/LibGit2Sharp/Core/GitFilter.cs +++ b/LibGit2Sharp/Core/GitFilter.cs @@ -1,5 +1,6 @@ using System; using System.Runtime.InteropServices; +using LibGit2Sharp.Core.Handles; namespace LibGit2Sharp.Core { @@ -118,7 +119,7 @@ public delegate int git_filter_stream_fn( [StructLayout(LayoutKind.Sequential)] internal unsafe struct git_filter_source { - public git_repository* repository; + public RepositoryHandle repository; public char* path; diff --git a/LibGit2Sharp/Core/Handles/Objects.cs b/LibGit2Sharp/Core/Handles/Objects.cs index 513a43030..5537bbd2d 100644 --- a/LibGit2Sharp/Core/Handles/Objects.cs +++ b/LibGit2Sharp/Core/Handles/Objects.cs @@ -6,11 +6,6 @@ namespace LibGit2Sharp.Core.Handles internal unsafe class TreeEntryHandle : Libgit2Object { - internal TreeEntryHandle(git_tree_entry* ptr, bool owned) - : base(ptr, owned) - { - } - internal TreeEntryHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -18,7 +13,7 @@ internal TreeEntryHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_tree_entry_free((git_tree_entry*)handle); + NativeMethods.git_tree_entry_free(this); return true; } @@ -26,11 +21,6 @@ protected override bool ReleaseHandle() internal unsafe class ReferenceHandle : Libgit2Object { - internal ReferenceHandle(git_reference* ptr, bool owned) - : base(ptr, owned) - { - } - internal ReferenceHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -38,7 +28,7 @@ internal ReferenceHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_reference_free((git_reference*)handle); + NativeMethods.git_reference_free(this); return true; } @@ -46,11 +36,6 @@ protected override bool ReleaseHandle() internal unsafe class RepositoryHandle : Libgit2Object { - internal RepositoryHandle(git_repository* ptr, bool owned) - : base(ptr, owned) - { - } - internal RepositoryHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -58,7 +43,7 @@ internal RepositoryHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_repository_free((git_repository*)handle); + NativeMethods.git_repository_free(this); return true; } @@ -66,11 +51,6 @@ protected override bool ReleaseHandle() internal unsafe class SignatureHandle : Libgit2Object { - internal SignatureHandle(git_signature* ptr, bool owned) - : base(ptr, owned) - { - } - internal SignatureHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -78,7 +58,7 @@ internal SignatureHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_signature_free((git_signature*)handle); + NativeMethods.git_signature_free(this); return true; } @@ -86,11 +66,6 @@ protected override bool ReleaseHandle() internal unsafe class StatusListHandle : Libgit2Object { - internal StatusListHandle(git_status_list* ptr, bool owned) - : base(ptr, owned) - { - } - internal StatusListHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -98,7 +73,7 @@ internal StatusListHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_status_list_free((git_status_list*)handle); + NativeMethods.git_status_list_free(this); return true; } @@ -106,11 +81,6 @@ protected override bool ReleaseHandle() internal unsafe class BlameHandle : Libgit2Object { - internal BlameHandle(git_blame* ptr, bool owned) - : base(ptr, owned) - { - } - internal BlameHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -118,7 +88,7 @@ internal BlameHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_blame_free((git_blame*)handle); + NativeMethods.git_blame_free(this); return true; } @@ -126,11 +96,6 @@ protected override bool ReleaseHandle() internal unsafe class DiffHandle : Libgit2Object { - internal DiffHandle(git_diff* ptr, bool owned) - : base(ptr, owned) - { - } - internal DiffHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -138,7 +103,7 @@ internal DiffHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_diff_free((git_diff*)handle); + NativeMethods.git_diff_free(this); return true; } @@ -146,11 +111,6 @@ protected override bool ReleaseHandle() internal unsafe class PatchHandle : Libgit2Object { - internal PatchHandle(git_patch* ptr, bool owned) - : base(ptr, owned) - { - } - internal PatchHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -158,7 +118,7 @@ internal PatchHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_patch_free((git_patch*)handle); + NativeMethods.git_patch_free(this); return true; } @@ -166,11 +126,6 @@ protected override bool ReleaseHandle() internal unsafe class ConfigurationHandle : Libgit2Object { - internal ConfigurationHandle(git_config* ptr, bool owned) - : base(ptr, owned) - { - } - internal ConfigurationHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -178,7 +133,7 @@ internal ConfigurationHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_config_free((git_config*)handle); + NativeMethods.git_config_free(this); return true; } @@ -186,11 +141,6 @@ protected override bool ReleaseHandle() internal unsafe class ConflictIteratorHandle : Libgit2Object { - internal ConflictIteratorHandle(git_index_conflict_iterator* ptr, bool owned) - : base(ptr, owned) - { - } - internal ConflictIteratorHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -198,7 +148,7 @@ internal ConflictIteratorHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_index_conflict_iterator_free((git_index_conflict_iterator*)handle); + NativeMethods.git_index_conflict_iterator_free(this); return true; } @@ -206,11 +156,6 @@ protected override bool ReleaseHandle() internal unsafe class IndexHandle : Libgit2Object { - internal IndexHandle(git_index* ptr, bool owned) - : base(ptr, owned) - { - } - internal IndexHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -218,7 +163,7 @@ internal IndexHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_index_free((git_index*)handle); + NativeMethods.git_index_free(this); return true; } @@ -226,11 +171,6 @@ protected override bool ReleaseHandle() internal unsafe class ReflogHandle : Libgit2Object { - internal ReflogHandle(git_reflog* ptr, bool owned) - : base(ptr, owned) - { - } - internal ReflogHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -238,7 +178,7 @@ internal ReflogHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_reflog_free((git_reflog*)handle); + NativeMethods.git_reflog_free(this); return true; } @@ -246,11 +186,6 @@ protected override bool ReleaseHandle() internal unsafe class TreeBuilderHandle : Libgit2Object { - internal TreeBuilderHandle(git_treebuilder* ptr, bool owned) - : base(ptr, owned) - { - } - internal TreeBuilderHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -258,7 +193,7 @@ internal TreeBuilderHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_treebuilder_free((git_treebuilder*)handle); + NativeMethods.git_treebuilder_free(this); return true; } @@ -266,11 +201,6 @@ protected override bool ReleaseHandle() internal unsafe class PackBuilderHandle : Libgit2Object { - internal PackBuilderHandle(git_packbuilder* ptr, bool owned) - : base(ptr, owned) - { - } - internal PackBuilderHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -278,7 +208,7 @@ internal PackBuilderHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_packbuilder_free((git_packbuilder*)handle); + NativeMethods.git_packbuilder_free(this); return true; } @@ -286,11 +216,6 @@ protected override bool ReleaseHandle() internal unsafe class NoteHandle : Libgit2Object { - internal NoteHandle(git_note* ptr, bool owned) - : base(ptr, owned) - { - } - internal NoteHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -298,7 +223,7 @@ internal NoteHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_note_free((git_note*)handle); + NativeMethods.git_note_free(this); return true; } @@ -306,11 +231,6 @@ protected override bool ReleaseHandle() internal unsafe class DescribeResultHandle : Libgit2Object { - internal DescribeResultHandle(git_describe_result* ptr, bool owned) - : base(ptr, owned) - { - } - internal DescribeResultHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -318,7 +238,7 @@ internal DescribeResultHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_describe_result_free((git_describe_result*)handle); + NativeMethods.git_describe_result_free(this); return true; } @@ -326,11 +246,6 @@ protected override bool ReleaseHandle() internal unsafe class SubmoduleHandle : Libgit2Object { - internal SubmoduleHandle(git_submodule* ptr, bool owned) - : base(ptr, owned) - { - } - internal SubmoduleHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -338,7 +253,7 @@ internal SubmoduleHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_submodule_free((git_submodule*)handle); + NativeMethods.git_submodule_free(this); return true; } @@ -346,11 +261,6 @@ protected override bool ReleaseHandle() internal unsafe class AnnotatedCommitHandle : Libgit2Object { - internal AnnotatedCommitHandle(git_annotated_commit* ptr, bool owned) - : base(ptr, owned) - { - } - internal AnnotatedCommitHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -358,7 +268,7 @@ internal AnnotatedCommitHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_annotated_commit_free((git_annotated_commit*)handle); + NativeMethods.git_annotated_commit_free(this); return true; } @@ -366,11 +276,6 @@ protected override bool ReleaseHandle() internal unsafe class ObjectDatabaseHandle : Libgit2Object { - internal ObjectDatabaseHandle(git_odb* ptr, bool owned) - : base(ptr, owned) - { - } - internal ObjectDatabaseHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -378,7 +283,7 @@ internal ObjectDatabaseHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_odb_free((git_odb*)handle); + NativeMethods.git_odb_free(this); return true; } @@ -386,11 +291,6 @@ protected override bool ReleaseHandle() internal unsafe class RevWalkerHandle : Libgit2Object { - internal RevWalkerHandle(git_revwalk* ptr, bool owned) - : base(ptr, owned) - { - } - internal RevWalkerHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -398,7 +298,7 @@ internal RevWalkerHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_revwalk_free((git_revwalk*)handle); + NativeMethods.git_revwalk_free(this); return true; } @@ -406,11 +306,6 @@ protected override bool ReleaseHandle() internal unsafe class RemoteHandle : Libgit2Object { - internal RemoteHandle(git_remote* ptr, bool owned) - : base(ptr, owned) - { - } - internal RemoteHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -418,7 +313,7 @@ internal RemoteHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_remote_free((git_remote*)handle); + NativeMethods.git_remote_free(this); return true; } @@ -426,11 +321,6 @@ protected override bool ReleaseHandle() internal unsafe class ObjectHandle : Libgit2Object { - internal ObjectHandle(git_object* ptr, bool owned) - : base(ptr, owned) - { - } - internal ObjectHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -438,7 +328,7 @@ internal ObjectHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_object_free((git_object*)handle); + NativeMethods.git_object_free(this); return true; } @@ -446,11 +336,6 @@ protected override bool ReleaseHandle() internal unsafe class RebaseHandle : Libgit2Object { - internal RebaseHandle(git_rebase* ptr, bool owned) - : base(ptr, owned) - { - } - internal RebaseHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -458,7 +343,7 @@ internal RebaseHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_rebase_free((git_rebase*)handle); + NativeMethods.git_rebase_free(this); return true; } @@ -466,11 +351,6 @@ protected override bool ReleaseHandle() internal unsafe class OdbStreamHandle : Libgit2Object { - internal OdbStreamHandle(git_odb_stream* ptr, bool owned) - : base(ptr, owned) - { - } - internal OdbStreamHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -478,7 +358,7 @@ internal OdbStreamHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_odb_stream_free((git_odb_stream*)handle); + NativeMethods.git_odb_stream_free(this); return true; } @@ -486,11 +366,6 @@ protected override bool ReleaseHandle() internal unsafe class WorktreeHandle : Libgit2Object { - internal WorktreeHandle(git_worktree* ptr, bool owned) - : base(ptr, owned) - { - } - internal WorktreeHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -498,7 +373,7 @@ internal WorktreeHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_worktree_free((git_worktree*)handle); + NativeMethods.git_worktree_free(this); return true; } diff --git a/LibGit2Sharp/Core/Handles/Objects.tt b/LibGit2Sharp/Core/Handles/Objects.tt index 5ec365c7e..2f53872de 100644 --- a/LibGit2Sharp/Core/Handles/Objects.tt +++ b/LibGit2Sharp/Core/Handles/Objects.tt @@ -72,11 +72,6 @@ for (var i = 0; i < cNames.Length; i++) #> internal unsafe class <#= csNames[i] #> : Libgit2Object { - internal <#= csNames[i] #>(<#= cNames[i] #>* ptr, bool owned) - : base(ptr, owned) - { - } - internal <#= csNames[i] #>(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -84,7 +79,7 @@ for (var i = 0; i < cNames.Length; i++) protected override bool ReleaseHandle() { - NativeMethods.<#= cNames[i] #>_free((<#= cNames[i] #>*)handle); + NativeMethods.<#= cNames[i] #>_free(this); return true; } diff --git a/LibGit2Sharp/Core/NativeMethods.cs b/LibGit2Sharp/Core/NativeMethods.cs index 53231bf7e..102799ddd 100644 --- a/LibGit2Sharp/Core/NativeMethods.cs +++ b/LibGit2Sharp/Core/NativeMethods.cs @@ -183,34 +183,34 @@ internal static extern int git_error_set_str( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_blame_hunk* git_blame_get_hunk_byindex( - git_blame* blame, uint index); + BlameHandle blame, uint index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_blame_file( - out git_blame* blame, - git_repository* repo, + out BlameHandle blame, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string path, git_blame_options options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_blame_free(git_blame* blame); + internal static extern unsafe void git_blame_free(BlameHandle blame); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_blob_create_from_disk( ref GitOid id, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_blob_create_from_workdir( ref GitOid id, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath relative_path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_blob_create_from_stream( out IntPtr stream, - git_repository* repositoryPtr, + RepositoryHandle repositoryPtr, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string hintpath); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -221,27 +221,27 @@ internal static extern int git_blob_create_from_stream_commit( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_blob_filtered_content( GitBuf buf, - git_object* blob, + ObjectHandle blob, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string as_path, [MarshalAs(UnmanagedType.Bool)] bool check_for_binary_data); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe IntPtr git_blob_rawcontent(git_object* blob); + internal static extern unsafe IntPtr git_blob_rawcontent(ObjectHandle blob); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe long git_blob_rawsize(git_object* blob); + internal static extern unsafe long git_blob_rawsize(ObjectHandle blob); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_branch_create_from_annotated( - out git_reference* ref_out, - git_repository* repo, + out ReferenceHandle ref_out, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string branch_name, - git_annotated_commit* target, + AnnotatedCommitHandle target, [MarshalAs(UnmanagedType.Bool)] bool force); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_branch_delete( - git_reference* reference); + ReferenceHandle reference); [UnmanagedFunctionPointer(CallingConvention.Cdecl)] internal delegate int branch_foreach_callback( @@ -261,8 +261,8 @@ internal static extern int git_branch_iterator_new( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_branch_move( - out git_reference* ref_out, - git_reference* reference, + out ReferenceHandle ref_out, + ReferenceHandle reference, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string new_branch_name, [MarshalAs(UnmanagedType.Bool)] bool force); @@ -275,7 +275,7 @@ internal static extern int git_branch_next( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_branch_remote_name( GitBuf buf, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string canonical_branch_name); [UnmanagedFunctionPointer(CallingConvention.Cdecl)] @@ -287,41 +287,41 @@ internal delegate int commit_signing_callback( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_rebase_init( - out git_rebase* rebase, - git_repository* repo, - git_annotated_commit* branch, - git_annotated_commit* upstream, - git_annotated_commit* onto, + out RebaseHandle rebase, + RepositoryHandle repo, + AnnotatedCommitHandle branch, + AnnotatedCommitHandle upstream, + AnnotatedCommitHandle onto, GitRebaseOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_rebase_open( - out git_rebase* rebase, - git_repository* repo, + out RebaseHandle rebase, + RepositoryHandle repo, GitRebaseOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe UIntPtr git_rebase_operation_entrycount( - git_rebase* rebase); + RebaseHandle rebase); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe UIntPtr git_rebase_operation_current( - git_rebase* rebase); + RebaseHandle rebase); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_rebase_operation* git_rebase_operation_byindex( - git_rebase* rebase, + RebaseHandle rebase, UIntPtr index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_rebase_next( out git_rebase_operation* operation, - git_rebase* rebase); + RebaseHandle rebase); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_rebase_commit( ref GitOid id, - git_rebase* rebase, + RebaseHandle rebase, git_signature* author, git_signature* committer, IntPtr message_encoding, @@ -329,20 +329,20 @@ internal static extern unsafe int git_rebase_commit( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_rebase_abort( - git_rebase* rebase); + RebaseHandle rebase); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_rebase_finish( - git_rebase* repo, + RebaseHandle repo, git_signature* signature); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_rebase_free(git_rebase* rebase); + internal static extern unsafe void git_rebase_free(RebaseHandle rebase); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_rename( ref GitStrArray problems, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string old_name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string new_name); @@ -354,7 +354,7 @@ internal delegate int git_remote_rename_problem_cb( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_branch_upstream_name( GitBuf buf, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string referenceName); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -362,33 +362,33 @@ internal static extern unsafe int git_branch_upstream_name( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_checkout_tree( - git_repository* repo, - git_object* treeish, + RepositoryHandle repo, + ObjectHandle treeish, ref GitCheckoutOpts opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_checkout_index( - git_repository* repo, - git_object* treeish, + RepositoryHandle repo, + ObjectHandle treeish, ref GitCheckoutOpts opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_clone( - out git_repository* repo, + out RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string origin_url, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath workdir_path, ref GitCloneOptions opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_signature* git_commit_author(git_object* commit); + internal static extern unsafe git_signature* git_commit_author(ObjectHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_signature* git_commit_committer(git_object* commit); + internal static extern unsafe git_signature* git_commit_committer(ObjectHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_commit_create_from_ids( out GitOid id, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string updateRef, git_signature* author, git_signature* committer, @@ -401,55 +401,55 @@ internal static extern unsafe int git_commit_create_from_ids( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_commit_create_buffer( GitBuf res, - git_repository* repo, + RepositoryHandle repo, git_signature* author, git_signature* committer, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string encoding, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message, - git_object* tree, + ObjectHandle tree, UIntPtr parent_count, IntPtr* parents /* git_commit** originally */); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_commit_create_with_signature( out GitOid id, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string commit_content, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string signature, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string signature_field); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_commit_message(git_object* commit); + internal static extern unsafe string git_commit_message(ObjectHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_commit_summary(git_object* commit); + internal static extern unsafe string git_commit_summary(ObjectHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_commit_message_encoding(git_object* commit); + internal static extern unsafe string git_commit_message_encoding(ObjectHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_oid* git_commit_parent_id(git_object* commit, uint n); + internal static extern unsafe git_oid* git_commit_parent_id(ObjectHandle commit, uint n); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe uint git_commit_parentcount(git_object* commit); + internal static extern unsafe uint git_commit_parentcount(ObjectHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_oid* git_commit_tree_id(git_object* commit); + internal static extern unsafe git_oid* git_commit_tree_id(ObjectHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_commit_extract_signature( GitBuf signature, GitBuf signed_data, - git_repository* repo, + RepositoryHandle repo, ref GitOid commit_id, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string field); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_delete_entry( - git_config* cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -457,13 +457,13 @@ internal static extern unsafe int git_config_delete_entry( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_delete_multivar( - git_config* cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string regexp); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_set_multivar( - git_config* cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string regexp, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string value); @@ -481,7 +481,7 @@ internal static extern unsafe int git_config_set_multivar( internal static extern int git_config_find_programdata(GitBuf programdata_config_path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_config_free(git_config* cfg); + internal static extern unsafe void git_config_free(ConfigurationHandle cfg); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe void git_config_entry_free(GitConfigEntry* entry); @@ -489,24 +489,24 @@ internal static extern unsafe int git_config_set_multivar( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_get_entry( out GitConfigEntry* entry, - git_config* cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_add_file_ondisk( - git_config* cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath path, uint level, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.Bool)] bool force); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_config_new(out git_config* cfg); + internal static extern unsafe int git_config_new(out ConfigurationHandle cfg); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_open_level( - out git_config* cfg, - git_config* parent, + out ConfigurationHandle cfg, + ConfigurationHandle parent, uint level); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -526,25 +526,25 @@ internal static extern int git_config_parse_int64( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_set_bool( - git_config* cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.Bool)] bool value); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_set_int32( - git_config* cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, int value); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_set_int64( - git_config* cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, long value); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_set_string( - git_config* cfg, + ConfigurationHandle cfg, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string value); @@ -555,7 +555,7 @@ internal delegate int config_foreach_callback( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_config_foreach( - git_config* cfg, + ConfigurationHandle cfg, config_foreach_callback callback, IntPtr payload); @@ -574,7 +574,7 @@ internal static extern int git_config_next( internal static extern void git_config_iterator_free(IntPtr iter); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_config_snapshot(out git_config* @out, git_config* config); + internal static extern unsafe int git_config_snapshot(out ConfigurationHandle @out, ConfigurationHandle config); // Ordinarily we would decorate the `url` parameter with the StrictUtf8Marshaler like we do everywhere // else, but apparently doing a native->managed callback with the 64-bit version of CLR 2.0 can @@ -603,55 +603,55 @@ internal static extern int git_cred_userpass_plaintext_new( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_describe_commit( - out git_describe_result* describe, - git_object* committish, + out DescribeResultHandle describe, + ObjectHandle committish, ref GitDescribeOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_describe_format( GitBuf buf, - git_describe_result* describe, + DescribeResultHandle describe, ref GitDescribeFormatOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_describe_result_free(git_describe_result* describe); + internal static extern unsafe void git_describe_result_free(DescribeResultHandle describe); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_diff_free(git_diff* diff); + internal static extern unsafe void git_diff_free(DiffHandle diff); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_diff_tree_to_tree( - out git_diff* diff, - git_repository* repo, - git_object* oldTree, - git_object* newTree, + out DiffHandle diff, + RepositoryHandle repo, + ObjectHandle oldTree, + ObjectHandle newTree, GitDiffOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_diff_tree_to_index( - out git_diff* diff, - git_repository* repo, - git_object* oldTree, - git_index* index, + out DiffHandle diff, + RepositoryHandle repo, + ObjectHandle oldTree, + IndexHandle index, GitDiffOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_diff_merge( - git_diff* onto, - git_diff* from); + DiffHandle onto, + DiffHandle from); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_diff_index_to_workdir( - out git_diff* diff, - git_repository* repo, - git_index* index, + out DiffHandle diff, + RepositoryHandle repo, + IndexHandle index, GitDiffOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_diff_tree_to_workdir( - out git_diff* diff, - git_repository* repo, - git_object* oldTree, + out DiffHandle diff, + RepositoryHandle repo, + ObjectHandle oldTree, GitDiffOptions options); [UnmanagedFunctionPointer(CallingConvention.Cdecl)] @@ -681,9 +681,9 @@ internal unsafe delegate int git_diff_binary_cb( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_diff_blobs( - git_object* oldBlob, + ObjectHandle oldBlob, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string old_as_path, - git_object* newBlob, + ObjectHandle newBlob, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string new_as_path, GitDiffOptions options, git_diff_file_cb fileCallback, @@ -694,7 +694,7 @@ internal static extern unsafe int git_diff_blobs( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_diff_foreach( - git_diff* diff, + DiffHandle diff, git_diff_file_cb fileCallback, git_diff_binary_cb binaryCallback, git_diff_hunk_cb hunkCallback, @@ -703,14 +703,14 @@ internal static extern unsafe int git_diff_foreach( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_diff_find_similar( - git_diff* diff, + DiffHandle diff, GitDiffFindOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe UIntPtr git_diff_num_deltas(git_diff* diff); + internal static extern unsafe UIntPtr git_diff_num_deltas(DiffHandle diff); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_diff_delta* git_diff_get_delta(git_diff* diff, UIntPtr idx); + internal static extern unsafe git_diff_delta* git_diff_get_delta(DiffHandle diff, UIntPtr idx); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_filter_register( @@ -813,36 +813,36 @@ internal static extern int git_libgit2_opts_osxarm64(int option, IntPtr nop2, In #endregion [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_graph_ahead_behind(out UIntPtr ahead, out UIntPtr behind, git_repository* repo, ref GitOid one, ref GitOid two); + internal static extern unsafe int git_graph_ahead_behind(out UIntPtr ahead, out UIntPtr behind, RepositoryHandle repo, ref GitOid one, ref GitOid two); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_graph_descendant_of( - git_repository* repo, + RepositoryHandle repo, ref GitOid commit, ref GitOid ancestor); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_ignore_add_rule( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string rules); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_ignore_clear_internal_rules(git_repository* repo); + internal static extern unsafe int git_ignore_clear_internal_rules(RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_ignore_path_is_ignored( out int ignored, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_index_add_bypath( - git_index* index, + IndexHandle index, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_index_add( - git_index* index, + IndexHandle index, git_index_entry* entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -850,140 +850,140 @@ internal static extern unsafe int git_index_conflict_get( out git_index_entry* ancestor, out git_index_entry* ours, out git_index_entry* theirs, - git_index* index, + IndexHandle index, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_index_conflict_iterator_new( - out git_index_conflict_iterator* iterator, - git_index* index); + out ConflictIteratorHandle iterator, + IndexHandle index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_index_conflict_next( out git_index_entry* ancestor, out git_index_entry* ours, out git_index_entry* theirs, - git_index_conflict_iterator* iterator); + ConflictIteratorHandle iterator); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe void git_index_conflict_iterator_free( - git_index_conflict_iterator* iterator); + ConflictIteratorHandle iterator); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe UIntPtr git_index_entrycount(git_index* index); + internal static extern unsafe UIntPtr git_index_entrycount(IndexHandle index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_index_entry_stage(git_index_entry* indexentry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_index_free(git_index* index); + internal static extern unsafe void git_index_free(IndexHandle index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_index_entry* git_index_get_byindex(git_index* index, UIntPtr n); + internal static extern unsafe git_index_entry* git_index_get_byindex(IndexHandle index, UIntPtr n); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_index_entry* git_index_get_bypath( - git_index* index, + IndexHandle index, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string path, int stage); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_index_has_conflicts(git_index* index); + internal static extern unsafe int git_index_has_conflicts(IndexHandle index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe UIntPtr git_index_name_entrycount(git_index* handle); + internal static extern unsafe UIntPtr git_index_name_entrycount(IndexHandle handle); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_index_name_entry* git_index_name_get_byindex(git_index* handle, UIntPtr n); + internal static extern unsafe git_index_name_entry* git_index_name_get_byindex(IndexHandle handle, UIntPtr n); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_index_open( - out git_index* index, + out IndexHandle index, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath indexpath); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_index_read( - git_index* index, + IndexHandle index, [MarshalAs(UnmanagedType.Bool)] bool force); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_index_remove_bypath( - git_index* index, + IndexHandle index, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe UIntPtr git_index_reuc_entrycount(git_index* handle); + internal static extern unsafe UIntPtr git_index_reuc_entrycount(IndexHandle handle); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_index_reuc_entry* git_index_reuc_get_byindex(git_index* handle, UIntPtr n); + internal static extern unsafe git_index_reuc_entry* git_index_reuc_get_byindex(IndexHandle handle, UIntPtr n); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_index_reuc_entry* git_index_reuc_get_bypath( - git_index* handle, + IndexHandle handle, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_index_write(git_index* index); + internal static extern unsafe int git_index_write(IndexHandle index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_index_write_tree(out GitOid treeOid, git_index* index); + internal static extern unsafe int git_index_write_tree(out GitOid treeOid, IndexHandle index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_index_write_tree_to(out GitOid treeOid, git_index* index, git_repository* repo); + internal static extern unsafe int git_index_write_tree_to(out GitOid treeOid, IndexHandle index, RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_index_read_tree(git_index* index, git_object* tree); + internal static extern unsafe int git_index_read_tree(IndexHandle index, ObjectHandle tree); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_index_clear(git_index* index); + internal static extern unsafe int git_index_clear(IndexHandle index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_merge_base_many( out GitOid mergeBase, - git_repository* repo, + RepositoryHandle repo, int length, [In] GitOid[] input_array); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_merge_base_octopus( out GitOid mergeBase, - git_repository* repo, + RepositoryHandle repo, int length, [In] GitOid[] input_array); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_annotated_commit_from_ref( - out git_annotated_commit* annotatedCommit, - git_repository* repo, - git_reference* reference); + out AnnotatedCommitHandle annotatedCommit, + RepositoryHandle repo, + ReferenceHandle reference); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_annotated_commit_from_fetchhead( - out git_annotated_commit* annotatedCommit, - git_repository* repo, + out AnnotatedCommitHandle annotatedCommit, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string branch_name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string remote_url, ref GitOid oid); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_annotated_commit_from_revspec( - out git_annotated_commit* annotatedCommit, - git_repository* repo, + out AnnotatedCommitHandle annotatedCommit, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string revspec); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_annotated_commit_lookup( - out git_annotated_commit* annotatedCommit, - git_repository* repo, + out AnnotatedCommitHandle annotatedCommit, + RepositoryHandle repo, ref GitOid id); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_oid* git_annotated_commit_id( - git_annotated_commit* annotatedCommit); + AnnotatedCommitHandle annotatedCommit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_merge( - git_repository* repo, + RepositoryHandle repo, [In] IntPtr[] their_heads, UIntPtr their_heads_len, ref GitMergeOpts merge_opts, @@ -991,22 +991,22 @@ internal static extern unsafe int git_merge( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_merge_commits( - out git_index* index, - git_repository* repo, - git_object* our_commit, - git_object* their_commit, + out IndexHandle index, + RepositoryHandle repo, + ObjectHandle our_commit, + ObjectHandle their_commit, ref GitMergeOpts merge_opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_merge_analysis( out GitMergeAnalysis status_out, out GitMergePreference preference_out, - git_repository* repo, + RepositoryHandle repo, [In] IntPtr[] their_heads, int their_heads_len); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_annotated_commit_free(git_annotated_commit* commit); + internal static extern unsafe void git_annotated_commit_free(AnnotatedCommitHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_message_prettify( @@ -1018,7 +1018,7 @@ internal static extern int git_message_prettify( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_note_create( out GitOid noteOid, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string notes_ref, git_signature* author, git_signature* committer, @@ -1027,25 +1027,25 @@ internal static extern unsafe int git_note_create( int force); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_note_free(git_note* note); + internal static extern unsafe void git_note_free(NoteHandle note); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_note_message(git_note* note); + internal static extern unsafe string git_note_message(NoteHandle note); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_oid* git_note_id(git_note* note); + internal static extern unsafe git_oid* git_note_id(NoteHandle note); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_note_read( - out git_note* note, - git_repository* repo, + out NoteHandle note, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string notes_ref, ref GitOid oid); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_note_remove( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string notes_ref, git_signature* author, git_signature* committer, @@ -1054,7 +1054,7 @@ internal static extern unsafe int git_note_remove( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_note_default_ref( GitBuf notes_ref, - git_repository* repo); + RepositoryHandle repo); [UnmanagedFunctionPointer(CallingConvention.Cdecl)] internal delegate int git_note_foreach_cb( @@ -1064,19 +1064,19 @@ internal delegate int git_note_foreach_cb( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_note_foreach( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string notes_ref, git_note_foreach_cb cb, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_odb_add_backend(git_odb* odb, IntPtr backend, int priority); + internal static extern unsafe int git_odb_add_backend(ObjectDatabaseHandle odb, IntPtr backend, int priority); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern IntPtr git_odb_backend_malloc(IntPtr backend, UIntPtr len); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_odb_exists(git_odb* odb, ref GitOid id); + internal static extern unsafe int git_odb_exists(ObjectDatabaseHandle odb, ref GitOid id); [UnmanagedFunctionPointer(CallingConvention.Cdecl)] internal delegate int git_odb_foreach_cb( @@ -1085,69 +1085,69 @@ internal delegate int git_odb_foreach_cb( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_odb_foreach( - git_odb* odb, + ObjectDatabaseHandle odb, git_odb_foreach_cb cb, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_odb_open_wstream(out git_odb_stream* stream, git_odb* odb, long size, GitObjectType type); + internal static extern unsafe int git_odb_open_wstream(out OdbStreamHandle stream, ObjectDatabaseHandle odb, long size, GitObjectType type); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_odb_free(git_odb* odb); + internal static extern unsafe void git_odb_free(ObjectDatabaseHandle odb); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_odb_read_header(out UIntPtr len_out, out GitObjectType type, git_odb* odb, ref GitOid id); + internal static extern unsafe int git_odb_read_header(out UIntPtr len_out, out GitObjectType type, ObjectDatabaseHandle odb, ref GitOid id); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_object_free(git_object* obj); + internal static extern unsafe void git_object_free(ObjectHandle obj); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_odb_stream_write(git_odb_stream* Stream, IntPtr Buffer, UIntPtr len); + internal static extern unsafe int git_odb_stream_write(OdbStreamHandle Stream, IntPtr Buffer, UIntPtr len); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_odb_stream_finalize_write(out GitOid id, git_odb_stream* stream); + internal static extern unsafe int git_odb_stream_finalize_write(out GitOid id, OdbStreamHandle stream); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_odb_stream_free(git_odb_stream* stream); + internal static extern unsafe void git_odb_stream_free(OdbStreamHandle stream); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_odb_write(out GitOid id, git_odb* odb, byte* data, UIntPtr len, GitObjectType type); + internal static extern unsafe int git_odb_write(out GitOid id, ObjectDatabaseHandle odb, byte* data, UIntPtr len, GitObjectType type); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_oid* git_object_id(git_object* obj); + internal static extern unsafe git_oid* git_object_id(ObjectHandle obj); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_object_lookup(out git_object* obj, git_repository* repo, ref GitOid id, GitObjectType type); + internal static extern unsafe int git_object_lookup(out ObjectHandle obj, RepositoryHandle repo, ref GitOid id, GitObjectType type); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_object_peel( - out git_object* peeled, - git_object* obj, + out ObjectHandle peeled, + ObjectHandle obj, GitObjectType type); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_object_short_id( GitBuf buf, - git_object* obj); + ObjectHandle obj); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe GitObjectType git_object_type(git_object* obj); + internal static extern unsafe GitObjectType git_object_type(ObjectHandle obj); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_patch_from_diff(out git_patch* patch, git_diff* diff, UIntPtr idx); + internal static extern unsafe int git_patch_from_diff(out PatchHandle patch, DiffHandle diff, UIntPtr idx); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_patch_print(git_patch* patch, git_diff_line_cb print_cb, IntPtr payload); + internal static extern unsafe int git_patch_print(PatchHandle patch, git_diff_line_cb print_cb, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_patch_line_stats( out UIntPtr total_context, out UIntPtr total_additions, out UIntPtr total_deletions, - git_patch* patch); + PatchHandle patch); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_patch_free(git_patch* patch); + internal static extern unsafe void git_patch_free(PatchHandle patch); /* Push network progress notification function */ [UnmanagedFunctionPointer(CallingConvention.Cdecl)] @@ -1156,54 +1156,54 @@ internal static extern unsafe int git_patch_line_stats( internal delegate int git_packbuilder_progress(int stage, uint current, uint total, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_packbuilder_free(git_packbuilder* packbuilder); + internal static extern unsafe void git_packbuilder_free(PackBuilderHandle packbuilder); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_packbuilder_insert( - git_packbuilder* packbuilder, + PackBuilderHandle packbuilder, ref GitOid id, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_packbuilder_insert_commit( - git_packbuilder* packbuilder, + PackBuilderHandle packbuilder, ref GitOid id); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_packbuilder_insert_recur( - git_packbuilder* packbuilder, + PackBuilderHandle packbuilder, ref GitOid id, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_packbuilder_insert_tree( - git_packbuilder* packbuilder, + PackBuilderHandle packbuilder, ref GitOid id); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_packbuilder_new(out git_packbuilder* packbuilder, git_repository* repo); + internal static extern unsafe int git_packbuilder_new(out PackBuilderHandle packbuilder, RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe UIntPtr git_packbuilder_object_count(git_packbuilder* packbuilder); + internal static extern unsafe UIntPtr git_packbuilder_object_count(PackBuilderHandle packbuilder); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe uint git_packbuilder_set_threads(git_packbuilder* packbuilder, uint numThreads); + internal static extern unsafe uint git_packbuilder_set_threads(PackBuilderHandle packbuilder, uint numThreads); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_packbuilder_write( - git_packbuilder* packbuilder, + PackBuilderHandle packbuilder, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath path, uint mode, IntPtr progressCallback, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe UIntPtr git_packbuilder_written(git_packbuilder* packbuilder); + internal static extern unsafe UIntPtr git_packbuilder_written(PackBuilderHandle packbuilder); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_create( - out git_reference* reference, - git_repository* repo, + out ReferenceHandle reference, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, ref GitOid oid, [MarshalAs(UnmanagedType.Bool)] bool force, @@ -1211,8 +1211,8 @@ internal static extern unsafe int git_reference_create( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_symbolic_create( - out git_reference* reference, - git_repository* repo, + out ReferenceHandle reference, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string target, [MarshalAs(UnmanagedType.Bool)] bool force, @@ -1225,25 +1225,25 @@ internal delegate int ref_glob_callback( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_foreach_glob( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string glob, ref_glob_callback callback, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_reference_free(git_reference* reference); + internal static extern unsafe void git_reference_free(ReferenceHandle reference); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_reference_is_valid_name( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string refname); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_reference_list(out GitStrArray array, git_repository* repo); + internal static extern unsafe int git_reference_list(out GitStrArray array, RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_lookup( - out git_reference* reference, - git_repository* repo, + out ReferenceHandle reference, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -1252,7 +1252,7 @@ internal static extern unsafe int git_reference_lookup( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_remove( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -1260,23 +1260,23 @@ internal static extern unsafe int git_reference_remove( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_rename( - out git_reference* ref_out, - git_reference* reference, + out ReferenceHandle ref_out, + ReferenceHandle reference, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string newName, [MarshalAs(UnmanagedType.Bool)] bool force, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string log_message); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_set_target( - out git_reference* ref_out, - git_reference* reference, + out ReferenceHandle ref_out, + ReferenceHandle reference, ref GitOid id, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string log_message); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_symbolic_set_target( - out git_reference* ref_out, - git_reference* reference, + out ReferenceHandle ref_out, + ReferenceHandle reference, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string target, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string log_message); @@ -1289,25 +1289,25 @@ internal static extern unsafe int git_reference_symbolic_set_target( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reference_ensure_log( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string refname); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_reflog_free(git_reflog* reflog); + internal static extern unsafe void git_reflog_free(ReflogHandle reflog); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reflog_read( - out git_reflog* ref_out, - git_repository* repo, + out ReflogHandle ref_out, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe UIntPtr git_reflog_entrycount - (git_reflog* reflog); + (ReflogHandle reflog); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_reflog_entry* git_reflog_entry_byindex( - git_reflog* reflog, + ReflogHandle reflog, UIntPtr idx); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -1371,11 +1371,11 @@ internal static extern bool git_refspec_dst_matches( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string reference); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_remote_autotag(git_remote* remote); + internal static extern unsafe int git_remote_autotag(RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_connect( - git_remote* remote, + RemoteHandle remote, GitDirection direction, ref GitRemoteCallbacks callbacks, ref GitProxyOptions proxy_options, @@ -1383,80 +1383,80 @@ internal static extern unsafe int git_remote_connect( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_create( - out git_remote* remote, - git_repository* repo, + out RemoteHandle remote, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string url); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_create_anonymous( - out git_remote* remote, - git_repository* repo, + out RemoteHandle remote, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string url); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_create_with_fetchspec( - out git_remote* remote, - git_repository* repo, + out RemoteHandle remote, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string url, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string refspec); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_delete( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_fetch( - git_remote* remote, + RemoteHandle remote, ref GitStrArray refspecs, GitFetchOptions fetch_opts, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string log_message); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_remote_free(git_remote* remote); + internal static extern unsafe void git_remote_free(RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_remote_get_fetch_refspecs(out GitStrArray array, git_remote* remote); + internal static extern unsafe int git_remote_get_fetch_refspecs(out GitStrArray array, RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_refspec* git_remote_get_refspec(git_remote* remote, UIntPtr n); + internal static extern unsafe git_refspec* git_remote_get_refspec(RemoteHandle remote, UIntPtr n); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_remote_get_push_refspecs(out GitStrArray array, git_remote* remote); + internal static extern unsafe int git_remote_get_push_refspecs(out GitStrArray array, RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_push( - git_remote* remote, + RemoteHandle remote, ref GitStrArray refSpecs, GitPushOptions opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe UIntPtr git_remote_refspec_count(git_remote* remote); + internal static extern unsafe UIntPtr git_remote_refspec_count(RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_set_url( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string remote, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string url); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_add_fetch( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string remote, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string url); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_set_pushurl( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string remote, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string url); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_add_push( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string remote, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string url); @@ -1465,32 +1465,32 @@ internal static extern int git_remote_is_valid_name( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string remote_name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_remote_list(out GitStrArray array, git_repository* repo); + internal static extern unsafe int git_remote_list(out GitStrArray array, RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_lookup( - out git_remote* remote, - git_repository* repo, + out RemoteHandle remote, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_remote_ls(out git_remote_head** heads, out UIntPtr size, git_remote* remote); + internal static extern unsafe int git_remote_ls(out git_remote_head** heads, out UIntPtr size, RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_remote_name(git_remote* remote); + internal static extern unsafe string git_remote_name(RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_remote_url(git_remote* remote); + internal static extern unsafe string git_remote_url(RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_remote_pushurl(git_remote* remote); + internal static extern unsafe string git_remote_pushurl(RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe void git_remote_set_autotag( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, TagFetchMode option); @@ -1537,12 +1537,12 @@ internal delegate int git_repository_fetchhead_foreach_cb( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_fetchhead_foreach( - git_repository* repo, + RepositoryHandle repo, git_repository_fetchhead_foreach_cb cb, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_repository_free(git_repository* repo); + internal static extern unsafe void git_repository_free(RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_repository_head_detached(RepositoryHandle repo); @@ -1554,14 +1554,14 @@ internal static extern unsafe int git_repository_fetchhead_foreach( internal static extern unsafe int git_repository_ident( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] out string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] out string email, - git_repository* repo); + RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_repository_index(out git_index* index, git_repository* repo); + internal static extern unsafe int git_repository_index(out IndexHandle index, RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_init_ext( - out git_repository* repository, + out RepositoryHandle repository, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath path, GitRepositoryInitOptions options); @@ -1572,7 +1572,7 @@ internal static extern unsafe int git_repository_init_ext( internal static extern int git_repository_is_shallow(RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_repository_state_cleanup(git_repository* repo); + internal static extern unsafe int git_repository_state_cleanup(RepositoryHandle repo); [UnmanagedFunctionPointer(CallingConvention.Cdecl)] internal delegate int git_repository_mergehead_foreach_cb( @@ -1581,83 +1581,83 @@ internal delegate int git_repository_mergehead_foreach_cb( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_mergehead_foreach( - git_repository* repo, + RepositoryHandle repo, git_repository_mergehead_foreach_cb cb, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_message( GitBuf buf, - git_repository* repository); + RepositoryHandle repository); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_new( - out git_repository* repo); + out RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_repository_odb(out git_odb* odb, git_repository* repo); + internal static extern unsafe int git_repository_odb(out ObjectDatabaseHandle odb, RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_open( - out git_repository* repository, + out RepositoryHandle repository, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_open_ext( - out git_repository* repository, + out RepositoryHandle repository, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath path, RepositoryOpenFlags flags, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath ceilingDirs); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxFilePathNoCleanupMarshaler))] - internal static extern unsafe FilePath git_repository_path(git_repository* repository); + internal static extern unsafe FilePath git_repository_path(RepositoryHandle repository); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_set_config( - git_repository* repository, - git_config* config); + RepositoryHandle repository, + ConfigurationHandle config); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_set_ident( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string email); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_set_index( - git_repository* repository, - git_index* index); + RepositoryHandle repository, + IndexHandle index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_set_workdir( - git_repository* repository, + RepositoryHandle repository, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath workdir, [MarshalAs(UnmanagedType.Bool)] bool update_gitlink); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_set_head_detached( - git_repository* repo, + RepositoryHandle repo, ref GitOid commitish); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_set_head_detached_from_annotated( - git_repository* repo, - git_annotated_commit* commit); + RepositoryHandle repo, + AnnotatedCommitHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_set_head( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string refname); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_state( - git_repository* repository); + RepositoryHandle repository); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxFilePathNoCleanupMarshaler))] - internal static extern unsafe FilePath git_repository_workdir(git_repository* repository); + internal static extern unsafe FilePath git_repository_workdir(RepositoryHandle repository); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxFilePathNoCleanupMarshaler))] @@ -1665,56 +1665,56 @@ internal static extern unsafe int git_repository_state( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reset( - git_repository* repo, - git_object* target, + RepositoryHandle repo, + ObjectHandle target, ResetMode reset_type, ref GitCheckoutOpts opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_revert( - git_repository* repo, - git_object* commit, + RepositoryHandle repo, + ObjectHandle commit, GitRevertOpts opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_revert_commit( - out git_index* index, - git_repository* repo, - git_object* revert_commit, - git_object* our_commit, + out IndexHandle index, + RepositoryHandle repo, + ObjectHandle revert_commit, + ObjectHandle our_commit, uint mainline, ref GitMergeOpts opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_revparse_ext( - out git_object* obj, - out git_reference* reference, - git_repository* repo, + out ObjectHandle obj, + out ReferenceHandle reference, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string spec); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_revwalk_free(git_revwalk* walker); + internal static extern unsafe void git_revwalk_free(RevWalkerHandle walker); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_revwalk_hide(git_revwalk* walker, ref GitOid commit_id); + internal static extern unsafe int git_revwalk_hide(RevWalkerHandle walker, ref GitOid commit_id); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_revwalk_new(out git_revwalk* walker, git_repository* repo); + internal static extern unsafe int git_revwalk_new(out RevWalkerHandle walker, RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_revwalk_next(out GitOid id, git_revwalk* walker); + internal static extern unsafe int git_revwalk_next(out GitOid id, RevWalkerHandle walker); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_revwalk_push(git_revwalk* walker, ref GitOid id); + internal static extern unsafe int git_revwalk_push(RevWalkerHandle walker, ref GitOid id); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_revwalk_reset(git_revwalk* walker); + internal static extern unsafe int git_revwalk_reset(RevWalkerHandle walker); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_revwalk_sorting(git_revwalk* walk, CommitSortStrategies sort); + internal static extern unsafe int git_revwalk_sorting(RevWalkerHandle walk, CommitSortStrategies sort); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_revwalk_simplify_first_parent(git_revwalk* walk); + internal static extern unsafe int git_revwalk_simplify_first_parent(RevWalkerHandle walk); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe void git_signature_free(git_signature* signature); @@ -1739,7 +1739,7 @@ internal static extern unsafe int git_signature_now( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_stash_save( out GitOid id, - git_repository* repo, + RepositoryHandle repo, git_signature* stasher, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message, StashModifiers flags); @@ -1753,50 +1753,50 @@ internal delegate int git_stash_cb( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_stash_foreach( - git_repository* repo, + RepositoryHandle repo, git_stash_cb callback, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_stash_drop(git_repository* repo, UIntPtr index); + internal static extern unsafe int git_stash_drop(RepositoryHandle repo, UIntPtr index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_stash_apply( - git_repository* repo, + RepositoryHandle repo, UIntPtr index, GitStashApplyOpts opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_stash_pop( - git_repository* repo, + RepositoryHandle repo, UIntPtr index, GitStashApplyOpts opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_status_file( out FileStatus statusflags, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath filepath); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_status_list_new( - out git_status_list* git_status_list, - git_repository* repo, + out StatusListHandle git_status_list, + RepositoryHandle repo, GitStatusOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_status_list_entrycount( - git_status_list* statusList); + StatusListHandle statusList); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_status_entry* git_status_byindex( - git_status_list* list, + StatusListHandle list, UIntPtr idx); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe void git_status_list_free( - git_status_list* statusList); + StatusListHandle statusList); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern void git_strarray_free( @@ -1804,19 +1804,19 @@ internal static extern void git_strarray_free( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_submodule_lookup( - out git_submodule* reference, - git_repository* repo, + out SubmoduleHandle reference, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_submodule_resolve_url( GitBuf buf, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string url); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_submodule_update( - git_submodule* sm, + SubmoduleHandle sm, [MarshalAs(UnmanagedType.Bool)] bool init, ref GitSubmoduleUpdateOptions submoduleUpdateOptions); @@ -1828,84 +1828,84 @@ internal delegate int submodule_callback( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_submodule_foreach( - git_repository* repo, + RepositoryHandle repo, submodule_callback callback, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_submodule_add_to_index( - git_submodule* submodule, + SubmoduleHandle submodule, [MarshalAs(UnmanagedType.Bool)] bool write_index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_submodule_free(git_submodule* submodule); + internal static extern unsafe void git_submodule_free(SubmoduleHandle submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] internal static extern unsafe string git_submodule_path( - git_submodule* submodule); + SubmoduleHandle submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] internal static extern unsafe string git_submodule_url( - git_submodule* submodule); + SubmoduleHandle submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_oid* git_submodule_index_id( - git_submodule* submodule); + SubmoduleHandle submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_oid* git_submodule_head_id( - git_submodule* submodule); + SubmoduleHandle submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_oid* git_submodule_wd_id( - git_submodule* submodule); + SubmoduleHandle submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe SubmoduleIgnore git_submodule_ignore( - git_submodule* submodule); + SubmoduleHandle submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe SubmoduleUpdate git_submodule_update_strategy( - git_submodule* submodule); + SubmoduleHandle submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe SubmoduleRecurse git_submodule_fetch_recurse_submodules( - git_submodule* submodule); + SubmoduleHandle submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_submodule_reload( - git_submodule* submodule, + SubmoduleHandle submodule, [MarshalAs(UnmanagedType.Bool)] bool force); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_submodule_status( out SubmoduleStatus status, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictFilePathMarshaler))] FilePath name, GitSubmoduleIgnore ignore); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_submodule_init( - git_submodule* submodule, + SubmoduleHandle submodule, [MarshalAs(UnmanagedType.Bool)] bool overwrite); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_tag_annotation_create( out GitOid oid, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, - git_object* target, + ObjectHandle target, git_signature* signature, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_tag_create( out GitOid oid, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, - git_object* target, + ObjectHandle target, git_signature* signature, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message, [MarshalAs(UnmanagedType.Bool)] @@ -1914,36 +1914,36 @@ internal static extern unsafe int git_tag_create( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_tag_create_lightweight( out GitOid oid, - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, - git_object* target, + ObjectHandle target, [MarshalAs(UnmanagedType.Bool)] bool force); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_tag_delete( - git_repository* repo, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string tagName); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_tag_list(out GitStrArray array, git_repository* repo); + internal static extern unsafe int git_tag_list(out GitStrArray array, RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_tag_message(git_object* tag); + internal static extern unsafe string git_tag_message(ObjectHandle tag); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_tag_name(git_object* tag); + internal static extern unsafe string git_tag_name(ObjectHandle tag); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_signature* git_tag_tagger(git_object* tag); + internal static extern unsafe git_signature* git_tag_tagger(ObjectHandle tag); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_oid* git_tag_target_id(git_object* tag); + internal static extern unsafe git_oid* git_tag_target_id(ObjectHandle tag); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe GitObjectType git_tag_target_type(git_object* tag); + internal static extern unsafe GitObjectType git_tag_target_type(ObjectHandle tag); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_libgit2_init(); @@ -2003,16 +2003,16 @@ internal static extern int git_transport_unregister( internal static extern unsafe uint git_tree_entry_filemode(TreeEntryHandle entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_tree_entry* git_tree_entry_byindex(git_object* tree, UIntPtr idx); + internal static extern unsafe TreeEntryHandle git_tree_entry_byindex(ObjectHandle tree, UIntPtr idx); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_tree_entry_bypath( - out git_tree_entry* tree, - git_object* root, + out TreeEntryHandle tree, + ObjectHandle root, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string treeentry_path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_tree_entry_free(git_tree_entry* treeEntry); + internal static extern unsafe void git_tree_entry_free(TreeEntryHandle treeEntry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_oid* git_tree_entry_id(TreeEntryHandle entry); @@ -2028,33 +2028,33 @@ internal static extern unsafe int git_tree_entry_bypath( internal static extern unsafe UIntPtr git_tree_entrycount(ObjectHandle tree); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_treebuilder_new(out git_treebuilder* builder, git_repository* repo, IntPtr src); + internal static extern unsafe int git_treebuilder_new(out TreeBuilderHandle builder, RepositoryHandle repo, IntPtr src); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_treebuilder_insert( IntPtr entry_out, - git_treebuilder* builder, + TreeBuilderHandle builder, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string treeentry_name, ref GitOid id, uint attributes); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_treebuilder_write(out GitOid id, git_treebuilder* bld); + internal static extern unsafe int git_treebuilder_write(out GitOid id, TreeBuilderHandle bld); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_treebuilder_free(git_treebuilder* bld); + internal static extern unsafe void git_treebuilder_free(TreeBuilderHandle bld); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_blob_is_binary(git_object* blob); + internal static extern unsafe int git_blob_is_binary(ObjectHandle blob); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_cherrypick(git_repository* repo, git_object* commit, GitCherryPickOptions options); + internal static extern unsafe int git_cherrypick(RepositoryHandle repo, ObjectHandle commit, GitCherryPickOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_cherrypick_commit(out git_index* index, - git_repository* repo, - git_object* cherrypick_commit, - git_object* our_commit, + internal static extern unsafe int git_cherrypick_commit(out IndexHandle index, + RepositoryHandle repo, + ObjectHandle cherrypick_commit, + ObjectHandle our_commit, uint mainline, ref GitMergeOpts options); @@ -2072,53 +2072,53 @@ internal delegate int url_resolve_callback( IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_worktree_free(git_worktree* worktree); + internal static extern unsafe void git_worktree_free(WorktreeHandle worktree); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_worktree_lookup( - out git_worktree* reference, - git_repository* repo, + out WorktreeHandle reference, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_worktree_list( out GitStrArray array, - git_repository* repo); + RepositoryHandle repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_repository_open_from_worktree( - out git_repository* repository, - git_worktree* worktree); + out RepositoryHandle repository, + WorktreeHandle worktree); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_worktree_is_locked( GitBuf reason, - git_worktree* worktree); + WorktreeHandle worktree); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_worktree_validate( - git_worktree* worktree); + WorktreeHandle worktree); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_worktree_lock( - git_worktree* worktree, + WorktreeHandle worktree, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string reason); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_worktree_unlock( - git_worktree* worktree); + WorktreeHandle worktree); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_worktree_add( - out git_worktree* reference, - git_repository* repo, + out WorktreeHandle reference, + RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string path, git_worktree_add_options options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_worktree_prune( - git_worktree* worktree, + WorktreeHandle worktree, git_worktree_prune_options options); } } diff --git a/LibGit2Sharp/Core/Opaques.cs b/LibGit2Sharp/Core/Opaques.cs deleted file mode 100644 index f83e8be10..000000000 --- a/LibGit2Sharp/Core/Opaques.cs +++ /dev/null @@ -1,32 +0,0 @@ -using System; - -namespace LibGit2Sharp.Core -{ - internal struct git_tree_entry { } - internal struct git_reference { } - internal struct git_refspec { } - internal struct git_repository { } - internal struct git_status_list { } - internal struct git_blame { } - internal struct git_diff { } - internal struct git_patch { } - internal struct git_config { } - internal struct git_index_conflict_iterator { } - internal struct git_index { } - internal struct git_reflog { } - internal struct git_reflog_entry { } - internal struct git_treebuilder { } - internal struct git_packbuilder { } - internal struct git_note { } - internal struct git_describe_result { } - internal struct git_submodule { } - internal struct git_annotated_commit { } - internal struct git_odb { } - internal struct git_revwalk { } - internal struct git_remote { } - internal struct git_object { } - internal struct git_rebase { } - internal struct git_odb_stream { } - internal struct git_worktree { } -} - diff --git a/LibGit2Sharp/Core/Proxy.cs b/LibGit2Sharp/Core/Proxy.cs index 5ff6df3a8..3dc015936 100644 --- a/LibGit2Sharp/Core/Proxy.cs +++ b/LibGit2Sharp/Core/Proxy.cs @@ -24,7 +24,7 @@ public static unsafe BlameHandle git_blame_file( string path, git_blame_options options) { - git_blame* ptr; + BlameHandle ptr; int res = NativeMethods.git_blame_file(out ptr, repo, path, options); Ensure.ZeroResult(res); return new BlameHandle(ptr, true); @@ -111,7 +111,7 @@ public static unsafe bool git_blob_is_binary(ObjectHandle obj) public static unsafe ReferenceHandle git_branch_create_from_annotated(RepositoryHandle repo, string branch_name, string targetIdentifier, bool force) { - git_reference* reference; + ReferenceHandle reference; using (var annotatedCommit = git_annotated_commit_from_revspec(repo, targetIdentifier)) { @@ -168,7 +168,7 @@ public static void git_branch_iterator_free(IntPtr iter) public static unsafe ReferenceHandle git_branch_move(ReferenceHandle reference, string new_branch_name, bool force) { - git_reference* ref_out; + ReferenceHandle ref_out; int res = NativeMethods.git_branch_move(out ref_out, reference, new_branch_name, force); Ensure.ZeroResult(res); return new ReferenceHandle(ref_out, true); @@ -252,7 +252,7 @@ internal static unsafe void git_cherrypick(RepositoryHandle repo, ObjectId commi internal static unsafe IndexHandle git_cherrypick_commit(RepositoryHandle repo, ObjectHandle cherrypickCommit, ObjectHandle ourCommit, uint mainline, GitMergeOpts opts, out bool earlyStop) { - git_index* index; + IndexHandle index; int res = NativeMethods.git_cherrypick_commit(out index, repo, cherrypickCommit, ourCommit, mainline, ref opts); if (res == (int)GitErrorCode.MergeConflict) { @@ -274,7 +274,7 @@ public static unsafe RepositoryHandle git_clone( string workdir, ref GitCloneOptions opts) { - git_repository* repo; + RepositoryHandle repo; int res = NativeMethods.git_clone(out repo, url, workdir, ref opts); Ensure.ZeroResult(res); return new RepositoryHandle(repo, true); @@ -444,7 +444,7 @@ public static unsafe SignatureInfo git_commit_extract_signature(RepositoryHandle public static unsafe void git_config_add_file_ondisk(ConfigurationHandle config, FilePath path, ConfigurationLevel level, RepositoryHandle repo) { // RepositoryHandle does implicit cast voodoo that is not null-safe, thus this explicit check - git_repository* repoHandle = (repo != null) ? (git_repository*)repo : null; + RepositoryHandle repoHandle = (repo != null) ? (RepositoryHandle)repo : null; int res = NativeMethods.git_config_add_file_ondisk(config, path, (uint)level, repoHandle, true); Ensure.ZeroResult(res); } @@ -497,7 +497,7 @@ public static FilePath git_config_find_programdata() return ConvertPath(NativeMethods.git_config_find_programdata); } - public static unsafe void git_config_free(git_config* config) + public static unsafe void git_config_free(ConfigurationHandle config) { NativeMethods.git_config_free(config); } @@ -531,7 +531,7 @@ public static unsafe ConfigurationEntry git_config_get_entry(Configuration public static unsafe ConfigurationHandle git_config_new() { - git_config* handle; + ConfigurationHandle handle; int res = NativeMethods.git_config_new(out handle); Ensure.ZeroResult(res); @@ -540,7 +540,7 @@ public static unsafe ConfigurationHandle git_config_new() public static unsafe ConfigurationHandle git_config_open_level(ConfigurationHandle parent, ConfigurationLevel level) { - git_config* handle; + ConfigurationHandle handle; int res = NativeMethods.git_config_open_level(out handle, parent, (uint)level); if (res == (int)GitErrorCode.NotFound) @@ -649,7 +649,7 @@ public static IEnumerable> git_config_iterator_glob( public static unsafe ConfigurationHandle git_config_snapshot(ConfigurationHandle config) { - git_config* handle; + ConfigurationHandle handle; int res = NativeMethods.git_config_snapshot(out handle, config); Ensure.ZeroResult(res); @@ -700,7 +700,7 @@ public static unsafe string git_describe_commit( try { - git_describe_result* result; + DescribeResultHandle result; int res = NativeMethods.git_describe_commit(out result, osw.ObjectPtr, ref opts); Ensure.ZeroResult(res); describeHandle = new DescribeResultHandle(result, true); @@ -763,7 +763,7 @@ public static unsafe void git_diff_blobs( } public static unsafe void git_diff_foreach( - git_diff* diff, + DiffHandle diff, NativeMethods.git_diff_file_cb fileCallback, NativeMethods.git_diff_hunk_cb hunkCallback, NativeMethods.git_diff_line_cb lineCallback) @@ -780,7 +780,7 @@ public static unsafe DiffHandle git_diff_tree_to_index( { using (var osw = new ObjectSafeWrapper(oldTree, repo, true)) { - git_diff* diff; + DiffHandle diff; int res = NativeMethods.git_diff_tree_to_index(out diff, repo, osw.ObjectPtr, index, options); Ensure.ZeroResult(res); @@ -803,7 +803,7 @@ public static unsafe DiffHandle git_diff_tree_to_tree( using (var osw1 = new ObjectSafeWrapper(oldTree, repo, true, throwIfMissing: true)) using (var osw2 = new ObjectSafeWrapper(newTree, repo, true, throwIfMissing: true)) { - git_diff* diff; + DiffHandle diff; int res = NativeMethods.git_diff_tree_to_tree(out diff, repo, osw1.ObjectPtr, osw2.ObjectPtr, options); Ensure.ZeroResult(res); @@ -816,7 +816,7 @@ public static unsafe DiffHandle git_diff_index_to_workdir( IndexHandle index, GitDiffOptions options) { - git_diff* diff; + DiffHandle diff; int res = NativeMethods.git_diff_index_to_workdir(out diff, repo, index, options); Ensure.ZeroResult(res); @@ -830,7 +830,7 @@ public static unsafe DiffHandle git_diff_tree_to_workdir( { using (var osw = new ObjectSafeWrapper(oldTree, repo, true)) { - git_diff* diff; + DiffHandle diff; int res = NativeMethods.git_diff_tree_to_workdir(out diff, repo, osw.ObjectPtr, options); Ensure.ZeroResult(res); @@ -1062,7 +1062,7 @@ public static unsafe Conflict git_index_conflict_get( public static unsafe ConflictIteratorHandle git_index_conflict_iterator_new(IndexHandle index) { - git_index_conflict_iterator* iter; + ConflictIteratorHandle iter; int res = NativeMethods.git_index_conflict_iterator_new(out iter, index); Ensure.ZeroResult(res); @@ -1129,7 +1129,7 @@ public static unsafe int git_index_name_entrycount(IndexHandle index) public static unsafe IndexHandle git_index_open(FilePath indexpath) { - git_index* handle; + IndexHandle handle; int res = NativeMethods.git_index_open(out handle, indexpath); Ensure.ZeroResult(res); @@ -1206,7 +1206,7 @@ public static unsafe void git_index_clear(Index index) public static unsafe IndexHandle git_merge_commits(RepositoryHandle repo, ObjectHandle ourCommit, ObjectHandle theirCommit, GitMergeOpts opts, out bool earlyStop) { - git_index* index; + IndexHandle index; int res = NativeMethods.git_merge_commits(out index, repo, ourCommit, theirCommit, ref opts); if (res == (int)GitErrorCode.MergeConflict) { @@ -1253,7 +1253,7 @@ public static unsafe ObjectId git_merge_base_octopus(RepositoryHandle repo, GitO public static unsafe AnnotatedCommitHandle git_annotated_commit_from_fetchhead(RepositoryHandle repo, string branchName, string remoteUrl, GitOid oid) { - git_annotated_commit* commit; + AnnotatedCommitHandle commit; int res = NativeMethods.git_annotated_commit_from_fetchhead(out commit, repo, branchName, remoteUrl, ref oid); @@ -1264,7 +1264,7 @@ public static unsafe AnnotatedCommitHandle git_annotated_commit_from_fetchhead(R public static unsafe AnnotatedCommitHandle git_annotated_commit_lookup(RepositoryHandle repo, GitOid oid) { - git_annotated_commit* commit; + AnnotatedCommitHandle commit; int res = NativeMethods.git_annotated_commit_lookup(out commit, repo, ref oid); @@ -1275,7 +1275,7 @@ public static unsafe AnnotatedCommitHandle git_annotated_commit_lookup(Repositor public static unsafe AnnotatedCommitHandle git_annotated_commit_from_ref(RepositoryHandle repo, ReferenceHandle reference) { - git_annotated_commit* commit; + AnnotatedCommitHandle commit; int res = NativeMethods.git_annotated_commit_from_ref(out commit, repo, reference); @@ -1286,7 +1286,7 @@ public static unsafe AnnotatedCommitHandle git_annotated_commit_from_ref(Reposit public static unsafe AnnotatedCommitHandle git_annotated_commit_from_revspec(RepositoryHandle repo, string revspec) { - git_annotated_commit* commit; + AnnotatedCommitHandle commit; int res = NativeMethods.git_annotated_commit_from_revspec(out commit, repo, revspec); @@ -1422,7 +1422,7 @@ public static unsafe ObjectId git_note_id(NoteHandle note) public static unsafe NoteHandle git_note_read(RepositoryHandle repo, string notes_ref, ObjectId id) { GitOid oid = id.Oid; - git_note* note; + NoteHandle note; int res = NativeMethods.git_note_read(out note, repo, notes_ref, ref oid); @@ -1465,7 +1465,7 @@ public static unsafe ObjectId git_object_id(ObjectHandle obj) public static unsafe ObjectHandle git_object_lookup(RepositoryHandle repo, ObjectId id, GitObjectType type) { - git_object* handle; + ObjectHandle handle; GitOid oid = id.Oid; int res = NativeMethods.git_object_lookup(out handle, repo, ref oid, type); @@ -1484,7 +1484,7 @@ public static unsafe ObjectHandle git_object_lookup(RepositoryHandle repo, Objec public static unsafe ObjectHandle git_object_peel(RepositoryHandle repo, ObjectId id, GitObjectType type, bool throwsIfCanNotPeel) { - git_object* peeled; + ObjectHandle peeled; int res; using (var obj = new ObjectSafeWrapper(id, repo)) @@ -1581,7 +1581,7 @@ public static unsafe ICollection git_odb_foreach(ObjectDatabaseHandle public static unsafe OdbStreamHandle git_odb_open_wstream(ObjectDatabaseHandle odb, long size, GitObjectType type) { - git_odb_stream* stream; + OdbStreamHandle stream; int res = NativeMethods.git_odb_open_wstream(out stream, odb, size, type); Ensure.ZeroResult(res); @@ -1630,7 +1630,7 @@ public static unsafe ObjectId git_odb_write(ObjectDatabaseHandle odb, byte[] dat public static unsafe PatchHandle git_patch_from_diff(DiffHandle diff, int idx) { - git_patch* handle; + PatchHandle handle; int res = NativeMethods.git_patch_from_diff(out handle, diff, (UIntPtr)idx); Ensure.ZeroResult(res); return new PatchHandle(handle, true); @@ -1656,7 +1656,7 @@ public static unsafe Tuple git_patch_line_stats(PatchHandle patch) public static unsafe PackBuilderHandle git_packbuilder_new(RepositoryHandle repo) { - git_packbuilder* handle; + PackBuilderHandle handle; int res = NativeMethods.git_packbuilder_new(out handle, repo); Ensure.ZeroResult(res); @@ -1727,7 +1727,7 @@ public static unsafe RebaseHandle git_rebase_init( AnnotatedCommitHandle onto, GitRebaseOptions options) { - git_rebase* rebase = null; + RebaseHandle rebase = null; int result = NativeMethods.git_rebase_init(out rebase, repo, branch, upstream, onto, options); Ensure.ZeroResult(result); @@ -1737,7 +1737,7 @@ public static unsafe RebaseHandle git_rebase_init( public static unsafe RebaseHandle git_rebase_open(RepositoryHandle repo, GitRebaseOptions options) { - git_rebase* rebase = null; + RebaseHandle rebase = null; int result = NativeMethods.git_rebase_open(out rebase, repo, options); Ensure.ZeroResult(result); @@ -1884,7 +1884,7 @@ public static unsafe ReferenceHandle git_reference_create( string logMessage) { GitOid oid = targetId.Oid; - git_reference* handle; + ReferenceHandle handle; int res = NativeMethods.git_reference_create(out handle, repo, name, ref oid, allowOverwrite, logMessage); Ensure.ZeroResult(res); @@ -1899,7 +1899,7 @@ public static unsafe ReferenceHandle git_reference_symbolic_create( bool allowOverwrite, string logMessage) { - git_reference* handle; + ReferenceHandle handle; int res = NativeMethods.git_reference_symbolic_create(out handle, repo, name, target, allowOverwrite, logMessage); Ensure.ZeroResult(res); @@ -1942,7 +1942,7 @@ public static unsafe IList git_reference_list(RepositoryHandle repo) public static unsafe ReferenceHandle git_reference_lookup(RepositoryHandle repo, string name, bool shouldThrowIfNotFound) { - git_reference* handle; + ReferenceHandle handle; int res = NativeMethods.git_reference_lookup(out handle, repo, name); if (!shouldThrowIfNotFound && res == (int)GitErrorCode.NotFound) @@ -1977,7 +1977,7 @@ public static unsafe ReferenceHandle git_reference_rename( bool allowOverwrite, string logMessage) { - git_reference* ref_out; + ReferenceHandle ref_out; int res = NativeMethods.git_reference_rename(out ref_out, reference, newName, allowOverwrite, logMessage); Ensure.ZeroResult(res); @@ -1988,7 +1988,7 @@ public static unsafe ReferenceHandle git_reference_rename( public static unsafe ReferenceHandle git_reference_set_target(ReferenceHandle reference, ObjectId id, string logMessage) { GitOid oid = id.Oid; - git_reference* ref_out; + ReferenceHandle ref_out; int res = NativeMethods.git_reference_set_target(out ref_out, reference, ref oid, logMessage); Ensure.ZeroResult(res); @@ -1998,7 +1998,7 @@ public static unsafe ReferenceHandle git_reference_set_target(ReferenceHandle re public static unsafe ReferenceHandle git_reference_symbolic_set_target(ReferenceHandle reference, string target, string logMessage) { - git_reference* ref_out; + ReferenceHandle ref_out; int res = NativeMethods.git_reference_symbolic_set_target(out ref_out, reference, target, logMessage); Ensure.ZeroResult(res); @@ -2028,7 +2028,7 @@ public static unsafe void git_reference_ensure_log(RepositoryHandle repo, string public static unsafe ReflogHandle git_reflog_read(RepositoryHandle repo, string canonicalName) { - git_reflog* reflog_out; + ReflogHandle reflog_out; int res = NativeMethods.git_reflog_read(out reflog_out, repo, canonicalName); Ensure.ZeroResult(res); @@ -2138,7 +2138,7 @@ public static unsafe TagFetchMode git_remote_autotag(RemoteHandle remote) public static unsafe RemoteHandle git_remote_create(RepositoryHandle repo, string name, string url) { - git_remote* handle; + RemoteHandle handle; int res = NativeMethods.git_remote_create(out handle, repo, name, url); Ensure.ZeroResult(res); @@ -2147,7 +2147,7 @@ public static unsafe RemoteHandle git_remote_create(RepositoryHandle repo, strin public static unsafe RemoteHandle git_remote_create_with_fetchspec(RepositoryHandle repo, string name, string url, string refspec) { - git_remote* handle; + RemoteHandle handle; int res = NativeMethods.git_remote_create_with_fetchspec(out handle, repo, name, url, refspec); Ensure.ZeroResult(res); @@ -2156,7 +2156,7 @@ public static unsafe RemoteHandle git_remote_create_with_fetchspec(RepositoryHan public static unsafe RemoteHandle git_remote_create_anonymous(RepositoryHandle repo, string url) { - git_remote* handle; + RemoteHandle handle; int res = NativeMethods.git_remote_create_anonymous(out handle, repo, url); Ensure.ZeroResult(res); @@ -2375,7 +2375,7 @@ public static unsafe IEnumerable git_remote_ls(Repository repository, public static unsafe RemoteHandle git_remote_lookup(RepositoryHandle repo, string name, bool throwsIfNotFound) { - git_remote* handle; + RemoteHandle handle; int res = NativeMethods.git_remote_lookup(out handle, repo, name); if (res == (int)GitErrorCode.NotFound && !throwsIfNotFound) @@ -2474,7 +2474,7 @@ public static bool git_repository_head_unborn(RepositoryHandle repo) public static unsafe IndexHandle git_repository_index(RepositoryHandle repo) { - git_index* handle; + IndexHandle handle; int res = NativeMethods.git_repository_index(out handle, repo); Ensure.ZeroResult(res); @@ -2488,7 +2488,7 @@ public static unsafe RepositoryHandle git_repository_init_ext( { using (var opts = GitRepositoryInitOptions.BuildFrom(workdirPath, isBare)) { - git_repository* repo; + RepositoryHandle repo; int res = NativeMethods.git_repository_init_ext(out repo, gitdirPath, opts); Ensure.ZeroResult(res); @@ -2539,7 +2539,7 @@ public static unsafe string git_repository_message(RepositoryHandle repo) public static unsafe ObjectDatabaseHandle git_repository_odb(RepositoryHandle repo) { - git_odb* handle; + ObjectDatabaseHandle handle; int res = NativeMethods.git_repository_odb(out handle, repo); Ensure.ZeroResult(res); @@ -2548,7 +2548,7 @@ public static unsafe ObjectDatabaseHandle git_repository_odb(RepositoryHandle re public static unsafe RepositoryHandle git_repository_open(string path) { - git_repository* repo; + RepositoryHandle repo; int res = NativeMethods.git_repository_open(out repo, path); if (res == (int)GitErrorCode.NotFound) @@ -2564,7 +2564,7 @@ public static unsafe RepositoryHandle git_repository_open(string path) public static unsafe RepositoryHandle git_repository_new() { - git_repository* repo; + RepositoryHandle repo; int res = NativeMethods.git_repository_new(out repo); Ensure.ZeroResult(res); @@ -2575,7 +2575,7 @@ public static unsafe RepositoryHandle git_repository_new() public static unsafe void git_repository_open_ext(string path, RepositoryOpenFlags flags, string ceilingDirs) { int res; - git_repository* repo; + RepositoryHandle repo; res = NativeMethods.git_repository_open_ext(out repo, path, flags, ceilingDirs); NativeMethods.git_repository_free(repo); @@ -2687,7 +2687,7 @@ public static unsafe void git_revert( internal static unsafe IndexHandle git_revert_commit(RepositoryHandle repo, ObjectHandle revertCommit, ObjectHandle ourCommit, uint mainline, GitMergeOpts opts, out bool earlyStop) { - git_index* index; + IndexHandle index; int res = NativeMethods.git_revert_commit(out index, repo, revertCommit, ourCommit, mainline, ref opts); if (res == (int)GitErrorCode.MergeConflict) { @@ -2706,8 +2706,8 @@ internal static unsafe IndexHandle git_revert_commit(RepositoryHandle repo, Obje public static unsafe Tuple git_revparse_ext(RepositoryHandle repo, string objectish) { - git_object* obj; - git_reference* reference; + ObjectHandle obj; + ReferenceHandle reference; int res = NativeMethods.git_revparse_ext(out obj, out reference, repo, objectish); switch (res) @@ -2754,7 +2754,7 @@ public static unsafe void git_revwalk_hide(RevWalkerHandle walker, ObjectId comm public static unsafe RevWalkerHandle git_revwalk_new(RepositoryHandle repo) { - git_revwalk* handle; + RevWalkerHandle handle; int res = NativeMethods.git_revwalk_new(out handle, repo); Ensure.ZeroResult(res); @@ -2942,7 +2942,7 @@ public static unsafe FileStatus git_status_file(RepositoryHandle repo, FilePath public static unsafe StatusListHandle git_status_list_new(RepositoryHandle repo, GitStatusOptions options) { - git_status_list* ptr; + StatusListHandle ptr; int res = NativeMethods.git_status_list_new(out ptr, repo, options); Ensure.ZeroResult(res); return new StatusListHandle(ptr, true); @@ -2970,7 +2970,7 @@ public static unsafe int git_status_list_entrycount(StatusListHandle list) /// public static unsafe SubmoduleHandle git_submodule_lookup(RepositoryHandle repo, string name) { - git_submodule* submodule; + SubmoduleHandle submodule; var res = NativeMethods.git_submodule_lookup(out submodule, repo, name); switch (res) @@ -3269,7 +3269,7 @@ public static unsafe TreeEntryHandle git_tree_entry_bypath(RepositoryHandle repo { using (var obj = new ObjectSafeWrapper(id, repo, throwIfMissing: true)) { - git_tree_entry* treeEntryPtr; + TreeEntryHandle treeEntryPtr; int res = NativeMethods.git_tree_entry_bypath(out treeEntryPtr, obj.ObjectPtr, treeentry_path); if (res == (int)GitErrorCode.NotFound) @@ -3309,7 +3309,7 @@ public static unsafe int git_tree_entrycount(ObjectHandle tree) public static unsafe TreeBuilderHandle git_treebuilder_new(RepositoryHandle repo) { - git_treebuilder* builder; + TreeBuilderHandle builder; int res = NativeMethods.git_treebuilder_new(out builder, repo, IntPtr.Zero); Ensure.ZeroResult(res); @@ -3623,7 +3623,7 @@ public static void git_libgit2_opts_set_owner_validation(bool enabled) /// public static unsafe WorktreeHandle git_worktree_lookup(RepositoryHandle repo, string name) { - git_worktree* worktree; + WorktreeHandle worktree; var res = NativeMethods.git_worktree_lookup(out worktree, repo, name); switch (res) @@ -3659,7 +3659,7 @@ public static unsafe IList git_worktree_list(RepositoryHandle repo) public static unsafe RepositoryHandle git_repository_open_from_worktree(WorktreeHandle handle) { - git_repository* repo; + RepositoryHandle repo; int res = NativeMethods.git_repository_open_from_worktree(out repo, handle); if (res == (int)GitErrorCode.NotFound) @@ -3720,7 +3720,7 @@ public static unsafe WorktreeHandle git_worktree_add( string path, git_worktree_add_options options) { - git_worktree* worktree; + WorktreeHandle worktree; int res = NativeMethods.git_worktree_add(out worktree, repo, name, path, options); Ensure.ZeroResult(res); return new WorktreeHandle(worktree, true); From 11aae8b65509449b6328b2027971a71bda7c8ddd Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Sat, 23 Nov 2024 00:53:00 -0500 Subject: [PATCH 06/11] WIP --- LibGit2Sharp/Core/GitFilter.cs | 3 +- LibGit2Sharp/Core/Handles/Libgit2Object.cs | 4 +- LibGit2Sharp/Core/Handles/Objects.cs | 125 +++++++++ LibGit2Sharp/Core/Handles/Objects.tt | 5 + LibGit2Sharp/Core/Proxy.cs | 303 ++++++++------------- LibGit2Sharp/Repository.cs | 9 +- 6 files changed, 255 insertions(+), 194 deletions(-) diff --git a/LibGit2Sharp/Core/GitFilter.cs b/LibGit2Sharp/Core/GitFilter.cs index 0b393b0ab..0f10c3465 100644 --- a/LibGit2Sharp/Core/GitFilter.cs +++ b/LibGit2Sharp/Core/GitFilter.cs @@ -1,6 +1,5 @@ using System; using System.Runtime.InteropServices; -using LibGit2Sharp.Core.Handles; namespace LibGit2Sharp.Core { @@ -119,7 +118,7 @@ public delegate int git_filter_stream_fn( [StructLayout(LayoutKind.Sequential)] internal unsafe struct git_filter_source { - public RepositoryHandle repository; + public IntPtr repository; public char* path; diff --git a/LibGit2Sharp/Core/Handles/Libgit2Object.cs b/LibGit2Sharp/Core/Handles/Libgit2Object.cs index e912d2137..9c3bd79db 100644 --- a/LibGit2Sharp/Core/Handles/Libgit2Object.cs +++ b/LibGit2Sharp/Core/Handles/Libgit2Object.cs @@ -90,8 +90,8 @@ internal unsafe abstract class Libgit2Object : SafeHandle private readonly Guid id; #endif - internal unsafe Libgit2Object(void* ptr, bool owned) - : this(new IntPtr(ptr), owned) + internal unsafe Libgit2Object() + : base(IntPtr.Zero, true) { } diff --git a/LibGit2Sharp/Core/Handles/Objects.cs b/LibGit2Sharp/Core/Handles/Objects.cs index 5537bbd2d..2445c7eb5 100644 --- a/LibGit2Sharp/Core/Handles/Objects.cs +++ b/LibGit2Sharp/Core/Handles/Objects.cs @@ -6,6 +6,11 @@ namespace LibGit2Sharp.Core.Handles internal unsafe class TreeEntryHandle : Libgit2Object { + internal TreeEntryHandle() + : base() + { + } + internal TreeEntryHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -21,6 +26,11 @@ protected override bool ReleaseHandle() internal unsafe class ReferenceHandle : Libgit2Object { + internal ReferenceHandle() + : base() + { + } + internal ReferenceHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -36,6 +46,11 @@ protected override bool ReleaseHandle() internal unsafe class RepositoryHandle : Libgit2Object { + internal RepositoryHandle() + : base() + { + } + internal RepositoryHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -51,6 +66,11 @@ protected override bool ReleaseHandle() internal unsafe class SignatureHandle : Libgit2Object { + internal SignatureHandle() + : base() + { + } + internal SignatureHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -66,6 +86,11 @@ protected override bool ReleaseHandle() internal unsafe class StatusListHandle : Libgit2Object { + internal StatusListHandle() + : base() + { + } + internal StatusListHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -81,6 +106,11 @@ protected override bool ReleaseHandle() internal unsafe class BlameHandle : Libgit2Object { + internal BlameHandle() + : base() + { + } + internal BlameHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -96,6 +126,11 @@ protected override bool ReleaseHandle() internal unsafe class DiffHandle : Libgit2Object { + internal DiffHandle() + : base() + { + } + internal DiffHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -111,6 +146,11 @@ protected override bool ReleaseHandle() internal unsafe class PatchHandle : Libgit2Object { + internal PatchHandle() + : base() + { + } + internal PatchHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -126,6 +166,11 @@ protected override bool ReleaseHandle() internal unsafe class ConfigurationHandle : Libgit2Object { + internal ConfigurationHandle() + : base() + { + } + internal ConfigurationHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -141,6 +186,11 @@ protected override bool ReleaseHandle() internal unsafe class ConflictIteratorHandle : Libgit2Object { + internal ConflictIteratorHandle() + : base() + { + } + internal ConflictIteratorHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -156,6 +206,11 @@ protected override bool ReleaseHandle() internal unsafe class IndexHandle : Libgit2Object { + internal IndexHandle() + : base() + { + } + internal IndexHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -171,6 +226,11 @@ protected override bool ReleaseHandle() internal unsafe class ReflogHandle : Libgit2Object { + internal ReflogHandle() + : base() + { + } + internal ReflogHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -186,6 +246,11 @@ protected override bool ReleaseHandle() internal unsafe class TreeBuilderHandle : Libgit2Object { + internal TreeBuilderHandle() + : base() + { + } + internal TreeBuilderHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -201,6 +266,11 @@ protected override bool ReleaseHandle() internal unsafe class PackBuilderHandle : Libgit2Object { + internal PackBuilderHandle() + : base() + { + } + internal PackBuilderHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -216,6 +286,11 @@ protected override bool ReleaseHandle() internal unsafe class NoteHandle : Libgit2Object { + internal NoteHandle() + : base() + { + } + internal NoteHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -231,6 +306,11 @@ protected override bool ReleaseHandle() internal unsafe class DescribeResultHandle : Libgit2Object { + internal DescribeResultHandle() + : base() + { + } + internal DescribeResultHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -246,6 +326,11 @@ protected override bool ReleaseHandle() internal unsafe class SubmoduleHandle : Libgit2Object { + internal SubmoduleHandle() + : base() + { + } + internal SubmoduleHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -261,6 +346,11 @@ protected override bool ReleaseHandle() internal unsafe class AnnotatedCommitHandle : Libgit2Object { + internal AnnotatedCommitHandle() + : base() + { + } + internal AnnotatedCommitHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -276,6 +366,11 @@ protected override bool ReleaseHandle() internal unsafe class ObjectDatabaseHandle : Libgit2Object { + internal ObjectDatabaseHandle() + : base() + { + } + internal ObjectDatabaseHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -291,6 +386,11 @@ protected override bool ReleaseHandle() internal unsafe class RevWalkerHandle : Libgit2Object { + internal RevWalkerHandle() + : base() + { + } + internal RevWalkerHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -306,6 +406,11 @@ protected override bool ReleaseHandle() internal unsafe class RemoteHandle : Libgit2Object { + internal RemoteHandle() + : base() + { + } + internal RemoteHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -321,6 +426,11 @@ protected override bool ReleaseHandle() internal unsafe class ObjectHandle : Libgit2Object { + internal ObjectHandle() + : base() + { + } + internal ObjectHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -336,6 +446,11 @@ protected override bool ReleaseHandle() internal unsafe class RebaseHandle : Libgit2Object { + internal RebaseHandle() + : base() + { + } + internal RebaseHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -351,6 +466,11 @@ protected override bool ReleaseHandle() internal unsafe class OdbStreamHandle : Libgit2Object { + internal OdbStreamHandle() + : base() + { + } + internal OdbStreamHandle(IntPtr ptr, bool owned) : base(ptr, owned) { @@ -366,6 +486,11 @@ protected override bool ReleaseHandle() internal unsafe class WorktreeHandle : Libgit2Object { + internal WorktreeHandle() + : base() + { + } + internal WorktreeHandle(IntPtr ptr, bool owned) : base(ptr, owned) { diff --git a/LibGit2Sharp/Core/Handles/Objects.tt b/LibGit2Sharp/Core/Handles/Objects.tt index 2f53872de..374d3803c 100644 --- a/LibGit2Sharp/Core/Handles/Objects.tt +++ b/LibGit2Sharp/Core/Handles/Objects.tt @@ -72,6 +72,11 @@ for (var i = 0; i < cNames.Length; i++) #> internal unsafe class <#= csNames[i] #> : Libgit2Object { + internal <#= csNames[i] #>() + : base() + { + } + internal <#= csNames[i] #>(IntPtr ptr, bool owned) : base(ptr, owned) { diff --git a/LibGit2Sharp/Core/Proxy.cs b/LibGit2Sharp/Core/Proxy.cs index 3dc015936..01ea688f2 100644 --- a/LibGit2Sharp/Core/Proxy.cs +++ b/LibGit2Sharp/Core/Proxy.cs @@ -24,10 +24,9 @@ public static unsafe BlameHandle git_blame_file( string path, git_blame_options options) { - BlameHandle ptr; - int res = NativeMethods.git_blame_file(out ptr, repo, path, options); + int res = NativeMethods.git_blame_file(out var blame, repo, path, options); Ensure.ZeroResult(res); - return new BlameHandle(ptr, true); + return blame; } public static unsafe git_blame_hunk* git_blame_get_hunk_byindex(BlameHandle blame, uint idx) @@ -111,15 +110,12 @@ public static unsafe bool git_blob_is_binary(ObjectHandle obj) public static unsafe ReferenceHandle git_branch_create_from_annotated(RepositoryHandle repo, string branch_name, string targetIdentifier, bool force) { - ReferenceHandle reference; + using var annotatedCommit = git_annotated_commit_from_revspec(repo, targetIdentifier); - using (var annotatedCommit = git_annotated_commit_from_revspec(repo, targetIdentifier)) - { - int res = NativeMethods.git_branch_create_from_annotated(out reference, repo, branch_name, annotatedCommit, force); - Ensure.ZeroResult(res); - } + int res = NativeMethods.git_branch_create_from_annotated(out var reference, repo, branch_name, annotatedCommit, force); + Ensure.ZeroResult(res); - return new ReferenceHandle(reference, true); + return reference; } public static unsafe void git_branch_delete(ReferenceHandle reference) @@ -168,10 +164,10 @@ public static void git_branch_iterator_free(IntPtr iter) public static unsafe ReferenceHandle git_branch_move(ReferenceHandle reference, string new_branch_name, bool force) { - ReferenceHandle ref_out; - int res = NativeMethods.git_branch_move(out ref_out, reference, new_branch_name, force); + int res = NativeMethods.git_branch_move(out var ref_out, reference, new_branch_name, force); Ensure.ZeroResult(res); - return new ReferenceHandle(ref_out, true); + + return ref_out; } public static unsafe string git_branch_remote_name(RepositoryHandle repo, string canonical_branch_name, bool shouldThrowIfNotFound) @@ -252,8 +248,7 @@ internal static unsafe void git_cherrypick(RepositoryHandle repo, ObjectId commi internal static unsafe IndexHandle git_cherrypick_commit(RepositoryHandle repo, ObjectHandle cherrypickCommit, ObjectHandle ourCommit, uint mainline, GitMergeOpts opts, out bool earlyStop) { - IndexHandle index; - int res = NativeMethods.git_cherrypick_commit(out index, repo, cherrypickCommit, ourCommit, mainline, ref opts); + int res = NativeMethods.git_cherrypick_commit(out var index, repo, cherrypickCommit, ourCommit, mainline, ref opts); if (res == (int)GitErrorCode.MergeConflict) { earlyStop = true; @@ -263,7 +258,8 @@ internal static unsafe IndexHandle git_cherrypick_commit(RepositoryHandle repo, earlyStop = false; Ensure.ZeroResult(res); } - return new IndexHandle(index, true); + + return index; } #endregion @@ -274,10 +270,9 @@ public static unsafe RepositoryHandle git_clone( string workdir, ref GitCloneOptions opts) { - RepositoryHandle repo; - int res = NativeMethods.git_clone(out repo, url, workdir, ref opts); + int res = NativeMethods.git_clone(out var repo, url, workdir, ref opts); Ensure.ZeroResult(res); - return new RepositoryHandle(repo, true); + return repo; } #endregion @@ -531,17 +526,15 @@ public static unsafe ConfigurationEntry git_config_get_entry(Configuration public static unsafe ConfigurationHandle git_config_new() { - ConfigurationHandle handle; - int res = NativeMethods.git_config_new(out handle); + int res = NativeMethods.git_config_new(out var handle); Ensure.ZeroResult(res); - return new ConfigurationHandle(handle, true); + return handle; } public static unsafe ConfigurationHandle git_config_open_level(ConfigurationHandle parent, ConfigurationLevel level) { - ConfigurationHandle handle; - int res = NativeMethods.git_config_open_level(out handle, parent, (uint)level); + int res = NativeMethods.git_config_open_level(out var handle, parent, (uint)level); if (res == (int)GitErrorCode.NotFound) { @@ -550,7 +543,7 @@ public static unsafe ConfigurationHandle git_config_open_level(ConfigurationHand Ensure.ZeroResult(res); - return new ConfigurationHandle(handle, true); + return handle; } public static bool git_config_parse_bool(string value) @@ -649,11 +642,10 @@ public static IEnumerable> git_config_iterator_glob( public static unsafe ConfigurationHandle git_config_snapshot(ConfigurationHandle config) { - ConfigurationHandle handle; - int res = NativeMethods.git_config_snapshot(out handle, config); + int res = NativeMethods.git_config_snapshot(out var handle, config); Ensure.ZeroResult(res); - return new ConfigurationHandle(handle, true); + return handle; } public static unsafe IntPtr git_config_lock(ConfigurationHandle config) @@ -700,10 +692,8 @@ public static unsafe string git_describe_commit( try { - DescribeResultHandle result; - int res = NativeMethods.git_describe_commit(out result, osw.ObjectPtr, ref opts); + int res = NativeMethods.git_describe_commit(out describeHandle, osw.ObjectPtr, ref opts); Ensure.ZeroResult(res); - describeHandle = new DescribeResultHandle(result, true); using (var buf = new GitBuf()) { @@ -780,11 +770,10 @@ public static unsafe DiffHandle git_diff_tree_to_index( { using (var osw = new ObjectSafeWrapper(oldTree, repo, true)) { - DiffHandle diff; - int res = NativeMethods.git_diff_tree_to_index(out diff, repo, osw.ObjectPtr, index, options); + int res = NativeMethods.git_diff_tree_to_index(out var diff, repo, osw.ObjectPtr, index, options); Ensure.ZeroResult(res); - return new DiffHandle(diff, true); + return diff; } } @@ -803,11 +792,10 @@ public static unsafe DiffHandle git_diff_tree_to_tree( using (var osw1 = new ObjectSafeWrapper(oldTree, repo, true, throwIfMissing: true)) using (var osw2 = new ObjectSafeWrapper(newTree, repo, true, throwIfMissing: true)) { - DiffHandle diff; - int res = NativeMethods.git_diff_tree_to_tree(out diff, repo, osw1.ObjectPtr, osw2.ObjectPtr, options); + int res = NativeMethods.git_diff_tree_to_tree(out var diff, repo, osw1.ObjectPtr, osw2.ObjectPtr, options); Ensure.ZeroResult(res); - return new DiffHandle(diff, true); + return diff; } } @@ -816,11 +804,10 @@ public static unsafe DiffHandle git_diff_index_to_workdir( IndexHandle index, GitDiffOptions options) { - DiffHandle diff; - int res = NativeMethods.git_diff_index_to_workdir(out diff, repo, index, options); + int res = NativeMethods.git_diff_index_to_workdir(out var diff, repo, index, options); Ensure.ZeroResult(res); - return new DiffHandle(diff, true); + return diff; } public static unsafe DiffHandle git_diff_tree_to_workdir( @@ -830,11 +817,10 @@ public static unsafe DiffHandle git_diff_tree_to_workdir( { using (var osw = new ObjectSafeWrapper(oldTree, repo, true)) { - DiffHandle diff; - int res = NativeMethods.git_diff_tree_to_workdir(out diff, repo, osw.ObjectPtr, options); + int res = NativeMethods.git_diff_tree_to_workdir(out var diff, repo, osw.ObjectPtr, options); Ensure.ZeroResult(res); - return new DiffHandle(diff, true); + return diff; } } @@ -1062,11 +1048,10 @@ public static unsafe Conflict git_index_conflict_get( public static unsafe ConflictIteratorHandle git_index_conflict_iterator_new(IndexHandle index) { - ConflictIteratorHandle iter; - int res = NativeMethods.git_index_conflict_iterator_new(out iter, index); + int res = NativeMethods.git_index_conflict_iterator_new(out var iter, index); Ensure.ZeroResult(res); - return new ConflictIteratorHandle(iter, true); + return iter; } public static unsafe Conflict git_index_conflict_next(ConflictIteratorHandle iterator) @@ -1129,11 +1114,10 @@ public static unsafe int git_index_name_entrycount(IndexHandle index) public static unsafe IndexHandle git_index_open(FilePath indexpath) { - IndexHandle handle; - int res = NativeMethods.git_index_open(out handle, indexpath); + int res = NativeMethods.git_index_open(out var handle, indexpath); Ensure.ZeroResult(res); - return new IndexHandle(handle, true); + return handle; } public static unsafe void git_index_read(IndexHandle index) @@ -1206,8 +1190,7 @@ public static unsafe void git_index_clear(Index index) public static unsafe IndexHandle git_merge_commits(RepositoryHandle repo, ObjectHandle ourCommit, ObjectHandle theirCommit, GitMergeOpts opts, out bool earlyStop) { - IndexHandle index; - int res = NativeMethods.git_merge_commits(out index, repo, ourCommit, theirCommit, ref opts); + int res = NativeMethods.git_merge_commits(out var index, repo, ourCommit, theirCommit, ref opts); if (res == (int)GitErrorCode.MergeConflict) { earlyStop = true; @@ -1218,7 +1201,7 @@ public static unsafe IndexHandle git_merge_commits(RepositoryHandle repo, Object Ensure.ZeroResult(res); } - return new IndexHandle(index, true); + return index; } public static unsafe ObjectId git_merge_base_many(RepositoryHandle repo, GitOid[] commitIds) @@ -1253,46 +1236,38 @@ public static unsafe ObjectId git_merge_base_octopus(RepositoryHandle repo, GitO public static unsafe AnnotatedCommitHandle git_annotated_commit_from_fetchhead(RepositoryHandle repo, string branchName, string remoteUrl, GitOid oid) { - AnnotatedCommitHandle commit; - - int res = NativeMethods.git_annotated_commit_from_fetchhead(out commit, repo, branchName, remoteUrl, ref oid); + int res = NativeMethods.git_annotated_commit_from_fetchhead(out var commit, repo, branchName, remoteUrl, ref oid); Ensure.ZeroResult(res); - return new AnnotatedCommitHandle(commit, true); + return commit; } public static unsafe AnnotatedCommitHandle git_annotated_commit_lookup(RepositoryHandle repo, GitOid oid) { - AnnotatedCommitHandle commit; - - int res = NativeMethods.git_annotated_commit_lookup(out commit, repo, ref oid); + int res = NativeMethods.git_annotated_commit_lookup(out var commit, repo, ref oid); Ensure.ZeroResult(res); - return new AnnotatedCommitHandle(commit, true); + return commit; } public static unsafe AnnotatedCommitHandle git_annotated_commit_from_ref(RepositoryHandle repo, ReferenceHandle reference) { - AnnotatedCommitHandle commit; - - int res = NativeMethods.git_annotated_commit_from_ref(out commit, repo, reference); + int res = NativeMethods.git_annotated_commit_from_ref(out var commit, repo, reference); Ensure.ZeroResult(res); - return new AnnotatedCommitHandle(commit, true); + return commit; } public static unsafe AnnotatedCommitHandle git_annotated_commit_from_revspec(RepositoryHandle repo, string revspec) { - AnnotatedCommitHandle commit; - - int res = NativeMethods.git_annotated_commit_from_revspec(out commit, repo, revspec); + int res = NativeMethods.git_annotated_commit_from_revspec(out var commit, repo, revspec); Ensure.ZeroResult(res); - return new AnnotatedCommitHandle(commit, true); + return commit; } public static unsafe ObjectId git_annotated_commit_id(AnnotatedCommitHandle mergeHead) @@ -1422,9 +1397,8 @@ public static unsafe ObjectId git_note_id(NoteHandle note) public static unsafe NoteHandle git_note_read(RepositoryHandle repo, string notes_ref, ObjectId id) { GitOid oid = id.Oid; - NoteHandle note; - int res = NativeMethods.git_note_read(out note, repo, notes_ref, ref oid); + int res = NativeMethods.git_note_read(out var note, repo, notes_ref, ref oid); if (res == (int)GitErrorCode.NotFound) { @@ -1433,7 +1407,7 @@ public static unsafe NoteHandle git_note_read(RepositoryHandle repo, string note Ensure.ZeroResult(res); - return new NoteHandle(note, true); + return note; } public static unsafe void git_note_remove(RepositoryHandle repo, string notes_ref, Signature author, Signature committer, ObjectId targetId) @@ -1465,10 +1439,9 @@ public static unsafe ObjectId git_object_id(ObjectHandle obj) public static unsafe ObjectHandle git_object_lookup(RepositoryHandle repo, ObjectId id, GitObjectType type) { - ObjectHandle handle; GitOid oid = id.Oid; - int res = NativeMethods.git_object_lookup(out handle, repo, ref oid, type); + int res = NativeMethods.git_object_lookup(out var handle, repo, ref oid, type); switch (res) { case (int)GitErrorCode.NotFound: @@ -1479,7 +1452,7 @@ public static unsafe ObjectHandle git_object_lookup(RepositoryHandle repo, Objec break; } - return new ObjectHandle(handle, true); + return handle; } public static unsafe ObjectHandle git_object_peel(RepositoryHandle repo, ObjectId id, GitObjectType type, bool throwsIfCanNotPeel) @@ -1500,7 +1473,7 @@ public static unsafe ObjectHandle git_object_peel(RepositoryHandle repo, ObjectI } Ensure.ZeroResult(res); - return new ObjectHandle(peeled, true); + return peeled; } public static unsafe string git_object_short_id(RepositoryHandle repo, ObjectId id) @@ -1581,11 +1554,10 @@ public static unsafe ICollection git_odb_foreach(ObjectDatabaseHandle public static unsafe OdbStreamHandle git_odb_open_wstream(ObjectDatabaseHandle odb, long size, GitObjectType type) { - OdbStreamHandle stream; - int res = NativeMethods.git_odb_open_wstream(out stream, odb, size, type); + int res = NativeMethods.git_odb_open_wstream(out var stream, odb, size, type); Ensure.ZeroResult(res); - return new OdbStreamHandle(stream, true); + return stream; } public static void git_odb_stream_write(OdbStreamHandle stream, byte[] data, int len) @@ -1630,10 +1602,9 @@ public static unsafe ObjectId git_odb_write(ObjectDatabaseHandle odb, byte[] dat public static unsafe PatchHandle git_patch_from_diff(DiffHandle diff, int idx) { - PatchHandle handle; - int res = NativeMethods.git_patch_from_diff(out handle, diff, (UIntPtr)idx); + int res = NativeMethods.git_patch_from_diff(out var handle, diff, (UIntPtr)idx); Ensure.ZeroResult(res); - return new PatchHandle(handle, true); + return handle; } public static unsafe void git_patch_print(PatchHandle patch, NativeMethods.git_diff_line_cb printCallback) @@ -1656,12 +1627,10 @@ public static unsafe Tuple git_patch_line_stats(PatchHandle patch) public static unsafe PackBuilderHandle git_packbuilder_new(RepositoryHandle repo) { - PackBuilderHandle handle; - - int res = NativeMethods.git_packbuilder_new(out handle, repo); + int res = NativeMethods.git_packbuilder_new(out var handle, repo); Ensure.ZeroResult(res); - return new PackBuilderHandle(handle, true); + return handle; } public static unsafe void git_packbuilder_insert(PackBuilderHandle packbuilder, ObjectId targetId, string name) @@ -1727,22 +1696,18 @@ public static unsafe RebaseHandle git_rebase_init( AnnotatedCommitHandle onto, GitRebaseOptions options) { - RebaseHandle rebase = null; - - int result = NativeMethods.git_rebase_init(out rebase, repo, branch, upstream, onto, options); + int result = NativeMethods.git_rebase_init(out var rebase, repo, branch, upstream, onto, options); Ensure.ZeroResult(result); - return new RebaseHandle(rebase, true); + return rebase; } public static unsafe RebaseHandle git_rebase_open(RepositoryHandle repo, GitRebaseOptions options) { - RebaseHandle rebase = null; - - int result = NativeMethods.git_rebase_open(out rebase, repo, options); + int result = NativeMethods.git_rebase_open(out var rebase, repo, options); Ensure.ZeroResult(result); - return new RebaseHandle(rebase, true); + return rebase; } public static unsafe long git_rebase_operation_entrycount(RebaseHandle rebase) @@ -1884,12 +1849,11 @@ public static unsafe ReferenceHandle git_reference_create( string logMessage) { GitOid oid = targetId.Oid; - ReferenceHandle handle; - int res = NativeMethods.git_reference_create(out handle, repo, name, ref oid, allowOverwrite, logMessage); + int res = NativeMethods.git_reference_create(out var handle, repo, name, ref oid, allowOverwrite, logMessage); Ensure.ZeroResult(res); - return new ReferenceHandle(handle, true); + return handle; } public static unsafe ReferenceHandle git_reference_symbolic_create( @@ -1899,12 +1863,10 @@ public static unsafe ReferenceHandle git_reference_symbolic_create( bool allowOverwrite, string logMessage) { - ReferenceHandle handle; - int res = NativeMethods.git_reference_symbolic_create(out handle, repo, name, target, allowOverwrite, - logMessage); + int res = NativeMethods.git_reference_symbolic_create(out var handle, repo, name, target, allowOverwrite, logMessage); Ensure.ZeroResult(res); - return new ReferenceHandle(handle, true); + return handle; } public static unsafe ICollection git_reference_foreach_glob( @@ -1942,8 +1904,7 @@ public static unsafe IList git_reference_list(RepositoryHandle repo) public static unsafe ReferenceHandle git_reference_lookup(RepositoryHandle repo, string name, bool shouldThrowIfNotFound) { - ReferenceHandle handle; - int res = NativeMethods.git_reference_lookup(out handle, repo, name); + int res = NativeMethods.git_reference_lookup(out var handle, repo, name); if (!shouldThrowIfNotFound && res == (int)GitErrorCode.NotFound) { @@ -1952,7 +1913,7 @@ public static unsafe ReferenceHandle git_reference_lookup(RepositoryHandle repo, Ensure.ZeroResult(res); - return new ReferenceHandle(handle, true); + return handle; } public static unsafe string git_reference_name(ReferenceHandle reference) @@ -1977,33 +1938,28 @@ public static unsafe ReferenceHandle git_reference_rename( bool allowOverwrite, string logMessage) { - ReferenceHandle ref_out; - - int res = NativeMethods.git_reference_rename(out ref_out, reference, newName, allowOverwrite, logMessage); + int res = NativeMethods.git_reference_rename(out var ref_out, reference, newName, allowOverwrite, logMessage); Ensure.ZeroResult(res); - return new ReferenceHandle(ref_out, true); + return ref_out; } public static unsafe ReferenceHandle git_reference_set_target(ReferenceHandle reference, ObjectId id, string logMessage) { GitOid oid = id.Oid; - ReferenceHandle ref_out; - int res = NativeMethods.git_reference_set_target(out ref_out, reference, ref oid, logMessage); + int res = NativeMethods.git_reference_set_target(out var ref_out, reference, ref oid, logMessage); Ensure.ZeroResult(res); - return new ReferenceHandle(ref_out, true); + return ref_out; } public static unsafe ReferenceHandle git_reference_symbolic_set_target(ReferenceHandle reference, string target, string logMessage) { - ReferenceHandle ref_out; - - int res = NativeMethods.git_reference_symbolic_set_target(out ref_out, reference, target, logMessage); + int res = NativeMethods.git_reference_symbolic_set_target(out var ref_out, reference, target, logMessage); Ensure.ZeroResult(res); - return new ReferenceHandle(ref_out, true); + return ref_out; } public static unsafe string git_reference_symbolic_target(ReferenceHandle reference) @@ -2028,12 +1984,10 @@ public static unsafe void git_reference_ensure_log(RepositoryHandle repo, string public static unsafe ReflogHandle git_reflog_read(RepositoryHandle repo, string canonicalName) { - ReflogHandle reflog_out; - - int res = NativeMethods.git_reflog_read(out reflog_out, repo, canonicalName); + int res = NativeMethods.git_reflog_read(out var reflog_out, repo, canonicalName); Ensure.ZeroResult(res); - return new ReflogHandle(reflog_out, true); + return reflog_out; } public static unsafe int git_reflog_entrycount(ReflogHandle reflog) @@ -2138,29 +2092,26 @@ public static unsafe TagFetchMode git_remote_autotag(RemoteHandle remote) public static unsafe RemoteHandle git_remote_create(RepositoryHandle repo, string name, string url) { - RemoteHandle handle; - int res = NativeMethods.git_remote_create(out handle, repo, name, url); + int res = NativeMethods.git_remote_create(out var handle, repo, name, url); Ensure.ZeroResult(res); - return new RemoteHandle(handle, true); + return handle; } public static unsafe RemoteHandle git_remote_create_with_fetchspec(RepositoryHandle repo, string name, string url, string refspec) { - RemoteHandle handle; - int res = NativeMethods.git_remote_create_with_fetchspec(out handle, repo, name, url, refspec); + int res = NativeMethods.git_remote_create_with_fetchspec(out var handle, repo, name, url, refspec); Ensure.ZeroResult(res); - return new RemoteHandle(handle, true); + return handle; } public static unsafe RemoteHandle git_remote_create_anonymous(RepositoryHandle repo, string url) { - RemoteHandle handle; - int res = NativeMethods.git_remote_create_anonymous(out handle, repo, url); + int res = NativeMethods.git_remote_create_anonymous(out var handle, repo, url); Ensure.ZeroResult(res); - return new RemoteHandle(handle, true); + return handle; } public static unsafe void git_remote_connect(RemoteHandle remote, GitDirection direction, ref GitRemoteCallbacks remoteCallbacks, ref GitProxyOptions proxyOptions) @@ -2375,8 +2326,7 @@ public static unsafe IEnumerable git_remote_ls(Repository repository, public static unsafe RemoteHandle git_remote_lookup(RepositoryHandle repo, string name, bool throwsIfNotFound) { - RemoteHandle handle; - int res = NativeMethods.git_remote_lookup(out handle, repo, name); + int res = NativeMethods.git_remote_lookup(out var handle, repo, name); if (res == (int)GitErrorCode.NotFound && !throwsIfNotFound) { @@ -2384,7 +2334,7 @@ public static unsafe RemoteHandle git_remote_lookup(RepositoryHandle repo, strin } Ensure.ZeroResult(res); - return new RemoteHandle(handle, true); + return handle; } public static unsafe string git_remote_name(RemoteHandle remote) @@ -2474,11 +2424,10 @@ public static bool git_repository_head_unborn(RepositoryHandle repo) public static unsafe IndexHandle git_repository_index(RepositoryHandle repo) { - IndexHandle handle; - int res = NativeMethods.git_repository_index(out handle, repo); + int res = NativeMethods.git_repository_index(out var handle, repo); Ensure.ZeroResult(res); - return new IndexHandle(handle, true); + return handle; } public static unsafe RepositoryHandle git_repository_init_ext( @@ -2488,11 +2437,10 @@ public static unsafe RepositoryHandle git_repository_init_ext( { using (var opts = GitRepositoryInitOptions.BuildFrom(workdirPath, isBare)) { - RepositoryHandle repo; - int res = NativeMethods.git_repository_init_ext(out repo, gitdirPath, opts); + int res = NativeMethods.git_repository_init_ext(out var repo, gitdirPath, opts); Ensure.ZeroResult(res); - return new RepositoryHandle(repo, true); + return repo; } } @@ -2539,37 +2487,33 @@ public static unsafe string git_repository_message(RepositoryHandle repo) public static unsafe ObjectDatabaseHandle git_repository_odb(RepositoryHandle repo) { - ObjectDatabaseHandle handle; - int res = NativeMethods.git_repository_odb(out handle, repo); + int res = NativeMethods.git_repository_odb(out var handle, repo); Ensure.ZeroResult(res); - return new ObjectDatabaseHandle(handle, true); + return handle; } public static unsafe RepositoryHandle git_repository_open(string path) { - RepositoryHandle repo; - int res = NativeMethods.git_repository_open(out repo, path); + int res = NativeMethods.git_repository_open(out var repo, path); if (res == (int)GitErrorCode.NotFound) { - throw new RepositoryNotFoundException("Path '{0}' doesn't point at a valid Git repository or workdir.", - path); + throw new RepositoryNotFoundException("Path '{0}' doesn't point at a valid Git repository or workdir.", path); } Ensure.ZeroResult(res); - return new RepositoryHandle(repo, true); + return repo; } public static unsafe RepositoryHandle git_repository_new() { - RepositoryHandle repo; - int res = NativeMethods.git_repository_new(out repo); + int res = NativeMethods.git_repository_new(out var repo); Ensure.ZeroResult(res); - return new RepositoryHandle(repo, true); + return repo; } public static unsafe void git_repository_open_ext(string path, RepositoryOpenFlags flags, string ceilingDirs) @@ -2582,8 +2526,7 @@ public static unsafe void git_repository_open_ext(string path, RepositoryOpenFla if (res == (int)GitErrorCode.NotFound) { - throw new RepositoryNotFoundException("Path '{0}' doesn't point at a valid Git repository or workdir.", - path); + throw new RepositoryNotFoundException("Path '{0}' doesn't point at a valid Git repository or workdir.", path); } Ensure.ZeroResult(res); @@ -2687,8 +2630,7 @@ public static unsafe void git_revert( internal static unsafe IndexHandle git_revert_commit(RepositoryHandle repo, ObjectHandle revertCommit, ObjectHandle ourCommit, uint mainline, GitMergeOpts opts, out bool earlyStop) { - IndexHandle index; - int res = NativeMethods.git_revert_commit(out index, repo, revertCommit, ourCommit, mainline, ref opts); + int res = NativeMethods.git_revert_commit(out var index, repo, revertCommit, ourCommit, mainline, ref opts); if (res == (int)GitErrorCode.MergeConflict) { earlyStop = true; @@ -2698,45 +2640,42 @@ internal static unsafe IndexHandle git_revert_commit(RepositoryHandle repo, Obje earlyStop = false; Ensure.ZeroResult(res); } - return new IndexHandle(index, true); + return index; } #endregion #region git_revparse_ - public static unsafe Tuple git_revparse_ext(RepositoryHandle repo, string objectish) + public static unsafe (ObjectHandle obj, ReferenceHandle reference) git_revparse_ext(RepositoryHandle repo, string objectish) { - ObjectHandle obj; - ReferenceHandle reference; - int res = NativeMethods.git_revparse_ext(out obj, out reference, repo, objectish); + int res = NativeMethods.git_revparse_ext(out var obj, out var reference, repo, objectish); switch (res) { case (int)GitErrorCode.NotFound: - return null; + return (null, null); case (int)GitErrorCode.Ambiguous: - throw new AmbiguousSpecificationException("Provided abbreviated ObjectId '{0}' is too short.", - objectish); + throw new AmbiguousSpecificationException("Provided abbreviated ObjectId '{0}' is too short.", objectish); default: Ensure.ZeroResult(res); break; } - return new Tuple(new ObjectHandle(obj, true), new ReferenceHandle(reference, true)); + return (obj, reference); } public static ObjectHandle git_revparse_single(RepositoryHandle repo, string objectish) { var handles = git_revparse_ext(repo, objectish); - if (handles == null) + if (handles == (null, null)) { return null; } - handles.Item2.Dispose(); + handles.reference.Dispose(); return handles.Item1; } @@ -2754,11 +2693,10 @@ public static unsafe void git_revwalk_hide(RevWalkerHandle walker, ObjectId comm public static unsafe RevWalkerHandle git_revwalk_new(RepositoryHandle repo) { - RevWalkerHandle handle; - int res = NativeMethods.git_revwalk_new(out handle, repo); + int res = NativeMethods.git_revwalk_new(out var handle, repo); Ensure.ZeroResult(res); - return new RevWalkerHandle(handle, true); + return handle; } public static unsafe ObjectId git_revwalk_next(RevWalkerHandle walker) @@ -2942,10 +2880,9 @@ public static unsafe FileStatus git_status_file(RepositoryHandle repo, FilePath public static unsafe StatusListHandle git_status_list_new(RepositoryHandle repo, GitStatusOptions options) { - StatusListHandle ptr; - int res = NativeMethods.git_status_list_new(out ptr, repo, options); + int res = NativeMethods.git_status_list_new(out var ptr, repo, options); Ensure.ZeroResult(res); - return new StatusListHandle(ptr, true); + return ptr; } public static unsafe int git_status_list_entrycount(StatusListHandle list) @@ -2970,8 +2907,7 @@ public static unsafe int git_status_list_entrycount(StatusListHandle list) /// public static unsafe SubmoduleHandle git_submodule_lookup(RepositoryHandle repo, string name) { - SubmoduleHandle submodule; - var res = NativeMethods.git_submodule_lookup(out submodule, repo, name); + var res = NativeMethods.git_submodule_lookup(out var submodule, repo, name); switch (res) { @@ -2982,7 +2918,7 @@ public static unsafe SubmoduleHandle git_submodule_lookup(RepositoryHandle repo, default: Ensure.ZeroResult(res); - return new SubmoduleHandle(submodule, true); + return submodule; } } @@ -3269,8 +3205,7 @@ public static unsafe TreeEntryHandle git_tree_entry_bypath(RepositoryHandle repo { using (var obj = new ObjectSafeWrapper(id, repo, throwIfMissing: true)) { - TreeEntryHandle treeEntryPtr; - int res = NativeMethods.git_tree_entry_bypath(out treeEntryPtr, obj.ObjectPtr, treeentry_path); + int res = NativeMethods.git_tree_entry_bypath(out var treeEntryPtr, obj.ObjectPtr, treeentry_path); if (res == (int)GitErrorCode.NotFound) { @@ -3279,7 +3214,7 @@ public static unsafe TreeEntryHandle git_tree_entry_bypath(RepositoryHandle repo Ensure.ZeroResult(res); - return new TreeEntryHandle(treeEntryPtr, true); + return treeEntryPtr; } } @@ -3309,11 +3244,10 @@ public static unsafe int git_tree_entrycount(ObjectHandle tree) public static unsafe TreeBuilderHandle git_treebuilder_new(RepositoryHandle repo) { - TreeBuilderHandle builder; - int res = NativeMethods.git_treebuilder_new(out builder, repo, IntPtr.Zero); + int res = NativeMethods.git_treebuilder_new(out var builder, repo, IntPtr.Zero); Ensure.ZeroResult(res); - return new TreeBuilderHandle(builder, true); + return builder; } public static unsafe void git_treebuilder_insert(TreeBuilderHandle builder, string treeentry_name, TreeEntryDefinition treeEntryDefinition) @@ -3623,8 +3557,7 @@ public static void git_libgit2_opts_set_owner_validation(bool enabled) /// public static unsafe WorktreeHandle git_worktree_lookup(RepositoryHandle repo, string name) { - WorktreeHandle worktree; - var res = NativeMethods.git_worktree_lookup(out worktree, repo, name); + var res = NativeMethods.git_worktree_lookup(out var worktree, repo, name); switch (res) { @@ -3636,7 +3569,7 @@ public static unsafe WorktreeHandle git_worktree_lookup(RepositoryHandle repo, s default: Ensure.ZeroResult(res); - return new WorktreeHandle(worktree, true); + return worktree; } } @@ -3659,8 +3592,7 @@ public static unsafe IList git_worktree_list(RepositoryHandle repo) public static unsafe RepositoryHandle git_repository_open_from_worktree(WorktreeHandle handle) { - RepositoryHandle repo; - int res = NativeMethods.git_repository_open_from_worktree(out repo, handle); + int res = NativeMethods.git_repository_open_from_worktree(out var repo, handle); if (res == (int)GitErrorCode.NotFound) { @@ -3669,7 +3601,7 @@ public static unsafe RepositoryHandle git_repository_open_from_worktree(Worktree Ensure.ZeroResult(res); - return new RepositoryHandle(repo, true); + return repo; } public static unsafe WorktreeLock git_worktree_is_locked(WorktreeHandle worktree) @@ -3720,10 +3652,9 @@ public static unsafe WorktreeHandle git_worktree_add( string path, git_worktree_add_options options) { - WorktreeHandle worktree; - int res = NativeMethods.git_worktree_add(out worktree, repo, name, path, options); + int res = NativeMethods.git_worktree_add(out var worktree, repo, name, path, options); Ensure.ZeroResult(res); - return new WorktreeHandle(worktree, true); + return worktree; } public static unsafe bool git_worktree_prune(WorktreeHandle worktree, diff --git a/LibGit2Sharp/Repository.cs b/LibGit2Sharp/Repository.cs index 9ac5e2424..2a44abab7 100644 --- a/LibGit2Sharp/Repository.cs +++ b/LibGit2Sharp/Repository.cs @@ -1167,7 +1167,7 @@ public unsafe void RemoveUntrackedFiles() | CheckoutStrategy.GIT_CHECKOUT_ALLOW_CONFLICTS, }; - Proxy.git_checkout_index(Handle, new ObjectHandle(null, false), ref options); + Proxy.git_checkout_index(Handle, new ObjectHandle(IntPtr.Zero, false), ref options); } private void CleanupDisposableDependencies() @@ -1769,13 +1769,14 @@ public string Describe(Commit commit, DescribeOptions options) public void RevParse(string revision, out Reference reference, out GitObject obj) { var handles = Proxy.git_revparse_ext(Handle, revision); - if (handles == null) + + if (handles == (null, null)) { Ensure.GitObjectIsNotNull(null, revision); } - using (var objH = handles.Item1) - using (var refH = handles.Item2) + using (var objH = handles.obj) + using (var refH = handles.reference) { reference = refH.IsInvalid ? null : Reference.BuildFromPtr(refH, this); obj = GitObject.BuildFrom(this, Proxy.git_object_id(objH), Proxy.git_object_type(objH), PathFromRevparseSpec(revision)); From 42ac5d29944f3e32f007fa3358c794c7171f8683 Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Wed, 27 Nov 2024 22:19:42 -0500 Subject: [PATCH 07/11] WIP --- LibGit2Sharp/Core/NativeMethods.cs | 59 +++++++++++------------- LibGit2Sharp/Core/ObjectSafeWrapper.cs | 2 +- LibGit2Sharp/Core/Proxy.cs | 36 +++++++-------- LibGit2Sharp/Identity.cs | 7 +-- LibGit2Sharp/Rebase.cs | 3 +- LibGit2Sharp/RefSpec.cs | 15 +++--- LibGit2Sharp/ReflogCollection.cs | 2 +- LibGit2Sharp/ReflogEntry.cs | 7 ++- LibGit2Sharp/Remote.cs | 4 +- LibGit2Sharp/Signature.cs | 63 ++++++++++++++++---------- 10 files changed, 102 insertions(+), 96 deletions(-) diff --git a/LibGit2Sharp/Core/NativeMethods.cs b/LibGit2Sharp/Core/NativeMethods.cs index 102799ddd..0991fbf53 100644 --- a/LibGit2Sharp/Core/NativeMethods.cs +++ b/LibGit2Sharp/Core/NativeMethods.cs @@ -322,8 +322,8 @@ internal static extern unsafe int git_rebase_next( internal static extern unsafe int git_rebase_commit( ref GitOid id, RebaseHandle rebase, - git_signature* author, - git_signature* committer, + SignatureHandle author, + SignatureHandle committer, IntPtr message_encoding, IntPtr message); @@ -334,7 +334,7 @@ internal static extern unsafe int git_rebase_abort( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_rebase_finish( RebaseHandle repo, - git_signature* signature); + SignatureHandle signature); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe void git_rebase_free(RebaseHandle rebase); @@ -380,18 +380,18 @@ internal static extern unsafe int git_clone( ref GitCloneOptions opts); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_signature* git_commit_author(ObjectHandle commit); + internal static extern unsafe SignatureHandle git_commit_author(ObjectHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_signature* git_commit_committer(ObjectHandle commit); + internal static extern unsafe SignatureHandle git_commit_committer(ObjectHandle commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_commit_create_from_ids( out GitOid id, RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string updateRef, - git_signature* author, - git_signature* committer, + SignatureHandle author, + SignatureHandle committer, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string encoding, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message, ref GitOid tree, @@ -402,8 +402,8 @@ internal static extern unsafe int git_commit_create_from_ids( internal static extern unsafe int git_commit_create_buffer( GitBuf res, RepositoryHandle repo, - git_signature* author, - git_signature* committer, + SignatureHandle author, + SignatureHandle committer, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string encoding, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message, ObjectHandle tree, @@ -1020,8 +1020,8 @@ internal static extern unsafe int git_note_create( out GitOid noteOid, RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string notes_ref, - git_signature* author, - git_signature* committer, + SignatureHandle author, + SignatureHandle committer, ref GitOid oid, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string note, int force); @@ -1047,8 +1047,8 @@ internal static extern unsafe int git_note_read( internal static extern unsafe int git_note_remove( RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string notes_ref, - git_signature* author, - git_signature* committer, + SignatureHandle author, + SignatureHandle committer, ref GitOid oid); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -1306,25 +1306,20 @@ internal static extern unsafe UIntPtr git_reflog_entrycount (ReflogHandle reflog); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_reflog_entry* git_reflog_entry_byindex( - ReflogHandle reflog, - UIntPtr idx); + internal static extern unsafe nint git_reflog_entry_byindex(ReflogHandle reflog, UIntPtr idx); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_oid* git_reflog_entry_id_old( - git_reflog_entry* entry); + internal static extern unsafe git_oid* git_reflog_entry_id_old(nint entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_oid* git_reflog_entry_id_new( - git_reflog_entry* entry); + internal static extern unsafe git_oid* git_reflog_entry_id_new(nint entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_signature* git_reflog_entry_committer( - git_reflog_entry* entry); + internal static extern unsafe SignatureHandle git_reflog_entry_committer(nint entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] - internal static extern unsafe string git_reflog_entry_message(git_reflog_entry* entry); + internal static extern unsafe string git_reflog_entry_message(nint entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_refspec_transform( @@ -1422,7 +1417,7 @@ internal static extern unsafe int git_remote_fetch( internal static extern unsafe int git_remote_get_fetch_refspecs(out GitStrArray array, RemoteHandle remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_refspec* git_remote_get_refspec(RemoteHandle remote, UIntPtr n); + internal static extern unsafe nint git_remote_get_refspec(RemoteHandle remote, UIntPtr n); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_get_push_refspecs(out GitStrArray array, RemoteHandle remote); @@ -1717,11 +1712,11 @@ internal static extern unsafe int git_revparse_ext( internal static extern unsafe int git_revwalk_simplify_first_parent(RevWalkerHandle walk); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_signature_free(git_signature* signature); + internal static extern unsafe void git_signature_free(SignatureHandle signature); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_signature_new( - out git_signature* signature, + out SignatureHandle signature, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string email, long time, @@ -1729,18 +1724,18 @@ internal static extern unsafe int git_signature_new( [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_signature_now( - out git_signature* signature, + out SignatureHandle signature, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string email); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe int git_signature_dup(out git_signature* dest, git_signature* sig); + internal static extern unsafe int git_signature_dup(out SignatureHandle dest, SignatureHandle sig); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_stash_save( out GitOid id, RepositoryHandle repo, - git_signature* stasher, + SignatureHandle stasher, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message, StashModifiers flags); @@ -1897,7 +1892,7 @@ internal static extern unsafe int git_tag_annotation_create( RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, ObjectHandle target, - git_signature* signature, + SignatureHandle signature, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] @@ -1906,7 +1901,7 @@ internal static extern unsafe int git_tag_create( RepositoryHandle repo, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string name, ObjectHandle target, - git_signature* signature, + SignatureHandle signature, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message, [MarshalAs(UnmanagedType.Bool)] bool force); @@ -1937,7 +1932,7 @@ internal static extern unsafe int git_tag_delete( internal static extern unsafe string git_tag_name(ObjectHandle tag); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_signature* git_tag_tagger(ObjectHandle tag); + internal static extern unsafe SignatureHandle git_tag_tagger(ObjectHandle tag); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_oid* git_tag_target_id(ObjectHandle tag); diff --git a/LibGit2Sharp/Core/ObjectSafeWrapper.cs b/LibGit2Sharp/Core/ObjectSafeWrapper.cs index f2ab4a9e1..de02028e4 100644 --- a/LibGit2Sharp/Core/ObjectSafeWrapper.cs +++ b/LibGit2Sharp/Core/ObjectSafeWrapper.cs @@ -13,7 +13,7 @@ public unsafe ObjectSafeWrapper(ObjectId id, RepositoryHandle handle, bool allow if (allowNullObjectId && id == null) { - objectPtr = new ObjectHandle(null, false); + objectPtr = new ObjectHandle(IntPtr.Zero, false); } else { diff --git a/LibGit2Sharp/Core/Proxy.cs b/LibGit2Sharp/Core/Proxy.cs index 01ea688f2..a910e5f85 100644 --- a/LibGit2Sharp/Core/Proxy.cs +++ b/LibGit2Sharp/Core/Proxy.cs @@ -1995,27 +1995,27 @@ public static unsafe int git_reflog_entrycount(ReflogHandle reflog) return (int)NativeMethods.git_reflog_entrycount(reflog); } - public static unsafe git_reflog_entry* git_reflog_entry_byindex(ReflogHandle reflog, int idx) + public static unsafe nint git_reflog_entry_byindex(ReflogHandle reflog, int idx) { return NativeMethods.git_reflog_entry_byindex(reflog, (UIntPtr)idx); } - public static unsafe ObjectId git_reflog_entry_id_old(git_reflog_entry* entry) + public static unsafe ObjectId git_reflog_entry_id_old(nint entry) { return ObjectId.BuildFromPtr(NativeMethods.git_reflog_entry_id_old(entry)); } - public static unsafe ObjectId git_reflog_entry_id_new(git_reflog_entry* entry) + public static unsafe ObjectId git_reflog_entry_id_new(nint entry) { return ObjectId.BuildFromPtr(NativeMethods.git_reflog_entry_id_new(entry)); } - public static unsafe Signature git_reflog_entry_committer(git_reflog_entry* entry) + public static unsafe Signature git_reflog_entry_committer(nint entry) { return new Signature(NativeMethods.git_reflog_entry_committer(entry)); } - public static unsafe string git_reflog_entry_message(git_reflog_entry* entry) + public static unsafe string git_reflog_entry_message(nint entry) { return NativeMethods.git_reflog_entry_message(entry); } @@ -2142,7 +2142,7 @@ public static unsafe void git_remote_delete(RepositoryHandle repo, string name) Ensure.ZeroResult(res); } - public static unsafe git_refspec* git_remote_get_refspec(RemoteHandle remote, int n) + public static unsafe nint git_remote_get_refspec(RemoteHandle remote, int n) { return NativeMethods.git_remote_get_refspec(remote, (UIntPtr)n); } @@ -2742,28 +2742,23 @@ public static unsafe int git_revwalk_simplify_first_parent(RevWalkerHandle walke public static unsafe SignatureHandle git_signature_new(string name, string email, DateTimeOffset when) { - git_signature* ptr; - - int res = NativeMethods.git_signature_new(out ptr, name, email, when.ToUnixTimeSeconds(), - (int)when.Offset.TotalMinutes); + int res = NativeMethods.git_signature_new(out var signature, name, email, when.ToUnixTimeSeconds(), (int)when.Offset.TotalMinutes); Ensure.ZeroResult(res); - return new SignatureHandle(ptr, true); + return signature; } public static unsafe SignatureHandle git_signature_now(string name, string email) { - git_signature* ptr; - int res = NativeMethods.git_signature_now(out ptr, name, email); + int res = NativeMethods.git_signature_now(out var signature, name, email); Ensure.ZeroResult(res); - return new SignatureHandle(ptr, true); + return signature; } - public static unsafe git_signature* git_signature_dup(git_signature* sig) + public static unsafe SignatureHandle git_signature_dup(SignatureHandle sig) { - git_signature* handle; - int res = NativeMethods.git_signature_dup(out handle, sig); + int res = NativeMethods.git_signature_dup(out var handle, sig); Ensure.ZeroResult(res); return handle; } @@ -3098,14 +3093,15 @@ public static unsafe string git_tag_name(ObjectHandle tag) public static unsafe Signature git_tag_tagger(ObjectHandle tag) { - git_signature* taggerHandle = NativeMethods.git_tag_tagger(tag); + var taggerSignatureHandle = NativeMethods.git_tag_tagger(tag); // Not all tags have a tagger signature - we need to handle // this case. Signature tagger = null; - if (taggerHandle != null) + + if (!taggerSignatureHandle.IsInvalid) { - tagger = new Signature(taggerHandle); + tagger = new Signature(taggerSignatureHandle); } return tagger; diff --git a/LibGit2Sharp/Identity.cs b/LibGit2Sharp/Identity.cs index faa4ec884..08fbf2aad 100644 --- a/LibGit2Sharp/Identity.cs +++ b/LibGit2Sharp/Identity.cs @@ -1,4 +1,5 @@ -using LibGit2Sharp.Core; +using System; +using LibGit2Sharp.Core; using LibGit2Sharp.Core.Handles; namespace LibGit2Sharp @@ -52,7 +53,7 @@ internal SignatureHandle BuildNowSignatureHandle() internal static class IdentityHelpers { /// - /// Build the handle for the Indentity with the current time, or return a handle + /// Build the handle for the Identity with the current time, or return a handle /// to an empty signature. /// /// @@ -61,7 +62,7 @@ public static unsafe SignatureHandle SafeBuildNowSignatureHandle(this Identity i { if (identity == null) { - return new SignatureHandle(null, false); + return new SignatureHandle(IntPtr.Zero, false); } return identity.BuildNowSignatureHandle(); diff --git a/LibGit2Sharp/Rebase.cs b/LibGit2Sharp/Rebase.cs index c573ffa65..9cd75e21e 100644 --- a/LibGit2Sharp/Rebase.cs +++ b/LibGit2Sharp/Rebase.cs @@ -1,7 +1,6 @@ using System; using LibGit2Sharp.Core; using LibGit2Sharp.Core.Handles; -using System.Globalization; namespace LibGit2Sharp { @@ -65,7 +64,7 @@ internal Rebase(Repository repo) unsafe AnnotatedCommitHandle AnnotatedCommitHandleFromRefHandle(ReferenceHandle refHandle) { return (refHandle == null) ? - new AnnotatedCommitHandle(null, false) : + new AnnotatedCommitHandle(IntPtr.Zero, false) : Proxy.git_annotated_commit_from_ref(this.repository.Handle, refHandle); } diff --git a/LibGit2Sharp/RefSpec.cs b/LibGit2Sharp/RefSpec.cs index 4d9e28fbe..bcf2b8c9b 100644 --- a/LibGit2Sharp/RefSpec.cs +++ b/LibGit2Sharp/RefSpec.cs @@ -2,7 +2,6 @@ using System.Diagnostics; using System.Globalization; using LibGit2Sharp.Core; -using LibGit2Sharp.Core.Handles; namespace LibGit2Sharp { @@ -18,10 +17,10 @@ public class RefSpec #pragma warning restore 0414 readonly IntPtr handle; - internal unsafe RefSpec(Remote remote, git_refspec* handle) + internal unsafe RefSpec(Remote remote, nint handle) { this.remote = remote; - this.handle = new IntPtr(handle); + this.handle = handle; } /// @@ -37,7 +36,7 @@ public virtual string Specification { get { - return Proxy.git_refspec_string(this.handle); + return Proxy.git_refspec_string(handle); } } @@ -48,7 +47,7 @@ public virtual RefSpecDirection Direction { get { - return Proxy.git_refspec_direction(this.handle); + return Proxy.git_refspec_direction(handle); } } @@ -59,7 +58,7 @@ public virtual string Source { get { - return Proxy.git_refspec_src(this.handle); + return Proxy.git_refspec_src(handle); } } @@ -70,7 +69,7 @@ public virtual string Destination { get { - return Proxy.git_refspec_dst(this.handle); + return Proxy.git_refspec_dst(handle); } } @@ -81,7 +80,7 @@ public virtual bool ForceUpdate { get { - return Proxy.git_refspec_force(this.handle); + return Proxy.git_refspec_force(handle); } } diff --git a/LibGit2Sharp/ReflogCollection.cs b/LibGit2Sharp/ReflogCollection.cs index 20b1a8b73..af453376c 100644 --- a/LibGit2Sharp/ReflogCollection.cs +++ b/LibGit2Sharp/ReflogCollection.cs @@ -63,7 +63,7 @@ public virtual unsafe IEnumerator GetEnumerator() for (int i = 0; i < entriesCount; i++) { - git_reflog_entry* handle = Proxy.git_reflog_entry_byindex(reflog, i); + var handle = Proxy.git_reflog_entry_byindex(reflog, i); entries.Add(new ReflogEntry(handle)); } } diff --git a/LibGit2Sharp/ReflogEntry.cs b/LibGit2Sharp/ReflogEntry.cs index d5f064c5a..154c298e0 100644 --- a/LibGit2Sharp/ReflogEntry.cs +++ b/LibGit2Sharp/ReflogEntry.cs @@ -1,5 +1,4 @@ -using System; -using System.Runtime.InteropServices; +using System.Runtime.InteropServices; using LibGit2Sharp.Core; namespace LibGit2Sharp @@ -25,7 +24,7 @@ protected ReflogEntry() /// Initializes a new instance of the class. /// /// a to the reflog entry - internal unsafe ReflogEntry(git_reflog_entry* entryHandle) + internal unsafe ReflogEntry(nint entryHandle) { _from = Proxy.git_reflog_entry_id_old(entryHandle); _to = Proxy.git_reflog_entry_id_new(entryHandle); @@ -58,7 +57,7 @@ public virtual Signature Committer } /// - /// the message assiocated to this reference update + /// the message associated to this reference update /// public virtual string Message { diff --git a/LibGit2Sharp/Remote.cs b/LibGit2Sharp/Remote.cs index 401a7ddd0..85f9b0f14 100644 --- a/LibGit2Sharp/Remote.cs +++ b/LibGit2Sharp/Remote.cs @@ -135,8 +135,8 @@ internal unsafe string FetchSpecTransformToSource(string reference) { using (RemoteHandle remoteHandle = Proxy.git_remote_lookup(repository.Handle, Name, true)) { - git_refspec* fetchSpecPtr = Proxy.git_remote_get_refspec(remoteHandle, 0); - return Proxy.git_refspec_rtransform(new IntPtr(fetchSpecPtr), reference); + var fetchSpecPtr = Proxy.git_remote_get_refspec(remoteHandle, 0); + return Proxy.git_refspec_rtransform(fetchSpecPtr, reference); } } diff --git a/LibGit2Sharp/Signature.cs b/LibGit2Sharp/Signature.cs index 7ed7a4916..6afe3e498 100644 --- a/LibGit2Sharp/Signature.cs +++ b/LibGit2Sharp/Signature.cs @@ -15,13 +15,30 @@ public sealed class Signature : IEquatable private readonly string email; private static readonly LambdaEqualityHelper equalityHelper = - new LambdaEqualityHelper(x => x.Name, x => x.Email, x => x.When); + new(x => x.Name, x => x.Email, x => x.When); - internal unsafe Signature(git_signature* sig) + internal unsafe Signature(SignatureHandle signatureHandle) { - name = LaxUtf8Marshaler.FromNative(sig->name); - email = LaxUtf8Marshaler.FromNative(sig->email); - when = DateTimeOffset.FromUnixTimeSeconds(sig->when.time).ToOffset(TimeSpan.FromMinutes(sig->when.offset)); + var success = false; + + try + { + signatureHandle.DangerousAddRef(ref success); + + var handle = signatureHandle.DangerousGetHandle(); + var sig = (git_signature*)handle; + + name = LaxUtf8Marshaler.FromNative(sig->name); + email = LaxUtf8Marshaler.FromNative(sig->email); + when = DateTimeOffset.FromUnixTimeSeconds(sig->when.time).ToOffset(TimeSpan.FromMinutes(sig->when.offset)); + } + finally + { + if (success) + { + signatureHandle.DangerousRelease(); + } + } } /// @@ -146,22 +163,22 @@ public override string ToString() } } - internal static class SignatureHelpers - { - /// - /// Build the handle for the Signature, or return a handle - /// to an empty signature. - /// - /// - /// - public static unsafe SignatureHandle SafeBuildHandle(this Signature signature) - { - if (signature == null) - { - return new SignatureHandle(null, false); - } - - return signature.BuildHandle(); - } - } + //internal static class SignatureHelpers + //{ + // /// + // /// Build the handle for the Signature, or return a handle + // /// to an empty signature. + // /// + // /// + // /// + // public static unsafe SignatureHandle SafeBuildHandle(this Signature signature) + // { + // if (signature == null) + // { + // return new SignatureHandle(null, false); + // } + + // return signature.BuildHandle(); + // } + //} } From 04cdfe6300d3b8d07783278c9a56121dd33dacec Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Wed, 27 Nov 2024 22:26:48 -0500 Subject: [PATCH 08/11] WIP --- .../Core/Handles/UnownedTreeEntryHandle.cs | 16 ++++++++++++++++ LibGit2Sharp/Core/NativeMethods.cs | 2 +- LibGit2Sharp/Core/Proxy.cs | 8 +------- 3 files changed, 18 insertions(+), 8 deletions(-) create mode 100644 LibGit2Sharp/Core/Handles/UnownedTreeEntryHandle.cs diff --git a/LibGit2Sharp/Core/Handles/UnownedTreeEntryHandle.cs b/LibGit2Sharp/Core/Handles/UnownedTreeEntryHandle.cs new file mode 100644 index 000000000..f2d422d58 --- /dev/null +++ b/LibGit2Sharp/Core/Handles/UnownedTreeEntryHandle.cs @@ -0,0 +1,16 @@ +using System; + +namespace LibGit2Sharp.Core.Handles; + +internal unsafe class UnownedTreeEntryHandle : TreeEntryHandle +{ + internal UnownedTreeEntryHandle() + : base(IntPtr.Zero, false) + { + } + + internal UnownedTreeEntryHandle(IntPtr ptr) + : base(ptr, false) + { + } +} diff --git a/LibGit2Sharp/Core/NativeMethods.cs b/LibGit2Sharp/Core/NativeMethods.cs index 0991fbf53..61128f1f4 100644 --- a/LibGit2Sharp/Core/NativeMethods.cs +++ b/LibGit2Sharp/Core/NativeMethods.cs @@ -1998,7 +1998,7 @@ internal static extern int git_transport_unregister( internal static extern unsafe uint git_tree_entry_filemode(TreeEntryHandle entry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe TreeEntryHandle git_tree_entry_byindex(ObjectHandle tree, UIntPtr idx); + internal static extern unsafe UnownedTreeEntryHandle git_tree_entry_byindex(ObjectHandle tree, UIntPtr idx); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_tree_entry_bypath( diff --git a/LibGit2Sharp/Core/Proxy.cs b/LibGit2Sharp/Core/Proxy.cs index a910e5f85..da76b0609 100644 --- a/LibGit2Sharp/Core/Proxy.cs +++ b/LibGit2Sharp/Core/Proxy.cs @@ -3188,13 +3188,7 @@ public static unsafe Mode git_tree_entry_attributes(TreeEntryHandle entry) public static unsafe TreeEntryHandle git_tree_entry_byindex(ObjectHandle tree, long idx) { - var handle = NativeMethods.git_tree_entry_byindex(tree, (UIntPtr)idx); - if (handle == null) - { - return null; - } - - return new TreeEntryHandle(handle, false); + return NativeMethods.git_tree_entry_byindex(tree, (UIntPtr)idx); } public static unsafe TreeEntryHandle git_tree_entry_bypath(RepositoryHandle repo, ObjectId id, string treeentry_path) From 01a3711ee98bd90a4fb73eb2c832873c77cd384c Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Wed, 27 Nov 2024 22:50:52 -0500 Subject: [PATCH 09/11] WIP --- LibGit2Sharp/BlameHunk.cs | 11 +++++++++-- LibGit2Sharp/Core/NativeMethods.cs | 3 +-- LibGit2Sharp/FilterSource.cs | 7 ++++--- 3 files changed, 14 insertions(+), 7 deletions(-) diff --git a/LibGit2Sharp/BlameHunk.cs b/LibGit2Sharp/BlameHunk.cs index 6350a9bbc..087a5a6d3 100644 --- a/LibGit2Sharp/BlameHunk.cs +++ b/LibGit2Sharp/BlameHunk.cs @@ -2,6 +2,7 @@ using System.Diagnostics; using System.Globalization; using LibGit2Sharp.Core; +using LibGit2Sharp.Core.Handles; namespace LibGit2Sharp { @@ -42,12 +43,18 @@ internal unsafe BlameHunk(IRepository repository, git_blame_hunk* rawHunk) // Signature objects need to have ownership of their native pointers if (rawHunk->final_signature != null) { - FinalSignature = new Signature(rawHunk->final_signature); + var ptr = new IntPtr(rawHunk->final_signature); + var signatureHandle = new SignatureHandle(ptr, false); + + FinalSignature = new Signature(signatureHandle); } if (rawHunk->orig_signature != null) { - InitialSignature = new Signature(rawHunk->orig_signature); + var ptr = new IntPtr(rawHunk->orig_signature); + var signatureHandle = new SignatureHandle(ptr, false); + + InitialSignature = new Signature(signatureHandle); } } diff --git a/LibGit2Sharp/Core/NativeMethods.cs b/LibGit2Sharp/Core/NativeMethods.cs index 61128f1f4..bbd0f9f14 100644 --- a/LibGit2Sharp/Core/NativeMethods.cs +++ b/LibGit2Sharp/Core/NativeMethods.cs @@ -182,8 +182,7 @@ internal static extern int git_error_set_str( internal static extern unsafe uint git_blame_get_hunk_count(BlameHandle blame); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe git_blame_hunk* git_blame_get_hunk_byindex( - BlameHandle blame, uint index); + internal static extern unsafe git_blame_hunk* git_blame_get_hunk_byindex(BlameHandle blame, uint index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_blame_file( diff --git a/LibGit2Sharp/FilterSource.cs b/LibGit2Sharp/FilterSource.cs index ab1dcb35c..b8cfbe611 100644 --- a/LibGit2Sharp/FilterSource.cs +++ b/LibGit2Sharp/FilterSource.cs @@ -18,11 +18,12 @@ internal unsafe FilterSource(FilePath path, FilterMode mode, git_filter_source* SourceMode = mode; ObjectId = ObjectId.BuildFromPtr(&source->oid); Path = path.Native; - Root = Proxy.git_repository_workdir(new IntPtr(source->repository)).Native; + + Root = Proxy.git_repository_workdir(source->repository).Native; } /// - /// Take an unmanaged pointer and convert it to filter source callback paramater + /// Take an unmanaged pointer and convert it to filter source callback parameter. /// /// /// @@ -32,7 +33,7 @@ internal static unsafe FilterSource FromNativePtr(IntPtr ptr) } /// - /// Take an unmanaged pointer and convert it to filter source callback paramater + /// Take an unmanaged pointer and convert it to filter source callback parameter. /// /// /// From fdf4d972c47ed6d06083b1dc53bde344924c96c7 Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Wed, 27 Nov 2024 23:38:14 -0500 Subject: [PATCH 10/11] WIP --- LibGit2Sharp/Core/Handles/Objects.cs | 50 +++++++++++++------------- LibGit2Sharp/Core/Handles/Objects.tt | 2 +- LibGit2Sharp/Core/NativeMethods.cs | 52 +++++++++++++--------------- LibGit2Sharp/Core/Proxy.cs | 26 +++++++------- 4 files changed, 64 insertions(+), 66 deletions(-) diff --git a/LibGit2Sharp/Core/Handles/Objects.cs b/LibGit2Sharp/Core/Handles/Objects.cs index 2445c7eb5..0150e04f9 100644 --- a/LibGit2Sharp/Core/Handles/Objects.cs +++ b/LibGit2Sharp/Core/Handles/Objects.cs @@ -18,7 +18,7 @@ internal TreeEntryHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_tree_entry_free(this); + NativeMethods.git_tree_entry_free(handle); return true; } @@ -38,7 +38,7 @@ internal ReferenceHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_reference_free(this); + NativeMethods.git_reference_free(handle); return true; } @@ -58,7 +58,7 @@ internal RepositoryHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_repository_free(this); + NativeMethods.git_repository_free(handle); return true; } @@ -78,7 +78,7 @@ internal SignatureHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_signature_free(this); + NativeMethods.git_signature_free(handle); return true; } @@ -98,7 +98,7 @@ internal StatusListHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_status_list_free(this); + NativeMethods.git_status_list_free(handle); return true; } @@ -118,7 +118,7 @@ internal BlameHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_blame_free(this); + NativeMethods.git_blame_free(handle); return true; } @@ -138,7 +138,7 @@ internal DiffHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_diff_free(this); + NativeMethods.git_diff_free(handle); return true; } @@ -158,7 +158,7 @@ internal PatchHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_patch_free(this); + NativeMethods.git_patch_free(handle); return true; } @@ -178,7 +178,7 @@ internal ConfigurationHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_config_free(this); + NativeMethods.git_config_free(handle); return true; } @@ -198,7 +198,7 @@ internal ConflictIteratorHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_index_conflict_iterator_free(this); + NativeMethods.git_index_conflict_iterator_free(handle); return true; } @@ -218,7 +218,7 @@ internal IndexHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_index_free(this); + NativeMethods.git_index_free(handle); return true; } @@ -238,7 +238,7 @@ internal ReflogHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_reflog_free(this); + NativeMethods.git_reflog_free(handle); return true; } @@ -258,7 +258,7 @@ internal TreeBuilderHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_treebuilder_free(this); + NativeMethods.git_treebuilder_free(handle); return true; } @@ -278,7 +278,7 @@ internal PackBuilderHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_packbuilder_free(this); + NativeMethods.git_packbuilder_free(handle); return true; } @@ -298,7 +298,7 @@ internal NoteHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_note_free(this); + NativeMethods.git_note_free(handle); return true; } @@ -318,7 +318,7 @@ internal DescribeResultHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_describe_result_free(this); + NativeMethods.git_describe_result_free(handle); return true; } @@ -338,7 +338,7 @@ internal SubmoduleHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_submodule_free(this); + NativeMethods.git_submodule_free(handle); return true; } @@ -358,7 +358,7 @@ internal AnnotatedCommitHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_annotated_commit_free(this); + NativeMethods.git_annotated_commit_free(handle); return true; } @@ -378,7 +378,7 @@ internal ObjectDatabaseHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_odb_free(this); + NativeMethods.git_odb_free(handle); return true; } @@ -398,7 +398,7 @@ internal RevWalkerHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_revwalk_free(this); + NativeMethods.git_revwalk_free(handle); return true; } @@ -418,7 +418,7 @@ internal RemoteHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_remote_free(this); + NativeMethods.git_remote_free(handle); return true; } @@ -438,7 +438,7 @@ internal ObjectHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_object_free(this); + NativeMethods.git_object_free(handle); return true; } @@ -458,7 +458,7 @@ internal RebaseHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_rebase_free(this); + NativeMethods.git_rebase_free(handle); return true; } @@ -478,7 +478,7 @@ internal OdbStreamHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_odb_stream_free(this); + NativeMethods.git_odb_stream_free(handle); return true; } @@ -498,7 +498,7 @@ internal WorktreeHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_worktree_free(this); + NativeMethods.git_worktree_free(handle); return true; } diff --git a/LibGit2Sharp/Core/Handles/Objects.tt b/LibGit2Sharp/Core/Handles/Objects.tt index 374d3803c..9d2865883 100644 --- a/LibGit2Sharp/Core/Handles/Objects.tt +++ b/LibGit2Sharp/Core/Handles/Objects.tt @@ -84,7 +84,7 @@ for (var i = 0; i < cNames.Length; i++) protected override bool ReleaseHandle() { - NativeMethods.<#= cNames[i] #>_free(this); + NativeMethods.<#= cNames[i] #>_free(handle); return true; } diff --git a/LibGit2Sharp/Core/NativeMethods.cs b/LibGit2Sharp/Core/NativeMethods.cs index bbd0f9f14..d130e7514 100644 --- a/LibGit2Sharp/Core/NativeMethods.cs +++ b/LibGit2Sharp/Core/NativeMethods.cs @@ -192,7 +192,7 @@ internal static extern unsafe int git_blame_file( git_blame_options options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_blame_free(BlameHandle blame); + internal static extern unsafe void git_blame_free(nint blame); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_blob_create_from_disk( @@ -336,7 +336,7 @@ internal static extern unsafe int git_rebase_finish( SignatureHandle signature); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_rebase_free(RebaseHandle rebase); + internal static extern unsafe void git_rebase_free(nint rebase); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_rename( @@ -480,7 +480,7 @@ internal static extern unsafe int git_config_set_multivar( internal static extern int git_config_find_programdata(GitBuf programdata_config_path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_config_free(ConfigurationHandle cfg); + internal static extern unsafe void git_config_free(nint cfg); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe void git_config_entry_free(GitConfigEntry* entry); @@ -613,10 +613,10 @@ internal static extern unsafe int git_describe_format( ref GitDescribeFormatOptions options); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_describe_result_free(DescribeResultHandle describe); + internal static extern unsafe void git_describe_result_free(nint describe); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_diff_free(DiffHandle diff); + internal static extern unsafe void git_diff_free(nint diff); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_diff_tree_to_tree( @@ -865,8 +865,7 @@ internal static extern unsafe int git_index_conflict_next( ConflictIteratorHandle iterator); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_index_conflict_iterator_free( - ConflictIteratorHandle iterator); + internal static extern unsafe void git_index_conflict_iterator_free(nint iterator); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe UIntPtr git_index_entrycount(IndexHandle index); @@ -875,7 +874,7 @@ internal static extern unsafe void git_index_conflict_iterator_free( internal static extern unsafe int git_index_entry_stage(git_index_entry* indexentry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_index_free(IndexHandle index); + internal static extern unsafe void git_index_free(nint index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_index_entry* git_index_get_byindex(IndexHandle index, UIntPtr n); @@ -1005,7 +1004,7 @@ internal static extern unsafe int git_merge_analysis( int their_heads_len); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_annotated_commit_free(AnnotatedCommitHandle commit); + internal static extern unsafe void git_annotated_commit_free(nint commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_message_prettify( @@ -1026,7 +1025,7 @@ internal static extern unsafe int git_note_create( int force); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_note_free(NoteHandle note); + internal static extern unsafe void git_note_free(nint note); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] @@ -1092,13 +1091,13 @@ internal static extern unsafe int git_odb_foreach( internal static extern unsafe int git_odb_open_wstream(out OdbStreamHandle stream, ObjectDatabaseHandle odb, long size, GitObjectType type); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_odb_free(ObjectDatabaseHandle odb); + internal static extern unsafe void git_odb_free(nint odb); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_odb_read_header(out UIntPtr len_out, out GitObjectType type, ObjectDatabaseHandle odb, ref GitOid id); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_object_free(ObjectHandle obj); + internal static extern unsafe void git_object_free(nint obj); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_odb_stream_write(OdbStreamHandle Stream, IntPtr Buffer, UIntPtr len); @@ -1107,7 +1106,7 @@ internal static extern unsafe int git_odb_foreach( internal static extern unsafe int git_odb_stream_finalize_write(out GitOid id, OdbStreamHandle stream); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_odb_stream_free(OdbStreamHandle stream); + internal static extern unsafe void git_odb_stream_free(nint stream); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_odb_write(out GitOid id, ObjectDatabaseHandle odb, byte* data, UIntPtr len, GitObjectType type); @@ -1146,7 +1145,7 @@ internal static extern unsafe int git_patch_line_stats( PatchHandle patch); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_patch_free(PatchHandle patch); + internal static extern unsafe void git_patch_free(nint patch); /* Push network progress notification function */ [UnmanagedFunctionPointer(CallingConvention.Cdecl)] @@ -1155,7 +1154,7 @@ internal static extern unsafe int git_patch_line_stats( internal delegate int git_packbuilder_progress(int stage, uint current, uint total, IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_packbuilder_free(PackBuilderHandle packbuilder); + internal static extern unsafe void git_packbuilder_free(nint packbuilder); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_packbuilder_insert( @@ -1230,7 +1229,7 @@ internal static extern unsafe int git_reference_foreach_glob( IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_reference_free(ReferenceHandle reference); + internal static extern unsafe void git_reference_free(nint reference); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_reference_is_valid_name( @@ -1292,7 +1291,7 @@ internal static extern unsafe int git_reference_ensure_log( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string refname); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_reflog_free(ReflogHandle reflog); + internal static extern unsafe void git_reflog_free(nint reflog); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_reflog_read( @@ -1410,7 +1409,7 @@ internal static extern unsafe int git_remote_fetch( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string log_message); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_remote_free(RemoteHandle remote); + internal static extern unsafe void git_remote_free(nint remote); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_remote_get_fetch_refspecs(out GitStrArray array, RemoteHandle remote); @@ -1536,7 +1535,7 @@ internal static extern unsafe int git_repository_fetchhead_foreach( IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_repository_free(RepositoryHandle repo); + internal static extern unsafe void git_repository_free(nint repo); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_repository_head_detached(RepositoryHandle repo); @@ -1687,7 +1686,7 @@ internal static extern unsafe int git_revparse_ext( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string spec); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_revwalk_free(RevWalkerHandle walker); + internal static extern unsafe void git_revwalk_free(nint walker); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_revwalk_hide(RevWalkerHandle walker, ref GitOid commit_id); @@ -1711,7 +1710,7 @@ internal static extern unsafe int git_revparse_ext( internal static extern unsafe int git_revwalk_simplify_first_parent(RevWalkerHandle walk); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_signature_free(SignatureHandle signature); + internal static extern unsafe void git_signature_free(nint signature); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_signature_new( @@ -1789,8 +1788,7 @@ internal static extern unsafe int git_status_list_entrycount( UIntPtr idx); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_status_list_free( - StatusListHandle statusList); + internal static extern unsafe void git_status_list_free(nint statusList); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern void git_strarray_free( @@ -1832,7 +1830,7 @@ internal static extern unsafe int git_submodule_add_to_index( [MarshalAs(UnmanagedType.Bool)] bool write_index); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_submodule_free(SubmoduleHandle submodule); + internal static extern unsafe void git_submodule_free(nint submodule); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] [return: MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(LaxUtf8NoCleanupMarshaler))] @@ -2006,7 +2004,7 @@ internal static extern unsafe int git_tree_entry_bypath( [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string treeentry_path); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_tree_entry_free(TreeEntryHandle treeEntry); + internal static extern unsafe void git_tree_entry_free(nint treeEntry); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe git_oid* git_tree_entry_id(TreeEntryHandle entry); @@ -2036,7 +2034,7 @@ internal static extern unsafe int git_treebuilder_insert( internal static extern unsafe int git_treebuilder_write(out GitOid id, TreeBuilderHandle bld); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_treebuilder_free(TreeBuilderHandle bld); + internal static extern unsafe void git_treebuilder_free(nint bld); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_blob_is_binary(ObjectHandle blob); @@ -2066,7 +2064,7 @@ internal delegate int url_resolve_callback( IntPtr payload); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] - internal static extern unsafe void git_worktree_free(WorktreeHandle worktree); + internal static extern unsafe void git_worktree_free(nint worktree); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern unsafe int git_worktree_lookup( diff --git a/LibGit2Sharp/Core/Proxy.cs b/LibGit2Sharp/Core/Proxy.cs index da76b0609..54e002f30 100644 --- a/LibGit2Sharp/Core/Proxy.cs +++ b/LibGit2Sharp/Core/Proxy.cs @@ -492,11 +492,6 @@ public static FilePath git_config_find_programdata() return ConvertPath(NativeMethods.git_config_find_programdata); } - public static unsafe void git_config_free(ConfigurationHandle config) - { - NativeMethods.git_config_free(config); - } - public static unsafe ConfigurationEntry git_config_get_entry(ConfigurationHandle config, string key) { if (!configurationParser.ContainsKey(typeof(T))) @@ -2518,18 +2513,23 @@ public static unsafe RepositoryHandle git_repository_new() public static unsafe void git_repository_open_ext(string path, RepositoryOpenFlags flags, string ceilingDirs) { - int res; - RepositoryHandle repo; + RepositoryHandle repo = null; - res = NativeMethods.git_repository_open_ext(out repo, path, flags, ceilingDirs); - NativeMethods.git_repository_free(repo); + try + { + int res = NativeMethods.git_repository_open_ext(out repo, path, flags, ceilingDirs); - if (res == (int)GitErrorCode.NotFound) + if (res == (int)GitErrorCode.NotFound) + { + throw new RepositoryNotFoundException("Path '{0}' doesn't point at a valid Git repository or workdir.", path); + } + + Ensure.ZeroResult(res); + } + finally { - throw new RepositoryNotFoundException("Path '{0}' doesn't point at a valid Git repository or workdir.", path); + repo?.Dispose(); } - - Ensure.ZeroResult(res); } public static unsafe FilePath git_repository_path(RepositoryHandle repo) From 070d9c3176de4223cfc3a89abd333e21e2882785 Mon Sep 17 00:00:00 2001 From: Brandon Ording Date: Sun, 1 Dec 2024 16:42:27 -0500 Subject: [PATCH 11/11] WIP --- LibGit2Sharp/Configuration.cs | 4 ++-- LibGit2Sharp/Core/Proxy.cs | 4 +--- 2 files changed, 3 insertions(+), 5 deletions(-) diff --git a/LibGit2Sharp/Configuration.cs b/LibGit2Sharp/Configuration.cs index 84a8a3e53..142c34b12 100644 --- a/LibGit2Sharp/Configuration.cs +++ b/LibGit2Sharp/Configuration.cs @@ -52,9 +52,9 @@ internal Configuration( private void Init(Repository repository) { configHandle = Proxy.git_config_new(); - RepositoryHandle repoHandle = (repository != null) ? repository.Handle : null; + RepositoryHandle repoHandle = repository?.Handle ?? new RepositoryHandle(); - if (repoHandle != null) + if (!repoHandle.IsInvalid) { //TODO: push back this logic into libgit2. // As stated by @carlosmn "having a helper function to load the defaults and then allowing you diff --git a/LibGit2Sharp/Core/Proxy.cs b/LibGit2Sharp/Core/Proxy.cs index 54e002f30..ff67e7303 100644 --- a/LibGit2Sharp/Core/Proxy.cs +++ b/LibGit2Sharp/Core/Proxy.cs @@ -438,9 +438,7 @@ public static unsafe SignatureInfo git_commit_extract_signature(RepositoryHandle public static unsafe void git_config_add_file_ondisk(ConfigurationHandle config, FilePath path, ConfigurationLevel level, RepositoryHandle repo) { - // RepositoryHandle does implicit cast voodoo that is not null-safe, thus this explicit check - RepositoryHandle repoHandle = (repo != null) ? (RepositoryHandle)repo : null; - int res = NativeMethods.git_config_add_file_ondisk(config, path, (uint)level, repoHandle, true); + int res = NativeMethods.git_config_add_file_ondisk(config, path, (uint)level, repo, true); Ensure.ZeroResult(res); }