You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I noticed that while flux's assumption about parametricity mostly holds, it has potential issues with downcasting. flux does seem to notice that type parameters with an explicit T: 'static bound don't have paramatricity, but misses implicit bounds caused by having &'static T in scope. For example flux verifies:
While this issue could be addressed by not considering paramatricity for type parameters rustc can infer outlive 'static, there could still be potential unsound interactions with other crates that allow downcasting without 'static bounds.
For example, while the following example produces and error in flux
use castaway::cast;use flux_rs::*;fnnot_id2<T>(mutt:T) -> T{ifletOk(n) = cast!(&mut t,&mutu32){*n = 42;}
t
}#[sig(fn(b:bool[true]))]pubfnassert(b:bool){if !b {panic!("assertion failed")}}fnmain(){assert(not_id2(0u32) == 0u32)}
error[E0999]: internal flux error: crates/flux-infer/src/infer.rs:579:22
--> src/main.rs:6:20
|
6 | if let Ok(n) = cast!(&mut t, &mut u32) {
| ^^^^^^^^^^^^^^^^^^^^^^^
|
= note: incompatible types: `ptr(mut['?32], _1)` - `&'_ mut ∃b0. { T[b0] | * }`
= note: this error originates in the macro `cast` (in Nightly builds, run with -Z macro-backtrace for more info)
error: could not compile `flux-test` (bin "flux-test") due to 1 previous error
If not_id2 came from a different crate flux would also verify it.
The text was updated successfully, but these errors were encountered:
I noticed that while
flux
's assumption about parametricity mostly holds, it has potential issues with downcasting.flux
does seem to notice that type parameters with an explicitT: 'static
bound don't have paramatricity, but misses implicit bounds caused by having&'static T
in scope. For exampleflux
verifies:While this issue could be addressed by not considering paramatricity for type parameters
rustc
can infer outlive'static
, there could still be potential unsound interactions with other crates that allow downcasting without'static
bounds.For example, while the following example produces and error in
flux
If
not_id2
came from a different crateflux
would also verify it.The text was updated successfully, but these errors were encountered: