1 ------------------------------------------------------------------------------
3 -- GNAT COMPILER COMPONENTS --
9 -- Copyright (C) 2001 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 2, 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 COPYING. If not, write --
19 -- to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, --
20 -- MA 02111-1307, USA. --
22 -- GNAT was originally developed by the GNAT team at New York University. --
23 -- Extensive contributions were provided by Ada Core Technologies Inc. --
25 ------------------------------------------------------------------------------
27 with Ada
.Exceptions
; use Ada
.Exceptions
;
29 with Errout
; use Errout
;
30 with Output
; use Output
;
31 with Prj
.Com
; use Prj
.Com
;
34 with Prj
.Tree
; use Prj
.Tree
;
36 package body Prj
.Pars
is
43 (Project
: out Project_Id
;
44 Project_File_Name
: String)
46 Project_Tree
: Project_Node_Id
:= Empty_Node
;
47 The_Project
: Project_Id
:= No_Project
;
50 -- Parse the main project file into a tree
53 (Project
=> Project_Tree
,
54 Project_File_Name
=> Project_File_Name
,
55 Always_Errout_Finalize
=> False);
57 -- If there were no error, process the tree
59 if Project_Tree
/= Empty_Node
then
61 (Project
=> The_Project
,
62 From_Project_Node
=> Project_Tree
,
63 Report_Error
=> null);
67 Project
:= The_Project
;
74 Write_Line
(Exception_Information
(X
));
75 Write_Str
("Exception ");
76 Write_Str
(Exception_Name
(X
));
77 Write_Line
(" raised, while processing project file");
78 Project
:= No_Project
;
85 procedure Set_Verbosity
(To
: in Verbosity
) is
87 Current_Verbosity
:= To
;