X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.structural2%2Fsrc%2Forg%2Fsimantics%2Fstructural2%2Fscl%2Fprocedural%2FProceduralComponentTypeCompilationContextRequest.java;fp=bundles%2Forg.simantics.structural2%2Fsrc%2Forg%2Fsimantics%2Fstructural2%2Fscl%2Fprocedural%2FProceduralComponentTypeCompilationContextRequest.java;h=e0d63fe4252eee12a41683f3e8556c70bcd7e092;hb=969bd23cab98a79ca9101af33334000879fb60c5;hp=0000000000000000000000000000000000000000;hpb=866dba5cd5a3929bbeae85991796acb212338a08;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.structural2/src/org/simantics/structural2/scl/procedural/ProceduralComponentTypeCompilationContextRequest.java b/bundles/org.simantics.structural2/src/org/simantics/structural2/scl/procedural/ProceduralComponentTypeCompilationContextRequest.java new file mode 100644 index 000000000..e0d63fe42 --- /dev/null +++ b/bundles/org.simantics.structural2/src/org/simantics/structural2/scl/procedural/ProceduralComponentTypeCompilationContextRequest.java @@ -0,0 +1,44 @@ +package org.simantics.structural2.scl.procedural; + +import java.util.Map; + +import org.simantics.db.ReadGraph; +import org.simantics.db.Resource; +import org.simantics.db.common.procedure.adapter.TransientCacheListener; +import org.simantics.db.common.request.IndexRoot; +import org.simantics.db.common.request.UnaryRead; +import org.simantics.db.exception.DatabaseException; +import org.simantics.db.layer0.util.RuntimeEnvironmentRequest; +import org.simantics.scl.compiler.environment.specification.EnvironmentSpecification; +import org.simantics.scl.compiler.runtime.RuntimeEnvironment; +import org.simantics.structural2.scl.ComponentTypeProperty; +import org.simantics.structural2.scl.ReadComponentTypeConnectionsRequest; +import org.simantics.structural2.scl.ReadComponentTypeInterfaceRequest; + +public class ProceduralComponentTypeCompilationContextRequest extends UnaryRead { + + public ProceduralComponentTypeCompilationContextRequest(Resource parameter) { + super(parameter); + } + + @Override + public ProceduralComponentTypeCompilationContext perform(ReadGraph graph) + throws DatabaseException { + Resource indexRoot = graph.syncRequest(new IndexRoot(parameter)); + RuntimeEnvironment runtimeEnvironment = graph.syncRequest(new RuntimeEnvironmentRequest(indexRoot) { + @Override + protected void fillEnvironmentSpecification( + EnvironmentSpecification environmentSpecification) { + environmentSpecification.importModule("Structural/Procedural", ""); + } + }); + Map propertyMap = + graph.syncRequest(new ReadComponentTypeInterfaceRequest(parameter, runtimeEnvironment.getEnvironment()), + TransientCacheListener.>instance()); + Map connectionPointMap = + graph.syncRequest(new ReadComponentTypeConnectionsRequest(parameter), + TransientCacheListener.>instance()); + return new ProceduralComponentTypeCompilationContext(runtimeEnvironment, propertyMap, connectionPointMap); + } + +}