8911bc2f4e33eb712a0913360cf9ec5959ec217f
[ghc-heap-view.git] / ghc-heap-view.cabal
1 Name:                ghc-heap-view
2 Version:             0.5.6
3 Synopsis:            Extract the heap representation of Haskell values and thunks
4 Description:
5   This library provides functions to introspect the Haskell heap, for example
6   to investigate sharing and lazy evaluation. As this is tied to the internals
7   of the compiler,it only works with specific versions. Currently, GHC 7.4
8   through 7.10 should be supported.
9   .
10   It has been inspired by (and taken code from) the vacuum package and the GHCi
11   debugger, but also allows to investiage thunks and other closures. 
12   .
13   This package also provides a new GHCi-command, @:printHeap@, which allows you
14   to inspect the current heap representation of a value, including sharing and
15   cyclic references. To enable the command, you need to load the included ghci
16   script or add it to @~/.ghci@, as explained by @cabal install@. Once it is
17   set up, you can do this:
18   .
19   >> let value = "A Value"
20   >> let x = (value, if head value == 'A' then value else "", cycle [True, False])
21   >> :printHeap x
22   >let x1 = _bco
23   >    x21 = []
24   >in (x1,_bco,_bco)
25   >> length (take 100 (show x)) `seq` return () -- evaluate everything
26   >> :printHeap x
27   >let x1 = "A Value"
28   >    x16 = True : False : x16
29   >in (x1,x1,x16)
30   .
31   You can change the maximum recursion depth using @:setPrintHeapDepth@:
32   .
33   >> :setPrintHeapDepth 3
34   >> :printHeap x
35   >let x1 = C# 'A' : ... : ...
36   >in (x1,x1,True : ... : ...)
37   .
38   If the view is impaired by blackholes (written @_bh@), running
39   @System.Mem.performGC@ usually helps.
40   .
41   The work on this package has been supported by the Deutsche Telekom Stiftung
42   (<http://telekom-stiftung.de>).
43 License:             BSD3
44 License-file:        LICENSE
45 Author:              Joachim Breitner, Dennis Felsing
46 Maintainer:          Joachim Breitner <mail@joachim-breitner.de>
47 Copyright:           2012-2014 Joachim Breitner
48 bug-reports:         https://github.com/nomeata/ghc-heap-view
49 Category:            Debug, GHC
50 Build-type:          Custom
51 Cabal-version:       >=1.14
52 Extra-source-files:  Demo.hs
53 data-files:          ghci
54
55 Flag prim-supports-any
56     Description: The used GHC supports Any as an argument to foreign prim functions (GHC ticket #5931)
57     Default: False
58
59 Flag ghc_7_7
60
61 Flag ghc_8_0
62
63 Library
64   Default-Language:    Haskell2010
65   Exposed-modules:
66     GHC.HeapView
67     GHC.AssertNF
68     GHC.Disassembler
69     GHC.HeapView.Debug
70   Build-depends:
71     base >= 4.5 && < 4.10,
72     containers,
73     transformers,
74     template-haskell,
75     bytestring >= 0.10,
76     binary
77
78   if flag(ghc_7_7)
79     build-depends: ghc >= 7.7 && < 8
80     cc-options: -DGHC_7_7
81     cpp-options: -DGHC_7_7
82   else
83     if flag(ghc_8_0)
84       build-depends: ghc >= 8
85       cc-options: -DGHC_8_0
86       cpp-options: -DGHC_8_0
87     else
88       build-depends: ghc < 7.7
89
90   C-Sources: cbits/HeapView.c cbits/HeapViewPrim.cmm
91   Hs-source-dirs: src/
92   Ghc-options: -Wall
93   default-language: Haskell2010
94
95   if flag(prim-supports-any)
96     cpp-options: -DPRIM_SUPPORTS_ANY
97  
98 test-suite Test
99   type:           exitcode-stdio-1.0
100   main-is:        Test.hs
101   build-depends:  base, ghc-heap-view, deepseq
102   default-language: Haskell2010
103   Ghc-options:    -O0
104
105   
106 source-repository head
107   type:     git
108   location: git://git.nomeata.de/ghc-heap-view.git
109   subdir:   Cabal