2014-12-22 15:33:29 -05:00
|
|
|
/-
|
|
|
|
Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
Author: Leonardo de Moura
|
|
|
|
-/
|
|
|
|
|
2014-11-30 20:34:12 -08:00
|
|
|
import logic.eq
|
2014-10-01 17:51:17 -07:00
|
|
|
open eq.ops decidable
|
2014-07-31 18:40:09 -07:00
|
|
|
|
2014-09-04 16:36:06 -07:00
|
|
|
namespace option
|
2015-05-03 21:40:33 -07:00
|
|
|
definition is_none {A : Type} : option A → Prop
|
|
|
|
| none := true
|
|
|
|
| (some v) := false
|
2014-09-04 22:31:52 -07:00
|
|
|
|
|
|
|
theorem is_none_none {A : Type} : is_none (@none A) :=
|
|
|
|
trivial
|
|
|
|
|
|
|
|
theorem not_is_none_some {A : Type} (a : A) : ¬ is_none (some a) :=
|
2014-11-30 20:34:12 -08:00
|
|
|
not_false
|
2014-09-04 22:31:52 -07:00
|
|
|
|
|
|
|
theorem none_ne_some {A : Type} (a : A) : none ≠ some a :=
|
2015-04-30 13:56:12 -07:00
|
|
|
by contradiction
|
2014-09-04 22:31:52 -07:00
|
|
|
|
2014-11-16 17:56:51 -08:00
|
|
|
theorem some.inj {A : Type} {a₁ a₂ : A} (H : some a₁ = some a₂) : a₁ = a₂ :=
|
2015-05-01 18:18:29 -07:00
|
|
|
by injection H; assumption
|
2014-09-04 22:31:52 -07:00
|
|
|
|
2014-10-02 09:00:34 -07:00
|
|
|
protected definition is_inhabited [instance] (A : Type) : inhabited (option A) :=
|
2014-09-04 22:31:52 -07:00
|
|
|
inhabited.mk none
|
|
|
|
|
2015-05-03 21:40:33 -07:00
|
|
|
protected definition has_decidable_eq [instance] {A : Type} [H : decidable_eq A] : ∀ o₁ o₂ : option A, decidable (o₁ = o₂)
|
|
|
|
| none none := by left; reflexivity
|
|
|
|
| none (some v₂) := by right; contradiction
|
|
|
|
| (some v₁) none := by right; contradiction
|
|
|
|
| (some v₁) (some v₂) :=
|
|
|
|
match H v₁ v₂ with
|
|
|
|
| inl e := by left; congruence; assumption
|
2015-05-25 10:43:28 -07:00
|
|
|
| inr n := by right; intro h; injection h; contradiction
|
2015-05-03 21:40:33 -07:00
|
|
|
end
|
2014-08-19 19:32:44 -07:00
|
|
|
end option
|