From dc91e4474c6170ca3f515088e54bdb207cbac2b3 Mon Sep 17 00:00:00 2001 From: "Paolo G. Giarrusso" <p.giarrusso@gmail.com> Date: Sat, 17 Jul 2021 15:58:20 +0200 Subject: [PATCH] Mark gset methods as simpl never and add test --- tests/gmap.ref | 72 +++++++++++++++++++++++++++++++++++++++++++++++++ tests/gmap.v | 70 +++++++++++++++++++++++++++++++++++++++++++++++ theories/gmap.v | 17 +++++++++++- 3 files changed, 158 insertions(+), 1 deletion(-) create mode 100644 tests/gmap.ref create mode 100644 tests/gmap.v diff --git a/tests/gmap.ref b/tests/gmap.ref new file mode 100644 index 00000000..a4d42549 --- /dev/null +++ b/tests/gmap.ref @@ -0,0 +1,72 @@ +The command has indeed failed with message: +Failed to progress. +The command has indeed failed with message: +Failed to progress. +1 goal + + ============================ + {[1; 2; 3]} = ∅ +The command has indeed failed with message: +Failed to progress. +The command has indeed failed with message: +Failed to progress. +1 goal + + ============================ + elements {[1; 2; 3]} = [] +The command has indeed failed with message: +Failed to progress. +The command has indeed failed with message: +Failed to progress. +1 goal + + ============================ + {[1; 2; 3]} ∖ {[1]} ∪ {[4]} ∩ {[10]} = ∅ ∖ {[2]} +The command has indeed failed with message: +Failed to progress. +The command has indeed failed with message: +Failed to progress. +1 goal + + ============================ + 1 ∈ dom (gset nat) (<[1:=2]> ∅) +The command has indeed failed with message: +Failed to progress. +The command has indeed failed with message: +Failed to progress. +1 goal + + ============================ + bool_decide (∅ = {[1; 2; 3]}) = false +The command has indeed failed with message: +Failed to progress. +The command has indeed failed with message: +Failed to progress. +1 goal + + ============================ + bool_decide (∅ ≡ {[1; 2; 3]}) = false +The command has indeed failed with message: +Failed to progress. +The command has indeed failed with message: +Failed to progress. +1 goal + + ============================ + bool_decide (1 ∈ {[1; 2; 3]}) = true +The command has indeed failed with message: +Failed to progress. +The command has indeed failed with message: +Failed to progress. +1 goal + + ============================ + bool_decide (∅ ## {[1; 2; 3]}) = true +The command has indeed failed with message: +Failed to progress. +The command has indeed failed with message: +Failed to progress. +1 goal + + ============================ + bool_decide (∅ ⊆ {[1; 2; 3]}) = true diff --git a/tests/gmap.v b/tests/gmap.v new file mode 100644 index 00000000..8fdc6174 --- /dev/null +++ b/tests/gmap.v @@ -0,0 +1,70 @@ +From stdpp Require Import gmap. + +Goal {[1; 2; 3]} =@{gset nat} ∅. +Proof. + Fail progress simpl. + Fail progress cbn. + Show. +Abort. + +Goal elements (C := gset nat) {[1; 2; 3]} = []. +Proof. + Fail progress simpl. + Fail progress cbn. + Show. +Abort. + +Goal + {[1; 2; 3]} ∖ {[ 1 ]} ∪ {[ 4 ]} ∩ {[ 10 ]} =@{gset nat} ∅ ∖ {[ 2 ]}. +Proof. + Fail progress simpl. + Fail progress cbn. + Show. +Abort. + +Goal 1 ∈ dom (M := gmap _ _) (gset _) (<[ 1 := 2 ]> ∅). +Proof. + Fail progress simpl. + Fail progress cbn. + Show. +Abort. + +Goal bool_decide (∅ =@{gset _} {[ 1; 2; 3 ]}) = false. +Proof. + Fail progress simpl. + Fail progress cbn. + Show. + reflexivity. +Qed. + +Goal bool_decide (∅ ≡@{gset _} {[ 1; 2; 3 ]}) = false. +Proof. + Fail progress simpl. + Fail progress cbn. + Show. + reflexivity. +Qed. + +Goal bool_decide (1 ∈@{gset _} {[ 1; 2; 3 ]}) = true. +Proof. + Fail progress simpl. + Fail progress cbn. + Show. + reflexivity. +Qed. + +Goal bool_decide (∅ ##@{gset _} {[ 1; 2; 3 ]}) = true. +Proof. + Fail progress simpl. + Fail progress cbn. + Show. + reflexivity. +Qed. + +Goal bool_decide (∅ ⊆@{gset _} {[ 1; 2; 3 ]}) = true. +Proof. + Fail progress simpl. + Fail progress cbn. + Show. + reflexivity. +Qed. diff --git a/theories/gmap.v b/theories/gmap.v index 79813f63..97726848 100644 --- a/theories/gmap.v +++ b/theories/gmap.v @@ -237,7 +237,7 @@ Definition gset K `{Countable K} := mapset (gmap K). Section gset. Context `{Countable K}. - (* Lift instances of operational TCs from [mapset]. *) + (* Lift instances of operational TCs from [mapset] and mark them [simpl never]. *) Global Instance gset_elem_of: ElemOf K (gset K) := _. Global Instance gset_empty : Empty (gset K) := _. Global Instance gset_singleton : Singleton K (gset K) := _. @@ -253,6 +253,21 @@ Section gset. Global Instance gset_subseteq_dec : RelDecision (⊆@{gset K}) := _. Global Instance gset_dom {A} : Dom (gmap K A) (gset K) := mapset_dom. + Global Arguments gset_elem_of : simpl never. + Global Arguments gset_empty : simpl never. + Global Arguments gset_singleton : simpl never. + Global Arguments gset_union : simpl never. + Global Arguments gset_intersection : simpl never. + Global Arguments gset_difference : simpl never. + Global Arguments gset_elements : simpl never. + Global Arguments gset_eq_dec : simpl never. + Global Arguments gset_countable : simpl never. + Global Arguments gset_equiv_dec : simpl never. + Global Arguments gset_elem_of_dec : simpl never. + Global Arguments gset_disjoint_dec : simpl never. + Global Arguments gset_subseteq_dec : simpl never. + Global Arguments gset_dom : simpl never. + (* Lift instances of other TCs. *) Global Instance gset_leibniz : LeibnizEquiv (gset K) := _. Global Instance gset_semi_set : SemiSet K (gset K) | 1 := _. -- GitLab