/* * 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.graph.compose.test; import org.apache.jena.graph.Factory ; import org.apache.jena.graph.Graph ; import org.apache.jena.graph.GraphUtil ; import org.apache.jena.graph.Triple ; import org.apache.jena.graph.compose.MultiUnion ; import org.apache.jena.graph.test.NodeCreateUtils ; import org.apache.jena.rdf.model.impl.ReifierStd ; import org.apache.jena.rdf.model.test.ModelTestBase ; import org.apache.jena.util.iterator.ExtendedIterator ; /** Test the reifier for multi-unions. */ public class TestMultiUnionReifier extends ModelTestBase { public TestMultiUnionReifier( String name ) { super( name ); } public void testX() { MultiUnion mu = multi( "a P b; !b Q c; ~c R d", "" ); for (ExtendedIterator<Triple> it = GraphUtil.findAll( mu ); it.hasNext();) { System.err.println( "]] " + it.next() ); } } private MultiUnion multi( String a, String b ) { Graph A = graph( a ), B = graph( b ); return new MultiUnion( new Graph[] {A, B} ); } static int count = 0; private Graph graph( String facts ) { Graph result = Factory.createDefaultGraph( ); String [] factArray = facts.split( ";" ); for ( String aFactArray : factArray ) { String fact = aFactArray.trim(); if ( fact.equals( "" ) ) { } else if ( fact.charAt( 0 ) == '!' ) { Triple t = NodeCreateUtils.createTriple( fact.substring( 1 ) ); result.add( t ); ReifierStd.reifyAs( result, NodeCreateUtils.create( "_r" + ++count ), t ); } else if ( fact.charAt( 0 ) == '~' ) { Triple t = NodeCreateUtils.createTriple( fact.substring( 1 ) ); ReifierStd.reifyAs( result, NodeCreateUtils.create( "_r" + ++count ), t ); } else { result.add( NodeCreateUtils.createTriple( fact ) ); } } return result; } }