mirror of
https://github.com/Thealexbarney/LibHac.git
synced 2024-11-14 10:49:41 +01:00
Remove all uses of InlineIL.Fody
This commit is contained in:
parent
72b9a1e5d0
commit
c7dcbab6ff
8 changed files with 46 additions and 75 deletions
|
@ -1,7 +1,6 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Runtime.CompilerServices;
|
using System.Runtime.CompilerServices;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using InlineIL;
|
|
||||||
using LibHac.Diag;
|
using LibHac.Diag;
|
||||||
|
|
||||||
#pragma warning disable LH0001
|
#pragma warning disable LH0001
|
||||||
|
@ -13,17 +12,13 @@ public static class SharedRefExtensions
|
||||||
// ReSharper disable once EntityNameCapturedOnly.Global
|
// ReSharper disable once EntityNameCapturedOnly.Global
|
||||||
public static ref SharedRef<T> Ref<T>(this in SharedRef<T> value) where T : class, IDisposable
|
public static ref SharedRef<T> Ref<T>(this in SharedRef<T> value) where T : class, IDisposable
|
||||||
{
|
{
|
||||||
IL.Emit.Ldarg(nameof(value));
|
return ref Unsafe.AsRef(in value);
|
||||||
IL.Emit.Ret();
|
|
||||||
throw IL.Unreachable();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ReSharper disable once EntityNameCapturedOnly.Global
|
// ReSharper disable once EntityNameCapturedOnly.Global
|
||||||
public static ref WeakRef<T> Ref<T>(this in WeakRef<T> value) where T : class, IDisposable
|
public static ref WeakRef<T> Ref<T>(this in WeakRef<T> value) where T : class, IDisposable
|
||||||
{
|
{
|
||||||
IL.Emit.Ldarg(nameof(value));
|
return ref Unsafe.AsRef(in value);
|
||||||
IL.Emit.Ret();
|
|
||||||
throw IL.Unreachable();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
using System;
|
using System;
|
||||||
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using System.Runtime.CompilerServices;
|
using System.Runtime.CompilerServices;
|
||||||
using InlineIL;
|
|
||||||
using static InlineIL.IL.Emit;
|
|
||||||
|
|
||||||
namespace LibHac.Common;
|
namespace LibHac.Common;
|
||||||
|
|
||||||
|
@ -10,9 +9,7 @@ public static class UniqueRefExtensions
|
||||||
// ReSharper disable once EntityNameCapturedOnly.Global
|
// ReSharper disable once EntityNameCapturedOnly.Global
|
||||||
public static ref UniqueRef<T> Ref<T>(this in UniqueRef<T> value) where T : class, IDisposable
|
public static ref UniqueRef<T> Ref<T>(this in UniqueRef<T> value) where T : class, IDisposable
|
||||||
{
|
{
|
||||||
Ldarg(nameof(value));
|
return ref Unsafe.AsRef(in value);
|
||||||
Ret();
|
|
||||||
throw IL.Unreachable();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,16 +18,8 @@ public struct UniqueRef<T> : IDisposable where T : class, IDisposable
|
||||||
{
|
{
|
||||||
private T _value;
|
private T _value;
|
||||||
|
|
||||||
public readonly ref T Get
|
[UnscopedRef]
|
||||||
{
|
public readonly ref readonly T Get => ref _value;
|
||||||
get
|
|
||||||
{
|
|
||||||
Ldarg_0();
|
|
||||||
Ldflda(new FieldRef(typeof(UniqueRef<T>), nameof(_value)));
|
|
||||||
Ret();
|
|
||||||
throw IL.Unreachable();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public readonly bool HasValue => Get is not null;
|
public readonly bool HasValue => Get is not null;
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,6 @@ using System.Diagnostics;
|
||||||
using LibHac.Common;
|
using LibHac.Common;
|
||||||
using LibHac.Diag;
|
using LibHac.Diag;
|
||||||
using LibHac.Util;
|
using LibHac.Util;
|
||||||
using static InlineIL.IL.Emit;
|
|
||||||
using static LibHac.Fs.StringTraits;
|
using static LibHac.Fs.StringTraits;
|
||||||
|
|
||||||
// ReSharper disable once CheckNamespace
|
// ReSharper disable once CheckNamespace
|
||||||
|
@ -45,30 +44,40 @@ public static class PathExtensions
|
||||||
/// of the input <see langword="readonly"/> reference.</para></remarks>
|
/// of the input <see langword="readonly"/> reference.</para></remarks>
|
||||||
/// <param name="path">The read-only reference to reinterpret.</param>
|
/// <param name="path">The read-only reference to reinterpret.</param>
|
||||||
/// <returns>A reference to the given <see cref="Path"/>.</returns>
|
/// <returns>A reference to the given <see cref="Path"/>.</returns>
|
||||||
// ReSharper disable once EntityNameCapturedOnly.Global
|
#pragma warning disable LH0001 // DoNotCopyValue
|
||||||
public static ref Path Ref(this scoped in Path path)
|
#pragma warning disable CS8500 // This takes the address of, gets the size of, or declares a pointer to a managed type
|
||||||
|
public static unsafe ref Path Ref(this scoped in Path path)
|
||||||
{
|
{
|
||||||
Ldarg(nameof(path));
|
fixed (Path* p = &path)
|
||||||
Ret();
|
{
|
||||||
throw InlineIL.IL.Unreachable();
|
return ref *p;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ref Path GetNullRef()
|
public static unsafe ref Path GetNullRef()
|
||||||
{
|
{
|
||||||
Ldc_I4_0();
|
// Todo: Combine into one statement once ReSharper stops detecting that as an error
|
||||||
Conv_U();
|
var p = (Path*)null;
|
||||||
Ret();
|
return ref *p;
|
||||||
throw InlineIL.IL.Unreachable();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static bool IsNullRef(in Path path)
|
public static unsafe bool IsNullRef(in Path path)
|
||||||
{
|
{
|
||||||
Ldarg_0();
|
fixed (Path* p = &path)
|
||||||
Ldc_I4_0();
|
{
|
||||||
Conv_U();
|
return p == null;
|
||||||
Ceq();
|
}
|
||||||
return InlineIL.IL.Return<bool>();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static unsafe bool IsNullRef(in int path)
|
||||||
|
{
|
||||||
|
fixed (int* p = &path)
|
||||||
|
{
|
||||||
|
return p == null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#pragma warning restore CS8500 // This takes the address of, gets the size of, or declares a pointer to a managed type
|
||||||
|
#pragma warning restore LH0001 // DoNotCopyValue
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -1214,7 +1223,7 @@ public static class PathFunctions
|
||||||
/// <returns><see cref="Result.Success"/>: The operation was successful.<br/>
|
/// <returns><see cref="Result.Success"/>: The operation was successful.<br/>
|
||||||
/// <see cref="ResultFs.InvalidArgument"/>: <paramref name="pathBuffer"/> was too small to contain the built path.</returns>
|
/// <see cref="ResultFs.InvalidArgument"/>: <paramref name="pathBuffer"/> was too small to contain the built path.</returns>
|
||||||
internal static Result SetUpFixedPathDoubleEntry(scoped ref Path path, Span<byte> pathBuffer,
|
internal static Result SetUpFixedPathDoubleEntry(scoped ref Path path, Span<byte> pathBuffer,
|
||||||
scoped ReadOnlySpan<byte> entryName1, scoped ReadOnlySpan<byte> entryName2)
|
scoped ReadOnlySpan<byte> entryName1, scoped ReadOnlySpan<byte> entryName2)
|
||||||
{
|
{
|
||||||
var sb = new U8StringBuilder(pathBuffer);
|
var sb = new U8StringBuilder(pathBuffer);
|
||||||
sb.Append((byte)'/').Append(entryName1)
|
sb.Append((byte)'/').Append(entryName1)
|
||||||
|
|
|
@ -590,7 +590,7 @@ namespace LibHac.Fs.Shim
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Result ReadSaveDataIteratorSaveDataInfo(this FileSystemClientImpl fs, out long readCount,
|
public static Result ReadSaveDataIteratorSaveDataInfo(this FileSystemClientImpl fs, out long readCount,
|
||||||
Span<SaveDataInfo> buffer, ref SaveDataIterator iterator)
|
Span<SaveDataInfo> buffer, SaveDataIterator iterator)
|
||||||
{
|
{
|
||||||
Result res = iterator.ReadSaveDataInfo(out readCount, buffer);
|
Result res = iterator.ReadSaveDataInfo(out readCount, buffer);
|
||||||
if (res.IsFailure()) return res.Miss();
|
if (res.IsFailure()) return res.Miss();
|
||||||
|
|
|
@ -367,7 +367,7 @@ namespace LibHac.Fs.Shim
|
||||||
Unsafe.SkipInit(out SaveDataInfo info);
|
Unsafe.SkipInit(out SaveDataInfo info);
|
||||||
|
|
||||||
res = fs.Impl.ReadSaveDataIteratorSaveDataInfo(out long count, SpanHelpers.AsSpan(ref info),
|
res = fs.Impl.ReadSaveDataIteratorSaveDataInfo(out long count, SpanHelpers.AsSpan(ref info),
|
||||||
ref iterator.Get);
|
iterator.Get);
|
||||||
|
|
||||||
fs.Impl.LogResultErrorMessage(res);
|
fs.Impl.LogResultErrorMessage(res);
|
||||||
if (res.IsFailure()) return res.Miss();
|
if (res.IsFailure()) return res.Miss();
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Buffers.Binary;
|
using System.Buffers.Binary;
|
||||||
|
using System.Diagnostics.CodeAnalysis;
|
||||||
using System.Runtime.CompilerServices;
|
using System.Runtime.CompilerServices;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using LibHac.Common;
|
using LibHac.Common;
|
||||||
|
@ -887,15 +888,8 @@ public partial class BucketTree : IDisposable
|
||||||
/// <remarks><para>This property allows using a <see langword="using"/> expression with <see cref="Visitor"/>s
|
/// <remarks><para>This property allows using a <see langword="using"/> expression with <see cref="Visitor"/>s
|
||||||
/// while still being able to pass it by reference.</para></remarks>
|
/// while still being able to pass it by reference.</para></remarks>
|
||||||
/// <returns>A reference to this <see cref="Visitor"/>.</returns>
|
/// <returns>A reference to this <see cref="Visitor"/>.</returns>
|
||||||
public ref Visitor Ref
|
[UnscopedRef]
|
||||||
{
|
public ref Visitor Ref => ref this;
|
||||||
get
|
|
||||||
{
|
|
||||||
InlineIL.IL.Emit.Ldarg_0();
|
|
||||||
InlineIL.IL.Emit.Ret();
|
|
||||||
throw InlineIL.IL.Unreachable();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
internal Result Initialize(BucketTree tree, in Offsets offsets)
|
internal Result Initialize(BucketTree tree, in Offsets offsets)
|
||||||
{
|
{
|
||||||
|
|
|
@ -25,9 +25,6 @@
|
||||||
<PathMap Condition=" '$(BuildType)' == 'Release' and '$(HasGitDir)' == 'false' ">$(MSBuildProjectDirectory)=C:/LibHac/</PathMap>
|
<PathMap Condition=" '$(BuildType)' == 'Release' and '$(HasGitDir)' == 'false' ">$(MSBuildProjectDirectory)=C:/LibHac/</PathMap>
|
||||||
<DeterministicSourcePaths Condition=" '$(BuildType)' == 'Release' and '$(HasGitDir)' == 'true' ">true</DeterministicSourcePaths>
|
<DeterministicSourcePaths Condition=" '$(BuildType)' == 'Release' and '$(HasGitDir)' == 'true' ">true</DeterministicSourcePaths>
|
||||||
|
|
||||||
<!-- Workaround https://github.com/jbevain/cecil/issues/610 by including the pdb in the main .nupkg -->
|
|
||||||
<AllowedOutputExtensionsInPackageBuildOutputFolder>$(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb</AllowedOutputExtensionsInPackageBuildOutputFolder>
|
|
||||||
|
|
||||||
<NoWarn>$(NoWarn);1591</NoWarn>
|
<NoWarn>$(NoWarn);1591</NoWarn>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
|
@ -41,8 +38,6 @@
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<PackageReference Include="Fody" Version="6.6.4" PrivateAssets="All" />
|
|
||||||
<PackageReference Include="InlineIL.Fody" Version="1.7.2" PrivateAssets="All" />
|
|
||||||
<PackageReference Include="Microsoft.SourceLink.GitHub" Version="1.1.1" PrivateAssets="All" />
|
<PackageReference Include="Microsoft.SourceLink.GitHub" Version="1.1.1" PrivateAssets="All" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
@ -52,13 +47,4 @@
|
||||||
</AssemblyAttribute>
|
</AssemblyAttribute>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
<!-- Configuration for Fody -->
|
|
||||||
<PropertyGroup>
|
|
||||||
<WeaverConfiguration>
|
|
||||||
<Weavers>
|
|
||||||
<InlineIL />
|
|
||||||
</Weavers>
|
|
||||||
</WeaverConfiguration>
|
|
||||||
</PropertyGroup>
|
|
||||||
|
|
||||||
</Project>
|
</Project>
|
|
@ -2,7 +2,6 @@
|
||||||
using System.Runtime.CompilerServices;
|
using System.Runtime.CompilerServices;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using LibHac.Common;
|
using LibHac.Common;
|
||||||
using static InlineIL.IL.Emit;
|
|
||||||
|
|
||||||
namespace LibHac.Os;
|
namespace LibHac.Os;
|
||||||
|
|
||||||
|
@ -26,20 +25,19 @@ public static class UniqueLock
|
||||||
return new UniqueLock<TMutex>(lockable);
|
return new UniqueLock<TMutex>(lockable);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ReSharper disable once EntityNameCapturedOnly.Global
|
#pragma warning disable CS8500 // This takes the address of, gets the size of, or declares a pointer to a managed type
|
||||||
public static ref UniqueLockRef<T> Ref<T>(this in UniqueLockRef<T> value) where T : struct, ILockable
|
public static unsafe ref UniqueLockRef<T> Ref<T>(this in UniqueLockRef<T> value) where T : struct, ILockable
|
||||||
{
|
{
|
||||||
Ldarg(nameof(value));
|
fixed (UniqueLockRef<T>* p = &value)
|
||||||
Ret();
|
{
|
||||||
throw InlineIL.IL.Unreachable();
|
return ref *p;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
#pragma warning restore CS8500 // This takes the address of, gets the size of, or declares a pointer to a managed type
|
||||||
|
|
||||||
// ReSharper disable once EntityNameCapturedOnly.Global
|
|
||||||
public static ref UniqueLock<T> Ref<T>(this in UniqueLock<T> value) where T : class, ILockable
|
public static ref UniqueLock<T> Ref<T>(this in UniqueLock<T> value) where T : class, ILockable
|
||||||
{
|
{
|
||||||
Ldarg(nameof(value));
|
return ref Unsafe.AsRef(in value);
|
||||||
Ret();
|
|
||||||
throw InlineIL.IL.Unreachable();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue