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/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/GitFilter.cs b/LibGit2Sharp/Core/GitFilter.cs index 72fa2f763..0f10c3465 100644 --- a/LibGit2Sharp/Core/GitFilter.cs +++ b/LibGit2Sharp/Core/GitFilter.cs @@ -118,7 +118,7 @@ public delegate int git_filter_stream_fn( [StructLayout(LayoutKind.Sequential)] internal unsafe struct git_filter_source { - public git_repository* repository; + public IntPtr repository; public char* path; diff --git a/LibGit2Sharp/Core/Handles/Libgit2Object.cs b/LibGit2Sharp/Core/Handles/Libgit2Object.cs index a96d99e10..9c3bd79db 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,20 +83,20 @@ 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; private readonly Guid id; #endif - internal unsafe Libgit2Object(void* ptr, bool owned) - : this(new IntPtr(ptr), owned) + internal unsafe Libgit2Object() + : base(IntPtr.Zero, true) { } internal unsafe Libgit2Object(IntPtr ptr, bool owned) - : base(owned) + : base(IntPtr.Zero, owned) { SetHandle(ptr); @@ -108,12 +108,12 @@ internal unsafe Libgit2Object(IntPtr ptr, bool owned) #endif } - internal IntPtr AsIntPtr() => DangerousGetHandle(); + public override bool IsInvalid => handle == IntPtr.Zero; protected override void Dispose(bool disposing) { #if LEAKS_IDENTIFYING - bool leaked = !disposing && DangerousGetHandle() != IntPtr.Zero; + bool leaked = !disposing && !IsInvalid; if (leaked) { diff --git a/LibGit2Sharp/Core/Handles/Objects.cs b/LibGit2Sharp/Core/Handles/Objects.cs index ddca49bee..0150e04f9 100644 --- a/LibGit2Sharp/Core/Handles/Objects.cs +++ b/LibGit2Sharp/Core/Handles/Objects.cs @@ -6,8 +6,8 @@ namespace LibGit2Sharp.Core.Handles internal unsafe class TreeEntryHandle : Libgit2Object { - internal TreeEntryHandle(git_tree_entry* ptr, bool owned) - : base(ptr, owned) + internal TreeEntryHandle() + : base() { } @@ -18,21 +18,16 @@ internal TreeEntryHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_tree_entry_free((git_tree_entry*)AsIntPtr()); + NativeMethods.git_tree_entry_free(handle); return true; } - - public static implicit operator git_tree_entry*(TreeEntryHandle handle) - { - return (git_tree_entry*)handle.AsIntPtr(); - } } internal unsafe class ReferenceHandle : Libgit2Object { - internal ReferenceHandle(git_reference* ptr, bool owned) - : base(ptr, owned) + internal ReferenceHandle() + : base() { } @@ -43,21 +38,16 @@ internal ReferenceHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_reference_free((git_reference*)AsIntPtr()); + NativeMethods.git_reference_free(handle); return true; } - - public static implicit operator git_reference*(ReferenceHandle handle) - { - return (git_reference*)handle.AsIntPtr(); - } } internal unsafe class RepositoryHandle : Libgit2Object { - internal RepositoryHandle(git_repository* ptr, bool owned) - : base(ptr, owned) + internal RepositoryHandle() + : base() { } @@ -68,21 +58,16 @@ internal RepositoryHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_repository_free((git_repository*)AsIntPtr()); + NativeMethods.git_repository_free(handle); return true; } - - public static implicit operator git_repository*(RepositoryHandle handle) - { - return (git_repository*)handle.AsIntPtr(); - } } internal unsafe class SignatureHandle : Libgit2Object { - internal SignatureHandle(git_signature* ptr, bool owned) - : base(ptr, owned) + internal SignatureHandle() + : base() { } @@ -93,21 +78,16 @@ internal SignatureHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_signature_free((git_signature*)AsIntPtr()); + NativeMethods.git_signature_free(handle); return true; } - - public static implicit operator git_signature*(SignatureHandle handle) - { - return (git_signature*)handle.AsIntPtr(); - } } internal unsafe class StatusListHandle : Libgit2Object { - internal StatusListHandle(git_status_list* ptr, bool owned) - : base(ptr, owned) + internal StatusListHandle() + : base() { } @@ -118,21 +98,16 @@ internal StatusListHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_status_list_free((git_status_list*)AsIntPtr()); + NativeMethods.git_status_list_free(handle); return true; } - - public static implicit operator git_status_list*(StatusListHandle handle) - { - return (git_status_list*)handle.AsIntPtr(); - } } internal unsafe class BlameHandle : Libgit2Object { - internal BlameHandle(git_blame* ptr, bool owned) - : base(ptr, owned) + internal BlameHandle() + : base() { } @@ -143,21 +118,16 @@ internal BlameHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_blame_free((git_blame*)AsIntPtr()); + NativeMethods.git_blame_free(handle); return true; } - - public static implicit operator git_blame*(BlameHandle handle) - { - return (git_blame*)handle.AsIntPtr(); - } } internal unsafe class DiffHandle : Libgit2Object { - internal DiffHandle(git_diff* ptr, bool owned) - : base(ptr, owned) + internal DiffHandle() + : base() { } @@ -168,21 +138,16 @@ internal DiffHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_diff_free((git_diff*)AsIntPtr()); + NativeMethods.git_diff_free(handle); return true; } - - public static implicit operator git_diff*(DiffHandle handle) - { - return (git_diff*)handle.AsIntPtr(); - } } internal unsafe class PatchHandle : Libgit2Object { - internal PatchHandle(git_patch* ptr, bool owned) - : base(ptr, owned) + internal PatchHandle() + : base() { } @@ -193,21 +158,16 @@ internal PatchHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_patch_free((git_patch*)AsIntPtr()); + NativeMethods.git_patch_free(handle); return true; } - - public static implicit operator git_patch*(PatchHandle handle) - { - return (git_patch*)handle.AsIntPtr(); - } } internal unsafe class ConfigurationHandle : Libgit2Object { - internal ConfigurationHandle(git_config* ptr, bool owned) - : base(ptr, owned) + internal ConfigurationHandle() + : base() { } @@ -218,21 +178,16 @@ internal ConfigurationHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_config_free((git_config*)AsIntPtr()); + NativeMethods.git_config_free(handle); return true; } - - public static implicit operator git_config*(ConfigurationHandle handle) - { - return (git_config*)handle.AsIntPtr(); - } } internal unsafe class ConflictIteratorHandle : Libgit2Object { - internal ConflictIteratorHandle(git_index_conflict_iterator* ptr, bool owned) - : base(ptr, owned) + internal ConflictIteratorHandle() + : base() { } @@ -243,21 +198,16 @@ 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(handle); return true; } - - public static implicit operator git_index_conflict_iterator*(ConflictIteratorHandle handle) - { - return (git_index_conflict_iterator*)handle.AsIntPtr(); - } } internal unsafe class IndexHandle : Libgit2Object { - internal IndexHandle(git_index* ptr, bool owned) - : base(ptr, owned) + internal IndexHandle() + : base() { } @@ -268,21 +218,16 @@ internal IndexHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_index_free((git_index*)AsIntPtr()); + NativeMethods.git_index_free(handle); return true; } - - public static implicit operator git_index*(IndexHandle handle) - { - return (git_index*)handle.AsIntPtr(); - } } internal unsafe class ReflogHandle : Libgit2Object { - internal ReflogHandle(git_reflog* ptr, bool owned) - : base(ptr, owned) + internal ReflogHandle() + : base() { } @@ -293,21 +238,16 @@ internal ReflogHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_reflog_free((git_reflog*)AsIntPtr()); + NativeMethods.git_reflog_free(handle); return true; } - - public static implicit operator git_reflog*(ReflogHandle handle) - { - return (git_reflog*)handle.AsIntPtr(); - } } internal unsafe class TreeBuilderHandle : Libgit2Object { - internal TreeBuilderHandle(git_treebuilder* ptr, bool owned) - : base(ptr, owned) + internal TreeBuilderHandle() + : base() { } @@ -318,21 +258,16 @@ internal TreeBuilderHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_treebuilder_free((git_treebuilder*)AsIntPtr()); + NativeMethods.git_treebuilder_free(handle); return true; } - - public static implicit operator git_treebuilder*(TreeBuilderHandle handle) - { - return (git_treebuilder*)handle.AsIntPtr(); - } } internal unsafe class PackBuilderHandle : Libgit2Object { - internal PackBuilderHandle(git_packbuilder* ptr, bool owned) - : base(ptr, owned) + internal PackBuilderHandle() + : base() { } @@ -343,21 +278,16 @@ internal PackBuilderHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_packbuilder_free((git_packbuilder*)AsIntPtr()); + NativeMethods.git_packbuilder_free(handle); return true; } - - public static implicit operator git_packbuilder*(PackBuilderHandle handle) - { - return (git_packbuilder*)handle.AsIntPtr(); - } } internal unsafe class NoteHandle : Libgit2Object { - internal NoteHandle(git_note* ptr, bool owned) - : base(ptr, owned) + internal NoteHandle() + : base() { } @@ -368,21 +298,16 @@ internal NoteHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_note_free((git_note*)AsIntPtr()); + NativeMethods.git_note_free(handle); return true; } - - public static implicit operator git_note*(NoteHandle handle) - { - return (git_note*)handle.AsIntPtr(); - } } internal unsafe class DescribeResultHandle : Libgit2Object { - internal DescribeResultHandle(git_describe_result* ptr, bool owned) - : base(ptr, owned) + internal DescribeResultHandle() + : base() { } @@ -393,21 +318,16 @@ internal DescribeResultHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_describe_result_free((git_describe_result*)AsIntPtr()); + NativeMethods.git_describe_result_free(handle); return true; } - - public static implicit operator git_describe_result*(DescribeResultHandle handle) - { - return (git_describe_result*)handle.AsIntPtr(); - } } internal unsafe class SubmoduleHandle : Libgit2Object { - internal SubmoduleHandle(git_submodule* ptr, bool owned) - : base(ptr, owned) + internal SubmoduleHandle() + : base() { } @@ -418,21 +338,16 @@ internal SubmoduleHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_submodule_free((git_submodule*)AsIntPtr()); + NativeMethods.git_submodule_free(handle); return true; } - - public static implicit operator git_submodule*(SubmoduleHandle handle) - { - return (git_submodule*)handle.AsIntPtr(); - } } internal unsafe class AnnotatedCommitHandle : Libgit2Object { - internal AnnotatedCommitHandle(git_annotated_commit* ptr, bool owned) - : base(ptr, owned) + internal AnnotatedCommitHandle() + : base() { } @@ -443,21 +358,16 @@ internal AnnotatedCommitHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_annotated_commit_free((git_annotated_commit*)AsIntPtr()); + NativeMethods.git_annotated_commit_free(handle); return true; } - - public static implicit operator git_annotated_commit*(AnnotatedCommitHandle handle) - { - return (git_annotated_commit*)handle.AsIntPtr(); - } } internal unsafe class ObjectDatabaseHandle : Libgit2Object { - internal ObjectDatabaseHandle(git_odb* ptr, bool owned) - : base(ptr, owned) + internal ObjectDatabaseHandle() + : base() { } @@ -468,21 +378,16 @@ internal ObjectDatabaseHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_odb_free((git_odb*)AsIntPtr()); + NativeMethods.git_odb_free(handle); return true; } - - public static implicit operator git_odb*(ObjectDatabaseHandle handle) - { - return (git_odb*)handle.AsIntPtr(); - } } internal unsafe class RevWalkerHandle : Libgit2Object { - internal RevWalkerHandle(git_revwalk* ptr, bool owned) - : base(ptr, owned) + internal RevWalkerHandle() + : base() { } @@ -493,21 +398,16 @@ internal RevWalkerHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_revwalk_free((git_revwalk*)AsIntPtr()); + NativeMethods.git_revwalk_free(handle); return true; } - - public static implicit operator git_revwalk*(RevWalkerHandle handle) - { - return (git_revwalk*)handle.AsIntPtr(); - } } internal unsafe class RemoteHandle : Libgit2Object { - internal RemoteHandle(git_remote* ptr, bool owned) - : base(ptr, owned) + internal RemoteHandle() + : base() { } @@ -518,21 +418,16 @@ internal RemoteHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_remote_free((git_remote*)AsIntPtr()); + NativeMethods.git_remote_free(handle); return true; } - - public static implicit operator git_remote*(RemoteHandle handle) - { - return (git_remote*)handle.AsIntPtr(); - } } internal unsafe class ObjectHandle : Libgit2Object { - internal ObjectHandle(git_object* ptr, bool owned) - : base(ptr, owned) + internal ObjectHandle() + : base() { } @@ -543,21 +438,16 @@ internal ObjectHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_object_free((git_object*)AsIntPtr()); + NativeMethods.git_object_free(handle); return true; } - - public static implicit operator git_object*(ObjectHandle handle) - { - return (git_object*)handle.AsIntPtr(); - } } internal unsafe class RebaseHandle : Libgit2Object { - internal RebaseHandle(git_rebase* ptr, bool owned) - : base(ptr, owned) + internal RebaseHandle() + : base() { } @@ -568,21 +458,16 @@ internal RebaseHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_rebase_free((git_rebase*)AsIntPtr()); + NativeMethods.git_rebase_free(handle); return true; } - - public static implicit operator git_rebase*(RebaseHandle handle) - { - return (git_rebase*)handle.AsIntPtr(); - } } internal unsafe class OdbStreamHandle : Libgit2Object { - internal OdbStreamHandle(git_odb_stream* ptr, bool owned) - : base(ptr, owned) + internal OdbStreamHandle() + : base() { } @@ -593,21 +478,16 @@ internal OdbStreamHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_odb_stream_free((git_odb_stream*)AsIntPtr()); + NativeMethods.git_odb_stream_free(handle); return true; } - - public static implicit operator git_odb_stream*(OdbStreamHandle handle) - { - return (git_odb_stream*)handle.AsIntPtr(); - } } internal unsafe class WorktreeHandle : Libgit2Object { - internal WorktreeHandle(git_worktree* ptr, bool owned) - : base(ptr, owned) + internal WorktreeHandle() + : base() { } @@ -618,15 +498,10 @@ internal WorktreeHandle(IntPtr ptr, bool owned) protected override bool ReleaseHandle() { - NativeMethods.git_worktree_free((git_worktree*)AsIntPtr()); + NativeMethods.git_worktree_free(handle); return true; } - - public static implicit operator git_worktree*(WorktreeHandle handle) - { - return (git_worktree*)handle.AsIntPtr(); - } } } diff --git a/LibGit2Sharp/Core/Handles/Objects.tt b/LibGit2Sharp/Core/Handles/Objects.tt index e522bd859..9d2865883 100644 --- a/LibGit2Sharp/Core/Handles/Objects.tt +++ b/LibGit2Sharp/Core/Handles/Objects.tt @@ -72,8 +72,8 @@ 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] #>() + : base() { } @@ -84,15 +84,10 @@ for (var i = 0; i < cNames.Length; i++) protected override bool ReleaseHandle() { - NativeMethods.<#= cNames[i] #>_free((<#= cNames[i] #>*)AsIntPtr()); + NativeMethods.<#= cNames[i] #>_free(handle); return true; } - - public static implicit operator <#= cNames[i] #>*(<#= csNames[i] #> handle) - { - return (<#= cNames[i] #>*)handle.AsIntPtr(); - } } <# 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 cbb850b16..d130e7514 100644 --- a/LibGit2Sharp/Core/NativeMethods.cs +++ b/LibGit2Sharp/Core/NativeMethods.cs @@ -179,38 +179,37 @@ 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( - git_blame* 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( - 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(nint 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 +220,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( @@ -256,13 +255,13 @@ 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)] 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 +274,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,62 +286,62 @@ 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, - git_signature* author, - git_signature* committer, + RebaseHandle rebase, + SignatureHandle author, + SignatureHandle committer, IntPtr message_encoding, IntPtr message); [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, - git_signature* signature); + RebaseHandle repo, + SignatureHandle 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(nint 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 +353,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,36 +361,36 @@ 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 SignatureHandle 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 SignatureHandle 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, + 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, @@ -401,69 +400,69 @@ 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, - git_signature* author, - git_signature* committer, + RepositoryHandle repo, + 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, - 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)] - 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( - 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 +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(git_config* 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); @@ -489,24 +488,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 +525,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,14 +554,14 @@ 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); [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)] @@ -574,7 +573,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 +602,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(nint 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(nint 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 +680,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 +693,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 +702,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 +812,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 +849,139 @@ 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); + 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(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(nint 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 +989,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(nint commit); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern int git_message_prettify( @@ -1018,43 +1016,43 @@ 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, + SignatureHandle author, + SignatureHandle committer, ref GitOid oid, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string note, 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(nint 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, + SignatureHandle author, + SignatureHandle committer, ref GitOid oid); [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 +1062,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 +1083,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(nint 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(nint 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(nint 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(nint patch); /* Push network progress notification function */ [UnmanagedFunctionPointer(CallingConvention.Cdecl)] @@ -1156,54 +1154,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(nint 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 +1209,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,106 +1223,101 @@ 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(nint 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)] [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( - 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 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( - 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); [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(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( - 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(nint 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, - 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( @@ -1371,11 +1364,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 +1376,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(nint 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 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, 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 +1458,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,42 +1530,42 @@ 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(nint 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( [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); [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); + internal static extern unsafe int git_repository_state_cleanup(RepositoryHandle repo); [UnmanagedFunctionPointer(CallingConvention.Cdecl)] internal delegate int git_repository_mergehead_foreach_cb( @@ -1581,83 +1574,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,63 +1658,63 @@ 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(nint 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); + internal static extern unsafe void git_signature_free(nint 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 +1722,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, - git_repository* repo, - git_signature* stasher, + RepositoryHandle repo, + SignatureHandle stasher, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message, StashModifiers flags); @@ -1753,50 +1746,49 @@ 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); + internal static extern unsafe void git_status_list_free(nint statusList); [DllImport(libgit2, CallingConvention = CallingConvention.Cdecl)] internal static extern void git_strarray_free( @@ -1804,19 +1796,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,85 +1820,85 @@ 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(nint 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, - git_signature* signature, + ObjectHandle target, + SignatureHandle 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, - git_signature* signature, + ObjectHandle target, + SignatureHandle signature, [MarshalAs(UnmanagedType.CustomMarshaler, MarshalCookie = UniqueId.UniqueIdentifier, MarshalTypeRef = typeof(StrictUtf8Marshaler))] string message, [MarshalAs(UnmanagedType.Bool)] bool force); @@ -1914,36 +1906,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 SignatureHandle 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(); @@ -2000,61 +1992,61 @@ 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); + 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( - 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(nint 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); + 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(nint 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 +2064,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(nint 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/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/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 83d35e22c..ff67e7303 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) { - git_blame* 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) { - git_reference* 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) @@ -131,7 +127,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 @@ -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) { - git_reference* 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) { - git_index* 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) { - git_repository* 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 @@ -345,7 +340,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) { @@ -443,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 - git_repository* repoHandle = (repo != null) ? (git_repository*)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); } @@ -497,11 +490,6 @@ public static FilePath git_config_find_programdata() return ConvertPath(NativeMethods.git_config_find_programdata); } - public static unsafe void git_config_free(git_config* config) - { - NativeMethods.git_config_free(config); - } - public static unsafe ConfigurationEntry git_config_get_entry(ConfigurationHandle config, string key) { if (!configurationParser.ContainsKey(typeof(T))) @@ -531,17 +519,15 @@ public static unsafe ConfigurationEntry git_config_get_entry(Configuration public static unsafe ConfigurationHandle git_config_new() { - git_config* 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) { - git_config* 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 +536,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) @@ -624,7 +610,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 { @@ -649,14 +635,13 @@ public static IEnumerable> git_config_iterator_glob( public static unsafe ConfigurationHandle git_config_snapshot(ConfigurationHandle config) { - git_config* 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(git_config* config) + public static unsafe IntPtr git_config_lock(ConfigurationHandle config) { IntPtr txn; int res = NativeMethods.git_config_lock(out txn, config); @@ -700,10 +685,8 @@ public static unsafe string git_describe_commit( try { - git_describe_result* 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()) { @@ -763,7 +746,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,11 +763,10 @@ public static unsafe DiffHandle git_diff_tree_to_index( { using (var osw = new ObjectSafeWrapper(oldTree, repo, true)) { - git_diff* 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 +785,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)) { - git_diff* 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 +797,10 @@ public static unsafe DiffHandle git_diff_index_to_workdir( IndexHandle index, GitDiffOptions options) { - git_diff* 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 +810,10 @@ public static unsafe DiffHandle git_diff_tree_to_workdir( { using (var osw = new ObjectSafeWrapper(oldTree, repo, true)) { - git_diff* 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 +1041,10 @@ public static unsafe Conflict git_index_conflict_get( public static unsafe ConflictIteratorHandle git_index_conflict_iterator_new(IndexHandle index) { - git_index_conflict_iterator* 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 +1107,10 @@ public static unsafe int git_index_name_entrycount(IndexHandle index) public static unsafe IndexHandle git_index_open(FilePath indexpath) { - git_index* 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 +1183,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; - 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 +1194,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 +1229,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) { - git_annotated_commit* 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) { - git_annotated_commit* 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) { - git_annotated_commit* 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) { - git_annotated_commit* 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) @@ -1302,7 +1270,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 +1295,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, @@ -1422,9 +1390,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; - git_note* 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 +1400,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 +1432,9 @@ 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; 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,12 +1445,12 @@ 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) { - git_object* peeled; + ObjectHandle peeled; int res; using (var obj = new ObjectSafeWrapper(id, repo)) @@ -1500,7 +1466,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 +1547,10 @@ 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; - 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 +1595,9 @@ 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; - 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 +1620,10 @@ public static unsafe Tuple git_patch_line_stats(PatchHandle patch) public static unsafe PackBuilderHandle git_packbuilder_new(RepositoryHandle repo) { - git_packbuilder* 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 +1689,18 @@ public static unsafe RebaseHandle git_rebase_init( AnnotatedCommitHandle onto, GitRebaseOptions options) { - git_rebase* 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) { - git_rebase* 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 +1842,11 @@ public static unsafe ReferenceHandle git_reference_create( string logMessage) { GitOid oid = targetId.Oid; - git_reference* 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 +1856,10 @@ public static unsafe ReferenceHandle git_reference_symbolic_create( bool allowOverwrite, string logMessage) { - git_reference* 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 +1897,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; - 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,10 +1906,10 @@ 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(git_reference* reference) + public static unsafe string git_reference_name(ReferenceHandle reference) { return NativeMethods.git_reference_name(reference); } @@ -1966,7 +1920,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)); } @@ -1977,41 +1931,36 @@ public static unsafe ReferenceHandle git_reference_rename( bool allowOverwrite, string logMessage) { - git_reference* 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; - git_reference* 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) { - git_reference* 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(git_reference* reference) + public static unsafe string git_reference_symbolic_target(ReferenceHandle reference) { 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); } @@ -2028,12 +1977,10 @@ 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; - - 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) @@ -2041,27 +1988,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); } @@ -2138,29 +2085,26 @@ 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; - 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) { - git_remote* 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) { - git_remote* 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) @@ -2191,7 +2135,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); } @@ -2375,8 +2319,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; - 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 +2327,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 +2417,10 @@ public static bool git_repository_head_unborn(RepositoryHandle repo) public static unsafe IndexHandle git_repository_index(RepositoryHandle repo) { - git_index* 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 +2430,10 @@ public static unsafe RepositoryHandle git_repository_init_ext( { using (var opts = GitRepositoryInitOptions.BuildFrom(workdirPath, isBare)) { - git_repository* 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,54 +2480,54 @@ public static unsafe string git_repository_message(RepositoryHandle repo) public static unsafe ObjectDatabaseHandle git_repository_odb(RepositoryHandle repo) { - git_odb* 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) { - git_repository* 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() { - git_repository* 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) { - int res; - git_repository* 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) @@ -2687,8 +2628,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; - 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 +2638,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) { - git_object* obj; - git_reference* 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 +2691,10 @@ public static unsafe void git_revwalk_hide(RevWalkerHandle walker, ObjectId comm public static unsafe RevWalkerHandle git_revwalk_new(RepositoryHandle repo) { - git_revwalk* 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) @@ -2804,28 +2740,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; } @@ -2942,10 +2873,9 @@ 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; - 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 +2900,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; - 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 +2911,7 @@ public static unsafe SubmoduleHandle git_submodule_lookup(RepositoryHandle repo, default: Ensure.ZeroResult(res); - return new SubmoduleHandle(submodule, true); + return submodule; } } @@ -3162,14 +3091,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; @@ -3249,28 +3179,21 @@ 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); } 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) { using (var obj = new ObjectSafeWrapper(id, repo, throwIfMissing: true)) { - git_tree_entry* 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,21 +3202,21 @@ public static unsafe TreeEntryHandle git_tree_entry_bypath(RepositoryHandle repo Ensure.ZeroResult(res); - return new TreeEntryHandle(treeEntryPtr, true); + return treeEntryPtr; } } - 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); } @@ -3309,11 +3232,10 @@ public static unsafe int git_tree_entrycount(ObjectHandle tree) public static unsafe TreeBuilderHandle git_treebuilder_new(RepositoryHandle repo) { - git_treebuilder* 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 +3545,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; - 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 +3557,7 @@ public static unsafe WorktreeHandle git_worktree_lookup(RepositoryHandle repo, s default: Ensure.ZeroResult(res); - return new WorktreeHandle(worktree, true); + return worktree; } } @@ -3659,8 +3580,7 @@ public static unsafe IList git_worktree_list(RepositoryHandle repo) public static unsafe RepositoryHandle git_repository_open_from_worktree(WorktreeHandle handle) { - git_repository* 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 +3589,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 +3640,9 @@ public static unsafe WorktreeHandle git_worktree_add( string path, git_worktree_add_options options) { - git_worktree* 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, @@ -3822,9 +3741,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/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. /// /// /// 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/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); 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/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)); 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(); + // } + //} }