ILGeneratorEx.cs 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. using System;
  2. namespace ChocolArm64
  3. {
  4. using System.Reflection.Emit;
  5. static class ILGeneratorEx
  6. {
  7. public static void EmitLdc_I4(this ILGenerator Generator,int Value)
  8. {
  9. switch (Value)
  10. {
  11. case 0: Generator.Emit(OpCodes.Ldc_I4_0); break;
  12. case 1: Generator.Emit(OpCodes.Ldc_I4_1); break;
  13. case 2: Generator.Emit(OpCodes.Ldc_I4_2); break;
  14. case 3: Generator.Emit(OpCodes.Ldc_I4_3); break;
  15. case 4: Generator.Emit(OpCodes.Ldc_I4_4); break;
  16. case 5: Generator.Emit(OpCodes.Ldc_I4_5); break;
  17. case 6: Generator.Emit(OpCodes.Ldc_I4_6); break;
  18. case 7: Generator.Emit(OpCodes.Ldc_I4_7); break;
  19. case 8: Generator.Emit(OpCodes.Ldc_I4_8); break;
  20. case -1: Generator.Emit(OpCodes.Ldc_I4_M1); break;
  21. default: Generator.Emit(OpCodes.Ldc_I4, Value); break;
  22. }
  23. }
  24. public static void EmitLdarg(this ILGenerator Generator, int Index)
  25. {
  26. switch (Index)
  27. {
  28. case 0: Generator.Emit(OpCodes.Ldarg_0); break;
  29. case 1: Generator.Emit(OpCodes.Ldarg_1); break;
  30. case 2: Generator.Emit(OpCodes.Ldarg_2); break;
  31. case 3: Generator.Emit(OpCodes.Ldarg_3); break;
  32. default:
  33. if ((uint)Index <= byte.MaxValue)
  34. {
  35. Generator.Emit(OpCodes.Ldarg_S, (byte)Index);
  36. }
  37. else if ((uint)Index < ushort.MaxValue)
  38. {
  39. Generator.Emit(OpCodes.Ldarg, (short)Index);
  40. }
  41. else
  42. {
  43. throw new ArgumentOutOfRangeException(nameof(Index));
  44. }
  45. break;
  46. }
  47. }
  48. public static void EmitStarg(this ILGenerator Generator, int Index)
  49. {
  50. if ((uint)Index <= byte.MaxValue)
  51. {
  52. Generator.Emit(OpCodes.Starg_S, (byte)Index);
  53. }
  54. else if ((uint)Index < ushort.MaxValue)
  55. {
  56. Generator.Emit(OpCodes.Starg, (short)Index);
  57. }
  58. else
  59. {
  60. throw new ArgumentOutOfRangeException(nameof(Index));
  61. }
  62. }
  63. public static void EmitLdloc(this ILGenerator Generator, int Index)
  64. {
  65. switch (Index)
  66. {
  67. case 0: Generator.Emit(OpCodes.Ldloc_0); break;
  68. case 1: Generator.Emit(OpCodes.Ldloc_1); break;
  69. case 2: Generator.Emit(OpCodes.Ldloc_2); break;
  70. case 3: Generator.Emit(OpCodes.Ldloc_3); break;
  71. default:
  72. if ((uint)Index <= byte.MaxValue)
  73. {
  74. Generator.Emit(OpCodes.Ldloc_S, (byte)Index);
  75. }
  76. else if ((uint)Index < ushort.MaxValue)
  77. {
  78. Generator.Emit(OpCodes.Ldloc, (short)Index);
  79. }
  80. else
  81. {
  82. throw new ArgumentOutOfRangeException(nameof(Index));
  83. }
  84. break;
  85. }
  86. }
  87. public static void EmitStloc(this ILGenerator Generator, int Index)
  88. {
  89. switch (Index)
  90. {
  91. case 0: Generator.Emit(OpCodes.Stloc_0); break;
  92. case 1: Generator.Emit(OpCodes.Stloc_1); break;
  93. case 2: Generator.Emit(OpCodes.Stloc_2); break;
  94. case 3: Generator.Emit(OpCodes.Stloc_3); break;
  95. default:
  96. if ((uint)Index <= byte.MaxValue)
  97. {
  98. Generator.Emit(OpCodes.Stloc_S, (byte)Index);
  99. }
  100. else if ((uint)Index < ushort.MaxValue)
  101. {
  102. Generator.Emit(OpCodes.Stloc, (short)Index);
  103. }
  104. else
  105. {
  106. throw new ArgumentOutOfRangeException(nameof(Index));
  107. }
  108. break;
  109. }
  110. }
  111. public static void EmitLdargSeq(this ILGenerator Generator, int Count)
  112. {
  113. for (int Index = 0; Index < Count; Index++)
  114. {
  115. Generator.EmitLdarg(Index);
  116. }
  117. }
  118. }
  119. }