{-# OPTIONS_GHC -Wunused-imports #-}
module Agda.Utils.CallStack.Base (
SrcLocPackage
, SrcLocModule
, SrcFun
, SrcLocFile
, SrcLocLine
, SrcLocCol
, CallSite(..)
, CallSiteFilter
, prettySrcLoc
, prettyCallSite
, prettyCallStack
, filterCallStack
, headCallSite
, overCallSites
, popnCallStack
, truncatedCallStack
, withCallerCallStack
, withCurrentCallStack
, withNBackCallStack
, CallStack
, callStack
, fromCallSiteList
, getCallStack
, HasCallStack
, SrcLoc(..)
)
where
import Data.List ( intercalate )
import Data.Maybe ( listToMaybe )
import GHC.Stack
( callStack
, CallStack
, emptyCallStack
, fromCallSiteList
, getCallStack
, HasCallStack
, popCallStack
, prettySrcLoc
, SrcLoc(..)
)
type SrcLocPackage = String
type SrcLocModule = String
type SrcFun = String
type SrcLocFile = String
type SrcLocLine = Int
type SrcLocCol = Int
newtype CallSite = CallSite { CallSite -> ([Char], SrcLoc)
unCallSite :: (SrcFun, SrcLoc) }
type CallSiteFilter = CallSite -> Bool
prettyCallSite :: CallSite -> String
prettyCallSite :: CallSite -> [Char]
prettyCallSite (CallSite ([Char]
fun, SrcLoc
loc)) = [Char]
fun [Char] -> [Char] -> [Char]
forall a. [a] -> [a] -> [a]
++ [Char]
", called at " [Char] -> [Char] -> [Char]
forall a. [a] -> [a] -> [a]
++ SrcLoc -> [Char]
prettySrcLoc SrcLoc
loc
prettyCallStack :: CallStack -> String
prettyCallStack :: CallStack -> [Char]
prettyCallStack CallStack
cs = case (([Char], SrcLoc) -> [Char]) -> [([Char], SrcLoc)] -> [[Char]]
forall a b. (a -> b) -> [a] -> [b]
map (CallSite -> [Char]
prettyCallSite (CallSite -> [Char])
-> (([Char], SrcLoc) -> CallSite) -> ([Char], SrcLoc) -> [Char]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ([Char], SrcLoc) -> CallSite
CallSite) (CallStack -> [([Char], SrcLoc)]
getCallStack CallStack
cs) of
[] -> [Char]
"(empty CallStack)"
[Char]
firstLoc : [[Char]]
restLocs -> [Char] -> [[Char]] -> [Char]
forall a. [a] -> [[a]] -> [a]
intercalate [Char]
"\n" ([Char]
firstLoc [Char] -> [[Char]] -> [[Char]]
forall a. a -> [a] -> [a]
: (([Char] -> [Char]) -> [[Char]] -> [[Char]]
forall a b. (a -> b) -> [a] -> [b]
map ([Char]
" " [Char] -> [Char] -> [Char]
forall a. [a] -> [a] -> [a]
++) [[Char]]
restLocs))
headCallSite :: CallStack -> Maybe CallSite
headCallSite :: CallStack -> Maybe CallSite
headCallSite = (([Char], SrcLoc) -> CallSite)
-> Maybe ([Char], SrcLoc) -> Maybe CallSite
forall a b. (a -> b) -> Maybe a -> Maybe b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ([Char], SrcLoc) -> CallSite
CallSite (Maybe ([Char], SrcLoc) -> Maybe CallSite)
-> (CallStack -> Maybe ([Char], SrcLoc))
-> CallStack
-> Maybe CallSite
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [([Char], SrcLoc)] -> Maybe ([Char], SrcLoc)
forall a. [a] -> Maybe a
listToMaybe ([([Char], SrcLoc)] -> Maybe ([Char], SrcLoc))
-> (CallStack -> [([Char], SrcLoc)])
-> CallStack
-> Maybe ([Char], SrcLoc)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CallStack -> [([Char], SrcLoc)]
getCallStack
truncatedCallStack :: CallStack -> CallStack
truncatedCallStack :: CallStack -> CallStack
truncatedCallStack CallStack
cs = CallStack
-> (([Char], SrcLoc) -> CallStack)
-> Maybe ([Char], SrcLoc)
-> CallStack
forall b a. b -> (a -> b) -> Maybe a -> b
maybe CallStack
emptyCallStack ([([Char], SrcLoc)] -> CallStack
fromCallSiteList ([([Char], SrcLoc)] -> CallStack)
-> (([Char], SrcLoc) -> [([Char], SrcLoc)])
-> ([Char], SrcLoc)
-> CallStack
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ([Char], SrcLoc) -> [([Char], SrcLoc)]
forall a. a -> [a]
forall (f :: * -> *) a. Applicative f => a -> f a
pure) ((CallSite -> ([Char], SrcLoc))
-> Maybe CallSite -> Maybe ([Char], SrcLoc)
forall a b. (a -> b) -> Maybe a -> Maybe b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap CallSite -> ([Char], SrcLoc)
unCallSite (Maybe CallSite -> Maybe ([Char], SrcLoc))
-> Maybe CallSite -> Maybe ([Char], SrcLoc)
forall a b. (a -> b) -> a -> b
$ CallStack -> Maybe CallSite
headCallSite CallStack
cs)
overCallSites :: ([CallSite] -> [CallSite]) -> CallStack -> CallStack
overCallSites :: ([CallSite] -> [CallSite]) -> CallStack -> CallStack
overCallSites [CallSite] -> [CallSite]
f = [([Char], SrcLoc)] -> CallStack
fromCallSiteList ([([Char], SrcLoc)] -> CallStack)
-> (CallStack -> [([Char], SrcLoc)]) -> CallStack -> CallStack
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ((CallSite -> ([Char], SrcLoc)) -> [CallSite] -> [([Char], SrcLoc)]
forall a b. (a -> b) -> [a] -> [b]
map CallSite -> ([Char], SrcLoc)
unCallSite ([CallSite] -> [([Char], SrcLoc)])
-> ([([Char], SrcLoc)] -> [CallSite])
-> [([Char], SrcLoc)]
-> [([Char], SrcLoc)]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [CallSite] -> [CallSite]
f ([CallSite] -> [CallSite])
-> ([([Char], SrcLoc)] -> [CallSite])
-> [([Char], SrcLoc)]
-> [CallSite]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (([Char], SrcLoc) -> CallSite) -> [([Char], SrcLoc)] -> [CallSite]
forall a b. (a -> b) -> [a] -> [b]
map ([Char], SrcLoc) -> CallSite
CallSite) ([([Char], SrcLoc)] -> [([Char], SrcLoc)])
-> (CallStack -> [([Char], SrcLoc)])
-> CallStack
-> [([Char], SrcLoc)]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CallStack -> [([Char], SrcLoc)]
getCallStack
filterCallStack :: CallSiteFilter -> CallStack -> CallStack
filterCallStack :: CallSiteFilter -> CallStack -> CallStack
filterCallStack = ([CallSite] -> [CallSite]) -> CallStack -> CallStack
overCallSites (([CallSite] -> [CallSite]) -> CallStack -> CallStack)
-> (CallSiteFilter -> [CallSite] -> [CallSite])
-> CallSiteFilter
-> CallStack
-> CallStack
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CallSiteFilter -> [CallSite] -> [CallSite]
forall a. (a -> Bool) -> [a] -> [a]
filter
popnCallStack :: Word -> CallStack -> CallStack
popnCallStack :: Word -> CallStack -> CallStack
popnCallStack Word
0 = CallStack -> CallStack
forall a. a -> a
id
popnCallStack Word
n = (Word -> CallStack -> CallStack
popnCallStack (Word
n Word -> Word -> Word
forall a. Num a => a -> a -> a
- Word
1)) (CallStack -> CallStack)
-> (CallStack -> CallStack) -> CallStack -> CallStack
forall b c a. (b -> c) -> (a -> b) -> a -> c
. CallStack -> CallStack
popCallStack
withNBackCallStack :: HasCallStack => Word -> (CallStack -> b) -> b
withNBackCallStack :: forall b. HasCallStack => Word -> (CallStack -> b) -> b
withNBackCallStack Word
n CallStack -> b
f = CallStack -> b
f (Word -> CallStack -> CallStack
popnCallStack Word
n CallStack
from)
where
here :: CallStack
here = CallStack
HasCallStack => CallStack
callStack
from :: CallStack
from = CallStack -> CallStack
popCallStack CallStack
here
withCurrentCallStack :: HasCallStack => (CallStack -> b) -> b
withCurrentCallStack :: forall b. HasCallStack => (CallStack -> b) -> b
withCurrentCallStack = Word -> (CallStack -> b) -> b
forall b. HasCallStack => Word -> (CallStack -> b) -> b
withNBackCallStack Word
0
withCallerCallStack :: HasCallStack => (CallStack -> b) -> b
withCallerCallStack :: forall b. HasCallStack => (CallStack -> b) -> b
withCallerCallStack = Word -> (CallStack -> b) -> b
forall b. HasCallStack => Word -> (CallStack -> b) -> b
withNBackCallStack Word
1