Merge GreemDev/master
This commit is contained in:
commit
c43fd79bff
3
.github/workflows/canary.yml
vendored
3
.github/workflows/canary.yml
vendored
@ -22,6 +22,7 @@ env:
|
|||||||
RYUJINX_BASE_VERSION: "1.2"
|
RYUJINX_BASE_VERSION: "1.2"
|
||||||
RYUJINX_TARGET_RELEASE_CHANNEL_NAME: "canary"
|
RYUJINX_TARGET_RELEASE_CHANNEL_NAME: "canary"
|
||||||
RYUJINX_TARGET_RELEASE_CHANNEL_OWNER: "GreemDev"
|
RYUJINX_TARGET_RELEASE_CHANNEL_OWNER: "GreemDev"
|
||||||
|
RYUJINX_TARGET_RELEASE_CHANNEL_SOURCE_REPO: "Ryujinx"
|
||||||
RYUJINX_TARGET_RELEASE_CHANNEL_REPO: "Ryujinx-Canary"
|
RYUJINX_TARGET_RELEASE_CHANNEL_REPO: "Ryujinx-Canary"
|
||||||
RELEASE: 1
|
RELEASE: 1
|
||||||
|
|
||||||
@ -93,6 +94,7 @@ jobs:
|
|||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_NAME\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_NAME }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_NAME\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_NAME }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_OWNER }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_OWNER }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_SOURCE_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_SOURCE_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_CONFIG_FILE_NAME\%\%/Config\.json/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_CONFIG_FILE_NAME\%\%/Config\.json/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
@ -228,6 +230,7 @@ jobs:
|
|||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_NAME\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_NAME }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_NAME\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_NAME }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_OWNER }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_OWNER }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_SOURCE_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_SOURCE_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_CONFIG_FILE_NAME\%\%/Config\.json/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_CONFIG_FILE_NAME\%\%/Config\.json/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
|
2
.github/workflows/release.yml
vendored
2
.github/workflows/release.yml
vendored
@ -93,6 +93,7 @@ jobs:
|
|||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_NAME\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_NAME }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_NAME\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_NAME }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_OWNER }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_OWNER }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_SOURCE_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_CONFIG_FILE_NAME\%\%/Config\.json/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_CONFIG_FILE_NAME\%\%/Config\.json/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
@ -224,6 +225,7 @@ jobs:
|
|||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_NAME\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_NAME }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_NAME\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_NAME }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_OWNER }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_OWNER }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
|
sed -r --in-place 's/\%\%RYUJINX_TARGET_RELEASE_CHANNEL_SOURCE_REPO\%\%/${{ env.RYUJINX_TARGET_RELEASE_CHANNEL_REPO }}/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
sed -r --in-place 's/\%\%RYUJINX_CONFIG_FILE_NAME\%\%/Config\.json/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
sed -r --in-place 's/\%\%RYUJINX_CONFIG_FILE_NAME\%\%/Config\.json/g;' src/Ryujinx.Common/ReleaseInformation.cs
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
|
@ -13,6 +13,7 @@ using System.Collections.Generic;
|
|||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.IO.Compression;
|
using System.IO.Compression;
|
||||||
|
using System.Linq;
|
||||||
using System.Runtime;
|
using System.Runtime;
|
||||||
using System.Runtime.CompilerServices;
|
using System.Runtime.CompilerServices;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
@ -848,18 +849,15 @@ namespace ARMeilleure.Translation.PTC
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
List<Thread> threads = new();
|
|
||||||
|
|
||||||
for (int i = 0; i < degreeOfParallelism; i++)
|
List<Thread> threads = Enumerable.Range(0, degreeOfParallelism)
|
||||||
{
|
.Select(idx =>
|
||||||
Thread thread = new(TranslateFuncs)
|
new Thread(TranslateFuncs)
|
||||||
{
|
{
|
||||||
IsBackground = true,
|
IsBackground = true,
|
||||||
Name = "Ptc.TranslateThread." + i
|
Name = "Ptc.TranslateThread." + idx
|
||||||
};
|
}
|
||||||
|
).ToList();
|
||||||
threads.Add(thread);
|
|
||||||
}
|
|
||||||
|
|
||||||
Stopwatch sw = Stopwatch.StartNew();
|
Stopwatch sw = Stopwatch.StartNew();
|
||||||
|
|
||||||
|
@ -30,10 +30,10 @@ namespace Ryujinx.Common.Logging.Targets
|
|||||||
string ILogTarget.Name { get => _target.Name; }
|
string ILogTarget.Name { get => _target.Name; }
|
||||||
|
|
||||||
public AsyncLogTargetWrapper(ILogTarget target)
|
public AsyncLogTargetWrapper(ILogTarget target)
|
||||||
: this(target, -1, AsyncLogTargetOverflowAction.Block)
|
: this(target, -1)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
public AsyncLogTargetWrapper(ILogTarget target, int queueLimit, AsyncLogTargetOverflowAction overflowAction)
|
public AsyncLogTargetWrapper(ILogTarget target, int queueLimit = -1, AsyncLogTargetOverflowAction overflowAction = AsyncLogTargetOverflowAction.Block)
|
||||||
{
|
{
|
||||||
_target = target;
|
_target = target;
|
||||||
_messageQueue = new BlockingCollection<LogEventArgs>(queueLimit);
|
_messageQueue = new BlockingCollection<LogEventArgs>(queueLimit);
|
||||||
|
@ -47,7 +47,7 @@ namespace Ryujinx.Common.Logging.Targets
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Clean up old logs, should only keep 3
|
// Clean up old logs, should only keep 3
|
||||||
FileInfo[] files = logDir.GetFiles("*.log").OrderBy((info => info.CreationTime)).ToArray();
|
FileInfo[] files = logDir.GetFiles("*.log").OrderBy(info => info.CreationTime).ToArray();
|
||||||
for (int i = 0; i < files.Length - 2; i++)
|
for (int i = 0; i < files.Length - 2; i++)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
|
@ -1,11 +1,13 @@
|
|||||||
|
using Ryujinx.Common.Logging;
|
||||||
using System;
|
using System;
|
||||||
|
using System.Globalization;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
|
|
||||||
namespace Ryujinx.Common
|
namespace Ryujinx.Common
|
||||||
{
|
{
|
||||||
public class ReactiveObject<T>
|
public class ReactiveObject<T>
|
||||||
{
|
{
|
||||||
private readonly ReaderWriterLockSlim _readerWriterLock = new();
|
private readonly ReaderWriterLockSlim _rwLock = new();
|
||||||
private bool _isInitialized;
|
private bool _isInitialized;
|
||||||
private T _value;
|
private T _value;
|
||||||
|
|
||||||
@ -15,15 +17,15 @@ namespace Ryujinx.Common
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
_readerWriterLock.EnterReadLock();
|
_rwLock.EnterReadLock();
|
||||||
T value = _value;
|
T value = _value;
|
||||||
_readerWriterLock.ExitReadLock();
|
_rwLock.ExitReadLock();
|
||||||
|
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
set
|
set
|
||||||
{
|
{
|
||||||
_readerWriterLock.EnterWriteLock();
|
_rwLock.EnterWriteLock();
|
||||||
|
|
||||||
T oldValue = _value;
|
T oldValue = _value;
|
||||||
|
|
||||||
@ -32,7 +34,7 @@ namespace Ryujinx.Common
|
|||||||
_isInitialized = true;
|
_isInitialized = true;
|
||||||
_value = value;
|
_value = value;
|
||||||
|
|
||||||
_readerWriterLock.ExitWriteLock();
|
_rwLock.ExitWriteLock();
|
||||||
|
|
||||||
if (!oldIsInitialized || oldValue == null || !oldValue.Equals(_value))
|
if (!oldIsInitialized || oldValue == null || !oldValue.Equals(_value))
|
||||||
{
|
{
|
||||||
@ -41,11 +43,21 @@ namespace Ryujinx.Common
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void LogChangesToValue(string valueName, LogClass logClass = LogClass.Configuration)
|
||||||
|
=> Event += (_, e) => ReactiveObjectHelper.LogValueChange(logClass, e, valueName);
|
||||||
|
|
||||||
public static implicit operator T(ReactiveObject<T> obj) => obj.Value;
|
public static implicit operator T(ReactiveObject<T> obj) => obj.Value;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class ReactiveObjectHelper
|
public static class ReactiveObjectHelper
|
||||||
{
|
{
|
||||||
|
public static void LogValueChange<T>(LogClass logClass, ReactiveEventArgs<T> eventArgs, string valueName)
|
||||||
|
{
|
||||||
|
string message = string.Create(CultureInfo.InvariantCulture, $"{valueName} set to: {eventArgs.NewValue}");
|
||||||
|
|
||||||
|
Logger.Info?.Print(logClass, message);
|
||||||
|
}
|
||||||
|
|
||||||
public static void Toggle(this ReactiveObject<bool> rBoolean) => rBoolean.Value = !rBoolean.Value;
|
public static void Toggle(this ReactiveObject<bool> rBoolean) => rBoolean.Value = !rBoolean.Value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,6 +15,7 @@ namespace Ryujinx.Common
|
|||||||
private const string ConfigFileName = "%%RYUJINX_CONFIG_FILE_NAME%%";
|
private const string ConfigFileName = "%%RYUJINX_CONFIG_FILE_NAME%%";
|
||||||
|
|
||||||
public const string ReleaseChannelOwner = "%%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER%%";
|
public const string ReleaseChannelOwner = "%%RYUJINX_TARGET_RELEASE_CHANNEL_OWNER%%";
|
||||||
|
public const string ReleaseChannelSourceRepo = "%%RYUJINX_TARGET_RELEASE_CHANNEL_SOURCE_REPO%%";
|
||||||
public const string ReleaseChannelRepo = "%%RYUJINX_TARGET_RELEASE_CHANNEL_REPO%%";
|
public const string ReleaseChannelRepo = "%%RYUJINX_TARGET_RELEASE_CHANNEL_REPO%%";
|
||||||
|
|
||||||
public static string ConfigName => !ConfigFileName.StartsWith("%%") ? ConfigFileName : "Config.json";
|
public static string ConfigName => !ConfigFileName.StartsWith("%%") ? ConfigFileName : "Config.json";
|
||||||
@ -23,6 +24,7 @@ namespace Ryujinx.Common
|
|||||||
!BuildGitHash.StartsWith("%%") &&
|
!BuildGitHash.StartsWith("%%") &&
|
||||||
!ReleaseChannelName.StartsWith("%%") &&
|
!ReleaseChannelName.StartsWith("%%") &&
|
||||||
!ReleaseChannelOwner.StartsWith("%%") &&
|
!ReleaseChannelOwner.StartsWith("%%") &&
|
||||||
|
!ReleaseChannelSourceRepo.StartsWith("%%") &&
|
||||||
!ReleaseChannelRepo.StartsWith("%%") &&
|
!ReleaseChannelRepo.StartsWith("%%") &&
|
||||||
!ConfigFileName.StartsWith("%%");
|
!ConfigFileName.StartsWith("%%");
|
||||||
|
|
||||||
|
@ -2463,7 +2463,7 @@ namespace Ryujinx.HLE.HOS.Diagnostics.Demangler
|
|||||||
return ParseIntegerLiteral("unsigned short");
|
return ParseIntegerLiteral("unsigned short");
|
||||||
case 'i':
|
case 'i':
|
||||||
_position++;
|
_position++;
|
||||||
return ParseIntegerLiteral("");
|
return ParseIntegerLiteral(string.Empty);
|
||||||
case 'j':
|
case 'j':
|
||||||
_position++;
|
_position++;
|
||||||
return ParseIntegerLiteral("u");
|
return ParseIntegerLiteral("u");
|
||||||
|
@ -116,18 +116,13 @@ namespace Ryujinx.HLE.HOS
|
|||||||
private readonly Dictionary<ulong, ModCache> _appMods; // key is ApplicationId
|
private readonly Dictionary<ulong, ModCache> _appMods; // key is ApplicationId
|
||||||
private PatchCache _patches;
|
private PatchCache _patches;
|
||||||
|
|
||||||
private static readonly EnumerationOptions _dirEnumOptions;
|
private static readonly EnumerationOptions _dirEnumOptions = new()
|
||||||
|
|
||||||
static ModLoader()
|
|
||||||
{
|
{
|
||||||
_dirEnumOptions = new EnumerationOptions
|
MatchCasing = MatchCasing.CaseInsensitive,
|
||||||
{
|
MatchType = MatchType.Simple,
|
||||||
MatchCasing = MatchCasing.CaseInsensitive,
|
RecurseSubdirectories = false,
|
||||||
MatchType = MatchType.Simple,
|
ReturnSpecialDirectories = false,
|
||||||
RecurseSubdirectories = false,
|
};
|
||||||
ReturnSpecialDirectories = false,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
public ModLoader()
|
public ModLoader()
|
||||||
{
|
{
|
||||||
@ -169,7 +164,7 @@ namespace Ryujinx.HLE.HOS
|
|||||||
foreach (var modDir in dir.EnumerateDirectories())
|
foreach (var modDir in dir.EnumerateDirectories())
|
||||||
{
|
{
|
||||||
types.Clear();
|
types.Clear();
|
||||||
Mod<DirectoryInfo> mod = new("", null, true);
|
Mod<DirectoryInfo> mod = new(string.Empty, null, true);
|
||||||
|
|
||||||
if (StrEquals(RomfsDir, modDir.Name))
|
if (StrEquals(RomfsDir, modDir.Name))
|
||||||
{
|
{
|
||||||
|
@ -117,8 +117,9 @@ namespace Ryujinx.Headless.SDL2.OpenGL
|
|||||||
GraphicsDebugLevel glLogLevel,
|
GraphicsDebugLevel glLogLevel,
|
||||||
AspectRatio aspectRatio,
|
AspectRatio aspectRatio,
|
||||||
bool enableMouse,
|
bool enableMouse,
|
||||||
HideCursorMode hideCursorMode)
|
HideCursorMode hideCursorMode,
|
||||||
: base(inputManager, glLogLevel, aspectRatio, enableMouse, hideCursorMode)
|
bool ignoreControllerApplet)
|
||||||
|
: base(inputManager, glLogLevel, aspectRatio, enableMouse, hideCursorMode, ignoreControllerApplet)
|
||||||
{
|
{
|
||||||
_glLogLevel = glLogLevel;
|
_glLogLevel = glLogLevel;
|
||||||
}
|
}
|
||||||
|
@ -226,6 +226,9 @@ namespace Ryujinx.Headless.SDL2
|
|||||||
[Option("ignore-missing-services", Required = false, Default = false, HelpText = "Enable ignoring missing services.")]
|
[Option("ignore-missing-services", Required = false, Default = false, HelpText = "Enable ignoring missing services.")]
|
||||||
public bool IgnoreMissingServices { get; set; }
|
public bool IgnoreMissingServices { get; set; }
|
||||||
|
|
||||||
|
[Option("ignore-controller-applet", Required = false, Default = false, HelpText = "Enable ignoring the controller applet when your game loses connection to your controller.")]
|
||||||
|
public bool IgnoreControllerApplet { get; set; }
|
||||||
|
|
||||||
// Values
|
// Values
|
||||||
|
|
||||||
[Value(0, MetaName = "input", HelpText = "Input to load.", Required = true)]
|
[Value(0, MetaName = "input", HelpText = "Input to load.", Required = true)]
|
||||||
|
@ -444,8 +444,7 @@ namespace Ryujinx.Headless.SDL2
|
|||||||
{
|
{
|
||||||
Logger.AddTarget(new AsyncLogTargetWrapper(
|
Logger.AddTarget(new AsyncLogTargetWrapper(
|
||||||
new FileLogTarget("file", logFile),
|
new FileLogTarget("file", logFile),
|
||||||
1000,
|
1000
|
||||||
AsyncLogTargetOverflowAction.Block
|
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -506,8 +505,8 @@ namespace Ryujinx.Headless.SDL2
|
|||||||
private static WindowBase CreateWindow(Options options)
|
private static WindowBase CreateWindow(Options options)
|
||||||
{
|
{
|
||||||
return options.GraphicsBackend == GraphicsBackend.Vulkan
|
return options.GraphicsBackend == GraphicsBackend.Vulkan
|
||||||
? new VulkanWindow(_inputManager, options.LoggingGraphicsDebugLevel, options.AspectRatio, options.EnableMouse, options.HideCursorMode)
|
? new VulkanWindow(_inputManager, options.LoggingGraphicsDebugLevel, options.AspectRatio, options.EnableMouse, options.HideCursorMode, options.IgnoreControllerApplet)
|
||||||
: new OpenGLWindow(_inputManager, options.LoggingGraphicsDebugLevel, options.AspectRatio, options.EnableMouse, options.HideCursorMode);
|
: new OpenGLWindow(_inputManager, options.LoggingGraphicsDebugLevel, options.AspectRatio, options.EnableMouse, options.HideCursorMode, options.IgnoreControllerApplet);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static IRenderer CreateRenderer(Options options, WindowBase window)
|
private static IRenderer CreateRenderer(Options options, WindowBase window)
|
||||||
|
@ -17,8 +17,9 @@ namespace Ryujinx.Headless.SDL2.Vulkan
|
|||||||
GraphicsDebugLevel glLogLevel,
|
GraphicsDebugLevel glLogLevel,
|
||||||
AspectRatio aspectRatio,
|
AspectRatio aspectRatio,
|
||||||
bool enableMouse,
|
bool enableMouse,
|
||||||
HideCursorMode hideCursorMode)
|
HideCursorMode hideCursorMode,
|
||||||
: base(inputManager, glLogLevel, aspectRatio, enableMouse, hideCursorMode)
|
bool ignoreControllerApplet)
|
||||||
|
: base(inputManager, glLogLevel, aspectRatio, enableMouse, hideCursorMode, ignoreControllerApplet)
|
||||||
{
|
{
|
||||||
_glLogLevel = glLogLevel;
|
_glLogLevel = glLogLevel;
|
||||||
}
|
}
|
||||||
|
@ -86,13 +86,15 @@ namespace Ryujinx.Headless.SDL2
|
|||||||
|
|
||||||
private readonly AspectRatio _aspectRatio;
|
private readonly AspectRatio _aspectRatio;
|
||||||
private readonly bool _enableMouse;
|
private readonly bool _enableMouse;
|
||||||
|
private readonly bool _ignoreControllerApplet;
|
||||||
|
|
||||||
public WindowBase(
|
public WindowBase(
|
||||||
InputManager inputManager,
|
InputManager inputManager,
|
||||||
GraphicsDebugLevel glLogLevel,
|
GraphicsDebugLevel glLogLevel,
|
||||||
AspectRatio aspectRatio,
|
AspectRatio aspectRatio,
|
||||||
bool enableMouse,
|
bool enableMouse,
|
||||||
HideCursorMode hideCursorMode)
|
HideCursorMode hideCursorMode,
|
||||||
|
bool ignoreControllerApplet)
|
||||||
{
|
{
|
||||||
MouseDriver = new SDL2MouseDriver(hideCursorMode);
|
MouseDriver = new SDL2MouseDriver(hideCursorMode);
|
||||||
_inputManager = inputManager;
|
_inputManager = inputManager;
|
||||||
@ -108,6 +110,7 @@ namespace Ryujinx.Headless.SDL2
|
|||||||
_gpuDoneEvent = new ManualResetEvent(false);
|
_gpuDoneEvent = new ManualResetEvent(false);
|
||||||
_aspectRatio = aspectRatio;
|
_aspectRatio = aspectRatio;
|
||||||
_enableMouse = enableMouse;
|
_enableMouse = enableMouse;
|
||||||
|
_ignoreControllerApplet = ignoreControllerApplet;
|
||||||
HostUITheme = new HeadlessHostUiTheme();
|
HostUITheme = new HeadlessHostUiTheme();
|
||||||
|
|
||||||
SDL2Driver.Instance.Initialize();
|
SDL2Driver.Instance.Initialize();
|
||||||
@ -484,6 +487,8 @@ namespace Ryujinx.Headless.SDL2
|
|||||||
|
|
||||||
public bool DisplayMessageDialog(ControllerAppletUIArgs args)
|
public bool DisplayMessageDialog(ControllerAppletUIArgs args)
|
||||||
{
|
{
|
||||||
|
if (_ignoreControllerApplet) return false;
|
||||||
|
|
||||||
string playerCount = args.PlayerCountMin == args.PlayerCountMax ? $"exactly {args.PlayerCountMin}" : $"{args.PlayerCountMin}-{args.PlayerCountMax}";
|
string playerCount = args.PlayerCountMin == args.PlayerCountMax ? $"exactly {args.PlayerCountMin}" : $"{args.PlayerCountMin}-{args.PlayerCountMax}";
|
||||||
|
|
||||||
string message = $"Application requests {playerCount} {"player".ToQuantity(args.PlayerCountMin + args.PlayerCountMax, ShowQuantityAs.None)} with:\n\n"
|
string message = $"Application requests {playerCount} {"player".ToQuantity(args.PlayerCountMin + args.PlayerCountMax, ShowQuantityAs.None)} with:\n\n"
|
||||||
|
@ -0,0 +1,718 @@
|
|||||||
|
using Ryujinx.Common.Configuration;
|
||||||
|
using Ryujinx.Common.Configuration.Hid;
|
||||||
|
using Ryujinx.Common.Configuration.Hid.Controller;
|
||||||
|
using Ryujinx.Common.Configuration.Hid.Keyboard;
|
||||||
|
using Ryujinx.Common.Configuration.Multiplayer;
|
||||||
|
using Ryujinx.Common.Logging;
|
||||||
|
using Ryujinx.HLE;
|
||||||
|
using Ryujinx.UI.Common.Configuration.System;
|
||||||
|
using Ryujinx.UI.Common.Configuration.UI;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace Ryujinx.UI.Common.Configuration
|
||||||
|
{
|
||||||
|
public partial class ConfigurationState
|
||||||
|
{
|
||||||
|
public void Load(ConfigurationFileFormat configurationFileFormat, string configurationFilePath)
|
||||||
|
{
|
||||||
|
bool configurationFileUpdated = false;
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version is < 0 or > ConfigurationFileFormat.CurrentVersion)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Unsupported configuration version {configurationFileFormat.Version}, loading default.");
|
||||||
|
|
||||||
|
LoadDefault();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 2)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 2.");
|
||||||
|
|
||||||
|
configurationFileFormat.SystemRegion = Region.USA;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 3)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 3.");
|
||||||
|
|
||||||
|
configurationFileFormat.SystemTimeZone = "UTC";
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 4)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 4.");
|
||||||
|
|
||||||
|
configurationFileFormat.MaxAnisotropy = -1;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 5)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 5.");
|
||||||
|
|
||||||
|
configurationFileFormat.SystemTimeOffset = 0;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 8)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 8.");
|
||||||
|
|
||||||
|
configurationFileFormat.EnablePtc = true;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 9)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 9.");
|
||||||
|
|
||||||
|
configurationFileFormat.ColumnSort = new ColumnSort
|
||||||
|
{
|
||||||
|
SortColumnId = 0,
|
||||||
|
SortAscending = false,
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileFormat.Hotkeys = new KeyboardHotkeys
|
||||||
|
{
|
||||||
|
ToggleVsync = Key.F1,
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 10)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 10.");
|
||||||
|
|
||||||
|
configurationFileFormat.AudioBackend = AudioBackend.OpenAl;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 11)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 11.");
|
||||||
|
|
||||||
|
configurationFileFormat.ResScale = 1;
|
||||||
|
configurationFileFormat.ResScaleCustom = 1.0f;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 12)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 12.");
|
||||||
|
|
||||||
|
configurationFileFormat.LoggingGraphicsDebugLevel = GraphicsDebugLevel.None;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// configurationFileFormat.Version == 13 -> LDN1
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 14)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 14.");
|
||||||
|
|
||||||
|
configurationFileFormat.CheckUpdatesOnStart = true;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 16)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 16.");
|
||||||
|
|
||||||
|
configurationFileFormat.EnableShaderCache = true;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 17)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 17.");
|
||||||
|
|
||||||
|
configurationFileFormat.StartFullscreen = false;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 18)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 18.");
|
||||||
|
|
||||||
|
configurationFileFormat.AspectRatio = AspectRatio.Fixed16x9;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// configurationFileFormat.Version == 19 -> LDN2
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 20)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 20.");
|
||||||
|
|
||||||
|
configurationFileFormat.ShowConfirmExit = true;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 21)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 21.");
|
||||||
|
|
||||||
|
// Initialize network config.
|
||||||
|
|
||||||
|
configurationFileFormat.MultiplayerMode = MultiplayerMode.Disabled;
|
||||||
|
configurationFileFormat.MultiplayerLanInterfaceId = "0";
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 22)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 22.");
|
||||||
|
|
||||||
|
configurationFileFormat.HideCursor = HideCursorMode.Never;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 24)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 24.");
|
||||||
|
|
||||||
|
configurationFileFormat.InputConfig = new List<InputConfig>
|
||||||
|
{
|
||||||
|
new StandardKeyboardInputConfig
|
||||||
|
{
|
||||||
|
Version = InputConfig.CurrentVersion,
|
||||||
|
Backend = InputBackendType.WindowKeyboard,
|
||||||
|
Id = "0",
|
||||||
|
PlayerIndex = PlayerIndex.Player1,
|
||||||
|
ControllerType = ControllerType.ProController,
|
||||||
|
LeftJoycon = new LeftJoyconCommonConfig<Key>
|
||||||
|
{
|
||||||
|
DpadUp = Key.Up,
|
||||||
|
DpadDown = Key.Down,
|
||||||
|
DpadLeft = Key.Left,
|
||||||
|
DpadRight = Key.Right,
|
||||||
|
ButtonMinus = Key.Minus,
|
||||||
|
ButtonL = Key.E,
|
||||||
|
ButtonZl = Key.Q,
|
||||||
|
ButtonSl = Key.Unbound,
|
||||||
|
ButtonSr = Key.Unbound,
|
||||||
|
},
|
||||||
|
LeftJoyconStick = new JoyconConfigKeyboardStick<Key>
|
||||||
|
{
|
||||||
|
StickUp = Key.W,
|
||||||
|
StickDown = Key.S,
|
||||||
|
StickLeft = Key.A,
|
||||||
|
StickRight = Key.D,
|
||||||
|
StickButton = Key.F,
|
||||||
|
},
|
||||||
|
RightJoycon = new RightJoyconCommonConfig<Key>
|
||||||
|
{
|
||||||
|
ButtonA = Key.Z,
|
||||||
|
ButtonB = Key.X,
|
||||||
|
ButtonX = Key.C,
|
||||||
|
ButtonY = Key.V,
|
||||||
|
ButtonPlus = Key.Plus,
|
||||||
|
ButtonR = Key.U,
|
||||||
|
ButtonZr = Key.O,
|
||||||
|
ButtonSl = Key.Unbound,
|
||||||
|
ButtonSr = Key.Unbound,
|
||||||
|
},
|
||||||
|
RightJoyconStick = new JoyconConfigKeyboardStick<Key>
|
||||||
|
{
|
||||||
|
StickUp = Key.I,
|
||||||
|
StickDown = Key.K,
|
||||||
|
StickLeft = Key.J,
|
||||||
|
StickRight = Key.L,
|
||||||
|
StickButton = Key.H,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 25)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 25.");
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 26)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 26.");
|
||||||
|
|
||||||
|
configurationFileFormat.MemoryManagerMode = MemoryManagerMode.HostMappedUnsafe;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 27)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 27.");
|
||||||
|
|
||||||
|
configurationFileFormat.EnableMouse = false;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 28)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 28.");
|
||||||
|
|
||||||
|
configurationFileFormat.Hotkeys = new KeyboardHotkeys
|
||||||
|
{
|
||||||
|
ToggleVsync = Key.F1,
|
||||||
|
Screenshot = Key.F8,
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 29)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 29.");
|
||||||
|
|
||||||
|
configurationFileFormat.Hotkeys = new KeyboardHotkeys
|
||||||
|
{
|
||||||
|
ToggleVsync = Key.F1,
|
||||||
|
Screenshot = Key.F8,
|
||||||
|
ShowUI = Key.F4,
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 30)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 30.");
|
||||||
|
|
||||||
|
foreach (InputConfig config in configurationFileFormat.InputConfig)
|
||||||
|
{
|
||||||
|
if (config is StandardControllerInputConfig controllerConfig)
|
||||||
|
{
|
||||||
|
controllerConfig.Rumble = new RumbleConfigController
|
||||||
|
{
|
||||||
|
EnableRumble = false,
|
||||||
|
StrongRumble = 1f,
|
||||||
|
WeakRumble = 1f,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 31)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 31.");
|
||||||
|
|
||||||
|
configurationFileFormat.BackendThreading = BackendThreading.Auto;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 32)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 32.");
|
||||||
|
|
||||||
|
configurationFileFormat.Hotkeys = new KeyboardHotkeys
|
||||||
|
{
|
||||||
|
ToggleVsync = configurationFileFormat.Hotkeys.ToggleVsync,
|
||||||
|
Screenshot = configurationFileFormat.Hotkeys.Screenshot,
|
||||||
|
ShowUI = configurationFileFormat.Hotkeys.ShowUI,
|
||||||
|
Pause = Key.F5,
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 33)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 33.");
|
||||||
|
|
||||||
|
configurationFileFormat.Hotkeys = new KeyboardHotkeys
|
||||||
|
{
|
||||||
|
ToggleVsync = configurationFileFormat.Hotkeys.ToggleVsync,
|
||||||
|
Screenshot = configurationFileFormat.Hotkeys.Screenshot,
|
||||||
|
ShowUI = configurationFileFormat.Hotkeys.ShowUI,
|
||||||
|
Pause = configurationFileFormat.Hotkeys.Pause,
|
||||||
|
ToggleMute = Key.F2,
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileFormat.AudioVolume = 1;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 34)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 34.");
|
||||||
|
|
||||||
|
configurationFileFormat.EnableInternetAccess = false;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 35)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 35.");
|
||||||
|
|
||||||
|
foreach (InputConfig config in configurationFileFormat.InputConfig)
|
||||||
|
{
|
||||||
|
if (config is StandardControllerInputConfig controllerConfig)
|
||||||
|
{
|
||||||
|
controllerConfig.RangeLeft = 1.0f;
|
||||||
|
controllerConfig.RangeRight = 1.0f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 36)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 36.");
|
||||||
|
|
||||||
|
configurationFileFormat.LoggingEnableTrace = false;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 37)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 37.");
|
||||||
|
|
||||||
|
configurationFileFormat.ShowConsole = true;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 38)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 38.");
|
||||||
|
|
||||||
|
configurationFileFormat.BaseStyle = "Dark";
|
||||||
|
configurationFileFormat.GameListViewMode = 0;
|
||||||
|
configurationFileFormat.ShowNames = true;
|
||||||
|
configurationFileFormat.GridSize = 2;
|
||||||
|
configurationFileFormat.LanguageCode = "en_US";
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 39)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 39.");
|
||||||
|
|
||||||
|
configurationFileFormat.Hotkeys = new KeyboardHotkeys
|
||||||
|
{
|
||||||
|
ToggleVsync = configurationFileFormat.Hotkeys.ToggleVsync,
|
||||||
|
Screenshot = configurationFileFormat.Hotkeys.Screenshot,
|
||||||
|
ShowUI = configurationFileFormat.Hotkeys.ShowUI,
|
||||||
|
Pause = configurationFileFormat.Hotkeys.Pause,
|
||||||
|
ToggleMute = configurationFileFormat.Hotkeys.ToggleMute,
|
||||||
|
ResScaleUp = Key.Unbound,
|
||||||
|
ResScaleDown = Key.Unbound,
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 40)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 40.");
|
||||||
|
|
||||||
|
configurationFileFormat.GraphicsBackend = GraphicsBackend.OpenGl;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 41)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 41.");
|
||||||
|
|
||||||
|
configurationFileFormat.Hotkeys = new KeyboardHotkeys
|
||||||
|
{
|
||||||
|
ToggleVsync = configurationFileFormat.Hotkeys.ToggleVsync,
|
||||||
|
Screenshot = configurationFileFormat.Hotkeys.Screenshot,
|
||||||
|
ShowUI = configurationFileFormat.Hotkeys.ShowUI,
|
||||||
|
Pause = configurationFileFormat.Hotkeys.Pause,
|
||||||
|
ToggleMute = configurationFileFormat.Hotkeys.ToggleMute,
|
||||||
|
ResScaleUp = configurationFileFormat.Hotkeys.ResScaleUp,
|
||||||
|
ResScaleDown = configurationFileFormat.Hotkeys.ResScaleDown,
|
||||||
|
VolumeUp = Key.Unbound,
|
||||||
|
VolumeDown = Key.Unbound,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 42)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 42.");
|
||||||
|
|
||||||
|
configurationFileFormat.EnableMacroHLE = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 43)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 43.");
|
||||||
|
|
||||||
|
configurationFileFormat.UseHypervisor = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 44)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 44.");
|
||||||
|
|
||||||
|
configurationFileFormat.AntiAliasing = AntiAliasing.None;
|
||||||
|
configurationFileFormat.ScalingFilter = ScalingFilter.Bilinear;
|
||||||
|
configurationFileFormat.ScalingFilterLevel = 80;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 45)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 45.");
|
||||||
|
|
||||||
|
configurationFileFormat.ShownFileTypes = new ShownFileTypes
|
||||||
|
{
|
||||||
|
NSP = true,
|
||||||
|
PFS0 = true,
|
||||||
|
XCI = true,
|
||||||
|
NCA = true,
|
||||||
|
NRO = true,
|
||||||
|
NSO = true,
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 46)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 46.");
|
||||||
|
|
||||||
|
configurationFileFormat.MultiplayerLanInterfaceId = "0";
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 47)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 47.");
|
||||||
|
|
||||||
|
configurationFileFormat.WindowStartup = new WindowStartup
|
||||||
|
{
|
||||||
|
WindowPositionX = 0,
|
||||||
|
WindowPositionY = 0,
|
||||||
|
WindowSizeHeight = 760,
|
||||||
|
WindowSizeWidth = 1280,
|
||||||
|
WindowMaximized = false,
|
||||||
|
};
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 48)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 48.");
|
||||||
|
|
||||||
|
configurationFileFormat.EnableColorSpacePassthrough = false;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 49)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 49.");
|
||||||
|
|
||||||
|
if (OperatingSystem.IsMacOS())
|
||||||
|
{
|
||||||
|
AppDataManager.FixMacOSConfigurationFolders();
|
||||||
|
}
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 50)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 50.");
|
||||||
|
|
||||||
|
configurationFileFormat.EnableHardwareAcceleration = true;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 51)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 51.");
|
||||||
|
|
||||||
|
configurationFileFormat.RememberWindowState = true;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 52)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 52.");
|
||||||
|
|
||||||
|
configurationFileFormat.AutoloadDirs = [];
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 53)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 53.");
|
||||||
|
|
||||||
|
configurationFileFormat.EnableLowPowerPtc = false;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 54)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 54.");
|
||||||
|
|
||||||
|
configurationFileFormat.DramSize = MemoryConfiguration.MemoryConfiguration4GiB;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 55)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 55.");
|
||||||
|
|
||||||
|
configurationFileFormat.IgnoreApplet = false;
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (configurationFileFormat.Version < 56)
|
||||||
|
{
|
||||||
|
Ryujinx.Common.Logging.Logger.Warning?.Print(LogClass.Application, $"Outdated configuration version {configurationFileFormat.Version}, migrating to version 56.");
|
||||||
|
|
||||||
|
configurationFileFormat.ShowTitleBar = !OperatingSystem.IsWindows();
|
||||||
|
|
||||||
|
configurationFileUpdated = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.EnableFileLog.Value = configurationFileFormat.EnableFileLog;
|
||||||
|
Graphics.ResScale.Value = configurationFileFormat.ResScale;
|
||||||
|
Graphics.ResScaleCustom.Value = configurationFileFormat.ResScaleCustom;
|
||||||
|
Graphics.MaxAnisotropy.Value = configurationFileFormat.MaxAnisotropy;
|
||||||
|
Graphics.AspectRatio.Value = configurationFileFormat.AspectRatio;
|
||||||
|
Graphics.ShadersDumpPath.Value = configurationFileFormat.GraphicsShadersDumpPath;
|
||||||
|
Graphics.BackendThreading.Value = configurationFileFormat.BackendThreading;
|
||||||
|
Graphics.GraphicsBackend.Value = configurationFileFormat.GraphicsBackend;
|
||||||
|
Graphics.PreferredGpu.Value = configurationFileFormat.PreferredGpu;
|
||||||
|
Graphics.AntiAliasing.Value = configurationFileFormat.AntiAliasing;
|
||||||
|
Graphics.ScalingFilter.Value = configurationFileFormat.ScalingFilter;
|
||||||
|
Graphics.ScalingFilterLevel.Value = configurationFileFormat.ScalingFilterLevel;
|
||||||
|
Logger.EnableDebug.Value = configurationFileFormat.LoggingEnableDebug;
|
||||||
|
Logger.EnableStub.Value = configurationFileFormat.LoggingEnableStub;
|
||||||
|
Logger.EnableInfo.Value = configurationFileFormat.LoggingEnableInfo;
|
||||||
|
Logger.EnableWarn.Value = configurationFileFormat.LoggingEnableWarn;
|
||||||
|
Logger.EnableError.Value = configurationFileFormat.LoggingEnableError;
|
||||||
|
Logger.EnableTrace.Value = configurationFileFormat.LoggingEnableTrace;
|
||||||
|
Logger.EnableGuest.Value = configurationFileFormat.LoggingEnableGuest;
|
||||||
|
Logger.EnableFsAccessLog.Value = configurationFileFormat.LoggingEnableFsAccessLog;
|
||||||
|
Logger.FilteredClasses.Value = configurationFileFormat.LoggingFilteredClasses;
|
||||||
|
Logger.GraphicsDebugLevel.Value = configurationFileFormat.LoggingGraphicsDebugLevel;
|
||||||
|
System.Language.Value = configurationFileFormat.SystemLanguage;
|
||||||
|
System.Region.Value = configurationFileFormat.SystemRegion;
|
||||||
|
System.TimeZone.Value = configurationFileFormat.SystemTimeZone;
|
||||||
|
System.SystemTimeOffset.Value = configurationFileFormat.SystemTimeOffset;
|
||||||
|
System.EnableDockedMode.Value = configurationFileFormat.DockedMode;
|
||||||
|
EnableDiscordIntegration.Value = configurationFileFormat.EnableDiscordIntegration;
|
||||||
|
CheckUpdatesOnStart.Value = configurationFileFormat.CheckUpdatesOnStart;
|
||||||
|
ShowConfirmExit.Value = configurationFileFormat.ShowConfirmExit;
|
||||||
|
IgnoreApplet.Value = configurationFileFormat.IgnoreApplet;
|
||||||
|
RememberWindowState.Value = configurationFileFormat.RememberWindowState;
|
||||||
|
ShowTitleBar.Value = configurationFileFormat.ShowTitleBar;
|
||||||
|
EnableHardwareAcceleration.Value = configurationFileFormat.EnableHardwareAcceleration;
|
||||||
|
HideCursor.Value = configurationFileFormat.HideCursor;
|
||||||
|
Graphics.EnableVsync.Value = configurationFileFormat.EnableVsync;
|
||||||
|
Graphics.EnableShaderCache.Value = configurationFileFormat.EnableShaderCache;
|
||||||
|
Graphics.EnableTextureRecompression.Value = configurationFileFormat.EnableTextureRecompression;
|
||||||
|
Graphics.EnableMacroHLE.Value = configurationFileFormat.EnableMacroHLE;
|
||||||
|
Graphics.EnableColorSpacePassthrough.Value = configurationFileFormat.EnableColorSpacePassthrough;
|
||||||
|
System.EnablePtc.Value = configurationFileFormat.EnablePtc;
|
||||||
|
System.EnableLowPowerPtc.Value = configurationFileFormat.EnableLowPowerPtc;
|
||||||
|
System.EnableInternetAccess.Value = configurationFileFormat.EnableInternetAccess;
|
||||||
|
System.EnableFsIntegrityChecks.Value = configurationFileFormat.EnableFsIntegrityChecks;
|
||||||
|
System.FsGlobalAccessLogMode.Value = configurationFileFormat.FsGlobalAccessLogMode;
|
||||||
|
System.AudioBackend.Value = configurationFileFormat.AudioBackend;
|
||||||
|
System.AudioVolume.Value = configurationFileFormat.AudioVolume;
|
||||||
|
System.MemoryManagerMode.Value = configurationFileFormat.MemoryManagerMode;
|
||||||
|
System.DramSize.Value = configurationFileFormat.DramSize;
|
||||||
|
System.IgnoreMissingServices.Value = configurationFileFormat.IgnoreMissingServices;
|
||||||
|
System.UseHypervisor.Value = configurationFileFormat.UseHypervisor;
|
||||||
|
UI.GuiColumns.FavColumn.Value = configurationFileFormat.GuiColumns.FavColumn;
|
||||||
|
UI.GuiColumns.IconColumn.Value = configurationFileFormat.GuiColumns.IconColumn;
|
||||||
|
UI.GuiColumns.AppColumn.Value = configurationFileFormat.GuiColumns.AppColumn;
|
||||||
|
UI.GuiColumns.DevColumn.Value = configurationFileFormat.GuiColumns.DevColumn;
|
||||||
|
UI.GuiColumns.VersionColumn.Value = configurationFileFormat.GuiColumns.VersionColumn;
|
||||||
|
UI.GuiColumns.TimePlayedColumn.Value = configurationFileFormat.GuiColumns.TimePlayedColumn;
|
||||||
|
UI.GuiColumns.LastPlayedColumn.Value = configurationFileFormat.GuiColumns.LastPlayedColumn;
|
||||||
|
UI.GuiColumns.FileExtColumn.Value = configurationFileFormat.GuiColumns.FileExtColumn;
|
||||||
|
UI.GuiColumns.FileSizeColumn.Value = configurationFileFormat.GuiColumns.FileSizeColumn;
|
||||||
|
UI.GuiColumns.PathColumn.Value = configurationFileFormat.GuiColumns.PathColumn;
|
||||||
|
UI.ColumnSort.SortColumnId.Value = configurationFileFormat.ColumnSort.SortColumnId;
|
||||||
|
UI.ColumnSort.SortAscending.Value = configurationFileFormat.ColumnSort.SortAscending;
|
||||||
|
UI.GameDirs.Value = configurationFileFormat.GameDirs;
|
||||||
|
UI.AutoloadDirs.Value = configurationFileFormat.AutoloadDirs ?? [];
|
||||||
|
UI.ShownFileTypes.NSP.Value = configurationFileFormat.ShownFileTypes.NSP;
|
||||||
|
UI.ShownFileTypes.PFS0.Value = configurationFileFormat.ShownFileTypes.PFS0;
|
||||||
|
UI.ShownFileTypes.XCI.Value = configurationFileFormat.ShownFileTypes.XCI;
|
||||||
|
UI.ShownFileTypes.NCA.Value = configurationFileFormat.ShownFileTypes.NCA;
|
||||||
|
UI.ShownFileTypes.NRO.Value = configurationFileFormat.ShownFileTypes.NRO;
|
||||||
|
UI.ShownFileTypes.NSO.Value = configurationFileFormat.ShownFileTypes.NSO;
|
||||||
|
UI.LanguageCode.Value = configurationFileFormat.LanguageCode;
|
||||||
|
UI.BaseStyle.Value = configurationFileFormat.BaseStyle;
|
||||||
|
UI.GameListViewMode.Value = configurationFileFormat.GameListViewMode;
|
||||||
|
UI.ShowNames.Value = configurationFileFormat.ShowNames;
|
||||||
|
UI.IsAscendingOrder.Value = configurationFileFormat.IsAscendingOrder;
|
||||||
|
UI.GridSize.Value = configurationFileFormat.GridSize;
|
||||||
|
UI.ApplicationSort.Value = configurationFileFormat.ApplicationSort;
|
||||||
|
UI.StartFullscreen.Value = configurationFileFormat.StartFullscreen;
|
||||||
|
UI.ShowConsole.Value = configurationFileFormat.ShowConsole;
|
||||||
|
UI.WindowStartup.WindowSizeWidth.Value = configurationFileFormat.WindowStartup.WindowSizeWidth;
|
||||||
|
UI.WindowStartup.WindowSizeHeight.Value = configurationFileFormat.WindowStartup.WindowSizeHeight;
|
||||||
|
UI.WindowStartup.WindowPositionX.Value = configurationFileFormat.WindowStartup.WindowPositionX;
|
||||||
|
UI.WindowStartup.WindowPositionY.Value = configurationFileFormat.WindowStartup.WindowPositionY;
|
||||||
|
UI.WindowStartup.WindowMaximized.Value = configurationFileFormat.WindowStartup.WindowMaximized;
|
||||||
|
Hid.EnableKeyboard.Value = configurationFileFormat.EnableKeyboard;
|
||||||
|
Hid.EnableMouse.Value = configurationFileFormat.EnableMouse;
|
||||||
|
Hid.Hotkeys.Value = configurationFileFormat.Hotkeys;
|
||||||
|
Hid.InputConfig.Value = configurationFileFormat.InputConfig ?? [];
|
||||||
|
|
||||||
|
Multiplayer.LanInterfaceId.Value = configurationFileFormat.MultiplayerLanInterfaceId;
|
||||||
|
Multiplayer.Mode.Value = configurationFileFormat.MultiplayerMode;
|
||||||
|
Multiplayer.DisableP2p.Value = configurationFileFormat.MultiplayerDisableP2p;
|
||||||
|
Multiplayer.LdnPassphrase.Value = configurationFileFormat.MultiplayerLdnPassphrase;
|
||||||
|
Multiplayer.LdnServer.Value = configurationFileFormat.LdnServer;
|
||||||
|
|
||||||
|
if (configurationFileUpdated)
|
||||||
|
{
|
||||||
|
ToFileFormat().SaveConfig(configurationFilePath);
|
||||||
|
|
||||||
|
Ryujinx.Common.Logging.Logger.Notice.Print(LogClass.Application, $"Configuration file updated to version {ConfigurationFileFormat.CurrentVersion}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
700
src/Ryujinx.UI.Common/Configuration/ConfigurationState.Model.cs
Normal file
700
src/Ryujinx.UI.Common/Configuration/ConfigurationState.Model.cs
Normal file
@ -0,0 +1,700 @@
|
|||||||
|
using ARMeilleure;
|
||||||
|
using Ryujinx.Common;
|
||||||
|
using Ryujinx.Common.Configuration;
|
||||||
|
using Ryujinx.Common.Configuration.Hid;
|
||||||
|
using Ryujinx.Common.Configuration.Multiplayer;
|
||||||
|
using Ryujinx.Common.Logging;
|
||||||
|
using Ryujinx.HLE;
|
||||||
|
using Ryujinx.UI.Common.Configuration.System;
|
||||||
|
using Ryujinx.UI.Common.Helper;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace Ryujinx.UI.Common.Configuration
|
||||||
|
{
|
||||||
|
public partial class ConfigurationState
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// UI configuration section
|
||||||
|
/// </summary>
|
||||||
|
public class UISection
|
||||||
|
{
|
||||||
|
public class Columns
|
||||||
|
{
|
||||||
|
public ReactiveObject<bool> FavColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> IconColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> AppColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> DevColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> VersionColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> LdnInfoColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> TimePlayedColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> LastPlayedColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> FileExtColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> FileSizeColumn { get; private set; }
|
||||||
|
public ReactiveObject<bool> PathColumn { get; private set; }
|
||||||
|
|
||||||
|
public Columns()
|
||||||
|
{
|
||||||
|
FavColumn = new ReactiveObject<bool>();
|
||||||
|
IconColumn = new ReactiveObject<bool>();
|
||||||
|
AppColumn = new ReactiveObject<bool>();
|
||||||
|
DevColumn = new ReactiveObject<bool>();
|
||||||
|
VersionColumn = new ReactiveObject<bool>();
|
||||||
|
LdnInfoColumn = new ReactiveObject<bool>();
|
||||||
|
TimePlayedColumn = new ReactiveObject<bool>();
|
||||||
|
LastPlayedColumn = new ReactiveObject<bool>();
|
||||||
|
FileExtColumn = new ReactiveObject<bool>();
|
||||||
|
FileSizeColumn = new ReactiveObject<bool>();
|
||||||
|
PathColumn = new ReactiveObject<bool>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class ColumnSortSettings
|
||||||
|
{
|
||||||
|
public ReactiveObject<int> SortColumnId { get; private set; }
|
||||||
|
public ReactiveObject<bool> SortAscending { get; private set; }
|
||||||
|
|
||||||
|
public ColumnSortSettings()
|
||||||
|
{
|
||||||
|
SortColumnId = new ReactiveObject<int>();
|
||||||
|
SortAscending = new ReactiveObject<bool>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Used to toggle which file types are shown in the UI
|
||||||
|
/// </summary>
|
||||||
|
public class ShownFileTypeSettings
|
||||||
|
{
|
||||||
|
public ReactiveObject<bool> NSP { get; private set; }
|
||||||
|
public ReactiveObject<bool> PFS0 { get; private set; }
|
||||||
|
public ReactiveObject<bool> XCI { get; private set; }
|
||||||
|
public ReactiveObject<bool> NCA { get; private set; }
|
||||||
|
public ReactiveObject<bool> NRO { get; private set; }
|
||||||
|
public ReactiveObject<bool> NSO { get; private set; }
|
||||||
|
|
||||||
|
public ShownFileTypeSettings()
|
||||||
|
{
|
||||||
|
NSP = new ReactiveObject<bool>();
|
||||||
|
PFS0 = new ReactiveObject<bool>();
|
||||||
|
XCI = new ReactiveObject<bool>();
|
||||||
|
NCA = new ReactiveObject<bool>();
|
||||||
|
NRO = new ReactiveObject<bool>();
|
||||||
|
NSO = new ReactiveObject<bool>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// <summary>
|
||||||
|
/// Determines main window start-up position, size and state
|
||||||
|
///<summary>
|
||||||
|
public class WindowStartupSettings
|
||||||
|
{
|
||||||
|
public ReactiveObject<int> WindowSizeWidth { get; private set; }
|
||||||
|
public ReactiveObject<int> WindowSizeHeight { get; private set; }
|
||||||
|
public ReactiveObject<int> WindowPositionX { get; private set; }
|
||||||
|
public ReactiveObject<int> WindowPositionY { get; private set; }
|
||||||
|
public ReactiveObject<bool> WindowMaximized { get; private set; }
|
||||||
|
|
||||||
|
public WindowStartupSettings()
|
||||||
|
{
|
||||||
|
WindowSizeWidth = new ReactiveObject<int>();
|
||||||
|
WindowSizeHeight = new ReactiveObject<int>();
|
||||||
|
WindowPositionX = new ReactiveObject<int>();
|
||||||
|
WindowPositionY = new ReactiveObject<int>();
|
||||||
|
WindowMaximized = new ReactiveObject<bool>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Used to toggle columns in the GUI
|
||||||
|
/// </summary>
|
||||||
|
public Columns GuiColumns { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Used to configure column sort settings in the GUI
|
||||||
|
/// </summary>
|
||||||
|
public ColumnSortSettings ColumnSort { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// A list of directories containing games to be used to load games into the games list
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<List<string>> GameDirs { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// A list of directories containing DLC/updates the user wants to autoload during library refreshes
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<List<string>> AutoloadDirs { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// A list of file types to be hidden in the games List
|
||||||
|
/// </summary>
|
||||||
|
public ShownFileTypeSettings ShownFileTypes { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Determines main window start-up position, size and state
|
||||||
|
/// </summary>
|
||||||
|
public WindowStartupSettings WindowStartup { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Language Code for the UI
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<string> LanguageCode { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Selects the base style
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<string> BaseStyle { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Start games in fullscreen mode
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> StartFullscreen { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Hide / Show Console Window
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> ShowConsole { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// View Mode of the Game list
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<int> GameListViewMode { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Show application name in Grid Mode
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> ShowNames { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Sets App Icon Size in Grid Mode
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<int> GridSize { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Sorts Apps in Grid Mode
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<int> ApplicationSort { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Sets if Grid is ordered in Ascending Order
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> IsAscendingOrder { get; private set; }
|
||||||
|
|
||||||
|
public UISection()
|
||||||
|
{
|
||||||
|
GuiColumns = new Columns();
|
||||||
|
ColumnSort = new ColumnSortSettings();
|
||||||
|
GameDirs = new ReactiveObject<List<string>>();
|
||||||
|
AutoloadDirs = new ReactiveObject<List<string>>();
|
||||||
|
ShownFileTypes = new ShownFileTypeSettings();
|
||||||
|
WindowStartup = new WindowStartupSettings();
|
||||||
|
BaseStyle = new ReactiveObject<string>();
|
||||||
|
StartFullscreen = new ReactiveObject<bool>();
|
||||||
|
GameListViewMode = new ReactiveObject<int>();
|
||||||
|
ShowNames = new ReactiveObject<bool>();
|
||||||
|
GridSize = new ReactiveObject<int>();
|
||||||
|
ApplicationSort = new ReactiveObject<int>();
|
||||||
|
IsAscendingOrder = new ReactiveObject<bool>();
|
||||||
|
LanguageCode = new ReactiveObject<string>();
|
||||||
|
ShowConsole = new ReactiveObject<bool>();
|
||||||
|
ShowConsole.Event += static (_, e) => ConsoleHelper.SetConsoleWindowState(e.NewValue);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Logger configuration section
|
||||||
|
/// </summary>
|
||||||
|
public class LoggerSection
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Enables printing debug log messages
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableDebug { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables printing stub log messages
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableStub { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables printing info log messages
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableInfo { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables printing warning log messages
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableWarn { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables printing error log messages
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableError { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables printing trace log messages
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableTrace { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables printing guest log messages
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableGuest { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables printing FS access log messages
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableFsAccessLog { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Controls which log messages are written to the log targets
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<LogClass[]> FilteredClasses { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables logging to a file on disk
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableFileLog { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Controls which OpenGL log messages are recorded in the log
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<GraphicsDebugLevel> GraphicsDebugLevel { get; private set; }
|
||||||
|
|
||||||
|
public LoggerSection()
|
||||||
|
{
|
||||||
|
EnableDebug = new ReactiveObject<bool>();
|
||||||
|
EnableDebug.LogChangesToValue(nameof(EnableDebug));
|
||||||
|
EnableStub = new ReactiveObject<bool>();
|
||||||
|
EnableInfo = new ReactiveObject<bool>();
|
||||||
|
EnableWarn = new ReactiveObject<bool>();
|
||||||
|
EnableError = new ReactiveObject<bool>();
|
||||||
|
EnableTrace = new ReactiveObject<bool>();
|
||||||
|
EnableGuest = new ReactiveObject<bool>();
|
||||||
|
EnableFsAccessLog = new ReactiveObject<bool>();
|
||||||
|
FilteredClasses = new ReactiveObject<LogClass[]>();
|
||||||
|
EnableFileLog = new ReactiveObject<bool>();
|
||||||
|
EnableFileLog.LogChangesToValue(nameof(EnableFileLog));
|
||||||
|
GraphicsDebugLevel = new ReactiveObject<GraphicsDebugLevel>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// System configuration section
|
||||||
|
/// </summary>
|
||||||
|
public class SystemSection
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Change System Language
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<Language> Language { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Change System Region
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<Region> Region { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Change System TimeZone
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<string> TimeZone { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// System Time Offset in Seconds
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<long> SystemTimeOffset { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables Docked Mode
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableDockedMode { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables persistent profiled translation cache
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnablePtc { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables low-power persistent profiled translation cache loading
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableLowPowerPtc { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables guest Internet access
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableInternetAccess { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables integrity checks on Game content files
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableFsIntegrityChecks { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables FS access log output to the console. Possible modes are 0-3
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<int> FsGlobalAccessLogMode { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The selected audio backend
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<AudioBackend> AudioBackend { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The audio backend volume
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<float> AudioVolume { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The selected memory manager mode
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<MemoryManagerMode> MemoryManagerMode { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Defines the amount of RAM available on the emulated system, and how it is distributed
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<MemoryConfiguration> DramSize { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enable or disable ignoring missing services
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> IgnoreMissingServices { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Uses Hypervisor over JIT if available
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> UseHypervisor { get; private set; }
|
||||||
|
|
||||||
|
public SystemSection()
|
||||||
|
{
|
||||||
|
Language = new ReactiveObject<Language>();
|
||||||
|
Language.LogChangesToValue(nameof(Language));
|
||||||
|
Region = new ReactiveObject<Region>();
|
||||||
|
Region.LogChangesToValue(nameof(Region));
|
||||||
|
TimeZone = new ReactiveObject<string>();
|
||||||
|
TimeZone.LogChangesToValue(nameof(TimeZone));
|
||||||
|
SystemTimeOffset = new ReactiveObject<long>();
|
||||||
|
SystemTimeOffset.LogChangesToValue(nameof(SystemTimeOffset));
|
||||||
|
EnableDockedMode = new ReactiveObject<bool>();
|
||||||
|
EnableDockedMode.LogChangesToValue(nameof(EnableDockedMode));
|
||||||
|
EnablePtc = new ReactiveObject<bool>();
|
||||||
|
EnablePtc.LogChangesToValue(nameof(EnablePtc));
|
||||||
|
EnableLowPowerPtc = new ReactiveObject<bool>();
|
||||||
|
EnableLowPowerPtc.LogChangesToValue(nameof(EnableLowPowerPtc));
|
||||||
|
EnableLowPowerPtc.Event += (_, evnt)
|
||||||
|
=> Optimizations.LowPower = evnt.NewValue;
|
||||||
|
EnableInternetAccess = new ReactiveObject<bool>();
|
||||||
|
EnableInternetAccess.LogChangesToValue(nameof(EnableInternetAccess));
|
||||||
|
EnableFsIntegrityChecks = new ReactiveObject<bool>();
|
||||||
|
EnableFsIntegrityChecks.LogChangesToValue(nameof(EnableFsIntegrityChecks));
|
||||||
|
FsGlobalAccessLogMode = new ReactiveObject<int>();
|
||||||
|
FsGlobalAccessLogMode.LogChangesToValue(nameof(FsGlobalAccessLogMode));
|
||||||
|
AudioBackend = new ReactiveObject<AudioBackend>();
|
||||||
|
AudioBackend.LogChangesToValue(nameof(AudioBackend));
|
||||||
|
MemoryManagerMode = new ReactiveObject<MemoryManagerMode>();
|
||||||
|
MemoryManagerMode.LogChangesToValue(nameof(MemoryManagerMode));
|
||||||
|
DramSize = new ReactiveObject<MemoryConfiguration>();
|
||||||
|
DramSize.LogChangesToValue(nameof(DramSize));
|
||||||
|
IgnoreMissingServices = new ReactiveObject<bool>();
|
||||||
|
IgnoreMissingServices.LogChangesToValue(nameof(IgnoreMissingServices));
|
||||||
|
AudioVolume = new ReactiveObject<float>();
|
||||||
|
AudioVolume.LogChangesToValue(nameof(AudioVolume));
|
||||||
|
UseHypervisor = new ReactiveObject<bool>();
|
||||||
|
UseHypervisor.LogChangesToValue(nameof(UseHypervisor));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Hid configuration section
|
||||||
|
/// </summary>
|
||||||
|
public class HidSection
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Enable or disable keyboard support (Independent from controllers binding)
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableKeyboard { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enable or disable mouse support (Independent from controllers binding)
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableMouse { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Hotkey Keyboard Bindings
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<KeyboardHotkeys> Hotkeys { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Input device configuration.
|
||||||
|
/// NOTE: This ReactiveObject won't issue an event when the List has elements added or removed.
|
||||||
|
/// TODO: Implement a ReactiveList class.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<List<InputConfig>> InputConfig { get; private set; }
|
||||||
|
|
||||||
|
public HidSection()
|
||||||
|
{
|
||||||
|
EnableKeyboard = new ReactiveObject<bool>();
|
||||||
|
EnableMouse = new ReactiveObject<bool>();
|
||||||
|
Hotkeys = new ReactiveObject<KeyboardHotkeys>();
|
||||||
|
InputConfig = new ReactiveObject<List<InputConfig>>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Graphics configuration section
|
||||||
|
/// </summary>
|
||||||
|
public class GraphicsSection
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Whether or not backend threading is enabled. The "Auto" setting will determine whether threading should be enabled at runtime.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<BackendThreading> BackendThreading { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Max Anisotropy. Values range from 0 - 16. Set to -1 to let the game decide.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<float> MaxAnisotropy { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Aspect Ratio applied to the renderer window.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<AspectRatio> AspectRatio { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Resolution Scale. An integer scale applied to applicable render targets. Values 1-4, or -1 to use a custom floating point scale instead.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<int> ResScale { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Custom Resolution Scale. A custom floating point scale applied to applicable render targets. Only active when Resolution Scale is -1.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<float> ResScaleCustom { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Dumps shaders in this local directory
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<string> ShadersDumpPath { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables Vertical Sync
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableVsync { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables Shader cache
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableShaderCache { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables texture recompression
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableTextureRecompression { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables Macro high-level emulation
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableMacroHLE { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables color space passthrough, if available.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableColorSpacePassthrough { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Graphics backend
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<GraphicsBackend> GraphicsBackend { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Applies anti-aliasing to the renderer.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<AntiAliasing> AntiAliasing { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Sets the framebuffer upscaling type.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<ScalingFilter> ScalingFilter { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Sets the framebuffer upscaling level.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<int> ScalingFilterLevel { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Preferred GPU
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<string> PreferredGpu { get; private set; }
|
||||||
|
|
||||||
|
public GraphicsSection()
|
||||||
|
{
|
||||||
|
BackendThreading = new ReactiveObject<BackendThreading>();
|
||||||
|
BackendThreading.LogChangesToValue(nameof(BackendThreading));
|
||||||
|
ResScale = new ReactiveObject<int>();
|
||||||
|
ResScale.LogChangesToValue(nameof(ResScale));
|
||||||
|
ResScaleCustom = new ReactiveObject<float>();
|
||||||
|
ResScaleCustom.LogChangesToValue(nameof(ResScaleCustom));
|
||||||
|
MaxAnisotropy = new ReactiveObject<float>();
|
||||||
|
MaxAnisotropy.LogChangesToValue(nameof(MaxAnisotropy));
|
||||||
|
AspectRatio = new ReactiveObject<AspectRatio>();
|
||||||
|
AspectRatio.LogChangesToValue(nameof(AspectRatio));
|
||||||
|
ShadersDumpPath = new ReactiveObject<string>();
|
||||||
|
EnableVsync = new ReactiveObject<bool>();
|
||||||
|
EnableVsync.LogChangesToValue(nameof(EnableVsync));
|
||||||
|
EnableShaderCache = new ReactiveObject<bool>();
|
||||||
|
EnableShaderCache.LogChangesToValue(nameof(EnableShaderCache));
|
||||||
|
EnableTextureRecompression = new ReactiveObject<bool>();
|
||||||
|
EnableTextureRecompression.LogChangesToValue(nameof(EnableTextureRecompression));
|
||||||
|
GraphicsBackend = new ReactiveObject<GraphicsBackend>();
|
||||||
|
GraphicsBackend.LogChangesToValue(nameof(GraphicsBackend));
|
||||||
|
PreferredGpu = new ReactiveObject<string>();
|
||||||
|
PreferredGpu.LogChangesToValue(nameof(PreferredGpu));
|
||||||
|
EnableMacroHLE = new ReactiveObject<bool>();
|
||||||
|
EnableMacroHLE.LogChangesToValue(nameof(EnableMacroHLE));
|
||||||
|
EnableColorSpacePassthrough = new ReactiveObject<bool>();
|
||||||
|
EnableColorSpacePassthrough.LogChangesToValue(nameof(EnableColorSpacePassthrough));
|
||||||
|
AntiAliasing = new ReactiveObject<AntiAliasing>();
|
||||||
|
AntiAliasing.LogChangesToValue(nameof(AntiAliasing));
|
||||||
|
ScalingFilter = new ReactiveObject<ScalingFilter>();
|
||||||
|
ScalingFilter.LogChangesToValue(nameof(ScalingFilter));
|
||||||
|
ScalingFilterLevel = new ReactiveObject<int>();
|
||||||
|
ScalingFilterLevel.LogChangesToValue(nameof(ScalingFilterLevel));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Multiplayer configuration section
|
||||||
|
/// </summary>
|
||||||
|
public class MultiplayerSection
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// GUID for the network interface used by LAN (or 0 for default)
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<string> LanInterfaceId { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Multiplayer Mode
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<MultiplayerMode> Mode { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Disable P2P
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> DisableP2p { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// LDN PassPhrase
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<string> LdnPassphrase { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// LDN Server
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<string> LdnServer { get; private set; }
|
||||||
|
|
||||||
|
public MultiplayerSection()
|
||||||
|
{
|
||||||
|
LanInterfaceId = new ReactiveObject<string>();
|
||||||
|
Mode = new ReactiveObject<MultiplayerMode>();
|
||||||
|
Mode.LogChangesToValue(nameof(MultiplayerMode));
|
||||||
|
DisableP2p = new ReactiveObject<bool>();
|
||||||
|
DisableP2p.LogChangesToValue(nameof(DisableP2p));
|
||||||
|
LdnPassphrase = new ReactiveObject<string>();
|
||||||
|
LdnPassphrase.LogChangesToValue(nameof(LdnPassphrase));
|
||||||
|
LdnServer = new ReactiveObject<string>();
|
||||||
|
LdnServer.LogChangesToValue(nameof(LdnServer));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The default configuration instance
|
||||||
|
/// </summary>
|
||||||
|
public static ConfigurationState Instance { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The UI section
|
||||||
|
/// </summary>
|
||||||
|
public UISection UI { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The Logger section
|
||||||
|
/// </summary>
|
||||||
|
public LoggerSection Logger { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The System section
|
||||||
|
/// </summary>
|
||||||
|
public SystemSection System { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The Graphics section
|
||||||
|
/// </summary>
|
||||||
|
public GraphicsSection Graphics { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The Hid section
|
||||||
|
/// </summary>
|
||||||
|
public HidSection Hid { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The Multiplayer section
|
||||||
|
/// </summary>
|
||||||
|
public MultiplayerSection Multiplayer { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables Discord Rich Presence
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableDiscordIntegration { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Checks for updates when Ryujinx starts when enabled
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> CheckUpdatesOnStart { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Show "Confirm Exit" Dialog
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> ShowConfirmExit { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Ignore Applet
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> IgnoreApplet { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables save window size, position and state on close.
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> RememberWindowState { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables or disables the redesigned title bar
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> ShowTitleBar { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Enables hardware-accelerated rendering for Avalonia
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<bool> EnableHardwareAcceleration { get; private set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Hide Cursor on Idle
|
||||||
|
/// </summary>
|
||||||
|
public ReactiveObject<HideCursorMode> HideCursor { get; private set; }
|
||||||
|
|
||||||
|
private ConfigurationState()
|
||||||
|
{
|
||||||
|
UI = new UISection();
|
||||||
|
Logger = new LoggerSection();
|
||||||
|
System = new SystemSection();
|
||||||
|
Graphics = new GraphicsSection();
|
||||||
|
Hid = new HidSection();
|
||||||
|
Multiplayer = new MultiplayerSection();
|
||||||
|
EnableDiscordIntegration = new ReactiveObject<bool>();
|
||||||
|
CheckUpdatesOnStart = new ReactiveObject<bool>();
|
||||||
|
ShowConfirmExit = new ReactiveObject<bool>();
|
||||||
|
IgnoreApplet = new ReactiveObject<bool>();
|
||||||
|
IgnoreApplet.LogChangesToValue(nameof(IgnoreApplet));
|
||||||
|
RememberWindowState = new ReactiveObject<bool>();
|
||||||
|
ShowTitleBar = new ReactiveObject<bool>();
|
||||||
|
EnableHardwareAcceleration = new ReactiveObject<bool>();
|
||||||
|
HideCursor = new ReactiveObject<HideCursorMode>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
File diff suppressed because it is too large
Load Diff
@ -1,4 +1,3 @@
|
|||||||
using Ryujinx.Common;
|
|
||||||
using Ryujinx.Common.Configuration;
|
using Ryujinx.Common.Configuration;
|
||||||
using Ryujinx.Common.Logging;
|
using Ryujinx.Common.Logging;
|
||||||
using Ryujinx.Common.Logging.Targets;
|
using Ryujinx.Common.Logging.Targets;
|
||||||
@ -11,103 +10,69 @@ namespace Ryujinx.UI.Common.Configuration
|
|||||||
{
|
{
|
||||||
public static void Initialize()
|
public static void Initialize()
|
||||||
{
|
{
|
||||||
ConfigurationState.Instance.Logger.EnableDebug.Event += ReloadEnableDebug;
|
ConfigurationState.Instance.Logger.EnableDebug.Event +=
|
||||||
ConfigurationState.Instance.Logger.EnableStub.Event += ReloadEnableStub;
|
(_, e) => Logger.SetEnable(LogLevel.Debug, e.NewValue);
|
||||||
ConfigurationState.Instance.Logger.EnableInfo.Event += ReloadEnableInfo;
|
ConfigurationState.Instance.Logger.EnableStub.Event +=
|
||||||
ConfigurationState.Instance.Logger.EnableWarn.Event += ReloadEnableWarning;
|
(_, e) => Logger.SetEnable(LogLevel.Stub, e.NewValue);
|
||||||
ConfigurationState.Instance.Logger.EnableError.Event += ReloadEnableError;
|
ConfigurationState.Instance.Logger.EnableInfo.Event +=
|
||||||
ConfigurationState.Instance.Logger.EnableTrace.Event += ReloadEnableTrace;
|
(_, e) => Logger.SetEnable(LogLevel.Info, e.NewValue);
|
||||||
ConfigurationState.Instance.Logger.EnableGuest.Event += ReloadEnableGuest;
|
ConfigurationState.Instance.Logger.EnableWarn.Event +=
|
||||||
ConfigurationState.Instance.Logger.EnableFsAccessLog.Event += ReloadEnableFsAccessLog;
|
(_, e) => Logger.SetEnable(LogLevel.Warning, e.NewValue);
|
||||||
ConfigurationState.Instance.Logger.FilteredClasses.Event += ReloadFilteredClasses;
|
ConfigurationState.Instance.Logger.EnableError.Event +=
|
||||||
ConfigurationState.Instance.Logger.EnableFileLog.Event += ReloadFileLogger;
|
(_, e) => Logger.SetEnable(LogLevel.Error, e.NewValue);
|
||||||
}
|
ConfigurationState.Instance.Logger.EnableTrace.Event +=
|
||||||
|
(_, e) => Logger.SetEnable(LogLevel.Trace, e.NewValue);
|
||||||
|
ConfigurationState.Instance.Logger.EnableGuest.Event +=
|
||||||
|
(_, e) => Logger.SetEnable(LogLevel.Guest, e.NewValue);
|
||||||
|
ConfigurationState.Instance.Logger.EnableFsAccessLog.Event +=
|
||||||
|
(_, e) => Logger.SetEnable(LogLevel.AccessLog, e.NewValue);
|
||||||
|
|
||||||
private static void ReloadEnableDebug(object sender, ReactiveEventArgs<bool> e)
|
ConfigurationState.Instance.Logger.FilteredClasses.Event += (_, e) =>
|
||||||
{
|
|
||||||
Logger.SetEnable(LogLevel.Debug, e.NewValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ReloadEnableStub(object sender, ReactiveEventArgs<bool> e)
|
|
||||||
{
|
|
||||||
Logger.SetEnable(LogLevel.Stub, e.NewValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ReloadEnableInfo(object sender, ReactiveEventArgs<bool> e)
|
|
||||||
{
|
|
||||||
Logger.SetEnable(LogLevel.Info, e.NewValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ReloadEnableWarning(object sender, ReactiveEventArgs<bool> e)
|
|
||||||
{
|
|
||||||
Logger.SetEnable(LogLevel.Warning, e.NewValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ReloadEnableError(object sender, ReactiveEventArgs<bool> e)
|
|
||||||
{
|
|
||||||
Logger.SetEnable(LogLevel.Error, e.NewValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ReloadEnableTrace(object sender, ReactiveEventArgs<bool> e)
|
|
||||||
{
|
|
||||||
Logger.SetEnable(LogLevel.Trace, e.NewValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ReloadEnableGuest(object sender, ReactiveEventArgs<bool> e)
|
|
||||||
{
|
|
||||||
Logger.SetEnable(LogLevel.Guest, e.NewValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ReloadEnableFsAccessLog(object sender, ReactiveEventArgs<bool> e)
|
|
||||||
{
|
|
||||||
Logger.SetEnable(LogLevel.AccessLog, e.NewValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ReloadFilteredClasses(object sender, ReactiveEventArgs<LogClass[]> e)
|
|
||||||
{
|
|
||||||
bool noFilter = e.NewValue.Length == 0;
|
|
||||||
|
|
||||||
foreach (var logClass in Enum.GetValues<LogClass>())
|
|
||||||
{
|
{
|
||||||
Logger.SetEnable(logClass, noFilter);
|
bool noFilter = e.NewValue.Length == 0;
|
||||||
}
|
|
||||||
|
|
||||||
foreach (var logClass in e.NewValue)
|
foreach (var logClass in Enum.GetValues<LogClass>())
|
||||||
{
|
|
||||||
Logger.SetEnable(logClass, true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void ReloadFileLogger(object sender, ReactiveEventArgs<bool> e)
|
|
||||||
{
|
|
||||||
if (e.NewValue)
|
|
||||||
{
|
|
||||||
string logDir = AppDataManager.LogsDirPath;
|
|
||||||
FileStream logFile = null;
|
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(logDir))
|
|
||||||
{
|
{
|
||||||
logFile = FileLogTarget.PrepareLogFile(logDir);
|
Logger.SetEnable(logClass, noFilter);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (logFile == null)
|
foreach (var logClass in e.NewValue)
|
||||||
|
{
|
||||||
|
Logger.SetEnable(logClass, true);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
ConfigurationState.Instance.Logger.EnableFileLog.Event += (_, e) =>
|
||||||
|
{
|
||||||
|
if (e.NewValue)
|
||||||
|
{
|
||||||
|
string logDir = AppDataManager.LogsDirPath;
|
||||||
|
FileStream logFile = null;
|
||||||
|
|
||||||
|
if (!string.IsNullOrEmpty(logDir))
|
||||||
|
{
|
||||||
|
logFile = FileLogTarget.PrepareLogFile(logDir);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (logFile == null)
|
||||||
|
{
|
||||||
|
Logger.Error?.Print(LogClass.Application,
|
||||||
|
"No writable log directory available. Make sure either the Logs directory, Application Data, or the Ryujinx directory is writable.");
|
||||||
|
Logger.RemoveTarget("file");
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.AddTarget(new AsyncLogTargetWrapper(
|
||||||
|
new FileLogTarget("file", logFile),
|
||||||
|
1000
|
||||||
|
));
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
Logger.Error?.Print(LogClass.Application, "No writable log directory available. Make sure either the Logs directory, Application Data, or the Ryujinx directory is writable.");
|
|
||||||
Logger.RemoveTarget("file");
|
Logger.RemoveTarget("file");
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
};
|
||||||
Logger.AddTarget(new AsyncLogTargetWrapper(
|
|
||||||
new FileLogTarget("file", logFile),
|
|
||||||
1000,
|
|
||||||
AsyncLogTargetOverflowAction.Block
|
|
||||||
));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Logger.RemoveTarget("file");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -15,9 +15,13 @@ namespace Ryujinx.UI.Common
|
|||||||
{
|
{
|
||||||
public static Timestamps StartedAt { get; set; }
|
public static Timestamps StartedAt { get; set; }
|
||||||
|
|
||||||
private static readonly string _description = ReleaseInformation.IsValid
|
private static string VersionString
|
||||||
? $"v{ReleaseInformation.Version} {ReleaseInformation.ReleaseChannelOwner}/{ReleaseInformation.ReleaseChannelRepo}@{ReleaseInformation.BuildGitHash}"
|
=> (ReleaseInformation.IsCanaryBuild ? "Canary " : string.Empty) + $"v{ReleaseInformation.Version}";
|
||||||
: "dev build";
|
|
||||||
|
private static readonly string _description =
|
||||||
|
ReleaseInformation.IsValid
|
||||||
|
? $"{VersionString} {ReleaseInformation.ReleaseChannelOwner}/{ReleaseInformation.ReleaseChannelSourceRepo}@{ReleaseInformation.BuildGitHash}"
|
||||||
|
: "dev build";
|
||||||
|
|
||||||
private const string ApplicationId = "1293250299716173864";
|
private const string ApplicationId = "1293250299716173864";
|
||||||
|
|
||||||
@ -163,6 +167,7 @@ namespace Ryujinx.UI.Common
|
|||||||
"010036b0034e4000", // Super Mario Party
|
"010036b0034e4000", // Super Mario Party
|
||||||
"01006fe013472000", // Mario Party Superstars
|
"01006fe013472000", // Mario Party Superstars
|
||||||
"0100965017338000", // Super Mario Party Jamboree
|
"0100965017338000", // Super Mario Party Jamboree
|
||||||
|
"01006d0017f7a000", // Mario & Luigi: Brothership
|
||||||
"010067300059a000", // Mario + Rabbids: Kingdom Battle
|
"010067300059a000", // Mario + Rabbids: Kingdom Battle
|
||||||
"0100317013770000", // Mario + Rabbids: Sparks of Hope
|
"0100317013770000", // Mario + Rabbids: Sparks of Hope
|
||||||
"0100a3900c3e2000", // Paper Mario: The Origami King
|
"0100a3900c3e2000", // Paper Mario: The Origami King
|
||||||
|
@ -4,6 +4,7 @@ using Ryujinx.Common.Logging;
|
|||||||
using System;
|
using System;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
using System.Runtime.InteropServices;
|
using System.Runtime.InteropServices;
|
||||||
using System.Runtime.Versioning;
|
using System.Runtime.Versioning;
|
||||||
|
|
||||||
@ -24,6 +25,26 @@ namespace Ryujinx.UI.Common.Helper
|
|||||||
|
|
||||||
public static bool IsTypeAssociationSupported => (OperatingSystem.IsLinux() || OperatingSystem.IsWindows()) && !ReleaseInformation.IsFlatHubBuild;
|
public static bool IsTypeAssociationSupported => (OperatingSystem.IsLinux() || OperatingSystem.IsWindows()) && !ReleaseInformation.IsFlatHubBuild;
|
||||||
|
|
||||||
|
public static bool AreMimeTypesRegistered
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (OperatingSystem.IsLinux())
|
||||||
|
{
|
||||||
|
return AreMimeTypesRegisteredLinux();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (OperatingSystem.IsWindows())
|
||||||
|
{
|
||||||
|
return AreMimeTypesRegisteredWindows();
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: Add macOS support.
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
[SupportedOSPlatform("linux")]
|
[SupportedOSPlatform("linux")]
|
||||||
private static bool AreMimeTypesRegisteredLinux() => File.Exists(Path.Combine(_mimeDbPath, "packages", "Ryujinx.xml"));
|
private static bool AreMimeTypesRegisteredLinux() => File.Exists(Path.Combine(_mimeDbPath, "packages", "Ryujinx.xml"));
|
||||||
|
|
||||||
@ -72,6 +93,10 @@ namespace Ryujinx.UI.Common.Helper
|
|||||||
[SupportedOSPlatform("windows")]
|
[SupportedOSPlatform("windows")]
|
||||||
private static bool AreMimeTypesRegisteredWindows()
|
private static bool AreMimeTypesRegisteredWindows()
|
||||||
{
|
{
|
||||||
|
return _fileExtensions.Aggregate(false,
|
||||||
|
(current, ext) => current | CheckRegistering(ext)
|
||||||
|
);
|
||||||
|
|
||||||
static bool CheckRegistering(string ext)
|
static bool CheckRegistering(string ext)
|
||||||
{
|
{
|
||||||
RegistryKey key = Registry.CurrentUser.OpenSubKey(@$"Software\Classes\{ext}");
|
RegistryKey key = Registry.CurrentUser.OpenSubKey(@$"Software\Classes\{ext}");
|
||||||
@ -87,20 +112,20 @@ namespace Ryujinx.UI.Common.Helper
|
|||||||
|
|
||||||
return keyValue is not null && (keyValue.Contains("Ryujinx") || keyValue.Contains(AppDomain.CurrentDomain.FriendlyName));
|
return keyValue is not null && (keyValue.Contains("Ryujinx") || keyValue.Contains(AppDomain.CurrentDomain.FriendlyName));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool registered = false;
|
|
||||||
|
|
||||||
foreach (string ext in _fileExtensions)
|
|
||||||
{
|
|
||||||
registered |= CheckRegistering(ext);
|
|
||||||
}
|
|
||||||
|
|
||||||
return registered;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[SupportedOSPlatform("windows")]
|
[SupportedOSPlatform("windows")]
|
||||||
private static bool InstallWindowsMimeTypes(bool uninstall = false)
|
private static bool InstallWindowsMimeTypes(bool uninstall = false)
|
||||||
{
|
{
|
||||||
|
bool registered = _fileExtensions.Aggregate(false,
|
||||||
|
(current, ext) => current | RegisterExtension(ext, uninstall)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Notify Explorer the file association has been changed.
|
||||||
|
SHChangeNotify(SHCNE_ASSOCCHANGED, SHCNF_FLUSH, nint.Zero, nint.Zero);
|
||||||
|
|
||||||
|
return registered;
|
||||||
|
|
||||||
static bool RegisterExtension(string ext, bool uninstall = false)
|
static bool RegisterExtension(string ext, bool uninstall = false)
|
||||||
{
|
{
|
||||||
string keyString = @$"Software\Classes\{ext}";
|
string keyString = @$"Software\Classes\{ext}";
|
||||||
@ -127,42 +152,13 @@ namespace Ryujinx.UI.Common.Helper
|
|||||||
|
|
||||||
Logger.Debug?.Print(LogClass.Application, $"Adding type association {ext}");
|
Logger.Debug?.Print(LogClass.Application, $"Adding type association {ext}");
|
||||||
using var openCmd = key.CreateSubKey(@"shell\open\command");
|
using var openCmd = key.CreateSubKey(@"shell\open\command");
|
||||||
openCmd.SetValue("", $"\"{Environment.ProcessPath}\" \"%1\"");
|
openCmd.SetValue(string.Empty, $"\"{Environment.ProcessPath}\" \"%1\"");
|
||||||
Logger.Debug?.Print(LogClass.Application, $"Added type association {ext}");
|
Logger.Debug?.Print(LogClass.Application, $"Added type association {ext}");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool registered = false;
|
|
||||||
|
|
||||||
foreach (string ext in _fileExtensions)
|
|
||||||
{
|
|
||||||
registered |= RegisterExtension(ext, uninstall);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Notify Explorer the file association has been changed.
|
|
||||||
SHChangeNotify(SHCNE_ASSOCCHANGED, SHCNF_FLUSH, nint.Zero, nint.Zero);
|
|
||||||
|
|
||||||
return registered;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static bool AreMimeTypesRegistered()
|
|
||||||
{
|
|
||||||
if (OperatingSystem.IsLinux())
|
|
||||||
{
|
|
||||||
return AreMimeTypesRegisteredLinux();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (OperatingSystem.IsWindows())
|
|
||||||
{
|
|
||||||
return AreMimeTypesRegisteredWindows();
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: Add macOS support.
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static bool Install()
|
public static bool Install()
|
||||||
|
@ -43,8 +43,8 @@ namespace Ryujinx.UI.Common.Models
|
|||||||
{
|
{
|
||||||
if (obj == null)
|
if (obj == null)
|
||||||
return false;
|
return false;
|
||||||
else
|
|
||||||
return this.Path == obj.Path;
|
return this.Path == obj.Path;
|
||||||
}
|
}
|
||||||
|
|
||||||
public override int GetHashCode()
|
public override int GetHashCode()
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "تعيين لون الخلفية",
|
"AvatarSetBackgroundColor": "تعيين لون الخلفية",
|
||||||
"AvatarClose": "إغلاق",
|
"AvatarClose": "إغلاق",
|
||||||
"ControllerSettingsLoadProfileToolTip": "تحميل الملف الشخصي",
|
"ControllerSettingsLoadProfileToolTip": "تحميل الملف الشخصي",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "إضافة ملف شخصي",
|
"ControllerSettingsAddProfileToolTip": "إضافة ملف شخصي",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "إزالة الملف الشخصي",
|
"ControllerSettingsRemoveProfileToolTip": "إزالة الملف الشخصي",
|
||||||
"ControllerSettingsSaveProfileToolTip": "حفظ الملف الشخصي",
|
"ControllerSettingsSaveProfileToolTip": "حفظ الملف الشخصي",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "حدث خطأ أثناء البحث عن بيانات الحفظ المحددة: {0}",
|
"DialogMessageFindSaveErrorMessage": "حدث خطأ أثناء البحث عن بيانات الحفظ المحددة: {0}",
|
||||||
"FolderDialogExtractTitle": "اختر المجلد الذي تريد الاستخراج إليه",
|
"FolderDialogExtractTitle": "اختر المجلد الذي تريد الاستخراج إليه",
|
||||||
"DialogNcaExtractionMessage": "استخراج قسم {0} من {1}...",
|
"DialogNcaExtractionMessage": "استخراج قسم {0} من {1}...",
|
||||||
"DialogNcaExtractionTitle": "ريوجينكس - مستخرج قسم NCA",
|
"DialogNcaExtractionTitle": "مستخرج قسم NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "فشل الاستخراج. لم يكن NCA الرئيسي موجودا في الملف المحدد.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "فشل الاستخراج. لم يكن NCA الرئيسي موجودا في الملف المحدد.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "فشل الاستخراج. اقرأ ملف التسجيل لمزيد من المعلومات.",
|
"DialogNcaExtractionCheckLogErrorMessage": "فشل الاستخراج. اقرأ ملف التسجيل لمزيد من المعلومات.",
|
||||||
"DialogNcaExtractionSuccessMessage": "تم الاستخراج بنجاح.",
|
"DialogNcaExtractionSuccessMessage": "تم الاستخراج بنجاح.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "Hintergrundfarbe auswählen",
|
"AvatarSetBackgroundColor": "Hintergrundfarbe auswählen",
|
||||||
"AvatarClose": "Schließen",
|
"AvatarClose": "Schließen",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Lädt ein Profil",
|
"ControllerSettingsLoadProfileToolTip": "Lädt ein Profil",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "Fügt ein Profil hinzu",
|
"ControllerSettingsAddProfileToolTip": "Fügt ein Profil hinzu",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Entfernt ein Profil",
|
"ControllerSettingsRemoveProfileToolTip": "Entfernt ein Profil",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Speichert ein Profil",
|
"ControllerSettingsSaveProfileToolTip": "Speichert ein Profil",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "Es ist ein Fehler beim Suchen der angegebenen Speicherdaten aufgetreten: {0}",
|
"DialogMessageFindSaveErrorMessage": "Es ist ein Fehler beim Suchen der angegebenen Speicherdaten aufgetreten: {0}",
|
||||||
"FolderDialogExtractTitle": "Wähle den Ordner, in welchen die Dateien entpackt werden sollen",
|
"FolderDialogExtractTitle": "Wähle den Ordner, in welchen die Dateien entpackt werden sollen",
|
||||||
"DialogNcaExtractionMessage": "Extrahiert {0} abschnitt von {1}...",
|
"DialogNcaExtractionMessage": "Extrahiert {0} abschnitt von {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - NCA-Abschnitt-Extraktor",
|
"DialogNcaExtractionTitle": "NCA-Abschnitt-Extraktor",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Extraktion fehlgeschlagen. Der Hauptheader der NCA war in der ausgewählten Datei nicht vorhanden.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Extraktion fehlgeschlagen. Der Hauptheader der NCA war in der ausgewählten Datei nicht vorhanden.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Extraktion fehlgeschlagen. Überprüfe die Logs für weitere Informationen.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Extraktion fehlgeschlagen. Überprüfe die Logs für weitere Informationen.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Extraktion erfolgreich abgeschlossen.",
|
"DialogNcaExtractionSuccessMessage": "Extraktion erfolgreich abgeschlossen.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "Ορισμός Χρώματος Φόντου",
|
"AvatarSetBackgroundColor": "Ορισμός Χρώματος Φόντου",
|
||||||
"AvatarClose": "Κλείσιμο",
|
"AvatarClose": "Κλείσιμο",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Φόρτωση Προφίλ",
|
"ControllerSettingsLoadProfileToolTip": "Φόρτωση Προφίλ",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "Προσθήκη Προφίλ",
|
"ControllerSettingsAddProfileToolTip": "Προσθήκη Προφίλ",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Κατάργηση Προφίλ",
|
"ControllerSettingsRemoveProfileToolTip": "Κατάργηση Προφίλ",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Αποθήκευση Προφίλ",
|
"ControllerSettingsSaveProfileToolTip": "Αποθήκευση Προφίλ",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "Σφάλμα κατά την εύρεση των αποθηκευμένων δεδομένων: {0}",
|
"DialogMessageFindSaveErrorMessage": "Σφάλμα κατά την εύρεση των αποθηκευμένων δεδομένων: {0}",
|
||||||
"FolderDialogExtractTitle": "Επιλέξτε τον φάκελο στον οποίο θέλετε να εξαγάγετε",
|
"FolderDialogExtractTitle": "Επιλέξτε τον φάκελο στον οποίο θέλετε να εξαγάγετε",
|
||||||
"DialogNcaExtractionMessage": "Εξαγωγή ενότητας {0} από {1}...",
|
"DialogNcaExtractionMessage": "Εξαγωγή ενότητας {0} από {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - NCA Εξαγωγέας Τμημάτων",
|
"DialogNcaExtractionTitle": "NCA Εξαγωγέας Τμημάτων",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Αποτυχία εξαγωγής. Η κύρια NCA δεν υπήρχε στο επιλεγμένο αρχείο.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Αποτυχία εξαγωγής. Η κύρια NCA δεν υπήρχε στο επιλεγμένο αρχείο.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Αποτυχία εξαγωγής. Διαβάστε το αρχείο καταγραφής για περισσότερες πληροφορίες.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Αποτυχία εξαγωγής. Διαβάστε το αρχείο καταγραφής για περισσότερες πληροφορίες.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Η εξαγωγή ολοκληρώθηκε με επιτυχία.",
|
"DialogNcaExtractionSuccessMessage": "Η εξαγωγή ολοκληρώθηκε με επιτυχία.",
|
||||||
|
@ -444,7 +444,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "There was an error finding the specified savedata: {0}",
|
"DialogMessageFindSaveErrorMessage": "There was an error finding the specified savedata: {0}",
|
||||||
"FolderDialogExtractTitle": "Choose the folder to extract into",
|
"FolderDialogExtractTitle": "Choose the folder to extract into",
|
||||||
"DialogNcaExtractionMessage": "Extracting {0} section from {1}...",
|
"DialogNcaExtractionMessage": "Extracting {0} section from {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - NCA Section Extractor",
|
"DialogNcaExtractionTitle": "NCA Section Extractor",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Extraction failure. The main NCA was not present in the selected file.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Extraction failure. The main NCA was not present in the selected file.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Extraction failed. Please check the log file for more details.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Extraction failed. Please check the log file for more details.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Extraction completed successfully.",
|
"DialogNcaExtractionSuccessMessage": "Extraction completed successfully.",
|
||||||
@ -461,7 +461,7 @@
|
|||||||
"DialogUpdaterRestartMessage": "Do you want to restart Ryujinx now?",
|
"DialogUpdaterRestartMessage": "Do you want to restart Ryujinx now?",
|
||||||
"DialogUpdaterNoInternetMessage": "You are not connected to the Internet!",
|
"DialogUpdaterNoInternetMessage": "You are not connected to the Internet!",
|
||||||
"DialogUpdaterNoInternetSubMessage": "Please verify that you have a working Internet connection!",
|
"DialogUpdaterNoInternetSubMessage": "Please verify that you have a working Internet connection!",
|
||||||
"DialogUpdaterDirtyBuildMessage": "You Cannot update a Dirty build of Ryujinx!",
|
"DialogUpdaterDirtyBuildMessage": "You cannot update a Dirty build of Ryujinx!",
|
||||||
"DialogUpdaterDirtyBuildSubMessage": "Please download Ryujinx at https://github.com/GreemDev/Ryujinx/releases/ if you are looking for a supported version.",
|
"DialogUpdaterDirtyBuildSubMessage": "Please download Ryujinx at https://github.com/GreemDev/Ryujinx/releases/ if you are looking for a supported version.",
|
||||||
"DialogRestartRequiredMessage": "Restart Required",
|
"DialogRestartRequiredMessage": "Restart Required",
|
||||||
"DialogThemeRestartMessage": "Theme has been saved. A restart is needed to apply the theme.",
|
"DialogThemeRestartMessage": "Theme has been saved. A restart is needed to apply the theme.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "Establecer color de fondo",
|
"AvatarSetBackgroundColor": "Establecer color de fondo",
|
||||||
"AvatarClose": "Cerrar",
|
"AvatarClose": "Cerrar",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Cargar perfil",
|
"ControllerSettingsLoadProfileToolTip": "Cargar perfil",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "Agregar perfil",
|
"ControllerSettingsAddProfileToolTip": "Agregar perfil",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Eliminar perfil",
|
"ControllerSettingsRemoveProfileToolTip": "Eliminar perfil",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Guardar perfil",
|
"ControllerSettingsSaveProfileToolTip": "Guardar perfil",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "Hubo un error encontrando los datos de guardado especificados: {0}",
|
"DialogMessageFindSaveErrorMessage": "Hubo un error encontrando los datos de guardado especificados: {0}",
|
||||||
"FolderDialogExtractTitle": "Elige la carpeta en la que deseas extraer",
|
"FolderDialogExtractTitle": "Elige la carpeta en la que deseas extraer",
|
||||||
"DialogNcaExtractionMessage": "Extrayendo {0} sección de {1}...",
|
"DialogNcaExtractionMessage": "Extrayendo {0} sección de {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - Extractor de sección NCA",
|
"DialogNcaExtractionTitle": "Extractor de sección NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Fallo de extracción. El NCA principal no estaba presente en el archivo seleccionado.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Fallo de extracción. El NCA principal no estaba presente en el archivo seleccionado.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Fallo de extracción. Lee el registro para más información.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Fallo de extracción. Lee el registro para más información.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Se completó la extracción con éxito.",
|
"DialogNcaExtractionSuccessMessage": "Se completó la extracción con éxito.",
|
||||||
|
@ -408,6 +408,7 @@
|
|||||||
"AvatarClose": "Fermer",
|
"AvatarClose": "Fermer",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Charger un profil",
|
"ControllerSettingsLoadProfileToolTip": "Charger un profil",
|
||||||
"ControllerSettingsAddProfileToolTip": "Ajouter un profil",
|
"ControllerSettingsAddProfileToolTip": "Ajouter un profil",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Supprimer un profil",
|
"ControllerSettingsRemoveProfileToolTip": "Supprimer un profil",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Enregistrer un profil",
|
"ControllerSettingsSaveProfileToolTip": "Enregistrer un profil",
|
||||||
"MenuBarFileToolsTakeScreenshot": "Prendre une capture d'écran",
|
"MenuBarFileToolsTakeScreenshot": "Prendre une capture d'écran",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "Une erreur s'est produite lors de la recherche de la sauvegarde spécifiée : {0}",
|
"DialogMessageFindSaveErrorMessage": "Une erreur s'est produite lors de la recherche de la sauvegarde spécifiée : {0}",
|
||||||
"FolderDialogExtractTitle": "Choisissez le dossier dans lequel extraire",
|
"FolderDialogExtractTitle": "Choisissez le dossier dans lequel extraire",
|
||||||
"DialogNcaExtractionMessage": "Extraction de la section {0} depuis {1}...",
|
"DialogNcaExtractionMessage": "Extraction de la section {0} depuis {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - Extracteur de la section NCA",
|
"DialogNcaExtractionTitle": "Extracteur de la section NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Échec de l'extraction. Le NCA principal n'était pas présent dans le fichier sélectionné.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Échec de l'extraction. Le NCA principal n'était pas présent dans le fichier sélectionné.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Échec de l'extraction. Lisez le fichier journal pour plus d'informations.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Échec de l'extraction. Lisez le fichier journal pour plus d'informations.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Extraction terminée avec succès.",
|
"DialogNcaExtractionSuccessMessage": "Extraction terminée avec succès.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "הגדר צבע רקע",
|
"AvatarSetBackgroundColor": "הגדר צבע רקע",
|
||||||
"AvatarClose": "סגור",
|
"AvatarClose": "סגור",
|
||||||
"ControllerSettingsLoadProfileToolTip": "טען פרופיל",
|
"ControllerSettingsLoadProfileToolTip": "טען פרופיל",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "הוסף פרופיל",
|
"ControllerSettingsAddProfileToolTip": "הוסף פרופיל",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "הסר פרופיל",
|
"ControllerSettingsRemoveProfileToolTip": "הסר פרופיל",
|
||||||
"ControllerSettingsSaveProfileToolTip": "שמור פרופיל",
|
"ControllerSettingsSaveProfileToolTip": "שמור פרופיל",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "אירעה שגיאה במציאת שמור המשחק שצויין: {0}",
|
"DialogMessageFindSaveErrorMessage": "אירעה שגיאה במציאת שמור המשחק שצויין: {0}",
|
||||||
"FolderDialogExtractTitle": "בחרו את התיקייה לחילוץ",
|
"FolderDialogExtractTitle": "בחרו את התיקייה לחילוץ",
|
||||||
"DialogNcaExtractionMessage": "מלחץ {0} ממקטע {1}...",
|
"DialogNcaExtractionMessage": "מלחץ {0} ממקטע {1}...",
|
||||||
"DialogNcaExtractionTitle": "ריוג'ינקס - מחלץ מקטע NCA",
|
"DialogNcaExtractionTitle": "מחלץ מקטע NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "כשל בחילוץ. ה-NCA הראשי לא היה קיים בקובץ שנבחר.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "כשל בחילוץ. ה-NCA הראשי לא היה קיים בקובץ שנבחר.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "כשל בחילוץ. קרא את קובץ הרישום למידע נוסף.",
|
"DialogNcaExtractionCheckLogErrorMessage": "כשל בחילוץ. קרא את קובץ הרישום למידע נוסף.",
|
||||||
"DialogNcaExtractionSuccessMessage": "החילוץ הושלם בהצלחה.",
|
"DialogNcaExtractionSuccessMessage": "החילוץ הושלם בהצלחה.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "Imposta colore di sfondo",
|
"AvatarSetBackgroundColor": "Imposta colore di sfondo",
|
||||||
"AvatarClose": "Chiudi",
|
"AvatarClose": "Chiudi",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Carica profilo",
|
"ControllerSettingsLoadProfileToolTip": "Carica profilo",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "Aggiungi profilo",
|
"ControllerSettingsAddProfileToolTip": "Aggiungi profilo",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Rimuovi profilo",
|
"ControllerSettingsRemoveProfileToolTip": "Rimuovi profilo",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Salva profilo",
|
"ControllerSettingsSaveProfileToolTip": "Salva profilo",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "C'è stato un errore durante la ricerca dei dati di salvataggio: {0}",
|
"DialogMessageFindSaveErrorMessage": "C'è stato un errore durante la ricerca dei dati di salvataggio: {0}",
|
||||||
"FolderDialogExtractTitle": "Scegli una cartella in cui estrarre",
|
"FolderDialogExtractTitle": "Scegli una cartella in cui estrarre",
|
||||||
"DialogNcaExtractionMessage": "Estrazione della sezione {0} da {1}...",
|
"DialogNcaExtractionMessage": "Estrazione della sezione {0} da {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - Estrazione sezione NCA",
|
"DialogNcaExtractionTitle": "Estrazione sezione NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "L'estrazione è fallita. L'NCA principale non era presente nel file selezionato.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "L'estrazione è fallita. L'NCA principale non era presente nel file selezionato.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "L'estrazione è fallita. Consulta il file di log per maggiori informazioni.",
|
"DialogNcaExtractionCheckLogErrorMessage": "L'estrazione è fallita. Consulta il file di log per maggiori informazioni.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Estrazione completata con successo.",
|
"DialogNcaExtractionSuccessMessage": "Estrazione completata con successo.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "背景色を指定",
|
"AvatarSetBackgroundColor": "背景色を指定",
|
||||||
"AvatarClose": "閉じる",
|
"AvatarClose": "閉じる",
|
||||||
"ControllerSettingsLoadProfileToolTip": "プロファイルをロード",
|
"ControllerSettingsLoadProfileToolTip": "プロファイルをロード",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "プロファイルを追加",
|
"ControllerSettingsAddProfileToolTip": "プロファイルを追加",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "プロファイルを削除",
|
"ControllerSettingsRemoveProfileToolTip": "プロファイルを削除",
|
||||||
"ControllerSettingsSaveProfileToolTip": "プロファイルをセーブ",
|
"ControllerSettingsSaveProfileToolTip": "プロファイルをセーブ",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "セーブデータ: {0} の検索中にエラーが発生しました",
|
"DialogMessageFindSaveErrorMessage": "セーブデータ: {0} の検索中にエラーが発生しました",
|
||||||
"FolderDialogExtractTitle": "展開フォルダを選択",
|
"FolderDialogExtractTitle": "展開フォルダを選択",
|
||||||
"DialogNcaExtractionMessage": "{1} から {0} セクションを展開中...",
|
"DialogNcaExtractionMessage": "{1} から {0} セクションを展開中...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - NCA セクション展開",
|
"DialogNcaExtractionTitle": "NCA セクション展開",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "展開に失敗しました. 選択されたファイルにはメイン NCA が存在しません.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "展開に失敗しました. 選択されたファイルにはメイン NCA が存在しません.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "展開に失敗しました. 詳細はログを確認してください.",
|
"DialogNcaExtractionCheckLogErrorMessage": "展開に失敗しました. 詳細はログを確認してください.",
|
||||||
"DialogNcaExtractionSuccessMessage": "展開が正常終了しました",
|
"DialogNcaExtractionSuccessMessage": "展開が正常終了しました",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "배경색 설정",
|
"AvatarSetBackgroundColor": "배경색 설정",
|
||||||
"AvatarClose": "닫기",
|
"AvatarClose": "닫기",
|
||||||
"ControllerSettingsLoadProfileToolTip": "프로필 불러오기",
|
"ControllerSettingsLoadProfileToolTip": "프로필 불러오기",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "프로필 추가",
|
"ControllerSettingsAddProfileToolTip": "프로필 추가",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "프로필 제거",
|
"ControllerSettingsRemoveProfileToolTip": "프로필 제거",
|
||||||
"ControllerSettingsSaveProfileToolTip": "프로필 저장",
|
"ControllerSettingsSaveProfileToolTip": "프로필 저장",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "지정된 저장 데이터를 찾는 중에 오류 발생: {0}",
|
"DialogMessageFindSaveErrorMessage": "지정된 저장 데이터를 찾는 중에 오류 발생: {0}",
|
||||||
"FolderDialogExtractTitle": "추출할 폴더 선택",
|
"FolderDialogExtractTitle": "추출할 폴더 선택",
|
||||||
"DialogNcaExtractionMessage": "{1}에서 {0} 섹션을 추출하는 중...",
|
"DialogNcaExtractionMessage": "{1}에서 {0} 섹션을 추출하는 중...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - NCA 섹션 추출기",
|
"DialogNcaExtractionTitle": "NCA 섹션 추출기",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "추출 실패하였습니다. 선택한 파일에 기본 NCA가 없습니다.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "추출 실패하였습니다. 선택한 파일에 기본 NCA가 없습니다.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "추출 실패하였습니다. 자세한 내용은 로그 파일을 읽으세요.",
|
"DialogNcaExtractionCheckLogErrorMessage": "추출 실패하였습니다. 자세한 내용은 로그 파일을 읽으세요.",
|
||||||
"DialogNcaExtractionSuccessMessage": "추출이 성공적으로 완료되었습니다.",
|
"DialogNcaExtractionSuccessMessage": "추출이 성공적으로 완료되었습니다.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "Ustaw kolor tła",
|
"AvatarSetBackgroundColor": "Ustaw kolor tła",
|
||||||
"AvatarClose": "Zamknij",
|
"AvatarClose": "Zamknij",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Wczytaj profil",
|
"ControllerSettingsLoadProfileToolTip": "Wczytaj profil",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "Dodaj profil",
|
"ControllerSettingsAddProfileToolTip": "Dodaj profil",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Usuń profil",
|
"ControllerSettingsRemoveProfileToolTip": "Usuń profil",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Zapisz profil",
|
"ControllerSettingsSaveProfileToolTip": "Zapisz profil",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "Wystąpił błąd podczas próby znalezienia określonych zapisanych danych: {0}",
|
"DialogMessageFindSaveErrorMessage": "Wystąpił błąd podczas próby znalezienia określonych zapisanych danych: {0}",
|
||||||
"FolderDialogExtractTitle": "Wybierz folder, do którego chcesz rozpakować",
|
"FolderDialogExtractTitle": "Wybierz folder, do którego chcesz rozpakować",
|
||||||
"DialogNcaExtractionMessage": "Wypakowywanie sekcji {0} z {1}...",
|
"DialogNcaExtractionMessage": "Wypakowywanie sekcji {0} z {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - Asystent wypakowania sekcji NCA",
|
"DialogNcaExtractionTitle": "Asystent wypakowania sekcji NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Niepowodzenie podczas wypakowywania. W wybranym pliku nie było głównego NCA.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Niepowodzenie podczas wypakowywania. W wybranym pliku nie było głównego NCA.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Niepowodzenie podczas wypakowywania. Przeczytaj plik dziennika, aby uzyskać więcej informacji.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Niepowodzenie podczas wypakowywania. Przeczytaj plik dziennika, aby uzyskać więcej informacji.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Wypakowywanie zakończone pomyślnie.",
|
"DialogNcaExtractionSuccessMessage": "Wypakowywanie zakończone pomyślnie.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "Definir cor de fundo",
|
"AvatarSetBackgroundColor": "Definir cor de fundo",
|
||||||
"AvatarClose": "Fechar",
|
"AvatarClose": "Fechar",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Carregar perfil",
|
"ControllerSettingsLoadProfileToolTip": "Carregar perfil",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "Adicionar perfil",
|
"ControllerSettingsAddProfileToolTip": "Adicionar perfil",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Remover perfil",
|
"ControllerSettingsRemoveProfileToolTip": "Remover perfil",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Salvar perfil",
|
"ControllerSettingsSaveProfileToolTip": "Salvar perfil",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "Ocorreu um erro ao tentar encontrar o diretório de salvamento: {0}",
|
"DialogMessageFindSaveErrorMessage": "Ocorreu um erro ao tentar encontrar o diretório de salvamento: {0}",
|
||||||
"FolderDialogExtractTitle": "Escolha o diretório onde os arquivos serão extraídos",
|
"FolderDialogExtractTitle": "Escolha o diretório onde os arquivos serão extraídos",
|
||||||
"DialogNcaExtractionMessage": "Extraindo seção {0} de {1}...",
|
"DialogNcaExtractionMessage": "Extraindo seção {0} de {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - Extrator de seções NCA",
|
"DialogNcaExtractionTitle": "Extrator de seções NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Falha na extração. O NCA principal não foi encontrado no arquivo selecionado.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Falha na extração. O NCA principal não foi encontrado no arquivo selecionado.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Falha na extração. Leia o arquivo de log para mais informações.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Falha na extração. Leia o arquivo de log para mais informações.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Extração concluída com êxito.",
|
"DialogNcaExtractionSuccessMessage": "Extração concluída com êxito.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "Установить цвет фона",
|
"AvatarSetBackgroundColor": "Установить цвет фона",
|
||||||
"AvatarClose": "Закрыть",
|
"AvatarClose": "Закрыть",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Загрузить профиль",
|
"ControllerSettingsLoadProfileToolTip": "Загрузить профиль",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "Добавить профиль",
|
"ControllerSettingsAddProfileToolTip": "Добавить профиль",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Удалить профиль",
|
"ControllerSettingsRemoveProfileToolTip": "Удалить профиль",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Сохранить профиль",
|
"ControllerSettingsSaveProfileToolTip": "Сохранить профиль",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "Произошла ошибка при поиске указанных данных сохранения: {0}",
|
"DialogMessageFindSaveErrorMessage": "Произошла ошибка при поиске указанных данных сохранения: {0}",
|
||||||
"FolderDialogExtractTitle": "Выберите папку для извлечения",
|
"FolderDialogExtractTitle": "Выберите папку для извлечения",
|
||||||
"DialogNcaExtractionMessage": "Извлечение {0} раздела из {1}...",
|
"DialogNcaExtractionMessage": "Извлечение {0} раздела из {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - Извлечение разделов NCA",
|
"DialogNcaExtractionTitle": "Извлечение разделов NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Ошибка извлечения. Основной NCA не присутствовал в выбранном файле.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Ошибка извлечения. Основной NCA не присутствовал в выбранном файле.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Ошибка извлечения. Прочтите файл журнала для получения дополнительной информации.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Ошибка извлечения. Прочтите файл журнала для получения дополнительной информации.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Извлечение завершено успешно.",
|
"DialogNcaExtractionSuccessMessage": "Извлечение завершено успешно.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "ตั้งค่าสีพื้นหลัง",
|
"AvatarSetBackgroundColor": "ตั้งค่าสีพื้นหลัง",
|
||||||
"AvatarClose": "ปิด",
|
"AvatarClose": "ปิด",
|
||||||
"ControllerSettingsLoadProfileToolTip": "โหลด โปรไฟล์",
|
"ControllerSettingsLoadProfileToolTip": "โหลด โปรไฟล์",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "เพิ่ม โปรไฟล์",
|
"ControllerSettingsAddProfileToolTip": "เพิ่ม โปรไฟล์",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "ลบ โปรไฟล์",
|
"ControllerSettingsRemoveProfileToolTip": "ลบ โปรไฟล์",
|
||||||
"ControllerSettingsSaveProfileToolTip": "บันทึก โปรไฟล์",
|
"ControllerSettingsSaveProfileToolTip": "บันทึก โปรไฟล์",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "มีข้อผิดพลาดในการค้นหาข้อมูลบันทึกที่ระบุไว้: {0}",
|
"DialogMessageFindSaveErrorMessage": "มีข้อผิดพลาดในการค้นหาข้อมูลบันทึกที่ระบุไว้: {0}",
|
||||||
"FolderDialogExtractTitle": "เลือกโฟลเดอร์ที่จะแตกไฟล์เข้าไป",
|
"FolderDialogExtractTitle": "เลือกโฟลเดอร์ที่จะแตกไฟล์เข้าไป",
|
||||||
"DialogNcaExtractionMessage": "กำลังแตกไฟล์ {0} จากส่วน {1}...",
|
"DialogNcaExtractionMessage": "กำลังแตกไฟล์ {0} จากส่วน {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - เครื่องมือแตกไฟล์ของ NCA",
|
"DialogNcaExtractionTitle": "เครื่องมือแตกไฟล์ของ NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "เกิดความล้มเหลวในการแตกไฟล์เนื่องจากไม่พบ NCA หลักในไฟล์ที่เลือก",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "เกิดความล้มเหลวในการแตกไฟล์เนื่องจากไม่พบ NCA หลักในไฟล์ที่เลือก",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "เกิดความล้มเหลวในการแตกไฟล์ โปรดอ่านไฟล์บันทึกประวัติเพื่อดูข้อมูลเพิ่มเติม",
|
"DialogNcaExtractionCheckLogErrorMessage": "เกิดความล้มเหลวในการแตกไฟล์ โปรดอ่านไฟล์บันทึกประวัติเพื่อดูข้อมูลเพิ่มเติม",
|
||||||
"DialogNcaExtractionSuccessMessage": "การแตกไฟล์เสร็จสมบูรณ์แล้ว",
|
"DialogNcaExtractionSuccessMessage": "การแตกไฟล์เสร็จสมบูรณ์แล้ว",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "Arka Plan Rengi Ayarla",
|
"AvatarSetBackgroundColor": "Arka Plan Rengi Ayarla",
|
||||||
"AvatarClose": "Kapat",
|
"AvatarClose": "Kapat",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Profil Yükle",
|
"ControllerSettingsLoadProfileToolTip": "Profil Yükle",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "Profil Ekle",
|
"ControllerSettingsAddProfileToolTip": "Profil Ekle",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Profili Kaldır",
|
"ControllerSettingsRemoveProfileToolTip": "Profili Kaldır",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Profili Kaydet",
|
"ControllerSettingsSaveProfileToolTip": "Profili Kaydet",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "Belirtilen kayıt verisi bulunmaya çalışırken hata: {0}",
|
"DialogMessageFindSaveErrorMessage": "Belirtilen kayıt verisi bulunmaya çalışırken hata: {0}",
|
||||||
"FolderDialogExtractTitle": "İçine ayıklanacak klasörü seç",
|
"FolderDialogExtractTitle": "İçine ayıklanacak klasörü seç",
|
||||||
"DialogNcaExtractionMessage": "{1} den {0} kısmı ayıklanıyor...",
|
"DialogNcaExtractionMessage": "{1} den {0} kısmı ayıklanıyor...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - NCA Kısmı Ayıklayıcısı",
|
"DialogNcaExtractionTitle": "NCA Kısmı Ayıklayıcısı",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Ayıklama hatası. Ana NCA seçilen dosyada bulunamadı.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Ayıklama hatası. Ana NCA seçilen dosyada bulunamadı.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Ayıklama hatası. Ek bilgi için kayıt dosyasını okuyun.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Ayıklama hatası. Ek bilgi için kayıt dosyasını okuyun.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Ayıklama başarıyla tamamlandı.",
|
"DialogNcaExtractionSuccessMessage": "Ayıklama başarıyla tamamlandı.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "Встановити колір фону",
|
"AvatarSetBackgroundColor": "Встановити колір фону",
|
||||||
"AvatarClose": "Закрити",
|
"AvatarClose": "Закрити",
|
||||||
"ControllerSettingsLoadProfileToolTip": "Завантажити профіль",
|
"ControllerSettingsLoadProfileToolTip": "Завантажити профіль",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "Додати профіль",
|
"ControllerSettingsAddProfileToolTip": "Додати профіль",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "Видалити профіль",
|
"ControllerSettingsRemoveProfileToolTip": "Видалити профіль",
|
||||||
"ControllerSettingsSaveProfileToolTip": "Зберегти профіль",
|
"ControllerSettingsSaveProfileToolTip": "Зберегти профіль",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "Під час пошуку вказаних даних збереження сталася помилка: {0}",
|
"DialogMessageFindSaveErrorMessage": "Під час пошуку вказаних даних збереження сталася помилка: {0}",
|
||||||
"FolderDialogExtractTitle": "Виберіть папку для видобування",
|
"FolderDialogExtractTitle": "Виберіть папку для видобування",
|
||||||
"DialogNcaExtractionMessage": "Видобування розділу {0} з {1}...",
|
"DialogNcaExtractionMessage": "Видобування розділу {0} з {1}...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - Екстрактор розділів NCA",
|
"DialogNcaExtractionTitle": "Екстрактор розділів NCA",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Помилка видобування. Основний NCA не був присутній у вибраному файлі.",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "Помилка видобування. Основний NCA не був присутній у вибраному файлі.",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "Помилка видобування. Прочитайте файл журналу для отримання додаткової інформації.",
|
"DialogNcaExtractionCheckLogErrorMessage": "Помилка видобування. Прочитайте файл журналу для отримання додаткової інформації.",
|
||||||
"DialogNcaExtractionSuccessMessage": "Видобування успішно завершено.",
|
"DialogNcaExtractionSuccessMessage": "Видобування успішно завершено.",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "设置背景色",
|
"AvatarSetBackgroundColor": "设置背景色",
|
||||||
"AvatarClose": "关闭",
|
"AvatarClose": "关闭",
|
||||||
"ControllerSettingsLoadProfileToolTip": "加载配置文件",
|
"ControllerSettingsLoadProfileToolTip": "加载配置文件",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "新增配置文件",
|
"ControllerSettingsAddProfileToolTip": "新增配置文件",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "删除配置文件",
|
"ControllerSettingsRemoveProfileToolTip": "删除配置文件",
|
||||||
"ControllerSettingsSaveProfileToolTip": "保存配置文件",
|
"ControllerSettingsSaveProfileToolTip": "保存配置文件",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "查找指定存档时出错:{0}",
|
"DialogMessageFindSaveErrorMessage": "查找指定存档时出错:{0}",
|
||||||
"FolderDialogExtractTitle": "选择要提取到的文件夹",
|
"FolderDialogExtractTitle": "选择要提取到的文件夹",
|
||||||
"DialogNcaExtractionMessage": "提取 {1} 的 {0} 分区...",
|
"DialogNcaExtractionMessage": "提取 {1} 的 {0} 分区...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - NCA 分区提取",
|
"DialogNcaExtractionTitle": "NCA 分区提取",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "提取失败,所选文件中没有 NCA 文件",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "提取失败,所选文件中没有 NCA 文件",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "提取失败,请查看日志文件获取详情",
|
"DialogNcaExtractionCheckLogErrorMessage": "提取失败,请查看日志文件获取详情",
|
||||||
"DialogNcaExtractionSuccessMessage": "提取成功!",
|
"DialogNcaExtractionSuccessMessage": "提取成功!",
|
||||||
|
@ -407,6 +407,7 @@
|
|||||||
"AvatarSetBackgroundColor": "設定背景顏色",
|
"AvatarSetBackgroundColor": "設定背景顏色",
|
||||||
"AvatarClose": "關閉",
|
"AvatarClose": "關閉",
|
||||||
"ControllerSettingsLoadProfileToolTip": "載入設定檔",
|
"ControllerSettingsLoadProfileToolTip": "載入設定檔",
|
||||||
|
"ControllerSettingsViewProfileToolTip": "View Profile",
|
||||||
"ControllerSettingsAddProfileToolTip": "新增設定檔",
|
"ControllerSettingsAddProfileToolTip": "新增設定檔",
|
||||||
"ControllerSettingsRemoveProfileToolTip": "刪除設定檔",
|
"ControllerSettingsRemoveProfileToolTip": "刪除設定檔",
|
||||||
"ControllerSettingsSaveProfileToolTip": "儲存設定檔",
|
"ControllerSettingsSaveProfileToolTip": "儲存設定檔",
|
||||||
@ -437,7 +438,7 @@
|
|||||||
"DialogMessageFindSaveErrorMessage": "尋找指定的存檔時出現錯誤: {0}",
|
"DialogMessageFindSaveErrorMessage": "尋找指定的存檔時出現錯誤: {0}",
|
||||||
"FolderDialogExtractTitle": "選擇要解壓到的資料夾",
|
"FolderDialogExtractTitle": "選擇要解壓到的資料夾",
|
||||||
"DialogNcaExtractionMessage": "從 {1} 提取 {0} 分區...",
|
"DialogNcaExtractionMessage": "從 {1} 提取 {0} 分區...",
|
||||||
"DialogNcaExtractionTitle": "Ryujinx - NCA 分區提取器",
|
"DialogNcaExtractionTitle": "NCA 分區提取器",
|
||||||
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "提取失敗。所選檔案中不存在主 NCA 檔案。",
|
"DialogNcaExtractionMainNcaNotFoundErrorMessage": "提取失敗。所選檔案中不存在主 NCA 檔案。",
|
||||||
"DialogNcaExtractionCheckLogErrorMessage": "提取失敗。請閱讀日誌檔案了解更多資訊。",
|
"DialogNcaExtractionCheckLogErrorMessage": "提取失敗。請閱讀日誌檔案了解更多資訊。",
|
||||||
"DialogNcaExtractionSuccessMessage": "提取成功。",
|
"DialogNcaExtractionSuccessMessage": "提取成功。",
|
||||||
|
@ -146,7 +146,7 @@ namespace Ryujinx.Ava.Common
|
|||||||
var cancellationToken = new CancellationTokenSource();
|
var cancellationToken = new CancellationTokenSource();
|
||||||
|
|
||||||
UpdateWaitWindow waitingDialog = new(
|
UpdateWaitWindow waitingDialog = new(
|
||||||
LocaleManager.Instance[LocaleKeys.DialogNcaExtractionTitle],
|
App.FormatTitle(LocaleKeys.DialogNcaExtractionTitle),
|
||||||
LocaleManager.Instance.UpdateAndGetDynamicValue(LocaleKeys.DialogNcaExtractionMessage, ncaSectionType, Path.GetFileName(titleFilePath)),
|
LocaleManager.Instance.UpdateAndGetDynamicValue(LocaleKeys.DialogNcaExtractionMessage, ncaSectionType, Path.GetFileName(titleFilePath)),
|
||||||
cancellationToken);
|
cancellationToken);
|
||||||
|
|
||||||
@ -269,7 +269,7 @@ namespace Ryujinx.Ava.Common
|
|||||||
Dispatcher.UIThread.Post(waitingDialog.Close);
|
Dispatcher.UIThread.Post(waitingDialog.Close);
|
||||||
|
|
||||||
NotificationHelper.Show(
|
NotificationHelper.Show(
|
||||||
LocaleManager.Instance[LocaleKeys.DialogNcaExtractionTitle],
|
App.FormatTitle(LocaleKeys.DialogNcaExtractionTitle),
|
||||||
$"{titleName}\n\n{LocaleManager.Instance[LocaleKeys.DialogNcaExtractionSuccessMessage]}",
|
$"{titleName}\n\n{LocaleManager.Instance[LocaleKeys.DialogNcaExtractionSuccessMessage]}",
|
||||||
NotificationType.Information);
|
NotificationType.Information);
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,6 @@ namespace Ryujinx.Ava
|
|||||||
{
|
{
|
||||||
internal partial class Program
|
internal partial class Program
|
||||||
{
|
{
|
||||||
//
|
|
||||||
public static double WindowScaleFactor { get; set; }
|
public static double WindowScaleFactor { get; set; }
|
||||||
public static double DesktopScaleFactor { get; set; } = 1.0;
|
public static double DesktopScaleFactor { get; set; } = 1.0;
|
||||||
public static string Version { get; private set; }
|
public static string Version { get; private set; }
|
||||||
@ -101,7 +100,7 @@ namespace Ryujinx.Ava
|
|||||||
// Delete backup files after updating.
|
// Delete backup files after updating.
|
||||||
Task.Run(Updater.CleanupUpdate);
|
Task.Run(Updater.CleanupUpdate);
|
||||||
|
|
||||||
Console.Title = $"Ryujinx Console {Version}";
|
Console.Title = $"{App.FullAppName} Console {Version}";
|
||||||
|
|
||||||
// Hook unhandled exception and process exit events.
|
// Hook unhandled exception and process exit events.
|
||||||
AppDomain.CurrentDomain.UnhandledException += (sender, e)
|
AppDomain.CurrentDomain.UnhandledException += (sender, e)
|
||||||
|
@ -226,11 +226,11 @@ namespace Ryujinx.Ava.UI.Helpers
|
|||||||
(int)Symbol.Help,
|
(int)Symbol.Help,
|
||||||
primaryButtonResult);
|
primaryButtonResult);
|
||||||
|
|
||||||
internal static async Task<UserResult> CreateConfirmationDialogExtended(
|
internal static async Task<UserResult> CreateDeniableConfirmationDialog(
|
||||||
string primaryText,
|
string primaryText,
|
||||||
string secondaryText,
|
string secondaryText,
|
||||||
string acceptButtonText,
|
string acceptButtonText,
|
||||||
string noacceptButtonText,
|
string noAcceptButtonText,
|
||||||
string cancelButtonText,
|
string cancelButtonText,
|
||||||
string title,
|
string title,
|
||||||
UserResult primaryButtonResult = UserResult.Yes)
|
UserResult primaryButtonResult = UserResult.Yes)
|
||||||
@ -239,7 +239,7 @@ namespace Ryujinx.Ava.UI.Helpers
|
|||||||
primaryText,
|
primaryText,
|
||||||
secondaryText,
|
secondaryText,
|
||||||
acceptButtonText,
|
acceptButtonText,
|
||||||
noacceptButtonText,
|
noAcceptButtonText,
|
||||||
cancelButtonText,
|
cancelButtonText,
|
||||||
(int)Symbol.Help,
|
(int)Symbol.Help,
|
||||||
primaryButtonResult);
|
primaryButtonResult);
|
||||||
|
@ -805,6 +805,11 @@ namespace Ryujinx.Ava.UI.ViewModels
|
|||||||
get => FileAssociationHelper.IsTypeAssociationSupported;
|
get => FileAssociationHelper.IsTypeAssociationSupported;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public bool AreMimeTypesRegistered
|
||||||
|
{
|
||||||
|
get => FileAssociationHelper.AreMimeTypesRegistered;
|
||||||
|
}
|
||||||
|
|
||||||
public ObservableCollectionExtended<ApplicationData> Applications
|
public ObservableCollectionExtended<ApplicationData> Applications
|
||||||
{
|
{
|
||||||
get => _applications;
|
get => _applications;
|
||||||
|
@ -26,19 +26,17 @@ namespace Ryujinx.Ava.UI.Views.Input
|
|||||||
|
|
||||||
foreach (ILogical visual in SettingButtons.GetLogicalDescendants())
|
foreach (ILogical visual in SettingButtons.GetLogicalDescendants())
|
||||||
{
|
{
|
||||||
if (visual is ToggleButton button and not CheckBox)
|
switch (visual)
|
||||||
{
|
{
|
||||||
button.IsCheckedChanged += Button_IsCheckedChanged;
|
case ToggleButton button and not CheckBox:
|
||||||
}
|
button.IsCheckedChanged += Button_IsCheckedChanged;
|
||||||
|
break;
|
||||||
if (visual is CheckBox check)
|
case CheckBox check:
|
||||||
{
|
check.IsCheckedChanged += CheckBox_IsCheckedChanged;
|
||||||
check.IsCheckedChanged += CheckBox_IsCheckedChanged;
|
break;
|
||||||
}
|
case Slider slider:
|
||||||
|
slider.PropertyChanged += Slider_ValueChanged;
|
||||||
if (visual is Slider slider)
|
break;
|
||||||
{
|
|
||||||
slider.PropertyChanged += Slider_IsCheckedChanged;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -47,33 +45,28 @@ namespace Ryujinx.Ava.UI.Views.Input
|
|||||||
{
|
{
|
||||||
base.OnPointerReleased(e);
|
base.OnPointerReleased(e);
|
||||||
|
|
||||||
if (_currentAssigner != null && _currentAssigner.ToggledButton != null && !_currentAssigner.ToggledButton.IsPointerOver)
|
if (_currentAssigner is { ToggledButton.IsPointerOver: false })
|
||||||
{
|
{
|
||||||
_currentAssigner.Cancel();
|
_currentAssigner.Cancel();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private float _changeSlider = -1.0f;
|
private float _changeSlider = float.NaN;
|
||||||
|
|
||||||
private void Slider_IsCheckedChanged(object sender, AvaloniaPropertyChangedEventArgs e)
|
private void Slider_ValueChanged(object sender, AvaloniaPropertyChangedEventArgs e)
|
||||||
{
|
{
|
||||||
if (sender is Slider check)
|
if (sender is Slider check)
|
||||||
{
|
{
|
||||||
if ((bool)check.IsPointerOver && _changeSlider == -1.0f)
|
_changeSlider = check.IsPointerOver switch
|
||||||
{
|
{
|
||||||
_changeSlider = (float)check.Value;
|
true when float.IsNaN(_changeSlider) => (float)check.Value,
|
||||||
|
false => float.NaN,
|
||||||
|
_ => _changeSlider
|
||||||
|
};
|
||||||
|
|
||||||
}
|
if (!float.IsNaN(_changeSlider) && _changeSlider != (float)check.Value)
|
||||||
else if (!(bool)check.IsPointerOver)
|
|
||||||
{
|
{
|
||||||
_changeSlider = -1.0f;
|
(DataContext as ControllerInputViewModel)!.ParentModel.IsModified = true;
|
||||||
}
|
|
||||||
|
|
||||||
if (_changeSlider != -1.0f && _changeSlider != (float)check.Value)
|
|
||||||
{
|
|
||||||
|
|
||||||
var viewModel = (DataContext as ControllerInputViewModel);
|
|
||||||
viewModel.ParentModel.IsModified = true;
|
|
||||||
_changeSlider = (float)check.Value;
|
_changeSlider = (float)check.Value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -81,25 +74,20 @@ namespace Ryujinx.Ava.UI.Views.Input
|
|||||||
|
|
||||||
private void CheckBox_IsCheckedChanged(object sender, RoutedEventArgs e)
|
private void CheckBox_IsCheckedChanged(object sender, RoutedEventArgs e)
|
||||||
{
|
{
|
||||||
if (sender is CheckBox check)
|
if (sender is CheckBox { IsPointerOver: true })
|
||||||
{
|
{
|
||||||
if ((bool)check.IsPointerOver)
|
(DataContext as ControllerInputViewModel)!.ParentModel.IsModified = true;
|
||||||
{
|
_currentAssigner?.Cancel();
|
||||||
|
_currentAssigner = null;
|
||||||
var viewModel = (DataContext as ControllerInputViewModel);
|
|
||||||
viewModel.ParentModel.IsModified = true;
|
|
||||||
_currentAssigner?.Cancel();
|
|
||||||
_currentAssigner = null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void Button_IsCheckedChanged(object sender, RoutedEventArgs e)
|
private void Button_IsCheckedChanged(object sender, RoutedEventArgs e)
|
||||||
{
|
{
|
||||||
if (sender is ToggleButton button )
|
if (sender is ToggleButton button)
|
||||||
{
|
{
|
||||||
if ((bool)button.IsChecked)
|
if (button.IsChecked is true)
|
||||||
{
|
{
|
||||||
if (_currentAssigner != null && button == _currentAssigner.ToggledButton)
|
if (_currentAssigner != null && button == _currentAssigner.ToggledButton)
|
||||||
{
|
{
|
||||||
@ -204,7 +192,7 @@ namespace Ryujinx.Ava.UI.Views.Input
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (_currentAssigner != null )
|
if (_currentAssigner != null)
|
||||||
{
|
{
|
||||||
_currentAssigner.Cancel();
|
_currentAssigner.Cancel();
|
||||||
_currentAssigner = null;
|
_currentAssigner = null;
|
||||||
|
@ -37,7 +37,7 @@ namespace Ryujinx.Ava.UI.Views.Input
|
|||||||
{
|
{
|
||||||
_dialogOpen = true;
|
_dialogOpen = true;
|
||||||
|
|
||||||
var result = await ContentDialogHelper.CreateConfirmationDialogExtended(
|
var result = await ContentDialogHelper.CreateDeniableConfirmationDialog(
|
||||||
LocaleManager.Instance[LocaleKeys.DialogControllerSettingsModifiedConfirmMessage],
|
LocaleManager.Instance[LocaleKeys.DialogControllerSettingsModifiedConfirmMessage],
|
||||||
LocaleManager.Instance[LocaleKeys.DialogControllerSettingsModifiedConfirmSubMessage],
|
LocaleManager.Instance[LocaleKeys.DialogControllerSettingsModifiedConfirmSubMessage],
|
||||||
LocaleManager.Instance[LocaleKeys.InputDialogYes],
|
LocaleManager.Instance[LocaleKeys.InputDialogYes],
|
||||||
@ -53,28 +53,19 @@ namespace Ryujinx.Ava.UI.Views.Input
|
|||||||
|
|
||||||
_dialogOpen = false;
|
_dialogOpen = false;
|
||||||
|
|
||||||
if (result == UserResult.Cancel)
|
|
||||||
{
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
ViewModel.IsModified = false;
|
|
||||||
|
|
||||||
if (result != UserResult.Cancel)
|
|
||||||
{
|
|
||||||
ViewModel.PlayerId = ViewModel.PlayerIdChoose;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (result == UserResult.Cancel)
|
if (result == UserResult.Cancel)
|
||||||
{
|
{
|
||||||
if (e.AddedItems.Count > 0)
|
if (e.AddedItems.Count > 0)
|
||||||
{
|
{
|
||||||
ViewModel.IsModified = true;
|
ViewModel.IsModified = true;
|
||||||
var player = (PlayerModel)e.AddedItems[0];
|
ViewModel.PlayerId = ((PlayerModel)e.AddedItems[0])!.Id;
|
||||||
ViewModel.PlayerId = player.Id;
|
|
||||||
}
|
}
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ViewModel.PlayerId = ViewModel.PlayerIdChoose;
|
||||||
|
|
||||||
|
ViewModel.IsModified = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -265,11 +265,11 @@
|
|||||||
<MenuItem Command="{Binding InstallFirmwareFromFolder}" Header="{ext:Locale MenuBarFileToolsInstallFirmwareFromDirectory}" Icon="{ext:Icon mdi-folder-cog}" />
|
<MenuItem Command="{Binding InstallFirmwareFromFolder}" Header="{ext:Locale MenuBarFileToolsInstallFirmwareFromDirectory}" Icon="{ext:Icon mdi-folder-cog}" />
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem Header="{ext:Locale MenuBarToolsManageFileTypes}" IsVisible="{Binding ManageFileTypesVisible}">
|
<MenuItem Header="{ext:Locale MenuBarToolsManageFileTypes}" IsVisible="{Binding ManageFileTypesVisible}">
|
||||||
<MenuItem Header="{ext:Locale MenuBarToolsInstallFileTypes}" Click="InstallFileTypes_Click"/>
|
<MenuItem Header="{ext:Locale MenuBarToolsInstallFileTypes}" Click="InstallFileTypes_Click" IsEnabled="{Binding AreMimeTypesRegistered, Converter={x:Static BoolConverters.Not}}" />
|
||||||
<MenuItem Header="{ext:Locale MenuBarToolsUninstallFileTypes}" Click="UninstallFileTypes_Click"/>
|
<MenuItem Header="{ext:Locale MenuBarToolsUninstallFileTypes}" Click="UninstallFileTypes_Click" IsEnabled="{Binding AreMimeTypesRegistered}" />
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
<Separator />
|
<Separator />
|
||||||
<MenuItem Header="{ext:Locale MenuBarToolsXCITrimmer}" Click="OpenXCITrimmerWindow" Icon="{ext:Icon fa-solid fa-scissors}" />
|
<MenuItem Header="{ext:Locale MenuBarToolsXCITrimmer}" IsEnabled="{Binding EnableNonGameRunningControls}" Click="OpenXCITrimmerWindow" Icon="{ext:Icon fa-solid fa-scissors}" />
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
<MenuItem VerticalAlignment="Center" Header="{ext:Locale MenuBarView}">
|
<MenuItem VerticalAlignment="Center" Header="{ext:Locale MenuBarView}">
|
||||||
<MenuItem VerticalAlignment="Center" Header="{ext:Locale MenuBarViewWindow}">
|
<MenuItem VerticalAlignment="Center" Header="{ext:Locale MenuBarViewWindow}">
|
||||||
|
@ -75,7 +75,7 @@ namespace Ryujinx.Ava.UI.Windows
|
|||||||
string parentPath = currentCheatFile.Replace(titleModsPath, string.Empty);
|
string parentPath = currentCheatFile.Replace(titleModsPath, string.Empty);
|
||||||
|
|
||||||
buildId = Path.GetFileNameWithoutExtension(currentCheatFile).ToUpper();
|
buildId = Path.GetFileNameWithoutExtension(currentCheatFile).ToUpper();
|
||||||
currentGroup = new CheatNode("", buildId, parentPath, true);
|
currentGroup = new CheatNode(string.Empty, buildId, parentPath, true);
|
||||||
|
|
||||||
LoadedCheats.Add(currentGroup);
|
LoadedCheats.Add(currentGroup);
|
||||||
}
|
}
|
||||||
|
@ -32,9 +32,9 @@ namespace Ryujinx.Ava.UI.Windows
|
|||||||
{
|
{
|
||||||
ContentDialog contentDialog = new()
|
ContentDialog contentDialog = new()
|
||||||
{
|
{
|
||||||
PrimaryButtonText = "",
|
PrimaryButtonText = string.Empty,
|
||||||
SecondaryButtonText = "",
|
SecondaryButtonText = string.Empty,
|
||||||
CloseButtonText = "",
|
CloseButtonText = string.Empty,
|
||||||
Content = new XCITrimmerWindow(mainWindowViewModel),
|
Content = new XCITrimmerWindow(mainWindowViewModel),
|
||||||
Title = string.Format(LocaleManager.Instance[LocaleKeys.XCITrimmerWindowTitle]),
|
Title = string.Format(LocaleManager.Instance[LocaleKeys.XCITrimmerWindowTitle]),
|
||||||
};
|
};
|
||||||
|
@ -32,7 +32,8 @@ namespace Ryujinx.Ava
|
|||||||
internal static class Updater
|
internal static class Updater
|
||||||
{
|
{
|
||||||
private const string GitHubApiUrl = "https://api.github.com";
|
private const string GitHubApiUrl = "https://api.github.com";
|
||||||
private const string LatestReleaseUrl = $"{GitHubApiUrl}/repos/{ReleaseInformation.ReleaseChannelOwner}/{ReleaseInformation.ReleaseChannelRepo}/releases/latest";
|
private const string LatestReleaseUrl =
|
||||||
|
$"{GitHubApiUrl}/repos/{ReleaseInformation.ReleaseChannelOwner}/{ReleaseInformation.ReleaseChannelRepo}/releases/latest";
|
||||||
|
|
||||||
private static readonly GithubReleasesJsonSerializerContext _serializerContext = new(JsonHelper.GetDefaultSerializerOptions());
|
private static readonly GithubReleasesJsonSerializerContext _serializerContext = new(JsonHelper.GetDefaultSerializerOptions());
|
||||||
|
|
||||||
@ -83,7 +84,7 @@ namespace Ryujinx.Ava
|
|||||||
}
|
}
|
||||||
catch
|
catch
|
||||||
{
|
{
|
||||||
Logger.Error?.Print(LogClass.Application, "Failed to convert the current Ryujinx version!");
|
Logger.Error?.Print(LogClass.Application, $"Failed to convert the current {App.FullAppName} version!");
|
||||||
|
|
||||||
await ContentDialogHelper.CreateWarningDialog(
|
await ContentDialogHelper.CreateWarningDialog(
|
||||||
LocaleManager.Instance[LocaleKeys.DialogUpdaterConvertFailedMessage],
|
LocaleManager.Instance[LocaleKeys.DialogUpdaterConvertFailedMessage],
|
||||||
|
Loading…
x
Reference in New Issue
Block a user