Use ObligationCtxt::new_in_snapshot in satisfied_from_param_env
This commit is contained in:
parent
f55b0022db
commit
343a359109
3 changed files with 57 additions and 1 deletions
|
@ -219,7 +219,7 @@ fn satisfied_from_param_env<'tcx>(
|
|||
}
|
||||
|
||||
if let Some(Ok(c)) = single_match {
|
||||
let ocx = ObligationCtxt::new(infcx);
|
||||
let ocx = ObligationCtxt::new_in_snapshot(infcx);
|
||||
assert!(ocx.eq(&ObligationCause::dummy(), param_env, c.ty(), ct.ty()).is_ok());
|
||||
assert!(ocx.eq(&ObligationCause::dummy(), param_env, c, ct).is_ok());
|
||||
assert!(ocx.select_all_or_error().is_empty());
|
||||
|
|
|
@ -0,0 +1,17 @@
|
|||
#![feature(generic_const_exprs)]
|
||||
#![allow(incomplete_features)]
|
||||
|
||||
pub trait Enumerable {
|
||||
const N: usize;
|
||||
}
|
||||
|
||||
#[derive(Clone)]
|
||||
pub struct SymmetricGroup<S>
|
||||
where
|
||||
S: Enumerable,
|
||||
[(); S::N]: Sized,
|
||||
{
|
||||
_phantom: std::marker::PhantomData<S>,
|
||||
}
|
||||
|
||||
fn main() {}
|
|
@ -0,0 +1,39 @@
|
|||
// check-pass
|
||||
|
||||
#![allow(incomplete_features)]
|
||||
#![feature(generic_const_exprs)]
|
||||
|
||||
use std::marker::PhantomData;
|
||||
|
||||
pub trait Bytes {
|
||||
const BYTES: usize;
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug)]
|
||||
pub struct Conster<OT>
|
||||
where
|
||||
OT: Bytes,
|
||||
[(); OT::BYTES]: Sized,
|
||||
{
|
||||
_offset_type: PhantomData<fn(OT) -> OT>,
|
||||
}
|
||||
|
||||
impl<OT> Conster<OT>
|
||||
where
|
||||
OT: Bytes,
|
||||
[(); OT::BYTES]: Sized,
|
||||
{
|
||||
pub fn new() -> Self {
|
||||
Conster { _offset_type: PhantomData }
|
||||
}
|
||||
}
|
||||
|
||||
pub fn make_conster<COT>() -> Conster<COT>
|
||||
where
|
||||
COT: Bytes,
|
||||
[(); COT::BYTES]: Sized,
|
||||
{
|
||||
Conster::new()
|
||||
}
|
||||
|
||||
fn main() {}
|
Loading…
Add table
Reference in a new issue