Bladeren bron

暂时移除HybridCLR

guodong 3 jaren geleden
bovenliggende
commit
881e8bcad7
84 gewijzigde bestanden met toevoegingen van 65 en 4315 verwijderingen
  1. 45 0
      GameClient/Assets/Editor/BuildEditor/BuildHotfixEditor.cs
  2. 1 1
      GameClient/Assets/Editor/BuildEditor/BuildHotfixEditor.cs.meta
  3. 0 8
      GameClient/Assets/Editor/HybridCLR.meta
  4. 0 124
      GameClient/Assets/Editor/HybridCLR/AssetBundleBuildHelper.cs
  5. 0 11
      GameClient/Assets/Editor/HybridCLR/AssetBundleBuildHelper.cs.meta
  6. 0 95
      GameClient/Assets/Editor/HybridCLR/BuildConfig.cs
  7. 0 11
      GameClient/Assets/Editor/HybridCLR/BuildConfig.cs.meta
  8. 0 52
      GameClient/Assets/Editor/HybridCLR/BuildConfig_Custom.cs
  9. 0 11
      GameClient/Assets/Editor/HybridCLR/BuildConfig_Custom.cs.meta
  10. 0 148
      GameClient/Assets/Editor/HybridCLR/BuildPlayerHelper.cs
  11. 0 175
      GameClient/Assets/Editor/HybridCLR/BuildProcessor_2019.cs
  12. 0 11
      GameClient/Assets/Editor/HybridCLR/BuildProcessor_2019.cs.meta
  13. 0 165
      GameClient/Assets/Editor/HybridCLR/BuildProcessor_2020_1_OR_NEWER.cs
  14. 0 11
      GameClient/Assets/Editor/HybridCLR/BuildProcessor_2020_1_OR_NEWER.cs.meta
  15. 0 65
      GameClient/Assets/Editor/HybridCLR/CompileDllHelper.cs
  16. 0 11
      GameClient/Assets/Editor/HybridCLR/CompileDllHelper.cs.meta
  17. 0 8
      GameClient/Assets/Editor/HybridCLR/Generators.meta
  18. 0 13
      GameClient/Assets/Editor/HybridCLR/Generators/ConstStrings.cs
  19. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/ConstStrings.cs.meta
  20. 0 40
      GameClient/Assets/Editor/HybridCLR/Generators/FileRegionReplace.cs
  21. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/FileRegionReplace.cs.meta
  22. 0 70
      GameClient/Assets/Editor/HybridCLR/Generators/GeneratorConfig.cs
  23. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/GeneratorConfig.cs.meta
  24. 0 8
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge.meta
  25. 0 28
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/IPlatformAdaptor.cs
  26. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/IPlatformAdaptor.cs.meta
  27. 0 343
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/MethodBridgeGenerator.cs
  28. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/MethodBridgeGenerator.cs.meta
  29. 0 156
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/MethodBridgeSig.cs
  30. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/MethodBridgeSig.cs.meta
  31. 0 44
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ParamInfo.cs
  32. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ParamInfo.cs.meta
  33. 0 38
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ParamOrReturnType.cs
  34. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ParamOrReturnType.cs.meta
  35. 0 9
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformABI.cs
  36. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformABI.cs.meta
  37. 0 160
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptorBase.cs
  38. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptorBase.cs.meta
  39. 0 208
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Arm64.cs
  40. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Arm64.cs.meta
  41. 0 96
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Universal32.cs
  42. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Universal32.cs.meta
  43. 0 189
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Universal64.cs
  44. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Universal64.cs.meta
  45. 0 19
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/SignatureProviderAttribute.cs
  46. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/SignatureProviderAttribute.cs.meta
  47. 0 132
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/TypeInfo.cs
  48. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/TypeInfo.cs.meta
  49. 0 148
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ValueTypeSizeAligmentCalculator.cs
  50. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ValueTypeSizeAligmentCalculator.cs.meta
  51. 0 38
      GameClient/Assets/Editor/HybridCLR/Generators/TemplateUtil.cs
  52. 0 11
      GameClient/Assets/Editor/HybridCLR/Generators/TemplateUtil.cs.meta
  53. 0 8
      GameClient/Assets/Editor/HybridCLR/Generators/Templates.meta
  54. 0 22
      GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Arm64.cpp
  55. 0 27
      GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Arm64.cpp.meta
  56. 0 22
      GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Universal32.cpp
  57. 0 27
      GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Universal32.cpp.meta
  58. 0 22
      GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Universal64.cpp
  59. 0 27
      GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Universal64.cpp.meta
  60. 0 119
      GameClient/Assets/Editor/HybridCLR/MethodBridgeHelper.cs
  61. 0 11
      GameClient/Assets/Editor/HybridCLR/MethodBridgeHelper.cs.meta
  62. 0 8
      GameClient/Assets/Editor/HybridCLR/UnityBinFileReader.meta
  63. 0 107
      GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinFile.cs
  64. 0 11
      GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinFile.cs.meta
  65. 0 397
      GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinFileDefines.cs
  66. 0 11
      GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinFileDefines.cs.meta
  67. 0 78
      GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinUtils.cs
  68. 0 11
      GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinUtils.cs.meta
  69. 0 8
      GameClient/Assets/Editor/HybridCLRExtension.meta
  70. 0 45
      GameClient/Assets/Editor/HybridCLRExtension/DllHelper.cs
  71. 0 11
      GameClient/Assets/Editor/HybridCLRExtension/DllHelper.cs.meta
  72. 0 3
      GameClient/Assets/Editor/Xasset/Builds/BuildTask.cs
  73. 3 1
      GameClient/Assets/Game/HotUpdate/Game.HotUpdate.asmdef
  74. 0 47
      GameClient/Assets/Game/HotUpdate/HotUpdateEntry.cs
  75. 13 24
      GameClient/Assets/Game/Launcher/HotUpdateProxy/HotUpdateCodeLoader.cs
  76. 0 22
      GameClient/HybridCLRData/README.md
  77. 0 88
      GameClient/HybridCLRData/iOSBuild/CMakeLists.txt
  78. 0 19
      GameClient/HybridCLRData/iOSBuild/build_libil2cpp.sh
  79. 0 47
      GameClient/HybridCLRData/iOSBuild/external/CMakeLists.txt
  80. 0 64
      GameClient/HybridCLRData/iOSBuild/gen_lump.sh
  81. 0 62
      GameClient/HybridCLRData/iOSBuild/objective/CMakeLists.txt
  82. 0 61
      GameClient/HybridCLRData/init_local_il2cpp_data.bat
  83. 0 69
      GameClient/HybridCLRData/init_local_il2cpp_data.sh
  84. 3 3
      GameClient/ProjectSettings/ProjectSettings.asset

+ 45 - 0
GameClient/Assets/Editor/BuildEditor/BuildHotfixEditor.cs

@@ -0,0 +1,45 @@
+using System.IO;
+using UnityEditor;
+using UnityEngine;
+using GFGGame;
+
+namespace GFGEditor
+{
+    [InitializeOnLoad]
+    public class BuildHotfixEditor
+    {
+        //Unity代码生成dll位置
+        private const string ScriptAssembliesDir = "Library/ScriptAssemblies";
+        //热更代码dll文件
+        private const string HotfixDll = "Game.HotUpdate.dll";
+        //热更代码pdb文件
+        private const string HotfixPdb = "Game.HotUpdate.pdb";
+        //热更代码存放位置
+        private const string CodeDir = LauncherConfig.DllDirHotfix;
+        //热更代码存放位置
+        private const string EditorDllDir = "Assets/Editor/Excel/DLL/";
+
+        static BuildHotfixEditor()
+        {
+            CopyCode();
+        }
+
+        static void CopyCode()
+        {
+            Debug.Log($"Copy Hotfix Code");
+            if (!Directory.Exists(CodeDir))
+                Directory.CreateDirectory(CodeDir);
+            var path = Path.Combine(ScriptAssembliesDir, HotfixDll);
+            if (File.Exists(path))
+            {
+                File.Copy(path, Path.Combine(CodeDir, "Game.HotUpdate.dll.bytes"), true);
+                //File.Delete(path);
+                path = Path.Combine(ScriptAssembliesDir, HotfixPdb);
+                File.Copy(path, Path.Combine(CodeDir, "Game.HotUpdate.pdb.bytes"), true);
+                //File.Delete(path);
+                Debug.Log($"复制Game.HotUpdate.dll, Game.HotUpdate.pdb到Res/Code完成");
+                AssetDatabase.Refresh();
+            }
+        }
+    }
+}

+ 1 - 1
GameClient/Assets/Editor/HybridCLR/BuildPlayerHelper.cs.meta → GameClient/Assets/Editor/BuildEditor/BuildHotfixEditor.cs.meta

@@ -1,5 +1,5 @@
 fileFormatVersion: 2
-guid: 7796c8df856ac4a4a9d644329c1f0958
+guid: f249fd6ea2f49a3409417d52aafd79b0
 MonoImporter:
   externalObjects: {}
   serializedVersion: 2

+ 0 - 8
GameClient/Assets/Editor/HybridCLR.meta

@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 0cca09dc9d27f314da15fa746a01d51c
-folderAsset: yes
-DefaultImporter:
-  externalObjects: {}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 124
GameClient/Assets/Editor/HybridCLR/AssetBundleBuildHelper.cs

