From 045b0917ba0292c507042854f27801e12a41adf5 Mon Sep 17 00:00:00 2001 From: Evan Hemsley <2342303+ehemsley@users.noreply.github.com> Date: Wed, 25 Mar 2020 14:19:40 -0700 Subject: [PATCH] fix reflection breaking on .net framework --- encompass-cs/UberEngine.cs | 80 +++++++++++++----------------------- encompass-cs/UberRenderer.cs | 26 ++++-------- 2 files changed, 35 insertions(+), 71 deletions(-) diff --git a/encompass-cs/UberEngine.cs b/encompass-cs/UberEngine.cs index 5d5378e..54adce6 100644 --- a/encompass-cs/UberEngine.cs +++ b/encompass-cs/UberEngine.cs @@ -39,60 +39,52 @@ namespace Encompass { foreach (var type in _componentTypes) { - CallGenericMethod(type, "ReadComponent", null); - CallGenericWrappedMethod(type, "ReadComponentsWrapper", null); - CallGenericMethod(type, "ReadEntity", null); - CallGenericWrappedMethod(type, "ReadEntitiesWrapper", null); - CallGenericMethod(type, "GetComponent", new object[] { Entity }); - CallGenericMethod(type, "HasComponent", 1, new object[] { Entity }); - CallGenericMethod(type, "SomeComponent", null); - CallGenericMethod(type, "DestroyWith", null); - CallGenericMethod(type, "DestroyAllWith", null); - CallGenericMethod(type, "RemoveComponent", new object[] { Entity }); + CallGenericWrappedMethod(type, "CallAllComponentMethods", null); } foreach (var type in _messageTypes) { - CallGenericMethod(type, "SendMessageIgnoringTimeDilation", new object[] { Activator.CreateInstance(type), 1 }); - CallGenericMethod(type, "SendMessage", 1, new object[] { Activator.CreateInstance(type) }); - CallGenericMethod(type, "SendMessage", 2, new object[] { Activator.CreateInstance(type), 1 }); - CallGenericMethod(type, "ReadMessage", null); + CallGenericWrappedMethod(type, "CallAllMessageMethods", null); - CallGenericWrappedMethod(type, "ReadMessagesWrapper", null); - CallGenericMethod(type, "SomeMessage", null); if (typeof(IHasEntity).IsAssignableFrom(type)) { - CallGenericMethod(type, "ReadMessagesWithEntity", new object[] { Entity }); - CallGenericMethod(type, "ReadMessageWithEntity", new object[] { Entity }); - CallGenericMethod(type, "SomeMessageWithEntity", new object[] { Entity }); + CallGenericWrappedMethod(type, "CallAllEntityMessageMethods", null); } } } - // we can't reflect invoke on Span returns right now... so we have non-return wrapper methods + // we can't reflect invoke on byref returns or Span returns right now... so we have non-return wrapper methods - protected void ReadComponentsWrapper() where TComponent : struct, IComponent + protected void CallAllComponentMethods() where TComponent : struct, IComponent { + ReadComponent(); ReadComponents(); - } - - protected void ReadMessagesWrapper() where TMessage : struct, IMessage - { - ReadMessages(); - } - - protected void ReadEntitiesWrapper() where TComponent : struct, IComponent - { + ReadEntity(); ReadEntities(); + GetComponent(Entity); + HasComponent(Entity); + SomeComponent(); + DestroyWith(); + DestroyAllWith(); + RemoveComponent(Entity); + AddComponent(Entity, default); } - // trying to use PrepareMethod because we can't reflect invoke methods that return a span... - private void CallGenericMethod(Type type, string methodName, object[] parameters) + protected void CallAllMessageMethods() where TMessage : struct, IMessage { - var readComponentMethod = typeof(Engine).GetMethod(methodName, BindingFlags.NonPublic | BindingFlags.Instance); - var genericReadComponentMethod = readComponentMethod.MakeGenericMethod(type); - genericReadComponentMethod.Invoke(this, parameters); - // RuntimeHelpers.PrepareMethod(genericReadComponentMethod.MethodHandle); + SendMessageIgnoringTimeDilation(default, 0.1); + SendMessage(default); + SendMessage(default, 0.1); + ReadMessage(); + ReadMessages(); + SomeMessage(); + } + + protected void CallAllEntityMessageMethods() where TMessage : struct, IMessage, IHasEntity + { + ReadMessagesWithEntity(Entity); + ReadMessageWithEntity(Entity); + SomeMessageWithEntity(Entity); } private void CallGenericWrappedMethod(Type type, string methodName, object[] parameters) @@ -101,21 +93,5 @@ namespace Encompass var genericReadComponentMethod = readComponentMethod.MakeGenericMethod(type); genericReadComponentMethod.Invoke(this, parameters); } - - private void CallGenericMethod(Type type, string methodName, Type[] types, object[] parameters) - { - var readComponentMethod = typeof(Engine).GetMethod(methodName, BindingFlags.NonPublic | BindingFlags.Instance, null, types, null); - var genericReadComponentMethod = readComponentMethod.MakeGenericMethod(type); - genericReadComponentMethod.Invoke(this, parameters); - // RuntimeHelpers.PrepareMethod(genericReadComponentMethod.MethodHandle); - } - - private void CallGenericMethod(Type type, string methodName, int argumentNum, object[] parameters) - { - var method = typeof(Engine).GetRuntimeMethods().Where(m => m.Name == methodName && m.GetParameters().Length == argumentNum).First(); - var genericMethod = method.MakeGenericMethod(type); - genericMethod.Invoke(this, parameters); - // RuntimeHelpers.PrepareMethod(genericMethod.MethodHandle); - } } } diff --git a/encompass-cs/UberRenderer.cs b/encompass-cs/UberRenderer.cs index 9d96e2c..a3ab60b 100644 --- a/encompass-cs/UberRenderer.cs +++ b/encompass-cs/UberRenderer.cs @@ -24,31 +24,19 @@ namespace Encompass { foreach (var type in _componentTypes) { - CallGenericWrappedMethod(type, "ReadEntitiesWrapper", null); - CallGenericMethod(type, "ReadEntity", null); - CallGenericWrappedMethod(type, "ReadComponentsWrapper", null); - CallGenericMethod(type, "ReadComponent", null); - CallGenericMethod(type, "GetComponent", new object[] { _entity }); - CallGenericMethod(type, "HasComponent", new object[] { _entity }); - CallGenericMethod(type, "SomeComponent", null); + CallGenericWrappedMethod(type, "CallAllComponentMethods", null); } } - protected void ReadEntitiesWrapper() where TComponent : struct, IComponent + protected void CallAllComponentMethods() where TComponent : struct, IComponent { + ReadEntity(); ReadEntities(); - } - - protected void ReadComponentsWrapper() where TComponent : struct, IComponent - { + ReadComponent(); ReadComponents(); - } - - private void CallGenericMethod(Type type, string methodName, object[] parameters) - { - var readComponentMethod = typeof(Renderer).GetMethod(methodName, BindingFlags.NonPublic | BindingFlags.Instance); - var genericReadComponentMethod = readComponentMethod.MakeGenericMethod(type); - genericReadComponentMethod.Invoke(this, parameters); + GetComponent(_entity); + HasComponent(_entity); + SomeComponent(); } private void CallGenericWrappedMethod(Type type, string methodName, object[] parameters) -- 2.25.1