Config.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. using LibHac.IO;
  2. using Ryujinx.Common.Logging;
  3. using Ryujinx.HLE;
  4. using Ryujinx.HLE.HOS.SystemState;
  5. using Ryujinx.HLE.Input;
  6. using Ryujinx.UI.Input;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Globalization;
  10. using System.IO;
  11. using System.Linq;
  12. using System.Reflection;
  13. namespace Ryujinx
  14. {
  15. public static class Config
  16. {
  17. public static NpadKeyboard NpadKeyboard { get; private set; }
  18. public static NpadController NpadController { get; private set; }
  19. public static void Read(Switch device)
  20. {
  21. string iniFolder = Path.GetDirectoryName(Assembly.GetEntryAssembly().Location);
  22. string iniPath = Path.Combine(iniFolder, "Ryujinx.conf");
  23. IniParser parser = new IniParser(iniPath);
  24. GraphicsConfig.ShadersDumpPath = parser.Value("Graphics_Shaders_Dump_Path");
  25. Logger.SetEnable(LogLevel.Debug, Convert.ToBoolean(parser.Value("Logging_Enable_Debug")));
  26. Logger.SetEnable(LogLevel.Stub, Convert.ToBoolean(parser.Value("Logging_Enable_Stub")));
  27. Logger.SetEnable(LogLevel.Info, Convert.ToBoolean(parser.Value("Logging_Enable_Info")));
  28. Logger.SetEnable(LogLevel.Warning, Convert.ToBoolean(parser.Value("Logging_Enable_Warn")));
  29. Logger.SetEnable(LogLevel.Error, Convert.ToBoolean(parser.Value("Logging_Enable_Error")));
  30. string[] filteredLogClasses = parser.Value("Logging_Filtered_Classes").Split(',', StringSplitOptions.RemoveEmptyEntries);
  31. //When the classes are specified on the list, we only
  32. //enable the classes that are on the list.
  33. //So, first disable everything, then enable
  34. //the classes that the user added to the list.
  35. if (filteredLogClasses.Length > 0)
  36. {
  37. foreach (LogClass Class in Enum.GetValues(typeof(LogClass)))
  38. {
  39. Logger.SetEnable(Class, false);
  40. }
  41. }
  42. foreach (string logClass in filteredLogClasses)
  43. {
  44. if (!string.IsNullOrEmpty(logClass.Trim()))
  45. {
  46. foreach (LogClass Class in Enum.GetValues(typeof(LogClass)))
  47. {
  48. if (Class.ToString().ToLower().Contains(logClass.Trim().ToLower()))
  49. {
  50. Logger.SetEnable(Class, true);
  51. }
  52. }
  53. }
  54. }
  55. Logger.EnableFileLog = Convert.ToBoolean(parser.Value("Enable_File_Log"));
  56. SystemLanguage SetLanguage = Enum.Parse<SystemLanguage>(parser.Value("System_Language"));
  57. device.System.State.SetLanguage(SetLanguage);
  58. device.System.State.DockedMode = Convert.ToBoolean(parser.Value("Docked_Mode"));
  59. device.EnableDeviceVsync = Convert.ToBoolean(parser.Value("Enable_Vsync"));
  60. if (Convert.ToBoolean(parser.Value("Enable_MultiCore_Scheduling")))
  61. {
  62. device.System.EnableMultiCoreScheduling();
  63. }
  64. device.System.FsIntegrityCheckLevel = Convert.ToBoolean(parser.Value("Enable_FS_Integrity_Checks"))
  65. ? IntegrityCheckLevel.ErrorOnInvalid
  66. : IntegrityCheckLevel.None;
  67. HidControllerType ControllerType = Enum.Parse<HidControllerType>(parser.Value("Controller_Type"));
  68. device.Hid.InitilizePrimaryController(ControllerType);
  69. NpadKeyboard = new NpadKeyboard(
  70. new NpadKeyboardLeft
  71. {
  72. StickUp = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_Stick_Up")),
  73. StickDown = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_Stick_Down")),
  74. StickLeft = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_Stick_Left")),
  75. StickRight = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_Stick_Right")),
  76. StickButton = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_Stick_Button")),
  77. DPadUp = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_DPad_Up")),
  78. DPadDown = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_DPad_Down")),
  79. DPadLeft = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_DPad_Left")),
  80. DPadRight = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_DPad_Right")),
  81. ButtonMinus = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_Button_Minus")),
  82. ButtonL = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_Button_L")),
  83. ButtonZl = Convert.ToInt16(parser.Value("Controls_Left_JoyConKeyboard_Button_ZL"))
  84. },
  85. new NpadKeyboardRight
  86. {
  87. StickUp = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Stick_Up")),
  88. StickDown = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Stick_Down")),
  89. StickLeft = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Stick_Left")),
  90. StickRight = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Stick_Right")),
  91. StickButton = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Stick_Button")),
  92. ButtonA = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Button_A")),
  93. ButtonB = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Button_B")),
  94. ButtonX = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Button_X")),
  95. ButtonY = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Button_Y")),
  96. ButtonPlus = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Button_Plus")),
  97. ButtonR = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Button_R")),
  98. ButtonZr = Convert.ToInt16(parser.Value("Controls_Right_JoyConKeyboard_Button_ZR"))
  99. });
  100. NpadController = new NpadController(
  101. Convert.ToBoolean(parser.Value("GamePad_Enable")),
  102. Convert.ToInt32 (parser.Value("GamePad_Index")),
  103. (float)Convert.ToDouble (parser.Value("GamePad_Deadzone"), CultureInfo.InvariantCulture),
  104. (float)Convert.ToDouble (parser.Value("GamePad_Trigger_Threshold"), CultureInfo.InvariantCulture),
  105. new NpadControllerLeft
  106. {
  107. Stick = ToId(parser.Value("Controls_Left_JoyConController_Stick")),
  108. StickButton = ToId(parser.Value("Controls_Left_JoyConController_Stick_Button")),
  109. DPadUp = ToId(parser.Value("Controls_Left_JoyConController_DPad_Up")),
  110. DPadDown = ToId(parser.Value("Controls_Left_JoyConController_DPad_Down")),
  111. DPadLeft = ToId(parser.Value("Controls_Left_JoyConController_DPad_Left")),
  112. DPadRight = ToId(parser.Value("Controls_Left_JoyConController_DPad_Right")),
  113. ButtonMinus = ToId(parser.Value("Controls_Left_JoyConController_Button_Minus")),
  114. ButtonL = ToId(parser.Value("Controls_Left_JoyConController_Button_L")),
  115. ButtonZl = ToId(parser.Value("Controls_Left_JoyConController_Button_ZL"))
  116. },
  117. new NpadControllerRight
  118. {
  119. Stick = ToId(parser.Value("Controls_Right_JoyConController_Stick")),
  120. StickButton = ToId(parser.Value("Controls_Right_JoyConController_Stick_Button")),
  121. ButtonA = ToId(parser.Value("Controls_Right_JoyConController_Button_A")),
  122. ButtonB = ToId(parser.Value("Controls_Right_JoyConController_Button_B")),
  123. ButtonX = ToId(parser.Value("Controls_Right_JoyConController_Button_X")),
  124. ButtonY = ToId(parser.Value("Controls_Right_JoyConController_Button_Y")),
  125. ButtonPlus = ToId(parser.Value("Controls_Right_JoyConController_Button_Plus")),
  126. ButtonR = ToId(parser.Value("Controls_Right_JoyConController_Button_R")),
  127. ButtonZr = ToId(parser.Value("Controls_Right_JoyConController_Button_ZR"))
  128. });
  129. }
  130. private static ControllerInputId ToId(string key)
  131. {
  132. switch (key.ToUpper())
  133. {
  134. case "LSTICK": return ControllerInputId.LStick;
  135. case "DPADUP": return ControllerInputId.DPadUp;
  136. case "DPADDOWN": return ControllerInputId.DPadDown;
  137. case "DPADLEFT": return ControllerInputId.DPadLeft;
  138. case "DPADRIGHT": return ControllerInputId.DPadRight;
  139. case "BACK": return ControllerInputId.Back;
  140. case "LSHOULDER": return ControllerInputId.LShoulder;
  141. case "LTRIGGER": return ControllerInputId.LTrigger;
  142. case "RSTICK": return ControllerInputId.RStick;
  143. case "A": return ControllerInputId.A;
  144. case "B": return ControllerInputId.B;
  145. case "X": return ControllerInputId.X;
  146. case "Y": return ControllerInputId.Y;
  147. case "START": return ControllerInputId.Start;
  148. case "RSHOULDER": return ControllerInputId.RShoulder;
  149. case "RTRIGGER": return ControllerInputId.RTrigger;
  150. case "LJOYSTICK": return ControllerInputId.LJoystick;
  151. case "RJOYSTICK": return ControllerInputId.RJoystick;
  152. default: return ControllerInputId.Invalid;
  153. }
  154. }
  155. }
  156. //https://stackoverflow.com/a/37772571
  157. public class IniParser
  158. {
  159. private readonly Dictionary<string, string> _values;
  160. public IniParser(string path)
  161. {
  162. _values = File.ReadLines(path)
  163. .Where(line => !string.IsNullOrWhiteSpace(line) && !line.StartsWith('#'))
  164. .Select(line => line.Split('=', 2))
  165. .ToDictionary(parts => parts[0].Trim(), parts => parts.Length > 1 ? parts[1].Trim() : null);
  166. }
  167. public string Value(string name)
  168. {
  169. return _values.TryGetValue(name, out string value) ? value : null;
  170. }
  171. }
  172. }