X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.mapping%2Fsrc%2Forg%2Fsimantics%2Fmapping%2Fconstraint%2Finstructions%2FTripletSubjectPredicateQuery.java;h=883eb8d52b603f6e69c75b80e82b402e2e20536e;hb=refs%2Fchanges%2F38%2F238%2F2;hp=130549c5baef4d70d5761ad016ed9de5d51ea06d;hpb=24e2b34260f219f0d1644ca7a138894980e25b14;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.mapping/src/org/simantics/mapping/constraint/instructions/TripletSubjectPredicateQuery.java b/bundles/org.simantics.mapping/src/org/simantics/mapping/constraint/instructions/TripletSubjectPredicateQuery.java index 130549c5b..883eb8d52 100644 --- a/bundles/org.simantics.mapping/src/org/simantics/mapping/constraint/instructions/TripletSubjectPredicateQuery.java +++ b/bundles/org.simantics.mapping/src/org/simantics/mapping/constraint/instructions/TripletSubjectPredicateQuery.java @@ -1,84 +1,84 @@ -/******************************************************************************* - * 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.mapping.constraint.instructions; - -import gnu.trove.set.hash.TIntHashSet; - -import java.util.Collection; -import java.util.Iterator; - -import org.simantics.db.ReadGraph; -import org.simantics.db.Resource; -import org.simantics.db.Statement; -import org.simantics.db.exception.DatabaseException; -import org.simantics.layer0.Layer0; - -public class TripletSubjectPredicateQuery extends TripletInstruction { - - Resource predicate; - - public TripletSubjectPredicateQuery(int variable0, int variable1, int variable2, - Resource predicate) { - super(variable0, variable1, variable2); - this.predicate = predicate; - } - - public TripletSubjectPredicateQuery(int variable0, int variable1, int variable2) { - this(variable0, variable1, variable2, null); - } - - @Override - public Object query(ReadGraph g, Object[] bindings) throws DatabaseException { - Resource r2 = (Resource)bindings[variable2]; -// ITask task = ThreadLogger.getInstance().begin("g"); - Collection result = - predicate == null - ? g.getStatements(r2, Layer0.getInstance(g).IsWeaklyRelatedTo) - : g.getStatements(r2, g.getInverse(predicate)); -// task.finish(); - if(result.isEmpty()) - return IInstruction.FAILURE; - Iterator it = result.iterator(); - Statement stat = it.next(); - bindings[variable1] = g.getInverse(stat.getPredicate()); - bindings[variable0] = stat.getObject(); - if(it.hasNext()) - return it; - else - return null; - } - - @SuppressWarnings("unchecked") - @Override - public Object next(ReadGraph g, Object[] bindings, Object continuation) throws DatabaseException { - Iterator it = (Iterator)continuation; - if(it.hasNext()) { - Statement stat = it.next(); - bindings[variable1] = g.getInverse(stat.getPredicate()); - bindings[variable0] = stat.getObject(); - if(it.hasNext()) - return it; - else - return null; - } - else - return IInstruction.FAILURE; - } - - @Override - public void collectVariables(TIntHashSet reads, TIntHashSet writes) { - super.collectVariables(reads, writes); - writes.add(variable0); - writes.add(variable1); - } - -} +/******************************************************************************* + * 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.mapping.constraint.instructions; + +import gnu.trove.set.hash.TIntHashSet; + +import java.util.Collection; +import java.util.Iterator; + +import org.simantics.db.ReadGraph; +import org.simantics.db.Resource; +import org.simantics.db.Statement; +import org.simantics.db.exception.DatabaseException; +import org.simantics.layer0.Layer0; + +public class TripletSubjectPredicateQuery extends TripletInstruction { + + Resource predicate; + + public TripletSubjectPredicateQuery(int variable0, int variable1, int variable2, + Resource predicate) { + super(variable0, variable1, variable2); + this.predicate = predicate; + } + + public TripletSubjectPredicateQuery(int variable0, int variable1, int variable2) { + this(variable0, variable1, variable2, null); + } + + @Override + public Object query(ReadGraph g, Object[] bindings) throws DatabaseException { + Resource r2 = (Resource)bindings[variable2]; +// ITask task = ThreadLogger.getInstance().begin("g"); + Collection result = + predicate == null + ? g.getStatements(r2, Layer0.getInstance(g).IsWeaklyRelatedTo) + : g.getStatements(r2, g.getInverse(predicate)); +// task.finish(); + if(result.isEmpty()) + return IInstruction.FAILURE; + Iterator it = result.iterator(); + Statement stat = it.next(); + bindings[variable1] = g.getInverse(stat.getPredicate()); + bindings[variable0] = stat.getObject(); + if(it.hasNext()) + return it; + else + return null; + } + + @SuppressWarnings("unchecked") + @Override + public Object next(ReadGraph g, Object[] bindings, Object continuation) throws DatabaseException { + Iterator it = (Iterator)continuation; + if(it.hasNext()) { + Statement stat = it.next(); + bindings[variable1] = g.getInverse(stat.getPredicate()); + bindings[variable0] = stat.getObject(); + if(it.hasNext()) + return it; + else + return null; + } + else + return IInstruction.FAILURE; + } + + @Override + public void collectVariables(TIntHashSet reads, TIntHashSet writes) { + super.collectVariables(reads, writes); + writes.add(variable0); + writes.add(variable1); + } + +}