X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.db%2Fsrc%2Forg%2Fsimantics%2Fdb%2Fprocedure%2FAsyncMultiProcedure.java;fp=bundles%2Forg.simantics.db%2Fsrc%2Forg%2Fsimantics%2Fdb%2Fprocedure%2FAsyncMultiProcedure.java;h=b07e4eef83deddd1bbb3389f70764c338bcec1a1;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.db/src/org/simantics/db/procedure/AsyncMultiProcedure.java b/bundles/org.simantics.db/src/org/simantics/db/procedure/AsyncMultiProcedure.java new file mode 100644 index 000000000..b07e4eef8 --- /dev/null +++ b/bundles/org.simantics.db/src/org/simantics/db/procedure/AsyncMultiProcedure.java @@ -0,0 +1,57 @@ +/******************************************************************************* + * Copyright (c) 2007, 2010 Association for Decentralized Information Management + * in Industry THTH ry. + * 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: + * VTT Technical Research Centre of Finland - initial API and implementation + *******************************************************************************/ +package org.simantics.db.procedure; + +import org.simantics.db.AsyncReadGraph; + +/** + * @author Antti Villberg + * + * First execute is called k times. After this finished or exception is called exactly once. + * + * @param the result object type accepted by the procedure + */ +public interface AsyncMultiProcedure { + + /** + * Invoked once for each separate result of the request with potentially + * multiple results. It shall be guaranteed that all execute + * invocations have been completed when either + * {@link #finished(AsyncReadGraph)} or + * {@link #exception(AsyncReadGraph, Throwable)} are called and that no + * execute invocations will follow afterwards. + * + * @param graph asynchronous graph access + * @param result a single result of the multiresult procedure + */ + void execute(AsyncReadGraph graph, Result result); + + /** + * Invoked after all {@link #execute(AsyncReadGraph, Object)} calls have + * been finished successfully. This method will not be invoked if case of + * errors in {@link #execute(AsyncReadGraph, Object)} or the performed + * request that provides the results to this procedure. + * + * @param graph asynchronous graph access + */ + void finished(AsyncReadGraph graph); + + /** + * If an error occurs in the processing of the database request that + * produces the results for this procedure. + * + * @param graph asynchronous graph access + * @param throwable the exception that occurred + */ + void exception(AsyncReadGraph graph, Throwable throwable); + +}