add "delete" functions

This commit is contained in:
rnhmjoj 2016-12-04 15:36:06 +01:00
parent d22f298356
commit d88a6e59ad
No known key found for this signature in database
GPG Key ID: 362BB82B7E496B7C

View File

@ -25,7 +25,6 @@ import Data.Maybe (Maybe(..))
import Data.Char (Char) import Data.Char (Char)
import Data.Function ((), flip) import Data.Function ((), flip)
import Data.Singletons (SingI, sing) import Data.Singletons (SingI, sing)
import Data.TypeClass import Data.TypeClass
@ -387,3 +386,20 @@ unzip ∷ Vec n (a, b) → (Vec n a, Vec n b)
unzip Nil = (Nil, Nil) unzip Nil = (Nil, Nil)
unzip ((x, y) :- xys) = (x :- xs, y :- ys) unzip ((x, y) :- xys) = (x :- xs, y :- ys)
where (xs, ys) = unzip xys where (xs, ys) = unzip xys
-- * "Set" operations
-- | 'delete' @x@ removes the first occurrence of @x@ from its list argument.
-- For example,
--
-- > delete 'a' "banana" ≡ Just "bnana"
delete Eq a a Vec (S n) a Maybe (Vec n a)
delete = deleteBy ()
-- | The 'deleteBy' function behaves like 'delete', but takes a
-- user-supplied equality predicate.
deleteBy (a a 𝔹) a Vec (S n) a Maybe (Vec n a)
deleteBy () t (x:-Nil) = if t x then Just Nil else Nothing
deleteBy () t (x:-xs@(_:-_)) = if t x then Just xs else fmap (x:-) (deleteBy () t xs)