aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJosh Rahm <rahm@google.com>2022-03-28 10:26:20 -0600
committerJosh Rahm <rahm@google.com>2022-03-28 10:26:20 -0600
commit19b26eaa2e72e3917bd4531a3e467cf58a721ac2 (patch)
tree0f4229b88df38d7c8e7d762c2c19007e7c01a442
parent44f6a7437ab37dd2db0f3e9e41db30b6926b3c8e (diff)
downloadrde-19b26eaa2e72e3917bd4531a3e467cf58a721ac2.tar.gz
rde-19b26eaa2e72e3917bd4531a3e467cf58a721ac2.tar.bz2
rde-19b26eaa2e72e3917bd4531a3e467cf58a721ac2.zip
Add NoPersist and use it in Logger.hs
-rw-r--r--src/Internal/NoPersist.hs23
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