Add some documentation to push_next

This commit is contained in:
Maik Klein 2019-02-27 11:10:38 +01:00
parent c66ae6b77e
commit 1e13b999d7
2 changed files with 7862 additions and 7050 deletions

File diff suppressed because it is too large Load diff

View file

@ -1594,7 +1594,11 @@ pub fn derive_setters(
// We only implement a next methods for root create infos // We only implement a next methods for root create infos
let next_function = if has_next && next_extends.is_none() { let next_function = if has_next && next_extends.is_none() {
quote! { quote! {
/// Prepend /// Prepends the given extension struct between the root and the first pointer. This
/// method only exists on create infos that can be passed to a function directly. Only
/// valid extension structs can be pushed into the chain.
/// If the chain looks like `A -> B -> C`, and you call `builder.push_next(&mut D)`, then the
/// chain will look like `A -> D -> B -> C`.
pub fn push_next<T: #extends_name>(mut self, next: &'a mut T) -> #name_builder<'a> { pub fn push_next<T: #extends_name>(mut self, next: &'a mut T) -> #name_builder<'a> {
unsafe{ unsafe{
let next_ptr = next.as_ptr_mut(); let next_ptr = next.as_ptr_mut();