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 itertools::Itertools;
|
||||
use proc_macro2::Term;
|
||||
use proc_macro2::{Literal, Term};
|
||||
use quote::Tokens;
|
||||
use std::collections::{BTreeMap, HashMap, HashSet};
|
||||
use std::path::Path;
|
||||
|
@ -85,13 +85,30 @@ named!(cfloat<&str, f32>,
|
|||
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 {
|
||||
quote! {
|
||||
#[macro_export]
|
||||
macro_rules! define_handle{
|
||||
($name: ident, $ty: ident) => {
|
||||
($name: ident, $ty: ident, $doc_link: meta) => {
|
||||
#[repr(transparent)]
|
||||
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Hash)]
|
||||
#[$doc_link]
|
||||
pub struct $name(*mut u8);
|
||||
impl Default for $name {
|
||||
fn default() -> $name {
|
||||
|
@ -135,8 +152,12 @@ pub fn handle_nondispatchable_macro() -> Tokens {
|
|||
#[macro_export]
|
||||
macro_rules! handle_nondispatchable {
|
||||
($name: ident, $ty: ident) => {
|
||||
handle_nondispatchable!($name, $ty, doc = "");
|
||||
};
|
||||
($name: ident, $ty: ident, $doc_link: meta) => {
|
||||
#[repr(transparent)]
|
||||
#[derive(Eq, PartialEq, Ord, PartialOrd, Clone, Copy, Hash, Default)]
|
||||
#[$doc_link]
|
||||
pub struct $name(u64);
|
||||
|
||||
impl Handle for $name {
|
||||
|
@ -700,6 +721,11 @@ fn generate_function_pointers<'a>(
|
|||
let raw_names_ref = &raw_names;
|
||||
let names_left = &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
|
||||
.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 {
|
||||
(self.#names_left)(#(#param_names_ref,)*)
|
||||
}
|
||||
|
@ -1005,7 +1032,9 @@ pub fn generate_extension<'a>(
|
|||
pub fn generate_typedef(typedef: &vkxml::Typedef) -> Tokens {
|
||||
let typedef_name = to_type_tokens(&typedef.name, None);
|
||||
let typedef_ty = to_type_tokens(&typedef.basetype, None);
|
||||
let khronos_link = khronos_link!(typedef.name);
|
||||
quote! {
|
||||
#[doc = #khronos_link]
|
||||
pub type #typedef_name = #typedef_ty;
|
||||
}
|
||||
}
|
||||
|
@ -1028,9 +1057,11 @@ pub fn generate_bitmask(
|
|||
return None;
|
||||
};
|
||||
bitflags_cache.insert(ident.clone());
|
||||
let khronos_link = khronos_link!(bitmask.name);
|
||||
Some(quote! {
|
||||
#[repr(transparent)]
|
||||
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||
#[doc = #khronos_link]
|
||||
pub struct #ident(Flags);
|
||||
vk_bitflags_wrapped!(#ident, 0b0, Flags);
|
||||
})
|
||||
|
@ -1134,6 +1165,8 @@ pub fn generate_enum<'a>(
|
|||
values.push(constant.variant_ident(&_enum.name));
|
||||
}
|
||||
|
||||
let khronos_link = khronos_link!(_enum.name);
|
||||
|
||||
if name.contains("Bit") {
|
||||
let ident = Ident::from(_name.as_str());
|
||||
let all_bits = constants
|
||||
|
@ -1150,6 +1183,7 @@ pub fn generate_enum<'a>(
|
|||
let q = quote! {
|
||||
#[repr(transparent)]
|
||||
#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||
#[doc = #khronos_link]
|
||||
pub struct #ident(pub(crate) Flags);
|
||||
vk_bitflags_wrapped!(#ident, #all_bits_term, Flags);
|
||||
#impl_bitflags
|
||||
|
@ -1161,6 +1195,7 @@ pub fn generate_enum<'a>(
|
|||
let enum_quote = quote! {
|
||||
#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Default)]
|
||||
#[repr(transparent)]
|
||||
#[doc = #khronos_link]
|
||||
pub struct #ident(pub(crate) i32);
|
||||
impl #ident {
|
||||
pub fn from_raw(x: i32) -> Self { #ident(x) }
|
||||
|
@ -1745,9 +1780,11 @@ pub fn generate_struct(
|
|||
} else {
|
||||
quote!()
|
||||
};
|
||||
let khronos_link = khronos_link!(_struct.name);
|
||||
quote! {
|
||||
#[repr(C)]
|
||||
#[derive(Copy, Clone, #default_str #dbg_str #manual_derive_tokens)]
|
||||
#[doc = #khronos_link]
|
||||
pub struct #name {
|
||||
#(#params,)*
|
||||
}
|
||||
|
@ -1761,13 +1798,14 @@ pub fn generate_handle(handle: &vkxml::Handle) -> Option<Tokens> {
|
|||
if handle.name == "" {
|
||||
return None;
|
||||
}
|
||||
let khronos_link = khronos_link!(handle.name);
|
||||
let tokens = match handle.ty {
|
||||
vkxml::HandleType::Dispatch => {
|
||||
let name = &handle.name[2..];
|
||||
let ty = Ident::from(name.to_shouty_snake_case());
|
||||
let name = Ident::from(name);
|
||||
quote! {
|
||||
define_handle!(#name, #ty);
|
||||
define_handle!(#name, #ty, doc = #khronos_link);
|
||||
}
|
||||
}
|
||||
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 name = Ident::from(name);
|
||||
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
|
||||
}
|
||||
});
|
||||
let khronos_link = khronos_link!(fnptr.name);
|
||||
quote! {
|
||||
#[allow(non_camel_case_types)]
|
||||
#[doc = #khronos_link]
|
||||
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
|
||||
}
|
||||
});
|
||||
let khronos_link = khronos_link!(union.name);
|
||||
quote! {
|
||||
#[repr(C)]
|
||||
#[derive(Copy, Clone)]
|
||||
#[doc = #khronos_link]
|
||||
pub union #name {
|
||||
#(#fields),*
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue