Skip to content

Simply increase the alignment of any statics or include_bytes!

License

Notifications You must be signed in to change notification settings

CasualX/align_data

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Align Data

MIT License crates.io docs.rs

Simply increase the alignment of any statics or include_bytes!.

Examples

When including raw data through include_bytes! it is often used to directly interpret as structured data however it does not align the included bytes according to the structured data's alignment.

This crate fixes this oversight:

use align_data::{include_aligned, Align4K};

static ALIGNED: &[u8] = include_aligned!(Align4K, "lib.rs");
assert_eq!(ALIGNED.as_ptr() as usize % 0x1000, 0);

The value of any constant expression can be forced to the given alignment:

use align_data::{aligned, Align16};

let five = aligned!(Align16, i32, 5);
assert_eq!(five as *const _ as usize % 0x10, 0);

License

Licensed under MIT License, see license.txt.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, shall be licensed as above, without any additional terms or conditions.

About

Simply increase the alignment of any statics or include_bytes!

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages