Comments (5)
I would like to know in which environment you are executing Harmony. On mono, which is the main focus of this lib, a DynamicMethod is static but can emulate an instance method by choosing the correct attributes.
In case you are executing this on Core you might want to test again with the lastest commits. I just accepted a pull request that deals with that environment.
from harmony.
I'm running this code on Win10, using .NET 4.6.2 and I'm actually working with those changes you've merged earlier, including two little changes of my own to allow patching of static method under .NET 4.6.2, as detailed here.
from harmony.
From what I understand, the only required criterion to emulate an instance method properly is using the first argument (technically 0th argument) passed as this
, very similar to how extension methods work. I haven't seen anything else inside the method body that would need changes. And also from my understanding, we're just caring about the jump target body, not its attributes.
I'd personally like to know if always setting it to Public | Static
causes any side effects. Preparing a HarmonyTests test case right now for future reference.
from harmony.
I've just tested a build after the latest fix has been merged and the above example is now working for me :)
@pardeike I guess you can close this issue now.
from harmony.
Excellent!
from harmony.
Related Issues (20)
- Add strongname to make all projects can use this library HOT 2
- Seemingly random NOP invalid IL errors HOT 4
- Correct way to patch TWindow GetWindow<TWindow>() HOT 1
- Release a new prerelease for the updated Mono.Cecil
- Error in exported Godot Engine build when attempting to patch method HOT 5
- Incorrect code generation for exception block when patching `System.Net.WebClient::DownloadFile(System.Uri address, System.String fileName)` HOT 2
- Problem patching specific method with latest pre-release HOT 2
- Harmony CANNOT be used in Godot!!!! HOT 2
- Any restriction to hook .Net service? HOT 9
- Getting an instance from the TargetMethod patch HOT 1
- Using GeneratedRegex causes failed compile due to ReadOnlySpan HOT 2
- A crash after hook:The object's current state invalidates the operation HOT 2
- Harmony fails to patch method and throws exception in exported Godot build HOT 13
- NuGet Package reference assembly conflict HOT 8
- ModuleInitializerAttribute HOT 1
- RtDynamicMethod get MetadataToken throws InvalidOperationException HOT 2
- Patch on .net 7&8 throw TypeLoadException while debugging HOT 17
- Harmony 3.0: Utility Epic
- Investigate Testing the NuGet Package Directly HOT 3
- Add a Release Pipeline
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from harmony.