| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190 |
- using System.Collections.Generic;
- using System.IO;
- using Ryujinx.Common.Configuration.Hid;
- using Ryujinx.Common.Logging;
- using Ryujinx.Common.Utilities;
- using Ryujinx.Configuration.System;
- using Ryujinx.Configuration.Hid;
- using Ryujinx.Configuration.Ui;
- using Ryujinx.UI.Input;
- namespace Ryujinx.Configuration
- {
- public class ConfigurationFileFormat
- {
- /// <summary>
- /// The current version of the file format
- /// </summary>
- public const int CurrentVersion = 5;
- public int Version { get; set; }
- /// <summary>
- /// Max Anisotropy. Values range from 0 - 16. Set to -1 to let the game decide.
- /// </summary>
- public float MaxAnisotropy { get; set; }
- /// <summary>
- /// Dumps shaders in this local directory
- /// </summary>
- public string GraphicsShadersDumpPath { get; set; }
- /// <summary>
- /// Enables printing debug log messages
- /// </summary>
- public bool LoggingEnableDebug { get; set; }
- /// <summary>
- /// Enables printing stub log messages
- /// </summary>
- public bool LoggingEnableStub { get; set; }
- /// <summary>
- /// Enables printing info log messages
- /// </summary>
- public bool LoggingEnableInfo { get; set; }
- /// <summary>
- /// Enables printing warning log messages
- /// </summary>
- public bool LoggingEnableWarn { get; set; }
- /// <summary>
- /// Enables printing error log messages
- /// </summary>
- public bool LoggingEnableError { get; set; }
- /// <summary>
- /// Enables printing guest log messages
- /// </summary>
- public bool LoggingEnableGuest { get; set; }
- /// <summary>
- /// Enables printing FS access log messages
- /// </summary>
- public bool LoggingEnableFsAccessLog { get; set; }
- /// <summary>
- /// Controls which log messages are written to the log targets
- /// </summary>
- public LogClass[] LoggingFilteredClasses { get; set; }
- /// <summary>
- /// Enables or disables logging to a file on disk
- /// </summary>
- public bool EnableFileLog { get; set; }
- /// <summary>
- /// Change System Language
- /// </summary>
- public Language SystemLanguage { get; set; }
- /// <summary>
- /// Change System Region
- /// </summary>
- public Region SystemRegion { get; set; }
- /// <summary>
- /// Change System TimeZone
- /// </summary>
- public string SystemTimeZone { get; set; }
- /// <summary>
- /// Change System Time Offset in seconds
- /// </summary>
- public long SystemTimeOffset { get; set; }
- /// <summary>
- /// Enables or disables Docked Mode
- /// </summary>
- public bool DockedMode { get; set; }
- /// <summary>
- /// Enables or disables Discord Rich Presence
- /// </summary>
- public bool EnableDiscordIntegration { get; set; }
- /// <summary>
- /// Enables or disables Vertical Sync
- /// </summary>
- public bool EnableVsync { get; set; }
- /// <summary>
- /// Enables or disables multi-core scheduling of threads
- /// </summary>
- public bool EnableMulticoreScheduling { get; set; }
- /// <summary>
- /// Enables integrity checks on Game content files
- /// </summary>
- public bool EnableFsIntegrityChecks { get; set; }
- /// <summary>
- /// Enables FS access log output to the console. Possible modes are 0-3
- /// </summary>
- public int FsGlobalAccessLogMode { get; set; }
- /// <summary>
- /// Enable or disable ignoring missing services
- /// </summary>
- public bool IgnoreMissingServices { get; set; }
- /// <summary>
- /// The primary controller's type
- /// </summary>
- public ControllerType ControllerType { get; set; }
- /// <summary>
- /// Used to toggle columns in the GUI
- /// </summary>
- public GuiColumns GuiColumns { get; set; }
- /// <summary>
- /// A list of directories containing games to be used to load games into the games list
- /// </summary>
- public List<string> GameDirs { get; set; }
- /// <summary>
- /// Enable or disable custom themes in the GUI
- /// </summary>
- public bool EnableCustomTheme { get; set; }
- /// <summary>
- /// Path to custom GUI theme
- /// </summary>
- public string CustomThemePath { get; set; }
- /// <summary>
- /// Enable or disable keyboard support (Independent from controllers binding)
- /// </summary>
- public bool EnableKeyboard { get; set; }
- /// <summary>
- /// Keyboard control bindings
- /// </summary>
- public NpadKeyboard KeyboardControls { get; set; }
- /// <summary>
- /// Controller control bindings
- /// </summary>
- public NpadController JoystickControls { get; set; }
- /// <summary>
- /// Loads a configuration file from disk
- /// </summary>
- /// <param name="path">The path to the JSON configuration file</param>
- public static ConfigurationFileFormat Load(string path)
- {
- return JsonHelper.DeserializeFromFile<ConfigurationFileFormat>(path);
- }
- /// <summary>
- /// Save a configuration file to disk
- /// </summary>
- /// <param name="path">The path to the JSON configuration file</param>
- public void SaveConfig(string path)
- {
- File.WriteAllText(path, JsonHelper.Serialize(this, true));
- }
- }
- }
|