@@ -1,124 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEditor;
-using UnityEngine;
-
-namespace HybridCLR
-{
-    public static class AssetBundleBuildHelper
-    {
-
-        public static string ToRelativeAssetPath(string s)
-        {
-            return s.Substring(s.IndexOf("Assets/"));
-        }
-
-        /// <summary>
-        /// 将HotFix.dll和HotUpdatePrefab.prefab打入common包.
-        /// 将HotUpdateScene.unity打入scene包.
-        /// </summary>
-        /// <param name="tempDir"></param>
-        /// <param name="outputDir"></param>
-        /// <param name="target"></param>
-        private static void BuildAssetBundles(string tempDir, string outputDir, BuildTarget target)
-        {
-            Directory.CreateDirectory(tempDir);
-            Directory.CreateDirectory(outputDir);
-            CompileDllHelper.CompileDll(target);
-
-
-            List<string> notSceneAssets = new List<string>();
-
-            string hotfixDllSrcDir = BuildConfig.GetHotFixDllsOutputDirByTarget(target);
-            foreach (var dll in BuildConfig.AllHotUpdateDllNames)
-            {
-                string dllPath = $"{hotfixDllSrcDir}/{dll}";
-                string dllBytesPath = $"{tempDir}/{dll}.bytes";
-                File.Copy(dllPath, dllBytesPath, true);
-                notSceneAssets.Add(dllBytesPath);
-            }
-
-            string aotDllDir = BuildConfig.GetAssembliesPostIl2CppStripDir(target);
-            foreach (var dll in BuildConfig.AOTMetaDlls)
-            {
-                string dllPath = $"{aotDllDir}/{dll}";
-                if (!File.Exists(dllPath))
-                {
-                    Debug.LogError($"ab中添加AOT补充元数据dll:{dllPath} 时发生错误,文件不存在。裁剪后的AOT dll在BuildPlayer时才能生成,因此需要你先构建一次游戏App后再打包。");
-                    continue;
-                }
-                string dllBytesPath = $"{tempDir}/{dll}.bytes";
-                File.Copy(dllPath, dllBytesPath, true);
-                notSceneAssets.Add(dllBytesPath);
-            }
-
-            string testPrefab = $"{Application.dataPath}/Prefabs/HotUpdatePrefab.prefab";
-            notSceneAssets.Add(testPrefab);
-            AssetDatabase.Refresh(ImportAssetOptions.ForceUpdate);
-
-            List<AssetBundleBuild> abs = new List<AssetBundleBuild>();
-            AssetBundleBuild notSceneAb = new AssetBundleBuild
-            {
-                assetBundleName = "common",
-                assetNames = notSceneAssets.Select(s => ToRelativeAssetPath(s)).ToArray(),
-            };
-            abs.Add(notSceneAb);
-
-            BuildPipeline.BuildAssetBundles(outputDir, abs.ToArray(), BuildAssetBundleOptions.None, target);
-
-            AssetDatabase.Refresh(ImportAssetOptions.ForceUpdate);
-
-            string streamingAssetPathDst = $"{Application.streamingAssetsPath}";
-            Directory.CreateDirectory(streamingAssetPathDst);
-
-            foreach (var ab in abs)
-            {
-                AssetDatabase.CopyAsset(ToRelativeAssetPath($"{outputDir}/{ab.assetBundleName}"),
-                    ToRelativeAssetPath($"{streamingAssetPathDst}/{ab.assetBundleName}"));
-            }
-        }
-
-        public static void BuildAssetBundleByTarget(BuildTarget target)
-        {
-            BuildAssetBundles(BuildConfig.GetAssetBundleTempDirByTarget(target), BuildConfig.GetAssetBundleOutputDirByTarget(target), target);
-        }
-
-        [MenuItem("HybridCLR/BuildBundles/ActiveBuildTarget")]
-        public static void BuildSceneAssetBundleActiveBuildTarget()
-        {
-            BuildAssetBundleByTarget(EditorUserBuildSettings.activeBuildTarget);
-        }
-
-        [MenuItem("HybridCLR/BuildBundles/Win64")]
-        public static void BuildSceneAssetBundleWin64()
-        {
-            var target = BuildTarget.StandaloneWindows64;
-            BuildAssetBundleByTarget(target);
-        }
-
-        [MenuItem("HybridCLR/BuildBundles/Win32")]
-        public static void BuildSceneAssetBundleWin32()
-        {
-            var target = BuildTarget.StandaloneWindows;
-            BuildAssetBundleByTarget(target);
-        }
-
-        [MenuItem("HybridCLR/BuildBundles/Android")]
-        public static void BuildSceneAssetBundleAndroid()
-        {
-            var target = BuildTarget.Android;
-            BuildAssetBundleByTarget(target);
-        }
-
-        [MenuItem("HybridCLR/BuildBundles/IOS")]
-        public static void BuildSceneAssetBundleIOS()
-        {
-            var target = BuildTarget.iOS;
-            BuildAssetBundleByTarget(target);
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/AssetBundleBuildHelper.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 1a8357532218e6f49a9bb9401382d6d4
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 95
GameClient/Assets/Editor/HybridCLR/BuildConfig.cs

@@ -1,95 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEditor;
-using UnityEngine;
-
-namespace HybridCLR
-{
-    public static partial class BuildConfig
-    {
-#if !UNITY_IOS
-        [InitializeOnLoadMethod]
-        private static void Setup()
-        {
-            ///
-            /// unity允许使用UNITY_IL2CPP_PATH环境变量指定il2cpp的位置,因此我们不再直接修改安装位置的il2cpp,
-            /// 而是在本地目录
-            ///
-            var localIl2cppDir = LocalIl2CppDir;
-            if (!Directory.Exists(localIl2cppDir))
-            {
-                Debug.LogError($"本地il2cpp目录:{localIl2cppDir} 不存在,未安装本地il2cpp。请手动执行一次 {HybridCLRDataDir} 目录下的 init_local_il2cpp_data.bat 或者 init_local_il2cpp_data.sh 文件");
-            }
-            Environment.SetEnvironmentVariable("UNITY_IL2CPP_PATH", localIl2cppDir);
-        }
-#endif
-
-        public static string ProjectDir => Directory.GetParent(Application.dataPath).ToString();
-
-        public static string ScriptingAssembliesJsonFile { get; } = "ScriptingAssemblies.json";
-
-        public static string HybridCLRBuildCacheDir => Application.dataPath + "/HybridCLRBuildCache";
-
-        public static string HotFixDllsOutputDir => $"{HybridCLRDataDir}/HotFixDlls";
-
-        public static string AssetBundleOutputDir => $"{HybridCLRBuildCacheDir}/AssetBundleOutput";
-
-        public static string AssetBundleSourceDataTempDir => $"{HybridCLRBuildCacheDir}/AssetBundleSourceData";
-
-        public static string HybridCLRDataDir { get; } = $"{ProjectDir}/HybridCLRData";
-
-        public static string AssembliesPostIl2CppStripDir => $"{HybridCLRDataDir}/AssembliesPostIl2CppStrip";
-
-        public static string LocalIl2CppDir => $"{HybridCLRDataDir}/LocalIl2CppData/il2cpp";
-
-        public static string MethodBridgeCppDir => $"{LocalIl2CppDir}/libil2cpp/hybridclr/interpreter";
-
-        public static string Il2CppBuildCacheDir { get; } = $"{ProjectDir}/Library/Il2cppBuildCache";
-
-        public static string GetHotFixDllsOutputDirByTarget(BuildTarget target)
-        {
-            return $"{HotFixDllsOutputDir}/{target}";
-        }
-
-        public static string GetAssembliesPostIl2CppStripDir(BuildTarget target)
-        {
-            return $"{AssembliesPostIl2CppStripDir}/{target}";
-        }
-
-        public static string GetOriginBuildStripAssembliesDir(BuildTarget target)
-        {
-#if UNITY_2021_1_OR_NEWER
-#if UNITY_STANDALONE_WIN
-            return $"{ProjectDir}/Library/Bee/artifacts/WinPlayerBuildProgram/ManagedStripped";
-#elif UNITY_ANDROID
-            return $"{ProjectDir}/Library/Bee/artifacts/Android/ManagedStripped";
-#elif UNITY_IOS
-            return $"{ProjectDir}/Library/PlayerDataCache/iOS/Data/Managed";
-#elif UNITY_WEBGL
-            return $"{ProjectDir}/Library/Bee/artifacts/WebGL/ManagedStripped";
-#else
-            throw new NotSupportedException("GetOriginBuildStripAssembliesDir");
-#endif
-#else
-            return target == BuildTarget.Android ?
-                $"{ProjectDir}/Temp/StagingArea/assets/bin/Data/Managed" :
-                $"{ProjectDir}/Temp/StagingArea/Data/Managed/";
-#endif
-        }
-
-        public static string GetAssetBundleOutputDirByTarget(BuildTarget target)
-        {
-            return $"{AssetBundleOutputDir}/{target}";
-        }
-
-        public static string GetAssetBundleTempDirByTarget(BuildTarget target)
-        {
-            return $"{AssetBundleSourceDataTempDir}/{target}";
-        }
-
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/BuildConfig.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: bf7714fc37515834382cd5836b503a9f
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 52
GameClient/Assets/Editor/HybridCLR/BuildConfig_Custom.cs

@@ -1,52 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEditor;
-using UnityEngine;
-
-namespace HybridCLR
-{
-    public static partial class BuildConfig
-    {
-
-        /// <summary>
-        /// 需要在Prefab上挂脚本的热更dll名称列表,不需要挂到Prefab上的脚本可以不放在这里
-        /// 但放在这里的dll即使勾选了 AnyPlatform 也会在打包过程中被排除
-        /// 
-        /// 另外请务必注意: 需要挂脚本的dll的名字最好别改,因为这个列表无法热更(上线后删除或添加某些非挂脚本dll没问题)。
-        /// 
-        /// 注意:多热更新dll不是必须的!大多数项目完全可以只有HotFix.dll这一个热更新模块,纯粹出于演示才故意设计了两个热更新模块。
-        /// 另外,是否热更新跟dll名毫无关系,凡是不打包到主工程的,都可以是热更新dll。
-        /// </summary>
-        public static List<string> MonoHotUpdateDllNames { get; } = new List<string>()
-        {
-            
-        };
-
-        /// <summary>
-        /// 所有热更新dll列表。放到此列表中的dll在打包时OnFilterAssemblies回调中被过滤。
-        /// </summary>
-        public static List<string> AllHotUpdateDllNames { get; } = MonoHotUpdateDllNames.Concat(new List<string>
-        {
-            // 这里放除了s_monoHotUpdateDllNames以外的脚本不需要挂到资源上的dll列表
-            "Game.HotUpdate.dll",
-        }).ToList();
-
-        public static List<string> AOTMetaDlls { get; } = new List<string>()
-        {
-            "mscorlib.dll",
-            "System.dll",
-            "System.Core.dll", // 如果使用了Linq,需要这个
-            "ThirdParty.dll",
-            "Game.Launcher.dll",
-        };
-
-        public static List<string> AssetBundleFiles { get; } = new List<string>
-        {
-            "common",
-        };
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/BuildConfig_Custom.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 33c09b498146d144a947ed6d8ff104f3
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 148
GameClient/Assets/Editor/HybridCLR/BuildPlayerHelper.cs

@@ -1,148 +0,0 @@
-using System.Collections;
-using System.Collections.Generic;
-using System.IO;
-using UnityEditor;
-using UnityEngine;
-
-namespace HybridCLR
-{
-    public class BuildPlayerHelper
-    {
-        public static void CopyAssetBundles(string outputDir)
-        {
-            Directory.CreateDirectory(outputDir);
-
-            foreach(var ab in BuildConfig.AssetBundleFiles)
-            {
-                string srcFile = $"{Application.streamingAssetsPath}/{ab}";
-                string dstFile = $"{outputDir}/{Path.GetFileName(ab)}";
-                File.Copy(srcFile, dstFile, true);
-            }
-        }
-
-        [MenuItem("HybridCLR/Build/Win64")]
-        public static void Build_Win64()
-        {
-            BuildTarget target = BuildTarget.StandaloneWindows64;
-            BuildTarget activeTarget = EditorUserBuildSettings.activeBuildTarget;
-            if (activeTarget != BuildTarget.StandaloneWindows64 && activeTarget != BuildTarget.StandaloneWindows)
-            {
-                Debug.LogError("请先切到Win平台再打包");
-                return;
-            }
-            // Get filename.
-            string outputPath = $"{BuildConfig.ProjectDir}/Release-Win64";
-
-            var buildOptions = BuildOptions.None;
-
-            string location = $"{outputPath}/HybridCLRTrial.exe";
-
-            Debug.Log("====> Build App");
-            BuildPlayerOptions buildPlayerOptions = new BuildPlayerOptions()
-            {
-                scenes = new string[] { "Assets/Scenes/main.unity" },
-                locationPathName = location,
-                options = buildOptions,
-                target = target,
-                targetGroup = BuildTargetGroup.Standalone,
-            };
-
-            var report = BuildPipeline.BuildPlayer(buildPlayerOptions);
-            if (report.summary.result != UnityEditor.Build.Reporting.BuildResult.Succeeded)
-            {
-                Debug.LogError("打包失败");
-                return;
-            }
-
-            Debug.Log("====> Build AssetBundle");
-            AssetBundleBuildHelper.BuildAssetBundleByTarget(target);
-            Debug.Log("====> 复制 AssetBundle");
-            CopyAssetBundles($"{outputPath}/HybridCLRTrial_Data/StreamingAssets");
-
-#if UNITY_EDITOR
-            Application.OpenURL($"file:///{location}");
-#endif
-        }
-
-        [MenuItem("HybridCLR/Build/Win32")]
-        public static void Build_Win32()
-        {
-            BuildTarget target = BuildTarget.StandaloneWindows;
-            BuildTarget activeTarget = EditorUserBuildSettings.activeBuildTarget;
-            if (activeTarget != BuildTarget.StandaloneWindows64 && activeTarget != BuildTarget.StandaloneWindows)
-            {
-                Debug.LogError("请先切到Win平台再打包");
-                return;
-            }
-            // Get filename.
-            string outputPath = $"{BuildConfig.ProjectDir}/Release-Win32";
-
-            var buildOptions = BuildOptions.None;
-
-            string location = $"{outputPath}/HybridCLRTrial.exe";
-
-            Debug.Log("====> Build App");
-            BuildPlayerOptions buildPlayerOptions = new BuildPlayerOptions()
-            {
-                scenes = new string[] { "Assets/Scenes/main.unity" },
-                locationPathName = location,
-                options = buildOptions,
-                target = target,
-                targetGroup = BuildTargetGroup.Standalone,
-            };
-
-            var report = BuildPipeline.BuildPlayer(buildPlayerOptions);
-            if (report.summary.result != UnityEditor.Build.Reporting.BuildResult.Succeeded)
-            {
-                Debug.LogError("打包失败");
-                return;
-            }
-
-            Debug.Log("====> Build AssetBundle");
-            AssetBundleBuildHelper.BuildAssetBundleByTarget(target);
-            Debug.Log("====> 复制 AssetBundle");
-            CopyAssetBundles($"{outputPath}/HybridCLRTrial_Data/StreamingAssets");
-
-#if UNITY_EDITOR
-            Application.OpenURL($"file:///{outputPath}");
-#endif
-        }
-
-        [MenuItem("HybridCLR/Build/Android64")]
-        public static void Build_Android64()
-        {
-            BuildTarget target = BuildTarget.Android;
-            BuildTarget activeTarget = EditorUserBuildSettings.activeBuildTarget;
-            if (activeTarget != BuildTarget.Android)
-            {
-                Debug.LogError("请先切到Android平台再打包");
-                return;
-            }
-            // Get filename.
-            string outputPath = $"{BuildConfig.ProjectDir}/Release-Android";
-
-            var buildOptions = BuildOptions.None;
-
-            string location = outputPath + "/HybridCLRTrial.apk";
-            BuildPlayerOptions buildPlayerOptions = new BuildPlayerOptions()
-            {
-                scenes = new string[] { "Assets/Scenes/main.unity" },
-                locationPathName = location,
-                options = buildOptions,
-                target = target,
-                targetGroup = BuildTargetGroup.Android,
-            };
-
-            Debug.Log("====> 第1次 Build App(为了生成补充AOT元数据dll)");
-            BuildPipeline.BuildPlayer(buildPlayerOptions);
-            Debug.Log("====> Build AssetBundle");
-            AssetBundleBuildHelper.BuildAssetBundleByTarget(target);
-
-            Debug.Log("====> 第2次打包");
-            BuildPipeline.BuildPlayer(buildPlayerOptions);
-#if UNITY_EDITOR
-            Application.OpenURL($"file:///{outputPath}");
-#endif
-        }
-    }
-}

+ 0 - 175
GameClient/Assets/Editor/HybridCLR/BuildProcessor_2019.cs

@@ -1,175 +0,0 @@
-#if UNITY_2018_1_OR_NEWER && !UNITY_2020_1_OR_NEWER
-using System.Collections;
-using System.Collections.Generic;
-using UnityEditor;
-using UnityEditor.Build;
-using UnityEditor.Build.Reporting;
-using UnityEngine;
-using UnityEngine.SceneManagement;
-using System.Linq;
-using System.IO;
-using System;
-using UnityEditor.UnityLinker;
-using System.Reflection;
-using UnityEditor.Il2Cpp;
-using HybridCLR.Editor.GlobalManagers;
-#if UNITY_ANDROID
-using UnityEditor.Android;
-#endif
-
-namespace HybridCLR
-{
-    public class BuildProcessor_2019 : IPreprocessBuildWithReport, IPostprocessBuildWithReport
-#if UNITY_ANDROID
-        , IPostGenerateGradleAndroidProject
-#endif
-        , IProcessSceneWithReport, IFilterBuildAssemblies, IPostBuildPlayerScriptDLLs, IUnityLinkerProcessor, IIl2CppProcessor
-    {
-        /// <summary>
-        /// 需要在Prefab上挂脚本的热更dll名称列表,不需要挂到Prefab上的脚本可以不放在这里
-        /// 但放在这里的dll即使勾选了 AnyPlatform 也会在打包过程中被排除
-        /// 
-        /// 另外请务必注意!: 需要挂脚本的dll的名字最好别改,因为这个列表无法热更(上线后删除或添加某些非挂脚本dll没问题)
-        /// </summary>
-        static List<string> monoDllNames = new List<string>() { "HotFix.dll"};
-
-        static MethodInfo s_BuildReport_AddMessage;
-
-        int IOrderedCallback.callbackOrder => 0;
-
-        static BuildProcessor_2019()
-        {
-            s_BuildReport_AddMessage = typeof(BuildReport).GetMethod("AddMessage", BindingFlags.Instance | BindingFlags.NonPublic);
-        }
-
-        void IPreprocessBuildWithReport.OnPreprocessBuild(BuildReport report)
-        {
-            if (!Application.isBatchMode && !EditorUtility.DisplayDialog("确认", "建议 Build 之前先打包 AssetBundle\r\n是否继续?", "继续", "取消"))
-            {
-                s_BuildReport_AddMessage.Invoke(report, new object[] { LogType.Exception, "用户取消", "BuildFailedException" });
-                return;
-            }
-        }
-
-        string[] IFilterBuildAssemblies.OnFilterAssemblies(BuildOptions buildOptions, string[] assemblies)
-        {
-            // 将热更dll从打包列表中移除
-            List<string> newNames = new List<string>(assemblies.Length);
-
-            foreach(string assembly in assemblies)
-            {
-                bool found = false;
-                foreach(string removeName in monoDllNames)
-                {
-                    if(assembly.EndsWith(removeName, StringComparison.OrdinalIgnoreCase))
-                    {
-                        found = true;
-                        break;
-                    }
-                }
-
-                if(!found)
-                    newNames.Add(assembly);
-            }
-            
-            return newNames.ToArray();
-        }
-
-
-        [Serializable]
-        public class ScriptingAssemblies
-        {
-            public List<string> names;
-            public List<int> types;
-        }
-
-        void IPostprocessBuildWithReport.OnPostprocessBuild(BuildReport report)
-        {
-            AddBackHotFixAssembliesTo_BinFile(report, null);
-        }
-
-#if UNITY_ANDROID
-        void IPostGenerateGradleAndroidProject.OnPostGenerateGradleAndroidProject(string path)
-        {
-            // 由于 Android 平台在 OnPostprocessBuild 调用时已经生成完 apk 文件,因此需要提前调用
-            AddBackHotFixAssembliesTo_BinFile(null, path);
-        }
-#endif
-
-        private void AddBackHotFixAssembliesTo_BinFile(BuildReport report, string path)
-        {
-            /*
-             * Unity2019 中 dll 加载列表存储在 globalgamemanagers 文件中,此列表在游戏启动时自动加载,
-             * 不在此列表中的dll在资源反序列化时无法被找到其类型
-             * 因此 OnFilterAssemblies 中移除的条目需要再加回来
-             */
-#if UNITY_ANDROID
-            string[] binFiles = new string[] { "Temp/gradleOut/unityLibrary/src/main/assets/bin/Data/globalgamemanagers" }; // report.files 不包含 Temp/gradleOut 等目录
-#else
-            // 直接出包和输出vs工程时路径不同,report.summary.outputPath 记录的是前者路径
-            string[] binFiles = Directory.GetFiles(Path.GetDirectoryName(report.summary.outputPath), "globalgamemanagers", SearchOption.AllDirectories);
-#endif
-
-            if (binFiles.Length == 0)
-            {
-                Debug.LogError("can not find file ScriptingAssemblies.json");
-                return;
-            }
-
-            foreach (string binPath in binFiles)
-            {
-                var binFile = new UnityBinFile();
-                binFile.LoadFromFile(binPath);
-
-                ScriptsData scriptsData = binFile.scriptsData;
-                foreach (string name in monoDllNames)
-                {
-                    if(!scriptsData.dllNames.Contains(name))
-                    {
-                        scriptsData.dllNames.Add(name);
-                        scriptsData.dllTypes.Add(16); // user dll type
-                    }
-                }
-                binFile.scriptsData = scriptsData;
-
-                binFile.RebuildAndFlushToFile(binPath);
-            }
-        }
-
-
-        void IProcessSceneWithReport.OnProcessScene(Scene scene, BuildReport report)
-        {
-
-        }
-
-        void IPostBuildPlayerScriptDLLs.OnPostBuildPlayerScriptDLLs(BuildReport report)
-        {
-
-        }
-
-        string IUnityLinkerProcessor.GenerateAdditionalLinkXmlFile(BuildReport report, UnityLinkerBuildPipelineData data)
-        {
-            return String.Empty;
-        }
-
-        void IUnityLinkerProcessor.OnBeforeRun(BuildReport report, UnityLinkerBuildPipelineData data)
-        {
-        }
-
-        void IUnityLinkerProcessor.OnAfterRun(BuildReport report, UnityLinkerBuildPipelineData data)
-        {
-        }
-
-        void IIl2CppProcessor.OnBeforeConvertRun(BuildReport report, Il2CppBuildPipelineData data)
-        {
-
-        }
-
-
-#if UNITY_IOS
-    // hook UnityEditor.BuildCompletionEventsHandler.ReportPostBuildCompletionInfo() ? 因为没有 mac 打包平台因此不清楚
-#endif
-    }
-
-}
-#endif

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/BuildProcessor_2019.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: ca7af90ea994cd145a19373563c301fc
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 165
GameClient/Assets/Editor/HybridCLR/BuildProcessor_2020_1_OR_NEWER.cs

@@ -1,165 +0,0 @@
-#if UNITY_2020_1_OR_NEWER
-using System.Collections;
-using System.Collections.Generic;
-using UnityEditor;
-using UnityEditor.Build;
-using UnityEditor.Build.Reporting;
-using UnityEngine;
-using UnityEngine.SceneManagement;
-using System.Linq;
-using System.IO;
-using System;
-using UnityEditor.UnityLinker;
-using System.Reflection;
-using UnityEditor.Il2Cpp;
-#if UNITY_ANDROID
-using UnityEditor.Android;
-#endif
-
-namespace HybridCLR
-{
-    public class BuildProcessor_2020_1_OR_NEWER : IPreprocessBuildWithReport,
-#if UNITY_ANDROID
-        IPostGenerateGradleAndroidProject,
-#endif
-        IPostprocessBuildWithReport,
-        IFilterBuildAssemblies,
-        IUnityLinkerProcessor
-#if !UNITY_2021_1_OR_NEWER
-    , IIl2CppProcessor
-#endif
-    {
-        public int callbackOrder => 0;
-
-        public string[] OnFilterAssemblies(BuildOptions buildOptions, string[] assemblies)
-        {
-            // 将热更dll从打包列表中移除
-            return assemblies.Where(ass => BuildConfig.AllHotUpdateDllNames.All(dll => !ass.EndsWith(dll, StringComparison.OrdinalIgnoreCase))).ToArray();
-        }
-
-
-        [Serializable]
-        private class ScriptingAssemblies
-        {
-            public List<string> names;
-            public List<int> types;
-        }
-
-        public void OnBeforeConvertRun(BuildReport report, Il2CppBuildPipelineData data)
-        {
-            Debug.Log("==== OnBeforeConvertRun");
-            // 此回调只在 2020中调用
-            CopyStripDlls(data.target);
-        }
-
-        public void OnPostGenerateGradleAndroidProject(string path)
-        {
-            Debug.Log("==== OnPostGenerateGradleAndroidProject");
-            // 由于 Android 平台在 OnPostprocessBuild 调用时已经生成完 apk 文件,因此需要提前调用
-            AddBackHotFixAssembliesToJson(null, path);
-
-            // 对于 2020, 已经在OnBeforeConvertRun中复制了,因此这儿不再复制
-//#if UNITY_2021_1_OR_NEWER
-//            BuildTarget target = EditorUserBuildSettings.activeBuildTarget;
-//            CopyStripDlls(target);
-//#endif
-        }
-
-        public void OnPostprocessBuild(BuildReport report)
-        {
-            Debug.Log("==== OnPostprocessBuild");
-#if !UNITY_ANDROID
-
-            AddBackHotFixAssembliesToJson(report, report.summary.outputPath);
-#endif
-        // Unity 2021开始,不再清理这个Temp目录,因此在这个时机复制较为合适
-#if UNITY_2021_1_OR_NEWER
-            BuildTarget target = EditorUserBuildSettings.activeBuildTarget;
-            CopyStripDlls(target);
-#endif
-        }
-        
-        private void AddBackHotFixAssembliesToJson(BuildReport report, string path)
-        {
-            /*
-             * ScriptingAssemblies.json 文件中记录了所有的dll名称,此列表在游戏启动时自动加载,
-             * 不在此列表中的dll在资源反序列化时无法被找到其类型
-             * 因此 OnFilterAssemblies 中移除的条目需要再加回来
-             */
-            string[] jsonFiles = Directory.GetFiles(Path.GetDirectoryName(path), BuildConfig.ScriptingAssembliesJsonFile, SearchOption.AllDirectories);
-
-            if (jsonFiles.Length == 0)
-            {
-                Debug.LogError($"can not find file {BuildConfig.ScriptingAssembliesJsonFile}");
-                return;
-            }
-
-            foreach (string file in jsonFiles)
-            {
-                string content = File.ReadAllText(file);
-                ScriptingAssemblies scriptingAssemblies = JsonUtility.FromJson<ScriptingAssemblies>(content);
-                foreach (string name in BuildConfig.MonoHotUpdateDllNames)
-                {
-                    if(!scriptingAssemblies.names.Contains(name))
-                    {
-                        scriptingAssemblies.names.Add(name);
-                        scriptingAssemblies.types.Add(16); // user dll type
-                    }
-                }
-                content = JsonUtility.ToJson(scriptingAssemblies);
-
-                File.WriteAllText(file, content);
-            }
-        }
-
-        private void CopyStripDlls(BuildTarget target)
-        {
-            var dstPath = BuildConfig.GetAssembliesPostIl2CppStripDir(target);
-
-            Directory.CreateDirectory(dstPath);
-
-            string srcStripDllPath = BuildConfig.GetOriginBuildStripAssembliesDir(target);
-
-            foreach (var fileFullPath in Directory.GetFiles(srcStripDllPath, "*.dll"))
-            {
-                var file = Path.GetFileName(fileFullPath);
-                Debug.Log($"copy strip dll {fileFullPath} ==> {dstPath}/{file}");
-                File.Copy($"{fileFullPath}", $"{dstPath}/{file}", true);
-            }
-        }
-
-        #region useless
-
-        private static void BuildExceptionEventHandler(object sender, UnhandledExceptionEventArgs e)
-        {
-
-        }
-
-        public void OnPreprocessBuild(BuildReport report)
-        {
-
-        }
-
-        public string GenerateAdditionalLinkXmlFile(BuildReport report, UnityLinkerBuildPipelineData data)
-        {
-            return String.Empty;
-        }
-
-        public void OnBeforeRun(BuildReport report, UnityLinkerBuildPipelineData data)
-        {
-
-        }
-
-        public void OnAfterRun(BuildReport report, UnityLinkerBuildPipelineData data)
-        {
-        }
-
-
-#if UNITY_IOS
-    // hook UnityEditor.BuildCompletionEventsHandler.ReportPostBuildCompletionInfo() ? 因为没有 mac 打包平台因此不清楚
-#endif
-        #endregion
-    }
-
-}
-#endif

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/BuildProcessor_2020_1_OR_NEWER.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: af5a0eff26871774893f1c7ec32b2bde
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 65
GameClient/Assets/Editor/HybridCLR/CompileDllHelper.cs

@@ -1,65 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEditor;
-using UnityEditor.Build.Player;
-using UnityEngine;
-
-namespace HybridCLR
-{
-    internal class CompileDllHelper
-    {
-        public static void CompileDll(string buildDir, BuildTarget target)
-        {
-            var group = BuildPipeline.GetBuildTargetGroup(target);
-
-            ScriptCompilationSettings scriptCompilationSettings = new ScriptCompilationSettings();
-            scriptCompilationSettings.group = group;
-            scriptCompilationSettings.target = target;
-            Directory.CreateDirectory(buildDir);
-            ScriptCompilationResult scriptCompilationResult = PlayerBuildInterface.CompilePlayerScripts(scriptCompilationSettings, buildDir);
-            foreach (var ass in scriptCompilationResult.assemblies)
-            {
-                Debug.LogFormat("compile assemblies:{1}/{0}", ass, buildDir);
-            }
-        }
-
-        public static void CompileDll(BuildTarget target)
-        {
-            CompileDll(BuildConfig.GetHotFixDllsOutputDirByTarget(target), target);
-        }
-
-        [MenuItem("HybridCLR/CompileDll/ActiveBuildTarget")]
-        public static void CompileDllActiveBuildTarget()
-        {
-            CompileDll(EditorUserBuildSettings.activeBuildTarget);
-        }
-
-        [MenuItem("HybridCLR/CompileDll/Win32")]
-        public static void CompileDllWin32()
-        {
-            CompileDll(BuildTarget.StandaloneWindows);
-        }
-
-        [MenuItem("HybridCLR/CompileDll/Win64")]
-        public static void CompileDllWin64()
-        {
-            CompileDll(BuildTarget.StandaloneWindows64);
-        }
-
-        [MenuItem("HybridCLR/CompileDll/Android")]
-        public static void CompileDllAndroid()
-        {
-            CompileDll(BuildTarget.Android);
-        }
-
-        [MenuItem("HybridCLR/CompileDll/IOS")]
-        public static void CompileDllIOS()
-        {
-            CompileDll(BuildTarget.iOS);
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/CompileDllHelper.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 91aca02079207d746b74aeea1b595127
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 8
GameClient/Assets/Editor/HybridCLR/Generators.meta

@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: f85b93bff3478c045ae862a7cc216b18
-folderAsset: yes
-DefaultImporter:
-  externalObjects: {}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 13
GameClient/Assets/Editor/HybridCLR/Generators/ConstStrings.cs

@@ -1,13 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-
-namespace HybridCLR.Generators
-{
-    internal static class ConstStrings
-    {
-        public const string typeObjectPtr = "Il2CppObject*";
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/ConstStrings.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: e1465458aaad6884d95af7c4fc2de7a1
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 40
GameClient/Assets/Editor/HybridCLR/Generators/FileRegionReplace.cs

@@ -1,40 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-
-namespace HybridCLR.Generators
-{
-    public class FileRegionReplace
-    {
-        private readonly string _tplFile;
-
-        private readonly Dictionary<string, string> _regionReplaceContents = new Dictionary<string, string>();
-
-        public FileRegionReplace(string tplFile)
-        {
-            _tplFile = tplFile;
-        }
-
-        public void Replace(string regionName, string regionContent)
-        {
-            _regionReplaceContents.Add(regionName, regionContent);
-        }
-
-        public void Commit(string outputFile)
-        {
-            string originContent = File.ReadAllText(_tplFile, Encoding.UTF8);
-
-            string resultContent = originContent;
-
-            foreach (var c in _regionReplaceContents)
-            {
-                resultContent = TemplateUtil.ReplaceRegion(resultContent, c.Key, c.Value);
-            }
-            var utf8WithoutBOM = new System.Text.UTF8Encoding(false);
-            File.WriteAllText(outputFile, resultContent, utf8WithoutBOM);
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/FileRegionReplace.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: e5aa6559bd1b1e4488aa6746eda8202b
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 70
GameClient/Assets/Editor/HybridCLR/Generators/GeneratorConfig.cs

@@ -1,70 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEngine;
-
-namespace HybridCLR.Generators
-{
-    internal class GeneratorConfig
-    {
-        /// <summary>
-        /// 目前已经根据热更新dll的依赖自动计算需要扫描哪些dll来收集桥接函数。
-        /// 只要你的热更新以assembly def形式放到项目中,是不需要改这个的
-        /// </summary>
-        /// <returns></returns>
-        public static List<string> GetExtraAssembiles()
-        {
-            return new List<string>
-            {
-                // "mscorlib",
-            };
-        }
-
-        /// <summary>
-        /// 暂时没有仔细扫描泛型,如果运行时发现有生成缺失,先手动在此添加类
-        /// </summary>
-        /// <returns></returns>
-        public static List<Type> PrepareCustomGenericTypes()
-        {
-            return new List<Type>
-            {
-                typeof(Action<int, string, Vector3>),
-            };
-        }
-
-        /// <summary>
-        /// 如果提示缺失桥接函数,将提示缺失的签名加入到下列列表是简单的做法。
-        /// 这里添加64位App缺失的桥接函数签名
-        /// </summary>
-        /// <returns></returns>
-        public static List<string> PrepareCustomMethodSignatures64()
-        {
-            return new List<string>
-            {
-                "vi8i8",
-                "i4i8i8i4i4i8i8",
-                "i8i8S12",
-                "S12i8S12",
-                "S12i8S12S12",
-                "i16i8i16i16",
-            };
-        }
-
-        /// <summary>
-        /// 如果提示缺失桥接函数,将提示缺失的签名加入到下列列表是简单的做法。
-        /// 这里添加32位App缺失的桥接函数签名
-        /// </summary>
-        /// <returns></returns>
-        public static List<string> PrepareCustomMethodSignatures32()
-        {
-            return new List<string>
-            {
-                "vi4i4",
-                "S12i4S12S12",
-            };
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/GeneratorConfig.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: d1d14f8f858560948ae1dfa0fa572e51
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 8
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge.meta

@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 4aa66b41c89ed7742ad067898725f7ff
-folderAsset: yes
-DefaultImporter:
-  externalObjects: {}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 28
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/IPlatformAdaptor.cs

@@ -1,28 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using System.Text;
-using System.Threading.Tasks;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-    public interface IPlatformAdaptor
-    {
-        bool IsArch32 { get; }
-
-        TypeInfo CreateTypeInfo(Type type, bool returnValue);
-
-        void GenerateManaged2NativeMethod(MethodBridgeSig method, List<string> outputLines);
-
-        void GenerateManaged2NativeStub(List<MethodBridgeSig> methods, List<string> lines);
-
-        void GenerateNative2ManagedMethod(MethodBridgeSig method, List<string> outputLines);
-
-        void GenerateNative2ManagedStub(List<MethodBridgeSig> methods, List<string> lines);
-
-        void GenerateAdjustThunkMethod(MethodBridgeSig method, List<string> outputLines);
-
-        void GenerateAdjustThunkStub(List<MethodBridgeSig> methods, List<string> lines);
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/IPlatformAdaptor.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 983dbdeb1fb7d0b43a863c6b22160ace
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 343
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/MethodBridgeGenerator.cs

@@ -1,343 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Reflection;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEditor;
-using UnityEngine;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-
-    public class TypeGenInfo
-    {
-        public Type Type { get; set; }
-
-        public List<MethodInfo> GenericMethods { get; set; }
-    }
-
-    public class MethodBridgeGeneratorOptions
-    {
-        public List<Assembly> HotfixAssemblies { get; set; }
-
-        public List<Assembly> AllAssemblies { get; set; }
-
-        public PlatformABI CallConvention { get; set; }
-
-        public string OutputFile { get; set; }
-    }
-
-    public class MethodBridgeGenerator
-    {
-        private readonly HashSet<Assembly> _hotfixAssemblies;
-
-        private readonly List<Assembly> _assemblies;
-
-        private readonly PlatformABI _callConvention;
-
-        private readonly string _outputFile;
-
-        private readonly IPlatformAdaptor _platformAdaptor;
-
-        private readonly HashSet<MethodBridgeSig> _managed2nativeMethodSet = new HashSet<MethodBridgeSig>();
-
-        private List<MethodBridgeSig> _managed2nativeMethodList;
-
-        private readonly HashSet<MethodBridgeSig> _native2managedMethodSet = new HashSet<MethodBridgeSig>();
-
-        private List<MethodBridgeSig> _native2managedMethodList;
-
-        private readonly HashSet<MethodBridgeSig> _adjustThunkMethodSet = new HashSet<MethodBridgeSig>();
-
-        private List<MethodBridgeSig> _adjustThunkMethodList;
-
-        public bool IsHotFixType(Type type)
-        {
-            return _hotfixAssemblies.Contains(type.Assembly);
-        }
-
-        public MethodBridgeGenerator(MethodBridgeGeneratorOptions options)
-        {
-            _hotfixAssemblies = new HashSet<Assembly>(options.HotfixAssemblies);
-            _assemblies = options.AllAssemblies;
-            _callConvention = options.CallConvention;
-            _outputFile = options.OutputFile;
-            _platformAdaptor = CreatePlatformAdaptor(options.CallConvention);
-        }
-
-        private static IPlatformAdaptor CreatePlatformAdaptor(PlatformABI type)
-        {
-            return type switch
-            {
-                PlatformABI.Universal32 => new PlatformAdaptor_Universal32(),
-                PlatformABI.Universal64 => new PlatformAdaptor_Universal64(),
-                PlatformABI.Arm64 => new PlatformAdaptor_Arm64(),
-                _ => throw new NotSupportedException(),
-            };
-        }
-
-        private string GetTemplateFile()
-        {
-            string tplFile = _callConvention switch
-            {
-                PlatformABI.Universal32 => "Universal32",
-                PlatformABI.Universal64 => "Universal64",
-                PlatformABI.Arm64 => "Arm64",
-                _ => throw new NotSupportedException(),
-            };
-            return $"{Application.dataPath}/Editor/HybridCLR/Generators/Templates/MethodBridge_{tplFile}.cpp";
-        }
-
-        public IEnumerable<TypeGenInfo> GetGenerateTypes()
-        {
-            return new List<TypeGenInfo>();
-        }
-
-        private MethodBridgeSig CreateMethodBridgeSig(bool isStatic, ParameterInfo returnType, ParameterInfo[] parameters)
-        {
-            var paramInfos = new List<ParamInfo>();
-            if (!isStatic)
-            {
-                // FIXME arm32 is s_i4u4
-                paramInfos.Add(new ParamInfo() { Type = _platformAdaptor.IsArch32 ? TypeInfo.s_i4u4 : TypeInfo.s_i8u8 });
-            }
-            foreach (var paramInfo in parameters)
-            {
-                paramInfos.Add(new ParamInfo() { Type = _platformAdaptor.CreateTypeInfo(paramInfo.ParameterType, false) });
-            }
-            var mbs = new MethodBridgeSig()
-            {
-                ReturnInfo = new ReturnInfo() { Type = returnType != null ? _platformAdaptor.CreateTypeInfo(returnType.ParameterType, true) : TypeInfo.s_void },
-                ParamInfos = paramInfos,
-            };
-            return mbs;
-        }
-
-        private void AddManaged2NativeMethod(MethodBridgeSig method)
-        {
-            if (_managed2nativeMethodSet.Add(method))
-            {
-                method.Init();
-            }
-        }
-
-        private void AddNative2ManagedMethod(MethodBridgeSig method)
-        {
-            if (_native2managedMethodSet.Add(method))
-            {
-                method.Init();
-            }
-        }
-
-        private void AddAdjustThunkMethod(MethodBridgeSig method)
-        {
-            if (_adjustThunkMethodSet.Add(method))
-            {
-                method.Init();
-            }
-        }
-
-        private void ScanType(Type type)
-        {
-            if (type.IsGenericTypeDefinition)
-            {
-                return;
-            }
-            if (!type.IsNested)
-            {
-                if (!type.IsPublic)
-                {
-                    return;
-                }
-            }
-            else
-            {
-                if (type.IsNestedPrivate)
-                {
-                    return;
-                }
-            }
-            var typeDel = typeof(MulticastDelegate);
-            if (typeDel.IsAssignableFrom(type))
-            {
-                var method = type.GetMethod("Invoke");
-                if (method == null)
-                {
-                    //Debug.LogError($"delegate:{typeDel.FullName} Invoke not exists");
-                    return;
-                }
-                // Debug.Log($"== delegate:{type}");
-                var instanceCallMethod = CreateMethodBridgeSig(false, method.ReturnParameter, method.GetParameters());
-                AddManaged2NativeMethod(instanceCallMethod);
-                AddNative2ManagedMethod(instanceCallMethod);
-
-                var staticCallMethod = CreateMethodBridgeSig(true, method.ReturnParameter, method.GetParameters());
-                AddManaged2NativeMethod(staticCallMethod);
-                AddNative2ManagedMethod(staticCallMethod);
-                return;
-            }
-            foreach (var method in type.GetMethods(BindingFlags.Static | BindingFlags.Instance | BindingFlags.Public
-| BindingFlags.NonPublic | BindingFlags.CreateInstance | BindingFlags.InvokeMethod | BindingFlags.FlattenHierarchy))
-            {
-                if (method.IsGenericMethodDefinition)
-                {
-                    continue;
-                }
-
-                if (method.IsPrivate || (method.IsAssembly && !method.IsPublic && !method.IsFamily))
-                {
-                    continue;
-                }
-
-                if (method.IsFamily || method.IsPublic)
-                {
-                    var m2nMethod = CreateMethodBridgeSig(method.IsStatic, method.ReturnParameter, method.GetParameters());
-                    AddManaged2NativeMethod(m2nMethod);
-
-                    if (type.IsValueType && !method.IsStatic)
-                    {
-                        var adjustThunkMethod = CreateMethodBridgeSig(false, method.ReturnParameter, method.GetParameters());
-                        AddAdjustThunkMethod(adjustThunkMethod);
-                    }
-
-                    if (method.IsVirtual)
-                    {
-                        AddNative2ManagedMethod(m2nMethod);
-                    }
-                }
-            }
-
-            foreach (var method in type.GetConstructors(BindingFlags.Instance | BindingFlags.Public
-| BindingFlags.NonPublic | BindingFlags.CreateInstance | BindingFlags.InvokeMethod | BindingFlags.FlattenHierarchy))
-            {
-                if (method.IsPrivate || (method.IsAssembly && !method.IsPublic && !method.IsFamily))
-                {
-                    continue;
-                }
-
-                if (method.IsFamily || method.IsPublic)
-                {
-                    var callMethod = CreateMethodBridgeSig(false, null, method.GetParameters());
-                    AddManaged2NativeMethod(callMethod);
-
-                    if (type.IsValueType && !method.IsStatic)
-                    {
-                        var invokeMethod = CreateMethodBridgeSig(false, null, method.GetParameters());
-                        AddAdjustThunkMethod(invokeMethod);
-                    }
-                }
-            }
-
-            foreach (var subType in type.GetNestedTypes(BindingFlags.Public | BindingFlags.NonPublic))
-            {
-                ScanType(subType);
-            }
-        }
-
-        public void PrepareFromAssemblies()
-        {
-            foreach (var ass in _assemblies)
-            {
-                if (_hotfixAssemblies.Contains(ass))
-                {
-                    continue;
-                }
-                //Debug.Log("prepare assembly:" + ass.FullName);
-                foreach (var type in ass.GetTypes())
-                {
-                    ScanType(type);
-                }
-            }
-        }
-
-        private void PrepareMethodsFromCustomeGenericTypes()
-        {
-            foreach (var type in GeneratorConfig.PrepareCustomGenericTypes())
-            {
-                ScanType(type);
-            }
-        }
-
-        public void PrepareMethods()
-        {
-            PrepareMethodsFromCustomeGenericTypes();
-
-
-            foreach(var methodSig in _platformAdaptor.IsArch32 ? GeneratorConfig.PrepareCustomMethodSignatures32() : GeneratorConfig.PrepareCustomMethodSignatures64())
-            {
-                var method = MethodBridgeSig.CreateBySignatuer(methodSig);
-                AddManaged2NativeMethod(method);
-                AddAdjustThunkMethod(method);
-            }
-            PrepareFromAssemblies();
-
-            {
-                var sortedMethods = new SortedDictionary<string, MethodBridgeSig>();
-                foreach (var method in _managed2nativeMethodSet)
-                {
-                    sortedMethods.Add(method.CreateCallSigName(), method);
-                }
-                _managed2nativeMethodList = sortedMethods.Values.ToList();
-            }
-            {
-                var sortedMethods = new SortedDictionary<string, MethodBridgeSig>();
-                foreach (var method in _native2managedMethodSet)
-                {
-                    sortedMethods.Add(method.CreateCallSigName(), method);
-                }
-                _native2managedMethodList = sortedMethods.Values.ToList();
-            }
-            {
-                var sortedMethods = new SortedDictionary<string, MethodBridgeSig>();
-                foreach (var method in _adjustThunkMethodSet)
-                {
-                    sortedMethods.Add(method.CreateCallSigName(), method);
-                }
-                _adjustThunkMethodList = sortedMethods.Values.ToList();
-            }
-        }
-
-        public void Generate()
-        {
-            var frr = new FileRegionReplace(GetTemplateFile());
-
-            List<string> lines = new List<string>(20_0000);
-
-            Debug.LogFormat("== managed2native method count:{0}", _managed2nativeMethodList.Count);
-
-            foreach(var method in _managed2nativeMethodList)
-            {
-                _platformAdaptor.GenerateManaged2NativeMethod(method, lines);
-            }
-
-            _platformAdaptor.GenerateManaged2NativeStub(_managed2nativeMethodList, lines);
-
-            Debug.LogFormat("== native2managed method count:{0}", _native2managedMethodList.Count);
-
-            foreach (var method in _native2managedMethodList)
-            {
-                _platformAdaptor.GenerateNative2ManagedMethod(method, lines);
-            }
-
-            _platformAdaptor.GenerateNative2ManagedStub(_native2managedMethodList, lines);
-
-            Debug.LogFormat("== adjustThunk method count:{0}", _adjustThunkMethodList.Count);
-
-            foreach (var method in _adjustThunkMethodList)
-            {
-                _platformAdaptor.GenerateAdjustThunkMethod(method, lines);
-            }
-
-            _platformAdaptor.GenerateAdjustThunkStub(_adjustThunkMethodList, lines);
-
-            frr.Replace("INVOKE_STUB", string.Join("\n", lines));
-
-            Directory.CreateDirectory(Path.GetDirectoryName(_outputFile));
-
-            frr.Commit(_outputFile);
-        }
-
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/MethodBridgeGenerator.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 3171ed79d43e06c4b8c889b0a3f38969
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 156
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/MethodBridgeSig.cs

@@ -1,156 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using System.Text;
-using System.Text.RegularExpressions;
-using System.Threading.Tasks;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-    public class MethodBridgeSig : IEquatable<MethodBridgeSig>
-    {
-
-        private readonly static Regex s_sigPattern = new Regex(@"^(v|i1|i2|i4|i8|r4|r8|i16|sr|vf2|vf3|vf4|vd2|vd3|vd4|S\d+|A\d+|B\d+|C\d+)+$");
-
-        public static MethodBridgeSig CreateBySignatuer(string sigName)
-        {
-            var re = s_sigPattern.Match(sigName);
-            if (!re.Success)
-            {
-                throw new ArgumentException($"{sigName} is not valid signature");
-            }
-            
-            var mbs = new MethodBridgeSig() { ParamInfos = new List<ParamInfo>()};
-            var sigs = re.Groups[1].Captures;
-            mbs.ReturnInfo = new ReturnInfo() { Type = CreateTypeInfoBySignature(sigs[0].Value)};
-            for(int i = 1; i < sigs.Count; i++)
-            {
-                mbs.ParamInfos.Add(new ParamInfo() { Type = CreateTypeInfoBySignature(sigs[i].Value)});
-            }
-            return mbs;
-        }
-
-
-        private static TypeInfo CreateTypeInfoBySignature(string sigName)
-        {
-            switch(sigName)
-            {
-                case "v": return new TypeInfo(typeof(void), ParamOrReturnType.VOID);
-                case "i1": return new TypeInfo(typeof(sbyte), ParamOrReturnType.I1_U1);
-                case "i2": return new TypeInfo(typeof(short), ParamOrReturnType.I2_U2);
-                case "i4": return new TypeInfo(typeof(int), ParamOrReturnType.I4_U4);
-                case "i8": return new TypeInfo(typeof(long), ParamOrReturnType.I8_U8);
-                case "r4": return new TypeInfo(typeof(float), ParamOrReturnType.R4);
-                case "r8": return new TypeInfo(typeof(double), ParamOrReturnType.R8);
-                case "i16": return TypeInfo.s_i16;
-                case "sr": return TypeInfo.s_ref;
-                case "vf2": return new TypeInfo(null, ParamOrReturnType.ARM64_HFA_FLOAT_2);
-                case "vf3": return new TypeInfo(null, ParamOrReturnType.ARM64_HFA_FLOAT_3);
-                case "vf4": return new TypeInfo(null, ParamOrReturnType.ARM64_HFA_FLOAT_4);
-                case "vd2": return new TypeInfo(null, ParamOrReturnType.ARM64_HFA_DOUBLE_2);
-                case "vd3": return new TypeInfo(null, ParamOrReturnType.ARM64_HFA_DOUBLE_3);
-                case "vd4": return new TypeInfo(null, ParamOrReturnType.ARM64_HFA_DOUBLE_4);
-                default:
-                    {
-                        if (sigName.StartsWith("S"))
-                        {
-                            return new TypeInfo(null, ParamOrReturnType.STRUCTURE_ALIGN1, int.Parse(sigName.Substring(1)));
-                        }
-                        if (sigName.StartsWith("A"))
-                        {
-                            return new TypeInfo(null, ParamOrReturnType.STRUCTURE_ALIGN2, int.Parse(sigName.Substring(1)));
-                        }
-                        if (sigName.StartsWith("B"))
-                        {
-                            return new TypeInfo(null, ParamOrReturnType.STRUCTURE_ALIGN4, int.Parse(sigName.Substring(1)));
-                        }
-                        if (sigName.StartsWith("C"))
-                        {
-                            return new TypeInfo(null, ParamOrReturnType.STRUCTURE_ALIGN8, int.Parse(sigName.Substring(1)));
-                        }
-                        throw new ArgumentException($"invalid signature:{sigName}");
-                    }
-            }
-        }
-
-
-        public ReturnInfo ReturnInfo { get; set; }
-
-        public List<ParamInfo> ParamInfos { get; set; }
-
-        public void Init()
-        {
-            for(int i = 0; i < ParamInfos.Count; i++)
-            {
-                ParamInfos[i].Index = i;
-            }
-        }
-
-        public string CreateCallSigName()
-        {
-            var n = new StringBuilder();
-            n.Append(ReturnInfo.Type.CreateSigName());
-            foreach(var param in ParamInfos)
-            {
-                n.Append(param.Type.CreateSigName());
-            }
-            return n.ToString();
-        }
-
-        public string CreateInvokeSigName()
-        {
-            var n = new StringBuilder();
-            n.Append(ReturnInfo.Type.CreateSigName());
-            foreach (var param in ParamInfos)
-            {
-                n.Append(param.Type.CreateSigName());
-            }
-            return n.ToString();
-        }
-
-        public override bool Equals(object obj)
-        {
-            return Equals((MethodBridgeSig)obj);
-        }
-
-        public bool Equals(MethodBridgeSig other)
-        {
-            if (other == null)
-            {
-                return false;
-            }
-
-            if (!ReturnInfo.Type.Equals(other.ReturnInfo.Type))
-            {
-                return false;
-            }
-            if (ParamInfos.Count != other.ParamInfos.Count)
-            {
-                return false;
-            }
-            for(int i = 0; i < ParamInfos.Count; i++)
-            {
-                if (!ParamInfos[i].Type.Equals(other.ParamInfos[i].Type))
-                {
-                    return false;
-                }
-            }
-            return true;
-        }
-
-        public override int GetHashCode()
-        {
-            int hash = 17;
-
-            hash = hash * 23  + ReturnInfo.Type.GetHashCode();
-
-            foreach(var p in ParamInfos)
-            {
-                hash = hash * 23 + p.Type.GetHashCode();
-            }
-
-            return hash;
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/MethodBridgeSig.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: cbe63fb39b5bdcc448f3589b475fb5d8
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 44
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ParamInfo.cs

@@ -1,44 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Diagnostics;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-
-    public class ParamInfo
-    {
-        public TypeInfo Type { get; set; }
-
-        public int Index { get; set; }
-
-        //public bool IsNative2ManagedByAddress => Type.PorType >= ParamOrReturnType.STRUCT_NOT_PASS_AS_VALUE;
-        public bool IsPassToManagedByAddress => Type.GetParamSlotNum() > 1;
-
-        public bool IsPassToNativeByAddress => Type.PorType == ParamOrReturnType.STRUCTURE_AS_REF_PARAM;
-
-        public string Native2ManagedParamValue(PlatformABI canv)
-        {
-            return IsPassToManagedByAddress ? $"(uint64_t)&__arg{Index}" : $"*(uint64_t*)&__arg{Index}";
-        }
-
-        public string Managed2NativeParamValue(PlatformABI canv)
-        {
-            return IsPassToNativeByAddress ? $"(uint64_t)(localVarBase+argVarIndexs[{Index}])" : $"*({Type.GetTypeName()}*)(localVarBase+argVarIndexs[{Index}])";
-        }
-    }
-
-    public class ReturnInfo
-    {
-        public TypeInfo Type { get; set; }
-
-        public bool IsVoid => Type.PorType == ParamOrReturnType.VOID;
-
-        public int GetParamSlotNum(PlatformABI canv)
-        {
-            return Type.GetParamSlotNum();
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ParamInfo.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: c04e163336b93af44b4b565d0ab195e2
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 38
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ParamOrReturnType.cs

@@ -1,38 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-    public enum ParamOrReturnType
-    {
-        VOID,
-        I1_U1,
-        //U1,
-        I2_U2,
-        //U2,
-        I4_U4,
-        I8_U8,
-        //I_U,
-        R4,
-        R8,
-        ARM64_HFA_FLOAT_2,
-        VALUE_TYPE_SIZE_LESS_EQUAL_8,
-        I16, // 8 < size <= 16
-        STRUCT_NOT_PASS_AS_VALUE, // struct  pass not as value
-        STRUCTURE_AS_REF_PARAM, // size > 16
-        ARM64_HFA_FLOAT_3,
-        ARM64_HFA_FLOAT_4,
-        ARM64_HFA_DOUBLE_2,
-        ARM64_HFA_DOUBLE_3,
-        ARM64_HFA_DOUBLE_4,
-        ARM64_HVA_8,
-        ARM64_HVA_16,
-        STRUCTURE_ALIGN1, // size > 16
-        STRUCTURE_ALIGN2,
-        STRUCTURE_ALIGN4,
-        STRUCTURE_ALIGN8,
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ParamOrReturnType.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 7886905937fafb64999dc4e358565982
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 9
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformABI.cs

@@ -1,9 +0,0 @@
-namespace HybridCLR.Generators.MethodBridge
-{
-    public enum PlatformABI
-    {
-        Universal32,
-        Universal64,
-        Arm64,
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformABI.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: deee8d06a7f05bf4d9ab4b78f0a8a47c
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 160
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptorBase.cs

@@ -1,160 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using System.Reflection.Emit;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEngine;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-    internal abstract class PlatformAdaptorBase : IPlatformAdaptor
-    {
-        public abstract bool IsArch32 { get; }
-
-        public abstract TypeInfo PointerType { get; }
-
-        protected abstract Dictionary<Type, TypeInfo> CacheTypes { get; }
-
-        protected abstract TypeInfo CreateValueType(Type type, bool returnValue);
-
-        public abstract void GenerateManaged2NativeMethod(MethodBridgeSig method, List<string> lines);
-
-        public abstract void GenerateNative2ManagedMethod(MethodBridgeSig method, List<string> lines);
-
-        public abstract void GenerateAdjustThunkMethod(MethodBridgeSig method, List<string> outputLines);
-
-        private static Dictionary<Type, (int, int)> _typeSizeCache64 = new Dictionary<Type, (int, int)>();
-
-        private static Dictionary<Type, (int, int)> _typeSizeCache32 = new Dictionary<Type, (int, int)>();
-
-        private static ValueTypeSizeAligmentCalculator s_calculator64 = new ValueTypeSizeAligmentCalculator(false);
-
-        private static ValueTypeSizeAligmentCalculator s_calculator32 = new ValueTypeSizeAligmentCalculator(true);
-
-        public static (int Size, int Aligment) ComputeSizeAndAligmentOfArch64(Type t)
-        {
-            if (_typeSizeCache64.TryGetValue(t, out var sizeAndAligment))
-            {
-                return sizeAndAligment;
-            }
-            // all this just to invoke one opcode with no arguments!
-            var method = new DynamicMethod("ComputeSizeOfImpl", typeof(int), Type.EmptyTypes, typeof(PlatformAdaptorBase), false);
-            var gen = method.GetILGenerator();
-            gen.Emit(OpCodes.Sizeof, t);
-            gen.Emit(OpCodes.Ret);
-            int clrSize = ((Func<int>)method.CreateDelegate(typeof(Func<int>)))();
-
-            sizeAndAligment = s_calculator64.SizeAndAligmentOf(t);
-            int customSize = sizeAndAligment.Item1;
-            if (customSize != clrSize)
-            {
-                s_calculator64.SizeAndAligmentOf(t);
-                Debug.LogError($"type:{t} size calculate error. HybridCLR Comput:{sizeAndAligment} CLR:{clrSize}");
-            }
-            _typeSizeCache64.Add(t, sizeAndAligment);
-            return sizeAndAligment;
-        }
-
-        protected static (int Size, int Aligment) ComputeSizeAndAligmentOfArch32(Type t)
-        {
-            if (_typeSizeCache32.TryGetValue(t, out var sa))
-            {
-                return sa;
-            }
-            // all this just to invoke one opcode with no arguments!
-            sa = s_calculator32.SizeAndAligmentOf(t);
-            _typeSizeCache32.Add(t, sa);
-            return sa;
-        }
-
-        public TypeInfo CreateTypeInfo(Type type, bool returnValue)
-        {
-            if (type.IsByRef)
-            {
-                return PointerType;
-            }
-            if (type == typeof(void))
-            {
-                return TypeInfo.s_void;
-            }
-            if (!type.IsValueType)
-            {
-                return PointerType;
-            }
-            if (CacheTypes.TryGetValue(type, out var cache))
-            {
-                return cache;
-            }
-            if (type.IsEnum)
-            {
-                return CreateTypeInfo(type.GetEnumUnderlyingType(), returnValue);
-            }
-            var ti = CreateValueType(type, returnValue);
-            // s_typeInfoCaches.Add(type, ti);
-            return ti;
-        }
-
-        protected static TypeInfo CreateGeneralValueType(Type type, int size, int aligment)
-        {
-            Debug.Assert(size % aligment == 0);
-            switch (aligment)
-            {
-                case 1: return new TypeInfo(type, ParamOrReturnType.STRUCTURE_ALIGN1, size);
-                case 2: return new TypeInfo(type, ParamOrReturnType.STRUCTURE_ALIGN2, size);
-                case 4: return new TypeInfo(type, ParamOrReturnType.STRUCTURE_ALIGN4, size);
-                case 8: return new TypeInfo(type, ParamOrReturnType.STRUCTURE_ALIGN8, size);
-                default: throw new NotSupportedException($"type:{type} not support aligment:{aligment}");
-            }
-        }
-
-        public void GenerateManaged2NativeStub(List<MethodBridgeSig> methods, List<string> lines)
-        {
-            lines.Add($@"
-Managed2NativeMethodInfo hybridclr::interpreter::g_managed2nativeStub[] = 
-{{
-");
-
-            foreach (var method in methods)
-            {
-                lines.Add($"\t{{\"{method.CreateInvokeSigName()}\", __M2N_{method.CreateInvokeSigName()}}},");
-            }
-
-            lines.Add($"\t{{nullptr, nullptr}},");
-            lines.Add("};");
-        }
-
-        public void GenerateNative2ManagedStub(List<MethodBridgeSig> methods, List<string> lines)
-        {
-            lines.Add($@"
-Native2ManagedMethodInfo hybridclr::interpreter::g_native2managedStub[] = 
-{{
-");
-
-            foreach (var method in methods)
-            {
-                lines.Add($"\t{{\"{method.CreateInvokeSigName()}\", (Il2CppMethodPointer)__N2M_{method.CreateInvokeSigName()}}},");
-            }
-
-            lines.Add($"\t{{nullptr, nullptr}},");
-            lines.Add("};");
-        }
-
-        public void GenerateAdjustThunkStub(List<MethodBridgeSig> methods, List<string> lines)
-        {
-            lines.Add($@"
-NativeAdjustThunkMethodInfo hybridclr::interpreter::g_adjustThunkStub[] = 
-{{
-");
-
-            foreach (var method in methods)
-            {
-                lines.Add($"\t{{\"{method.CreateInvokeSigName()}\", (Il2CppMethodPointer)__N2M_AdjustorThunk_{method.CreateCallSigName()}}},");
-            }
-
-            lines.Add($"\t{{nullptr, nullptr}},");
-            lines.Add("};");
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptorBase.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: ebf14107fd82b364cb7d61276d444829
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 208
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Arm64.cs

@@ -1,208 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEngine;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-    internal class PlatformAdaptor_Arm64 : PlatformAdaptorBase
-    {
-
-        private static readonly Dictionary<Type, TypeInfo> s_typeInfoCaches = new Dictionary<Type, TypeInfo>()
-        {
-            { typeof(void), new TypeInfo(typeof(void), ParamOrReturnType.VOID)},
-            { typeof(bool), new TypeInfo(typeof(bool), ParamOrReturnType.I1_U1)},
-            { typeof(byte), new TypeInfo(typeof(byte), ParamOrReturnType.I1_U1)},
-            { typeof(sbyte), new TypeInfo(typeof(sbyte), ParamOrReturnType.I1_U1) },
-            { typeof(short), new TypeInfo(typeof(short), ParamOrReturnType.I2_U2) },
-            { typeof(ushort), new TypeInfo(typeof(ushort), ParamOrReturnType.I2_U2) },
-            { typeof(char), new TypeInfo(typeof(char), ParamOrReturnType.I2_U2) },
-            { typeof(int), new TypeInfo(typeof(int), ParamOrReturnType.I4_U4) },
-            { typeof(uint), new TypeInfo(typeof(uint), ParamOrReturnType.I4_U4) },
-            { typeof(long), new TypeInfo(typeof(long), ParamOrReturnType.I8_U8) },
-            { typeof(ulong), new TypeInfo(typeof(ulong), ParamOrReturnType.I8_U8)},
-            { typeof(float), new TypeInfo(typeof(float), ParamOrReturnType.R4)},
-            { typeof(double), new TypeInfo(typeof(double), ParamOrReturnType.R8)},
-            { typeof(IntPtr), new TypeInfo(null, ParamOrReturnType.I8_U8)},
-            { typeof(UIntPtr), new TypeInfo(null, ParamOrReturnType.I8_U8)},
-            { typeof(Vector2), new TypeInfo(typeof(Vector2), ParamOrReturnType.ARM64_HFA_FLOAT_2) },
-            { typeof(Vector3), new TypeInfo(typeof(Vector3), ParamOrReturnType.ARM64_HFA_FLOAT_3) },
-            { typeof(Vector4), new TypeInfo(typeof(Vector4), ParamOrReturnType.ARM64_HFA_FLOAT_4) },
-            { typeof(System.Numerics.Vector2), new TypeInfo(typeof(System.Numerics.Vector2), ParamOrReturnType.ARM64_HFA_FLOAT_2) },
-            { typeof(System.Numerics.Vector3), new TypeInfo(typeof(System.Numerics.Vector3), ParamOrReturnType.ARM64_HFA_FLOAT_3) },
-            { typeof(System.Numerics.Vector4), new TypeInfo(typeof(System.Numerics.Vector4), ParamOrReturnType.ARM64_HFA_FLOAT_4) },
-        };
-
-        public PlatformABI CallConventionType { get; } = PlatformABI.Universal64;
-
-        public override bool IsArch32 => false;
-
-        public override TypeInfo PointerType => TypeInfo.s_i8u8;
-
-        protected override Dictionary<Type, TypeInfo> CacheTypes => s_typeInfoCaches;
-
-        public class HFATypeInfo
-        {
-            public Type Type { get; set; }
-
-            public int Count { get; set; }
-        }
-
-        private static bool IsNotHFAFastCheck(int typeSize)
-        {
-            return typeSize != 8 && typeSize != 12 && typeSize != 16 && typeSize != 24 && typeSize != 32;
-        }
-
-        private static bool ComputHFATypeInfo0(Type type, HFATypeInfo typeInfo)
-        {
-            var fields = type.GetFields(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic);
-            foreach (var field in fields)
-            {
-                Type ftype = field.FieldType;
-                if (ftype != typeof(float) && ftype != typeof(double))
-                {
-                    if (!ftype.IsPrimitive && ftype.IsValueType)
-                    {
-                        if (!ComputHFATypeInfo0(ftype, typeInfo))
-                        {
-                            return false;
-                        }
-                    }
-                    else
-                    {
-                        return false;
-                    }
-                }
-                else if (ftype == typeInfo.Type || typeInfo.Type == null)
-                {
-                    typeInfo.Type = ftype;
-                    ++typeInfo.Count;
-                }
-                else
-                {
-                    return false;
-                }
-            }
-            return typeInfo.Count <= 4;
-        }
-
-        public static bool ComputHFATypeInfo(Type type, int typeSize, out HFATypeInfo typeInfo)
-        {
-            typeInfo = new HFATypeInfo();
-            if (IsNotHFAFastCheck(typeSize))
-            {
-                return false;
-            }
-            bool ok = ComputHFATypeInfo0(type, typeInfo);
-            if (ok && typeInfo.Count >= 2 && typeInfo.Count <= 4)
-            {
-                int fieldSize = typeInfo.Type == typeof(float) ? 4 : 8;
-                return typeSize == fieldSize * typeInfo.Count;
-            }
-            return false;
-        }
-
-        protected override TypeInfo CreateValueType(Type type, bool returnValue)
-        {
-            (int typeSize, int typeAligment) = ComputeSizeAndAligmentOfArch64(type);
-            if (ComputHFATypeInfo(type, typeSize, out HFATypeInfo hfaTypeInfo))
-            {
-                if (hfaTypeInfo.Type == typeof(float))
-                {
-                    switch (hfaTypeInfo.Count)
-                    {
-                        case 2: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_FLOAT_2);
-                        case 3: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_FLOAT_3);
-                        case 4: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_FLOAT_4);
-                        default: throw new NotSupportedException();
-                    }
-                }
-                else
-                {
-                    Debug.Assert(hfaTypeInfo.Type == typeof(double));
-                    switch (hfaTypeInfo.Count)
-                    {
-                        case 2: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_DOUBLE_2);
-                        case 3: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_DOUBLE_3);
-                        case 4: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_DOUBLE_4);
-                        default: throw new NotSupportedException();
-                    }
-                }
-            }
-            else
-            {
-                // 64位下结构体内存对齐规则是一样的
-                return CreateArm64GeneralValueType(type, typeSize,returnValue);
-            }
-
-        }
-
-        private TypeInfo CreateArm64GeneralValueType(Type type, int typeSize, bool returnValue)
-        {
-            if (typeSize <= 8)
-            {
-                return TypeInfo.s_i8u8;
-            }
-            if (typeSize <= 16)
-            {
-                return TypeInfo.s_i16;
-            }
-            if (returnValue)
-            {
-                return new TypeInfo(type, ParamOrReturnType.STRUCTURE_ALIGN1, typeSize);
-            }
-            return TypeInfo.s_ref;
-        }
-
-        public override void GenerateManaged2NativeMethod(MethodBridgeSig method, List<string> lines)
-        {
-            int totalQuadWordNum = method.ParamInfos.Count + method.ReturnInfo.GetParamSlotNum(this.CallConventionType);
-            string paramListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()} __arg{p.Index}").Concat(new string[] { "const MethodInfo* method" }));
-            string paramNameListStr = string.Join(", ", method.ParamInfos.Select(p => p.Managed2NativeParamValue(this.CallConventionType)).Concat(new string[] { "method" }));
-
-            lines.Add($@"
-static void __M2N_{method.CreateCallSigName()}(const MethodInfo* method, uint16_t* argVarIndexs, StackObject* localVarBase, void* ret)
-{{
-    typedef {method.ReturnInfo.Type.GetTypeName()} (*NativeMethod)({paramListStr});
-    {(!method.ReturnInfo.IsVoid ? $"*({method.ReturnInfo.Type.GetTypeName()}*)ret = " : "")}((NativeMethod)(GetInterpreterDirectlyCallMethodPointer(method)))({paramNameListStr});
-}}
-");
-        }
-
-        public override void GenerateNative2ManagedMethod(MethodBridgeSig method, List<string> lines)
-        {
-            int totalQuadWordNum = method.ParamInfos.Count + method.ReturnInfo.GetParamSlotNum(this.CallConventionType);
-            string paramListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()} __arg{p.Index}").Concat(new string[] { "const MethodInfo* method" }));
-            
-            lines.Add($@"
-static {method.ReturnInfo.Type.GetTypeName()} __N2M_{method.CreateCallSigName()}({paramListStr})
-{{
-    StackObject args[{Math.Max(totalQuadWordNum, 1)}] = {{{string.Join(", ", method.ParamInfos.Select(p => p.Native2ManagedParamValue(this.CallConventionType)))} }};
-    StackObject* ret = {(method.ReturnInfo.IsVoid ? "nullptr" : "args + " + method.ParamInfos.Count)};
-    Interpreter::Execute(method, args, ret);
-    {(!method.ReturnInfo.IsVoid ? $"return *({method.ReturnInfo.Type.GetTypeName()}*)ret;" : "")}
-}}
-");
-        }
-
-        public override void GenerateAdjustThunkMethod(MethodBridgeSig method, List<string> lines)
-        {
-            int totalQuadWordNum = method.ParamInfos.Count + method.ReturnInfo.GetParamSlotNum(this.CallConventionType);
-
-            string paramListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()} __arg{p.Index}").Concat(new string[] { "const MethodInfo* method" }));
-
-            lines.Add($@"
-static {method.ReturnInfo.Type.GetTypeName()} __N2M_AdjustorThunk_{method.CreateCallSigName()}({paramListStr})
-{{
-    StackObject args[{Math.Max(totalQuadWordNum, 1)}] = {{{string.Join(", ", method.ParamInfos.Select(p => (p.Index == 0 ? $"(uint64_t)(*(uint8_t**)&__arg{p.Index} + sizeof(Il2CppObject))" : p.Native2ManagedParamValue(this.CallConventionType))))} }};
-    StackObject* ret = {(method.ReturnInfo.IsVoid ? "nullptr" : "args + " + method.ParamInfos.Count)};
-    Interpreter::Execute(method, args, ret);
-    {(!method.ReturnInfo.IsVoid ? $"return *({method.ReturnInfo.Type.GetTypeName()}*)ret;" : "")}
-}}
-");
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Arm64.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: bff17a6e8ee060c4eb9ac97fcf30bf78
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 96
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Universal32.cs

@@ -1,96 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEngine;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-    internal class PlatformAdaptor_Universal32 : PlatformAdaptorBase
-    {
-
-        private static readonly Dictionary<Type, TypeInfo> s_typeInfoCaches = new Dictionary<Type, TypeInfo>()
-        {
-            { typeof(void), new TypeInfo(typeof(void), ParamOrReturnType.VOID)},
-            { typeof(bool), new TypeInfo(typeof(bool), ParamOrReturnType.I1_U1)},
-            { typeof(byte), new TypeInfo(typeof(byte), ParamOrReturnType.I1_U1)},
-            { typeof(sbyte), new TypeInfo(typeof(sbyte), ParamOrReturnType.I1_U1) },
-            { typeof(short), new TypeInfo(typeof(short), ParamOrReturnType.I2_U2) },
-            { typeof(ushort), new TypeInfo(typeof(ushort), ParamOrReturnType.I2_U2) },
-            { typeof(char), new TypeInfo(typeof(char), ParamOrReturnType.I2_U2) },
-            { typeof(int), new TypeInfo(typeof(int), ParamOrReturnType.I4_U4) },
-            { typeof(uint), new TypeInfo(typeof(uint), ParamOrReturnType.I4_U4) },
-            { typeof(long), new TypeInfo(typeof(long), ParamOrReturnType.I8_U8) },
-            { typeof(ulong), new TypeInfo(typeof(ulong), ParamOrReturnType.I8_U8)},
-            { typeof(float), new TypeInfo(typeof(float), ParamOrReturnType.R4)},
-            { typeof(double), new TypeInfo(typeof(double), ParamOrReturnType.R8)},
-            { typeof(IntPtr), new TypeInfo(null, ParamOrReturnType.I4_U4)},
-            { typeof(UIntPtr), new TypeInfo(null, ParamOrReturnType.I4_U4)},
-        };
-
-
-        public PlatformABI CallConventionType { get; } = PlatformABI.Universal32;
-
-        public override bool IsArch32 => true;
-
-        public override TypeInfo PointerType => TypeInfo.s_i4u4;
-
-        protected override Dictionary<Type, TypeInfo> CacheTypes => s_typeInfoCaches;
-
-        protected override TypeInfo CreateValueType(Type type, bool returnValue)
-        {
-            (int typeSize, int typeAligment) = ComputeSizeAndAligmentOfArch32(type);
-            int actualAliment = typeAligment <= 4 ? 1 : 8;
-            return CreateGeneralValueType(type, typeSize, actualAliment);
-        }
-
-        public override void GenerateManaged2NativeMethod(MethodBridgeSig method, List<string> lines)
-        {
-            string paramListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()} __arg{p.Index}").Concat(new string[] { "const MethodInfo* method" }));
-            string paramNameListStr = string.Join(", ", method.ParamInfos.Select(p => p.Managed2NativeParamValue(this.CallConventionType)).Concat(new string[] { "method" }));
-
-            lines.Add($@"
-static void __M2N_{method.CreateCallSigName()}(const MethodInfo* method, uint16_t* argVarIndexs, StackObject* localVarBase, void* ret)
-{{
-    typedef {method.ReturnInfo.Type.GetTypeName()} (*NativeMethod)({paramListStr});
-    {(!method.ReturnInfo.IsVoid ? $"*({method.ReturnInfo.Type.GetTypeName()}*)ret = " : "")}((NativeMethod)(GetInterpreterDirectlyCallMethodPointer(method)))({paramNameListStr});
-}}
-");
-        }
-        public override void GenerateNative2ManagedMethod(MethodBridgeSig method, List<string> lines)
-        {
-            int totalQuadWordNum = method.ParamInfos.Count + method.ReturnInfo.GetParamSlotNum(this.CallConventionType);
-            string paramListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()} __arg{p.Index}").Concat(new string[] { "const MethodInfo* method" }));
-            
-            lines.Add($@"
-static {method.ReturnInfo.Type.GetTypeName()} __N2M_{method.CreateCallSigName()}({paramListStr})
-{{
-    StackObject args[{Math.Max(totalQuadWordNum, 1)}] = {{{string.Join(", ", method.ParamInfos.Select(p => p.Native2ManagedParamValue(this.CallConventionType)))} }};
-    StackObject* ret = {(method.ReturnInfo.IsVoid ? "nullptr" : "args + " + method.ParamInfos.Count)};
-    Interpreter::Execute(method, args, ret);
-    {(!method.ReturnInfo.IsVoid ? $"return *({method.ReturnInfo.Type.GetTypeName()}*)ret;" : "")}
-}}
-");
-        }
-        public override void GenerateAdjustThunkMethod(MethodBridgeSig method, List<string> lines)
-        {
-            int totalQuadWordNum = method.ParamInfos.Count + method.ReturnInfo.GetParamSlotNum(this.CallConventionType);
-
-            string paramListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()} __arg{p.Index}").Concat(new string[] { "const MethodInfo* method" }));
-
-            lines.Add($@"
-static {method.ReturnInfo.Type.GetTypeName()} __N2M_AdjustorThunk_{method.CreateCallSigName()}({paramListStr})
-{{
-    StackObject args[{Math.Max(totalQuadWordNum, 1)}] = {{{string.Join(", ", method.ParamInfos.Select(p => (p.Index == 0 ? $"(uint64_t)(*(uint8_t**)&__arg{p.Index} + sizeof(Il2CppObject))" : p.Native2ManagedParamValue(this.CallConventionType))))} }};
-    StackObject* ret = {(method.ReturnInfo.IsVoid ? "nullptr" : "args + " + method.ParamInfos.Count)};
-    Interpreter::Execute(method, args, ret);
-    {(!method.ReturnInfo.IsVoid ? $"return *({method.ReturnInfo.Type.GetTypeName()}*)ret;" : "")}
-}}
-");
-
-        }
-    }
-
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Universal32.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: fb741900113b22443a2054ddba6b131b
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 189
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Universal64.cs

@@ -1,189 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEngine;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-    internal class PlatformAdaptor_Universal64 : PlatformAdaptorBase
-    {
-
-        private static readonly Dictionary<Type, TypeInfo> s_typeInfoCaches = new Dictionary<Type, TypeInfo>()
-        {
-            { typeof(void), new TypeInfo(typeof(void), ParamOrReturnType.VOID)},
-            { typeof(bool), new TypeInfo(typeof(bool), ParamOrReturnType.I1_U1)},
-            { typeof(byte), new TypeInfo(typeof(byte), ParamOrReturnType.I1_U1)},
-            { typeof(sbyte), new TypeInfo(typeof(sbyte), ParamOrReturnType.I1_U1) },
-            { typeof(short), new TypeInfo(typeof(short), ParamOrReturnType.I2_U2) },
-            { typeof(ushort), new TypeInfo(typeof(ushort), ParamOrReturnType.I2_U2) },
-            { typeof(char), new TypeInfo(typeof(char), ParamOrReturnType.I2_U2) },
-            { typeof(int), new TypeInfo(typeof(int), ParamOrReturnType.I4_U4) },
-            { typeof(uint), new TypeInfo(typeof(uint), ParamOrReturnType.I4_U4) },
-            { typeof(long), new TypeInfo(typeof(long), ParamOrReturnType.I8_U8) },
-            { typeof(ulong), new TypeInfo(typeof(ulong), ParamOrReturnType.I8_U8)},
-            { typeof(float), new TypeInfo(typeof(float), ParamOrReturnType.R4)},
-            { typeof(double), new TypeInfo(typeof(double), ParamOrReturnType.R8)},
-            { typeof(IntPtr), new TypeInfo(null, ParamOrReturnType.I8_U8)},
-            { typeof(UIntPtr), new TypeInfo(null, ParamOrReturnType.I8_U8)},
-            { typeof(Vector2), new TypeInfo(typeof(Vector2), ParamOrReturnType.ARM64_HFA_FLOAT_2) },
-            { typeof(Vector3), new TypeInfo(typeof(Vector3), ParamOrReturnType.ARM64_HFA_FLOAT_3) },
-            { typeof(Vector4), new TypeInfo(typeof(Vector4), ParamOrReturnType.ARM64_HFA_FLOAT_4) },
-            { typeof(System.Numerics.Vector2), new TypeInfo(typeof(System.Numerics.Vector2), ParamOrReturnType.ARM64_HFA_FLOAT_2) },
-            { typeof(System.Numerics.Vector3), new TypeInfo(typeof(System.Numerics.Vector3), ParamOrReturnType.ARM64_HFA_FLOAT_3) },
-            { typeof(System.Numerics.Vector4), new TypeInfo(typeof(System.Numerics.Vector4), ParamOrReturnType.ARM64_HFA_FLOAT_4) },
-        };
-
-        public PlatformABI CallConventionType { get; } = PlatformABI.Universal64;
-
-        public override bool IsArch32 => false;
-
-        public override TypeInfo PointerType => TypeInfo.s_i8u8;
-
-        protected override Dictionary<Type, TypeInfo> CacheTypes => s_typeInfoCaches;
-
-        public class HFATypeInfo
-        {
-            public Type Type { get; set; }
-
-            public int Count { get; set; }
-        }
-
-        private static bool IsNotHFAFastCheck(int typeSize)
-        {
-            return typeSize != 8 && typeSize != 12 && typeSize != 16 && typeSize != 24 && typeSize != 32;
-        }
-
-        private static bool ComputHFATypeInfo0(Type type, HFATypeInfo typeInfo)
-        {
-            var fields = type.GetFields(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic);
-            foreach (var field in fields)
-            {
-                Type ftype = field.FieldType;
-                if (ftype != typeof(float) && ftype != typeof(double))
-                {
-                    if (!ftype.IsPrimitive && ftype.IsValueType)
-                    {
-                        if (!ComputHFATypeInfo0(ftype, typeInfo))
-                        {
-                            return false;
-                        }
-                    }
-                    else
-                    {
-                        return false;
-                    }
-                }
-                else if (ftype == typeInfo.Type || typeInfo.Type == null)
-                {
-                    typeInfo.Type = ftype;
-                    ++typeInfo.Count;
-                }
-                else
-                {
-                    return false;
-                }
-            }
-            return typeInfo.Count <= 4;
-        }
-
-        public static bool ComputHFATypeInfo(Type type, int typeSize, out HFATypeInfo typeInfo)
-        {
-            typeInfo = new HFATypeInfo();
-            if (IsNotHFAFastCheck(typeSize))
-            {
-                return false;
-            }
-            bool ok = ComputHFATypeInfo0(type, typeInfo);
-            if (ok && typeInfo.Count >= 2 && typeInfo.Count <= 4)
-            {
-                int fieldSize = typeInfo.Type == typeof(float) ? 4 : 8;
-                return typeSize == fieldSize * typeInfo.Count;
-            }
-            return false;
-        }
-
-        protected override TypeInfo CreateValueType(Type type, bool returnValue)
-        {
-            (int typeSize, int typeAligment) = ComputeSizeAndAligmentOfArch64(type);
-            if (ComputHFATypeInfo(type, typeSize, out HFATypeInfo hfaTypeInfo))
-            {
-                if (hfaTypeInfo.Type == typeof(float))
-                {
-                    switch (hfaTypeInfo.Count)
-                    {
-                        case 2: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_FLOAT_2);
-                        case 3: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_FLOAT_3);
-                        case 4: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_FLOAT_4);
-                        default: throw new NotSupportedException();
-                    }
-                }
-                else
-                {
-                    Debug.Assert(hfaTypeInfo.Type == typeof(double));
-                    switch (hfaTypeInfo.Count)
-                    {
-                        case 2: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_DOUBLE_2);
-                        case 3: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_DOUBLE_3);
-                        case 4: return new TypeInfo(type, ParamOrReturnType.ARM64_HFA_DOUBLE_4);
-                        default: throw new NotSupportedException();
-                    }
-                }
-            }
-            else
-            {
-                // 64位下结构体内存对齐规则是一样的
-                return CreateGeneralValueType(type, typeSize, 1 /*typeAligment*/);
-            }
-
-        }
-
-        public override void GenerateManaged2NativeMethod(MethodBridgeSig method, List<string> lines)
-        {
-            int totalQuadWordNum = method.ParamInfos.Count + method.ReturnInfo.GetParamSlotNum(this.CallConventionType);
-
-            string paramListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()} __arg{p.Index}").Concat(new string[] { "const MethodInfo* method" }));
-            string paramTypeListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()}").Concat(new string[] { "const MethodInfo*" })); ;
-            string paramNameListStr = string.Join(", ", method.ParamInfos.Select(p => p.Managed2NativeParamValue(this.CallConventionType)).Concat(new string[] { "method" }));
-
-            lines.Add($@"
-static void __M2N_{method.CreateCallSigName()}(const MethodInfo* method, uint16_t* argVarIndexs, StackObject* localVarBase, void* ret)
-{{
-    typedef {method.ReturnInfo.Type.GetTypeName()} (*NativeMethod)({paramListStr});
-    {(!method.ReturnInfo.IsVoid ? $"*({method.ReturnInfo.Type.GetTypeName()}*)ret = " : "")}((NativeMethod)(GetInterpreterDirectlyCallMethodPointer(method)))({paramNameListStr});
-}}
-");
-        }
-        public override void GenerateNative2ManagedMethod(MethodBridgeSig method, List<string> lines)
-        {
-            int totalQuadWordNum = method.ParamInfos.Count + method.ReturnInfo.GetParamSlotNum(this.CallConventionType);
-            string paramListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()} __arg{p.Index}").Concat(new string[] { "const MethodInfo* method" }));
-            lines.Add($@"
-static {method.ReturnInfo.Type.GetTypeName()} __N2M_{method.CreateCallSigName()}({paramListStr})
-{{
-    StackObject args[{Math.Max(totalQuadWordNum, 1)}] = {{{string.Join(", ", method.ParamInfos.Select(p => p.Native2ManagedParamValue(this.CallConventionType)))} }};
-    StackObject* ret = {(method.ReturnInfo.IsVoid ? "nullptr" : "args + " + method.ParamInfos.Count)};
-    Interpreter::Execute(method, args, ret);
-    {(!method.ReturnInfo.IsVoid ? $"return *({method.ReturnInfo.Type.GetTypeName()}*)ret;" : "")}
-}}
-");
-        }
-
-        public override void GenerateAdjustThunkMethod(MethodBridgeSig method, List<string> lines)
-        {
-            int totalQuadWordNum = method.ParamInfos.Count + method.ReturnInfo.GetParamSlotNum(this.CallConventionType);
-            string paramListStr = string.Join(", ", method.ParamInfos.Select(p => $"{p.Type.GetTypeName()} __arg{p.Index}").Concat(new string[] { "const MethodInfo* method" }));
-            lines.Add($@"
-static {method.ReturnInfo.Type.GetTypeName()} __N2M_AdjustorThunk_{method.CreateCallSigName()}({paramListStr})
-{{
-    StackObject args[{Math.Max(totalQuadWordNum, 1)}] = {{{string.Join(", ", method.ParamInfos.Select(p => (p.Index == 0 ? $"(uint64_t)(*(uint8_t**)&__arg{p.Index} + sizeof(Il2CppObject))" : p.Native2ManagedParamValue(this.CallConventionType))))} }};
-    StackObject* ret = {(method.ReturnInfo.IsVoid ? "nullptr" : "args + " + method.ParamInfos.Count)};
-    Interpreter::Execute(method, args, ret);
-    {(!method.ReturnInfo.IsVoid ? $"return *({method.ReturnInfo.Type.GetTypeName()}*)ret;" : "")}
-}}
-");
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/PlatformAdaptor_Universal64.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 26324be9505c9f54996bcbb62ba49132
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 19
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/SignatureProviderAttribute.cs

@@ -1,19 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-    [AttributeUsage(AttributeTargets.Method)]
-    public class SignatureProviderAttribute : Attribute
-    {
-        public List<PlatformABI> Platforms { get; }
-
-        public SignatureProviderAttribute(params PlatformABI[] platforms)
-        {
-            Platforms = new List<PlatformABI>(platforms);
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/SignatureProviderAttribute.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 50c5ec2d43d3fda4a8b8cfa75cb37a74
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 132
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/TypeInfo.cs

@@ -1,132 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Reflection;
-using UnityEngine;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-    public class TypeInfo : IEquatable<TypeInfo>
-    {
-
-        public static readonly TypeInfo s_void = new TypeInfo(typeof(void), ParamOrReturnType.VOID);
-        public static readonly TypeInfo s_i4u4 = new TypeInfo(null, ParamOrReturnType.I4_U4);
-        public static readonly TypeInfo s_i8u8 = new TypeInfo(null, ParamOrReturnType.I8_U8);
-        public static readonly TypeInfo s_i16 = new TypeInfo(null, ParamOrReturnType.I16);
-        public static readonly TypeInfo s_ref = new TypeInfo(null, ParamOrReturnType.STRUCTURE_AS_REF_PARAM);
-
-        public TypeInfo(Type type, ParamOrReturnType portype)
-        {
-            this.Type = type;
-            PorType = portype;
-            Size = 0;
-        }
-
-        public TypeInfo(Type type, ParamOrReturnType portype, int size)
-        {
-            this.Type = type;
-            PorType = portype;
-            Size = size;
-        }
-
-        public Type Type { get; }
-
-        public ParamOrReturnType PorType { get; }
-
-        public int Size { get; }
-
-        public bool Equals(TypeInfo other)
-        {
-            return PorType == other.PorType && Size == other.Size;
-        }
-
-        public override bool Equals(object obj)
-        {
-            return Equals((TypeInfo)obj);
-        }
-
-        public override int GetHashCode()
-        {
-            return (int)PorType * 23 + Size;
-        }
-
-        public string CreateSigName()
-        {
-            return PorType switch
-            {
-                ParamOrReturnType.VOID => "v",
-                ParamOrReturnType.I1_U1 => "i1",
-                ParamOrReturnType.I2_U2 => "i2",
-                ParamOrReturnType.I4_U4 => "i4",
-                ParamOrReturnType.I8_U8 => "i8",
-                ParamOrReturnType.R4 => "r4",
-                ParamOrReturnType.R8 => "r8",
-                ParamOrReturnType.I16 => "i16",
-                ParamOrReturnType.STRUCTURE_AS_REF_PARAM => "sr",
-                ParamOrReturnType.ARM64_HFA_FLOAT_2 => "vf2",
-                ParamOrReturnType.ARM64_HFA_FLOAT_3 => "vf3",
-                ParamOrReturnType.ARM64_HFA_FLOAT_4 => "vf4",
-                ParamOrReturnType.ARM64_HFA_DOUBLE_2 => "vd2",
-                ParamOrReturnType.ARM64_HFA_DOUBLE_3 => "vd3",
-                ParamOrReturnType.ARM64_HFA_DOUBLE_4 => "vd4",
-                ParamOrReturnType.STRUCTURE_ALIGN1 => "S" + Size,
-                ParamOrReturnType.STRUCTURE_ALIGN2 => "A" + Size,
-                ParamOrReturnType.STRUCTURE_ALIGN4 => "B" + Size,
-                ParamOrReturnType.STRUCTURE_ALIGN8 => "C" + Size,
-                _ => throw new NotSupportedException(PorType.ToString()),
-            };
-        }
-
-        public string GetTypeName()
-        {
-            return PorType switch
-            {
-                ParamOrReturnType.VOID => "void",
-                ParamOrReturnType.I1_U1 => "int8_t",
-                ParamOrReturnType.I2_U2 => "int16_t",
-                ParamOrReturnType.I4_U4 => "int32_t",
-                ParamOrReturnType.I8_U8 => "int64_t",
-                ParamOrReturnType.R4 => "float",
-                ParamOrReturnType.R8 => "double",
-                ParamOrReturnType.I16 => "ValueTypeSize16",
-                ParamOrReturnType.STRUCTURE_AS_REF_PARAM => "uint64_t",
-                ParamOrReturnType.ARM64_HFA_FLOAT_2 => "HtVector2f",
-                ParamOrReturnType.ARM64_HFA_FLOAT_3 => "HtVector3f",
-                ParamOrReturnType.ARM64_HFA_FLOAT_4 => "HtVector4f",
-                ParamOrReturnType.ARM64_HFA_DOUBLE_2 => "HtVector2d",
-                ParamOrReturnType.ARM64_HFA_DOUBLE_3 => "HtVector3d",
-                ParamOrReturnType.ARM64_HFA_DOUBLE_4 => "HtVector4d",
-                ParamOrReturnType.STRUCTURE_ALIGN1 => $"ValueTypeSize<{Size}>",
-                ParamOrReturnType.STRUCTURE_ALIGN2 => $"ValueTypeSizeAlign2<{Size}>",
-                ParamOrReturnType.STRUCTURE_ALIGN4 => $"ValueTypeSizeAlign4<{Size}>",
-                ParamOrReturnType.STRUCTURE_ALIGN8 => $"ValueTypeSizeAlign8<{Size}>",
-                _ => throw new NotImplementedException(PorType.ToString()),
-            };
-        }
-        public int GetParamSlotNum()
-        {
-            switch (PorType)
-            {
-                case ParamOrReturnType.VOID: return 0;
-                case ParamOrReturnType.I16: return 2;
-                case ParamOrReturnType.STRUCTURE_AS_REF_PARAM: return 1;
-                case ParamOrReturnType.ARM64_HFA_FLOAT_3: return 2;
-                case ParamOrReturnType.ARM64_HFA_FLOAT_4: return 2;
-                case ParamOrReturnType.ARM64_HFA_DOUBLE_2: return 2;
-                case ParamOrReturnType.ARM64_HFA_DOUBLE_3: return 3;
-                case ParamOrReturnType.ARM64_HFA_DOUBLE_4: return 4;
-                case ParamOrReturnType.ARM64_HVA_8:
-                case ParamOrReturnType.ARM64_HVA_16: throw new NotSupportedException();
-                case ParamOrReturnType.STRUCTURE_ALIGN1:
-                case ParamOrReturnType.STRUCTURE_ALIGN2:
-                case ParamOrReturnType.STRUCTURE_ALIGN4:
-                case ParamOrReturnType.STRUCTURE_ALIGN8: return (Size + 7) / 8;
-                default:
-                    {
-                        Debug.Assert(PorType < ParamOrReturnType.STRUCT_NOT_PASS_AS_VALUE);
-                        Debug.Assert(Size <= 8);
-                        return 1;
-                    }
-            }
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/TypeInfo.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 5afd7344483678a4abcb56158fd1442d
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 148
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ValueTypeSizeAligmentCalculator.cs

@@ -1,148 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Reflection;
-using System.Runtime.InteropServices;
-using System.Text;
-using System.Threading.Tasks;
-
-namespace HybridCLR.Generators.MethodBridge
-{
-
-
-	public class ValueTypeSizeAligmentCalculator
-	{
-		private static Dictionary<string, int> s_primitives = new Dictionary<string, int>(14) {
-			{ "Byte", 1 },
-			{ "SByte", 1 },
-			{ "Boolean", 1 },
-			{ "Int16", 2 },
-			{ "UInt16", 2 },
-			{ "Char", 2 },
-			{ "Int32", 4 },
-			{ "UInt32", 4 },
-			{ "Single", 4 },
-			{ "Int64", 8 },
-			{ "UInt64", 8 },
-			{ "Double", 8 },
-			//{ "IntPtr", _referenceSize },	// so rule return the same results
-			//{ "UIntPtr", _referenceSize },	// on 32 and 64 bits architectures
-		};
-
-		public ValueTypeSizeAligmentCalculator(bool arch32)
-        {
-			_referenceSize = arch32 ? 4 : 8;
-        }
-
-		// actually we should use IntPtr.Size but that would make the rule
-		// return different results on 64 bits systems
-		private readonly int _referenceSize;
-
-		// Note: Needs to be public since this is being tested by our unit tests
-
-
-		private static bool IsIgnoreField(FieldInfo field)
-        {
-			var ignoreAttr = field.GetCustomAttributes().Where(a => a.GetType().Name == "IgnoreAttribute").FirstOrDefault();
-			if (ignoreAttr == null)
-            {
-				return false;
-            }
-
-			var p = ignoreAttr.GetType().GetProperty("DoesNotContributeToSize");
-			return (bool)p.GetValue(ignoreAttr);
-		}
-
-		private (int Size, int Aligment) SizeAndAligmentOfStruct(Type type)
-		{
-			int totalSize = 0;
-			int packAligment = 8;
-			int maxAligment = 1;
-
-			StructLayoutAttribute sa = type.StructLayoutAttribute;
-			if (sa != null && sa.Pack > 0)
-            {
-				packAligment = sa.Pack;
-            }
-			bool useSLSize = true;
-			foreach (FieldInfo field in type.GetFields(BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic))
-			{
-				// add size of the type
-				var (fs, fa) = SizeAndAligmentOf(field.FieldType);
-				fa = Math.Min(fa, packAligment);
-				if (fa > maxAligment)
-                {
-					maxAligment = fa;
-				}
-				if (IsIgnoreField(field))
-				{
-					continue;
-				}
-				if (sa != null && sa.Value == LayoutKind.Explicit)
-				{
-					int offset = field.GetCustomAttribute<FieldOffsetAttribute>().Value;
-					totalSize = Math.Max(totalSize, offset + fs);
-					if (offset > sa.Size)
-					{
-						useSLSize = false;
-					}
-                }
-				else
-				{
-					if (totalSize % fa != 0)
-					{
-						totalSize = (totalSize + fa - 1) / fa * fa;
-					}
-					totalSize += fs;
-					if (sa != null && sa.Value == LayoutKind.Sequential && totalSize > sa.Size)
-                    {
-						useSLSize = false;
-                    }
-				}
-			}
-			if (totalSize == 0)
-            {
-				totalSize = maxAligment;
-			}
-			if (totalSize % maxAligment != 0)
-			{
-				totalSize = (totalSize + maxAligment - 1) / maxAligment * maxAligment;
-			}
-			if (sa != null && sa.Size > 0)
-			{
-				if (/*sa.Value == LayoutKind.Explicit &&*/ useSLSize)
-				{
-					totalSize = sa.Size;
-					while(totalSize % maxAligment != 0)
-                    {
-						maxAligment /= 2;
-                    }
-				}
-			}
-			return (totalSize, maxAligment);
-		}
-
-		public (int Size, int Aligment) SizeAndAligmentOf(Type type)
-		{
-			if (type.IsByRef || !type.IsValueType || type.IsArray)
-				return (_referenceSize, _referenceSize);
-
-			// list based on Type.IsPrimitive
-			if (type.Namespace == "System")
-			{
-				if (s_primitives.TryGetValue(type.Name, out var size))
-				{
-					return (size, size);
-				}
-				if (type.Name == "IntPtr" || type.Name == "UIntPtr")
-                {
-					return (_referenceSize, _referenceSize);
-                }
-			}
-			if (type.IsEnum)
-				return SizeAndAligmentOf(type.GetEnumUnderlyingType());
-
-			return SizeAndAligmentOfStruct(type);
-		}
-	}
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/MethodBridge/ValueTypeSizeAligmentCalculator.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 49b3dbcebadb1b543a42e01afec07ed1
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 38
GameClient/Assets/Editor/HybridCLR/Generators/TemplateUtil.cs

@@ -1,38 +0,0 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
-
-namespace HybridCLR.Generators
-{
-    public static class TemplateUtil
-    {
-        public static string EscapeIntegerName(int i)
-        {
-            return i >= 0 ? i.ToString() : "minus" + (-i);
-        }
-
-        public static string ReplaceRegion(string resultText, string region, string replaceContent)
-        {
-            int startIndex = resultText.IndexOf("//!!!{{" + region);
-            if (startIndex == -1)
-            {
-                throw new Exception($"region:{region} start not find");
-            }
-            int endIndex = resultText.IndexOf("//!!!}}" + region);
-            if (endIndex == -1)
-            {
-                throw new Exception($"region:{region} end not find");
-            }
-            int replaceStart = resultText.IndexOf('\n', startIndex);
-            int replaceEnd = resultText.LastIndexOf('\n', endIndex);
-            if (replaceStart == -1 || replaceEnd == -1)
-            {
-                throw new Exception($"region:{region} not find");
-            }
-            resultText = resultText.Substring(0, replaceStart) + "\n" + replaceContent + "\n" + resultText.Substring(replaceEnd);
-            return resultText;
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/Generators/TemplateUtil.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 32ec2cc1cf5c468468308fa6308fba19
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 8
GameClient/Assets/Editor/HybridCLR/Generators/Templates.meta

@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: 3a1563e7820e5b648a6a6691677f564c
-folderAsset: yes
-DefaultImporter:
-  externalObjects: {}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 22
GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Arm64.cpp

@@ -1,22 +0,0 @@
-#include "MethodBridge.h"
-
-#include <codegen/il2cpp-codegen-metadata.h>
-#include "vm/ClassInlines.h"
-#include "vm/Object.h"
-#include "vm/Class.h"
-
-#include "../metadata/MetadataModule.h"
-#include "../metadata/MetadataUtil.h"
-
-#include "Interpreter.h"
-#include "MemoryUtil.h"
-#include "InstrinctDef.h"
-
-using namespace hybridclr::interpreter;
-using hybridclr::GetInterpreterDirectlyCallMethodPointer;
-
-#if HYBRIDCLR_ABI_ARM_64
-//!!!{{INVOKE_STUB
-
-//!!!}}INVOKE_STUB
-#endif

+ 0 - 27
GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Arm64.cpp.meta

@@ -1,27 +0,0 @@
-fileFormatVersion: 2
-guid: 7e694feed8374f94380fe48bb70e9be1
-PluginImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  iconMap: {}
-  executionOrder: {}
-  defineConstraints: []
-  isPreloaded: 0
-  isOverridable: 0
-  isExplicitlyReferenced: 0
-  validateReferences: 1
-  platformData:
-  - first:
-      Any: 
-    second:
-      enabled: 0
-      settings: {}
-  - first:
-      Editor: Editor
-    second:
-      enabled: 1
-      settings:
-        DefaultValueInitialized: true
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 22
GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Universal32.cpp

@@ -1,22 +0,0 @@
-#include "MethodBridge.h"
-
-#include <codegen/il2cpp-codegen-metadata.h>
-#include "vm/ClassInlines.h"
-#include "vm/Object.h"
-#include "vm/Class.h"
-
-#include "../metadata/MetadataModule.h"
-#include "../metadata/MetadataUtil.h"
-
-#include "Interpreter.h"
-#include "MemoryUtil.h"
-#include "InstrinctDef.h"
-
-using namespace hybridclr::interpreter;
-using hybridclr::GetInterpreterDirectlyCallMethodPointer;
-
-#if HYBRIDCLR_ABI_UNIVERSAL_32
-//!!!{{INVOKE_STUB
-
-//!!!}}INVOKE_STUB
-#endif

+ 0 - 27
GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Universal32.cpp.meta

@@ -1,27 +0,0 @@
-fileFormatVersion: 2
-guid: 27135a158cd4b5049966f6f46d15ab10
-PluginImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  iconMap: {}
-  executionOrder: {}
-  defineConstraints: []
-  isPreloaded: 0
-  isOverridable: 0
-  isExplicitlyReferenced: 0
-  validateReferences: 1
-  platformData:
-  - first:
-      Any: 
-    second:
-      enabled: 0
-      settings: {}
-  - first:
-      Editor: Editor
-    second:
-      enabled: 1
-      settings:
-        DefaultValueInitialized: true
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 22
GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Universal64.cpp

@@ -1,22 +0,0 @@
-#include "MethodBridge.h"
-
-#include <codegen/il2cpp-codegen-metadata.h>
-#include "vm/ClassInlines.h"
-#include "vm/Object.h"
-#include "vm/Class.h"
-
-#include "../metadata/MetadataModule.h"
-#include "../metadata/MetadataUtil.h"
-
-#include "Interpreter.h"
-#include "MemoryUtil.h"
-#include "InstrinctDef.h"
-
-using namespace hybridclr::interpreter;
-using hybridclr::GetInterpreterDirectlyCallMethodPointer;
-
-#if HYBRIDCLR_ABI_UNIVERSAL_64
-//!!!{{INVOKE_STUB
-
-//!!!}}INVOKE_STUB
-#endif

+ 0 - 27
GameClient/Assets/Editor/HybridCLR/Generators/Templates/MethodBridge_Universal64.cpp.meta

@@ -1,27 +0,0 @@
-fileFormatVersion: 2
-guid: ca76fdf59c873e441aa5043ad00d4537
-PluginImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  iconMap: {}
-  executionOrder: {}
-  defineConstraints: []
-  isPreloaded: 0
-  isOverridable: 0
-  isExplicitlyReferenced: 0
-  validateReferences: 1
-  platformData:
-  - first:
-      Any: 
-    second:
-      enabled: 0
-      settings: {}
-  - first:
-      Editor: Editor
-    second:
-      enabled: 1
-      settings:
-        DefaultValueInitialized: true
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 119
GameClient/Assets/Editor/HybridCLR/MethodBridgeHelper.cs

@@ -1,119 +0,0 @@
-using HybridCLR.Generators;
-using HybridCLR.Generators.MethodBridge;
-using System;
-using System.Collections.Generic;
-using System.IO;
-using System.Linq;
-using System.Reflection;
-using System.Text;
-using System.Threading.Tasks;
-using UnityEditor;
-using UnityEngine;
-
-namespace HybridCLR
-{
-    internal class MethodBridgeHelper
-    {
-
-        private static void CleanIl2CppBuildCache()
-        {
-            string il2cppBuildCachePath = BuildConfig.Il2CppBuildCacheDir;
-            if (!Directory.Exists(il2cppBuildCachePath))
-            {
-                return;
-            }
-            Debug.Log($"clean il2cpp build cache:{il2cppBuildCachePath}");
-            Directory.Delete(il2cppBuildCachePath, true);
-        }
-
-        private static List<Assembly> CollectDependentAssemblies(Dictionary<string, Assembly> allAssByName, List<Assembly> dlls)
-        {
-            for(int i = 0; i < dlls.Count; i++)
-            {
-                Assembly ass = dlls[i];
-                foreach (var depAssName in ass.GetReferencedAssemblies())
-                {
-                    if (!allAssByName.ContainsKey(depAssName.Name))
-                    {
-                        Debug.Log($"ignore ref assembly:{depAssName.Name}");
-                        continue;
-                    }
-                    Assembly depAss = allAssByName[depAssName.Name];
-                    if (!dlls.Contains(depAss))
-                    {
-                        dlls.Add(depAss);
-                    }
-                }
-            }
-            return dlls;
-        }
-
-        private static List<Assembly> GetScanAssembiles()
-        {
-            var allAssByName = new Dictionary<string, Assembly>();
-            foreach(var ass in AppDomain.CurrentDomain.GetAssemblies())
-            {
-                allAssByName[ass.GetName().Name] = ass;
-            }
-            //CompileDllHelper.CompileDllActiveBuildTarget();
-
-            var rootAssemblies = BuildConfig.AllHotUpdateDllNames
-                .Select(dll => Path.GetFileNameWithoutExtension(dll)).Concat(GeneratorConfig.GetExtraAssembiles())
-                .Where(name => allAssByName.ContainsKey(name)).Select(name => allAssByName[name]).ToList();
-            //var rootAssemblies = GeneratorConfig.GetExtraAssembiles()
-            //    .Where(name => allAssByName.ContainsKey(name)).Select(name => allAssByName[name]).ToList();
-            CollectDependentAssemblies(allAssByName, rootAssemblies);
-            rootAssemblies.Sort((a, b) => a.GetName().Name.CompareTo(b.GetName().Name));
-            Debug.Log($"assembly count:{rootAssemblies.Count}");
-            foreach(var ass in rootAssemblies)
-            {
-                Debug.Log($"scan assembly:{ass.GetName().Name}");
-            }
-            return rootAssemblies;
-        }
-
-        private static void GenerateMethodBridgeCppFile(PlatformABI platform, string fileName)
-        {
-            string outputFile = $"{BuildConfig.MethodBridgeCppDir}/{fileName}.cpp";
-            var g = new MethodBridgeGenerator(new MethodBridgeGeneratorOptions()
-            {
-                CallConvention = platform,
-                HotfixAssemblies = BuildConfig.AllHotUpdateDllNames.Select(name =>
-                    AppDomain.CurrentDomain.GetAssemblies().First(ass => ass.GetName().Name + ".dll" == name)).ToList(),
-                AllAssemblies = GetScanAssembiles(),
-                OutputFile = outputFile,
-            });
-
-            g.PrepareMethods();
-            g.Generate();
-            Debug.LogFormat("== output:{0} ==", outputFile);
-            CleanIl2CppBuildCache();
-        }
-
-        [MenuItem("HybridCLR/MethodBridge/Arm64")]
-        public static void MethodBridge_Arm64()
-        {
-            GenerateMethodBridgeCppFile(PlatformABI.Arm64, "MethodBridge_Arm64");
-        }
-
-        [MenuItem("HybridCLR/MethodBridge/Universal64")]
-        public static void MethodBridge_Universal64()
-        {
-            GenerateMethodBridgeCppFile(PlatformABI.Universal64, "MethodBridge_Universal64");
-        }
-
-        [MenuItem("HybridCLR/MethodBridge/Universal32")]
-        public static void MethodBridge_Universal32()
-        {
-            GenerateMethodBridgeCppFile(PlatformABI.Universal32, "MethodBridge_Universal32");
-        }
-
-        [MenuItem("HybridCLR/MethodBridge/All")]
-        public static void MethodBridge_All()
-        {
-            GenerateMethodBridgeCppFile(PlatformABI.Arm64, "MethodBridge_Arm64");
-            GenerateMethodBridgeCppFile(PlatformABI.Universal64, "MethodBridge_Universal64");
-            GenerateMethodBridgeCppFile(PlatformABI.Universal32, "MethodBridge_Universal32");
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/MethodBridgeHelper.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 18beea79433bdce44af834574cd9c212
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 8
GameClient/Assets/Editor/HybridCLR/UnityBinFileReader.meta

@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: e52fb09e14efee949ae80ae8aa9f9d44
-folderAsset: yes
-DefaultImporter:
-  externalObjects: {}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 107
GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinFile.cs

@@ -1,107 +0,0 @@
-using System.Collections;
-using System.Collections.Generic;
-using System.IO;
-using UnityEngine;
-using System.Text;
-using System.Reflection;
-using System;
-using System.Linq;
-
-namespace HybridCLR.Editor.GlobalManagers
-{
-    /// <summary>
-    /// Unity 生成的二进制文件(本代码不支持5.x之前的版本)
-    /// </summary>
-    public unsafe class UnityBinFile
-    {
-        /*
-         * MonoManager: idx: 6;
-         * type: metaData.types[objects[6].typeID]
-         */
-        public const int kMonoManagerIdx = 6;
-
-        public string path { get; private set; }
-
-        public FileHeader header;
-        public MetaData metaData;
-        public ScriptsData scriptsData;
-
-        public void LoadFromFile(string path)
-        {
-            this.path = path;
-
-            var fs = new FileStream(path, FileMode.Open, FileAccess.Read);
-            var br = new BinaryReader(fs, Encoding.UTF8, true);
-            
-            header.LoadFromStream(br);
-            // 按理说 metaData 应该新开一个buffer来避免加载时的对齐逻辑问题,但由于 sizeof(Header) = 20,已经对齐到4了,所以可以连续读
-            metaData.LoadFromStream(br, header.dataOffset);
-            scriptsData = metaData.GetScriptData(br);
-
-            br.Close();
-            fs.Close();
-        }
-
-        public void RebuildAndFlushToFile(string newPath)
-        {
-            var fsR = new FileStream(path, FileMode.Open, FileAccess.Read);
-            var brR = new BinaryReader(fsR, Encoding.UTF8, true);
-
-            var ms = new MemoryStream((int)(header.fileSize * 1.5f));
-            var bw = new BinaryWriter(ms, Encoding.UTF8, true);
-
-            /*
-             * 开始写入data
-             * dll名称列表存储于 data 区段,修改其数据并不会影响 MetaData 大小,因此 dataOffset 不会改变
-             */
-            ms.Position = header.dataOffset;
-
-            Dictionary<long, ObjectInfo> newObjInfos = new Dictionary<long, ObjectInfo>();
-            foreach (var kv in metaData.objects)
-            {
-                long objID = kv.Key;
-                ObjectInfo objInfo = kv.Value;
-
-                byte[] buff = new byte[objInfo.size];
-                fsR.Position = objInfo.realPos;
-                brR.Read(buff, 0, buff.Length);
-
-
-                {// unity 的数据偏移貌似会对齐到 8
-                    int newPos = (((int)ms.Position + 7) >> 3) << 3;
-                    int gapSize = newPos - (int)ms.Position;
-                    
-                    for (int i = 0; i < gapSize; i++)
-                        bw.Write((byte)0);
-                    
-                    objInfo.dataPos = (uint)ms.Position - header.dataOffset; // 重定位数据偏移
-                }
-
-                if (objID != kMonoManagerIdx)
-                    bw.Write(buff, 0, buff.Length);
-                else
-                    objInfo.size = (uint)scriptsData.SaveToStream(bw);
-
-                newObjInfos.Add(objID, objInfo);
-            }
-
-            metaData.objects = newObjInfos;
-            header.fileSize = (uint)ms.Position;
-
-            ms.Position = 0;
-            header.SaveToStream(bw);
-            metaData.SaveToStream(bw);
-
-            brR.Close();
-            fsR.Close();
-
-            // 写入新文件
-            ms.Position = 0;
-            File.WriteAllBytes(newPath, ms.ToArray());
-            
-            bw.Close();
-            ms.Close();
-        }
-    }
-
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinFile.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: ae7ec6e3674077d46898fe821d24bf85
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 397
GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinFileDefines.cs

@@ -1,397 +0,0 @@
-using System.Collections;
-using System.Collections.Generic;
-using System.IO;
-using UnityEngine;
-using static HybridCLR.Editor.GlobalManagers.UnityBinUtils;
-
-namespace HybridCLR.Editor.GlobalManagers
-{
-    public struct FileHeader
-    {
-        public const int kSize = 20;
-
-        public uint dataSize => fileSize - metadataSize;
-
-        public uint metadataSize;
-        public uint fileSize;
-        public uint version;
-        public uint dataOffset;
-        public byte endianess;
-
-        public void LoadFromStream(BinaryReader br)
-        {
-            long startPos = br.BaseStream.Position;
-            metadataSize = br.ReadUInt32();
-            fileSize = br.ReadUInt32();
-            version = br.ReadUInt32();
-            dataOffset = br.ReadUInt32();
-            endianess = br.ReadByte();
-            br.BaseStream.Position = startPos + kSize;
-
-            SwapEndianess();
-        }
-
-        public long SaveToStream(BinaryWriter bw)
-        {
-            SwapEndianess();
-
-            long startPos = bw.BaseStream.Position;
-            bw.Write(metadataSize);
-            bw.Write(fileSize);
-            bw.Write(version);
-            bw.Write(dataOffset);
-            bw.Write(endianess);
-            bw.BaseStream.Position = startPos + kSize;
-            return kSize;
-        }
-
-        void SwapEndianess()
-        {
-            SwapUInt(ref metadataSize);
-            SwapUInt(ref fileSize);
-            SwapUInt(ref version);
-            SwapUInt(ref dataOffset);
-        }
-    }
-
-    public struct MetaData
-    {
-        public long dataStartPos;
-
-        public string version;
-        public uint platform;
-        public bool enableTypeTree;
-        public int typeCount;
-        public ObjectType[] types;
-        public int objectCount;
-        public Dictionary<long, ObjectInfo> objects;
-        public int scriptTypeCount;
-        public ScriptType[] scriptTypes;
-        public int externalsCount;
-        public ExternalInfo[] externals;
-
-#if UNITY_2019_2_OR_NEWER
-        public int refTypeCount;
-        public ObjectType[] refTypes;
-#endif
-        public string dummyStr;
-
-        public void LoadFromStream(BinaryReader br, uint dataOffset)
-        {
-            long startPos = br.BaseStream.Position;
-            dataStartPos = startPos;
-
-            version = br.ReadRawString();
-            platform = br.ReadUInt32();
-            enableTypeTree = br.ReadBoolean();
-            typeCount = br.ReadInt32();
-            types = new ObjectType[typeCount];
-
-            for (int i = 0; i < typeCount; i++)
-            {
-                types[i].LoadFromStream(br);
-            }
-
-            objectCount = br.ReadInt32();
-            objects = new Dictionary<long, ObjectInfo>();
-            for(int i = 0; i < objectCount; i++)
-            {
-                long id = br.AlignedReadInt64();
-                ObjectInfo objInfo = new ObjectInfo();
-                objInfo.LoadFromStream(br);
-                objInfo.realPos = objInfo.dataPos + dataOffset;
-
-                objects.Add(id, objInfo);
-            }
-
-            scriptTypeCount = br.ReadInt32();
-            scriptTypes = new ScriptType[scriptTypeCount];
-            for(int i = 0; i < scriptTypeCount; i++)
-            {
-                scriptTypes[i].LoadFromStream(br);
-            }
-
-            externalsCount = br.ReadInt32();
-            externals = new ExternalInfo[externalsCount];
-            for(int i = 0; i < externalsCount; i++)
-            {
-                externals[i].LoadFromStream(br);
-            }
-
-#if UNITY_2019_2_OR_NEWER
-            refTypeCount = br.ReadInt32();
-            refTypes = new ObjectType[refTypeCount];
-            for(int i = 0; i < refTypeCount; i++)
-            {
-                refTypes[i].LoadFromStream(br);
-            }
-#endif
-            dummyStr = br.ReadRawString();
-        }
-
-        public long SaveToStream(BinaryWriter bw)
-        {
-            long startPos = bw.BaseStream.Position;
-            bw.WriteRawString(version);
-            bw.Write(platform);
-            bw.Write(enableTypeTree);
-            
-            bw.Write(typeCount);
-            foreach(var type in types)
-                type.SaveToStream(bw);
-
-            bw.Write(objectCount);
-            foreach (var kv in objects)
-            {
-                bw.AlignedWriteInt64(kv.Key);
-                kv.Value.SaveToStream(bw);
-            }
-                
-            bw.Write(scriptTypeCount);
-            foreach(var st in scriptTypes)
-                st.SaveToStream(bw);
-
-            bw.Write(externalsCount);
-            foreach(var external in externals)
-                external.SaveToStream(bw);
-
-#if UNITY_2019_2_OR_NEWER
-            bw.Write(refTypeCount);
-            foreach(var refT in refTypes)
-                refT.SaveToStream(bw);
-#endif
-
-            bw.WriteRawString(dummyStr);
-
-            return bw.BaseStream.Position - startPos;
-        }
-
-        public ScriptsData GetScriptData(BinaryReader br)
-        {
-            ObjectInfo objInfo = objects[UnityBinFile.kMonoManagerIdx];
-            br.BaseStream.Seek(objInfo.realPos, SeekOrigin.Begin);
-
-            ScriptsData data = new ScriptsData();
-            data.LoadFromStream(br);
-            return data;
-        }
-    }
-
-    public struct ObjectType
-    {
-        public int typeID;
-        public bool isStriped;
-        public short scriptTypeIndex;
-
-        public bool needReadScriptHash; // dont save
-
-        public Hash scriptSigHash;
-        public Hash typeHash;
-
-        public void LoadFromStream(BinaryReader br)
-        {
-            typeID = br.ReadInt32();
-            isStriped = br.ReadBoolean();
-            scriptTypeIndex = br.ReadInt16();
-
-            needReadScriptHash = typeID == -1 || typeID == 0x72;
-            if(needReadScriptHash)
-                scriptSigHash.LoadFromStream(br);
-
-            typeHash.LoadFromStream(br);
-
-            // GlobalManagers does not has TypeTrees
-        }
-
-        public long SaveToStream(BinaryWriter bw)
-        {
-            long startPos = bw.BaseStream.Position;
-            bw.Write(typeID);
-            bw.Write(isStriped);
-            bw.Write(scriptTypeIndex);
-            
-            if(needReadScriptHash)
-                scriptSigHash.SaveToStream(bw);
-
-            typeHash.SaveToStream(bw);
-            return bw.BaseStream.Position - startPos;
-        }
-
-        public int Size()
-        {
-            int ret = 0;
-            ret += sizeof(int);
-            ret += sizeof(bool);
-            ret += sizeof(short);
-
-            if (needReadScriptHash)
-                ret += Hash.kSize;
-
-            ret += Hash.kSize;
-            return ret;
-        }
-    }
-
-    public struct ObjectInfo
-    {
-        public const int kSize = 12;
-
-        public uint dataPos;
-        public uint size;
-        public uint typeID;
-
-        public uint realPos; // dataPos + Header.dataOffset; // dont save
-
-        public void LoadFromStream(BinaryReader br)
-        {
-            dataPos = br.ReadUInt32();
-            size = br.ReadUInt32();
-            typeID = br.ReadUInt32();
-        }
-
-        public long SaveToStream(BinaryWriter bw)
-        {
-            bw.Write(dataPos);
-            bw.Write(size);
-            bw.Write(typeID);
-            return kSize;
-        }
-    }
-
-    public struct ScriptType
-    {
-        public int localFileIndex;
-        public long localIdentifierOfBin;
-
-        public void LoadFromStream(BinaryReader br)
-        {
-            localFileIndex = br.ReadInt32();
-            localIdentifierOfBin = br.AlignedReadInt64();
-        }
-
-        public long SaveToStream(BinaryWriter bw)
-        {
-            long startPos = bw.BaseStream.Position;
-            bw.Write(localFileIndex);
-            bw.AlignedWriteInt64(localIdentifierOfBin);
-            return bw.BaseStream.Position - startPos;
-        }
-    }
-
-    public struct ExternalInfo
-    {
-        public string dummy;
-        public Hash guid;
-        public int type;
-        public string name;
-        
-        public void LoadFromStream(BinaryReader br)
-        {
-            dummy = br.ReadRawString();
-            guid.LoadFromStream(br);
-            type = br.ReadInt32();
-            name = br.ReadRawString();
-        }
-
-        public long SaveToStream(BinaryWriter bw)
-        {
-            long startPos = bw.BaseStream.Position;
-            bw.WriteRawString(dummy);
-            guid.SaveToStream(bw);
-            bw.Write(type);
-            bw.WriteRawString(name);
-            return bw.BaseStream.Position - startPos;
-        }
-    }
-
-    public struct ScriptsData
-    {
-        public ScriptID[] scriptIDs;
-        public List<string> dllNames;
-        public List<int> dllTypes; // 16 is user type
-
-        public void LoadFromStream(BinaryReader br)
-        {
-            {
-                int count = br.ReadInt32();
-                scriptIDs = new ScriptID[count];
-                for(int i = 0; i < count; i++)
-                    scriptIDs[i].LoadFromStream(br);
-            }
-            {
-                int count = br.ReadInt32();
-                dllNames = new List<string>(count);
-                for (var i = 0; i < count; i++)
-                    dllNames.Add(br.ReadSizeString());
-            }
-            {
-                int count = br.ReadInt32();
-                dllTypes = new List<int>(count);
-                for(var i = 0; i < count; i++)
-                    dllTypes.Add(br.ReadInt32());
-            }
-        }
-
-        public long SaveToStream(BinaryWriter bw)
-        {
-            long startPos = bw.BaseStream.Position;
-            bw.Write(scriptIDs.Length);
-            for(int i = 0; i < scriptIDs.Length; i++)
-                scriptIDs[i].SaveToStream(bw);
-
-            bw.Write(dllNames.Count);
-            for(int i = 0, imax = dllNames.Count; i < imax; i++)
-                bw.WriteSizeString(dllNames[i]);
-
-            bw.Write(dllTypes.Count);
-            for(int i = 0, imax = dllTypes.Count; i < imax; i++)
-                bw.Write(dllTypes[i]);
-
-            return bw.BaseStream.Position - startPos;
-        }
-    }
-
-    public struct ScriptID
-    {
-        public int fileID;
-        public long pathID; // localIdentifier
-
-        public void LoadFromStream(BinaryReader br)
-        {
-            fileID = br.ReadInt32();
-            pathID = br.ReadInt64();
-        }
-
-        public long SaveToStream(BinaryWriter bw)
-        {
-            bw.Write(fileID);
-            bw.Write(pathID);
-            return 4 + 8;
-        }
-    }
-
-    public struct Hash
-    {
-        public const int kSize = 16;
-
-        public int[] data;
-
-        public void LoadFromStream(BinaryReader br)
-        {
-            data = new int[4];
-            for(int i = 0; i < data.Length; i++)
-            {
-                data[i] = br.ReadInt32();
-            }
-        }
-
-        public long SaveToStream(BinaryWriter bw)
-        {
-            for(int i = 0; i < data.Length; i++)
-            {
-                bw.Write(data[i]);
-            }
-            return kSize;
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinFileDefines.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: 96788c7fe08d5d54d95a87cfbdcb643a
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 78
GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinUtils.cs

@@ -1,78 +0,0 @@
-using System.Collections;
-using System.Collections.Generic;
-using System.IO;
-using UnityEngine;
-using System.Text;
-
-namespace HybridCLR.Editor.GlobalManagers
-{
-    public static class UnityBinUtils
-    {
-        public static void SwapUInt(ref uint val)
-        {
-            val = (val >> 24) | ((val >> 8) & 0x0000ff00) | ((val << 8) & 0x00ff0000) | (val << 24);
-        }
-
-        public static string ReadRawString(this BinaryReader br)
-        {
-            long startPos = br.BaseStream.Position;
-            while (true)
-            {
-                byte val = br.ReadByte();
-                if(val == 0)
-                    break;
-            }
-            int size = (int)(br.BaseStream.Position - startPos);
-            br.BaseStream.Position = startPos;
-
-            byte[] buffer = br.ReadBytes(size);
-            string ret = Encoding.UTF8.GetString(buffer, 0, size - 1);
-
-            return ret;
-        }
-
-        public static void WriteRawString(this BinaryWriter bw, string str)
-        {
-            byte[] buffer = Encoding.UTF8.GetBytes(str);
-            bw.Write(buffer, 0, buffer.Length);
-            bw.Write((byte)0);
-        }
-
-        public static string ReadSizeString(this BinaryReader br)
-        {
-            int size = br.ReadInt32();
-            byte[] buff = br.ReadBytes(size);
-            br.BaseStream.AlignOffset4();
-
-            string ret = Encoding.UTF8.GetString(buff);
-            return ret;
-        }
-
-        public static void WriteSizeString(this BinaryWriter bw, string str)
-        {
-            byte[] buff = Encoding.UTF8.GetBytes(str);
-            bw.Write(buff.Length);
-            bw.Write(buff, 0, buff.Length);
-            bw.BaseStream.AlignOffset4();
-        }
-
-        public static void AlignOffset4(this Stream stream)
-        {
-            int offset = (((int)stream.Position + 3) >> 2) << 2;
-            stream.Position = offset;
-        }
-
-        public static long AlignedReadInt64(this BinaryReader br)
-        {
-            br.BaseStream.AlignOffset4();
-            return br.ReadInt64();
-        }
-
-        public static void AlignedWriteInt64(this BinaryWriter bw, long val)
-        {
-            bw.BaseStream.AlignOffset4();
-            bw.Write(val);
-        }
-    }
-}
-

+ 0 - 11
GameClient/Assets/Editor/HybridCLR/UnityBinFileReader/UnityBinUtils.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: bf7c4cf970660614fb54d838ec6e7eda
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 8
GameClient/Assets/Editor/HybridCLRExtension.meta

@@ -1,8 +0,0 @@
-fileFormatVersion: 2
-guid: d5bbd9914301c1c468f85eac21ecf29c
-folderAsset: yes
-DefaultImporter:
-  externalObjects: {}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 45
GameClient/Assets/Editor/HybridCLRExtension/DllHelper.cs

@@ -1,45 +0,0 @@
-using System.IO;
-using UnityEditor;
-using UnityEngine;
-using HybridCLR;
-
-namespace GFGEditor
-{
-    public static class DllHelper
-    {
-        public static void BuildDll(string codeDir, BuildTarget target)
-        {
-            Directory.CreateDirectory(codeDir);
-            CompileDllHelper.CompileDll(target);
-
-            string hotfixDllSrcDir = BuildConfig.GetHotFixDllsOutputDirByTarget(target);
-            foreach (var dll in BuildConfig.AllHotUpdateDllNames)
-            {
-                string dllPath = $"{hotfixDllSrcDir}/{dll}";
-                string dllBytesPath = $"{codeDir}/{dll}.bytes";
-                File.Copy(dllPath, dllBytesPath, true);
-            }
-
-            AssetDatabase.Refresh(ImportAssetOptions.ForceUpdate);
-        }
-        public static void CopyAOTDll(string codeDir, BuildTarget target)
-        {
-            Directory.CreateDirectory(codeDir);
-
-            string aotDllDir = BuildConfig.GetAssembliesPostIl2CppStripDir(target);
-            foreach (var dll in BuildConfig.AOTMetaDlls)
-            {
-                string dllPath = $"{aotDllDir}/{dll}";
-                if (!File.Exists(dllPath))
-                {
-                    Debug.LogError($"ab中添加AOT补充元数据dll:{dllPath} 时发生错误,文件不存在。裁剪后的AOT dll在BuildPlayer时才能生成,因此需要你先构建一次游戏App后再打包。");
-                    continue;
-                }
-                string dllBytesPath = $"{codeDir}/{dll}.bytes";
-                File.Copy(dllPath, dllBytesPath, true);
-            }
-
-            AssetDatabase.Refresh(ImportAssetOptions.ForceUpdate);
-        }
-    }
-}

+ 0 - 11
GameClient/Assets/Editor/HybridCLRExtension/DllHelper.cs.meta

@@ -1,11 +0,0 @@
-fileFormatVersion: 2
-guid: ac11ce918afbf234d8d8d011dbd76639
-MonoImporter:
-  externalObjects: {}
-  serializedVersion: 2
-  defaultReferences: []
-  executionOrder: 0
-  icon: {instanceID: 0}
-  userData: 
-  assetBundleName: 
-  assetBundleVariant: 

+ 0 - 3
GameClient/Assets/Editor/Xasset/Builds/BuildTask.cs

@@ -4,7 +4,6 @@ using System.IO;
 using GFGEditor;
 using UnityEditor;
 using UnityEngine;
-using GFGGame;
 
 namespace VEngine.Editor.Builds
 {
@@ -78,8 +77,6 @@ namespace VEngine.Editor.Builds
 
         public void BuildCustomBundles(string[] resRootDirNames, string setName)
         {
-            DllHelper.BuildDll(LauncherConfig.DllDirHotfix, EditorUserBuildSettings.activeBuildTarget);
-            DllHelper.CopyAOTDll(LauncherConfig.DllDirAOT, EditorUserBuildSettings.activeBuildTarget);
             foreach (var resRootDirName in resRootDirNames)
             {
                 CreateBundles(resRootDirName, setName);

+ 3 - 1
GameClient/Assets/Game/HotUpdate/Game.HotUpdate.asmdef

@@ -6,7 +6,9 @@
         "GUID:7a41fac89c3ce014e99efb3723e6a98e",
         "GUID:7b430a36dc40f416cbc65566155a0e56"
     ],
-    "includePlatforms": [],
+    "includePlatforms": [
+        "Editor"
+    ],
     "excludePlatforms": [],
     "allowUnsafeCode": true,
     "overrideReferences": false,

+ 0 - 47
GameClient/Assets/Game/HotUpdate/HotUpdateEntry.cs

@@ -2,7 +2,6 @@
 using ET;
 using FairyGUI;
 using System;
-using System.Collections.Generic;
 using UnityEngine;
 namespace GFGGame.HotUpdate
 {
@@ -11,11 +10,6 @@ namespace GFGGame.HotUpdate
 
         public static void Start()
         {
-            Log.Debug("HotUpdateEntry Start 1");
-#if !UNITY_EDITOR
-            LoadMetadataForAOTAssembly();
-#endif
-            Log.Debug("HotUpdateEntry Start 2");
             VEngine.Logger.Loggable = false;
             //ET
             try
@@ -33,48 +27,7 @@ namespace GFGGame.HotUpdate
             {
                 Log.Error(e);
             }
-            Log.Debug("HotUpdateEntry Start 3");
             GameController.Start();
-            Log.Debug("HotUpdateEntry Start 4");
-        }
-
-        /// <summary>
-        /// 为aot assembly加载原始metadata, 这个代码放aot或者热更新都行。
-        /// 一旦加载后,如果AOT泛型函数对应native实现不存在,则自动替换为解释模式执行
-        /// </summary>
-        public static unsafe void LoadMetadataForAOTAssembly()
-        {
-            // 可以加载任意aot assembly的对应的dll。但要求dll必须与unity build过程中生成的裁剪后的dll一致,而不能直接使用原始dll。
-            // 我们在BuildProcessor_xxx里添加了处理代码,这些裁剪后的dll在打包时自动被复制到 {项目目录}/HybridCLRData/AssembliesPostIl2CppStrip/{Target} 目录。
-
-            /// 注意,补充元数据是给AOT dll补充元数据,而不是给热更新dll补充元数据。
-            /// 热更新dll不缺元数据,不需要补充,如果调用LoadMetadataForAOTAssembly会返回错误
-            /// 
-            List<string> aotDllList = new List<string>
-            {
-                "mscorlib.dll",
-                "System.dll",
-                "System.Core.dll", // 如果使用了Linq,需要这个
-                "ThirdParty.dll",
-                "Game.Launcher.dll",
-                // "Newtonsoft.Json.dll",
-                // "protobuf-net.dll",
-                // "Google.Protobuf.dll",
-                // "MongoDB.Bson.dll",
-                // "DOTween.Modules.dll",
-                // "UniTask.dll",
-            };
-
-            foreach (var aotDllName in aotDllList)
-            {
-                byte[] dllBytes = GFGAsset.Load<TextAsset>($"{LauncherConfig.DllDirAOT}{aotDllName}.bytes").bytes;
-                fixed (byte* ptr = dllBytes)
-                {
-                    // 加载assembly对应的dll,会自动为它hook。一旦aot泛型函数的native函数不存在,用解释器版本代码
-                    int err = HybridCLR.RuntimeApi.LoadMetadataForAOTAssembly((IntPtr)ptr, dllBytes.Length);
-                    Debug.Log($"LoadMetadataForAOTAssembly:{aotDllName}. ret:{err}");
-                }
-            }
         }
 
     }

+ 13 - 24
GameClient/Assets/Game/Launcher/HotUpdateProxy/HotUpdateCodeLoader.cs

@@ -3,7 +3,6 @@ using System.Collections;
 using System.Reflection;
 using UnityEngine;
 using GFGGame.Launcher;
-using System.Linq;
 
 namespace GFGGame
 {
@@ -22,41 +21,31 @@ namespace GFGGame
         }
 
 
-        private System.Reflection.Assembly gameAss;
         IEnumerator StartLoadAssemblyHotfix()
         {
             LogServerHelperHttp.SendNodeLog((int)LogNode.StartLoadGameDll);
             //ET.Log.Debug("ILRuntimeLauncher StartLoadAssemblyHotfix");
             yield return new WaitForSeconds(0.1f);
-#if !UNITY_EDITOR
-            LoadAssemblyJustInTime();
-#else
-            gameAss = AppDomain.CurrentDomain.GetAssemblies().First(assembly => assembly.GetName().Name == "Game.HotUpdate");
-#endif
-
-            RunMain();
-        }
-
-        private void LoadAssemblyJustInTime()
-        {
             var dllPath = $"{LauncherConfig.DllDirHotfix}Game.HotUpdate.dll.bytes";
             var asset = GFGAsset.Load<TextAsset>(dllPath);
             byte[] assBytes = asset.bytes;
-            gameAss = Assembly.Load(assBytes);
+            var pdbPath = $"{LauncherConfig.DllDirHotfix}Game.HotUpdate.pdb.bytes";
+            asset = GFGAsset.Load<TextAsset>(pdbPath);
+            byte[] pdbBytes = asset.bytes;
+            StartCoroutine(LoadAssemblyJustInTime(assBytes, pdbBytes));
             GFGAsset.Release(dllPath);
+            GFGAsset.Release(pdbPath);
         }
 
-        public void RunMain()
+        IEnumerator LoadAssemblyJustInTime(byte[] assBytes, byte[] pdbBytes)
         {
-            if (gameAss == null)
-            {
-                UnityEngine.Debug.LogError("dll未加载");
-                return;
-            }
-            this.allTypes = gameAss.GetTypes();
-            var appType = gameAss.GetType("GFGGame.HotUpdate.HotUpdateEntry");
-            var mainMethod = appType.GetMethod("Start");
-            mainMethod.Invoke(null, null);
+            //mono模式
+            var assembly = Assembly.Load(assBytes, pdbBytes);
+            this.allTypes = assembly.GetTypes();
+            System.Type type = assembly.GetType("GFGGame.HotUpdate.HotUpdateEntry");
+            type.GetMethod("Start").Invoke(type, null);
+            yield break;
         }
+
     }
 }

+ 0 - 22
GameClient/HybridCLRData/README.md

@@ -1,22 +0,0 @@
-# 使用说明
-
-这个目录主要包含
-
-- huatuo相关仓库
-- 本地il2cpp目录
-- 其他生成的目录
-
-## 安装huatuo
-
-正常情况下,安装huatuo需要替换Unity安装目录下libil2cpp目录为huatuo版本的实现,但Unity允许使用环境变量UNITY_IL2CPP_PATH自定义%IL2CPP_PATH%的位置。
-因此我们不修改原始的il2cpp目录,直接在本地创建huatuo版本的il2cpp,并让环境变量指向它
-
-安装流程
-
-- 酌情修改 init_local_il2cpp_data.bat(或.sh)文件中代码
-  - `set IL2CPP_BRANCH=2020.3.33` 改成你的版本(目前只有2020.3.33或2021.3.1)
-  - `set IL2CPP_PATH=<你的Unity editor的il2cpp目录的路径>` 改成你的Unity安装目录
-- 运行 init_local_il2cpp_data.bat 或.sh 文件 创建本地il2cpp目录,即 LocalIl2CppData 目录。
-
-如果看到初始化成功,表示运行成功。否则请参照文档,对应 .bat或.sh文件,自己查找错误原因。
-

+ 0 - 88
GameClient/HybridCLRData/iOSBuild/CMakeLists.txt

@@ -1,88 +0,0 @@
-# file: CMakeList.txt
-cmake_minimum_required(VERSION 3.0)
-set(CMAKE_OSX_DEPLOYMENT_TARGET iOS)
-
-set(TMP $ENV{HUATUO_IL2CPP_SOURCE_DIR})
-if ( NOT TMP )
-    message(FATAL_ERROR "需要设置环境变量: HUATUO_IL2CPP_SOURCE_DIR")
-else()
-    message(STATUS "unity il2cpp 路径为: ${TMP}")
-endif()
-
-set(SDK_VERSION $ENV{IPHONESIMULATOR_VERSION})
-if ( SDK_VERSION )
-    message(STATUS "使用iPhoneSimulator版本:" ${SDK_VERSION})
-else()
-    message(STATUS "当前使用默认版本的iPhoneSimulator,可以通过设置环境变量IPHONESIMULATOR_VERSION,指定版本")
-endif()
-
-project(il2cpp)
-execute_process(COMMAND sh gen_lump.sh ${PROJECT_BINARY_DIR} WORKING_DIRECTORY ${CMAKE_SOURCE_DIR})
-
-add_subdirectory(external)
-add_subdirectory(objective)
-
-
-set(IL2CPP_SOURCE_DIR $ENV{HUATUO_IL2CPP_SOURCE_DIR})
-
-message(STATUS "il2cpp project, binary dir: " ${CMAKE_BINARY_DIR})
-message(STATUS "il2cpp project, build dir: " ${PROJECT_BINARY_DIR})
-message(STATUS "il2cpp project, il2cpp source dir: " ${IL2CPP_SOURCE_DIR})
-
-
-SET_PROPERTY(GLOBAL PROPERTY USE_FOLDERS ON)
-find_program(CLANG_EXECUTABLE NAMES clang clang-7 clang-8 clang-9 clang-10)
-if (NOT CLANG_EXECUTABLE)
-    message(FATAL_ERROR "Cannot find any clang executable.")
-endif()
-
-
-set(CMAKE_OSX_SYSROOT /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator${SDK_VERSION}.sdk)
-
-#set(CMAKE_VERBOSE_MAKEFILE ON)
-set(CMAKE_CXX_COMPILER clang++)
-set(CMAKE_C_COMPILER clang)
-#add_compile_options(-x objective-c++)
-
-# 以下命令为复制的Xcode生成中的命令
-set(CMAKE_CXX_FLAGS "-target arm64-apple-ios11.0 -fmessage-length=0 -fdiagnostics-show-note-include-stack -fmacro-backtrace-limit=0 -std=gnu++1z -fmodules -fmodules-prune-interval=86400 -fmodules-prune-after=345600 -fmodules-ignore-macro=IL2CPP_TARGET_IOS=1 -fembed-bitcode -fmodules-ignore-macro=BASELIB_DYNAMICLIBRARY=1 -fmodules-ignore-macro=BASELIB_INLINE_NAMESPACE=il2cpp_baselib -fmodules-ignore-macro=AARCH64 -fmodules-ignore-macro=__aarch64__ -fmodules-ignore-macro=IL2CPP_SUPPORT_THREADS -fmodules-ignore-macro=IL2CPP_THREADS_PTHREAD -Wnon-modular-include-in-framework-module -Werror=non-modular-include-in-framework-module -Wno-trigraphs -fpascal-strings -Os -fno-common -Wno-missing-field-initializers -Wno-missing-prototypes -Werror=return-type -Wdocumentation -Wunreachable-code -Wquoted-include-in-framework-header -Werror=deprecated-objc-isa-usage -Werror=objc-root-class -Wno-non-virtual-dtor -Wno-overloaded-virtual -Wno-exit-time-destructors -Wno-missing-braces -Wparentheses -Wswitch -Wno-unused-function -Wno-unused-label -Wno-unused-parameter -Wno-unused-variable -Wunused-value -Wempty-body -Wuninitialized -Wconditional-uninitialized -Wno-unknown-pragmas -Wno-shadow -Wno-four-char-constants -Wno-conversion -Wconstant-conversion -Wint-conversion -Wbool-conversion -Wenum-conversion -Wno-float-conversion -Wnon-literal-null-conversion -Wobjc-literal-conversion -Wshorten-64-to-32 -Wno-newline-eof -Wno-c++11-extensions -DIL2CPP_TARGET_IOS=1 -isysroot ${CMAKE_OSX_SYSROOT} -fasm-blocks -fstrict-aliasing -Wdeprecated-declarations -Winvalid-offsetof -g -Wno-sign-conversion -Winfinite-recursion -Wmove -Wcomma -Wblock-capture-autoreleasing -Wstrict-prototypes -Wrange-loop-analysis -Wno-semicolon-before-method-body -Wunguarded-availability ")
-
-
-add_definitions(-DIL2CPP_TARGET_IOS=1)
-add_definitions(-DBASELIB_DYNAMICLIBRARY=1)
-add_definitions(-DBASELIB_INLINE_NAMESPACE=il2cpp_baselib)
-add_definitions(-DAARCH64)
-add_definitions(-D__aarch64__)
-add_definitions(-DIL2CPP_SUPPORT_THREADS)
-add_definitions(-DIL2CPP_THREADS_PTHREAD)
-#add_definitions(-DCMAKE_C_COMPILER=/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang)
-#add_definitions(-DCMAKE_CXX_COMPILER=/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang++)
-#add_definitions(-DIL2CPP_TARGET_DARWIN)
-add_definitions(-DIL2CPP_PLATFORM_SUPPORTS_TIMEZONEINFO)
-
-add_definitions(-MMD)
-add_definitions(-MT dependencies)
-
-
-include_directories(${IL2CPP_SOURCE_DIR}/libil2cpp/)
-include_directories(${IL2CPP_SOURCE_DIR}/external/)
-include_directories(${IL2CPP_SOURCE_DIR}/external/baselib/Include/)
-include_directories(${IL2CPP_SOURCE_DIR}/external/bdwgc/include/)
-include_directories(${IL2CPP_SOURCE_DIR}/external/baselib/Platforms/OSX/Include/)
-
-# 修改为本机对应SDK路径
-include_directories(SYSTEM /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator.sdk/usr/include/c++/v1)
-include_directories(SYSTEM /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator.sdk/usr/include)
-
-aux_source_directory(${PROJECT_BINARY_DIR}/lump_cpp LUMP_SOURCE_LIST)
-aux_source_directory(${IL2CPP_SOURCE_DIR}/libil2cpp LIBIL2CPP_SOURCE_LIST)
-
-#find_library(zlib ${PROJECT_SOURCE_DIR}/external)
-add_library(il2cpp_original STATIC ${LIBIL2CPP_SOURCE_LIST} ${LUMP_SOURCE_LIST})
-add_dependencies(il2cpp_original external objective)
-
-add_custom_command(TARGET il2cpp_original 
-    POST_BUILD
-    COMMAND xcrun -r libtool -static -o libil2cpp.a libil2cpp_original.a external/libexternal.a objective/libobjective.a
-    COMMENT "post build this is command combine libil2cpp_original.a, libojjective.a and libzlib.a into libil2cpp"
-    )

+ 0 - 19
GameClient/HybridCLRData/iOSBuild/build_libil2cpp.sh

@@ -1,19 +0,0 @@
-#!/bin/bash
-
-export HUATUO_IL2CPP_SOURCE_DIR=$(pushd ../LocalIl2CppData/il2cpp > /dev/null && pwd && popd > /dev/null)
-export IPHONESIMULATOR_VERSION=
-
-rm -rf build
-
-mkdir build
-cd build
-cmake ..
-make -j4
-
-if [ -f "libil2cpp.a" ]
-then
-	echo 'build succ'
-else
-    echo "build fail"
-    exit 1
-fi

+ 0 - 47
GameClient/HybridCLRData/iOSBuild/external/CMakeLists.txt

@@ -1,47 +0,0 @@
-# file: external/CMakeList.txt
-cmake_minimum_required(VERSION 3.0)
-set(CMAKE_OSX_DEPLOYMENT_TARGET iOS)
-
-set(IL2CPP_SOURCE_DIR $ENV{HUATUO_IL2CPP_SOURCE_DIR})
-set(SDK_VERSION $ENV{IPHONESIMULATOR_VERSION})
-
-message(STATUS "external project, external source dir: " ${IL2CPP_SOURCE_DIR})
-
-SET_PROPERTY(GLOBAL PROPERTY USE_FOLDERS ON)
-
-find_program(CLANG_EXECUTABLE NAMES clang clang-7 clang-8 clang-9 clang-10)
-if (NOT CLANG_EXECUTABLE)
-    message(FATAL_ERROR "Cannot find any clang executable.")
-endif()
-
-set(CMAKE_OSX_SYSROOT /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator${SDK_VERSION}.sdk)
-set(CMAKE_VERBOSE_MAKEFILE ON)
-set(CMAKE_C_COMPILER clang)
-
-set(CMAKE_C_FLAGS "-x c -target arm64-apple-ios11.0 -fmessage-length=0 -fdiagnostics-show-note-include-stack -fmacro-backtrace-limit=0 -std=gnu11 -fmodules -fmodules-prune-interval=86400 -fmodules-prune-after=345600 -fmodules-ignore-macro=IL2CPP_TARGET_IOS=1 -fembed-bitcode -fmodules-ignore-macro=BASELIB_DYNAMICLIBRARY=1 -fmodules-ignore-macro=BASELIB_INLINE_NAMESPACE=il2cpp_baselib -fmodules-ignore-macro=AARCH64 -fmodules-ignore-macro=__aarch64__ -fmodules-ignore-macro=IL2CPP_SUPPORT_THREADS -fmodules-ignore-macro=IL2CPP_THREADS_PTHREAD -Wnon-modular-include-in-framework-module -Werror=non-modular-include-in-framework-module -Wno-trigraphs -fpascal-strings -Os -fno-common -Wno-missing-field-initializers -Wno-missing-prototypes -Werror=return-type -Wdocumentation -Wunreachable-code -Wquoted-include-in-framework-header -Werror=deprecated-objc-isa-usage -Werror=objc-root-class -Wno-missing-braces -Wparentheses -Wswitch -Wunused-function -Wno-unused-label -Wno-unused-parameter -Wunused-variable -Wunused-value -Wempty-body -Wuninitialized -Wconditional-uninitialized -Wno-unknown-pragmas -Wno-shadow -Wno-four-char-constants -Wno-conversion -Wconstant-conversion -Wint-conversion -Wbool-conversion -Wenum-conversion -Wno-float-conversion -Wnon-literal-null-conversion -Wobjc-literal-conversion -Wshorten-64-to-32 -Wpointer-sign -Wno-newline-eof -DIL2CPP_TARGET_IOS=1 -isysroot ${CMAKE_OSX_SYSROOT} -fstrict-aliasing -Wdeprecated-declarations -g -Wno-sign-conversion -Winfinite-recursion -Wcomma -Wblock-capture-autoreleasing -Wstrict-prototypes -Wno-semicolon-before-method-body -Wunguarded-availability")
-
-
-add_definitions(-DIL2CPP_TARGET_IOS=1)
-add_definitions(-DBASELIB_DYNAMICLIBRARY=1)
-add_definitions(-DBASELIB_INLINE_NAMESPACE=il2cpp_baselib)
-add_definitions(-DAARCH64)
-add_definitions(-D__aarch64__)
-#add_definitions(-D__arm64__)
-add_definitions(-DIL2CPP_SUPPORT_THREADS)
-add_definitions(-DIL2CPP_THREADS_PTHREAD)
-#add_definitions(-DCMAKE_C_COMPILER=/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang)
-#add_definitions(-DCMAKE_CXX_COMPILER=/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang++)
-#add_definitions(-DIL2CPP_TARGET_DARWIN)
-add_definitions(-DIL2CPP_PLATFORM_SUPPORTS_TIMEZONEINFO=0)
-
-add_definitions(-MMD)
-add_definitions(-MT dependencies)
-
-include_directories(${IL2CPP_SOURCE_DIR}/external/)
-include_directories(${IL2CPP_SOURCE_DIR}/external/baselib/Include/)
-include_directories(${IL2CPP_SOURCE_DIR}/external/bdwgc/include/)
-include_directories(${IL2CPP_SOURCE_DIR}/external/baselib/Platforms/OSX/Include/)
-
-aux_source_directory(${IL2CPP_SOURCE_DIR}/external/zlib/ ZLIB_C_SOURCE_LIST)
-add_library(external STATIC ${ZLIB_C_SOURCE_LIST})
-

+ 0 - 64
GameClient/HybridCLRData/iOSBuild/gen_lump.sh

@@ -1,64 +0,0 @@
-echo '====================================================================='
-echo 'gen lump'
-echo '$HUATUO_IL2CPP_SOURCE_DIR='${HUATUO_IL2CPP_SOURCE_DIR}   #/Applications/Unity/Unity.app/Contents/il2cpp/
-
-GEN_SOURCE_DIR=$1
-BASE_DIR=${HUATUO_IL2CPP_SOURCE_DIR}/libil2cpp
-echo base dir: ${BASE_DIR}
-echo " "
-#BASE_DIR=${HUATUO_IL2CPP_SOURCE_DIR}/libil2cpp
-function SearchCppFile()
-{
-    for f in $(ls $1)
-    do
-        SUB_DIR=$1/$f
-        if [ -d ${SUB_DIR} ]; then
-            SearchCppFile ${SUB_DIR}
-        fi
-    done
-
-    CPP_FILE_NUM=`ls -l $1/ | grep "\.cpp$"|wc -l`
-    if (( ${CPP_FILE_NUM} > 0 ))
-    then
-        for f in $1/*.cpp
-        do
-            echo "#include \""$f"\"" >> ${OUTPUT_FILE_NAME}
-        done
-    fi
-
-    MM_FILE_NUM=`ls -l $1/ | grep "\.mm$"|wc -l`
-    if (( ${MM_FILE_NUM} > 0 ))
-    then
-        for f in $1/*.mm
-        do
-            echo "#include \""$f"\"" >> ${OBJECTIVE_FILE_NAME}
-        done
-    fi
-}
-
-rm -rf ${GEN_SOURCE_DIR}/lump_cpp
-rm -rf ${GEN_SOURCE_DIR}/lump_mm
-mkdir ${GEN_SOURCE_DIR}/lump_cpp
-mkdir ${GEN_SOURCE_DIR}/lump_mm
-
-OBJECTIVE_FILE_NAME=${GEN_SOURCE_DIR}/lump_mm/lump_libil2cpp_ojective.mm
-echo "#include \"${BASE_DIR}/il2cpp-config.h\"" > ${OBJECTIVE_FILE_NAME}
-echo gen file: ${OBJECTIVE_FILE_NAME}
-
-for FOLDER in hybridclr vm pch utils vm-utils codegen metadata os debugger mono gc icalls
-do
-    OUTPUT_FILE_NAME=${GEN_SOURCE_DIR}/lump_cpp/lump_libil2cpp_${FOLDER}.cpp
-    echo "#include \"${BASE_DIR}/il2cpp-config.h\"" > ${OUTPUT_FILE_NAME}
-    if  [ $FOLDER = hybridclr ] || [ $FOLDER = vm ]
-    then
-        echo "#include \"${BASE_DIR}/codegen/il2cpp-codegen.h\"" >> ${OUTPUT_FILE_NAME}
-    fi
-    SearchCppFile ${BASE_DIR}/${FOLDER}
-    echo gen file: ${OUTPUT_FILE_NAME}
-done
-
-echo gen done.
-echo '====================================================================='
-echo " "
-
-

+ 0 - 62
GameClient/HybridCLRData/iOSBuild/objective/CMakeLists.txt

@@ -1,62 +0,0 @@
-# file: CMakeList.txt
-cmake_minimum_required(VERSION 3.0)
-set(CMAKE_OSX_DEPLOYMENT_TARGET iOS)
-project(il2cpp)
-
-set(IL2CPP_SOURCE_DIR $ENV{HUATUO_IL2CPP_SOURCE_DIR})
-set(SDK_VERSION $ENV{IPHONESIMULATOR_VERSION})
-
-message(STATUS "objective project, binary dir: " ${PROJECT_BINARY_DIR})
-message(STATUS "objective project, il2cpp source dir: " ${PROJECT_SOURCE_DIR})
-
-
-SET_PROPERTY(GLOBAL PROPERTY USE_FOLDERS ON)
-find_program(CLANG_EXECUTABLE NAMES clang clang-7 clang-8 clang-9 clang-10)
-if (NOT CLANG_EXECUTABLE)
-    message(FATAL_ERROR "Cannot find any clang executable.")
-endif()
-
-
-set(CMAKE_OSX_SYSROOT /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator${SDK_VERSION}.sdk)
-
-set(CMAKE_VERBOSE_MAKEFILE ON)
-set(CMAKE_CXX_COMPILER clang++)
-set(CMAKE_C_COMPILER clang)
-#add_compile_options(-x objective-c++)
-
-# 以下命令为复制的Xcode生成中的命令
-set(CMAKE_CXX_FLAGS "-target arm64-apple-ios11.0 -fmessage-length=0 -fdiagnostics-show-note-include-stack -fmacro-backtrace-limit=0 -std=gnu++1z -fmodules -fmodules-prune-interval=86400 -fmodules-prune-after=345600 -fmodules-ignore-macro=IL2CPP_TARGET_IOS=1 -fembed-bitcode -fmodules-ignore-macro=BASELIB_DYNAMICLIBRARY=1 -fmodules-ignore-macro=BASELIB_INLINE_NAMESPACE=il2cpp_baselib -fmodules-ignore-macro=AARCH64 -fmodules-ignore-macro=__aarch64__ -fmodules-ignore-macro=IL2CPP_SUPPORT_THREADS -fmodules-ignore-macro=IL2CPP_THREADS_PTHREAD -Wnon-modular-include-in-framework-module -Werror=non-modular-include-in-framework-module -Wno-trigraphs -fpascal-strings -Os -fno-common -Wno-missing-field-initializers -Wno-missing-prototypes -Werror=return-type -Wdocumentation -Wunreachable-code -Wquoted-include-in-framework-header -Werror=deprecated-objc-isa-usage -Werror=objc-root-class -Wno-non-virtual-dtor -Wno-overloaded-virtual -Wno-exit-time-destructors -Wno-missing-braces -Wparentheses -Wswitch -Wno-unused-function -Wno-unused-label -Wno-unused-parameter -Wno-unused-variable -Wunused-value -Wempty-body -Wuninitialized -Wconditional-uninitialized -Wno-unknown-pragmas -Wno-shadow -Wno-four-char-constants -Wno-conversion -Wconstant-conversion -Wint-conversion -Wbool-conversion -Wenum-conversion -Wno-float-conversion -Wnon-literal-null-conversion -Wobjc-literal-conversion -Wshorten-64-to-32 -Wno-newline-eof -Wno-c++11-extensions -DIL2CPP_TARGET_IOS=1 -isysroot ${SDK_VERSION} -fasm-blocks -fstrict-aliasing -Wdeprecated-declarations -Winvalid-offsetof -g -Wno-sign-conversion -Winfinite-recursion -Wmove -Wcomma -Wblock-capture-autoreleasing -Wstrict-prototypes -Wrange-loop-analysis -Wno-semicolon-before-method-body -Wunguarded-availability ")
-
-
-add_definitions(-DIL2CPP_TARGET_IOS=1)
-add_definitions(-DBASELIB_DYNAMICLIBRARY=1)
-add_definitions(-DBASELIB_INLINE_NAMESPACE=il2cpp_baselib)
-add_definitions(-DAARCH64)
-add_definitions(-D__aarch64__)
-add_definitions(-DIL2CPP_SUPPORT_THREADS)
-add_definitions(-DIL2CPP_THREADS_PTHREAD)
-#add_definitions(-DCMAKE_C_COMPILER=/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang)
-#add_definitions(-DCMAKE_CXX_COMPILER=/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/clang++)
-#add_definitions(-DIL2CPP_TARGET_DARWIN)
-add_definitions(-DIL2CPP_PLATFORM_SUPPORTS_TIMEZONEINFO)
-
-add_definitions(-MMD)
-add_definitions(-MT dependencies)
-
-
-include_directories(${IL2CPP_SOURCE_DIR}/libil2cpp)
-include_directories(${IL2CPP_SOURCE_DIR}/external)
-include_directories(${IL2CPP_SOURCE_DIR}/external/baselib/Include/)
-include_directories(${IL2CPP_SOURCE_DIR}/external/bdwgc/include/)
-include_directories(${IL2CPP_SOURCE_DIR}/external/baselib/Platforms/OSX/Include/)
-
-# 修改为本机对应SDK路径
-include_directories(SYSTEM /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator.sdk/usr/include/c++/v1)
-include_directories(SYSTEM /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator.sdk/usr/include)
-
-get_filename_component(PARENT_PATH ${PROJECT_BINARY_DIR} PATH)
-aux_source_directory(${PARENT_PATH}/lump_mm LUMP_SOURCE_LIST)
-
-#find_library(zlib ${PROJECT_SOURCE_DIR}/external)
-add_library(objective STATIC ${LUMP_SOURCE_LIST})
-

+ 0 - 61
GameClient/HybridCLRData/init_local_il2cpp_data.bat

@@ -1,61 +0,0 @@
-@echo off
-
-rem set default branch
-set IL2CPP_BRANCH=2020.3.33
-
-if exist hybridclr_repo rd /s /q hybridclr_repo
-rem git clone https://github.com/focus-creative-games/hybridclr
-git clone --depth=1 https://gitee.com/focus-creative-games/hybridclr hybridclr_repo
-
-if exist il2cpp_plus_repo rd /s /q il2cpp_plus_repo
-rem git clone https://github.com/focus-creative-games/il2cpp_hybridclr
-git clone --depth=1 -b %IL2CPP_BRANCH% https://gitee.com/focus-creative-games/il2cpp_plus il2cpp_plus_repo
-
-
-rem replace with right Unity Editor Install path
-set IL2CPP_PATH=C:\Program Files\Unity\Hub\Editor\2020.3.30f1c1\Editor\Data\il2cpp
-
-if not exist "%IL2CPP_PATH%" (
-    echo "please set correct IL2CPP_PATH value"
-    goto EXIT
-)
-
-set LOCAL_IL2CPP_DATA=LocalIl2CppData
-
-if not exist %LOCAL_IL2CPP_DATA% (
-    mkdir %LOCAL_IL2CPP_DATA%
-)
-
-rem need copdy MonoBleedingEdge
-set MBE=%LOCAL_IL2CPP_DATA%\MonoBleedingEdge
-if not exist %MBE% (
-    xcopy /q /i /e "%IL2CPP_PATH%\..\MonoBleedingEdge" %MBE%
-)
-
-
-rem copy il2cpp
-set IL2CPP=%LOCAL_IL2CPP_DATA%\il2cpp
-if not exist %IL2CPP% (
-    xcopy /q /i /e "%IL2CPP_PATH%" %IL2CPP%
-)
-
-set HYBRIDCLR_REPO_DIR=hybridclr_repo
-
-set IL2CPP_PLUS_REPO_DIR=il2cpp_plus_repo
-
-set LIBIL2CPP_PATH=%LOCAL_IL2CPP_DATA%\il2cpp\libil2cpp
-rd /s /q %LIBIL2CPP_PATH%
-
-xcopy /q /i /e %IL2CPP_PLUS_REPO_DIR%\libil2cpp %LIBIL2CPP_PATH%
-xcopy /q /i /e %HYBRIDCLR_REPO_DIR%\hybridclr %LIBIL2CPP_PATH%\hybridclr
-
-rem clean il2cpp build cache
-set IL2CPP_CACHE=..\Library\Il2cppBuildCache
-echo clean %IL2CPP_CACHE%
-if exist "%IL2CPP_CACHE%" rd /s /q "%IL2CPP_CACHE%"
-
-echo succ
-
-:EXIT
-
-PAUSE

+ 0 - 69
GameClient/HybridCLRData/init_local_il2cpp_data.sh

@@ -1,69 +0,0 @@
-#!/bin/bash
-
-# 设置默认分支为2020.3.33,避免很多人忘了切分支
-IL2CPP_BRANCH=2020.3.33
-
-rm -rf hybridclr_repo
-# clone hybridclr仓库,国内推荐用 gitee
-# git clone https://github.com/focus-creative-games/hybridclr
-git clone --depth=1 https://gitee.com/focus-creative-games/hybridclr hybridclr_repo
-
-rm -rf il2cpp_plus_repo
-# git clone https://github.com/focus-creative-games/il2cpp_plus
-git clone --depth=1 -b $IL2CPP_BRANCH https://gitee.com/focus-creative-games/il2cpp_plus il2cpp_plus_repo
-
-
-# 请修改为你所用Unity的il2cpp目录
-# 一般像这样 
-# C:\Program Files\Unity\Hub\Editor\2020.3.33f1c2\Editor\Data\il2cpp
-# /Applications/Unity/Hub/Editor/2020.3.33f1/Unity.app/Contents/il2cpp
-IL2CPP_PATH='/Applications/Unity/Hub/Editor/2020.3.33f1/Unity.app/Contents/il2cpp'
-
-if [ ! -d "$IL2CPP_PATH" ] ; then
-    echo "你未指定正确的il2cpp路径"
-    exit 1
-fi
-
-LOCAL_IL2CPP_DATA=LocalIl2CppData
-
-if [ ! -d "$LOCAL_IL2CPP_DATA" ]; then
-    mkdir $LOCAL_IL2CPP_DATA
-fi
-
-
-# Unity 打包时允许使用环境变量UNITY_IL2CPP_PATH自定义%IL2CPP_PATH%的位置
-# 但同时又要求同级目录包含MonoBleedingEdge,因此需要拷贝这两个目录
-
-# 拷贝 MonoBleedingEdge 目录
-MBE=$LOCAL_IL2CPP_DATA/MonoBleedingEdge
-if [ ! -d "$MBE" ]; then
-    cp -r "$IL2CPP_PATH/../MonoBleedingEdge" $MBE
-fi
-
-
-# 拷贝il2cpp目录
-IL2CPP=$LOCAL_IL2CPP_DATA/il2cpp
-if [ ! -d "$IL2CPP" ]; then
-    cp -r "$IL2CPP_PATH" "$IL2CPP"
-fi
-
-# 接下来替换 il2cpp目录下的libil2cpp为 hybridclr修改后的版本
-# 需要使用 {https://gitee.com/focus-creative-games/il2cpp_plus}/libil2cpp 替换 il2cpp/libil2cpp目录
-# 需要使用 {https://gitee.com/focus-creative-games/hybridclr}/hybridclr 添加到 il2cpp/libil2cpp目录下,即il2cpp/libil2cpp/hybridclr
-
-HYBRIDCLR_REPO_DIR=hybridclr_repo
-IL2CPP_PLUS_REPO_DIR=il2cpp_plus_repo
-
-LIBIL2CPP_PATH=$LOCAL_IL2CPP_DATA/il2cpp/libil2cpp
-rm -rf "$LIBIL2CPP_PATH"
-
-cp -r "$IL2CPP_PLUS_REPO_DIR/libil2cpp" "$LIBIL2CPP_PATH"
-cp -r "$HYBRIDCLR_REPO_DIR/hybridclr" "$LIBIL2CPP_PATH/hybridclr"
-
-# 务必清除缓存,不然build仍然使用旧版本。
-# 只影响直接build的情况,不影响导出工程的情形。
-
-echo 清除 Library/Il2cppBuildCache 缓存目录
-rm -rf ../Library/Il2cppBuildCache
-
-echo 初始化成功

+ 3 - 3
GameClient/ProjectSettings/ProjectSettings.asset

@@ -254,7 +254,7 @@ PlayerSettings:
   useCustomBaseGradleTemplate: 0
   useCustomGradlePropertiesTemplate: 0
   useCustomProguardFile: 0
-  AndroidTargetArchitectures: 2
+  AndroidTargetArchitectures: 1
   AndroidTargetDevices: 0
   AndroidSplashScreenScale: 2
   androidSplashScreen: {fileID: 2800000, guid: 966dcb9a66b3b204abd4325a28c092ca, type: 3}
@@ -703,7 +703,7 @@ PlayerSettings:
   additionalCompilerArguments: {}
   platformArchitecture: {}
   scriptingBackend:
-    Android: 1
+    Android: 0
     Standalone: 1
   il2cppCompilerConfiguration: {}
   managedStrippingLevel: {}
@@ -715,7 +715,7 @@ PlayerSettings:
   enableRoslynAnalyzers: 1
   additionalIl2CppArgs: 
   scriptingRuntimeVersion: 1
-  gcIncremental: 0
+  gcIncremental: 1
   assemblyVersionValidation: 0
   gcWBarrierValidation: 0
   apiCompatibilityLevelPerPlatform: