#![no_implicit_prelude]
#![allow(warnings)]
#![deny(deprecated)]
include!("include.rs");
#[macro_export]
macro_rules! test {
($name:ident => $ty:item => $($trait:ident),*) => {
#[allow(non_snake_case)]
mod $name {
$(
mod $trait {
use super::super::*;
#[deprecated = "do not use"]
#[derive(imp::$trait)]
#[zerocopy(crate = "zerocopy_renamed")]
$ty
#[allow(deprecated)]
fn _allow_deprecated() {
util_assert_impl_all!($name: imp::$trait);
}
}
)*
}
};
}
test!(Enum => #[repr(u8)] enum Enum { A, } => TryFromBytes, FromZeros, KnownLayout, Immutable, IntoBytes, Unaligned);
test!(Struct => #[repr(C)] struct Struct; => TryFromBytes, FromZeros, FromBytes, KnownLayout, Immutable, IntoBytes, Unaligned);
test!(Union => #[repr(C)] union Union{ a: (), } => TryFromBytes, FromZeros, FromBytes, KnownLayout, Immutable, IntoBytes, Unaligned);
mod enum_hash_eq {
mod ByteHash {
use super::super::*;
#[deprecated = "do not use"]
#[derive(imp::ByteHash, imp::IntoBytes, imp::Immutable)]
#[zerocopy(crate = "zerocopy_renamed")]
#[repr(u8)]
enum Enum {
A,
}
#[allow(deprecated)]
fn _allow_deprecated() {
util_assert_impl_all!(Enum: ::core::hash::Hash);
}
}
mod ByteEq {
use super::super::*;
#[deprecated = "do not use"]
#[derive(imp::ByteEq, imp::IntoBytes, imp::Immutable)]
#[zerocopy(crate = "zerocopy_renamed")]
#[repr(u8)]
enum Enum {
A,
}
#[allow(deprecated)]
fn _allow_deprecated() {
util_assert_impl_all!(Enum: ::core::cmp::PartialEq, ::core::cmp::Eq);
}
}
}
mod struct_hash_eq {
mod ByteHash {
use super::super::*;
#[deprecated = "do not use"]
#[derive(imp::ByteHash, imp::IntoBytes, imp::Immutable)]
#[zerocopy(crate = "zerocopy_renamed")]
#[repr(C)]
struct Struct;
#[allow(deprecated)]
fn _allow_deprecated() {
util_assert_impl_all!(Struct: ::core::hash::Hash);
}
}
mod ByteEq {
use super::super::*;
#[deprecated = "do not use"]
#[derive(imp::ByteEq, imp::IntoBytes, imp::Immutable)]
#[zerocopy(crate = "zerocopy_renamed")]
#[repr(C)]
struct Struct;
#[allow(deprecated)]
fn _allow_deprecated() {
util_assert_impl_all!(Struct: ::core::cmp::PartialEq, ::core::cmp::Eq);
}
}
}
mod split_at_test {
mod SplitAt {
use super::super::*;
#[deprecated = "do not use"]
#[derive(imp::SplitAt, imp::KnownLayout)]
#[zerocopy(crate = "zerocopy_renamed")]
#[repr(C)]
struct Struct {
a: [u8],
}
#[allow(deprecated)]
fn _allow_deprecated() {
util_assert_impl_all!(Struct: imp::SplitAt);
}
}
}