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-- A reduce action is an action that reduces a collection to a single value 47-- by combining the elements of the collection. 48------------------------------------------------------------------------------ 49with AMF.UML.Actions; 50limited with AMF.UML.Behaviors; 51limited with AMF.UML.Input_Pins; 52limited with AMF.UML.Output_Pins; 53 54package AMF.UML.Reduce_Actions is 55 56 pragma Preelaborate; 57 58 type UML_Reduce_Action is limited interface 59 and AMF.UML.Actions.UML_Action; 60 61 type UML_Reduce_Action_Access is 62 access all UML_Reduce_Action'Class; 63 for UML_Reduce_Action_Access'Storage_Size use 0; 64 65 not overriding function Get_Collection 66 (Self : not null access constant UML_Reduce_Action) 67 return AMF.UML.Input_Pins.UML_Input_Pin_Access is abstract; 68 -- Getter of ReduceAction::collection. 69 -- 70 -- The collection to be reduced. 71 72 not overriding procedure Set_Collection 73 (Self : not null access UML_Reduce_Action; 74 To : AMF.UML.Input_Pins.UML_Input_Pin_Access) is abstract; 75 -- Setter of ReduceAction::collection. 76 -- 77 -- The collection to be reduced. 78 79 not overriding function Get_Is_Ordered 80 (Self : not null access constant UML_Reduce_Action) 81 return Boolean is abstract; 82 -- Getter of ReduceAction::isOrdered. 83 -- 84 -- Tells whether the order of the input collection should determine the 85 -- order in which the behavior is applied to its elements. 86 87 not overriding procedure Set_Is_Ordered 88 (Self : not null access UML_Reduce_Action; 89 To : Boolean) is abstract; 90 -- Setter of ReduceAction::isOrdered. 91 -- 92 -- Tells whether the order of the input collection should determine the 93 -- order in which the behavior is applied to its elements. 94 95 not overriding function Get_Reducer 96 (Self : not null access constant UML_Reduce_Action) 97 return AMF.UML.Behaviors.UML_Behavior_Access is abstract; 98 -- Getter of ReduceAction::reducer. 99 -- 100 -- Behavior that is applied to two elements of the input collection to 101 -- produce a value that is the same type as elements of the collection. 102 103 not overriding procedure Set_Reducer 104 (Self : not null access UML_Reduce_Action; 105 To : AMF.UML.Behaviors.UML_Behavior_Access) is abstract; 106 -- Setter of ReduceAction::reducer. 107 -- 108 -- Behavior that is applied to two elements of the input collection to 109 -- produce a value that is the same type as elements of the collection. 110 111 not overriding function Get_Result 112 (Self : not null access constant UML_Reduce_Action) 113 return AMF.UML.Output_Pins.UML_Output_Pin_Access is abstract; 114 -- Getter of ReduceAction::result. 115 -- 116 -- Gives the output pin on which the result is put. 117 118 not overriding procedure Set_Result 119 (Self : not null access UML_Reduce_Action; 120 To : AMF.UML.Output_Pins.UML_Output_Pin_Access) is abstract; 121 -- Setter of ReduceAction::result. 122 -- 123 -- Gives the output pin on which the result is put. 124 125end AMF.UML.Reduce_Actions; 126