final release preparations
This commit is contained in:
		
							
								
								
									
										1
									
								
								examples/src/lib.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								examples/src/lib.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
|  | ||||
							
								
								
									
										22
									
								
								libcsp-cargo-build/release-checklist.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								libcsp-cargo-build/release-checklist.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| Checklist for new releases | ||||
| ======= | ||||
|  | ||||
| # Pre-Release | ||||
|  | ||||
| 1. Make sure any new modules are documented sufficiently enough and check docs with | ||||
|    `cargo +nightly doc --all-features --config 'build.rustdocflags=["--cfg", "docs_rs"]' --open`. | ||||
| 2. Bump version specifier in `Cargo.toml`. | ||||
| 3. Update `CHANGELOG.md`: Convert `unreleased` section into version section with date and add new | ||||
|    `unreleased` section. | ||||
| 4. Run `cargo test --all-features` or `cargo nextest r --all-features`. | ||||
| 5. Run `cargo fmt` and `cargo clippy`. | ||||
| 6. Wait for CI/CD results for EGit and Github. These also check cross-compilation for bare-metal | ||||
|    targets. | ||||
|  | ||||
| # Release | ||||
|  | ||||
| 1. `cargo publish` | ||||
|  | ||||
| # Post-Release | ||||
|  | ||||
| 1. Create a new release on `EGit` based on the release branch. | ||||
| @@ -14,3 +14,6 @@ links = "csp" | ||||
|  | ||||
| [dependencies] | ||||
| libc = "0.2" | ||||
|  | ||||
| [package.metadata.docs.rs] | ||||
| rustdoc-args = ["--cfg", "docs_rs"] | ||||
|   | ||||
| @@ -19,3 +19,17 @@ The user has to provide the path to a directory containing this `autoconfig.rs` | ||||
| It is recommended to read the [main workspace README](https://egit.irs.uni-stuttgart.de/rust/libcsp-rust) | ||||
| for more information to make the generation and specification of this auto-configuration file | ||||
| as conveniently and easy as possible. | ||||
|  | ||||
| ## Run unittests | ||||
|  | ||||
| Running unittests required the `RUN_TESTS` environmental variable to be set to 1. This is because | ||||
| the actual `libcsp` library might be built and linked in a separate crate, so the linker is not | ||||
| able to process `-l csp` when running the tests. | ||||
|  | ||||
| You can use | ||||
|  | ||||
| ```sh | ||||
| RUN_TESTS=1 cargo test | ||||
| ``` | ||||
|  | ||||
| to run the unittests. | ||||
|   | ||||
| @@ -1,9 +1,19 @@ | ||||
| use std::{env, path::PathBuf}; | ||||
|  | ||||
| pub const ENV_KEY_CSP_CONFIG_DIR: &str = "CSP_CONFIG_DIR"; | ||||
| pub const ENV_KEY_TEST: &str = "RUN_TESTS"; | ||||
|  | ||||
| fn main() { | ||||
|     println!("cargo:rustc-link-lib=csp"); | ||||
|     // libcsp is built in a separate project, so linking it for tests will fail. | ||||
|     // For tests, we do not want to have the link directive to csp. | ||||
|     let run_tests = if let Ok(val) = env::var(ENV_KEY_TEST) { | ||||
|         val == "1" | ||||
|     } else { | ||||
|         false | ||||
|     }; | ||||
|     if !run_tests { | ||||
|         println!("cargo:rustc-link-lib=csp"); | ||||
|     } | ||||
|  | ||||
|     let out_path = env::var("OUT_DIR").unwrap(); | ||||
|     let csp_conf_dir = match env::var(ENV_KEY_CSP_CONFIG_DIR) { | ||||
|   | ||||
							
								
								
									
										22
									
								
								libcsp-sys/release-checklist.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								libcsp-sys/release-checklist.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| Checklist for new releases | ||||
| ======= | ||||
|  | ||||
| # Pre-Release | ||||
|  | ||||
| 1. Make sure any new modules are documented sufficiently enough and check docs with | ||||
|    `cargo +nightly doc --all-features --config 'build.rustdocflags=["--cfg", "docs_rs"]' --open`. | ||||
| 2. Bump version specifier in `Cargo.toml`. | ||||
| 3. Update `CHANGELOG.md`: Convert `unreleased` section into version section with date and add new | ||||
|    `unreleased` section. | ||||
| 4. Run `cargo test --all-features` or `cargo nextest r --all-features`. | ||||
| 5. Run `cargo fmt` and `cargo clippy`. | ||||
| 6. Wait for CI/CD results for EGit and Github. These also check cross-compilation for bare-metal | ||||
|    targets. | ||||
|  | ||||
| # Release | ||||
|  | ||||
| 1. `cargo publish` | ||||
|  | ||||
| # Post-Release | ||||
|  | ||||
| 1. Create a new release on `EGit` based on the release branch. | ||||
| @@ -14,6 +14,8 @@ | ||||
| //! [here](https://egit.irs.uni-stuttgart.de/rust/libcsp-rust/src/branch/main/examples/autoconfig.rs). | ||||
| //! The user has to provide the path to a directory containing this `autoconfig.rs` file using the | ||||
| //! `CSP_CONFIG_DIR` environmental variable. | ||||
| #![no_std] | ||||
| #![cfg_attr(docs_rs, feature(doc_auto_cfg))] | ||||
| #![allow(non_upper_case_globals)] | ||||
| #![allow(non_camel_case_types)] | ||||
| #![allow(non_snake_case)] | ||||
| @@ -549,8 +551,7 @@ pub mod hooks { | ||||
| #[cfg(test)] | ||||
| mod tests { | ||||
|     use super::*; | ||||
|     use core::mem::{align_of, size_of}; | ||||
|     use std::mem::MaybeUninit; | ||||
|     use core::mem::{align_of, size_of, MaybeUninit}; | ||||
|  | ||||
|     #[test] | ||||
|     fn bindgen_test_layout_csp_timestamp_t() { | ||||
| @@ -562,12 +563,12 @@ mod tests { | ||||
|             concat!("Size of: ", stringify!(csp_timestamp_t)) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             std::mem::align_of::<csp_timestamp_t>(), | ||||
|             core::mem::align_of::<csp_timestamp_t>(), | ||||
|             4usize, | ||||
|             concat!("Alignment of ", stringify!(csp_timestamp_t)) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).tv_sec) as usize - ptr as usize }, | ||||
|             unsafe { ::core::ptr::addr_of!((*ptr).tv_sec) as usize - ptr as usize }, | ||||
|             0usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -577,7 +578,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).tv_nsec) as usize - ptr as usize }, | ||||
|             unsafe { ::core::ptr::addr_of!((*ptr).tv_nsec) as usize - ptr as usize }, | ||||
|             4usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -603,7 +604,7 @@ mod tests { | ||||
|             concat!("Alignment of ", stringify!(__packed)) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).pri) as usize - ptr as usize }, | ||||
|             unsafe { ::core::ptr::addr_of!((*ptr).pri) as usize - ptr as usize }, | ||||
|             0usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -613,7 +614,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).flags) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).flags) as usize - ptr as usize }, | ||||
|             1usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -623,7 +624,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).src) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).src) as usize - ptr as usize }, | ||||
|             2usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -633,7 +634,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).dst) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).dst) as usize - ptr as usize }, | ||||
|             4usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -643,7 +644,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).dport) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).dport) as usize - ptr as usize }, | ||||
|             6usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -653,7 +654,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).sport) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).sport) as usize - ptr as usize }, | ||||
|             7usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -685,7 +686,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).rdp_quarantine) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).rdp_quarantine) as usize - ptr as usize }, | ||||
|             0usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -695,7 +696,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).timestamp_tx) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).timestamp_tx) as usize - ptr as usize }, | ||||
|             4usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -705,7 +706,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).timestamp_rx) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).timestamp_rx) as usize - ptr as usize }, | ||||
|             8usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -715,7 +716,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).conn) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).conn) as usize - ptr as usize }, | ||||
|             16usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -747,7 +748,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).rx_count) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).rx_count) as usize - ptr as usize }, | ||||
|             0usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -757,7 +758,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).remain) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).remain) as usize - ptr as usize }, | ||||
|             2usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -767,7 +768,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).cfpid) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).cfpid) as usize - ptr as usize }, | ||||
|             4usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -777,7 +778,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).last_used) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).last_used) as usize - ptr as usize }, | ||||
|             8usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -787,7 +788,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).frame_begin) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).frame_begin) as usize - ptr as usize }, | ||||
|             16usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -797,7 +798,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).frame_length) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).frame_length) as usize - ptr as usize }, | ||||
|             24usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -836,7 +837,7 @@ mod tests { | ||||
|             concat!("Alignment of ", stringify!(csp_packet_s__bindgen_ty_2)) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).data) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).data) as usize - ptr as usize }, | ||||
|             0usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -846,7 +847,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).data16) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).data16) as usize - ptr as usize }, | ||||
|             0usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -856,7 +857,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).data32) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).data32) as usize - ptr as usize }, | ||||
|             0usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -881,7 +882,7 @@ mod tests { | ||||
|             concat!("Alignment of ", stringify!(csp_packet_s)) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).length) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).length) as usize - ptr as usize }, | ||||
|             32usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -891,7 +892,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).id) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).id) as usize - ptr as usize }, | ||||
|             34usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -901,7 +902,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).next) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).next) as usize - ptr as usize }, | ||||
|             48usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -911,7 +912,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).header) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).header) as usize - ptr as usize }, | ||||
|             56usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -924,20 +925,20 @@ mod tests { | ||||
|  | ||||
|     #[test] | ||||
|     fn bindgen_test_layout_csp_socket_s() { | ||||
|         const UNINIT: ::std::mem::MaybeUninit<csp_socket_s> = ::std::mem::MaybeUninit::uninit(); | ||||
|         const UNINIT: core::mem::MaybeUninit<csp_socket_s> = core::mem::MaybeUninit::uninit(); | ||||
|         let ptr = UNINIT.as_ptr(); | ||||
|         assert_eq!( | ||||
|             ::std::mem::size_of::<csp_socket_s>(), | ||||
|             core::mem::size_of::<csp_socket_s>(), | ||||
|             152usize, | ||||
|             concat!("Size of: ", stringify!(csp_socket_s)) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             ::std::mem::align_of::<csp_socket_s>(), | ||||
|             core::mem::align_of::<csp_socket_s>(), | ||||
|             8usize, | ||||
|             concat!("Alignment of ", stringify!(csp_socket_s)) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).rx_queue) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).rx_queue) as usize - ptr as usize }, | ||||
|             0usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -947,7 +948,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).rx_queue_static) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).rx_queue_static) as usize - ptr as usize }, | ||||
|             8usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -957,7 +958,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).rx_queue_static_data) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).rx_queue_static_data) as usize - ptr as usize }, | ||||
|             16usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
| @@ -967,7 +968,7 @@ mod tests { | ||||
|             ) | ||||
|         ); | ||||
|         assert_eq!( | ||||
|             unsafe { ::std::ptr::addr_of!((*ptr).opts) as usize - ptr as usize }, | ||||
|             unsafe { core::ptr::addr_of!((*ptr).opts) as usize - ptr as usize }, | ||||
|             144usize, | ||||
|             concat!( | ||||
|                 "Offset of field: ", | ||||
|   | ||||
| @@ -15,4 +15,4 @@ categories = ["aerospace", "external-ffi-bindings", "no-std", "hardware-support" | ||||
| bitflags = "2" | ||||
| num_enum = "0.7" | ||||
| libc = "0.2" | ||||
| libcsp-sys = { path = "../libcsp-sys" } | ||||
| libcsp-sys = { version = "0.1", path = "../libcsp-sys" } | ||||
|   | ||||
							
								
								
									
										22
									
								
								libcsp/release-checklist.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								libcsp/release-checklist.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| Checklist for new releases | ||||
| ======= | ||||
|  | ||||
| # Pre-Release | ||||
|  | ||||
| 1. Make sure any new modules are documented sufficiently enough and check docs with | ||||
|    `cargo +nightly doc --all-features --config 'build.rustdocflags=["--cfg", "docs_rs"]' --open`. | ||||
| 2. Bump version specifier in `Cargo.toml`. | ||||
| 3. Update `CHANGELOG.md`: Convert `unreleased` section into version section with date and add new | ||||
|    `unreleased` section. | ||||
| 4. Run `cargo test --all-features` or `cargo nextest r --all-features`. | ||||
| 5. Run `cargo fmt` and `cargo clippy`. | ||||
| 6. Wait for CI/CD results for EGit and Github. These also check cross-compilation for bare-metal | ||||
|    targets. | ||||
|  | ||||
| # Release | ||||
|  | ||||
| 1. `cargo publish` | ||||
|  | ||||
| # Post-Release | ||||
|  | ||||
| 1. Create a new release on `EGit` based on the release branch. | ||||
		Reference in New Issue
	
	Block a user