in Rust.
An intrusive structure is a general-purpose structure directly embedded within a containing structure, in order to add that general-purpose facility to the container. As an example, one might use an intrusive "link" structure to allow objects to be organized in a linked-list:
```rust struct Link { next: Option, } struct List { head: Option, tail: Option, }
struct Container { link: Link, } ```
While this module does not provide a linked-list implementation (for separation-of-concerns reasons, I believe a linked-list implementation belongs in a separate crate), it does provide some necessary abstractions for using intrusive structures:
field_offset!
macro, which identifies the location of a field
in a containing structure. This isn't too useful in itself, but is
necessary to support:intrusive!
macro, which provides a newtype for using
"intrusive" fields to work with the container object.```rust
extern crate "intrusive";
struct Link {
next: Option,
}
// FIXME: is this legal? want to enforce constraint that List
only
// operates against intrusive Link
s.
struct
struct Container { link: Link, } intrusive!(ContainerLink = Container:link::Link);
fn create() -> List
git checkout -b my-new-feature
)git commit -am 'Add some feature'
)git push origin my-new-feature
)