forked from libre-chip/fayalite
get #[hdl] struct S<A: KnownSize, B: KnownSize> to work
This commit is contained in:
parent
4909724995
commit
d0229fbcfb
|
@ -85,7 +85,7 @@ impl<T: Type, Len: Size> ArrayType<T, Len> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T: Type, Len: KnownSize> ArrayType<T, Len> {
|
impl<T: Type, Len: KnownSize + Size<SizeType = Len>> ArrayType<T, Len> {
|
||||||
pub fn new_static(element: T) -> Self {
|
pub fn new_static(element: T) -> Self {
|
||||||
Self::new(element, Len::SizeType::default())
|
Self::new(element, Len::SizeType::default())
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,8 +32,23 @@ mod sealed {
|
||||||
pub const DYN_SIZE: usize = !0;
|
pub const DYN_SIZE: usize = !0;
|
||||||
pub type DynSize = ConstUsize<DYN_SIZE>;
|
pub type DynSize = ConstUsize<DYN_SIZE>;
|
||||||
|
|
||||||
pub trait KnownSize: GenericConstUsize + Size<SizeType = Self> {
|
pub trait KnownSize:
|
||||||
|
GenericConstUsize + sealed::SizeTypeSealed + sealed::SizeSealed + Default
|
||||||
|
{
|
||||||
const SIZE: Self;
|
const SIZE: Self;
|
||||||
|
type ArrayMatch<Element: Type>: AsRef<[Expr<Element>]>
|
||||||
|
+ AsMut<[Expr<Element>]>
|
||||||
|
+ BorrowMut<[Expr<Element>]>
|
||||||
|
+ 'static
|
||||||
|
+ Send
|
||||||
|
+ Sync
|
||||||
|
+ Eq
|
||||||
|
+ Clone
|
||||||
|
+ std::hash::Hash
|
||||||
|
+ std::fmt::Debug
|
||||||
|
+ IntoIterator<Item = Expr<Element>>
|
||||||
|
+ TryFrom<Vec<Expr<Element>>>
|
||||||
|
+ Into<Vec<Expr<Element>>>;
|
||||||
}
|
}
|
||||||
|
|
||||||
macro_rules! known_widths {
|
macro_rules! known_widths {
|
||||||
|
@ -44,6 +59,7 @@ macro_rules! known_widths {
|
||||||
v
|
v
|
||||||
}> {
|
}> {
|
||||||
const SIZE: Self = Self;
|
const SIZE: Self = Self;
|
||||||
|
type ArrayMatch<Element: Type> = [Expr<Element>; Self::VALUE];
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
([2 $($rest:tt)*] $($bits:literal)+) => {
|
([2 $($rest:tt)*] $($bits:literal)+) => {
|
||||||
|
@ -55,6 +71,7 @@ macro_rules! known_widths {
|
||||||
known_widths!([$($rest)*] 1);
|
known_widths!([$($rest)*] 1);
|
||||||
impl KnownSize for ConstUsize<{2 $(* $rest)*}> {
|
impl KnownSize for ConstUsize<{2 $(* $rest)*}> {
|
||||||
const SIZE: Self = Self;
|
const SIZE: Self = Self;
|
||||||
|
type ArrayMatch<Element: Type> = [Expr<Element>; Self::VALUE];
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -124,30 +141,24 @@ impl<const VALUE: usize> sealed::SizeSealed for ConstUsize<VALUE> {}
|
||||||
|
|
||||||
impl<const VALUE: usize> sealed::SizeTypeSealed for ConstUsize<VALUE> {}
|
impl<const VALUE: usize> sealed::SizeTypeSealed for ConstUsize<VALUE> {}
|
||||||
|
|
||||||
impl<const VALUE: usize> SizeType for ConstUsize<VALUE>
|
impl<T: KnownSize> SizeType for T {
|
||||||
where
|
type Size = T;
|
||||||
ConstUsize<VALUE>: KnownSize,
|
|
||||||
{
|
|
||||||
type Size = ConstUsize<VALUE>;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<const VALUE: usize> Size for ConstUsize<VALUE>
|
impl<T: KnownSize> Size for T {
|
||||||
where
|
type ArrayMatch<Element: Type> = <T as KnownSize>::ArrayMatch<Element>;
|
||||||
ConstUsize<VALUE>: KnownSize,
|
|
||||||
{
|
|
||||||
type ArrayMatch<Element: Type> = [Expr<Element>; VALUE];
|
|
||||||
|
|
||||||
const KNOWN_VALUE: Option<usize> = Some(VALUE);
|
const KNOWN_VALUE: Option<usize> = Some(T::VALUE);
|
||||||
|
|
||||||
type SizeType = ConstUsize<VALUE>;
|
type SizeType = T;
|
||||||
|
|
||||||
fn as_usize(_size_type: Self::SizeType) -> usize {
|
fn as_usize(_size_type: Self::SizeType) -> usize {
|
||||||
VALUE
|
T::VALUE
|
||||||
}
|
}
|
||||||
|
|
||||||
fn try_from_usize(v: usize) -> Option<Self::SizeType> {
|
fn try_from_usize(v: usize) -> Option<Self::SizeType> {
|
||||||
if v == VALUE {
|
if v == T::VALUE {
|
||||||
Some(ConstUsize)
|
Some(T::SIZE)
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
@ -252,9 +263,7 @@ macro_rules! impl_int {
|
||||||
|
|
||||||
impl<Width: KnownSize> $name<Width> {
|
impl<Width: KnownSize> $name<Width> {
|
||||||
pub fn new_static() -> Self {
|
pub fn new_static() -> Self {
|
||||||
Self {
|
Self { width: Width::SIZE }
|
||||||
width: Width::SizeType::default(),
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -526,9 +535,9 @@ pub trait BoolOrIntType: Type + sealed::BoolOrIntTypeSealed {
|
||||||
fn new(width: <Self::Width as Size>::SizeType) -> Self;
|
fn new(width: <Self::Width as Size>::SizeType) -> Self;
|
||||||
fn new_static() -> Self
|
fn new_static() -> Self
|
||||||
where
|
where
|
||||||
Self::Width: KnownSize,
|
Self::Width: KnownSize + Size<SizeType = Self::Width>,
|
||||||
{
|
{
|
||||||
Self::new(<Self::Width as Size>::SizeType::default())
|
Self::new(Self::Width::default())
|
||||||
}
|
}
|
||||||
fn as_same_width_sint(self) -> SIntType<Self::Width> {
|
fn as_same_width_sint(self) -> SIntType<Self::Width> {
|
||||||
SIntType::new(Self::Width::from_usize(self.width()))
|
SIntType::new(Self::Width::from_usize(self.width()))
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
// SPDX-License-Identifier: LGPL-3.0-or-later
|
// SPDX-License-Identifier: LGPL-3.0-or-later
|
||||||
// See Notices.txt for copyright information
|
// See Notices.txt for copyright information
|
||||||
use fayalite::prelude::*;
|
|
||||||
#[cfg(todo)]
|
|
||||||
use fayalite::{
|
use fayalite::{
|
||||||
bundle::BundleType,
|
bundle::BundleType,
|
||||||
enum_::EnumType,
|
enum_::EnumType,
|
||||||
int::{BoolOrIntType, IntType},
|
int::{BoolOrIntType, IntType},
|
||||||
|
prelude::*,
|
||||||
ty::StaticType,
|
ty::StaticType,
|
||||||
};
|
};
|
||||||
use std::marker::PhantomData;
|
use std::marker::PhantomData;
|
||||||
|
@ -121,7 +120,6 @@ mod bound_kind {
|
||||||
|
|
||||||
macro_rules! check_bounds {
|
macro_rules! check_bounds {
|
||||||
($name:ident<$(#[$field:ident, $kind:ident] $var:ident: $($bound:ident +)*),*>) => {
|
($name:ident<$(#[$field:ident, $kind:ident] $var:ident: $($bound:ident +)*),*>) => {
|
||||||
#[cfg(todo)]
|
|
||||||
#[hdl(outline_generated)]
|
#[hdl(outline_generated)]
|
||||||
struct $name<$($var: $($bound +)*,)*> {
|
struct $name<$($var: $($bound +)*,)*> {
|
||||||
$($field: bound_kind::$kind<$var>,)*
|
$($field: bound_kind::$kind<$var>,)*
|
||||||
|
|
Loading…
Reference in a new issue