diff options
| author | Emmanuel Hansen <emmausssss@gmail.com> | 2022-01-03 08:39:43 +0000 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-01-03 09:39:43 +0100 |
| commit | e98abf182043630fd8fae1a20a3ddfe5fe56a313 (patch) | |
| tree | 7de26ce2e12e9c5036278c49023b023442f2fbc1 /Ryujinx.HLE/HOS/TamperMachine.cs | |
| parent | dc8a1d5cbafc842c1ad52adcbf0a4a023931541a (diff) | |
Add Cheat Manager (#2964)
* add cheatmanager
* use modloader to load cheats for manager
* addressed nits
Diffstat (limited to 'Ryujinx.HLE/HOS/TamperMachine.cs')
| -rw-r--r-- | Ryujinx.HLE/HOS/TamperMachine.cs | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/Ryujinx.HLE/HOS/TamperMachine.cs b/Ryujinx.HLE/HOS/TamperMachine.cs index 6044368e..016f326f 100644 --- a/Ryujinx.HLE/HOS/TamperMachine.cs +++ b/Ryujinx.HLE/HOS/TamperMachine.cs @@ -20,6 +20,7 @@ namespace Ryujinx.HLE.HOS private Thread _tamperThread = null; private ConcurrentQueue<ITamperProgram> _programs = new ConcurrentQueue<ITamperProgram>(); private long _pressedKeys = 0; + private Dictionary<string, ITamperProgram> _programDictionary = new Dictionary<string, ITamperProgram>(); private void Activate() { @@ -31,7 +32,7 @@ namespace Ryujinx.HLE.HOS } } - internal void InstallAtmosphereCheat(string name, IEnumerable<string> rawInstructions, ProcessTamperInfo info, ulong exeAddress) + internal void InstallAtmosphereCheat(string name, string buildId, IEnumerable<string> rawInstructions, ProcessTamperInfo info, ulong exeAddress) { if (!CanInstallOnPid(info.Process.Pid)) { @@ -47,6 +48,7 @@ namespace Ryujinx.HLE.HOS program.TampersCodeMemory = false; _programs.Enqueue(program); + _programDictionary.TryAdd($"{buildId}-{name}", program); } Activate(); @@ -65,6 +67,22 @@ namespace Ryujinx.HLE.HOS return true; } + public void EnableCheats(string[] enabledCheats) + { + foreach (var program in _programDictionary.Values) + { + program.IsEnabled = false; + } + + foreach (var cheat in enabledCheats) + { + if (_programDictionary.TryGetValue(cheat, out var program)) + { + program.IsEnabled = true; + } + } + } + private bool IsProcessValid(ITamperedProcess process) { return process.State != ProcessState.Crashed && process.State != ProcessState.Exiting && process.State != ProcessState.Exited; @@ -105,6 +123,8 @@ namespace Ryujinx.HLE.HOS if (!_programs.TryDequeue(out ITamperProgram program)) { // No more programs in the queue. + _programDictionary.Clear(); + return false; } |
