Skip to content
Snippets Groups Projects
Commit e49c4aa0 authored by Robbert Krebbers's avatar Robbert Krebbers
Browse files

Commonly used variant of `singleton_included` when the element is exclusive.

parent 87afb294
No related branches found
No related tags found
No related merge requests found
...@@ -278,6 +278,13 @@ Proof. ...@@ -278,6 +278,13 @@ Proof.
+ by rewrite lookup_op lookup_singleton lookup_partial_alter Hi. + by rewrite lookup_op lookup_singleton lookup_partial_alter Hi.
+ by rewrite lookup_op lookup_singleton_ne// lookup_partial_alter_ne// left_id. + by rewrite lookup_op lookup_singleton_ne// lookup_partial_alter_ne// left_id.
Qed. Qed.
Lemma singleton_included_exclusive m i x :
Exclusive x m
{[ i := x ]} m m !! i Some x.
Proof.
intros ? Hm. rewrite singleton_included. split; last by eauto.
intros (y&?&->%(Some_included_exclusive _)); eauto using lookup_valid_Some.
Qed.
Global Instance singleton_cancelable i x : Global Instance singleton_cancelable i x :
Cancelable (Some x) Cancelable {[ i := x ]}. Cancelable (Some x) Cancelable {[ i := x ]}.
......
...@@ -121,10 +121,8 @@ Section to_proph_map. ...@@ -121,10 +121,8 @@ Section to_proph_map.
Lemma proph_map_singleton_included R p v : Lemma proph_map_singleton_included R p v :
{[p := Excl v]} to_proph_map R R !! p = Some v. {[p := Excl v]} to_proph_map R R !! p = Some v.
Proof. Proof.
rewrite singleton_included=> -[v' []]. rewrite singleton_included_exclusive; last by apply to_proph_map_valid.
rewrite /to_proph_map lookup_fmap fmap_Some_equiv=> -[v'' [Hp ->]]. by rewrite leibniz_equiv_iff /to_proph_map lookup_fmap fmap_Some=> -[v' [-> [->]]].
intros [=->]%Some_included_exclusive%leibniz_equiv_iff; first done; last done.
apply excl_exclusive.
Qed. Qed.
End to_proph_map. End to_proph_map.
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment