X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.browsing.ui.model%2Fsrc%2Forg%2Fsimantics%2Fbrowsing%2Fui%2Fmodel%2Fbrowsecontexts%2FContributedActionBrowseContexts.java;h=dd3fba2c750f068b7835445429452d1905fdc356;hb=ef12da1a6651051f3674b593a732d253c9ea4461;hp=51affb5faf7c3e5525833d8feae06ee3c6cf9a96;hpb=0ae2b770234dfc3cbb18bd38f324125cf0faca07;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.browsing.ui.model/src/org/simantics/browsing/ui/model/browsecontexts/ContributedActionBrowseContexts.java b/bundles/org.simantics.browsing.ui.model/src/org/simantics/browsing/ui/model/browsecontexts/ContributedActionBrowseContexts.java index 51affb5fa..dd3fba2c7 100644 --- a/bundles/org.simantics.browsing.ui.model/src/org/simantics/browsing/ui/model/browsecontexts/ContributedActionBrowseContexts.java +++ b/bundles/org.simantics.browsing.ui.model/src/org/simantics/browsing/ui/model/browsecontexts/ContributedActionBrowseContexts.java @@ -3,6 +3,7 @@ package org.simantics.browsing.ui.model.browsecontexts; import java.util.ArrayList; import java.util.Collection; +import org.simantics.browsing.ui.model.tests.Test; import org.simantics.databoard.Bindings; import org.simantics.db.ReadGraph; import org.simantics.db.Resource; @@ -26,16 +27,25 @@ public class ContributedActionBrowseContexts extends TernaryRead result = new ArrayList(); for(Resource contribution : query.find(graph, parameter)) { Resource type = graph.getPossibleObject(contribution, VP.ActionBrowseContextContribution_HasType); - if(type == null) continue; - if(graph.isInstanceOf(parameter2, type)) { - Resource context = graph.getPossibleObject(contribution, VP.ActionBrowseContextContribution_HasActionBrowseContext); - if(context == null) continue; - String[] allowedContexts = graph.getPossibleRelatedValue(contribution, VP.ActionBrowseContextContribution_allowedUIContexts, Bindings.STRING_ARRAY); - if(allowedContexts != null) - if(!Arrays.contains(allowedContexts, parameter3)) - continue; - result.add(context); + if(type != null) { + if(!graph.isInstanceOf(parameter2, type)) continue; } + Resource testResource = graph.getPossibleObject(contribution, VP.ActionBrowseContextContribution_HasTest); + if(testResource != null) { + Test test = graph.getPossibleAdapter(testResource, Test.class); + if(test != null) { + if(!test.test(graph, parameter2)) continue; + } + } + + Resource context = graph.getPossibleObject(contribution, VP.ActionBrowseContextContribution_HasActionBrowseContext); + if(context == null) continue; + String[] allowedContexts = graph.getPossibleRelatedValue(contribution, VP.ActionBrowseContextContribution_allowedUIContexts, Bindings.STRING_ARRAY); + if(allowedContexts != null) + if(!Arrays.contains(allowedContexts, parameter3)) + continue; + result.add(context); + } return result;