aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Ryujinx.Ava/Modules/Updater/Updater.cs29
-rw-r--r--Ryujinx/Modules/Updater/Updater.cs21
2 files changed, 29 insertions, 21 deletions
diff --git a/Ryujinx.Ava/Modules/Updater/Updater.cs b/Ryujinx.Ava/Modules/Updater/Updater.cs
index a48156c4..b3a1ef30 100644
--- a/Ryujinx.Ava/Modules/Updater/Updater.cs
+++ b/Ryujinx.Ava/Modules/Updater/Updater.cs
@@ -11,6 +11,7 @@ using Ryujinx.Ava.Ui.Controls;
using Ryujinx.Ava.Ui.Windows;
using Ryujinx.Common;
using Ryujinx.Common.Logging;
+using Ryujinx.Ui.Common.Helper;
using System;
using System.Collections.Generic;
using System.Diagnostics;
@@ -278,14 +279,15 @@ namespace Ryujinx.Modules
{
string ryuName = Path.GetFileName(Environment.ProcessPath);
string ryuExe = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, ryuName);
- var ryuArg = Environment.GetCommandLineArgs().Skip(1);
- if (!OperatingSystem.IsWindows())
+ if (!Path.Exists(ryuExe))
{
- chmod(ryuExe, Convert.ToUInt32("0777", 8));
+ ryuExe = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, OperatingSystem.IsWindows() ? "Ryujinx.exe" : "Ryujinx");
}
- Process.Start(ryuExe, ryuArg);
+ SetFileExecutable(ryuExe);
+
+ Process.Start(ryuExe, CommandLineState.Arguments);
Environment.Exit(0);
}
@@ -456,16 +458,19 @@ namespace Ryujinx.Modules
worker.Start();
}
- [DllImport("libc", SetLastError = true)]
- private static extern int chmod(string path, uint mode);
-
- private static void SetUnixPermissions()
+ private static void SetFileExecutable(string path)
{
- string ryuBin = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Ryujinx");
+ const UnixFileMode ExecutableFileMode = UnixFileMode.UserExecute |
+ UnixFileMode.UserWrite |
+ UnixFileMode.UserRead |
+ UnixFileMode.GroupRead |
+ UnixFileMode.GroupWrite |
+ UnixFileMode.OtherRead |
+ UnixFileMode.OtherWrite;
- if (!OperatingSystem.IsWindows())
+ if (!OperatingSystem.IsWindows() && File.Exists(path))
{
- chmod(ryuBin, 493);
+ File.SetUnixFileMode(path, ExecutableFileMode);
}
}
@@ -586,7 +591,7 @@ namespace Ryujinx.Modules
Directory.Delete(UpdateDir, true);
- SetUnixPermissions();
+ SetFileExecutable(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Ryujinx"));
UpdateSuccessful = true;
diff --git a/Ryujinx/Modules/Updater/Updater.cs b/Ryujinx/Modules/Updater/Updater.cs
index 194d35e5..0a1cb53b 100644
--- a/Ryujinx/Modules/Updater/Updater.cs
+++ b/Ryujinx/Modules/Updater/Updater.cs
@@ -387,16 +387,19 @@ namespace Ryujinx.Modules
worker.Start();
}
- [DllImport("libc", SetLastError = true)]
- private static extern int chmod(string path, uint mode);
-
- private static void SetUnixPermissions()
+ private static void SetFileExecutable(string path)
{
- string ryuBin = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Ryujinx");
-
- if (!OperatingSystem.IsWindows())
+ const UnixFileMode ExecutableFileMode = UnixFileMode.UserExecute |
+ UnixFileMode.UserWrite |
+ UnixFileMode.UserRead |
+ UnixFileMode.GroupRead |
+ UnixFileMode.GroupWrite |
+ UnixFileMode.OtherRead |
+ UnixFileMode.OtherWrite;
+
+ if (!OperatingSystem.IsWindows() && File.Exists(path))
{
- chmod(ryuBin, 493);
+ File.SetUnixFileMode(path, ExecutableFileMode);
}
}
@@ -519,7 +522,7 @@ namespace Ryujinx.Modules
Directory.Delete(UpdateDir, true);
- SetUnixPermissions();
+ SetFileExecutable(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Ryujinx"));
updateDialog.MainText.Text = "Update Complete!";
updateDialog.SecondaryText.Text = "Do you want to restart Ryujinx now?";