aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.HLE/OsHle/AppletStateMgr.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Ryujinx.HLE/OsHle/AppletStateMgr.cs')
-rw-r--r--Ryujinx.HLE/OsHle/AppletStateMgr.cs62
1 files changed, 62 insertions, 0 deletions
diff --git a/Ryujinx.HLE/OsHle/AppletStateMgr.cs b/Ryujinx.HLE/OsHle/AppletStateMgr.cs
new file mode 100644
index 00000000..5fdb5343
--- /dev/null
+++ b/Ryujinx.HLE/OsHle/AppletStateMgr.cs
@@ -0,0 +1,62 @@
+using Ryujinx.HLE.OsHle.Handles;
+using Ryujinx.HLE.OsHle.Services.Am;
+using System;
+using System.Collections.Concurrent;
+
+namespace Ryujinx.HLE.OsHle
+{
+ class AppletStateMgr : IDisposable
+ {
+ private ConcurrentQueue<MessageInfo> Messages;
+
+ public FocusState FocusState { get; private set; }
+
+ public KEvent MessageEvent { get; private set; }
+
+ public AppletStateMgr()
+ {
+ Messages = new ConcurrentQueue<MessageInfo>();
+
+ MessageEvent = new KEvent();
+ }
+
+ public void SetFocus(bool IsFocused)
+ {
+ FocusState = IsFocused
+ ? FocusState.InFocus
+ : FocusState.OutOfFocus;
+
+ EnqueueMessage(MessageInfo.FocusStateChanged);
+ }
+
+ public void EnqueueMessage(MessageInfo Message)
+ {
+ Messages.Enqueue(Message);
+
+ MessageEvent.WaitEvent.Set();
+ }
+
+ public bool TryDequeueMessage(out MessageInfo Message)
+ {
+ if (Messages.Count < 2)
+ {
+ MessageEvent.WaitEvent.Reset();
+ }
+
+ return Messages.TryDequeue(out Message);
+ }
+
+ public void Dispose()
+ {
+ Dispose(true);
+ }
+
+ protected virtual void Dispose(bool Disposing)
+ {
+ if (Disposing)
+ {
+ MessageEvent.Dispose();
+ }
+ }
+ }
+} \ No newline at end of file