{-# OPTIONS --cubical-compatible --safe #-}
module Data.Vec where
open import Level
open import Data.Bool.Base
import Data.Nat.Properties as ℕₚ
open import Data.Vec.Bounded.Base as Vec≤
using (Vec≤; ≤-cast; fromVec)
open import Relation.Nullary
open import Relation.Unary
private
variable
a p : Level
A : Set a
open import Data.Vec.Base public
module _ {P : A → Set p} (P? : Decidable P) where
filter : ∀ {n} → Vec A n → Vec≤ A n
filter [] = Vec≤.[]
filter (a ∷ as) with does (P? a)
... | true = a Vec≤.∷ filter as
... | false = ≤-cast (ℕₚ.n≤1+n _) (filter as)
takeWhile : ∀ {n} → Vec A n → Vec≤ A n
takeWhile [] = Vec≤.[]
takeWhile (a ∷ as) with does (P? a)
... | true = a Vec≤.∷ takeWhile as
... | false = Vec≤.[]
dropWhile : ∀ {n} → Vec A n → Vec≤ A n
dropWhile Vec.[] = Vec≤.[]
dropWhile (a Vec.∷ as) with does (P? a)
... | true = ≤-cast (ℕₚ.n≤1+n _) (dropWhile as)
... | false = fromVec (a Vec.∷ as)