diff options
| author | Pepe Iborra <mnislaih@gmail.com> | 2006-12-10 22:24:24 +0000 | 
|---|---|---|
| committer | Pepe Iborra <mnislaih@gmail.com> | 2006-12-10 22:24:24 +0000 | 
| commit | 1df34b328128f4949ef812c8be952ab1f85df7ac (patch) | |
| tree | d9dc828123d537d9ffdc2a2df60115d12f0a26dc /compiler/main/Breakpoints.hs | |
| parent | 376101055fb111ebd52b5ef1fb76e00334b44304 (diff) | |
| download | haskell-1df34b328128f4949ef812c8be952ab1f85df7ac.tar.gz | |
Handle breakpoint jumps while splicing TH functions in ghci
The dynamic linker has been modified so that it won't panic if one of the breakpointJump functions fails to resolve.
Now, if the dynamic linker fails to find a HValue for a Name, before looking for a static symbol it will ask to
Breakpoints.lookupBogusBreakpointVal :: Name -> Maybe HValue
which returns an identity function for the Jump names or Nothing else.
A TH function might contain a call to a breakpoint function. So if it is compiled to bytecodes, the breakpoints will be desugared to 'jumps'. Whenever this code is spliced, the linker will fail to find the jumpfunctions unless there is a default.
Diffstat (limited to 'compiler/main/Breakpoints.hs')
| -rw-r--r-- | compiler/main/Breakpoints.hs | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/compiler/main/Breakpoints.hs b/compiler/main/Breakpoints.hs index 14d9ea299d..b1b0118179 100644 --- a/compiler/main/Breakpoints.hs +++ b/compiler/main/Breakpoints.hs @@ -9,7 +9,16 @@  module Breakpoints where
 +#ifdef GHCI
 +import {-#SOURCE#-} ByteCodeLink ( HValue ) 
 +#endif
 +
  import {-#SOURCE#-} HscTypes     ( Session )
 +import Name
 +import Var                       ( Id )
 +import PrelNames
 +
 +import GHC.Exts                  ( unsafeCoerce# )
  data BkptHandler a = BkptHandler {
       handleBreakpoint  :: forall b. Session -> [(Id,HValue)] -> BkptLocation a ->  String -> b -> IO b
 @@ -29,3 +38,16 @@ type Coord        = (Int, Int)  noDbgSites :: SiteMap
  noDbgSites = []
 +
 +-- | Returns the 'identity' jumps
 +--   Used to deal with spliced code, where we don't want breakpoints
 +#ifdef GHCI
 +lookupBogusBreakpointVal :: Name -> Maybe HValue
 +lookupBogusBreakpointVal name 
 +  | name == breakpointJumpName     = Just$ unsafeCoerce# (\_ _ _ _ a->a)
 +  | name == breakpointAutoJumpName = Just$ unsafeCoerce# (\_ _ _ _ a->a)
 +  | name == breakpointCondJumpName = Just$ unsafeCoerce# (\_ _ _ _ _ a->a)
 +  | otherwise = Nothing
 +#else 
 +lookupBogusBreakpointVal _ = Nothing
 +#endif //GHCI
 | 
