Skip to content

Commit

Permalink
Add newtype Salign
Browse files Browse the repository at this point in the history
  • Loading branch information
chris-martin committed Feb 12, 2019
1 parent 0a6cb8c commit c586341
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 1 deletion.
11 changes: 10 additions & 1 deletion Data/Align.hs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
module Data.Align (
Align(..)
-- * Specialized aligns
, malign, salign, padZip, padZipWith
, malign, salign, Salign (..), padZip, padZipWith
, lpadZip, lpadZipWith
, rpadZip, rpadZipWith
, alignVectorWith
Expand Down Expand Up @@ -285,6 +285,15 @@ malign = alignWith (mergeThese mappend)
salign :: (Align f, Semigroup a) => f a -> f a -> f a
salign = alignWith (mergeThese (<>))

-- | Monoid under 'salign' and 'nil'.
newtype Salign f a = Salign (f a)

instance (Align f, Semigroup a) => Semigroup (Salign f a) where
Salign x <> Salign y = Salign (salign x y)

instance (Align f, Semigroup a) => Monoid (Salign f a) where
mempty = Salign nil

-- | Align two structures as in 'zip', but filling in blanks with 'Nothing'.
padZip :: (Align f) => f a -> f b -> f (Maybe a, Maybe b)
padZip = alignWith (fromThese Nothing Nothing . bimap Just Just)
Expand Down
7 changes: 7 additions & 0 deletions test/Tests.hs
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,11 @@
{-# LANGUAGE DeriveFoldable #-}
{-# LANGUAGE DeriveFunctor #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE GeneralizedNewtypeDeriving #-}
{-# LANGUAGE KindSignatures #-}
{-# LANGUAGE MonoLocalBinds #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# LANGUAGE TupleSections #-}
module Main (main) where

Expand Down Expand Up @@ -63,6 +65,7 @@ tests = testGroup "Tests"
[ semigroupLaws "These" (These "x" "y")
, semigroupLaws "SearchResult" (ScannedAndFound "x" "y")
, monoidLaws "List" "x" -- to disallow
, monoidLaws "Salign" (Salign ["x"])
]
]

Expand Down Expand Up @@ -444,3 +447,7 @@ instance Monoid a => Monoid (SearchResult a b) where
mappend = (<>)
mempty = Scanned mempty
-}

deriving instance Eq (f a) => Eq (Salign f a)
deriving instance Show (f a) => Show (Salign f a)
deriving instance Arbitrary (f a) => Arbitrary (Salign f a)

0 comments on commit c586341

Please sign in to comment.