Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Can you use a const value in docs in Rust?

Can you use a const's value in documentation in rust? Something like string interpolation to insert a value:

const EXPIRATION_TIME_IN_MINUTES: i64 = 60*24;

/// A struct that does something
/// Whatever this struct does, it expires in ${EXPIRATION_TIME_IN_MINUTES} minutes. 
struct SomeStruct {
   ...
}

The proposed use case is exactly this, documenting what the default setting for expiration for a function.

like image 290
kingledion Avatar asked Oct 23 '25 16:10

kingledion


2 Answers

Typical documentation that references a constant would do it by adding documentation in two places and linking them together:

/// The expiration time used for instances of `SomeStruct`, in minutes.
const EXPIRATION_TIME_IN_MINUTES: i64 = 60 * 24;

/// A struct that does something. The expiration associated with this struct 
/// is given by the constant [`EXPIRATION_TIME_IN_MINUTES`].
struct SomeStruct {
   ...
}

Even though the value of the constant will not appear inline, using [``] will create a hyperlink to the docs for the constant so a user can see the value there.

like image 110
Peter Hall Avatar answered Oct 26 '25 07:10

Peter Hall


No. I think rustdoc does not even perform const evaluation.

For documenting the default value, if it is really long, you can create a macro that expands to it and use it in documentation comments. It works like:

macro_rules! default_value {
    () => { 1440 };
}

const EXPIRATION_TIME_IN_MINUTES: i64 = default_value!();

/// A struct that does something
#[doc = concat!(" Whatever this struct does, it expires in ", default_value!(), " minutes.")]
struct SomeStruct {
}

The /// comment expands to #[doc = "..."] (//! comments expand to #![doc = "..."]). However, you cannot place expressions there, only literals, so it may not help you.

like image 38
Chayim Friedman Avatar answered Oct 26 '25 06:10

Chayim Friedman



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!