This PR changes the signature of `Array.get` to take a Nat and a proof, rather than a `Fin`, for consistency with the rest of the (planned) Array API. Note that because of bootstrapping issues we can't provide `get_elem_tactic` as an autoparameter for the proof. As users will mostly use the `xs[i]` notation provided by `GetElem`, this hopefully isn't a problem. We may restore `Fin` based versions, either here or downstream, as needed, but they won't be the "main" functions. --------- Co-authored-by: David Thrane Christiansen <david@davidchristiansen.dk>
22 lines
505 B
Text
22 lines
505 B
Text
namespace Ex
|
||
class GetElem (Cont : Type u) (Idx : Type v) (Elem : outParam (Type w)) where
|
||
getElem (xs : Cont) (i : Idx) : Elem
|
||
|
||
export GetElem (getElem)
|
||
|
||
instance : GetElem (Array α) Nat α where
|
||
getElem xs i := xs.get i sorry
|
||
|
||
opaque f : Option Bool → Id Unit
|
||
|
||
def bad2 (bs : Array Bool) (n : Nat) : Id Unit := do
|
||
for idx in [:n] do
|
||
let b := getElem bs idx
|
||
f b
|
||
|
||
def bad3 (bs : Array Bool) (n : Nat) : Id Unit := do
|
||
for h : idx in [:n] do
|
||
let b := getElem bs idx
|
||
f b
|
||
|
||
end Ex
|