Skip to content

Commit

Permalink
Merge pull request #1174 from hacspec/fix-1170
Browse files Browse the repository at this point in the history
Remove rejected type ascription patterns from generated f*.
  • Loading branch information
W95Psp authored Dec 9, 2024
2 parents de59826 + 92e7d33 commit 814a6a2
Show file tree
Hide file tree
Showing 7 changed files with 102 additions and 31 deletions.
3 changes: 2 additions & 1 deletion engine/backends/fstar/fstar_backend.ml
Original file line number Diff line number Diff line change
Expand Up @@ -401,8 +401,9 @@ struct
let ppat = ppat' false in
match p.p with
| PWild -> F.wild
| PAscription { typ; pat } ->
| PAscription { typ; pat = { p = PBinding _; _ } as pat } ->
F.pat @@ F.AST.PatAscribed (ppat pat, (pty p.span typ, None))
| PAscription { pat; _ } -> ppat pat
| PBinding
{
mut = Immutable;
Expand Down
50 changes: 25 additions & 25 deletions test-harness/src/snapshots/toolchain__literals into-fstar.snap
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ type t_Foo = { f_field:u8 }
let v_CONSTANT: t_Foo = { f_field = 3uy } <: t_Foo

let casts (x8: u8) (x16: u16) (x32: u32) (x64: u64) (xs: usize) : Prims.unit =
let (_: u64):u64 =
let _:u64 =
((((cast (x8 <: u8) <: u64) +! (cast (x16 <: u16) <: u64) <: u64) +! (cast (x32 <: u32) <: u64)
<:
u64) +!
Expand All @@ -47,28 +47,28 @@ let casts (x8: u8) (x16: u16) (x32: u32) (x64: u64) (xs: usize) : Prims.unit =
u64) +!
(cast (xs <: usize) <: u64)
in
let (_: u32):u32 =
let _:u32 =
((((cast (x8 <: u8) <: u32) +! (cast (x16 <: u16) <: u32) <: u32) +! x32 <: u32) +!
(cast (x64 <: u64) <: u32)
<:
u32) +!
(cast (xs <: usize) <: u32)
in
let (_: u16):u16 =
let _:u16 =
((((cast (x8 <: u8) <: u16) +! x16 <: u16) +! (cast (x32 <: u32) <: u16) <: u16) +!
(cast (x64 <: u64) <: u16)
<:
u16) +!
(cast (xs <: usize) <: u16)
in
let (_: u8):u8 =
let _:u8 =
(((x8 +! (cast (x16 <: u16) <: u8) <: u8) +! (cast (x32 <: u32) <: u8) <: u8) +!
(cast (x64 <: u64) <: u8)
<:
u8) +!
(cast (xs <: usize) <: u8)
in
let (_: i64):i64 =
let _:i64 =
((((cast (x8 <: u8) <: i64) +! (cast (x16 <: u16) <: i64) <: i64) +! (cast (x32 <: u32) <: i64)
<:
i64) +!
Expand All @@ -77,7 +77,7 @@ let casts (x8: u8) (x16: u16) (x32: u32) (x64: u64) (xs: usize) : Prims.unit =
i64) +!
(cast (xs <: usize) <: i64)
in
let (_: i32):i32 =
let _:i32 =
((((cast (x8 <: u8) <: i32) +! (cast (x16 <: u16) <: i32) <: i32) +! (cast (x32 <: u32) <: i32)
<:
i32) +!
Expand All @@ -86,7 +86,7 @@ let casts (x8: u8) (x16: u16) (x32: u32) (x64: u64) (xs: usize) : Prims.unit =
i32) +!
(cast (xs <: usize) <: i32)
in
let (_: i16):i16 =
let _:i16 =
((((cast (x8 <: u8) <: i16) +! (cast (x16 <: u16) <: i16) <: i16) +! (cast (x32 <: u32) <: i16)
<:
i16) +!
Expand All @@ -95,7 +95,7 @@ let casts (x8: u8) (x16: u16) (x32: u32) (x64: u64) (xs: usize) : Prims.unit =
i16) +!
(cast (xs <: usize) <: i16)
in
let (_: i8):i8 =
let _:i8 =
((((cast (x8 <: u8) <: i8) +! (cast (x16 <: u16) <: i8) <: i8) +! (cast (x32 <: u32) <: i8)
<:
i8) +!
Expand All @@ -115,7 +115,7 @@ let math_integers (x: Hax_lib.Int.t_Int)
: Prims.Pure u8
(requires x > (0 <: Hax_lib.Int.t_Int) && x < (16 <: Hax_lib.Int.t_Int))
(fun _ -> Prims.l_True) =
let (_: Hax_lib.Int.t_Int):Hax_lib.Int.t_Int = Rust_primitives.Hax.Int.from_machine (sz 3) in
let _:Hax_lib.Int.t_Int = Rust_primitives.Hax.Int.from_machine (sz 3) in
let _:bool =
((-340282366920938463463374607431768211455000) <: Hax_lib.Int.t_Int) >
(340282366920938463463374607431768211455000 <: Hax_lib.Int.t_Int)
Expand All @@ -129,26 +129,26 @@ let math_integers (x: Hax_lib.Int.t_Int)
let _:Hax_lib.Int.t_Int = x - x in
let _:Hax_lib.Int.t_Int = x * x in
let _:Hax_lib.Int.t_Int = x / x in
let (_: i16):i16 = Hax_lib.Int.impl__Int__to_i16 x in
let (_: i32):i32 = Hax_lib.Int.impl__Int__to_i32 x in
let (_: i64):i64 = Hax_lib.Int.impl__Int__to_i64 x in
let (_: i128):i128 = Hax_lib.Int.impl__Int__to_i128 x in
let (_: isize):isize = Hax_lib.Int.impl__Int__to_isize x in
let (_: u16):u16 = Hax_lib.Int.impl__Int__to_u16 x in
let (_: u32):u32 = Hax_lib.Int.impl__Int__to_u32 x in
let (_: u64):u64 = Hax_lib.Int.impl__Int__to_u64 x in
let (_: u128):u128 = Hax_lib.Int.impl__Int__to_u128 x in
let (_: usize):usize = Hax_lib.Int.impl__Int__to_usize x in
let _:i16 = Hax_lib.Int.impl__Int__to_i16 x in
let _:i32 = Hax_lib.Int.impl__Int__to_i32 x in
let _:i64 = Hax_lib.Int.impl__Int__to_i64 x in
let _:i128 = Hax_lib.Int.impl__Int__to_i128 x in
let _:isize = Hax_lib.Int.impl__Int__to_isize x in
let _:u16 = Hax_lib.Int.impl__Int__to_u16 x in
let _:u32 = Hax_lib.Int.impl__Int__to_u32 x in
let _:u64 = Hax_lib.Int.impl__Int__to_u64 x in
let _:u128 = Hax_lib.Int.impl__Int__to_u128 x in
let _:usize = Hax_lib.Int.impl__Int__to_usize x in
Hax_lib.Int.impl__Int__to_u8 (x + (x * x <: Hax_lib.Int.t_Int) <: Hax_lib.Int.t_Int)

let null: char = '\0'

let numeric (_: Prims.unit) : Prims.unit =
let (_: usize):usize = sz 123 in
let (_: isize):isize = isz (-42) in
let (_: isize):isize = isz 42 in
let (_: i32):i32 = (-42l) in
let (_: u128):u128 = pub_u128 22222222222222222222 in
let _:usize = sz 123 in
let _:isize = isz (-42) in
let _:isize = isz 42 in
let _:i32 = (-42l) in
let _:u128 = pub_u128 22222222222222222222 in
()

let patterns (_: Prims.unit) : Prims.unit =
Expand Down Expand Up @@ -190,7 +190,7 @@ let panic_with_msg (_: Prims.unit) : Prims.unit =
Rust_primitives.Hax.t_Never)

let empty_array (_: Prims.unit) : Prims.unit =
let (_: t_Slice u8):t_Slice u8 =
let _:t_Slice u8 =
(let list:Prims.list u8 = [] in
FStar.Pervasives.assert_norm (Prims.eq2 (List.Tot.length list) 0);
Rust_primitives.Hax.array_of_list 0 list)
Expand Down
41 changes: 41 additions & 0 deletions test-harness/src/snapshots/toolchain__patterns into-fstar.snap
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
---
source: test-harness/src/harness.rs
expression: snapshot
info:
kind:
Translate:
backend: fstar
info:
name: patterns
manifest: patterns/Cargo.toml
description: ~
spec:
optional: false
broken: false
issue_id: ~
positive: true
snapshot:
stderr: true
stdout: true
include_flag: ~
backend_options: ~
---
exit = 0
stderr = 'Finished `dev` profile [unoptimized + debuginfo] target(s) in XXs'

[stdout]
diagnostics = []

[stdout.files]
"Patterns.fst" = '''
module Patterns
#set-options "--fuel 0 --ifuel 1 --z3rlimit 15"
open Core
open FStar.Mul

type t_Other = | Other : i32 -> t_Other

type t_Test = | Test_C1 : t_Other -> t_Test

let impl__test (self: t_Test) : i32 = match self with | Test_C1 c -> c._0
'''
14 changes: 9 additions & 5 deletions tests/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions tests/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ members = [
"dyn",
"reordering",
"nested-derefs",
"patterns",
"proverif-minimal",
"proverif-basic-structs",
"proverif-ping-pong",
Expand Down
9 changes: 9 additions & 0 deletions tests/patterns/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
[package]
name = "patterns"
version = "0.1.0"
edition = "2021"

[dependencies]

[package.metadata.hax-tests]
into."fstar" = { issue_id = "1170" }
15 changes: 15 additions & 0 deletions tests/patterns/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
#![allow(dead_code)]

struct Other<'a>(&'a i32);

enum Test<'a> {
C1(Other<'a>),
}

impl<'a> Test<'a> {
fn test(&self) -> i32 {
match self {
Self::C1(c) => *c.0,
}
}
}

0 comments on commit 814a6a2

Please sign in to comment.