OSDN Git Service

2008-04-08 Hristian Kirtchev <kirtchev@adacore.com>
[pf3gnuchains/gcc-fork.git] / gcc / ada / s-traceb.ads
1 ------------------------------------------------------------------------------
2 --                                                                          --
3 --                         GNAT COMPILER COMPONENTS                         --
4 --                                                                          --
5 --                     S Y S T E M . T R A C E B A C K                      --
6 --                                                                          --
7 --                                 S p e c                                  --
8 --                                                                          --
9 --          Copyright (C) 1999-2007, Free Software Foundation, Inc.         --
10 --                                                                          --
11 -- GNAT is free software;  you can  redistribute it  and/or modify it under --
12 -- terms of the  GNU General Public License as published  by the Free Soft- --
13 -- ware  Foundation;  either version 2,  or (at your option) any later ver- --
14 -- sion.  GNAT is distributed in the hope that it will be useful, but WITH- --
15 -- OUT ANY WARRANTY;  without even the  implied warranty of MERCHANTABILITY --
16 -- or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License --
17 -- for  more details.  You should have  received  a copy of the GNU General --
18 -- Public License  distributed with GNAT;  see file COPYING.  If not, write --
19 -- to  the  Free Software Foundation,  51  Franklin  Street,  Fifth  Floor, --
20 -- Boston, MA 02110-1301, USA.                                              --
21 --                                                                          --
22 -- As a special exception,  if other files  instantiate  generics from this --
23 -- unit, or you link  this unit with other files  to produce an executable, --
24 -- this  unit  does not  by itself cause  the resulting  executable  to  be --
25 -- covered  by the  GNU  General  Public  License.  This exception does not --
26 -- however invalidate  any other reasons why  the executable file  might be --
27 -- covered by the  GNU Public License.                                      --
28 --                                                                          --
29 -- GNAT was originally developed  by the GNAT team at  New York University. --
30 -- Extensive contributions were provided by Ada Core Technologies Inc.      --
31 --                                                                          --
32 ------------------------------------------------------------------------------
33
34 --  This package provides a method for generating a traceback of the
35 --  current execution location. The traceback shows the locations of
36 --  calls in the call chain, up to either the top or a designated
37 --  number of levels.
38
39 pragma Warnings (Off);
40 pragma Compiler_Unit;
41 pragma Warnings (On);
42
43 pragma Polling (Off);
44 --  We must turn polling off for this unit, because otherwise we get
45 --  elaboration circularities with System.Exception_Tables.
46
47 package System.Traceback is
48
49    ----------------
50    -- Call_Chain --
51    ----------------
52
53    procedure Call_Chain
54      (Traceback   : System.Address;
55       Max_Len     : Natural;
56       Len         : out Natural;
57       Exclude_Min : System.Address := System.Null_Address;
58       Exclude_Max : System.Address := System.Null_Address;
59       Skip_Frames : Natural := 1);
60    --  Store up to Max_Len code locations in Traceback, corresponding to
61    --  the current call chain.
62    --
63    --    Traceback is the address of an array of addresses where the
64    --    result will be stored.
65    --
66    --    Max_Len is the length of the Traceback array. If the call chain
67    --    is longer than this, then additional entries are discarded, and
68    --    the traceback is missing some of the highest level entries.
69    --
70    --    Len is the returned actual number of addresses stored
71    --    in the Traceback array.
72    --
73    --    Exclude_Min/Exclude_Max, if non null, provide a range of addresses
74    --    to ignore from the computation of the traceback.
75    --
76    --    Skip_Frames says how many of the most recent calls should at least
77    --    be excluded from the result, regardless of the exclusion bounds and
78    --    starting with this procedure itself: 1 means exclude the frame for
79    --    this procedure, 2 means 1 + exclude the frame for this procedure's
80    --    caller, ...
81    --
82    --  On return, the Traceback array is filled in, and Len indicates
83    --  the number of stored entries. The first entry is the most recent
84    --  call, and the last entry is the highest level call.
85
86    function C_Call_Chain
87      (Traceback : System.Address;
88       Max_Len   : Natural)
89       return      Natural;
90    pragma Export (C, C_Call_Chain, "system__traceback__c_call_chain");
91    --  Version that can be used directly from C
92
93 end System.Traceback;