Generate doc links for all structs and functions
This commit is contained in:
parent
57859ba79d
commit
7555816b58
2 changed files with 1094 additions and 42 deletions
1086
ash/src/vk.rs
1086
ash/src/vk.rs
File diff suppressed because it is too large
Load diff
|
@ -12,7 +12,7 @@ pub extern crate vkxml;
|
||||||
|
|
||||||
use heck::{CamelCase, ShoutySnakeCase, SnakeCase};
|
use heck::{CamelCase, ShoutySnakeCase, SnakeCase};
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
use proc_macro2::Term;
|
use proc_macro2::{Literal, Term};
|
||||||
use quote::Tokens;
|
use quote::Tokens;
|
||||||
use std::collections::{BTreeMap, HashMap, HashSet};
|
use std::collections::{BTreeMap, HashMap, HashSet};
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
@ -85,13 +85,30 @@ named!(cfloat<&str, f32>,
|
||||||
terminated!(nom::float_s, char!('f'))
|
terminated!(nom::float_s, char!('f'))
|
||||||
);
|
);
|
||||||
|
|
||||||
|
macro_rules! khronos_link (
|
||||||
|
($name:expr) => {
|
||||||
|
Literal::string(&format!("<https://www.khronos.org/registry/vulkan/specs/1.1-extensions/man/html/{name}.html>", name=$name))
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
pub fn define_khronos_link_macro() -> Tokens {
|
||||||
|
quote! {
|
||||||
|
macro_rules! khronos_link (
|
||||||
|
($name:expr) => {
|
||||||
|
Literal::string(&format!("<https://www.khronos.org/registry/vulkan/specs/1.1-extensions/man/html/{name}.html>", name=$name))
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn define_handle_macro() -> Tokens {
|
pub fn define_handle_macro() -> Tokens {
|
||||||
quote! {
|
quote! {
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
macro_rules! define_handle{
|
macro_rules! define_handle{
|
||||||
($name: ident, $ty: ident) => {
|
($name: ident, $ty: ident, $doc_link: meta) => {
|
||||||
#[repr(transparent)]
|
#[repr(transparent)]
|
||||||
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Hash)]
|
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Hash)]
|
||||||
|
#[$doc_link]
|
||||||
pub struct $name(*mut u8);
|
pub struct $name(*mut u8);
|
||||||
impl Default for $name {
|
impl Default for $name {
|
||||||
fn default() -> $name {
|
fn default() -> $name {
|
||||||
|
@ -135,8 +152,12 @@ pub fn handle_nondispatchable_macro() -> Tokens {
|
||||||
#[macro_export]
|
#[macro_export]
|
||||||
macro_rules! handle_nondispatchable {
|
macro_rules! handle_nondispatchable {
|
||||||
($name: ident, $ty: ident) => {
|
($name: ident, $ty: ident) => {
|
||||||
|
handle_nondispatchable!($name, $ty, doc = "");
|
||||||
|
};
|
||||||
|
($name: ident, $ty: ident, $doc_link: meta) => {
|
||||||
#[repr(transparent)]
|
#[repr(transparent)]
|
||||||
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Hash, Default)]
|
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Hash, Default)]
|
||||||
|
#[$doc_link]
|
||||||
pub struct $name(u64);
|
pub struct $name(u64);
|
||||||
|
|
||||||
impl Handle for $name {
|
impl Handle for $name {
|
||||||
|
@ -700,6 +721,11 @@ fn generate_function_pointers<'a>(
|
||||||
let raw_names_ref = &raw_names;
|
let raw_names_ref = &raw_names;
|
||||||
let names_left = &names;
|
let names_left = &names;
|
||||||
let names_right = &names;
|
let names_right = &names;
|
||||||
|
let khronos_links: Vec<_> = raw_names.iter().map(|name| khronos_link!(name)).collect();
|
||||||
|
|
||||||
|
for (name, link) in names.iter().zip(khronos_links.iter()) {
|
||||||
|
println!("{} {}", name, link);
|
||||||
|
}
|
||||||
|
|
||||||
let pfn_commands: Vec<_> = commands
|
let pfn_commands: Vec<_> = commands
|
||||||
.iter()
|
.iter()
|
||||||
|
@ -847,6 +873,7 @@ fn generate_function_pointers<'a>(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#(
|
#(
|
||||||
|
#[doc = #khronos_links]
|
||||||
pub unsafe fn #names_ref(&self, #expanded_params_ref) -> #return_types_ref {
|
pub unsafe fn #names_ref(&self, #expanded_params_ref) -> #return_types_ref {
|
||||||
(self.#names_left)(#(#param_names_ref,)*)
|
(self.#names_left)(#(#param_names_ref,)*)
|
||||||
}
|
}
|
||||||
|
@ -1005,7 +1032,9 @@ pub fn generate_extension<'a>(
|
||||||
pub fn generate_typedef(typedef: &vkxml::Typedef) -> Tokens {
|
pub fn generate_typedef(typedef: &vkxml::Typedef) -> Tokens {
|
||||||
let typedef_name = to_type_tokens(&typedef.name, None);
|
let typedef_name = to_type_tokens(&typedef.name, None);
|
||||||
let typedef_ty = to_type_tokens(&typedef.basetype, None);
|
let typedef_ty = to_type_tokens(&typedef.basetype, None);
|
||||||
|
let khronos_link = khronos_link!(typedef.name);
|
||||||
quote! {
|
quote! {
|
||||||
|
#[doc = #khronos_link]
|
||||||
pub type #typedef_name = #typedef_ty;
|
pub type #typedef_name = #typedef_ty;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1028,9 +1057,11 @@ pub fn generate_bitmask(
|
||||||
return None;
|
return None;
|
||||||
};
|
};
|
||||||
bitflags_cache.insert(ident.clone());
|
bitflags_cache.insert(ident.clone());
|
||||||
|
let khronos_link = khronos_link!(bitmask.name);
|
||||||
Some(quote! {
|
Some(quote! {
|
||||||
#[repr(transparent)]
|
#[repr(transparent)]
|
||||||
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
|
#[doc = #khronos_link]
|
||||||
pub struct #ident(Flags);
|
pub struct #ident(Flags);
|
||||||
vk_bitflags_wrapped!(#ident, 0b0, Flags);
|
vk_bitflags_wrapped!(#ident, 0b0, Flags);
|
||||||
})
|
})
|
||||||
|
@ -1134,6 +1165,8 @@ pub fn generate_enum<'a>(
|
||||||
values.push(constant.variant_ident(&_enum.name));
|
values.push(constant.variant_ident(&_enum.name));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let khronos_link = khronos_link!(_enum.name);
|
||||||
|
|
||||||
if name.contains("Bit") {
|
if name.contains("Bit") {
|
||||||
let ident = Ident::from(_name.as_str());
|
let ident = Ident::from(_name.as_str());
|
||||||
let all_bits = constants
|
let all_bits = constants
|
||||||
|
@ -1150,6 +1183,7 @@ pub fn generate_enum<'a>(
|
||||||
let q = quote! {
|
let q = quote! {
|
||||||
#[repr(transparent)]
|
#[repr(transparent)]
|
||||||
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
|
#[doc = #khronos_link]
|
||||||
pub struct #ident(pub(crate) Flags);
|
pub struct #ident(pub(crate) Flags);
|
||||||
vk_bitflags_wrapped!(#ident, #all_bits_term, Flags);
|
vk_bitflags_wrapped!(#ident, #all_bits_term, Flags);
|
||||||
#impl_bitflags
|
#impl_bitflags
|
||||||
|
@ -1161,6 +1195,7 @@ pub fn generate_enum<'a>(
|
||||||
let enum_quote = quote! {
|
let enum_quote = quote! {
|
||||||
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Default)]
|
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Default)]
|
||||||
#[repr(transparent)]
|
#[repr(transparent)]
|
||||||
|
#[doc = #khronos_link]
|
||||||
pub struct #ident(pub(crate) i32);
|
pub struct #ident(pub(crate) i32);
|
||||||
impl #ident {
|
impl #ident {
|
||||||
pub fn from_raw(x: i32) -> Self { #ident(x) }
|
pub fn from_raw(x: i32) -> Self { #ident(x) }
|
||||||
|
@ -1745,9 +1780,11 @@ pub fn generate_struct(
|
||||||
} else {
|
} else {
|
||||||
quote!()
|
quote!()
|
||||||
};
|
};
|
||||||
|
let khronos_link = khronos_link!(_struct.name);
|
||||||
quote! {
|
quote! {
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
#[derive(Copy, Clone, #default_str #dbg_str #manual_derive_tokens)]
|
#[derive(Copy, Clone, #default_str #dbg_str #manual_derive_tokens)]
|
||||||
|
#[doc = #khronos_link]
|
||||||
pub struct #name {
|
pub struct #name {
|
||||||
#(#params,)*
|
#(#params,)*
|
||||||
}
|
}
|
||||||
|
@ -1761,13 +1798,14 @@ pub fn generate_handle(handle: &vkxml::Handle) -> Option<Tokens> {
|
||||||
if handle.name == "" {
|
if handle.name == "" {
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
|
let khronos_link = khronos_link!(handle.name);
|
||||||
let tokens = match handle.ty {
|
let tokens = match handle.ty {
|
||||||
vkxml::HandleType::Dispatch => {
|
vkxml::HandleType::Dispatch => {
|
||||||
let name = &handle.name[2..];
|
let name = &handle.name[2..];
|
||||||
let ty = Ident::from(name.to_shouty_snake_case());
|
let ty = Ident::from(name.to_shouty_snake_case());
|
||||||
let name = Ident::from(name);
|
let name = Ident::from(name);
|
||||||
quote! {
|
quote! {
|
||||||
define_handle!(#name, #ty);
|
define_handle!(#name, #ty, doc = #khronos_link);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
vkxml::HandleType::NoDispatch => {
|
vkxml::HandleType::NoDispatch => {
|
||||||
|
@ -1775,7 +1813,7 @@ pub fn generate_handle(handle: &vkxml::Handle) -> Option<Tokens> {
|
||||||
let ty = Ident::from(name.to_shouty_snake_case());
|
let ty = Ident::from(name.to_shouty_snake_case());
|
||||||
let name = Ident::from(name);
|
let name = Ident::from(name);
|
||||||
quote! {
|
quote! {
|
||||||
handle_nondispatchable!(#name, #ty);
|
handle_nondispatchable!(#name, #ty, doc = #khronos_link);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -1791,8 +1829,10 @@ fn generate_funcptr(fnptr: &vkxml::FunctionPointer) -> Tokens {
|
||||||
#ident: #type_tokens
|
#ident: #type_tokens
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
let khronos_link = khronos_link!(fnptr.name);
|
||||||
quote! {
|
quote! {
|
||||||
#[allow(non_camel_case_types)]
|
#[allow(non_camel_case_types)]
|
||||||
|
#[doc = #khronos_link]
|
||||||
pub type #name = Option<unsafe extern "system" fn(#(#params),*) -> #ret_ty_tokens>;
|
pub type #name = Option<unsafe extern "system" fn(#(#params),*) -> #ret_ty_tokens>;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1806,9 +1846,11 @@ fn generate_union(union: &vkxml::Union) -> Tokens {
|
||||||
pub #name: #ty
|
pub #name: #ty
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
let khronos_link = khronos_link!(union.name);
|
||||||
quote! {
|
quote! {
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
#[derive(Copy, Clone)]
|
#[derive(Copy, Clone)]
|
||||||
|
#[doc = #khronos_link]
|
||||||
pub union #name {
|
pub union #name {
|
||||||
#(#fields),*
|
#(#fields),*
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue