
org.apache.jena.tdb.store.DatasetPrefixesTDB Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.jena.tdb.store;
import java.util.* ;
import org.apache.jena.atlas.iterator.Iter ;
import org.apache.jena.atlas.lib.tuple.Tuple ;
import org.apache.jena.atlas.logging.Log ;
import org.apache.jena.graph.Node ;
import org.apache.jena.graph.NodeFactory ;
import org.apache.jena.riot.system.PrefixMap;
import org.apache.jena.riot.system.Prefixes;
import org.apache.jena.tdb.store.nodetupletable.NodeTupleTable ;
/**
* Dataset prefixes; a table of nodes with prefix-centric operations. The table is G-P-U
* where G is a graph name as a URI (a URI for <> is used for the default graph), P is a
* string (the prefix) and U is the IRI.
*/
public class DatasetPrefixesTDB implements DatasetPrefixStorage
{
private final NodeTupleTable nodeTupleTable ;
public DatasetPrefixesTDB(NodeTupleTable nodeTupleTable) {
this.nodeTupleTable = nodeTupleTable ;
}
@Override
public synchronized void insertPrefix(String graphName, String prefix, String uri) {
Node g = NodeFactory.createURI(graphName) ;
Node p = NodeFactory.createLiteral(prefix) ;
Node u = NodeFactory.createURI(uri) ;
// Remove any previous mapping.
remove_prefix(g,p,Node.ANY);
nodeTupleTable.addRow(g,p,u) ;
}
private void remove_prefix(Node g, Node p, Node u) {
Iterator> iter = nodeTupleTable.find(g, p, u);
List> list = Iter.toList(iter); // Materialize.
for ( Tuple tuple : list )
nodeTupleTable.deleteRow(tuple.get(0), tuple.get(1), tuple.get(2));
}
private void dump() {
System.out.println("> NodeTupleTable");
nodeTupleTable.findAll().forEachRemaining(t->System.out.println(" "+t));
System.out.println("<");
}
@Override
public Set graphNames() {
Iterator> iter = nodeTupleTable.find((Node)null, null, null) ;
Set x = new HashSet<>() ;
for ( ; iter.hasNext() ; )
x.add(iter.next().get(0).getURI()) ;
Iter.close(iter) ;
return x ;
}
@Override
public synchronized String readPrefix(String graphName, String prefix) {
Node g = NodeFactory.createURI(graphName) ;
Node p = NodeFactory.createLiteral(prefix) ;
Iterator> iter = nodeTupleTable.find(g, p, null) ;
try {
if ( ! iter.hasNext() )
return null ;
Tuple t = iter.next() ;
Node uri = t.get(2) ;
return uri.getURI() ;
} finally { Iter.close(iter) ; }
}
@Override
public synchronized String readByURI(String graphName, String uriStr) {
Node g = NodeFactory.createURI(graphName) ;
Node u = NodeFactory.createURI(uriStr) ;
Iterator> iter = nodeTupleTable.find(g, null, u) ;
if ( ! iter.hasNext() )
return null ;
Node prefix = iter.next().get(1) ;
Iter.close(iter) ;
return prefix.getLiteralLexicalForm() ;
}
@Override
public synchronized Map readPrefixMap(String graphName) {
Map map = new HashMap<>() ;
// One class of problem from mangled databases
// (non-transactional, not shutdown cleanly)
// ends up with NPE access to the node table from
// the prefix index. As prefixes are "nice extras", we
// keep calm and carry on in the face of exceptions.
Node g = NodeFactory.createURI(graphName) ;
Iterator> iter = nodeTupleTable.find(g, null, null) ;
for ( ; iter.hasNext() ; )
{
try {
Tuple t = iter.next();
String prefix = t.get(1).getLiteralLexicalForm() ;
String uri = t.get(2).getURI() ;
map.put(prefix, uri) ;
} catch (Exception ex) {
Log.warn(this, "Mangled prefix map: graph name='"+graphName+"'", ex) ;
}
}
Iter.close(iter) ;
return map ;
}
@Override
public void removeFromPrefixMap(String graphName, String prefix) {
Node g = NodeFactory.createURI(graphName) ;
Node p = NodeFactory.createLiteral(prefix) ;
removeAll(g, p, null) ;
}
@Override
public void removeAllFromPrefixMap(String graphName) {
Node g = NodeFactory.createURI(graphName) ;
removeAll(g, null, null) ;
}
/** Remove by pattern */
private synchronized void removeAll(Node g, Node p, Node uri) {
Iterator> iter = nodeTupleTable.find(g, p, uri) ;
List> list = Iter.toList(iter) ; // Materialize.
Iter.close(iter) ;
for ( Tuple tuple : list )
nodeTupleTable.deleteRow(tuple.get(0), tuple.get(1), tuple.get(2)) ;
}
public NodeTupleTable getNodeTupleTable() { return nodeTupleTable ; }
/** Return a PrefixMapping for the dataset */
@Override
public PrefixMap getPrefixMap()
{ return getPrefixMap(Prefixes.datasetPrefixSet) ; }
/** Return a PrefixMapping for a named graph */
@Override
public PrefixMap getPrefixMap(String graphName) {
return new GraphPrefixesProjection(graphName, this) ;
}
@Override
public void close() {
nodeTupleTable.close() ;
}
@Override
public void sync() {
nodeTupleTable.sync() ;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy