diff options
| author | Josh Rahm <rahm@google.com> | 2022-03-28 10:26:20 -0600 |
|---|---|---|
| committer | Josh Rahm <rahm@google.com> | 2022-03-28 10:26:20 -0600 |
| commit | 19b26eaa2e72e3917bd4531a3e467cf58a721ac2 (patch) | |
| tree | 0f4229b88df38d7c8e7d762c2c19007e7c01a442 | |
| parent | 44f6a7437ab37dd2db0f3e9e41db30b6926b3c8e (diff) | |
| download | rde-19b26eaa2e72e3917bd4531a3e467cf58a721ac2.tar.gz rde-19b26eaa2e72e3917bd4531a3e467cf58a721ac2.tar.bz2 rde-19b26eaa2e72e3917bd4531a3e467cf58a721ac2.zip | |
Add NoPersist and use it in Logger.hs
| -rw-r--r-- | src/Internal/NoPersist.hs | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/src/Internal/NoPersist.hs b/src/Internal/NoPersist.hs new file mode 100644 index 0000000..a67e649 --- /dev/null +++ b/src/Internal/NoPersist.hs @@ -0,0 +1,23 @@ +-- Module for not persisting XMonad state. To be used with ExtensibleState +-- for data types that cannot be persisted. +module Internal.NoPersist where + +import Data.Default (Default, def) +import Data.Typeable + +import XMonad (ExtensionClass(..)) + +newtype NoPersist a = NoPersist a + deriving (Typeable) + +instance Show (NoPersist a) where + show (NoPersist _) = show () + +instance (Default a) => Read (NoPersist a) where + readsPrec i s = map (\(_, s) -> (NoPersist def, s)) (readsPrec i s :: [((), String)]) + +instance (Default a) => Default (NoPersist a) where + def = NoPersist def + +instance (Default a, Typeable a) => ExtensionClass (NoPersist a) where + initialValue = NoPersist def |