CelesteAnalyzer 1.0.2
See the version list below for details.
dotnet add package CelesteAnalyzer --version 1.0.2
NuGet\Install-Package CelesteAnalyzer -Version 1.0.2
<PackageReference Include="CelesteAnalyzer" Version="1.0.2" />
paket add CelesteAnalyzer --version 1.0.2
#r "nuget: CelesteAnalyzer, 1.0.2"
// Install CelesteAnalyzer as a Cake Addin #addin nuget:?package=CelesteAnalyzer&version=1.0.2 // Install CelesteAnalyzer as a Cake Tool #tool nuget:?package=CelesteAnalyzer&version=1.0.2
CelesteAnalyzer
A Roslyn analyzer which helps you avoid common mistakes made when developing Celeste mods.
Features
CL0001: Lambda passed to ILCursor.EmitDelegate
Passing lambdas to ILCursor.EmitDelegate
, like this:
cursor.EmitDelegate((int f) => f * 2);
Emits inefficient IL code similar to this:
ldc.i4 1
ldc.i4 38750844
call T MonoMod.Utils.DynamicReferenceManager::GetValueTUnsafe<System.Delegate>(System.Int32,System.Int32)
call TResult MonoMod.Cil.FastDelegateInvokers::InvokeTypeVal1<System.Int32,System.Int32>(T0,MonoMod.Cil.FastDelegateInvokers/TypeVal1`2<TResult,T0>)
This analyzer will warn you about this, and recommend to switch to a static method reference (though there's currently no code fixer for this):
cursor.EmitDelegate(Manipulator);
// somewhere in your class
private static int Manipulator(int f) => f * 2;
This translates to a simple call
instruction
CL0002: Instance method passed to EmitDelegate
Avoid passing instance methods to ILCursor.EmitDelegate
, as it can result in capturing an instance of your class in unexpected ways.
The analyzer will warn about this.
CL0003: Orig not called in hook
Warns about not calling the orig
method received as the 1st parameter to a On. hook in any code path, as this breaks mod compatibility.
CL0004: Hooks should be static
Warns about non-static methods used as targets for On
hooks or manipulators for IL
hooks.
Provides a code fixer to make them static.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.