system.d 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  1. /*
  2. Boost Software License - Version 1.0 - August 17th, 2003
  3. Permission is hereby granted, free of charge, to any person or organization
  4. obtaining a copy of the software and accompanying documentation covered by
  5. this license (the "Software") to use, reproduce, display, distribute,
  6. execute, and transmit the Software, and to prepare derivative works of the
  7. Software, and to permit third-parties to whom the Software is furnished to
  8. do so, all subject to the following:
  9. The copyright notices in the Software and this entire statement, including
  10. the above license grant, this restriction and the following disclaimer,
  11. must be included in all copies of the Software, in whole or in part, and
  12. all derivative works of the Software, unless such copies or derivative
  13. works are solely in the form of machine-executable object code generated by
  14. a source language processor.
  15. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  17. FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
  18. SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
  19. FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
  20. ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  21. DEALINGS IN THE SOFTWARE.
  22. */
  23. module derelict.vulkan.system;
  24. import derelict.util.system;
  25. import derelict.vulkan.base;
  26. enum VKSystem {
  27. Other = 0,
  28. Windows = 1 << 0,
  29. Android = 1 << 1,
  30. Posix = 1 << 2
  31. }
  32. mixin SystemFunctionality;
  33. private:
  34. import std.conv;
  35. auto derelictVulkanSystem() {
  36. static if (Derelict_OS_Posix) {
  37. return VKSystem.Posix;
  38. } else static if (Derelict_OS_Windows) {
  39. return VKSystem.Windows;
  40. } else static if (Derelict_OS_Android) {
  41. return VKSystem.Android;
  42. } else {
  43. pragma(msg, "Non of currently supported systems is fit to yours. "
  44. , "If required functionality is missed, feel free to extend and share on GitHub.");
  45. return VKSystem.Other;
  46. }
  47. }
  48. mixin template SystemFunctionality() {
  49. extern(System):
  50. enum currentSystem = derelictVulkanSystem();
  51. pragma(msg, "DerelictVulkanSystem: ", to!string(currentSystem));
  52. static if (currentSystem == VKSystem.Windows) {
  53. mixin WindowsSys;
  54. } else static if (currentSystem == VKSystem.Android) {
  55. mixin AndroidSys;
  56. } else static if (currentSystem == VKSystem.Posix) {
  57. mixin PosixSys;
  58. }
  59. }
  60. mixin template WindowsSys() {
  61. import core.sys.windows.windows;
  62. enum VK_KHR_win32_surface = 1;
  63. enum VK_KHR_WIN32_SURFACE_SPEC_VERSION = 5;
  64. enum VK_KHR_WIN32_SURFACE_EXTENSION_NAME = "VK_KHR_win32_surface";
  65. alias VkWin32SurfaceCreateFlagsKHR = VkFlags;
  66. struct VkWin32SurfaceCreateInfoKHR {
  67. VkStructureType sType ;
  68. const(void)* pNext ;
  69. VkWin32SurfaceCreateFlagsKHR flags ;
  70. HINSTANCE hinstance;
  71. HWND hwnd ;
  72. }
  73. alias PFN_vkCreateWin32SurfaceKHR = nothrow
  74. VkResult function( VkInstance instance
  75. , const(VkWin32SurfaceCreateInfoKHR)* pCreateInfo
  76. , const(VkAllocationCallbacks)* pAllocator
  77. , VkSurfaceKHR* pSurface );
  78. alias PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR = nothrow
  79. VkBool32 function( VkPhysicalDevice physicalDevice, uint queueFamilyIndex );
  80. version (none) {
  81. VkResult vkCreateWin32SurfaceKHR( VkInstance instance
  82. , const(VkWin32SurfaceCreateInfoKHR)* pCreateInfo
  83. , const(VkAllocationCallbacks)* pAllocator
  84. , VkSurfaceKHR* pSurface );
  85. VkBool32 vkGetPhysicalDeviceWin32PresentationSupportKHR( VkPhysicalDevice physicalDevice, uint queueFamilyIndex );
  86. }
  87. }
  88. mixin template AndroidSys() {
  89. // #include <android/native_window.h>
  90. enum VK_KHR_android_surface = 1;
  91. enum VK_KHR_ANDROID_SURFACE_SPEC_VERSION = 6;
  92. enum VK_KHR_ANDROID_SURFACE_EXTENSION_NAME = "VK_KHR_android_surface";
  93. alias VkAndroidSurfaceCreateFlagsKHR = VkFlags;
  94. struct VkAndroidSurfaceCreateInfoKHR {
  95. VkStructureType sType ;
  96. const(void)* pNext ;
  97. VkAndroidSurfaceCreateFlagsKHR flags ;
  98. ANativeWindow* window;
  99. }
  100. alias PFN_vkCreateAndroidSurfaceKHR = nothrow
  101. VkResult function( VkInstance instance
  102. , const(VkAndroidSurfaceCreateInfoKHR)* pCreateInfo
  103. , const(VkAllocationCallbacks)* pAllocator
  104. , VkSurfaceKHR* pSurface );
  105. version (none) {
  106. VkResult vkCreateAndroidSurfaceKHR( VkInstance instance
  107. , const(VkAndroidSurfaceCreateInfoKHR)* pCreateInfo
  108. , const(VkAllocationCallbacks)* pAllocator
  109. , VkSurfaceKHR* pSurface);
  110. }
  111. }
  112. mixin template PosixSys() {
  113. version (VK_USE_PLATFORM_XCB_KHR) mixin XCBProtocol ;
  114. version (VK_USE_PLATFORM_XLIB_KHR) mixin XLibProtocol ;
  115. version (VK_USE_PLATFORM_MIR_KHR) mixin MirProtocol ;
  116. version (VK_USE_PLATFORM_WAYLAND_KHR) mixin WaylandProtocol;
  117. else pragma(msg, "Non protocol been selected for Posix system.");
  118. }
  119. mixin template XCBProtocol() {
  120. // #include <xcb/xcb.h>
  121. enum VK_KHR_xcb_surface = 1;
  122. enum VK_KHR_XCB_SURFACE_SPEC_VERSION = 6;
  123. enum VK_KHR_XCB_SURFACE_EXTENSION_NAME = "VK_KHR_xcb_surface";
  124. alias VkXcbSurfaceCreateFlagsKHR = VkFlags;
  125. struct VkXcbSurfaceCreateInfoKHR {
  126. VkStructureType sType ;
  127. const(void)* pNext ;
  128. VkXcbSurfaceCreateFlagsKHR flags ;
  129. xcb_connection_t* connection;
  130. xcb_window_t window ;
  131. }
  132. alias PFN_vkCreateXcbSurfaceKHR = nothrow
  133. VkResult function( VkInstance instance
  134. , const(VkXcbSurfaceCreateInfoKHR)* pCreateInfo
  135. , const(VkAllocationCallbacks)* pAllocator
  136. , VkSurfaceKHR* pSurface );
  137. alias PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR = nothrow
  138. VkBool32 function( VkPhysicalDevice physicalDevice
  139. , uint queueFamilyIndex
  140. , xcb_connection_t* connection
  141. , xcb_visualid_t visual_id );
  142. version (none) {
  143. VkResult vkCreateXcbSurfaceKHR( VkInstance instance
  144. , const(VkXcbSurfaceCreateInfoKHR)* pCreateInfo
  145. , const(VkAllocationCallbacks)* pAllocator
  146. , VkSurfaceKHR* pSurface );
  147. VkBool32 vkGetPhysicalDeviceXcbPresentationSupportKHR( VkPhysicalDevice physicalDevice
  148. , uint queueFamilyIndex
  149. , xcb_connection_t* connection
  150. , xcb_visualid_t visual_id);
  151. }
  152. }
  153. mixin template XLibProtocol() {
  154. // #include <X11/Xlib.h>
  155. enum VK_KHR_xlib_surface = 1;
  156. enum VK_KHR_XLIB_SURFACE_SPEC_VERSION = 6;
  157. enum VK_KHR_XLIB_SURFACE_EXTENSION_NAME = "VK_KHR_xlib_surface";
  158. alias VkXlibSurfaceCreateFlagsKHR = VkFlags;
  159. struct VkXlibSurfaceCreateInfoKHR {
  160. VkStructureType sType ;
  161. const(void)* pNext ;
  162. VkXlibSurfaceCreateFlagsKHR flags ;
  163. Display* dpy ;
  164. Window window;
  165. }
  166. alias PFN_vkCreateXlibSurfaceKHR = nothrow
  167. VkResult function( VkInstance instance
  168. , const(VkXlibSurfaceCreateInfoKHR)* pCreateInfo
  169. , const(VkAllocationCallbacks)* pAllocator
  170. , VkSurfaceKHR* pSurface );
  171. alias PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR = nothrow
  172. VkBool32 function( VkPhysicalDevice physicalDevice
  173. , uint queueFamilyIndex
  174. , Display* dpy
  175. , VisualID visualID);
  176. version (none) {
  177. VkResult vkCreateXlibSurfaceKHR( VkInstance instance
  178. , const(VkXlibSurfaceCreateInfoKHR)* pCreateInfo
  179. , const(VkAllocationCallbacks)* pAllocator
  180. , VkSurfaceKHR* pSurface );
  181. VkBool32 vkGetPhysicalDeviceXlibPresentationSupportKHR( VkPhysicalDevice physicalDevice
  182. , uint queueFamilyIndex
  183. , Display* dpy
  184. , VisualID visualID );
  185. }
  186. }
  187. mixin template MirProtocol() {
  188. // #include <mir_toolkit/client_types.h>
  189. enum VK_KHR_mir_surface = 1;
  190. enum VK_KHR_MIR_SURFACE_SPEC_VERSION = 4;
  191. enum VK_KHR_MIR_SURFACE_EXTENSION_NAME = "VK_KHR_mir_surface";
  192. alias VkMirSurfaceCreateFlagsKHR = VkFlags;
  193. struct VkMirSurfaceCreateInfoKHR {
  194. VkStructureType sType ;
  195. const(void)* pNext ;
  196. VkMirSurfaceCreateFlagsKHR flags ;
  197. MirConnection* connection;
  198. MirSurface* mirSurface;
  199. }
  200. alias PFN_vkCreateMirSurfaceKHR = nothrow
  201. VkResult function( VkInstance instance
  202. , const(VkMirSurfaceCreateInfoKHR)* pCreateInfo
  203. , const(VkAllocationCallbacks)* pAllocator
  204. , VkSurfaceKHR* pSurface );
  205. alias PFN_vkGetPhysicalDeviceMirPresentationSupportKHR = nothrow
  206. VkBool32 function( VkPhysicalDevice physicalDevice
  207. , uint queueFamilyIndex
  208. , MirConnection* connection);
  209. version (none) {
  210. VkResult vkCreateMirSurfaceKHR( VkInstance instance
  211. , const(VkMirSurfaceCreateInfoKHR)* pCreateInfo
  212. , const(VkAllocationCallbacks)* pAllocator
  213. , VkSurfaceKHR* pSurface );
  214. VkBool32 vkGetPhysicalDeviceMirPresentationSupportKHR( VkPhysicalDevice physicalDevice
  215. , uint queueFamilyIndex
  216. , MirConnection* connection );
  217. }
  218. }
  219. mixin template WaylandProtocol() {
  220. // #include <wayland-client.h>
  221. enum VK_KHR_wayland_surface = 1;
  222. enum VK_KHR_WAYLAND_SURFACE_SPEC_VERSION = 5;
  223. enum VK_KHR_WAYLAND_SURFACE_EXTENSION_NAME = "VK_KHR_wayland_surface";
  224. alias VkWaylandSurfaceCreateFlagsKHR = VkFlags;
  225. struct VkWaylandSurfaceCreateInfoKHR {
  226. VkStructureType sType ;
  227. const(void)* pNext ;
  228. VkWaylandSurfaceCreateFlagsKHR flags ;
  229. wl_display* display;
  230. wl_surface* surface;
  231. }
  232. alias PFN_vkCreateWaylandSurfaceKHR = nothrow
  233. VkResult function( VkInstance instance
  234. , const(VkWaylandSurfaceCreateInfoKHR)* pCreateInfo
  235. , const(VkAllocationCallbacks)* pAllocator
  236. , VkSurfaceKHR* pSurface );
  237. alias PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR = nothrow
  238. VkBool32 function( VkPhysicalDevice physicalDevice
  239. , uint queueFamilyIndex
  240. , wl_display* display );
  241. version (none) {
  242. VkResult vkCreateWaylandSurfaceKHR( VkInstance instance
  243. , const(VkWaylandSurfaceCreateInfoKHR)* pCreateInfo
  244. , const(VkAllocationCallbacks)* pAllocator
  245. , VkSurfaceKHR* pSurface );
  246. VkBool32 vkGetPhysicalDeviceWaylandPresentationSupportKHR( VkPhysicalDevice physicalDevice
  247. , uint queueFamilyIndex
  248. , wl_display* display );
  249. }
  250. }