2014-12-12 Marc Glisse <marc.glisse@inria.fr>
[official-gcc.git] / gcc / ada / exp_intr.ads
blobf9be797d85d157a036cad1afd51ff9e4cae68ab7
1 ------------------------------------------------------------------------------
2 -- --
3 -- GNAT COMPILER COMPONENTS --
4 -- --
5 -- E X P _ I N T 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 -- Processing for expanding intrinsic subprogram calls
28 with Namet; use Namet;
29 with Types; use Types;
31 package Exp_Intr is
33 procedure Add_Source_Info (Loc : Source_Ptr; Nam : Name_Id);
34 -- Append a string to Name_Buffer depending on Nam
35 -- Name_File - append name of source file
36 -- Name_Line - append line number
37 -- Name_Source_Location - append source location (file:line)
38 -- Name_Enclosing_Entity - append name of enclosing entity
39 -- Name_Compilation_Date - append compilation date
40 -- Name_Compilation_Time - append compilation time
41 -- The caller must set Name_Buffer and Name_Len before the call. Loc is
42 -- passed to provide location information where it is needed.
44 procedure Expand_Intrinsic_Call (N : Node_Id; E : Entity_Id);
45 -- N is either a function call node, a procedure call statement node, or
46 -- an operator where the corresponding subprogram is intrinsic (i.e. was
47 -- the subject of an Import or Interface pragma specifying the subprogram
48 -- as intrinsic. The effect is to replace the call with appropriate
49 -- specialized nodes. The second argument is the entity for the
50 -- subprogram spec.
52 end Exp_Intr;