1 /*******************************************************************************
\r
2 * Copyright (c) 2007, 2010 Association for Decentralized Information Management
\r
3 * in Industry THTH ry.
\r
4 * All rights reserved. This program and the accompanying materials
\r
5 * are made available under the terms of the Eclipse Public License v1.0
\r
6 * which accompanies this distribution, and is available at
\r
7 * http://www.eclipse.org/legal/epl-v10.html
\r
10 * VTT Technical Research Centre of Finland - initial API and implementation
\r
11 *******************************************************************************/
\r
12 package org.simantics.db.procedure;
\r
14 import org.simantics.db.AsyncReadGraph;
\r
17 * @author Antti Villberg
\r
19 * First execute is called k times. After this finished or exception is called exactly once.
\r
21 * @param <Result> the result object type accepted by the procedure
\r
23 public interface AsyncContextMultiProcedure<Context, Result> {
\r
26 * Invoked once for each separate result of the request with potentially
\r
27 * multiple results. It shall be guaranteed that all <code>execute</code>
\r
28 * invocations have been completed when either
\r
29 * {@link #finished(AsyncReadGraph)} or
\r
30 * {@link #exception(AsyncReadGraph, Throwable)} are called and that no
\r
31 * <code>execute</code> invocations will follow afterwards.
\r
33 * @param graph asynchronous graph access
\r
34 * @param result a single result of the multiresult procedure
\r
36 void execute(AsyncReadGraph graph, Context context, Result result);
\r
39 * Invoked after all {@link #execute(AsyncReadGraph, Object)} calls have
\r
40 * been finished successfully. This method will not be invoked if case of
\r
41 * errors in {@link #execute(AsyncReadGraph, Object)} or the performed
\r
42 * request that provides the results to this procedure.
\r
44 * @param graph asynchronous graph access
\r
46 void finished(AsyncReadGraph graph);
\r
49 * If an error occurs in the processing of the database request that
\r
50 * produces the results for this procedure.
\r
52 * @param graph asynchronous graph access
\r
53 * @param throwable the exception that occurred
\r
55 void exception(AsyncReadGraph graph, Throwable throwable);
\r