Plugins: Refactor existing interfaces into ILoadPipeline
This commit is contained in:
@@ -1,74 +0,0 @@
|
|||||||
/*
|
|
||||||
Copyright 2020 Katy Coe - http://www.djkaty.com - https://github.com/djkaty
|
|
||||||
|
|
||||||
All rights reserved.
|
|
||||||
*/
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.IO;
|
|
||||||
using NoisyCowStudios.Bin2Object;
|
|
||||||
using Il2CppInspector.Reflection;
|
|
||||||
|
|
||||||
// Hooks we provide to plugins which can choose whether or not to provide implementations
|
|
||||||
namespace Il2CppInspector.PluginAPI.V100
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Executes when the plugin's options are updated by the user
|
|
||||||
/// Not called on first load (with the default, possibly incomplete options provided by the plugin author)
|
|
||||||
/// Do not perform any long-running operations here
|
|
||||||
/// Implementation is optional - the default is to do nothing
|
|
||||||
/// </summary>
|
|
||||||
public partial interface IPlugin
|
|
||||||
{
|
|
||||||
void OptionsChanged(PluginOptionsChangedEventInfo e) { }
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Process global-metadata.dat when it is first opened as a sequence of bytes
|
|
||||||
/// Seek cursor will be at the start of the file
|
|
||||||
/// </summary>
|
|
||||||
public interface IPreProcessMetadata
|
|
||||||
{
|
|
||||||
void PreProcessMetadata(BinaryObjectStream stream, PluginPreProcessMetadataEventInfo data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Process global-metadata.dat after it has been loaded into a Metadata object
|
|
||||||
/// </summary>
|
|
||||||
public interface IPostProcessMetadata
|
|
||||||
{
|
|
||||||
void PostProcessMetadata(Metadata metadata, PluginPostProcessMetadataEventInfo data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Fetch all of the .NET identifier strings
|
|
||||||
/// </summary>
|
|
||||||
public interface IGetStrings
|
|
||||||
{
|
|
||||||
void GetStrings(Metadata metadata, PluginGetStringsEventInfo data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Fetch all of the (constant) string literals
|
|
||||||
/// </summary>
|
|
||||||
public interface IGetStringLiterals
|
|
||||||
{
|
|
||||||
void GetStringLiterals(Metadata metadata, PluginGetStringLiteralsEventInfo data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Post-process the entire IL2CPP application package after the metadata and binary have been loaded and merged
|
|
||||||
/// </summary>
|
|
||||||
public interface IPostProcessPackage
|
|
||||||
{
|
|
||||||
void PostProcessPackage(Il2CppInspector package, PluginPostProcessPackageEventInfo data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Post-process the .NET type model to make changes after it has been fully created
|
|
||||||
/// </summary>
|
|
||||||
public interface IPostProcessTypeModel
|
|
||||||
{
|
|
||||||
void PostProcessTypeModel(TypeModel model, PluginPostProcessTypeModelEventInfo data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
50
Il2CppInspector.Common/Plugins/API/V100/ILoadPipeline.cs
Normal file
50
Il2CppInspector.Common/Plugins/API/V100/ILoadPipeline.cs
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
/*
|
||||||
|
Copyright 2020 Katy Coe - http://www.djkaty.com - https://github.com/djkaty
|
||||||
|
|
||||||
|
All rights reserved.
|
||||||
|
*/
|
||||||
|
|
||||||
|
using NoisyCowStudios.Bin2Object;
|
||||||
|
using Il2CppInspector.Reflection;
|
||||||
|
|
||||||
|
namespace Il2CppInspector.PluginAPI.V100
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Plugins which implement ILoadPipeline perform additional processing on IL2CPP workloads
|
||||||
|
/// as they are analyzed and translated into an internal model
|
||||||
|
/// Calls are performed in the order listed below
|
||||||
|
/// </summary>
|
||||||
|
public interface ILoadPipeline
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Process global-metadata.dat when it is first opened as a sequence of bytes
|
||||||
|
/// Seek cursor will be at the start of the file
|
||||||
|
/// </summary>
|
||||||
|
void PreProcessMetadata(BinaryObjectStream stream, PluginPreProcessMetadataEventInfo data) { }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Fetch all of the .NET identifier strings
|
||||||
|
/// </summary>
|
||||||
|
void GetStrings(Metadata metadata, PluginGetStringsEventInfo data) { }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Fetch all of the (constant) string literals
|
||||||
|
/// </summary>
|
||||||
|
void GetStringLiterals(Metadata metadata, PluginGetStringLiteralsEventInfo data) { }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Process global-metadata.dat after it has been loaded into a Metadata object
|
||||||
|
/// </summary>
|
||||||
|
void PostProcessMetadata(Metadata metadata, PluginPostProcessMetadataEventInfo data) { }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Post-process the entire IL2CPP application package after the metadata and binary have been loaded and merged
|
||||||
|
/// </summary>
|
||||||
|
void PostProcessPackage(Il2CppInspector package, PluginPostProcessPackageEventInfo data) { }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Post-process the .NET type model to make changes after it has been fully created
|
||||||
|
/// </summary>
|
||||||
|
void PostProcessTypeModel(TypeModel model, PluginPostProcessTypeModelEventInfo data) { }
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -40,8 +40,16 @@ namespace Il2CppInspector.PluginAPI.V100
|
|||||||
public string Description { get; }
|
public string Description { get; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Plugin options
|
/// Plugin options with their current values (or default values on startup where applicable)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public List<IPluginOption> Options { get; }
|
public List<IPluginOption> Options { get; }
|
||||||
}
|
|
||||||
|
/// <summary>
|
||||||
|
/// Executes when the plugin's options are updated by the user
|
||||||
|
/// Not called on first load (with the default, possibly incomplete options provided by the plugin author)
|
||||||
|
/// Do not perform any long-running operations here
|
||||||
|
/// Implementation is optional. The default is to do nothing
|
||||||
|
/// </summary>
|
||||||
|
void OptionsChanged(PluginOptionsChangedEventInfo e) { }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,11 +4,11 @@
|
|||||||
All rights reserved.
|
All rights reserved.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// This is the ONLY line to update when the API version changes
|
|
||||||
using System.IO;
|
|
||||||
using NoisyCowStudios.Bin2Object;
|
|
||||||
using Il2CppInspector.PluginAPI.V100;
|
|
||||||
using Il2CppInspector.Reflection;
|
using Il2CppInspector.Reflection;
|
||||||
|
using NoisyCowStudios.Bin2Object;
|
||||||
|
|
||||||
|
// This is the ONLY line to update when the API version changes
|
||||||
|
using Il2CppInspector.PluginAPI.V100;
|
||||||
|
|
||||||
namespace Il2CppInspector
|
namespace Il2CppInspector
|
||||||
{
|
{
|
||||||
@@ -17,25 +17,25 @@ namespace Il2CppInspector
|
|||||||
internal static class PluginHooks
|
internal static class PluginHooks
|
||||||
{
|
{
|
||||||
public static PluginPreProcessMetadataEventInfo PreProcessMetadata(BinaryObjectStream stream)
|
public static PluginPreProcessMetadataEventInfo PreProcessMetadata(BinaryObjectStream stream)
|
||||||
=> PluginManager.Try<IPreProcessMetadata, PluginPreProcessMetadataEventInfo>((p, e) => {
|
=> PluginManager.Try<ILoadPipeline, PluginPreProcessMetadataEventInfo>((p, e) => {
|
||||||
stream.Position = 0;
|
stream.Position = 0;
|
||||||
p.PreProcessMetadata(stream, e);
|
p.PreProcessMetadata(stream, e);
|
||||||
});
|
});
|
||||||
|
|
||||||
public static PluginPostProcessMetadataEventInfo PostProcessMetadata(Metadata metadata)
|
public static PluginPostProcessMetadataEventInfo PostProcessMetadata(Metadata metadata)
|
||||||
=> PluginManager.Try<IPostProcessMetadata, PluginPostProcessMetadataEventInfo>((p, e) => p.PostProcessMetadata(metadata, e));
|
=> PluginManager.Try<ILoadPipeline, PluginPostProcessMetadataEventInfo>((p, e) => p.PostProcessMetadata(metadata, e));
|
||||||
|
|
||||||
public static PluginGetStringsEventInfo GetStrings(Metadata metadata)
|
public static PluginGetStringsEventInfo GetStrings(Metadata metadata)
|
||||||
=> PluginManager.Try<IGetStrings, PluginGetStringsEventInfo>((p, e) => p.GetStrings(metadata, e));
|
=> PluginManager.Try<ILoadPipeline, PluginGetStringsEventInfo>((p, e) => p.GetStrings(metadata, e));
|
||||||
|
|
||||||
public static PluginGetStringLiteralsEventInfo GetStringLiterals(Metadata metadata)
|
public static PluginGetStringLiteralsEventInfo GetStringLiterals(Metadata metadata)
|
||||||
=> PluginManager.Try<IGetStringLiterals, PluginGetStringLiteralsEventInfo>((p, e) => p.GetStringLiterals(metadata, e));
|
=> PluginManager.Try<ILoadPipeline, PluginGetStringLiteralsEventInfo>((p, e) => p.GetStringLiterals(metadata, e));
|
||||||
|
|
||||||
public static PluginPostProcessPackageEventInfo PostProcessPackage(Il2CppInspector package)
|
public static PluginPostProcessPackageEventInfo PostProcessPackage(Il2CppInspector package)
|
||||||
=> PluginManager.Try<IPostProcessPackage, PluginPostProcessPackageEventInfo>((p, e) => p.PostProcessPackage(package, e));
|
=> PluginManager.Try<ILoadPipeline, PluginPostProcessPackageEventInfo>((p, e) => p.PostProcessPackage(package, e));
|
||||||
|
|
||||||
public static PluginPostProcessTypeModelEventInfo PostProcessTypeModel(TypeModel typeModel)
|
public static PluginPostProcessTypeModelEventInfo PostProcessTypeModel(TypeModel typeModel)
|
||||||
=> PluginManager.Try<IPostProcessTypeModel, PluginPostProcessTypeModelEventInfo>((p, e) => p.PostProcessTypeModel(typeModel, e));
|
=> PluginManager.Try<ILoadPipeline, PluginPostProcessTypeModelEventInfo>((p, e) => p.PostProcessTypeModel(typeModel, e));
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user