diff options
author | Matthew Heaney <heaney@adacore.com> | 2006-02-15 10:32:52 +0100 |
---|---|---|
committer | Arnaud Charlet <charlet@gcc.gnu.org> | 2006-02-15 10:32:52 +0100 |
commit | ffabcde5e102cd7cc8a283ddc89861a727226913 (patch) | |
tree | 39a55d293e0dcbbc8992be624d0eb85bc7be0307 /gcc/ada/a-cihama.adb | |
parent | 738819cdce8e966e04a3e83d305db2cfa9bdaa75 (diff) | |
download | gcc-ffabcde5e102cd7cc8a283ddc89861a727226913.zip gcc-ffabcde5e102cd7cc8a283ddc89861a727226913.tar.gz gcc-ffabcde5e102cd7cc8a283ddc89861a727226913.tar.bz2 |
a-rbtgso.adb, [...]: All explicit raise statements now include an exception message.
2006-02-13 Matthew Heaney <heaney@adacore.com>
* a-rbtgso.adb, a-crbtgo.adb, a-crbtgk.adb, a-coorse.adb,
a-cohama.adb, a-ciorse.adb, a-cihama.adb, a-cihase.adb,
a-cohase.adb: All explicit raise statements now include an exception
message.
* a-ciormu.ads, a-ciormu.adb, a-coormu.ads, a-coormu.adb
(Update_Element_Preserving_Key): renamed op to just Update_Element.
Explicit raise statements now include an exception message
* a-cihase.ads, a-cohase.ads: Removed comment.
* a-stboha.ads, a-stboha.adb, a-stfiha.ads, a-envvar.adb,
a-envvar.ads, a-swbwha.ads, a-swbwha.adb, a-swfwha.ads, a-szbzha.ads,
a-szbzha.adb, a-szfzha.ads: New files.
From-SVN: r111035
Diffstat (limited to 'gcc/ada/a-cihama.adb')
-rw-r--r-- | gcc/ada/a-cihama.adb | 147 |
1 files changed, 90 insertions, 57 deletions
diff --git a/gcc/ada/a-cihama.adb b/gcc/ada/a-cihama.adb index 3a78e8e..04c9c6b 100644 --- a/gcc/ada/a-cihama.adb +++ b/gcc/ada/a-cihama.adb @@ -186,7 +186,7 @@ package body Ada.Containers.Indefinite_Hashed_Maps is Key_Ops.Delete_Key_Sans_Free (Container.HT, Key, X); if X = null then - raise Constraint_Error; + raise Constraint_Error with "attempt to delete key not in map"; end if; Free (X); @@ -194,20 +194,23 @@ package body Ada.Containers.Indefinite_Hashed_Maps is procedure Delete (Container : in out Map; Position : in out Cursor) is begin - pragma Assert (Vet (Position), "bad cursor in Delete"); - if Position.Node = null then - raise Constraint_Error; + raise Constraint_Error with + "Position cursor of Delete equals No_Element"; end if; if Position.Container /= Container'Unrestricted_Access then - raise Program_Error; + raise Program_Error with + "Position cursor of Delete designates wrong map"; end if; if Container.HT.Busy > 0 then - raise Program_Error; + raise Program_Error with + "Delete attempted to tamper with elements (map is busy)"; end if; + pragma Assert (Vet (Position), "bad cursor in Delete"); + HT_Ops.Delete_Node_Sans_Free (Container.HT, Position.Node); Free (Position.Node); @@ -223,7 +226,8 @@ package body Ada.Containers.Indefinite_Hashed_Maps is begin if Node = null then - raise Constraint_Error; + raise Constraint_Error with + "no element available because key not in map"; end if; return Node.Element.all; @@ -231,16 +235,18 @@ package body Ada.Containers.Indefinite_Hashed_Maps is function Element (Position : Cursor) return Element_Type is begin - pragma Assert (Vet (Position), "bad cursor in function Element"); - if Position.Node = null then - raise Constraint_Error; + raise Constraint_Error with + "Position cursor of function Element equals No_Element"; end if; if Position.Node.Element = null then - raise Program_Error; + raise Program_Error with + "Position cursor of function Element is bad"; end if; + pragma Assert (Vet (Position), "bad cursor in function Element"); + return Position.Node.Element.all; end Element; @@ -262,21 +268,29 @@ package body Ada.Containers.Indefinite_Hashed_Maps is function Equivalent_Keys (Left, Right : Cursor) return Boolean is begin - pragma Assert (Vet (Left), "bad Left cursor in Equivalent_Keys"); - pragma Assert (Vet (Right), "bad Right cursor in Equivalent_Keys"); + if Left.Node = null then + raise Constraint_Error with + "Left cursor of Equivalent_Keys equals No_Element"; + end if; - if Left.Node = null - or else Right.Node = null - then - raise Constraint_Error; + if Right.Node = null then + raise Constraint_Error with + "Right cursor of Equivalent_Keys equals No_Element"; end if; - if Left.Node.Key = null - or else Right.Node.Key = null - then - raise Program_Error; + if Left.Node.Key = null then + raise Program_Error with + "Left cursor of Equivalent_Keys is bad"; + end if; + + if Right.Node.Key = null then + raise Program_Error with + "Right cursor of Equivalent_Keys is bad"; end if; + pragma Assert (Vet (Left), "bad Left cursor in Equivalent_Keys"); + pragma Assert (Vet (Right), "bad Right cursor in Equivalent_Keys"); + return Equivalent_Keys (Left.Node.Key.all, Right.Node.Key.all); end Equivalent_Keys; @@ -285,16 +299,18 @@ package body Ada.Containers.Indefinite_Hashed_Maps is Right : Key_Type) return Boolean is begin - pragma Assert (Vet (Left), "bad Left cursor in Equivalent_Keys"); - if Left.Node = null then - raise Constraint_Error; + raise Constraint_Error with + "Left cursor of Equivalent_Keys equals No_Element"; end if; if Left.Node.Key = null then - raise Program_Error; + raise Program_Error with + "Left cursor of Equivalent_Keys is bad"; end if; + pragma Assert (Vet (Left), "bad Left cursor in Equivalent_Keys"); + return Equivalent_Keys (Left.Node.Key.all, Right); end Equivalent_Keys; @@ -303,16 +319,18 @@ package body Ada.Containers.Indefinite_Hashed_Maps is Right : Cursor) return Boolean is begin - pragma Assert (Vet (Right), "bad Right cursor in Equivalent_Keys"); - if Right.Node = null then - raise Constraint_Error; + raise Constraint_Error with + "Right cursor of Equivalent_Keys equals No_Element"; end if; if Right.Node.Key = null then - raise Program_Error; + raise Program_Error with + "Right cursor of Equivalent_Keys is bad"; end if; + pragma Assert (Vet (Right), "bad Right cursor in Equivalent_Keys"); + return Equivalent_Keys (Left, Right.Node.Key.all); end Equivalent_Keys; @@ -472,7 +490,8 @@ package body Ada.Containers.Indefinite_Hashed_Maps is if not Inserted then if Container.HT.Lock > 0 then - raise Program_Error; + raise Program_Error with + "Include attempted to tamper with cursors (map is locked)"; end if; K := Position.Node.Key; @@ -559,7 +578,8 @@ package body Ada.Containers.Indefinite_Hashed_Maps is Insert (Container, Key, New_Item, Position, Inserted); if not Inserted then - raise Constraint_Error; + raise Constraint_Error with + "attempt to insert key already in map"; end if; end Insert; @@ -607,16 +627,18 @@ package body Ada.Containers.Indefinite_Hashed_Maps is function Key (Position : Cursor) return Key_Type is begin - pragma Assert (Vet (Position), "bad cursor in function Key"); - if Position.Node = null then - raise Constraint_Error; + raise Constraint_Error with + "Position cursor of function Key equals No_Element"; end if; if Position.Node.Key = null then - raise Program_Error; + raise Program_Error with + "Position cursor of function Key is bad"; end if; + pragma Assert (Vet (Position), "bad cursor in function Key"); + return Position.Node.Key.all; end Key; @@ -657,8 +679,6 @@ package body Ada.Containers.Indefinite_Hashed_Maps is function Next (Position : Cursor) return Cursor is begin - pragma Assert (Vet (Position), "bad cursor in function Next"); - if Position.Node = null then return No_Element; end if; @@ -666,9 +686,11 @@ package body Ada.Containers.Indefinite_Hashed_Maps is if Position.Node.Key = null or else Position.Node.Element = null then - raise Program_Error; + raise Program_Error with "Position cursor of Next is bad"; end if; + pragma Assert (Vet (Position), "Position cursor of Next is bad"); + declare HT : Hash_Table_Type renames Position.Container.HT; Node : constant Node_Access := HT_Ops.Next (HT, Position.Node); @@ -692,18 +714,20 @@ package body Ada.Containers.Indefinite_Hashed_Maps is Element : Element_Type)) is begin - pragma Assert (Vet (Position), "bad cursor in Query_Element"); - if Position.Node = null then - raise Constraint_Error; + raise Constraint_Error with + "Position cursor of Query_Element equals No_Element"; end if; if Position.Node.Key = null or else Position.Node.Element = null then - raise Program_Error; + raise Program_Error with + "Position cursor of Query_Element is bad"; end if; + pragma Assert (Vet (Position), "bad cursor in Query_Element"); + declare M : Map renames Position.Container.all; HT : Hash_Table_Type renames M.HT'Unrestricted_Access.all; @@ -752,7 +776,7 @@ package body Ada.Containers.Indefinite_Hashed_Maps is Item : out Cursor) is begin - raise Program_Error; + raise Program_Error with "attempt to stream map cursor"; end Read; --------------- @@ -801,11 +825,13 @@ package body Ada.Containers.Indefinite_Hashed_Maps is begin if Node = null then - raise Constraint_Error; + raise Constraint_Error with + "attempt to replace key not in map"; end if; if Container.HT.Lock > 0 then - raise Program_Error; + raise Program_Error with + "Replace attempted to tamper with cursors (map is locked)"; end if; K := Node.Key; @@ -835,26 +861,30 @@ package body Ada.Containers.Indefinite_Hashed_Maps is New_Item : Element_Type) is begin - pragma Assert (Vet (Position), "bad cursor in Replace_Element"); - if Position.Node = null then - raise Constraint_Error; + raise Constraint_Error with + "Position cursor of Replace_Element equals No_Element"; end if; if Position.Node.Key = null or else Position.Node.Element = null then - raise Program_Error; + raise Program_Error with + "Position cursor of Replace_Element is bad"; end if; if Position.Container /= Container'Unrestricted_Access then - raise Program_Error; + raise Program_Error with + "Position cursor of Replace_Element designates wrong map"; end if; if Position.Container.HT.Lock > 0 then - raise Program_Error; + raise Program_Error with + "Replace_Element attempted to tamper with cursors (map is locked)"; end if; + pragma Assert (Vet (Position), "bad cursor in Replace_Element"); + declare X : Element_Access := Position.Node.Element; @@ -896,22 +926,25 @@ package body Ada.Containers.Indefinite_Hashed_Maps is Element : in out Element_Type)) is begin - pragma Assert (Vet (Position), "bad cursor in Update_Element"); - if Position.Node = null then - raise Constraint_Error; + raise Constraint_Error with + "Position cursor of Update_Element equals No_Element"; end if; if Position.Node.Key = null or else Position.Node.Element = null then - raise Program_Error; + raise Program_Error with + "Position cursor of Update_Element is bad"; end if; if Position.Container /= Container'Unrestricted_Access then - raise Program_Error; + raise Program_Error with + "Position cursor of Update_Element designates wrong map"; end if; + pragma Assert (Vet (Position), "bad cursor in Update_Element"); + declare HT : Hash_Table_Type renames Container.HT; @@ -1021,7 +1054,7 @@ package body Ada.Containers.Indefinite_Hashed_Maps is Item : Cursor) is begin - raise Program_Error; + raise Program_Error with "attempt to stream map cursor"; end Write; ---------------- |