X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=bundles%2Forg.simantics.scl.runtime%2Fsrc%2Forg%2Fsimantics%2Fscl%2Fruntime%2FSCLContext.java;fp=bundles%2Forg.simantics.scl.runtime%2Fsrc%2Forg%2Fsimantics%2Fscl%2Fruntime%2FSCLContext.java;h=a9444bcf909f97bd77fde8c47b16ec97996bb0cb;hp=8703819776a95f521109b36eadbbbcec847ca6f8;hb=309b4b814a1375c2e2bd67bdee77d62bc9abf073;hpb=3edbf85ff8a7f1bd596857a24b1bdebd66943d6b diff --git a/bundles/org.simantics.scl.runtime/src/org/simantics/scl/runtime/SCLContext.java b/bundles/org.simantics.scl.runtime/src/org/simantics/scl/runtime/SCLContext.java index 870381977..a9444bcf9 100644 --- a/bundles/org.simantics.scl.runtime/src/org/simantics/scl/runtime/SCLContext.java +++ b/bundles/org.simantics.scl.runtime/src/org/simantics/scl/runtime/SCLContext.java @@ -1,5 +1,7 @@ package org.simantics.scl.runtime; +import org.simantics.scl.runtime.reporting.SCLReportingHandler; + import gnu.trove.map.hash.THashMap; public class SCLContext extends THashMap { @@ -32,6 +34,22 @@ public class SCLContext extends THashMap { CONTEXT.set(newContext); } + /** + * Creates a new context based on some properties of the current context. + * The new context is safe for use in parallel threads. + */ + public static SCLContext createDerivedContext() { + SCLContext newContext = new SCLContext(); + + SCLContext baseContext = CONTEXT.get(); + if(baseContext != null) { + Object reportingHandler = baseContext.get(SCLReportingHandler.REPORTING_HANDLER); + if(reportingHandler != null) + newContext.put(SCLReportingHandler.REPORTING_HANDLER, reportingHandler); + } + return newContext; + } + public static void pop() { OldContextNode node = OLD_CONTEXT.get(); if(node == null)