From cee712105850ac3385cd0091a923438167433f9f Mon Sep 17 00:00:00 2001
From: TSR Berry <20988865+TSRBerry@users.noreply.github.com>
Date: Sat, 8 Apr 2023 01:22:00 +0200
Subject: Move solution and projects to src

---
 .../Commands/SetRenderTargetsCommand.cs            | 24 ++++++++++++++++++++++
 1 file changed, 24 insertions(+)
 create mode 100644 src/Ryujinx.Graphics.GAL/Multithreading/Commands/SetRenderTargetsCommand.cs

(limited to 'src/Ryujinx.Graphics.GAL/Multithreading/Commands/SetRenderTargetsCommand.cs')

diff --git a/src/Ryujinx.Graphics.GAL/Multithreading/Commands/SetRenderTargetsCommand.cs b/src/Ryujinx.Graphics.GAL/Multithreading/Commands/SetRenderTargetsCommand.cs
new file mode 100644
index 00000000..0b175a72
--- /dev/null
+++ b/src/Ryujinx.Graphics.GAL/Multithreading/Commands/SetRenderTargetsCommand.cs
@@ -0,0 +1,24 @@
+using Ryujinx.Graphics.GAL.Multithreading.Model;
+using Ryujinx.Graphics.GAL.Multithreading.Resources;
+using System.Linq;
+
+namespace Ryujinx.Graphics.GAL.Multithreading.Commands
+{
+    struct SetRenderTargetsCommand : IGALCommand, IGALCommand<SetRenderTargetsCommand>
+    {
+        public CommandType CommandType => CommandType.SetRenderTargets;
+        private TableRef<ITexture[]> _colors;
+        private TableRef<ITexture> _depthStencil;
+
+        public void Set(TableRef<ITexture[]> colors, TableRef<ITexture> depthStencil)
+        {
+            _colors = colors;
+            _depthStencil = depthStencil;
+        }
+
+        public static void Run(ref SetRenderTargetsCommand command, ThreadedRenderer threaded, IRenderer renderer)
+        {
+            renderer.Pipeline.SetRenderTargets(command._colors.Get(threaded).Select(color => ((ThreadedTexture)color)?.Base).ToArray(), command._depthStencil.GetAs<ThreadedTexture>(threaded)?.Base);
+        }
+    }
+}
-- 
cgit v1.2.3-70-g09d2