1 /****************************************************************************
3 * GNAT COMPILER COMPONENTS *
9 * Copyright (C) 2001-2011, Free Software Foundation, Inc. *
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. *
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. *
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/>. *
27 * GNAT was originally developed by the GNAT team at New York University. *
28 * Extensive contributions were provided by Ada Core Technologies Inc. *
30 ****************************************************************************/
36 /* This function will return the Ada name from the encoded form.
37 The Ada coding is done in exp_dbug.ads and this is the inverse function.
38 see exp_dbug.ads for full encoding rules, a short description is added
39 below. Objects and routines are fully handled; types are stripped of their
42 CODED_NAME is the encoded entity name.
43 ADA_NAME is a pointer to a buffer, it will receive the Ada name. A safe
44 size for this buffer is: strlen (coded_name) * 2 + 60. (60 is for the
46 VERBOSE is nonzero if more information about the entity is to be
47 added at the end of the Ada name and surrounded by ( and ). */
48 extern void __gnat_decode (const char *, char *, int);
50 /* This function will return the GNAT encodings, in a colon-separated list,
51 from the encoded form. The Ada encodings are described in exp_dbug.ads. */
52 extern void get_encoding (const char *, char *);
54 /* ada_demangle is added for COMPATIBILITY ONLY. It has the name of the
55 function used in the binutils and GDB. Always consider using __gnat_decode
56 instead of ada_demangle. Caller must free the pointer returned. */
57 extern char *ada_demangle (const char *);