Update VulkanHeaders to 1.1.117 (#222)

* Update VulkanHeaders to 1.1.117

* Mark Ggp definitions as experimental

* Fix is_version

* Switch to 1.1.117
This commit is contained in:
Maik Klein 2019-10-20 18:11:13 +02:00 committed by GitHub
parent 1637ed4bf4
commit e67df2650a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 6985 additions and 667 deletions

File diff suppressed because it is too large Load diff

@ -1 +1 @@
Subproject commit c200cb25db0f47364d3318d92c1d8e9dfff2fef1
Subproject commit fd568d51ed3d9bc6132e1639d7492453a08fe1bc

View file

@ -355,6 +355,7 @@ pub fn platform_specific_types() -> Tokens {
#[allow(non_camel_case_types)]
pub type wl_surface = c_void;
pub type HANDLE = *mut c_void;
pub type HMONITOR = HANDLE;
pub type DWORD = c_ulong;
pub type LPCWSTR = *const u16;
#[allow(non_camel_case_types)]
@ -367,6 +368,11 @@ pub fn platform_specific_types() -> Tokens {
// Opage types
pub type ANativeWindow = c_void;
pub type AHardwareBuffer = c_void;
/// This definition is experimental and won't adhere to semver rules.
pub type GgpStreamDescriptor = u32;
/// This definition is experimental and won't adhere to semver rules.
pub type GgpFrameToken = u32;
pub type CAMetalLayer = c_void;
}
}
#[derive(Debug, Copy, Clone)]
@ -527,7 +533,7 @@ pub trait FeatureExt {
impl FeatureExt for vkxml::Feature {
fn is_version(&self, major: u32, minor: u32) -> bool {
let self_major = self.version as u32;
let self_minor = (self.version * 10.0) as u32 - self_major;
let self_minor = (self.version * 10.0) as u32 - self_major * 10;
major == self_major && self_minor == minor
}
fn version_string(&self) -> String {
@ -718,6 +724,19 @@ fn generate_function_pointers<'a>(
commands: &[&'a vkxml::Command],
fn_cache: &mut HashSet<&'a str, impl BuildHasher>,
) -> quote::Tokens {
// We filter commands so that we don't have duplicates
let commands: Vec<_> = commands
.iter()
.filter(|cmd| {
let ident = cmd.name.as_str();
if !fn_cache.contains(ident) {
fn_cache.insert(ident);
true
} else {
false
}
})
.collect();
let names: Vec<_> = commands.iter().map(|cmd| cmd.command_ident()).collect();
let names_ref = &names;
let names_ref1 = &names;
@ -732,19 +751,6 @@ fn generate_function_pointers<'a>(
let names_right = &names;
let khronos_links: Vec<_> = raw_names.iter().map(|name| khronos_link(name)).collect();
let pfn_commands: Vec<_> = commands
.iter()
.filter(|cmd| {
let ident = cmd.name.as_str();
if !fn_cache.contains(ident) {
fn_cache.insert(ident);
true
} else {
false
}
})
.collect();
let params: Vec<Vec<(Ident, Tokens)>> = commands
.iter()
.map(|cmd| {
@ -802,13 +808,13 @@ fn generate_function_pointers<'a>(
.collect();
let return_types_ref = &return_types;
let pfn_names: Vec<_> = pfn_commands
let pfn_names: Vec<_> = commands
.iter()
.map(|cmd| Ident::from(format!("PFN_{}", cmd.name.as_str())))
.collect();
let pfn_names_ref = &pfn_names;
let signature_params: Vec<Vec<_>> = pfn_commands
let signature_params: Vec<Vec<_>> = commands
.iter()
.map(|cmd| {
let params: Vec<_> = cmd
@ -825,7 +831,7 @@ fn generate_function_pointers<'a>(
.collect();
let signature_params_ref = &signature_params;
let pfn_return_types: Vec<_> = pfn_commands
let pfn_return_types: Vec<_> = commands
.iter()
.map(|cmd| cmd.return_type.type_tokens(true))
.collect();
@ -1292,7 +1298,7 @@ pub fn derive_default(_struct: &vkxml::Struct) -> Option<Tokens> {
// This are also pointers, and therefor also don't implement Default. The spec
// also doesn't mark them as pointers
let handles = ["LPCWSTR", "HANDLE", "HINSTANCE", "HWND"];
let handles = ["LPCWSTR", "HANDLE", "HINSTANCE", "HWND", "HMONITOR"];
let contains_ptr = members.clone().any(|field| field.reference.is_some());
let contains_strucutre_type = members.clone().any(is_structure_type);
let contains_static_array = members.clone().any(is_static_array);