| /** |
| * This file was copied and re-packaged automatically by |
| * org.eclipse.ocl.examples.build.GenerateAutoCSModels.mwe2 |
| * from |
| * ..\..\..\org.eclipse.qvtd\plugins\org.eclipse.qvtd.runtime\src\org\eclipse\qvtd\runtime\evaluation\Invocation.java |
| * |
| * Do not edit this file. |
| */ |
| /******************************************************************************* |
| * Copyright (c) 2013, 2015 Willink Transformations and others. |
| * All rights reserved. This program and the accompanying materials |
| * are made available under the terms of the Eclipse Public License v1.0 |
| * which accompanies this distribution, and is available at |
| * http://www.eclipse.org/legal/epl-v10.html |
| * |
| * Contributors: |
| * E.D.Willink - Initial API and implementation |
| *******************************************************************************/ |
| package org.eclipse.ocl.pivot.evaluation.tx; |
| |
| import org.eclipse.jdt.annotation.NonNull; |
| import org.eclipse.ocl.pivot.ids.IdResolver; |
| |
| /** |
| * An Invocation identifies a unique invocation of a Mapping and the objects/values bound to its guard variables. |
| * |
| * @noimplement clients should derive from AbstractInvocation |
| * @since 1.1 |
| */ |
| public interface Invocation extends ExecutionVisitable |
| { |
| /** |
| * Execute the mapping invocation, returning true if successfully executed, or false if some predicate failed. |
| * @throws InvocationFailedException if a required memory access could not be performed; a retry when ready is required |
| * @throws ReflectiveOperationException if a Java failure occurred while constructing an Invocation object |
| */ |
| boolean execute() throws InvocationFailedException, ReflectiveOperationException; |
| |
| /** |
| * Insert this Invocation following predecessor, which may be in the blocked or waiting invocations linked list. |
| */ |
| void insertAfter(@NonNull Invocation predecessor); |
| |
| /** |
| * Return true if a mapping invocation with thoseValues would be a re-invocation of this invocation. |
| */ |
| boolean isEqual(@NonNull IdResolver idResolver, @NonNull Object @NonNull [] thoseValues); |
| |
| /** |
| * Remove this Invocation from the blocked or waiting invocations linked list. |
| */ |
| void remove(); |
| |
| public interface Incremental extends Invocation |
| { |
| void addCreatedObject(@NonNull Object createdObject); |
| void addReadSlot(SlotState.@NonNull Incremental readSlot); |
| void addWriteSlot(SlotState.@NonNull Incremental writeSlot); |
| @NonNull Iterable<@NonNull Object> getCreatedObjects(); |
| @NonNull Iterable<SlotState.@NonNull Incremental> getReadSlots(); |
| @NonNull Iterable<SlotState.@NonNull Incremental> getWriteSlots(); |
| } |
| } |