/* * 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 arq; import java.util.Iterator ; import java.util.List ; import arq.cmdline.CmdUpdate ; import jena.cmd.ArgDecl; import jena.cmd.CmdException; import org.apache.jena.atlas.io.IndentedWriter ; import org.apache.jena.atlas.lib.Lib ; import org.apache.jena.graph.Graph ; import org.apache.jena.graph.Node ; import org.apache.jena.sparql.core.DatasetGraph ; import org.apache.jena.sparql.modify.request.UpdateLoad ; import org.apache.jena.sparql.sse.SSE ; import org.apache.jena.sparql.util.graph.GraphLoadMonitor ; import org.apache.jena.update.UpdateExecutionFactory ; import org.apache.jena.update.UpdateRequest ; public class load extends CmdUpdate { static private final ArgDecl graphNameArg = new ArgDecl(ArgDecl.HasValue, "--graph") ; static private final ArgDecl dumpArg = new ArgDecl(ArgDecl.NoValue, "--dump") ; String graphName = null ; List<String> loadFiles = null ; boolean dump = false ; public static void main (String... argv) { new load(argv).mainRun() ; } protected load(String[] argv) { super(argv) ; super.add(graphNameArg, "--graph=IRI", "Graph IRI (loads default graph if absent)") ; super.add(dumpArg, "--dump", "Dump the resulting graph store") ; } @Override protected void processModulesAndArgs() { if ( containsMultiple(graphNameArg) ) throw new CmdException("At most one --graph allowed") ; graphName = getValue(graphNameArg) ; loadFiles = super.getPositional() ; dump = contains(dumpArg) ; super.processModulesAndArgs() ; } @Override protected String getCommandName() { return Lib.className(this) ; } @Override protected String getSummary() { return getCommandName()+" --desc=assembler [--dump] --update=<request file>" ; } @Override protected void execUpdate(DatasetGraph graphStore) { if ( loadFiles.size() == 0 ) throw new CmdException("Nothing to do") ; UpdateRequest req = new UpdateRequest() ; for ( String filename : loadFiles ) { UpdateLoad loadReq = new UpdateLoad( filename, graphName ); req.add( loadReq ); } if ( true ) { // Need a better way monitor(graphStore.getDefaultGraph()) ; for ( Iterator<Node> iter = graphStore.listGraphNodes() ; iter.hasNext() ; ) { Graph g = graphStore.getGraph(iter.next()) ; monitor(g) ; } } UpdateExecutionFactory.create(req, graphStore).execute() ; if ( dump ) { IndentedWriter out = IndentedWriter.stdout ; SSE.write(graphStore) ; out.flush(); } } private void monitor(Graph graph) { GraphLoadMonitor m = new GraphLoadMonitor(20000,false) ; //m.setSummaryLabel(getCommandName()) ; graph.getEventManager().register(m) ; } @Override protected DatasetGraph dealWithNoDataset() { throw new CmdException("No dataset provided") ; } }