{-# LANGUAGE ConstraintKinds #-} {-# LANGUAGE FlexibleContexts #-} {-# LANGUAGE GADTs #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE ScopedTypeVariables #-} {-# LANGUAGE TypeApplications #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE TypeOperators #-} module Nix.Render where import Data.ByteString (ByteString) import Data.List.NonEmpty (NonEmpty((:|))) import qualified Data.Set as Set import Data.Void import Nix.Expr.Types.Annotated import Text.Megaparsec.Error import Text.Megaparsec.Pos (SourcePos(..)) import Text.PrettyPrint.ANSI.Leijen class Monad m => MonadFile m where readFile :: FilePath -> m ByteString posAndMsg :: SourcePos -> Doc -> ParseError t Void posAndMsg beg msg = FancyError (beg :| []) (Set.fromList [ErrorFail (show msg) :: ErrorFancy Void]) renderLocation :: MonadFile m => SrcSpan -> Doc -> m Doc renderLocation (SrcSpan beg@(SourcePos "" _ _) _) msg = return $ text $ init $ parseErrorPretty @Char (posAndMsg beg msg) renderLocation (SrcSpan beg@(SourcePos path _ _) _) msg = do contents <- Nix.Render.readFile path return $ text $ init $ parseErrorPretty' contents (posAndMsg beg msg)