ConfigLoaderInvoker.cs 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. using System;
  2. using System.Collections.Generic;
  3. using System.IO;
  4. using UnityEngine;
  5. namespace ET
  6. {
  7. [Invoke]
  8. public class GetAllConfigBytes: AInvokeHandler<ConfigLoader.GetAllConfigBytes, ETTask<Dictionary<Type, byte[]>>>
  9. {
  10. public override async ETTask<Dictionary<Type, byte[]>> Handle(ConfigLoader.GetAllConfigBytes args)
  11. {
  12. Dictionary<Type, byte[]> output = new Dictionary<Type, byte[]>();
  13. HashSet<Type> configTypes = CodeTypes.Instance.GetTypes(typeof (ConfigAttribute));
  14. if (Define.IsEditor)
  15. {
  16. string ct = "cs";
  17. GlobalConfig globalConfig = Resources.Load<GlobalConfig>("GlobalConfig");
  18. CodeMode codeMode = globalConfig.CodeMode;
  19. switch (codeMode)
  20. {
  21. case CodeMode.Client:
  22. ct = "c";
  23. break;
  24. case CodeMode.Server:
  25. ct = "s";
  26. break;
  27. case CodeMode.ClientServer:
  28. ct = "cs";
  29. break;
  30. default:
  31. throw new ArgumentOutOfRangeException();
  32. }
  33. List<string> startConfigs = new List<string>()
  34. {
  35. "StartMachineConfigCategory",
  36. "StartProcessConfigCategory",
  37. "StartSceneConfigCategory",
  38. "StartZoneConfigCategory",
  39. };
  40. foreach (Type configType in configTypes)
  41. {
  42. string configFilePath;
  43. if (startConfigs.Contains(configType.Name))
  44. {
  45. configFilePath = $"../Config/Excel/{ct}/{Options.Instance.StartConfig}/{configType.Name}.bytes";
  46. }
  47. else
  48. {
  49. configFilePath = $"../Config/Excel/{ct}/{configType.Name}.bytes";
  50. }
  51. output[configType] = File.ReadAllBytes(configFilePath);
  52. }
  53. }
  54. else
  55. {
  56. foreach (Type type in configTypes)
  57. {
  58. TextAsset v = await ResourcesComponent.Instance.LoadAssetAsync<TextAsset>($"Assets/Bundles/Config/{type.Name}.bytes");
  59. output[type] = v.bytes;
  60. }
  61. }
  62. return output;
  63. }
  64. }
  65. [Invoke]
  66. public class GetOneConfigBytes: AInvokeHandler<ConfigLoader.GetOneConfigBytes, ETTask<byte[]>>
  67. {
  68. public override async ETTask<byte[]> Handle(ConfigLoader.GetOneConfigBytes args)
  69. {
  70. string ct = "cs";
  71. GlobalConfig globalConfig = Resources.Load<GlobalConfig>("GlobalConfig");
  72. CodeMode codeMode = globalConfig.CodeMode;
  73. switch (codeMode)
  74. {
  75. case CodeMode.Client:
  76. ct = "c";
  77. break;
  78. case CodeMode.Server:
  79. ct = "s";
  80. break;
  81. case CodeMode.ClientServer:
  82. ct = "cs";
  83. break;
  84. default:
  85. throw new ArgumentOutOfRangeException();
  86. }
  87. List<string> startConfigs = new List<string>()
  88. {
  89. "StartMachineConfigCategory",
  90. "StartProcessConfigCategory",
  91. "StartSceneConfigCategory",
  92. "StartZoneConfigCategory",
  93. };
  94. string configName = args.ConfigName;
  95. string configFilePath;
  96. if (startConfigs.Contains(configName))
  97. {
  98. configFilePath = $"../Config/Excel/{ct}/{Options.Instance.StartConfig}/{configName}.bytes";
  99. }
  100. else
  101. {
  102. configFilePath = $"../Config/Excel/{ct}/{configName}.bytes";
  103. }
  104. await ETTask.CompletedTask;
  105. return File.ReadAllBytes(configFilePath);
  106. }
  107. }
  108. }