From 88478782e121391b70cfee76a9026c151ac84235 Mon Sep 17 00:00:00 2001
From: Togi <10451936+Togimaro@users.noreply.github.com>
Date: Mon, 30 Sep 2024 18:47:35 +0200
Subject: [PATCH] Add GDK-related platforms to enums and csproj (#8474)
See #8195.
This PR add the GDK platforms to various enums, this is necessary to
build the [GDK
backend](https://github.com/MonoGame/MonoGame.XB1/pull/51).
Unfortunately this add two GDK-specific #ifdef to the code, one in
Game.cs already present for DX11 and another one to
WinFormsGamePlatform.cs in order to add a Prepare() call used by the
DX12 backend and to avoid calling SharpDX related stuff. This could
probably be removed when merging when #8242 is ready.
---
.../MonoGame.Framework.Content.Pipeline.csproj | 1 +
.../Processors/EffectProcessor.cs | 4 ++++
.../Serialization/Compiler/ContentWriter.cs | 2 ++
MonoGame.Framework.Content.Pipeline/TargetPlatform.cs | 9 +++++++++
MonoGame.Framework/Content/ContentManager.cs | 2 ++
.../Platform/Windows/WinFormsGamePlatform.cs | 7 +++++++
MonoGame.Framework/Utilities/GraphicsBackend.cs | 9 +++++++--
MonoGame.Framework/Utilities/MonoGamePlatform.cs | 10 ++++++++++
.../MonoGame.Effect.Compiler.csproj | 1 +
9 files changed, 43 insertions(+), 2 deletions(-)
diff --git a/MonoGame.Framework.Content.Pipeline/MonoGame.Framework.Content.Pipeline.csproj b/MonoGame.Framework.Content.Pipeline/MonoGame.Framework.Content.Pipeline.csproj
index d442dd82659..124189b2f9e 100644
--- a/MonoGame.Framework.Content.Pipeline/MonoGame.Framework.Content.Pipeline.csproj
+++ b/MonoGame.Framework.Content.Pipeline/MonoGame.Framework.Content.Pipeline.csproj
@@ -174,5 +174,6 @@
+
diff --git a/MonoGame.Framework.Content.Pipeline/Processors/EffectProcessor.cs b/MonoGame.Framework.Content.Pipeline/Processors/EffectProcessor.cs
index 194b0f58674..1e2b0e80bb3 100644
--- a/MonoGame.Framework.Content.Pipeline/Processors/EffectProcessor.cs
+++ b/MonoGame.Framework.Content.Pipeline/Processors/EffectProcessor.cs
@@ -97,6 +97,10 @@ private string GetProfileForPlatform(TargetPlatform platform)
return "OpenGL";
case TargetPlatform.DesktopVK:
return "Vulkan";
+ case TargetPlatform.WindowsGDK:
+ case TargetPlatform.XboxOne:
+ case TargetPlatform.XboxSeries:
+ return "GDK";
}
return platform.ToString();
diff --git a/MonoGame.Framework.Content.Pipeline/Serialization/Compiler/ContentWriter.cs b/MonoGame.Framework.Content.Pipeline/Serialization/Compiler/ContentWriter.cs
index d433a191f58..e9e7785dc7c 100644
--- a/MonoGame.Framework.Content.Pipeline/Serialization/Compiler/ContentWriter.cs
+++ b/MonoGame.Framework.Content.Pipeline/Serialization/Compiler/ContentWriter.cs
@@ -55,6 +55,8 @@ public sealed class ContentWriter : BinaryWriter
'S', // Nintendo Switch
'b', // WebAssembly and Bridge.NET
'V', // DesktopVK (Vulkan)
+ 'G', // Windows GDK
+ 's', // Xbox Series
};
///
diff --git a/MonoGame.Framework.Content.Pipeline/TargetPlatform.cs b/MonoGame.Framework.Content.Pipeline/TargetPlatform.cs
index 503dcf28144..0f23414aa94 100644
--- a/MonoGame.Framework.Content.Pipeline/TargetPlatform.cs
+++ b/MonoGame.Framework.Content.Pipeline/TargetPlatform.cs
@@ -91,6 +91,15 @@ public enum TargetPlatform
/// All desktop versions using Vulkan.
///
DesktopVK,
+
+ /// Windows GDK
+ ///
+ WindowsGDK,
+
+ ///
+ /// Xbox Series
+ ///
+ XboxSeries
}
diff --git a/MonoGame.Framework/Content/ContentManager.cs b/MonoGame.Framework/Content/ContentManager.cs
index 41f5aaec1f9..c2ac1e3e2f6 100644
--- a/MonoGame.Framework/Content/ContentManager.cs
+++ b/MonoGame.Framework/Content/ContentManager.cs
@@ -50,6 +50,8 @@ public partial class ContentManager : IDisposable
'S', // Nintendo Switch
'b', // WebAssembly and Bridge.NET
'V', // DesktopVK
+ 'G', // Windows GDK
+ 's', // Xbox Series
// NOTE: There are additional identifiers for consoles that
// are not defined in this repository. Be sure to ask the
diff --git a/MonoGame.Framework/Platform/Windows/WinFormsGamePlatform.cs b/MonoGame.Framework/Platform/Windows/WinFormsGamePlatform.cs
index 885ad72fee0..5037d0a21da 100644
--- a/MonoGame.Framework/Platform/Windows/WinFormsGamePlatform.cs
+++ b/MonoGame.Framework/Platform/Windows/WinFormsGamePlatform.cs
@@ -80,6 +80,11 @@ public override bool BeforeUpdate(GameTime gameTime)
public override bool BeforeDraw(GameTime gameTime)
{
+#if GDKX
+ var device = Game.GraphicsDevice;
+ if (device != null)
+ device.PlatformPrepare(); // maybe add a Prepare() to GraphicsDevice, could be useful for other backend?
+#endif
return true;
}
@@ -126,7 +131,9 @@ protected override void Dispose(bool disposing)
_window = null;
Window = null;
}
+#if !GDKX
Microsoft.Xna.Framework.Media.MediaManagerState.CheckShutdown();
+#endif
}
base.Dispose(disposing);
diff --git a/MonoGame.Framework/Utilities/GraphicsBackend.cs b/MonoGame.Framework/Utilities/GraphicsBackend.cs
index d93dff82edb..06edd6d435d 100644
--- a/MonoGame.Framework/Utilities/GraphicsBackend.cs
+++ b/MonoGame.Framework/Utilities/GraphicsBackend.cs
@@ -10,7 +10,7 @@ namespace MonoGame.Framework.Utilities
public enum GraphicsBackend
{
///
- /// Represents the Microsoft DirectX graphics backend.
+ /// Represents the Microsoft DirectX 11 graphics backend.
///
DirectX,
@@ -27,6 +27,11 @@ public enum GraphicsBackend
///
/// Represents the Apple Metal graphics backend.
///
- Metal
+ Metal,
+
+ ///
+ /// Represents the Microsoft DirectX 12 graphics backend. (GDKX only for now)
+ ///
+ DirectX12
}
}
\ No newline at end of file
diff --git a/MonoGame.Framework/Utilities/MonoGamePlatform.cs b/MonoGame.Framework/Utilities/MonoGamePlatform.cs
index 1d5dc8d746f..05f6b6b73b5 100644
--- a/MonoGame.Framework/Utilities/MonoGamePlatform.cs
+++ b/MonoGame.Framework/Utilities/MonoGamePlatform.cs
@@ -43,6 +43,16 @@ public enum MonoGamePlatform
/// MonoGame Xbox One platform.
///
XboxOne,
+
+ ///
+ /// MonoGame Windows GDK platform.
+ ///
+ WindowsGDK,
+
+ ///
+ /// MonoGame Xbox Series platform.
+ ///
+ XboxSeries,
///
/// MonoGame PlayStation 4 platform.
diff --git a/Tools/MonoGame.Effect.Compiler/MonoGame.Effect.Compiler.csproj b/Tools/MonoGame.Effect.Compiler/MonoGame.Effect.Compiler.csproj
index 00ccca6da08..2d5eb5a0e74 100644
--- a/Tools/MonoGame.Effect.Compiler/MonoGame.Effect.Compiler.csproj
+++ b/Tools/MonoGame.Effect.Compiler/MonoGame.Effect.Compiler.csproj
@@ -83,6 +83,7 @@
+