summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/SMAPI/Framework/ModLoading/RewriteFacades/AccessToolsMethods.cs15
1 files changed, 12 insertions, 3 deletions
diff --git a/src/SMAPI/Framework/ModLoading/RewriteFacades/AccessToolsMethods.cs b/src/SMAPI/Framework/ModLoading/RewriteFacades/AccessToolsMethods.cs
index ea35fec9..08857129 100644
--- a/src/SMAPI/Framework/ModLoading/RewriteFacades/AccessToolsMethods.cs
+++ b/src/SMAPI/Framework/ModLoading/RewriteFacades/AccessToolsMethods.cs
@@ -16,17 +16,26 @@ namespace StardewModdingAPI.Framework.ModLoading.RewriteFacades
*********/
public static ConstructorInfo DeclaredConstructor(Type type, Type[] parameters = null)
{
- return AccessTools.DeclaredConstructor(type, parameters, searchForStatic: true);
+ // Harmony 1.x matched both static and instance constructors
+ return
+ AccessTools.DeclaredConstructor(type, parameters, searchForStatic: false)
+ ?? AccessTools.DeclaredConstructor(type, parameters, searchForStatic: true);
}
public static ConstructorInfo Constructor(Type type, Type[] parameters = null)
{
- return AccessTools.Constructor(type, parameters, searchForStatic: true);
+ // Harmony 1.x matched both static and instance constructors
+ return
+ AccessTools.Constructor(type, parameters, searchForStatic: false)
+ ?? AccessTools.Constructor(type, parameters, searchForStatic: true);
}
public static List<ConstructorInfo> GetDeclaredConstructors(Type type)
{
- return AccessTools.GetDeclaredConstructors(type, searchForStatic: true);
+ // Harmony 1.x matched both static and instance constructors
+ return
+ AccessTools.GetDeclaredConstructors(type, searchForStatic: false)
+ ?? AccessTools.GetDeclaredConstructors(type, searchForStatic: true);
}
}
}