aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorArnaud Charlet <charlet@gcc.gnu.org>2014-02-19 15:40:26 +0100
committerArnaud Charlet <charlet@gcc.gnu.org>2014-02-19 15:40:26 +0100
commitedbd98c4cbdef1063e6cc12a8568d2d1e3dbeebb (patch)
tree485a9fb3db67b459864c3a394d0f406abb061712 /gcc
parentfd9710dc68bedffca930e64e0fc76149b03a18af (diff)
downloadgcc-edbd98c4cbdef1063e6cc12a8568d2d1e3dbeebb.zip
gcc-edbd98c4cbdef1063e6cc12a8568d2d1e3dbeebb.tar.gz
gcc-edbd98c4cbdef1063e6cc12a8568d2d1e3dbeebb.tar.bz2
[multiple changes]
2014-02-19 Robert Dewar <dewar@adacore.com> * sem_ch3.adb, style.adb, sem_prag.adb, sem_ch13.adb: Minor reformatting * a-sequio.adb: Remove useless pragma Extensions_Allowed (no longer needed). 2014-02-19 Claire Dross <dross@adacore.com> * a-cfdlli.ads, a-cfhase.ads, a-cforma.ads, a-cfhama.ads, a-cforse.ads, a-cofove.ads: Add Iterable aspect to formal containers. From-SVN: r207900
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ada/ChangeLog11
-rw-r--r--gcc/ada/a-cfdlli.ads6
-rw-r--r--gcc/ada/a-cfhama.ads6
-rw-r--r--gcc/ada/a-cfhase.ads6
-rw-r--r--gcc/ada/a-cforma.ads6
-rw-r--r--gcc/ada/a-cforse.ads6
-rw-r--r--gcc/ada/a-cofove.ads6
-rw-r--r--gcc/ada/a-sequio.adb9
-rw-r--r--gcc/ada/sem_ch13.adb18
-rw-r--r--gcc/ada/sem_ch3.adb4
-rw-r--r--gcc/ada/sem_prag.adb4
-rw-r--r--gcc/ada/style.adb3
12 files changed, 57 insertions, 28 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index 567aa0d..c25c5a5 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,3 +1,14 @@
+2014-02-19 Robert Dewar <dewar@adacore.com>
+
+ * sem_ch3.adb, style.adb, sem_prag.adb, sem_ch13.adb: Minor reformatting
+ * a-sequio.adb: Remove useless pragma Extensions_Allowed (no
+ longer needed).
+
+2014-02-19 Claire Dross <dross@adacore.com>
+
+ * a-cfdlli.ads, a-cfhase.ads, a-cforma.ads, a-cfhama.ads,
+ a-cforse.ads, a-cofove.ads: Add Iterable aspect to formal containers.
+
2014-02-19 Hristian Kirtchev <kirtchev@adacore.com>
* sem_ch3.adb (Analyze_Declarations): Analyze
diff --git a/gcc/ada/a-cfdlli.ads b/gcc/ada/a-cfdlli.ads
index 54f1886..7b19f1d 100644
--- a/gcc/ada/a-cfdlli.ads
+++ b/gcc/ada/a-cfdlli.ads
@@ -63,7 +63,11 @@ package Ada.Containers.Formal_Doubly_Linked_Lists is
pragma Annotate (GNATprove, External_Axiomatization);
pragma Pure;
- type List (Capacity : Count_Type) is private;
+ type List (Capacity : Count_Type) is private with
+ Iterable => (First => First,
+ Next => Next,
+ Has_Element => Has_Element,
+ Element => Element);
pragma Preelaborable_Initialization (List);
type Cursor is private;
diff --git a/gcc/ada/a-cfhama.ads b/gcc/ada/a-cfhama.ads
index 71eed2b..16a9505 100644
--- a/gcc/ada/a-cfhama.ads
+++ b/gcc/ada/a-cfhama.ads
@@ -67,7 +67,11 @@ package Ada.Containers.Formal_Hashed_Maps is
pragma Annotate (GNATprove, External_Axiomatization);
pragma Pure;
- type Map (Capacity : Count_Type; Modulus : Hash_Type) is private;
+ type Map (Capacity : Count_Type; Modulus : Hash_Type) is private with
+ Iterable => (First => First,
+ Next => Next,
+ Has_Element => Has_Element,
+ Element => Element);
pragma Preelaborable_Initialization (Map);
type Cursor is private;
diff --git a/gcc/ada/a-cfhase.ads b/gcc/ada/a-cfhase.ads
index a3fc63d..fc02e04 100644
--- a/gcc/ada/a-cfhase.ads
+++ b/gcc/ada/a-cfhase.ads
@@ -69,7 +69,11 @@ package Ada.Containers.Formal_Hashed_Sets is
pragma Annotate (GNATprove, External_Axiomatization);
pragma Pure;
- type Set (Capacity : Count_Type; Modulus : Hash_Type) is private;
+ type Set (Capacity : Count_Type; Modulus : Hash_Type) is private with
+ Iterable => (First => First,
+ Next => Next,
+ Has_Element => Has_Element,
+ Element => Element);
pragma Preelaborable_Initialization (Set);
type Cursor is private;
diff --git a/gcc/ada/a-cforma.ads b/gcc/ada/a-cforma.ads
index a942676..08dabf5 100644
--- a/gcc/ada/a-cforma.ads
+++ b/gcc/ada/a-cforma.ads
@@ -70,7 +70,11 @@ package Ada.Containers.Formal_Ordered_Maps is
function Equivalent_Keys (Left, Right : Key_Type) return Boolean;
- type Map (Capacity : Count_Type) is private;
+ type Map (Capacity : Count_Type) is private with
+ Iterable => (First => First,
+ Next => Next,
+ Has_Element => Has_Element,
+ Element => Element);
pragma Preelaborable_Initialization (Map);
type Cursor is private;
diff --git a/gcc/ada/a-cforse.ads b/gcc/ada/a-cforse.ads
index e935be5..bc69c1b 100644
--- a/gcc/ada/a-cforse.ads
+++ b/gcc/ada/a-cforse.ads
@@ -68,7 +68,11 @@ package Ada.Containers.Formal_Ordered_Sets is
function Equivalent_Elements (Left, Right : Element_Type) return Boolean;
- type Set (Capacity : Count_Type) is private;
+ type Set (Capacity : Count_Type) is private with
+ Iterable => (First => First,
+ Next => Next,
+ Has_Element => Has_Element,
+ Element => Element);
pragma Preelaborable_Initialization (Set);
type Cursor is private;
diff --git a/gcc/ada/a-cofove.ads b/gcc/ada/a-cofove.ads
index 313165c..17a3522 100644
--- a/gcc/ada/a-cofove.ads
+++ b/gcc/ada/a-cofove.ads
@@ -75,7 +75,11 @@ package Ada.Containers.Formal_Vectors is
subtype Capacity_Range is
Count_Type range 0 .. Count_Type (Index_Type'Last - Index_Type'First + 1);
- type Vector (Capacity : Capacity_Range) is private;
+ type Vector (Capacity : Capacity_Range) is private with
+ Iterable => (First => First,
+ Next => Next,
+ Has_Element => Has_Element,
+ Element => Element);
type Cursor is private;
pragma Preelaborable_Initialization (Cursor);
diff --git a/gcc/ada/a-sequio.adb b/gcc/ada/a-sequio.adb
index b842528..31e5d75 100644
--- a/gcc/ada/a-sequio.adb
+++ b/gcc/ada/a-sequio.adb
@@ -202,15 +202,10 @@ package body Ada.Sequential_IO is
-- buffer if Item is constrained, to check that the discriminants
-- are correct.
- pragma Extensions_Allowed (On);
- -- Needed to allow Constrained reference here
-
- if Element_Type'Has_Discriminants
- and then Item'Constrained
- then
+ if Element_Type'Has_Discriminants and then Item'Constrained then
declare
RsizS : constant SSE.Storage_Offset :=
- SSE.Storage_Offset (Rsiz - 1);
+ SSE.Storage_Offset (Rsiz - 1);
type SA is new SSE.Storage_Array (0 .. RsizS);
diff --git a/gcc/ada/sem_ch13.adb b/gcc/ada/sem_ch13.adb
index 952e770..70cf819 100644
--- a/gcc/ada/sem_ch13.adb
+++ b/gcc/ada/sem_ch13.adb
@@ -130,7 +130,7 @@ package body Sem_Ch13 is
function Get_Cursor_Type
(Aspect : Node_Id;
- Typ : Entity_Id) return Entity_Id;
+ Typ : Entity_Id) return Entity_Id;
-- Find Cursor type in scope of Typ, by locating primitive operation First.
-- For use in resolving the other primitive operations of an Iterable type.
@@ -9770,15 +9770,15 @@ package body Sem_Ch13 is
Cursor : Entity_Id;
begin
- -- If error already detected, return.
+ -- If error already detected, return
if Error_Posted (Aspect) then
return Any_Type;
end if;
- -- The cursor type for an Iterable aspect is the return type of
- -- a non-overloaded First primitive operation. Locate association
- -- for First.
+ -- The cursor type for an Iterable aspect is the return type of a
+ -- non-overloaded First primitive operation. Locate association for
+ -- First.
Assoc := First (Component_Associations (Expression (Aspect)));
First_Op := Any_Id;
@@ -9798,7 +9798,7 @@ package body Sem_Ch13 is
Cursor := Any_Type;
- -- Locate function with desired name and profile in scope of type.
+ -- Locate function with desired name and profile in scope of type
Func := First_Entity (Scope (Typ));
while Present (Func) loop
@@ -9810,7 +9810,7 @@ package body Sem_Ch13 is
then
if Cursor /= Any_Type then
Error_Msg_N
- ("Operation First for iterable type must be unique", Aspect);
+ ("Operation First for iterable type must be unique", Aspect);
return Any_Type;
else
@@ -9825,7 +9825,7 @@ package body Sem_Ch13 is
if Cursor = Any_Type then
Error_Msg_N
- ("No legal primitive operation First for Iterable type", Aspect);
+ ("No legal primitive operation First for Iterable type", Aspect);
end if;
return Cursor;
@@ -11524,7 +11524,7 @@ package body Sem_Ch13 is
Element_Id : Entity_Id;
begin
- -- If previous error aspect is unusable.
+ -- If previous error aspect is unusable
if Cursor = Any_Type then
return;
diff --git a/gcc/ada/sem_ch3.adb b/gcc/ada/sem_ch3.adb
index 98991e2..664a1da 100644
--- a/gcc/ada/sem_ch3.adb
+++ b/gcc/ada/sem_ch3.adb
@@ -9398,7 +9398,7 @@ package body Sem_Ch3 is
Error_Msg_Name_1 := Impl_Kind;
Error_Msg_N
("overriding operation& must have synchronization%",
- Subp_Alias);
+ Subp_Alias);
end if;
-- If primitive has Optional synchronization, overriding operation
@@ -9410,7 +9410,7 @@ package body Sem_Ch3 is
Error_Msg_Name_1 := Impl_Kind;
Error_Msg_N
("overriding operation& must have syncrhonization%",
- Subp_Alias);
+ Subp_Alias);
end if;
end Check_Pragma_Implemented;
diff --git a/gcc/ada/sem_prag.adb b/gcc/ada/sem_prag.adb
index b7d8674..21514bf 100644
--- a/gcc/ada/sem_prag.adb
+++ b/gcc/ada/sem_prag.adb
@@ -4651,8 +4651,7 @@ package body Sem_Prag is
Check_Grouping (Statements (HSS));
end if;
- -- The first pragma of the first topmost grouping has been
- -- found.
+ -- First pragma of the first topmost grouping has been found
elsif Is_Loop_Pragma (Stmt) then
@@ -4755,6 +4754,7 @@ package body Sem_Prag is
procedure Placement_Error (Constr : Node_Id) is
LA : constant String := " with Loop_Entry";
+
begin
if Prag_Id = Pragma_Assert then
Error_Msg_String (1 .. LA'Length) := LA;
diff --git a/gcc/ada/style.adb b/gcc/ada/style.adb
index fffcf36..d3f2d2c 100644
--- a/gcc/ada/style.adb
+++ b/gcc/ada/style.adb
@@ -260,8 +260,8 @@ package body Style is
procedure Missing_Overriding (N : Node_Id; E : Entity_Id) is
Nod : Node_Id;
- begin
+ begin
-- Perform the check on source subprograms and on subprogram instances,
-- because these can be primitives of untagged types. Note that such
-- indicators were introduced in Ada 2005.
@@ -278,7 +278,6 @@ package body Style is
and then Is_Generic_Instance (E)
then
Nod := Next (Parent (Parent (List_Containing (N))));
-
else
Nod := N;
end if;