1------------------------------------------------------------------------------
2--                                                                          --
3--                            Matreshka Project                             --
4--                                                                          --
5--                          Ada Modeling Framework                          --
6--                                                                          --
7--                        Runtime Library Component                         --
8--                                                                          --
9------------------------------------------------------------------------------
10--                                                                          --
11-- Copyright © 2011-2012, Vadim Godunko <vgodunko@gmail.com>                --
12-- All rights reserved.                                                     --
13--                                                                          --
14-- Redistribution and use in source and binary forms, with or without       --
15-- modification, are permitted provided that the following conditions       --
16-- are met:                                                                 --
17--                                                                          --
18--  * Redistributions of source code must retain the above copyright        --
19--    notice, this list of conditions and the following disclaimer.         --
20--                                                                          --
21--  * Redistributions in binary form must reproduce the above copyright     --
22--    notice, this list of conditions and the following disclaimer in the   --
23--    documentation and/or other materials provided with the distribution.  --
24--                                                                          --
25--  * Neither the name of the Vadim Godunko, IE nor the names of its        --
26--    contributors may be used to endorse or promote products derived from  --
27--    this software without specific prior written permission.              --
28--                                                                          --
29-- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS      --
30-- "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT        --
31-- LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR    --
32-- A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT     --
33-- HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,   --
34-- SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED --
35-- TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR   --
36-- PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF   --
37-- LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING     --
38-- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS       --
39-- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.             --
40--                                                                          --
41------------------------------------------------------------------------------
42--  $Revision: 2714 $ $Date: 2012-03-24 10:29:08 +0400 (Sat, 24 Mar 2012) $
43------------------------------------------------------------------------------
44--  This file is generated, don't edit it.
45------------------------------------------------------------------------------
46--  An exception handler is an element that specifies a body to execute in
47--  case the specified exception occurs during the execution of the protected
48--  node.
49------------------------------------------------------------------------------
50limited with AMF.UML.Classifiers.Collections;
51with AMF.UML.Elements;
52limited with AMF.UML.Executable_Nodes;
53limited with AMF.UML.Object_Nodes;
54
55package AMF.UML.Exception_Handlers is
56
57   pragma Preelaborate;
58
59   type UML_Exception_Handler is limited interface
60     and AMF.UML.Elements.UML_Element;
61
62   type UML_Exception_Handler_Access is
63     access all UML_Exception_Handler'Class;
64   for UML_Exception_Handler_Access'Storage_Size use 0;
65
66   not overriding function Get_Exception_Input
67    (Self : not null access constant UML_Exception_Handler)
68       return AMF.UML.Object_Nodes.UML_Object_Node_Access is abstract;
69   --  Getter of ExceptionHandler::exceptionInput.
70   --
71   --  An object node within the handler body. When the handler catches an
72   --  exception, the exception token is placed in this node, causing the body
73   --  to execute.
74
75   not overriding procedure Set_Exception_Input
76    (Self : not null access UML_Exception_Handler;
77     To   : AMF.UML.Object_Nodes.UML_Object_Node_Access) is abstract;
78   --  Setter of ExceptionHandler::exceptionInput.
79   --
80   --  An object node within the handler body. When the handler catches an
81   --  exception, the exception token is placed in this node, causing the body
82   --  to execute.
83
84   not overriding function Get_Exception_Type
85    (Self : not null access constant UML_Exception_Handler)
86       return AMF.UML.Classifiers.Collections.Set_Of_UML_Classifier is abstract;
87   --  Getter of ExceptionHandler::exceptionType.
88   --
89   --  The kind of instances that the handler catches. If an exception occurs
90   --  whose type is any of the classifiers in the set, the handler catches
91   --  the exception and executes its body.
92
93   not overriding function Get_Handler_Body
94    (Self : not null access constant UML_Exception_Handler)
95       return AMF.UML.Executable_Nodes.UML_Executable_Node_Access is abstract;
96   --  Getter of ExceptionHandler::handlerBody.
97   --
98   --  A node that is executed if the handler satisfies an uncaught exception.
99
100   not overriding procedure Set_Handler_Body
101    (Self : not null access UML_Exception_Handler;
102     To   : AMF.UML.Executable_Nodes.UML_Executable_Node_Access) is abstract;
103   --  Setter of ExceptionHandler::handlerBody.
104   --
105   --  A node that is executed if the handler satisfies an uncaught exception.
106
107   not overriding function Get_Protected_Node
108    (Self : not null access constant UML_Exception_Handler)
109       return AMF.UML.Executable_Nodes.UML_Executable_Node_Access is abstract;
110   --  Getter of ExceptionHandler::protectedNode.
111   --
112   --  The node protected by the handler. The handler is examined if an
113   --  exception propagates to the outside of the node.
114
115   not overriding procedure Set_Protected_Node
116    (Self : not null access UML_Exception_Handler;
117     To   : AMF.UML.Executable_Nodes.UML_Executable_Node_Access) is abstract;
118   --  Setter of ExceptionHandler::protectedNode.
119   --
120   --  The node protected by the handler. The handler is examined if an
121   --  exception propagates to the outside of the node.
122
123end AMF.UML.Exception_Handlers;
124