forked from libre-chip/fayalite
add repeat()
This commit is contained in:
parent
78edfc97b2
commit
a701f99fd6
|
@ -9,7 +9,7 @@ use crate::{
|
||||||
ops::ExprCastTo,
|
ops::ExprCastTo,
|
||||||
target::{GetTarget, Target},
|
target::{GetTarget, Target},
|
||||||
},
|
},
|
||||||
int::{Bool, DynSize, IntType, SIntType, SIntValue, Size, UInt, UIntType, UIntValue},
|
int::{Bool, DynSize, IntType, SIntType, SIntValue, Size, SizeType, UInt, UIntType, UIntValue},
|
||||||
intern::{Intern, Interned},
|
intern::{Intern, Interned},
|
||||||
memory::{DynPortType, MemPort, PortType},
|
memory::{DynPortType, MemPort, PortType},
|
||||||
module::{
|
module::{
|
||||||
|
@ -720,3 +720,18 @@ impl<T: Type> MakeUninitExpr for T {
|
||||||
ops::Uninit::new(self).to_expr()
|
ops::Uninit::new(self).to_expr()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn repeat<T: Type, L: SizeType>(
|
||||||
|
element: impl ToExpr<Type = T>,
|
||||||
|
len: L,
|
||||||
|
) -> Expr<ArrayType<T, L::Size>> {
|
||||||
|
let element = element.to_expr();
|
||||||
|
let canonical_element = Expr::canonical(element);
|
||||||
|
ops::ArrayLiteral::new(
|
||||||
|
Expr::ty(element),
|
||||||
|
std::iter::repeat(canonical_element)
|
||||||
|
.take(L::Size::as_usize(len))
|
||||||
|
.collect(),
|
||||||
|
)
|
||||||
|
.to_expr()
|
||||||
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@ pub use crate::{
|
||||||
clock::{Clock, ClockDomain, ToClock},
|
clock::{Clock, ClockDomain, ToClock},
|
||||||
enum_::{HdlNone, HdlOption, HdlSome},
|
enum_::{HdlNone, HdlOption, HdlSome},
|
||||||
expr::{
|
expr::{
|
||||||
CastBitsTo, CastTo, CastToBits, Expr, HdlPartialEq, HdlPartialOrd, MakeUninitExpr,
|
repeat, CastBitsTo, CastTo, CastToBits, Expr, HdlPartialEq, HdlPartialOrd, MakeUninitExpr,
|
||||||
ReduceBits, ToExpr,
|
ReduceBits, ToExpr,
|
||||||
},
|
},
|
||||||
hdl, hdl_module,
|
hdl, hdl_module,
|
||||||
|
|
Loading…
Reference in a new issue