system.d 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368
  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. public import derelict.vulkan.base;
  25. public import derelict.vulkan.types;
  26. import derelict.util.system;
  27. enum VKSystem {
  28. Other = 0,
  29. Windows = 1 << 0,
  30. Android = 1 << 1,
  31. Posix = 1 << 2
  32. }
  33. mixin SystemFunctionality;
  34. private:
  35. import std.conv;
  36. auto derelictVulkanSystem() {
  37. static if (Derelict_OS_Posix) {
  38. return VKSystem.Posix;
  39. } else static if (Derelict_OS_Windows) {
  40. return VKSystem.Windows;
  41. } else static if (Derelict_OS_Android) {
  42. return VKSystem.Android;
  43. } else {
  44. pragma(msg, "Non of currently supported systems is fit to yours. "
  45. , "If required functionality is missed, feel free to extend and share on GitHub.");
  46. return VKSystem.Other;
  47. }
  48. }
  49. mixin template DummyFunctions() {
  50. pragma(inline, true)
  51. void bindFunctions(alias bind)() {}
  52. }
  53. mixin template SystemFunctionality() {
  54. extern(System):
  55. enum currentSystem = derelictVulkanSystem();
  56. pragma(msg, "DerelictVulkanSystem: ", to!string(currentSystem));
  57. static if (currentSystem == VKSystem.Windows) {
  58. mixin WindowsSys;
  59. } else static if (currentSystem == VKSystem.Android) {
  60. mixin AndroidSys;
  61. } else static if (currentSystem == VKSystem.Posix) {
  62. mixin PosixSys;
  63. } else {
  64. package alias Functions = DummyFunctions;
  65. }
  66. }
  67. mixin template WindowsSys() {
  68. import core.sys.windows.windows;
  69. enum VK_KHR_win32_surface = 1;
  70. enum VK_KHR_WIN32_SURFACE_SPEC_VERSION = 5;
  71. enum VK_KHR_WIN32_SURFACE_EXTENSION_NAME = "VK_KHR_win32_surface";
  72. alias VkWin32SurfaceCreateFlagsKHR = VkFlags;
  73. struct VkWin32SurfaceCreateInfoKHR {
  74. VkStructureType sType ;
  75. const(void)* pNext ;
  76. VkWin32SurfaceCreateFlagsKHR flags ;
  77. HINSTANCE hinstance;
  78. HWND hwnd ;
  79. }
  80. alias PFN_vkCreateWin32SurfaceKHR = nothrow
  81. VkResult function( VkInstance instance
  82. , const(VkWin32SurfaceCreateInfoKHR)* pCreateInfo
  83. , const(VkAllocationCallbacks)* pAllocator
  84. , VkSurfaceKHR* pSurface );
  85. alias PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR = nothrow
  86. VkBool32 function( VkPhysicalDevice physicalDevice, uint queueFamilyIndex );
  87. mixin template Functions() {
  88. PFN_vkCreateWin32SurfaceKHR vkCreateWin32SurfaceKHR;
  89. PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR vkGetPhysicalDeviceWin32PresentationSupportKHR;
  90. pragma(inline, true)
  91. void bindFunctions(alias bind)() {
  92. bind(cast(void**)&vkCreateWin32SurfaceKHR, "vkCreateWin32SurfaceKHR");
  93. bind( cast(void**)&vkGetPhysicalDeviceWin32PresentationSupportKHR
  94. , "vkGetPhysicalDeviceWin32PresentationSupportKHR");
  95. }
  96. }
  97. version (none) {
  98. VkResult vkCreateWin32SurfaceKHR( VkInstance instance
  99. , const(VkWin32SurfaceCreateInfoKHR)* pCreateInfo
  100. , const(VkAllocationCallbacks)* pAllocator
  101. , VkSurfaceKHR* pSurface );
  102. VkBool32 vkGetPhysicalDeviceWin32PresentationSupportKHR( VkPhysicalDevice physicalDevice, uint queueFamilyIndex );
  103. }
  104. }
  105. mixin template AndroidSys() {
  106. // #include <android/native_window.h>
  107. enum VK_KHR_android_surface = 1;
  108. enum VK_KHR_ANDROID_SURFACE_SPEC_VERSION = 6;
  109. enum VK_KHR_ANDROID_SURFACE_EXTENSION_NAME = "VK_KHR_android_surface";
  110. alias VkAndroidSurfaceCreateFlagsKHR = VkFlags;
  111. struct VkAndroidSurfaceCreateInfoKHR {
  112. VkStructureType sType ;
  113. const(void)* pNext ;
  114. VkAndroidSurfaceCreateFlagsKHR flags ;
  115. ANativeWindow* window;
  116. }
  117. alias PFN_vkCreateAndroidSurfaceKHR = nothrow
  118. VkResult function( VkInstance instance
  119. , const(VkAndroidSurfaceCreateInfoKHR)* pCreateInfo
  120. , const(VkAllocationCallbacks)* pAllocator
  121. , VkSurfaceKHR* pSurface );
  122. mixin template Functions() {
  123. PFN_vkCreateAndroidSurfaceKHR vkCreateAndroidSurfaceKHR;
  124. pragma(inline, true)
  125. void bindFunctions(alias bind)() {
  126. bind(cast(void**)&vkCreateAndroidSurfaceKHR, "vkCreateAndroidSurfaceKHR");
  127. }
  128. }
  129. version (none) {
  130. VkResult vkCreateAndroidSurfaceKHR( VkInstance instance
  131. , const(VkAndroidSurfaceCreateInfoKHR)* pCreateInfo
  132. , const(VkAllocationCallbacks)* pAllocator
  133. , VkSurfaceKHR* pSurface);
  134. }
  135. }
  136. mixin template PosixSys() {
  137. version (VK_USE_PLATFORM_XCB_KHR) mixin XCBProtocol ;
  138. version (VK_USE_PLATFORM_XLIB_KHR) mixin XLibProtocol ;
  139. version (VK_USE_PLATFORM_MIR_KHR) mixin MirProtocol ;
  140. version (VK_USE_PLATFORM_WAYLAND_KHR) mixin WaylandProtocol;
  141. else {
  142. pragma(msg, "Non protocol been selected for Posix system.");
  143. package alias Functions = DummyFunctions;
  144. }
  145. }
  146. mixin template XCBProtocol() {
  147. import xcb.xcb;
  148. enum VK_KHR_xcb_surface = 1;
  149. enum VK_KHR_XCB_SURFACE_SPEC_VERSION = 6;
  150. enum VK_KHR_XCB_SURFACE_EXTENSION_NAME = "VK_KHR_xcb_surface";
  151. alias VkXcbSurfaceCreateFlagsKHR = VkFlags;
  152. struct VkXcbSurfaceCreateInfoKHR {
  153. VkStructureType sType ;
  154. const(void)* pNext ;
  155. VkXcbSurfaceCreateFlagsKHR flags ;
  156. xcb_connection_t* connection;
  157. xcb_window_t window ;
  158. }
  159. alias PFN_vkCreateXcbSurfaceKHR = nothrow
  160. VkResult function( VkInstance instance
  161. , const(VkXcbSurfaceCreateInfoKHR)* pCreateInfo
  162. , const(VkAllocationCallbacks)* pAllocator
  163. , VkSurfaceKHR* pSurface );
  164. alias PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR = nothrow
  165. VkBool32 function( VkPhysicalDevice physicalDevice
  166. , uint queueFamilyIndex
  167. , xcb_connection_t* connection
  168. , xcb_visualid_t visual_id );
  169. mixin template Functions() {
  170. PFN_vkCreateXcbSurfaceKHR vkCreateXcbSurfaceKHR;
  171. PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR vkGetPhysicalDeviceXcbPresentationSupportKHR;
  172. pragma(inline, true)
  173. void bindFunctions(alias bind)() {
  174. bind(cast(void**)&vkCreateXcbSurfaceKHR, "vkCreateXcbSurfaceKHR");
  175. bind( cast(void**)&vkGetPhysicalDeviceXcbPresentationSupportKHR
  176. , "vkGetPhysicalDeviceXcbPresentationSupportKHR" );
  177. }
  178. }
  179. version (none) {
  180. VkResult vkCreateXcbSurfaceKHR( VkInstance instance
  181. , const(VkXcbSurfaceCreateInfoKHR)* pCreateInfo
  182. , const(VkAllocationCallbacks)* pAllocator
  183. , VkSurfaceKHR* pSurface );
  184. VkBool32 vkGetPhysicalDeviceXcbPresentationSupportKHR( VkPhysicalDevice physicalDevice
  185. , uint queueFamilyIndex
  186. , xcb_connection_t* connection
  187. , xcb_visualid_t visual_id);
  188. }
  189. }
  190. mixin template XLibProtocol() {
  191. import X11.Xlib;
  192. enum VK_KHR_xlib_surface = 1;
  193. enum VK_KHR_XLIB_SURFACE_SPEC_VERSION = 6;
  194. enum VK_KHR_XLIB_SURFACE_EXTENSION_NAME = "VK_KHR_xlib_surface";
  195. alias VkXlibSurfaceCreateFlagsKHR = VkFlags;
  196. struct VkXlibSurfaceCreateInfoKHR {
  197. VkStructureType sType ;
  198. const(void)* pNext ;
  199. VkXlibSurfaceCreateFlagsKHR flags ;
  200. Display* dpy ;
  201. Window window;
  202. }
  203. alias PFN_vkCreateXlibSurfaceKHR = nothrow
  204. VkResult function( VkInstance instance
  205. , const(VkXlibSurfaceCreateInfoKHR)* pCreateInfo
  206. , const(VkAllocationCallbacks)* pAllocator
  207. , VkSurfaceKHR* pSurface );
  208. alias PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR = nothrow
  209. VkBool32 function( VkPhysicalDevice physicalDevice
  210. , uint queueFamilyIndex
  211. , Display* dpy
  212. , VisualID visualID);
  213. mixin template Functions() {
  214. PFN_vkCreateXlibSurfaceKHR vkCreateXlibSurfaceKHR;
  215. PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR vkGetPhysicalDeviceXlibPresentationSupportKHR;
  216. pragma(inline, true)
  217. void bindFunctions(alias bind)() {
  218. bind(cast(void**)&vkCreateXlibSurfaceKHR, "vkCreateXlibSurfaceKHR");
  219. bind( cast(void**)&vkGetPhysicalDeviceXlibPresentationSupportKHR
  220. , "vkGetPhysicalDeviceXlibPresentationSupportKHR" );
  221. }
  222. }
  223. version (none) {
  224. VkResult vkCreateXlibSurfaceKHR( VkInstance instance
  225. , const(VkXlibSurfaceCreateInfoKHR)* pCreateInfo
  226. , const(VkAllocationCallbacks)* pAllocator
  227. , VkSurfaceKHR* pSurface );
  228. VkBool32 vkGetPhysicalDeviceXlibPresentationSupportKHR( VkPhysicalDevice physicalDevice
  229. , uint queueFamilyIndex
  230. , Display* dpy
  231. , VisualID visualID );
  232. }
  233. }
  234. mixin template MirProtocol() {
  235. //TODO: add import of data related to Mir protocol
  236. // #include <mir_toolkit/client_types.h>
  237. enum VK_KHR_mir_surface = 1;
  238. enum VK_KHR_MIR_SURFACE_SPEC_VERSION = 4;
  239. enum VK_KHR_MIR_SURFACE_EXTENSION_NAME = "VK_KHR_mir_surface";
  240. alias VkMirSurfaceCreateFlagsKHR = VkFlags;
  241. struct VkMirSurfaceCreateInfoKHR {
  242. VkStructureType sType ;
  243. const(void)* pNext ;
  244. VkMirSurfaceCreateFlagsKHR flags ;
  245. MirConnection* connection;
  246. MirSurface* mirSurface;
  247. }
  248. alias PFN_vkCreateMirSurfaceKHR = nothrow
  249. VkResult function( VkInstance instance
  250. , const(VkMirSurfaceCreateInfoKHR)* pCreateInfo
  251. , const(VkAllocationCallbacks)* pAllocator
  252. , VkSurfaceKHR* pSurface );
  253. alias PFN_vkGetPhysicalDeviceMirPresentationSupportKHR = nothrow
  254. VkBool32 function( VkPhysicalDevice physicalDevice
  255. , uint queueFamilyIndex
  256. , MirConnection* connection);
  257. mixin template Functions() {
  258. PFN_vkCreateMirSurfaceKHR vkCreateMirSurfaceKHR;
  259. PFN_vkGetPhysicalDeviceMirPresentationSupportKHR vkGetPhysicalDeviceMirPresentationSupportKHR;
  260. pragma(inline, true)
  261. void bindFunctions(alias bind)() {
  262. bind(cast(void**)&vkCreateMirSurfaceKHR, "vkCreateMirSurfaceKHR");
  263. bind( cast(void**)&vkGetPhysicalDeviceMirPresentationSupportKHR
  264. , "vkGetPhysicalDeviceMirPresentationSupportKHR");
  265. }
  266. }
  267. version (none) {
  268. VkResult vkCreateMirSurfaceKHR( VkInstance instance
  269. , const(VkMirSurfaceCreateInfoKHR)* pCreateInfo
  270. , const(VkAllocationCallbacks)* pAllocator
  271. , VkSurfaceKHR* pSurface );
  272. VkBool32 vkGetPhysicalDeviceMirPresentationSupportKHR( VkPhysicalDevice physicalDevice
  273. , uint queueFamilyIndex
  274. , MirConnection* connection );
  275. }
  276. }
  277. mixin template WaylandProtocol() {
  278. //TODO: add import of data related to Wayland protocol
  279. // #include <wayland-client.h>
  280. enum VK_KHR_wayland_surface = 1;
  281. enum VK_KHR_WAYLAND_SURFACE_SPEC_VERSION = 5;
  282. enum VK_KHR_WAYLAND_SURFACE_EXTENSION_NAME = "VK_KHR_wayland_surface";
  283. alias VkWaylandSurfaceCreateFlagsKHR = VkFlags;
  284. struct VkWaylandSurfaceCreateInfoKHR {
  285. VkStructureType sType ;
  286. const(void)* pNext ;
  287. VkWaylandSurfaceCreateFlagsKHR flags ;
  288. wl_display* display;
  289. wl_surface* surface;
  290. }
  291. alias PFN_vkCreateWaylandSurfaceKHR = nothrow
  292. VkResult function( VkInstance instance
  293. , const(VkWaylandSurfaceCreateInfoKHR)* pCreateInfo
  294. , const(VkAllocationCallbacks)* pAllocator
  295. , VkSurfaceKHR* pSurface );
  296. alias PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR = nothrow
  297. VkBool32 function( VkPhysicalDevice physicalDevice
  298. , uint queueFamilyIndex
  299. , wl_display* display );
  300. mixin template Functions() {
  301. PFN_vkCreateWaylandSurfaceKHR vkCreateWaylandSurfaceKHR;
  302. PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR vkGetPhysicalDeviceWaylandPresentationSupportKHR;
  303. pragma(inline, true)
  304. void bindFunctions(alias bind)() {
  305. bind(cast(void**)&vkCreateWaylandSurfaceKHR, "vkCreateWaylandSurfaceKHR");
  306. bind( cast(void**)&vkGetPhysicalDeviceWaylandPresentationSupportKHR
  307. , "vkGetPhysicalDeviceWaylandPresentationSupportKHR" );
  308. }
  309. }
  310. version (none) {
  311. VkResult vkCreateWaylandSurfaceKHR( VkInstance instance
  312. , const(VkWaylandSurfaceCreateInfoKHR)* pCreateInfo
  313. , const(VkAllocationCallbacks)* pAllocator
  314. , VkSurfaceKHR* pSurface );
  315. VkBool32 vkGetPhysicalDeviceWaylandPresentationSupportKHR( VkPhysicalDevice physicalDevice
  316. , uint queueFamilyIndex
  317. , wl_display* display );
  318. }
  319. }