From c5c4347cd4ea11188ddfd27cbdd09ee370934ebc Mon Sep 17 00:00:00 2001 From: Carlos Sanchez <1175054+carlossanlop@users.noreply.github.com> Date: Wed, 6 Jul 2022 11:09:13 -0700 Subject: [PATCH] Fix S.R.InteropServices remarks (#71683) Moved the triple slash seealso items outside of the remarks section, to prevent porting them to dotnet-api-docs, because they would show weird in MS Docs. --- .../Marshalling/AnsiStringMarshaller.cs | 10 +--------- .../Marshalling/ArrayMarshaller.cs | 18 +----------------- .../Marshalling/BStrStringMarshaller.cs | 10 +--------- .../CustomTypeMarshallerAttribute.cs | 2 +- .../Marshalling/CustomTypeMarshallerKind.cs | 2 -- .../Marshalling/PointerArrayMarshaller.cs | 18 +----------------- .../Marshalling/Utf16StringMarshaller.cs | 8 -------- .../Marshalling/Utf8StringMarshaller.cs | 10 +--------- 8 files changed, 6 insertions(+), 72 deletions(-) diff --git a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/AnsiStringMarshaller.cs b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/AnsiStringMarshaller.cs index 6d729263bda5e..5baea94b9372d 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/AnsiStringMarshaller.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/AnsiStringMarshaller.cs @@ -32,8 +32,8 @@ public AnsiStringMarshaller(string? str) /// /// The must not be movable - that is, it should not be /// on the managed heap or it should be pinned. - /// /// + /// public AnsiStringMarshaller(string? str, Span buffer) { _allocated = false; @@ -65,18 +65,14 @@ public AnsiStringMarshaller(string? str, Span buffer) /// /// Returns the native value representing the string. /// - /// /// - /// public byte* ToNativeValue() => _nativeValue; /// /// Sets the native value representing the string. /// /// The native value. - /// /// - /// public void FromNativeValue(byte* value) { _nativeValue = value; @@ -86,17 +82,13 @@ public void FromNativeValue(byte* value) /// /// Returns the managed string. /// - /// /// - /// public string? ToManaged() => Marshal.PtrToStringAnsi((IntPtr)_nativeValue); /// /// Frees native resources. /// - /// /// - /// public void FreeNative() { if (_allocated) diff --git a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/ArrayMarshaller.cs b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/ArrayMarshaller.cs index ac65ab279cc1e..07386d0864c62 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/ArrayMarshaller.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/ArrayMarshaller.cs @@ -50,8 +50,8 @@ public ArrayMarshaller(T[]? array, int sizeOfNativeElement) /// /// The must not be movable - that is, it should not be /// on the managed heap or it should be pinned. - /// /// + /// public ArrayMarshaller(T[]? array, Span buffer, int sizeOfNativeElement) { _allocatedMemory = default; @@ -83,9 +83,7 @@ public ArrayMarshaller(T[]? array, Span buffer, int sizeOfNativeElement) /// Gets a span that points to the memory where the managed values of the array are stored. /// /// Span over managed values of the array. - /// /// - /// public ReadOnlySpan GetManagedValuesSource() => _managedArray; /// @@ -93,9 +91,7 @@ public ArrayMarshaller(T[]? array, Span buffer, int sizeOfNativeElement) /// /// Length of the array. /// Span where managed values of the array should be stored. - /// /// - /// public Span GetManagedValuesDestination(int length) => _allocatedMemory == IntPtr.Zero ? null : _managedArray = new T[length]; /// @@ -103,9 +99,7 @@ public ArrayMarshaller(T[]? array, Span buffer, int sizeOfNativeElement) /// /// Length of the array. /// Span over the native values of the array. - /// /// - /// public ReadOnlySpan GetNativeValuesSource(int length) { if (_allocatedMemory == IntPtr.Zero) @@ -120,9 +114,7 @@ public ReadOnlySpan GetNativeValuesSource(int length) /// Returns a span that points to the memory where the native values of the array should be stored. /// /// Span where native values of the array should be stored. - /// /// - /// public Span GetNativeValuesDestination() => _span; /// @@ -133,18 +125,14 @@ public ReadOnlySpan GetNativeValuesSource(int length) /// /// Returns the native value representing the array. /// - /// /// - /// public byte* ToNativeValue() => (byte*)Unsafe.AsPointer(ref GetPinnableReference()); /// /// Sets the native value representing the array. /// /// The native value. - /// /// - /// public void FromNativeValue(byte* value) { _allocatedMemory = (IntPtr)value; @@ -153,17 +141,13 @@ public void FromNativeValue(byte* value) /// /// Returns the managed array. /// - /// /// - /// public T[]? ToManaged() => _managedArray; /// /// Frees native resources. /// - /// /// - /// public void FreeNative() { Marshal.FreeCoTaskMem(_allocatedMemory); diff --git a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/BStrStringMarshaller.cs b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/BStrStringMarshaller.cs index ce5a83a69e1ab..4f246a26bc326 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/BStrStringMarshaller.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/BStrStringMarshaller.cs @@ -34,8 +34,8 @@ public BStrStringMarshaller(string? str) /// /// The must not be movable - that is, it should not be /// on the managed heap or it should be pinned. - /// /// + /// public BStrStringMarshaller(string? str, Span buffer) { _allocated = false; @@ -78,18 +78,14 @@ public BStrStringMarshaller(string? str, Span buffer) /// /// Returns the native value representing the string. /// - /// /// - /// public void* ToNativeValue() => _ptrToFirstChar; /// /// Sets the native value representing the string. /// /// The native value. - /// /// - /// public void FromNativeValue(void* value) { _ptrToFirstChar = value; @@ -99,9 +95,7 @@ public void FromNativeValue(void* value) /// /// Returns the managed string. /// - /// /// - /// public string? ToManaged() { if (_ptrToFirstChar is null) @@ -113,9 +107,7 @@ public void FromNativeValue(void* value) /// /// Frees native resources. /// - /// /// - /// public void FreeNative() { if (_allocated) diff --git a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/CustomTypeMarshallerAttribute.cs b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/CustomTypeMarshallerAttribute.cs index 8017d3d667b40..1bdad6fbaedc0 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/CustomTypeMarshallerAttribute.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/CustomTypeMarshallerAttribute.cs @@ -9,8 +9,8 @@ namespace System.Runtime.InteropServices.Marshalling /// /// This attribute is recognized by the runtime-provided source generators for source-generated interop scenarios. /// It is not used by the interop marshalling system at runtime. - /// /// + /// [AttributeUsage(AttributeTargets.Struct)] public sealed class CustomTypeMarshallerAttribute : Attribute { diff --git a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/CustomTypeMarshallerKind.cs b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/CustomTypeMarshallerKind.cs index f19d59b0fbe1c..02cba782fd6e0 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/CustomTypeMarshallerKind.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/CustomTypeMarshallerKind.cs @@ -10,9 +10,7 @@ namespace System.Runtime.InteropServices.Marshalling /// /// The shape of a custom type marshaller for usage in source-generated interop scenarios. /// - /// /// - /// public enum CustomTypeMarshallerKind { /// diff --git a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/PointerArrayMarshaller.cs b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/PointerArrayMarshaller.cs index 18e1bd162847e..03e2f3d245926 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/PointerArrayMarshaller.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/PointerArrayMarshaller.cs @@ -50,8 +50,8 @@ public PointerArrayMarshaller(T*[]? array, int sizeOfNativeElement) /// /// The must not be movable - that is, it should not be /// on the managed heap or it should be pinned. - /// /// + /// public PointerArrayMarshaller(T*[]? array, Span buffer, int sizeOfNativeElement) { _allocatedMemory = default; @@ -83,9 +83,7 @@ public PointerArrayMarshaller(T*[]? array, Span buffer, int sizeOfNativeEl /// Gets a span that points to the memory where the managed values of the array are stored. /// /// Span over managed values of the array. - /// /// - /// public ReadOnlySpan GetManagedValuesSource() => Unsafe.As(_managedArray); /// @@ -93,9 +91,7 @@ public PointerArrayMarshaller(T*[]? array, Span buffer, int sizeOfNativeEl /// /// Length of the array. /// Span where managed values of the array should be stored. - /// /// - /// public Span GetManagedValuesDestination(int length) { if (_allocatedMemory == IntPtr.Zero) @@ -110,9 +106,7 @@ public Span GetManagedValuesDestination(int length) /// /// Length of the array. /// Span over the native values of the array. - /// /// - /// public ReadOnlySpan GetNativeValuesSource(int length) { if (_allocatedMemory == IntPtr.Zero) @@ -127,9 +121,7 @@ public ReadOnlySpan GetNativeValuesSource(int length) /// Returns a span that points to the memory where the native values of the array should be stored. /// /// Span where native values of the array should be stored. - /// /// - /// public Span GetNativeValuesDestination() => _span; /// @@ -140,34 +132,26 @@ public ReadOnlySpan GetNativeValuesSource(int length) /// /// Returns the native value representing the array. /// - /// /// - /// public byte* ToNativeValue() => (byte*)Unsafe.AsPointer(ref GetPinnableReference()); /// /// Sets the native value representing the array. /// /// The native value. - /// /// - /// public void FromNativeValue(byte* value) => _allocatedMemory = (IntPtr)value; /// /// Returns the managed array. /// - /// /// - /// public T*[]? ToManaged() => _managedArray; /// /// Frees native resources. /// - /// /// - /// public void FreeNative() { Marshal.FreeCoTaskMem(_allocatedMemory); diff --git a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/Utf16StringMarshaller.cs b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/Utf16StringMarshaller.cs index 04ada6d9d5132..22d317a9cb17d 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/Utf16StringMarshaller.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/Utf16StringMarshaller.cs @@ -31,34 +31,26 @@ public Utf16StringMarshaller(string? str) /// /// Returns the native value representing the string. /// - /// /// - /// public void* ToNativeValue() => _nativeValue; /// /// Sets the native value representing the string. /// /// The native value. - /// /// - /// public void FromNativeValue(void* value) => _nativeValue = value; /// /// Returns the managed string. /// - /// /// - /// public string? ToManaged() => Marshal.PtrToStringUni((IntPtr)_nativeValue); /// /// Frees native resources. /// - /// /// - /// public void FreeNative() { Marshal.FreeCoTaskMem((IntPtr)_nativeValue); diff --git a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/Utf8StringMarshaller.cs b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/Utf8StringMarshaller.cs index e60db5416dfa6..955e6b7b62f70 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/Utf8StringMarshaller.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Runtime/InteropServices/Marshalling/Utf8StringMarshaller.cs @@ -33,8 +33,8 @@ public Utf8StringMarshaller(string? str) /// /// The must not be movable - that is, it should not be /// on the managed heap or it should be pinned. - /// /// + /// public Utf8StringMarshaller(string? str, Span buffer) { _allocated = false; @@ -69,18 +69,14 @@ public Utf8StringMarshaller(string? str, Span buffer) /// /// Returns the native value representing the string. /// - /// /// - /// public byte* ToNativeValue() => _nativeValue; /// /// Sets the native value representing the string. /// /// The native value. - /// /// - /// public void FromNativeValue(byte* value) { _nativeValue = value; @@ -90,17 +86,13 @@ public void FromNativeValue(byte* value) /// /// Returns the managed string. /// - /// /// - /// public string? ToManaged() => Marshal.PtrToStringUTF8((IntPtr)_nativeValue); /// /// Frees native resources. /// - /// /// - /// public void FreeNative() { if (_allocated)