📄 typeof.java
字号:
/* Sesame - Storage and Querying architecture for RDF and RDF Schema * Copyright (C) 2001-2005 Aduna * * Contact: * Aduna * Prinses Julianaplein 14 b * 3817 CS Amersfoort * The Netherlands * tel. +33 (0)33 465 99 87 * fax. +33 (0)33 465 99 87 * * http://aduna.biz/ * http://www.openrdf.org/ * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */package org.openrdf.sesame.query.rql.model;import java.io.IOException;import org.openrdf.model.Resource;import org.openrdf.model.Value;import org.openrdf.model.impl.URIImpl;import org.openrdf.sesame.query.QueryEvaluationException;import org.openrdf.sesame.query.TableQueryResultListener;import org.openrdf.sesame.query.rql.model.iterators.NestedResourceIterator;import org.openrdf.sesame.query.rql.model.iterators.StatementObjectIterator;import org.openrdf.sesame.sail.RdfSchemaSource;import org.openrdf.sesame.sail.ResourceIterator;import org.openrdf.sesame.sail.StatementIterator;import org.openrdf.sesame.sail.ValueIterator;import org.openrdf.sesame.sail.util.SingleResourceIterator;public class TypeOf implements ClassQuery { protected ResourceQuery _instanceQ; protected boolean _recursive; public TypeOf(ResourceQuery instanceQ, boolean recursive) { _instanceQ = instanceQ; _recursive = recursive; } public void evaluate(RdfSchemaSource rss, TableQueryResultListener listener) throws QueryEvaluationException { ResourceIterator iter = null; try { String columnHeaders[] = new String[1]; columnHeaders[0] = this.getQuery(); listener.startTableQueryResult(columnHeaders); iter = getClasses(rss); while (iter.hasNext()) { listener.startTuple(); listener.tupleValue(iter.next()); listener.endTuple(); } listener.endTableQueryResult(); } catch (IOException e) { throw new QueryEvaluationException(e); } finally { if (iter != null) { iter.close(); } } } public ValueIterator getResources(RdfSchemaSource rss) throws QueryEvaluationException { return getClasses(rss); } public ResourceIterator getClasses(RdfSchemaSource rss) throws QueryEvaluationException { ValueIterator instanceIter = _instanceQ.getResources(rss); return new Iterator(rss, instanceIter); } public boolean returnsSet() { return true; } public String getQuery() { return this.toString(); } public String toString() { if (_recursive) { return "typeOf(" + _instanceQ.toString() + ")"; } else { return "typeOf^(" + _instanceQ.toString() + ")"; } } /*---------------------------------------------------+ | Iterator | +---------------------------------------------------*/ class Iterator extends NestedResourceIterator { protected RdfSchemaSource _rss; public Iterator(RdfSchemaSource rss, ValueIterator instanceIter) { super(instanceIter); _rss = rss; } public ResourceIterator getInnerIterator(Value instance) { if (instance instanceof Resource) { StatementIterator statIter; if (_recursive) { statIter = _rss.getType((Resource)instance, null); } else { statIter = _rss.getDirectType((Resource)instance, null); } return new StatementObjectIterator(statIter); } else { // Literal return new SingleResourceIterator(URIImpl.RDFS_LITERAL); } } }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -