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