diff options
author | Robert Dewar <dewar@adacore.com> | 2006-02-15 10:36:57 +0100 |
---|---|---|
committer | Arnaud Charlet <charlet@gcc.gnu.org> | 2006-02-15 10:36:57 +0100 |
commit | 1f6a2b51d1d0c2a3a835cc47d34c0c52b0f56945 (patch) | |
tree | 9648ffa2fef61a47fdbcd90b5f5de65b15f23b2d /gcc | |
parent | 61dddae4e72e300597afeff4b081114a25598c5f (diff) | |
download | gcc-1f6a2b51d1d0c2a3a835cc47d34c0c52b0f56945.zip gcc-1f6a2b51d1d0c2a3a835cc47d34c0c52b0f56945.tar.gz gcc-1f6a2b51d1d0c2a3a835cc47d34c0c52b0f56945.tar.bz2 |
opt.ads opt.adb: Add Ada_Version_Explicit_Config along with save/restore routines.
2006-02-13 Robert Dewar <dewar@adacore.com>
Serguei Rybin <rybin@adacore.com>
* opt.ads opt.adb: Add Ada_Version_Explicit_Config along with
save/restore routines.
Properly handle Ada_Version_Explicit and Ada_Version_Config, which
were not always properly handled previously.
Since we are changing the tree format anyway, also get rid of the
junk obsolete Immediate_Errors flag.
(Tree_Read): Change the way of reading Tree_Version_String - now we
read the version string from the tree even if its length is not the
same as the length of the version string computed from Gnatvsn.
(Search_Directory_Present): New Boolean flag for the compiler.
Define Tree_Version_String as a dynamic string.
(Default_Stack_Size): new variable, used to handle switch -d.
* par-prag.adb:
For pragma Ada_2005, remove stuff about setting Ada_Version_Explicit
only for main unit.
Add pragma Ada_2005 (synonym for Ada_05)
Properly handle Ada_Version_Explicit and Ada_Version_Config, which
were not always properly handled previously.
* directio.ads, ioexcept.ads, sequenio.ads, text_io.ads: Change
explicit Ada_95 to Ada_2005.
From-SVN: r111054
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ada/directio.ads | 7 | ||||
-rw-r--r-- | gcc/ada/ioexcept.ads | 8 | ||||
-rw-r--r-- | gcc/ada/opt.adb | 46 | ||||
-rw-r--r-- | gcc/ada/opt.ads | 52 | ||||
-rw-r--r-- | gcc/ada/par-prag.adb | 12 | ||||
-rw-r--r-- | gcc/ada/sequenio.ads | 7 | ||||
-rw-r--r-- | gcc/ada/text_io.ads | 7 |
7 files changed, 89 insertions, 50 deletions
diff --git a/gcc/ada/directio.ads b/gcc/ada/directio.ads index 48068c6..c8239ec 100644 --- a/gcc/ada/directio.ads +++ b/gcc/ada/directio.ads @@ -13,7 +13,12 @@ -- -- ------------------------------------------------------------------------------ -pragma Ada_95; +pragma Ada_2005; +-- Explicit setting of Ada 2005 mode is required here, since we want to with a +-- child unit (not possible in Ada 83 mode), and Text_IO is not considered to +-- be an internal unit that is automatically compiled in Ada 2005 mode (since +-- a user is allowed to redeclare Direct_IO). + with Ada.Direct_IO; generic package Direct_IO renames Ada.Direct_IO; diff --git a/gcc/ada/ioexcept.ads b/gcc/ada/ioexcept.ads index c34e36d..548fd37 100644 --- a/gcc/ada/ioexcept.ads +++ b/gcc/ada/ioexcept.ads @@ -13,6 +13,12 @@ -- -- ------------------------------------------------------------------------------ -pragma Ada_95; +pragma Ada_2005; +-- Explicit setting of Ada 2005 mode is required here, since we want to with a +-- child unit (not possible in Ada 83 mode), and Text_IO is not considered to +-- be an internal unit that is automatically compiled in Ada 2005 mode (since +-- a user is allowed to redeclare IO_Exceptions). + with Ada.IO_Exceptions; + package IO_Exceptions renames Ada.IO_Exceptions; diff --git a/gcc/ada/opt.adb b/gcc/ada/opt.adb index 576c0d8..8c11718 100644 --- a/gcc/ada/opt.adb +++ b/gcc/ada/opt.adb @@ -6,7 +6,7 @@ -- -- -- B o d y -- -- -- --- Copyright (C) 1992-2005, Free Software Foundation, Inc. -- +-- Copyright (C) 1992-2006, Free Software Foundation, Inc. -- -- -- -- GNAT is free software; you can redistribute it and/or modify it under -- -- terms of the GNU General Public License as published by the Free Soft- -- @@ -31,17 +31,12 @@ -- -- ------------------------------------------------------------------------------ +with Gnatvsn; use Gnatvsn; with System; use System; with Tree_IO; use Tree_IO; package body Opt is - Immediate_Errors : Boolean := True; - -- This is an obsolete flag that is no longer present in opt.ads. We - -- retain it here because this flag was written to the tree and there - -- is no point in making trees incomaptible just for the sake of saving - -- one byte of data. The value written is ignored. - ---------------------------------- -- Register_Opt_Config_Switches -- ---------------------------------- @@ -114,6 +109,11 @@ package body Opt is -- Case of internal unit if Internal_Unit then + + -- Set standard switches. Note we do NOT set Ada_Version_Explicit + -- since the whole point of this is that it still properly indicates + -- the configuration setting even in a run time unit. + Ada_Version := Ada_Version_Runtime; Dynamic_Elaboration_Checks := False; Extensions_Allowed := True; @@ -126,10 +126,10 @@ package body Opt is -- is the main unit and they were explicitly enabled. if Main_Unit then - Assertions_Enabled := Assertions_Enabled_Config; + Assertions_Enabled := Assertions_Enabled_Config; Debug_Pragmas_Enabled := Debug_Pragmas_Enabled_Config; else - Assertions_Enabled := False; + Assertions_Enabled := False; Debug_Pragmas_Enabled := False; end if; @@ -137,6 +137,7 @@ package body Opt is else Ada_Version := Ada_Version_Config; + Ada_Version_Explicit := Ada_Version_Explicit_Config; Assertions_Enabled := Assertions_Enabled_Config; Debug_Pragmas_Enabled := Debug_Pragmas_Enabled_Config; Dynamic_Elaboration_Checks := Dynamic_Elaboration_Checks_Config; @@ -149,7 +150,6 @@ package body Opt is Exception_Locations_Suppressed := Exception_Locations_Suppressed_Config; Polling_Required := Polling_Required_Config; - Ada_Version_Explicit := Ada_Version_Explicit_Config; end Set_Opt_Config_Switches; --------------- @@ -189,28 +189,22 @@ package body Opt is Assertions_Enabled_Config := Boolean'Val (Assertions_Enabled_Config_Val); - -- Read version string: we have to check the length first + -- Read version string: we have to get the length first Tree_Read_Int (Tree_Version_String_Len); - if Tree_Version_String_Len = Tree_Version_String'Length then + declare + Tmp : String (1 .. Integer (Tree_Version_String_Len)); + begin Tree_Read_Data - (Tree_Version_String'Address, Tree_Version_String_Len); - else - Tree_Version_String := (others => '?'); - - declare - Tmp : String (1 .. Integer (Tree_Version_String_Len)); - begin - Tree_Read_Data - (Tmp'Address, Tree_Version_String_Len); - end; - - end if; + (Tmp'Address, Tree_Version_String_Len); + GNAT.Strings.Free (Tree_Version_String); + Free (Tree_Version_String); + Tree_Version_String := new String'(Tmp); + end; Tree_Read_Data (Distribution_Stub_Mode'Address, Distribution_Stub_Mode_Type'Object_Size / Storage_Unit); - Tree_Read_Bool (Immediate_Errors); Tree_Read_Bool (Inline_Active); Tree_Read_Bool (Inline_Processing_Required); Tree_Read_Bool (List_Units); @@ -231,6 +225,7 @@ package body Opt is procedure Tree_Write is Version_String : String := Gnat_Version_String; + begin Tree_Write_Int (ASIS_Version_Number); Tree_Write_Bool (Brief_Output); @@ -255,7 +250,6 @@ package body Opt is Version_String'Length); Tree_Write_Data (Distribution_Stub_Mode'Address, Distribution_Stub_Mode_Type'Object_Size / Storage_Unit); - Tree_Write_Bool (Immediate_Errors); Tree_Write_Bool (Inline_Active); Tree_Write_Bool (Inline_Processing_Required); Tree_Write_Bool (List_Units); diff --git a/gcc/ada/opt.ads b/gcc/ada/opt.ads index f125939..0db00ea 100644 --- a/gcc/ada/opt.ads +++ b/gcc/ada/opt.ads @@ -6,7 +6,7 @@ -- -- -- S p e c -- -- -- --- Copyright (C) 1992-2005, Free Software Foundation, Inc. -- +-- Copyright (C) 1992-2006, Free Software Foundation, Inc. -- -- -- -- GNAT is free software; you can redistribute it and/or modify it under -- -- terms of the GNU General Public License as published by the Free Soft- -- @@ -36,7 +36,6 @@ -- other GNAT tools. The comments indicate which options are used by which -- programs (GNAT, GNATBIND, GNATLINK, GNATMAKE, GPRMAKE, etc). -with Gnatvsn; use Gnatvsn; with Hostparm; use Hostparm; with Types; use Types; @@ -51,7 +50,7 @@ package Opt is -- The following mode values represent the current state of processing. -- The values set here are the default values. Unless otherwise noted, - -- the value may be reset in Switch with an appropropiate switch. In + -- the value may be reset in Switch-? with an appropropiate switch. In -- some cases, the values can also be modified by pragmas, and in the -- case of some binder variables, Gnatbind.Scan_Bind_Arg may modify -- the default values. @@ -93,13 +92,13 @@ package Opt is -- not Ada_Version_Explicit) when compiling predefined or internal units. Ada_Final_Suffix : constant String := "final"; - Ada_Final_Name : String_Ptr := new String'("ada" & Ada_Final_Suffix); + Ada_Final_Name : String_Ptr := new String'("ada" & Ada_Final_Suffix); -- GNATBIND -- The name of the procedure that performs the finalization at the end of -- execution. This variable may be modified by Gnatbind.Scan_Bind_Arg. Ada_Init_Suffix : constant String := "init"; - Ada_Init_Name : String_Ptr := new String'("ada" & Ada_Init_Suffix); + Ada_Init_Name : String_Ptr := new String'("ada" & Ada_Init_Suffix); -- GNATBIND -- The name of the procedure that performs initialization at the start -- of execution. This variable may be modified by Gnatbind.Scan_Bind_Arg. @@ -300,9 +299,15 @@ package Opt is -- Set the default exit status value. Set by the -Xnnn switch for the -- binder. + Default_Stack_Size : Int := -1; + -- GNATBIND + -- Set to default primary stack size in units of bytes. Set by + -- the -dnnn switch for the binder. A value of -1 indicates that no + -- default was set by the binder. + Default_Sec_Stack_Size : Int := -1; -- GNATBIND - -- Set to default secondary stack size in units of kilobytes. Set by + -- Set to default secondary stack size in units of bytes. Set by -- the -Dnnn switch for the binder. A value of -1 indicates that no -- default was set by the binder, and that the default should be the -- initial value of System.Secondary_Stack.Default_Secondary_Stack_Size. @@ -857,6 +862,15 @@ package Opt is -- GNATMAKE, GNATLINK -- Set to False when no run_path_option should be issued to the linker + Search_Directory_Present : Boolean := False; + -- GNAT + -- Set to True when argument is -I. Reset to False when next argument, + -- a search directory path is taken into account. Note that this is + -- quite different from other switches in this section in that it is + -- only set in a transitory manner as a result of scanning a -I switch + -- with no file name, and if set, is an indication that the next argument + -- is to be treated as a file name. + Sec_Stack_Used : Boolean := False; -- GNAT, GBATBIND -- Set True if generated code uses the System.Secondary_Stack package. @@ -1161,8 +1175,10 @@ package Opt is Ada_Version_Explicit_Config : Ada_Version_Type; -- GNAT - -- Same as above but used to initialize Ada_Version_Explicit. Currently - -- this will always have the same value as Ada_Version_Config. + -- This is set in the same manner as Ada_Version_Config. The difference is + -- that the setting of this flag is not ignored for internal and predefined + -- units, which for some purposes do indeed access this value, regardless + -- of the fact that they are compiled the the most up to date ada version). Assertions_Enabled_Config : Boolean; -- GNAT @@ -1306,13 +1322,14 @@ package Opt is -- tree, and they are supposed to be compared with the corresponding values -- from the Gnatvsn package which is a part of ASIS implementation. - Tree_Version_String : String (Gnat_Version_String'Range); + Tree_Version_String : String_Access; -- Used to store the compiler version string read from a tree file to check - -- if it is the same as stored in the version string in Gnatvsn. Therefore - -- its length is taken directly from the version string in Gnatvsn. If the - -- length of the version string stored in the tree is different, then - -- versions are for sure different, and a string containing '?' characters - -- is assigned to this variable as a result of tree read. + -- if it is from the same date as stored in the version string in Gnatvsn. + -- We require that ASIS Pro can be used only with GNAT Pro, but we allow + -- non-Pro ASIS and ASIS-based tools to be used with any version of the + -- GNAT compiler. Therefore, we need the possibility to compare the dates + -- of the corresponding source sets, using version strings that may be + -- of different lengths. Tree_ASIS_Version_Number : Int; -- Used to store the ASIS version number read from a tree file to check if @@ -1320,6 +1337,13 @@ package Opt is private + -- The following type is used to save and restore settings of switches in + -- Opt that represent the configuration (i.e. result of config pragmas). + + -- Note that Ada_Version_Explicit is not included, since this is a sticky + -- flag that once set does not get reset, since the whole idea of this flag + -- is to record the setting for the main unit. + type Config_Switches_Type is record Ada_Version : Ada_Version_Type; Ada_Version_Explicit : Ada_Version_Type; diff --git a/gcc/ada/par-prag.adb b/gcc/ada/par-prag.adb index 7489d9d..7646f6e 100644 --- a/gcc/ada/par-prag.adb +++ b/gcc/ada/par-prag.adb @@ -6,7 +6,7 @@ -- -- -- B o d y -- -- -- --- Copyright (C) 1992-2005, Free Software Foundation, Inc. -- +-- Copyright (C) 1992-2006, Free Software Foundation, Inc. -- -- -- -- GNAT is free software; you can redistribute it and/or modify it under -- -- terms of the GNU General Public License as published by the Free Soft- -- @@ -302,19 +302,19 @@ begin Ada_Version := Ada_95; Ada_Version_Explicit := Ada_Version; - ------------ - -- Ada_05 -- - ------------ + --------------------- + -- Ada_05/Ada_2005 -- + --------------------- -- This pragma must be processed at parse time, since we want to set -- the Ada version properly at parse time to recognize the appropriate -- Ada version syntax. However, it is only the zero argument form that -- must be processed at parse time. - when Pragma_Ada_05 => + when Pragma_Ada_05 | Pragma_Ada_2005 => if Arg_Count = 0 then Ada_Version := Ada_05; - Ada_Version_Explicit := Ada_Version; + Ada_Version_Explicit := Ada_05; end if; ----------- diff --git a/gcc/ada/sequenio.ads b/gcc/ada/sequenio.ads index f4a2726..8ea1890 100644 --- a/gcc/ada/sequenio.ads +++ b/gcc/ada/sequenio.ads @@ -13,7 +13,12 @@ -- -- ------------------------------------------------------------------------------ -pragma Ada_95; +pragma Ada_2005; +-- Explicit setting of Ada 2005 mode is required here, since we want to with a +-- child unit (not possible in Ada 83 mode), and Text_IO is not considered to +-- be an internal unit that is automatically compiled in Ada 2005 mode (since +-- a user is allowed to redeclare Sequential_IO). + with Ada.Sequential_IO; generic package Sequential_IO renames Ada.Sequential_IO; diff --git a/gcc/ada/text_io.ads b/gcc/ada/text_io.ads index 6b5d08c..f51e1c2 100644 --- a/gcc/ada/text_io.ads +++ b/gcc/ada/text_io.ads @@ -13,7 +13,12 @@ -- -- ------------------------------------------------------------------------------ -pragma Ada_95; +pragma Ada_2005; +-- Explicit setting of Ada 2005 mode is required here, since we want to with a +-- child unit (not possible in Ada 83 mode), and Text_IO is not considered to +-- be an internal unit that is automatically compiled in Ada 2005 mode (since +-- a user is allowed to redeclare Text_IO). + with Ada.Text_IO; package Text_IO renames Ada.Text_IO; |