OSDN Git Service

Nathanael Nerode <neroden@gcc.gnu.org>
[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 --                                                                          --
10 --          Copyright (C) 1999-2001 Free Software Foundation, Inc.          --
11 --                                                                          --
12 -- GNAT is free software;  you can  redistribute it  and/or modify it under --
13 -- terms of the  GNU General Public License as published  by the Free Soft- --
14 -- ware  Foundation;  either version 2,  or (at your option) any later ver- --
15 -- sion.  GNAT is distributed in the hope that it will be useful, but WITH- --
16 -- OUT ANY WARRANTY;  without even the  implied warranty of MERCHANTABILITY --
17 -- or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License --
18 -- for  more details.  You should have  received  a copy of the GNU General --
19 -- Public License  distributed with GNAT;  see file COPYING.  If not, write --
20 -- to  the Free Software Foundation,  59 Temple Place - Suite 330,  Boston, --
21 -- MA 02111-1307, USA.                                                      --
22 --                                                                          --
23 -- As a special exception,  if other files  instantiate  generics from this --
24 -- unit, or you link  this unit with other files  to produce an executable, --
25 -- this  unit  does not  by itself cause  the resulting  executable  to  be --
26 -- covered  by the  GNU  General  Public  License.  This exception does not --
27 -- however invalidate  any other reasons why  the executable file  might be --
28 -- covered by the  GNU Public License.                                      --
29 --                                                                          --
30 -- GNAT was originally developed  by the GNAT team at  New York University. --
31 -- Extensive contributions were provided by Ada Core Technologies Inc.      --
32 --                                                                          --
33 ------------------------------------------------------------------------------
34
35 --  This package provides a method for generating a traceback of the
36 --  current execution location. The traceback shows the locations of
37 --  calls in the call chain, up to either the top or a designated
38 --  number of levels.
39
40 pragma Polling (Off);
41 --  We must turn polling off for this unit, because otherwise we get
42 --  elaboration circularities with System.Exception_Tables.
43
44 package System.Traceback is
45
46    ----------------
47    -- Call_Chain --
48    ----------------
49
50    procedure Call_Chain
51      (Traceback   : System.Address;
52       Max_Len     : Natural;
53       Len         : out Natural;
54       Exclude_Min : System.Address := System.Null_Address;
55       Exclude_Max : System.Address := System.Null_Address);
56    --  Store up to Max_Len code locations in Traceback, corresponding to
57    --  the current call chain.
58    --
59    --    Traceback is the address of an array of addresses where the
60    --    result will be stored.
61    --
62    --    Max_Len is the length of the Traceback array. If the call chain
63    --    is longer than this, then additional entries are discarded, and
64    --    the traceback is missing some of the highest level entries.
65    --
66    --    Len is the returned actual number of addresses stored
67    --    in the Traceback array.
68    --
69    --    Exclude_Min/Exclude_Max, if non null, provide a range of addresses
70    --    to ignore from the computation of the traceback.
71    --
72    --  On return, the Traceback array is filled in, and Len indicates
73    --  the number of stored entries. The first entry is the most recent
74    --  call, and the last entry is the highest level call.
75
76    function C_Call_Chain
77      (Traceback : System.Address;
78       Max_Len   : Natural)
79       return      Natural;
80    pragma Export (C, C_Call_Chain, "system__traceback__c_call_chain");
81    --  Version that can be used directly from C.
82
83 end System.Traceback;