{-# OPTIONS_GHC -fno-warn-orphans #-} {-# LANGUAGE CPP, MultiParamTypeClasses #-} {- Copyright (C) 2013-2015 Dr. Alistair Ward This file is part of WeekDaze. WeekDaze is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. WeekDaze is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with WeekDaze. If not, see . -} {- | [@AUTHOR@] Dr. Alistair Ward [@DESCRIPTION@] Instance-definitions for 'Distribution.Verbosity.Verbosity'. -} module WeekDaze.OutputConfiguration.Verbosity( -- * Constants tag, range ) where import qualified Control.DeepSeq import qualified Data.Default import qualified Distribution.Verbosity import qualified Text.XML.HXT.Arrow.Pickle as HXT import qualified Text.XML.HXT.Arrow.Pickle.Schema #ifdef USE_HDBC import qualified Data.Convertible import qualified Database.HDBC instance Data.Convertible.Convertible Database.HDBC.SqlValue Distribution.Verbosity.Verbosity {-multi-parameter type-class-} where safeConvert = fmap read . Data.Convertible.safeConvert #endif /* USE_HDBC */ -- | Used to qualify SQL & XML. tag :: String tag = "verbosity" instance Data.Default.Default Distribution.Verbosity.Verbosity where def = Distribution.Verbosity.normal instance HXT.XmlPickler Distribution.Verbosity.Verbosity where -- xpickle = HXT.xpPrim xpickle = HXT.xpWrap (read, show) . HXT.xpAttr tag . HXT.xpTextDT . Text.XML.HXT.Arrow.Pickle.Schema.scEnum $ map show range -- CAVEAT: whether it'll be used as an XML-attribute or an XML-element isn't currently known. instance Control.DeepSeq.NFData Distribution.Verbosity.Verbosity where rnf _ = () -- | The constant complete range of values. range :: [Distribution.Verbosity.Verbosity] range = [minBound .. maxBound]