{- Copyright (C) 2018 Dr. Alistair Ward This file is part of BishBosh. BishBosh 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. BishBosh 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 BishBosh. If not, see . -} {- | [@AUTHOR@] Dr. Alistair Ward [@DESCRIPTION@] Defines options common to native (i.e. not some separate GUI) interfaces. -} module BishBosh.Input.NativeUIOptions( -- * Types -- ** Type-synonyms -- ScreenCoordinates, -- DepictFigurine, -- ** Data-types NativeUIOptions( -- MkNativeUIOptions, getBoardMagnification, getColourScheme, getDepictFigurine ), -- * Constants tag, boardMagnificationTag, -- nRowsTag, -- nColumnsTag, -- * Functions -- ** Constructors mkNativeUIOptions ) where import BishBosh.Data.Bool() import Control.Arrow((***)) import qualified BishBosh.Colour.ColourScheme as Colour.ColourScheme import qualified BishBosh.Data.Exception as Data.Exception import qualified BishBosh.Text.ShowList as Text.ShowList import qualified BishBosh.Type.Length as Type.Length import qualified Control.DeepSeq import qualified Control.Exception import qualified Data.Default import qualified Text.XML.HXT.Arrow.Pickle as HXT -- | Used to qualify XML. tag :: String tag = "nativeUIOptions" -- | Used to qualify XML. boardMagnificationTag :: String boardMagnificationTag = "boardMagnification" -- | Used to qualify XML. depictFigurineTag :: String depictFigurineTag = "depictFigurine" -- | Used to qualify XML. nRowsTag :: String nRowsTag = "nRows" -- | Used to qualify XML. nColumnsTag :: String nColumnsTag = "nColumns" -- | The coordinates used to index the screen. CAVEAT: the name is an anachronistic hang-over from a discarded implementation of a Curses display. type ScreenCoordinates = (Type.Length.Row, Type.Length.Column) -- | Whether to a depict a piece using a Unicode figurine. type DepictFigurine = Bool -- | Constructor. data NativeUIOptions = MkNativeUIOptions { getBoardMagnification :: ScreenCoordinates, -- ^ The factor by which the dimensions of the board are stretched when displayed. getColourScheme :: Colour.ColourScheme.ColourScheme, getDepictFigurine :: DepictFigurine -- ^ Whether to a depict pieces using Unicode figurines. } deriving Eq instance Control.DeepSeq.NFData NativeUIOptions where rnf MkNativeUIOptions { getBoardMagnification = boardMagnification, getColourScheme = colourScheme, getDepictFigurine = depictFigurine } = Control.DeepSeq.rnf ( boardMagnification, colourScheme, depictFigurine ) instance Show NativeUIOptions where showsPrec precision MkNativeUIOptions { getBoardMagnification = boardMagnification, getColourScheme = colourScheme, getDepictFigurine = depictFigurine } = Text.ShowList.showsAssociationList' [ ( boardMagnificationTag, showsPrec precision boardMagnification ), ( Colour.ColourScheme.tag, showsPrec precision colourScheme ), ( depictFigurineTag, showsPrec precision depictFigurine ) ] instance Data.Default.Default NativeUIOptions where def = MkNativeUIOptions { getBoardMagnification = (1, 1), getColourScheme = Data.Default.def, getDepictFigurine = False } instance HXT.XmlPickler NativeUIOptions where xpickle = HXT.xpElem tag . HXT.xpWrap ( \(a, b, c) -> mkNativeUIOptions a b c, -- Construct. \MkNativeUIOptions { getBoardMagnification = boardMagnification, getColourScheme = colourScheme, getDepictFigurine = depictFigurine } -> ( boardMagnification, colourScheme, depictFigurine ) ) $ HXT.xpTriple ( getBoardMagnification def `HXT.xpDefault` HXT.xpElem boardMagnificationTag ( HXT.xpAttr nRowsTag HXT.xpickle `HXT.xpPair` HXT.xpAttr nColumnsTag HXT.xpickle ) ) ( getColourScheme def `HXT.xpDefault` HXT.xpickle ) ( getDepictFigurine def `HXT.xpDefault` HXT.xpAttr depictFigurineTag HXT.xpickle ) where def = Data.Default.def -- | Smart constructor. mkNativeUIOptions :: ScreenCoordinates -- ^ The factor by which the dimensions of the board are stretched when displayed. -> Colour.ColourScheme.ColourScheme -> DepictFigurine -> NativeUIOptions mkNativeUIOptions boardMagnification colourScheme depictFigurine | uncurry (||) $ ( (< 1) *** (< 1) ) boardMagnification = Control.Exception.throw . Data.Exception.mkOutOfBounds . showString "BishBosh.Input.NativeUIOptions.mkNativeUIOptions:\t" . showString boardMagnificationTag . Text.ShowList.showsAssociation $ shows boardMagnification " must both exceed zero." | uncurry (||) $ ( even *** even ) boardMagnification = Control.Exception.throw . Data.Exception.mkInvalidDatum . showString "BishBosh.Input.NativeUIOptions.mkNativeUIOptions:\t" . showString boardMagnificationTag . Text.ShowList.showsAssociation $ shows boardMagnification " must both be odd." | otherwise = MkNativeUIOptions { getBoardMagnification = boardMagnification, getColourScheme = colourScheme, getDepictFigurine = depictFigurine }