/******************************************************************************* * 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.common.request; import java.util.Map; import org.simantics.db.AsyncRequestProcessor; import org.simantics.db.ChangeSetIdentifier; import org.simantics.db.Operation; import org.simantics.db.RequestProcessor; import org.simantics.db.exception.DatabaseException; import org.simantics.db.procedure.Procedure; import org.simantics.db.request.DelayedWrite; import org.simantics.db.request.UndoTraits; import org.simantics.db.request.WriteInterface; import org.simantics.utils.datastructures.Callback; /** * Usage samples: * *

* Synchronous read without checked exceptions: *

*
 * Resource r = new SimpleReadGraphRequest<Resource>(session) {
 *     {@code @Override}
 *     public Resource run(Graph g) {
 *         Resource r = doSomethingThatMayFail();
 *         return r;
 *     }
 * }.sync();
 * 
* *

* Synchronous read with a selected checked exception that may be thrown: *

*
 * Resource r = new SimpleReadGraphRequest<Resource>(session) {
 *     {@code @Override}
 *     public Resource run(Graph g) throws CheckedException {
 *         Resource r = doSomethingThatMayFailWithCheckedException();
 *         return r;
 *     }
 * }.sync(CheckedException.class);
 * 
* *

* Asynchronous read with a completed() method for examining the result: *

*
 * Resource r = new SimpleReadGraphRequest<Resource>(session) {
 *     {@code @Override}
 *     public Resource run(Graph g) {
 *         Resource r = doSomethingThatMayFail();
 *         return r;
 *     }
 *     public void completed(Resource result) {
 *         // quickly dispatch the result somewhere, do nothing serious in this code.
 *     }
 * }.async();
 * 
* * @param the result type */ public abstract class DelayedWriteRequest implements DelayedWrite, UndoTraits, WriteInterface { @Override public ChangeSetIdentifier getIdentifier() { return null; } @Override public void fillMetadata(Map metadata) { metadata.put("class=", this.getClass().getName()); } @Override public void commitOk(Operation op) { } @Override public void request(AsyncRequestProcessor processor, final Procedure procedure) { processor.asyncRequest(this, new Callback() { @Override public void run(DatabaseException parameter) { if(parameter != null) procedure.exception(parameter); else procedure.execute(null); } }); } @Override public Object request(RequestProcessor processor) throws DatabaseException { processor.syncRequest(this); return null; } }