2014-10-10 Robert Dewar <dewar@adacore.com>
[official-gcc.git] / gcc / ada / comperr.ads
blobdccd8ef343309b679d266e7935968d1ddae46454
1 ------------------------------------------------------------------------------
2 -- --
3 -- GNAT COMPILER COMPONENTS --
4 -- --
5 -- C O M P E R R --
6 -- --
7 -- S p e c --
8 -- --
9 -- Copyright (C) 1992-2014, 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. 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 COPYING3. If not, go to --
19 -- http://www.gnu.org/licenses for a complete copy of the license. --
20 -- --
21 -- GNAT was originally developed by the GNAT team at New York University. --
22 -- Extensive contributions were provided by Ada Core Technologies Inc. --
23 -- --
24 ------------------------------------------------------------------------------
26 -- This package contains the routine called when a fatal internal compiler
27 -- error is detected. Calls to this routines cause termination of the
28 -- current compilation with appropriate error output.
30 package Comperr is
32 procedure Compiler_Abort
33 (X : String;
34 Fallback_Loc : String := "";
35 From_GCC : Boolean := False);
36 pragma No_Return (Compiler_Abort);
37 -- Signals an internal compiler error. Never returns control. Depending on
38 -- processing may end up raising Unrecoverable_Error, or exiting directly.
39 -- The message output is a "bug box" containing the first string passed as
40 -- an argument. The Sloc field of the node in Current_Error_Node is used to
41 -- provide the location where the error should be signalled. If this Sloc
42 -- value is set to No_Location or any of the other special location values,
43 -- then the Fallback_Loc argument string is used instead. The message text
44 -- includes the node id, and the code parameter if it is positive.
46 -- Note that this is only used at the outer level (to handle constraint
47 -- errors or assert errors etc.) In the normal logic of the compiler we
48 -- always use pragma Assert to check for errors, and if necessary an
49 -- explicit abort is achieved by pragma Assert (False). From_GCC is true
50 -- for a GCC abort and false for a front end exception (with a possible
51 -- message stored in TSD.Current_Excep).
53 procedure Delete_SCIL_Files;
54 -- Delete SCIL files associated with the main unit
56 ------------------------------
57 -- Use of gnat_bug.box File --
58 ------------------------------
60 -- When comperr generates the "bug box". The first two lines contain
61 -- information on the version number, type of abort, and source location.
63 -- Normally the remaining text is one of three possible forms
64 -- depending on Gnatvsn.Gnat_Version_Type (FSF, Public, GNATPRO).
65 -- See body of this package for the exact text used.
67 -- In addition, an alternative mechanism exists for easily substituting
68 -- different text for this message. Compiler_Abort checks for the
69 -- existence of the file "gnat_bug.box" in the current source path.
70 -- Most typically this file, if present, will be in the directory
71 -- containing the run-time sources.
73 -- If this file is present, then it is a plain ASCII file, whose contents
74 -- replace the remaining text. The lines in this file should be seventy-two
75 -- characters or less to avoid misformatting the right boundary of the box.
76 -- Note that the file does not contain the vertical bar characters or any
77 -- leading spaces in lines.
79 end Comperr;