2009-10-01 Tobias Burnus <burnus@net-b.de>
[official-gcc/alias-decl.git] / gcc / ada / adadecode.h
blob8ae890726db5b5cc8af4441a66671f3c65d5f221
1 /****************************************************************************
2 * *
3 * GNAT COMPILER COMPONENTS *
4 * *
5 * A D A D E C O D E *
6 * *
7 * C Header File *
8 * *
9 * Copyright (C) 2001-2009, 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 3, 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. *
17 * *
18 * As a special exception under Section 7 of GPL version 3, you are granted *
19 * additional permissions described in the GCC Runtime Library Exception, *
20 * version 3.1, as published by the Free Software Foundation. *
21 * *
22 * You should have received a copy of the GNU General Public License and *
23 * a copy of the GCC Runtime Library Exception along with this program; *
24 * see the files COPYING3 and COPYING.RUNTIME respectively. If not, see *
25 * <http://www.gnu.org/licenses/>. *
26 * *
27 * GNAT was originally developed by the GNAT team at New York University. *
28 * Extensive contributions were provided by Ada Core Technologies Inc. *
29 * *
30 ****************************************************************************/
32 /* This function will return the Ada name from the encoded form.
33 The Ada coding is done in exp_dbug.ads and this is the inverse function.
34 see exp_dbug.ads for full encoding rules, a short description is added
35 below. Objects and routines are fully handled; types are stripped of their
36 encodings.
38 CODED_NAME is the encoded entity name.
39 ADA_NAME is a pointer to a buffer, it will receive the Ada name. A safe
40 size for this buffer is: strlen (coded_name) * 2 + 60. (60 is for the
41 verbose information).
42 VERBOSE is nonzero if more information about the entity is to be
43 added at the end of the Ada name and surrounded by ( and ). */
44 extern void __gnat_decode (const char *, char *, int);
46 /* This function will return the GNAT encodings, in a colon-separated list,
47 from the encoded form. The Ada encodings are described in exp_dbug.ads. */
48 extern void get_encoding (const char *, char *);
50 /* ada_demangle is added for COMPATIBILITY ONLY. It has the name of the
51 function used in the binutils and GDB. Always consider using __gnat_decode
52 instead of ada_demangle. Caller must free the pointer returned. */
53 extern char *ada_demangle (const char *);