From a7538ee986aecfc546707442d6d86e58666dd3d8 Mon Sep 17 00:00:00 2001 From: Marijn Suijten Date: Mon, 19 Dec 2022 19:17:48 +0100 Subject: [PATCH] Replace `<>` in documentation with link to `ref` (#693) Rustdoc since 1.66 points out that `<>` is malformed HTML, and the resulting `<>` isn't very helpful to users. Convert it to the relevant link in both documentation and `Result` `Display` to solve both issues at once. --- ash/src/vk/enums.rs | 37 ++----------------------------------- generator/src/lib.rs | 18 +++++++++++++----- 2 files changed, 15 insertions(+), 40 deletions(-) diff --git a/ash/src/vk/enums.rs b/ash/src/vk/enums.rs index 40c534d..3113805 100644 --- a/ash/src/vk/enums.rs +++ b/ash/src/vk/enums.rs @@ -966,7 +966,7 @@ impl Result { pub const ERROR_OUT_OF_DEVICE_MEMORY: Self = Self(-2); #[doc = "Initialization of an object has failed"] pub const ERROR_INITIALIZATION_FAILED: Self = Self(-3); - #[doc = "The logical device has been lost. See <>"] + #[doc = "The logical device has been lost. See "] pub const ERROR_DEVICE_LOST: Self = Self(-4); #[doc = "Mapping of a memory object has failed"] pub const ERROR_MEMORY_MAP_FAILED: Self = Self(-5); @@ -990,40 +990,7 @@ impl Result { impl ::std::error::Error for Result {} impl fmt::Display for Result { fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result { - let name = match *self { - Self::SUCCESS => Some("Command completed successfully"), - Self::NOT_READY => Some("A fence or query has not yet completed"), - Self::TIMEOUT => Some("A wait operation has not completed in the specified time"), - Self::EVENT_SET => Some("An event is signaled"), - Self::EVENT_RESET => Some("An event is unsignaled"), - Self::INCOMPLETE => Some("A return array was too small for the result"), - Self::ERROR_OUT_OF_HOST_MEMORY => Some("A host memory allocation has failed"), - Self::ERROR_OUT_OF_DEVICE_MEMORY => Some("A device memory allocation has failed"), - Self::ERROR_INITIALIZATION_FAILED => Some("Initialization of an object has failed"), - Self::ERROR_DEVICE_LOST => { - Some("The logical device has been lost. See <>") - } - Self::ERROR_MEMORY_MAP_FAILED => Some("Mapping of a memory object has failed"), - Self::ERROR_LAYER_NOT_PRESENT => Some("Layer specified does not exist"), - Self::ERROR_EXTENSION_NOT_PRESENT => Some("Extension specified does not exist"), - Self::ERROR_FEATURE_NOT_PRESENT => { - Some("Requested feature is not available on this device") - } - Self::ERROR_INCOMPATIBLE_DRIVER => Some("Unable to find a Vulkan driver"), - Self::ERROR_TOO_MANY_OBJECTS => { - Some("Too many objects of the type have already been created") - } - Self::ERROR_FORMAT_NOT_SUPPORTED => { - Some("Requested format is not supported on this device") - } - Self::ERROR_FRAGMENTED_POOL => Some( - "A requested pool allocation has failed due to fragmentation of the pool's memory", - ), - Self::ERROR_UNKNOWN => { - Some("An unknown error has occurred, due to an implementation or application bug") - } - _ => None, - }; + let name = match * self { Self :: SUCCESS => Some ("Command completed successfully") , Self :: NOT_READY => Some ("A fence or query has not yet completed") , Self :: TIMEOUT => Some ("A wait operation has not completed in the specified time") , Self :: EVENT_SET => Some ("An event is signaled") , Self :: EVENT_RESET => Some ("An event is unsignaled") , Self :: INCOMPLETE => Some ("A return array was too small for the result") , Self :: ERROR_OUT_OF_HOST_MEMORY => Some ("A host memory allocation has failed") , Self :: ERROR_OUT_OF_DEVICE_MEMORY => Some ("A device memory allocation has failed") , Self :: ERROR_INITIALIZATION_FAILED => Some ("Initialization of an object has failed") , Self :: ERROR_DEVICE_LOST => Some ("The logical device has been lost. See ") , Self :: ERROR_MEMORY_MAP_FAILED => Some ("Mapping of a memory object has failed") , Self :: ERROR_LAYER_NOT_PRESENT => Some ("Layer specified does not exist") , Self :: ERROR_EXTENSION_NOT_PRESENT => Some ("Extension specified does not exist") , Self :: ERROR_FEATURE_NOT_PRESENT => Some ("Requested feature is not available on this device") , Self :: ERROR_INCOMPATIBLE_DRIVER => Some ("Unable to find a Vulkan driver") , Self :: ERROR_TOO_MANY_OBJECTS => Some ("Too many objects of the type have already been created") , Self :: ERROR_FORMAT_NOT_SUPPORTED => Some ("Requested format is not supported on this device") , Self :: ERROR_FRAGMENTED_POOL => Some ("A requested pool allocation has failed due to fragmentation of the pool's memory") , Self :: ERROR_UNKNOWN => Some ("An unknown error has occurred, due to an implementation or application bug") , _ => None , } ; if let Some(x) = name { fmt.write_str(x) } else { diff --git a/generator/src/lib.rs b/generator/src/lib.rs index 04cdd67..fcf98f4 100644 --- a/generator/src/lib.rs +++ b/generator/src/lib.rs @@ -19,6 +19,7 @@ use proc_macro2::{Delimiter, Group, Literal, Span, TokenStream, TokenTree}; use quote::*; use regex::Regex; use std::{ + borrow::Cow, collections::{BTreeMap, HashMap, HashSet}, fmt::Display, path::Path, @@ -196,6 +197,15 @@ pub trait ConstantExt { fn constant(&self, enum_name: &str) -> Constant; fn variant_ident(&self, enum_name: &str) -> Ident; fn notation(&self) -> Option<&str>; + fn formatted_notation(&self) -> Option> { + static DOC_LINK: Lazy = Lazy::new(|| Regex::new(r#"<<([\w-]+)>>"#).unwrap()); + self.notation().map(|n| { + DOC_LINK.replace( + n, + "", + ) + }) + } fn is_alias(&self) -> bool { false } @@ -205,10 +215,8 @@ pub trait ConstantExt { Some(BACKWARDS_COMPATIBLE_ALIAS_COMMENT), "Backwards-compatible constants should not be emitted" ); - match self.notation() { - Some(n) if n.starts_with("Alias") => { - quote!(#[deprecated = #n]) - } + match self.formatted_notation() { + Some(n) if n.starts_with("Alias") => quote!(#[deprecated = #n]), Some(n) => quote!(#[doc = #n]), None => quote!(), } @@ -1402,7 +1410,7 @@ pub fn generate_result(ident: Ident, enum_: &vk_parse::Enums) -> TokenStream { let (variant_name, notation) = match *elem { vk_parse::EnumsChild::Enum(ref constant) => ( constant.name.as_str(), - constant.comment.as_deref().unwrap_or(""), + constant.formatted_notation().unwrap_or(Cow::Borrowed("")), ), _ => { return None;