{-# LANGUAGE DeriveDataTypeable #-}

module Hoogle.Type.ParseError where

import Hoogle.Type.TagStr
import Data.Data

-- | Data type representing a parse error. All indecies are 1-based.
data ParseError = ParseError
    {lineNo :: Int -- ^ Line number on which the error occured, 1 for the first line of a file.
    ,columnNo :: Int -- ^ Column number on which the error occured, 1 for the first character of a line.
    ,errorMessage :: String -- ^ Error message caused by the parse error.
    ,parseInput :: TagStr -- ^ Input string which caused the error - sometimes with a 'TagEmph' to indicate which part was incorrect.
    } deriving (Ord,Eq,Data,Typeable)

instance Show ParseError where
    show (ParseError line col err _) = "Parse error " ++ show line ++ ":" ++ show col ++ ": " ++ err


parseErrorWith :: Int -> Int -> String -> String -> ParseError
parseErrorWith line col err text = ParseError line col err $ Tags [Str pre, TagEmph $ Str $ post ++ post2]
    where
        (pre,post) = splitAt (col-1) text
        post2 = if null post then "   " else ""