diff options
author | Adam Vogt <vogt.adam@gmail.com> | 2011-06-09 07:18:58 +0200 |
---|---|---|
committer | Adam Vogt <vogt.adam@gmail.com> | 2011-06-09 07:18:58 +0200 |
commit | 79f42d9dd4b28df0dd0fef7c03b6dc2938fef4a9 (patch) | |
tree | 5effa0220f9771e36a26f16d18b259e661ccad43 | |
parent | 45c6b115e6609c905c0578a785a53784820da71d (diff) | |
download | XMonadContrib-79f42d9dd4b28df0dd0fef7c03b6dc2938fef4a9.tar.gz XMonadContrib-79f42d9dd4b28df0dd0fef7c03b6dc2938fef4a9.tar.xz XMonadContrib-79f42d9dd4b28df0dd0fef7c03b6dc2938fef4a9.zip |
Use a phantom type instead of undefined in L.LayoutBuilderP
Ignore-this: f9009c339ac20245ca0b1dc8154b673f
This better expresses the idea that the argument to alwaysTrue is just there to
select an instance. Another option could be to do use a fundep, which seems to
be compatible with the two instances so far.
class Predicate p w | p -> w
darcs-hash:20110609051858-1499c-ea3f8f433a510fea3c6fcc79b77098d14afe163f.gz
-rw-r--r-- | XMonad/Layout/LayoutBuilderP.hs | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/XMonad/Layout/LayoutBuilderP.hs b/XMonad/Layout/LayoutBuilderP.hs index 6ff48d0..aee6c6a 100644 --- a/XMonad/Layout/LayoutBuilderP.hs +++ b/XMonad/Layout/LayoutBuilderP.hs @@ -20,7 +20,7 @@ module XMonad.Layout.LayoutBuilderP ( B.relBox, B.absBox, -- * Overloading ways to select windows -- $selectWin - Predicate (..), + Predicate (..), Proxy(..), ) where import Control.Monad @@ -42,13 +42,16 @@ import qualified XMonad.Layout.LayoutBuilder as B -- | Type class for predicates. This enables us to manage not only Windows, -- but any objects, for which instance Predicate is defined. --- We assume that for all w checkPredicate (alwaysTrue undefined) == return True. -- -- Another instance exists in XMonad.Util.WindowPropertiesRE in xmonad-extras class Predicate p w where - alwaysTrue :: w -> p -- ^ A predicate that is always True. First argument is dummy, we always set it to undefined + alwaysTrue :: Proxy w -> p -- ^ A predicate that is always True. checkPredicate :: p -> w -> X Bool -- ^ Check if given object (window or smth else) matches that predicate +-- | Contains no actual data, but is needed to help select the correct instance +-- of 'Predicate' +data Proxy a = Proxy + -- | Data type for our layout. data LayoutP p l1 l2 a = LayoutP (Maybe a) (Maybe a) p B.SubBox (Maybe B.SubBox) (l1 a) (Maybe (l2 a)) @@ -71,7 +74,7 @@ layoutAll :: forall l1 p a. (Read a, Eq a, LayoutClass l1 a, Predicate p a) => -> l1 a -- ^ The layout to use in the specified area -> LayoutP p l1 Full a -- ^ The resulting layout layoutAll box sub = - let a = alwaysTrue (undefined :: a) + let a = alwaysTrue (Proxy :: Proxy a) in LayoutP Nothing Nothing a box Nothing sub Nothing instance (LayoutClass l1 w, LayoutClass l2 w, Predicate p w, Show w, Read w, Eq w, Typeable w, Show p) => |