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------------------------------------------------------------------------------ 25 26-- Processing for expanding intrinsic subprogram calls 27 28with Namet; use Namet; 29with Types; use Types; 30 31package Exp_Intr is 32 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. 43 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. 51 52end Exp_Intr; 53