Vulkan: Add support for extensions

Former-commit-id: ab5742edc79815dd75473bf467c7b1dd46e2fecb
This commit is contained in:
Lynix
2016-04-28 20:37:30 +02:00
parent da401af52c
commit e1d424e5f9
3 changed files with 223 additions and 0 deletions

View File

@@ -20,6 +20,33 @@ namespace Nz
Destroy();
}
inline bool Instance::Create(const String& appName, UInt32 appVersion, const String& engineName, UInt32 engineVersion, const std::vector<const char*>& layers, const std::vector<const char*>& extensions, const VkAllocationCallbacks* allocator)
{
VkApplicationInfo appInfo =
{
VK_STRUCTURE_TYPE_APPLICATION_INFO,
nullptr,
appName.GetConstBuffer(),
appVersion,
engineName.GetConstBuffer(),
engineVersion
};
VkInstanceCreateInfo instanceInfo =
{
VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO,
nullptr,
0,
&appInfo,
static_cast<UInt32>(layers.size()),
&layers[0],
static_cast<UInt32>(extensions.size()),
&extensions[0]
};
return Create(instanceInfo, allocator);
}
inline void Instance::Destroy()
{
if (m_instance)
@@ -40,6 +67,21 @@ namespace Nz
return m_lastErrorCode;
}
inline bool Instance::IsExtensionLoaded(const String& extensionName)
{
return m_loadedExtensions.count(extensionName) != 0;
}
inline bool Instance::IsLayerLoaded(const String& layerName)
{
return m_loadedLayers.count(layerName) != 0;
}
inline Instance::operator VkInstance()
{
return m_instance;
}
inline void Instance::GetPhysicalDeviceFeatures(VkPhysicalDevice device, VkPhysicalDeviceFeatures* features)
{
return vkGetPhysicalDeviceFeatures(device, features);