X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.db%2Fsrc%2Forg%2Fsimantics%2Fdb%2Fadaption%2FAdaptionService.java;fp=bundles%2Forg.simantics.db%2Fsrc%2Forg%2Fsimantics%2Fdb%2Fadaption%2FAdaptionService.java;h=28ada79a91d52b4e7d6c09b613c89250f46f1104;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.db/src/org/simantics/db/adaption/AdaptionService.java b/bundles/org.simantics.db/src/org/simantics/db/adaption/AdaptionService.java new file mode 100644 index 000000000..28ada79a9 --- /dev/null +++ b/bundles/org.simantics.db/src/org/simantics/db/adaption/AdaptionService.java @@ -0,0 +1,61 @@ +/******************************************************************************* + * 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); + +}