{- | Module : $Header$ Description : Monads for message handling Copyright : 2009 Holger Siegel 2012 - 2015 Björn Peemöller License : BSD-3-clause Maintainer : bjp@informatik.uni-kiel.de Stability : experimental Portability : portable The type message represents a compiler message with an optional source code position. -} {-# LANGUAGE CPP #-} module Curry.Base.Message ( Message (..), message, posMessage, showWarning, showError , ppMessage, ppWarning, ppError, ppMessages ) where #if __GLASGOW_HASKELL__ >= 804 import Prelude hiding ((<>)) #endif import Data.Maybe (fromMaybe) import Curry.Base.Position import Curry.Base.Pretty -- --------------------------------------------------------------------------- -- Message -- --------------------------------------------------------------------------- -- |Compiler message data Message = Message { msgPos :: Maybe Position -- ^ optional source code position , msgTxt :: Doc -- ^ the message itself } instance Eq Message where Message p1 t1 == Message p2 t2 = (p1, show t1) == (p2, show t2) instance Ord Message where Message p1 t1 `compare` Message p2 t2 = compare (p1, show t1) (p2, show t2) instance Show Message where showsPrec _ = shows . ppMessage instance HasPosition Message where getPosition = fromMaybe NoPos . msgPos setPosition p m = m { msgPos = Just p } instance Pretty Message where pPrint = ppMessage -- |Construct a 'Message' without a 'Position' message :: Doc -> Message message = Message Nothing -- |Construct a message from an entity with a 'Position' and a text posMessage :: HasPosition p => p -> Doc -> Message posMessage p msg = Message (Just $ getPosition p) msg -- |Show a 'Message' as a warning showWarning :: Message -> String showWarning = show . ppWarning -- |Show a 'Message' as an error showError :: Message -> String showError = show . ppError -- |Pretty print a 'Message' ppMessage :: Message -> Doc ppMessage = ppAs "" -- |Pretty print a 'Message' as a warning ppWarning :: Message -> Doc ppWarning = ppAs "Warning" -- |Pretty print a 'Message' as an error ppError :: Message -> Doc ppError = ppAs "Error" -- |Pretty print a 'Message' with a given key ppAs :: String -> Message -> Doc ppAs key (Message mbPos txt) = posPP <+> keyPP $$ nest 4 txt where posPP = maybe empty ((<> colon) . ppPosition) mbPos keyPP = if null key then empty else text key <> colon -- |Pretty print a list of 'Message's by vertical concatenation ppMessages :: (Message -> Doc) -> [Message] -> Doc ppMessages ppFun = foldr (\m ms -> text "" $+$ m $+$ ms) empty . map ppFun