/******************************************************************************* * 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.adaption; import org.simantics.db.AsyncReadGraph; import org.simantics.db.ReadGraph; import org.simantics.db.Resource; import org.simantics.db.exception.DatabaseException; import org.simantics.db.procedure.AsyncProcedure; public interface AdaptionService { T adapt(ReadGraph g, Resource r, C context, Class contextClass, Class targetClass, boolean possible) throws DatabaseException; void adapt(AsyncReadGraph g, Resource r, C context, Class contextClass, Class targetClass, boolean possible, AsyncProcedure procedure); void adaptNew(AsyncReadGraph g, Resource r, Class clazz, boolean possible, AsyncProcedure procedure); void declareAdapter(Resource type, Class targetClass); void declareAdapter(Resource type, Class targetClass, Class contextClass); void addAdapter(Resource type, Class targetClass, Adapter adapter); void addAdapter(Resource type, Class targetClass, Class contextClass, Adapter adapter); void addInstanceAdapter(Resource resource, Class targetClass, Adapter adapter); void addInstanceAdapter(Resource resource, Class targetClass, Class contextClass, Adapter adapter); /** * Remove instance adapter to specified class for specified resource, * regardless of the currently installed adapter. * * @param the adaptation target type * @param resource the resource from which to remove the adapter * @param clazz the target class of the adapter to be removed * @return the removed adapter or null if no adapter was * installed */ Adapter removeInstanceAdapter(Resource resource, Class clazz); Adapter removeInstanceAdapter(Resource resource, Class clazz, Class contextClass); /** * Remove instance adapter to specified class for specified resource * if the currently installed adapter matches the specified adapter. * * @param the adaptation target type * @param resource the resource from which to remove the adapter * @param clazz the target class of the adapter to be removed * @param adapter the adapter to remove */ void removeInstanceAdapter(Resource resource, Class clazz, Adapter adapter); void removeInstanceAdapter(Resource resource, Class clazz, Class contextClass, Adapter adapter); }