Difference between revisions of "leakview"
m |
|||
Line 1: | Line 1: | ||
− | '''Leakview''' | + | '''Leakview''' allows fast navigation through [[heaptrc|HeapTrc]] leak reports. |
[[image:leakview.png]] | [[image:leakview.png]] | ||
== Usage == | == Usage == | ||
+ | The Leakview utility is available in the IDE under ''View / Leaks and Traces''. | ||
+ | |||
Leakview reads [[heaptrc]] output. For this to work, you'll need to enable heaptrc in your code:<br> | Leakview reads [[heaptrc]] output. For this to work, you'll need to enable heaptrc in your code:<br> | ||
'''Never include heaptrc in your uses clause manually. This is done implicitly by the compiler when -gh is specified'''<br> | '''Never include heaptrc in your uses clause manually. This is done implicitly by the compiler when -gh is specified'''<br> |
Revision as of 07:18, 17 April 2017
Leakview allows fast navigation through HeapTrc leak reports.
Usage
The Leakview utility is available in the IDE under View / Leaks and Traces.
Leakview reads heaptrc output. For this to work, you'll need to enable heaptrc in your code:
Never include heaptrc in your uses clause manually. This is done implicitly by the compiler when -gh is specified
Enabling heaptrc in Lazarus
To enable this in your Lazarus project: go to Project Options/Linking and in the Debugging section enable Use Heaptrc unit (check for mem-leaks) (-gh)
You can then let the program log the output of the heaptrc unit to a file. Add the following code fragments in your .lpr, at the beginning of your code to redirect the heaptrc output to file:
{$DEFINE debug} // do this here or you can define a -dDEBUG in Project Options/Other/Custom Options, i.e. in a build mode so you can set up a Debug with leakview and a Default build mode without it
uses
...
{$IFDEF debug}
, SysUtils
{$ENDIF}
...
begin
{$IFDEF DEBUG}
// Assuming your build mode sets -dDEBUG in Project Options/Other when defining -gh
// This avoids interference when running a production/default build without -gh
// Set up -gh output for the Leakview package:
if FileExists('heap.trc') then
DeleteFile('heap.trc');
SetHeapTraceOutput('heap.trc');
{$ENDIF DEBUG}
...
end.
Enabling heaptrc in FPC
In FPC, you can specify -gh in your compiler options in fpc.cfg or on the commandline.
You can test if your binary is compiled with heaptrace by:
{$if Declared(UseHeapTrace)}...{$ifend}
Then redirect the heaptrc output to file (instead of standard output). You can use similar code to the Lazarus code or alternatively, set the environment variable, e.g. on *nix:
export HEAPTRC="log=heap.trc"
or Windows:
set HEAPTRC="log=heap.trc"