From ab8ff01daaebfcc98fd42116b514a9a0ddb33e38 Mon Sep 17 00:00:00 2001 From: Andy Seaborne Date: Sun, 13 Oct 2024 13:42:45 +0100 Subject: [PATCH] RDF 1.2 and SPARQL 1.2; SEMIJOIN and ANTIJOIN --- jena-arq/Grammar/.gitignore | 4 +- jena-arq/Grammar/README | 31 + jena-arq/Grammar/Turtle/turtle.jj | 181 +- jena-arq/Grammar/arq.jj | 330 +- jena-arq/Grammar/grammar | 1 + jena-arq/Grammar/jj2bnf | 302 ++ jena-arq/Grammar/main.jj | 492 ++- jena-arq/Grammar/sparql2bnf | 7 + jena-arq/Grammar/sparql2html | 16 +- jena-arq/Grammar/sparql_12.jj | 309 +- jena-arq/Grammar/sparql_12.txt | 486 --- jena-arq/Grammar/sse/grammar-sse | 19 +- jena-arq/Grammar/sse/jj2html | 469 --- jena-arq/Grammar/sse/sse.jj | 179 +- jena-arq/Grammar/sse/tokens.inc | 203 -- jena-arq/Grammar/tokens.txt | 30 +- .../org/apache/jena/riot/lang/LangEngine.java | 20 +- .../org/apache/jena/riot/lang/LangNQuads.java | 35 +- .../org/apache/jena/riot/lang/LangNTuple.java | 66 +- .../org/apache/jena/riot/lang/LangTriG.java | 70 +- .../org/apache/jena/riot/lang/LangTurtle.java | 2 +- .../apache/jena/riot/lang/LangTurtleBase.java | 347 +- .../org/apache/jena/riot/lang/ReaderTriX.java | 56 +- .../jena/riot/lang/extra/LangParserBase.java | 34 +- .../riot/lang/extra/javacc/TurtleJavacc.java | 445 ++- .../extra/javacc/TurtleJavaccConstants.java | 66 +- .../javacc/TurtleJavaccTokenManager.java | 595 ++-- .../apache/jena/riot/out/NodeFormatter.java | 3 + .../jena/riot/out/NodeFormatterBase.java | 10 +- .../apache/jena/riot/out/NodeFormatterNT.java | 9 + .../jena/riot/protobuf/ProtobufConvert.java | 4 +- .../riot/rowset/rw/RowSetReaderJSON_V1.java | 2 +- .../jena/riot/rowset/rw/RowSetReaderXML.java | 2 +- .../jena/riot/rowset/rw/RowSetWriterJSON.java | 6 +- .../jena/riot/rowset/rw/RowSetWriterXML.java | 2 +- .../rw/rs_json/RowSetJSONStreaming.java | 2 +- .../org/apache/jena/riot/system/Checker.java | 66 +- .../apache/jena/riot/system/FactoryRDF.java | 2 + .../jena/riot/system/FactoryRDFStd.java | 5 + .../jena/riot/system/ParserProfile.java | 21 +- .../jena/riot/system/ParserProfileStd.java | 42 +- .../riot/system/ParserProfileWrapper.java | 13 +- .../jena/riot/thrift/ThriftConvert.java | 4 +- .../jena/riot/writer/StreamWriterTriX.java | 2 +- .../apache/jena/riot/writer/TurtleShell.java | 8 +- .../jena/sparql/algebra/AlgebraGenerator.java | 19 + .../apache/jena/sparql/algebra/OpAsQuery.java | 28 +- .../apache/jena/sparql/algebra/OpVisitor.java | 73 +- .../jena/sparql/algebra/OpVisitorBase.java | 8 +- .../jena/sparql/algebra/OpVisitorByType.java | 15 +- .../apache/jena/sparql/algebra/Transform.java | 77 +- .../jena/sparql/algebra/TransformCopy.java | 10 +- .../jena/sparql/algebra/TransformSingle.java | 7 +- .../jena/sparql/algebra/TransformWrapper.java | 82 +- .../op/{OpDiff.java => OpAntiJoin.java} | 12 +- .../jena/sparql/algebra/op/OpSemiJoin.java | 55 + .../algebra/walker/OpVisitorByType.java | 34 +- .../walker/OpVisitorByTypeAndExpr.java | 15 +- .../apache/jena/sparql/core/Substitute.java | 6 +- .../org/apache/jena/sparql/engine/Rename.java | 8 +- .../engine/iterator/QueryIter2LoopOnLeft.java | 72 +- .../iterator/QueryIterAddTripleTerm.java | 2 +- .../sparql/engine/iterator/QueryIterDiff.java | 55 - .../engine/iterator/QueryIterHalfJoin.java | 72 + .../sparql/engine/main/ExecutionDispatch.java | 22 +- .../sparql/engine/main/JoinClassifier.java | 6 +- .../jena/sparql/engine/main/OpExecutor.java | 22 +- .../jena/sparql/engine/main/VarFinder.java | 18 +- .../jena/sparql/engine/main/solver/RX_PG.java | 8 +- .../sparql/engine/main/solver/SolverLib.java | 12 +- .../sparql/engine/main/solver/SolverRX3.java | 2 +- .../sparql/engine/main/solver/SolverRX4.java | 4 +- .../engine/main/solver/StageMatchTriple.java | 3 +- .../jena/sparql/engine/ref/Evaluator.java | 6 +- .../sparql/engine/ref/EvaluatorDispatch.java | 25 +- .../sparql/engine/ref/EvaluatorSimple.java | 60 + .../jena/sparql/engine/ref/RefEval.java | 60 + .../jena/sparql/engine/ref/TableJoin.java | 5 +- .../apache/jena/sparql/expr/E_HasLang.java | 42 + .../apache/jena/sparql/expr/E_HasLangDir.java | 41 + .../apache/jena/sparql/expr/E_IsNumeric.java | 20 +- .../apache/jena/sparql/expr/E_IsTriple.java | 4 +- .../org/apache/jena/sparql/expr/E_Lang.java | 6 +- .../apache/jena/sparql/expr/E_LangDir.java | 38 + .../apache/jena/sparql/expr/E_StrLang.java | 21 +- .../apache/jena/sparql/expr/E_StrLangDir.java | 39 + .../apache/jena/sparql/expr/E_TripleFn.java | 4 +- .../jena/sparql/expr/E_TripleObject.java | 4 +- .../jena/sparql/expr/E_TriplePredicate.java | 4 +- .../jena/sparql/expr/E_TripleSubject.java | 4 +- .../jena/sparql/expr/ExprFunction3.java | 2 +- .../org/apache/jena/sparql/expr/ExprLib.java | 2 +- .../jena/sparql/expr/ExprTripleTerm.java | 6 +- .../org/apache/jena/sparql/expr/ExprVars.java | 2 +- .../apache/jena/sparql/expr/NodeValue.java | 22 +- .../sparql/expr/nodevalue/NodeFunctions.java | 70 +- .../sparql/expr/nodevalue/NodeValueLang.java | 66 +- .../expr/nodevalue/NodeValueLangDir.java | 98 + .../expr/nodevalue/NodeValueVisitor.java | 1 + .../jena/sparql/function/FunctionEnvBase.java | 7 +- .../function/library/triple/IsTripleTerm.java | 2 +- .../function/library/triple/TripleObject.java | 2 +- .../library/triple/TriplePredicate.java | 2 +- .../library/triple/TripleSubject.java | 2 +- .../function/library/triple/TripleTerm.java | 2 +- ...ripleFunctions.java => TripleTermOps.java} | 8 +- .../apache/jena/sparql/graph/NodeConst.java | 18 +- .../jena/sparql/lang/QueryParserBase.java | 246 +- .../jena/sparql/lang/arq/ARQParser.java | 2715 +++++++++------ .../jena/sparql/lang/arq/ARQParserBase.java | 6 +- .../sparql/lang/arq/ARQParserConstants.java | 406 +-- .../lang/arq/ARQParserTokenManager.java | 3001 +++++++++-------- .../lang/sparql_10/SPARQLParser10Base.java | 22 +- .../lang/sparql_11/SPARQLParser11Base.java | 22 +- .../sparql/lang/sparql_12/JavaCharStream.java | 79 +- .../sparql/lang/sparql_12/SPARQLParser12.java | 1023 ++++-- ...ser11Base.java => SPARQLParser12Base.java} | 6 +- .../sparql_12/SPARQLParser12Constants.java | 300 +- .../sparql_12/SPARQLParser12TokenManager.java | 2316 +++++++------ .../sparql/resultset/ResultSetCompare.java | 2 +- .../jena/sparql/serializer/FormatterBase.java | 66 +- .../sparql/serializer/FormatterElement.java | 18 + .../org/apache/jena/sparql/sse/ItemLift.java | 58 +- .../apache/jena/sparql/sse/ItemWriter.java | 14 +- .../java/org/apache/jena/sparql/sse/Tags.java | 18 +- .../jena/sparql/sse/builders/BuilderExpr.java | 317 +- .../jena/sparql/sse/builders/BuilderOp.java | 87 +- .../sparql/sse/lang/ParseHandlerLink.java | 1 - .../sparql/sse/lang/ParseHandlerPlain.java | 2 +- .../jena/sparql/sse/lang/ParserSSEBase.java | 1 - .../sse/lang/parser/ParseException.java | 20 +- .../sse/lang/parser/SSE_ParserCore.java | 54 +- .../lang/parser/SSE_ParserCoreConstants.java | 30 +- .../parser/SSE_ParserCoreTokenManager.java | 487 +-- .../sse/lang/parser/SimpleCharStream.java | 20 +- .../jena/sparql/sse/lang/parser/Token.java | 20 +- .../sparql/sse/lang/parser/TokenMgrError.java | 23 +- .../jena/sparql/sse/writers/WriterOp.java | 15 +- .../apache/jena/sparql/syntax/Element.java | 52 +- .../jena/sparql/syntax/ElementAntiJoin.java | 59 + .../jena/sparql/syntax/ElementLateral.java | 1 - .../jena/sparql/syntax/ElementSemiJoin.java | 59 + .../jena/sparql/syntax/ElementVisitor.java | 38 +- .../sparql/syntax/ElementVisitorBase.java | 6 + .../jena/sparql/syntax/ElementWalker.java | 18 + .../jena/sparql/syntax/PatternVars.java | 137 +- .../sparql/syntax/PatternVarsVisitor.java | 102 - .../ApplyElementTransformVisitor.java | 14 + .../syntaxtransform/ElementTransform.java | 4 +- .../ElementTransformCopyBase.java | 14 + .../ElementTransformIdentity.java | 4 + .../org/apache/jena/sparql/util/FmtUtils.java | 44 +- .../org/apache/jena/sparql/util/IsoAlg.java | 8 +- .../apache/jena/sparql/util/ModelUtils.java | 2 +- .../org/apache/jena/sparql/util/NodeCmp.java | 6 +- .../apache/jena/sparql/util/NodeUtils.java | 103 +- .../org/apache/jena/sparql/util/VarUtils.java | 2 +- .../main/java/org/apache/jena/system/G.java | 22 +- .../java/org/apache/jena/system/RDFStar.java | 18 +- .../org/apache/jena/arq/ARQTestSuite.java | 6 +- .../org/apache/jena/arq/junit/LibTest.java | 42 + .../jena/arq/junit/sparql/SparqlTests.java | 2 + .../junit/sparql/tests/QuerySyntaxTest.java | 8 +- .../arq/junit/sparql/tests/SparqlTestLib.java | 2 +- .../jena/rdf12/AbstratTestSPARQL12Eval.java | 101 + .../apache/jena/rdf12/LibTestSPARQL12.java | 71 + .../Scripts_RDFStar.java => rdf12/TEST.java} | 18 +- .../java/org/apache/jena/rdf12/TS_RDF12.java | 39 + .../jena/rdf12/TestRDF12LangSyntax.java | 358 ++ .../apache/jena/rdf12/TestSPARQL12Eval.java | 24 +- .../TestSPARQL12Results.java} | 5 +- .../apache/jena/rdf12/TestSPARQL12Syntax.java | 219 ++ .../basic/TS_RDFStar_Basic.java} | 11 +- .../basic}/TestNQuadsStarParse.java | 22 +- .../basic}/TestNTriplesStarParse.java | 19 +- .../jena/rdf12/basic/TestSPARQLStarParse.java | 143 + .../basic}/TestTrigStarParse.java | 25 +- .../basic}/TestTurtleStarParse.java | 15 +- .../jena/rdf_star/TestSPARQLStarParse.java | 139 - .../apache/jena/riot/Scripts_AltTurtle.java | 9 +- .../apache/jena/riot/lang/TestLangTrig.java | 52 +- .../apache/jena/riot/lang/TestTriXBad.java | 11 +- .../riot/protobuf/TestProtobufResultSet.java | 8 +- .../jena/sparql/Scripts_DatasetMap.java | 54 + .../jena/sparql/Scripts_DatasetMapLink.java | 56 + .../org/apache/jena/sparql/Scripts_TIM.java | 5 +- .../java/org/apache/jena/sparql/TC_ARQ.java | 6 +- .../algebra/optimize/TestVarRename.java | 454 +-- .../jena/sparql/expr/TestExpressions.java | 25 +- .../jena/sparql/expr/TestExpressions2.java | 8 +- .../jena/sparql/expr/TestNodeFunctions.java | 35 +- .../jena/sparql/expr/TestNodeValue.java | 17 +- .../apache/jena/sparql/expr/TestOrdering.java | 26 +- .../jena/sparql/expr/TestSortOrdering.java | 26 +- .../sparql/junit/RunnerSPARQL_DatasetMap.java | 46 + .../junit/RunnerSPARQL_DatasetMapLink.java | 46 + .../jena/sparql/junit/RunnerSPARQL_TIM.java | 5 +- .../apache/jena/sparql/sse/TestSSE_Basic.java | 38 +- .../jena/sparql/util/TestIsoMatcher.java | 49 +- .../jena/system/TestRDFStarTranslation.java | 60 +- jena-arq/testing/RIOT/Lang/TriX/trix-ns-1.nq | 3 +- .../testing/RIOT/Lang/TriX/trix-ns-1.trix | 13 +- jena-arq/testing/RIOT/Lang/TriX/trix-ns-2.nq | 3 +- .../testing/RIOT/Lang/TriX/trix-ns-2.trix | 24 +- .../testing/RIOT/Lang/TriX/trix-star-1.nq | 3 +- .../testing/RIOT/Lang/TriX/trix-star-1.trix | 13 +- .../testing/RIOT/Lang/TriX/trix-star-2.nq | 5 +- .../testing/RIOT/Lang/TriX/trix-star-2.trix | 52 +- .../Lang/TriX/trix-star-bad-emb-nested-1.trix | 20 - .../Lang/TriX/trix-star-bad-emb-nested-2.trix | 16 - .../Lang/TriX/trix-star-bad-emb-nested-3.trix | 19 - ....trix => trix-star-bad-triple-term-1.trix} | 0 ....trix => trix-star-bad-triple-term-2.trix} | 0 ....trix => trix-star-bad-triple-term-3.trix} | 9 +- ....trix => trix-star-bad-triple-term-4.trix} | 13 +- jena-arq/testing/rdf-star-cg/manifest.ttl | 33 - .../rdf-star-cg/nt/syntax/manifest.ttl | 112 - .../nt/syntax/ntriples-star-bad-syntax-1.nt | 1 - .../nt/syntax/ntriples-star-bad-syntax-2.nt | 1 - .../nt/syntax/ntriples-star-bad-syntax-3.nt | 1 - .../nt/syntax/ntriples-star-bad-syntax-4.nt | 1 - .../nt/syntax/ntriples-star-bnode-1.nt | 2 - .../nt/syntax/ntriples-star-bnode-2.nt | 2 - .../nt/syntax/ntriples-star-nested-1.nt | 3 - .../nt/syntax/ntriples-star-nested-2.nt | 3 - .../nt/syntax/ntriples-star-syntax-1.nt | 1 - .../nt/syntax/ntriples-star-syntax-2.nt | 1 - .../nt/syntax/ntriples-star-syntax-3.nt | 1 - .../nt/syntax/ntriples-star-syntax-4.nt | 1 - .../nt/syntax/ntriples-star-syntax-5.nt | 1 - .../rdf-star-cg/sparql/eval/data-0.ttl | 14 - .../rdf-star-cg/sparql/eval/data-2.ttl | 16 - .../rdf-star-cg/sparql/eval/data-3.ttl | 4 - .../rdf-star-cg/sparql/eval/data-4.trig | 13 - .../rdf-star-cg/sparql/eval/data-5.ttl | 10 - .../rdf-star-cg/sparql/eval/data-6.trig | 4 - .../rdf-star-cg/sparql/eval/data-7.ttl | 24 - .../sparql/eval/data-order-kind.ttl | 18 - .../rdf-star-cg/sparql/eval/data-order.ttl | 26 - .../testing/rdf-star-cg/sparql/eval/empty.nq | 0 .../rdf-star-cg/sparql/eval/manifest.ttl | 366 -- .../sparql/eval/sparql-star-basic-2.rq | 5 - .../sparql/eval/sparql-star-basic-2.srj | 12 - .../sparql/eval/sparql-star-basic-3.rq | 5 - .../sparql/eval/sparql-star-basic-3.srj | 13 - .../sparql/eval/sparql-star-basic-4.rq | 5 - .../sparql/eval/sparql-star-basic-4.srj | 12 - .../sparql/eval/sparql-star-basic-5.rq | 5 - .../sparql/eval/sparql-star-basic-5.srj | 12 - .../sparql/eval/sparql-star-basic-6.rq | 5 - .../sparql/eval/sparql-star-basic-6.srj | 9 - .../sparql/eval/sparql-star-construct-1.rq | 5 - .../sparql/eval/sparql-star-construct-1.ttl | 3 - .../sparql/eval/sparql-star-construct-2.rq | 5 - .../sparql/eval/sparql-star-construct-2.ttl | 3 - .../sparql/eval/sparql-star-construct-3.rq | 7 - .../sparql/eval/sparql-star-construct-3.ttl | 8 - .../sparql/eval/sparql-star-construct-4.rq | 7 - .../sparql/eval/sparql-star-construct-4.ttl | 5 - .../sparql/eval/sparql-star-construct-5.rq | 5 - .../sparql/eval/sparql-star-construct-5.ttl | 5 - .../sparql/eval/sparql-star-expr-01.rq | 10 - .../sparql/eval/sparql-star-expr-01.ttl | 14 - .../sparql/eval/sparql-star-expr-02.rq | 13 - .../sparql/eval/sparql-star-expr-02.srj | 18 - .../sparql/eval/sparql-star-graphs-1.rq | 6 - .../sparql/eval/sparql-star-graphs-1.srj | 14 - .../sparql/eval/sparql-star-graphs-2.rq | 6 - .../sparql/eval/sparql-star-graphs-2.srj | 17 - .../sparql/eval/sparql-star-op-1.rq | 7 - .../sparql/eval/sparql-star-op-1.srj | 46 - .../sparql/eval/sparql-star-op-2.rq | 8 - .../sparql/eval/sparql-star-op-2.srj | 79 - .../sparql/eval/sparql-star-op-3.rq | 8 - .../sparql/eval/sparql-star-op-3.srj | 27 - .../sparql/eval/sparql-star-op-4.rq | 8 - .../sparql/eval/sparql-star-op-4.srj | 136 - .../sparql/eval/sparql-star-order-1.srj | 31 - .../sparql/eval/sparql-star-order-2.srj | 154 - .../sparql/eval/sparql-star-order-by.rq | 69 - .../sparql/eval/sparql-star-pattern-01.rq | 6 - .../sparql/eval/sparql-star-pattern-01.srj | 18 - .../sparql/eval/sparql-star-pattern-02.rq | 6 - .../sparql/eval/sparql-star-pattern-02.srj | 18 - .../sparql/eval/sparql-star-pattern-03.rq | 7 - .../sparql/eval/sparql-star-pattern-03.srj | 20 - .../sparql/eval/sparql-star-pattern-04.rq | 6 - .../sparql/eval/sparql-star-pattern-04.srj | 9 - .../sparql/eval/sparql-star-pattern-05.rq | 6 - .../sparql/eval/sparql-star-pattern-05.srj | 14 - .../sparql/eval/sparql-star-pattern-06.rq | 6 - .../sparql/eval/sparql-star-pattern-06.srj | 11 - .../sparql/eval/sparql-star-pattern-07.rq | 6 - .../sparql/eval/sparql-star-pattern-07.srj | 13 - .../sparql/eval/sparql-star-pattern-08.rq | 7 - .../sparql/eval/sparql-star-pattern-08.srj | 18 - .../sparql/eval/sparql-star-pattern-09.rq | 7 - .../sparql/eval/sparql-star-pattern-09.srj | 18 - .../sparql/eval/sparql-star-results-1.rq | 5 - .../sparql/eval/sparql-star-results-1.srj | 106 - .../sparql/eval/sparql-star-results-1.srx | 177 - .../sparql/eval/sparql-star-update-1.ru | 7 - .../sparql/eval/sparql-star-update-2.ru | 7 - .../sparql/eval/sparql-star-update-3.ru | 7 - .../sparql/eval/update-result-1.trig | 7 - .../sparql/eval/update-result-2.trig | 6 - .../sparql/eval/update-result-3.trig | 2 - .../rdf-star-cg/sparql/syntax/manifest.ttl | 433 --- .../syntax/sparql-star-annotation-01.rq | 5 - .../syntax/sparql-star-annotation-02.rq | 12 - .../syntax/sparql-star-annotation-03.rq | 6 - .../syntax/sparql-star-annotation-04.rq | 6 - .../syntax/sparql-star-annotation-05.rq | 6 - .../syntax/sparql-star-annotation-06.rq | 5 - .../syntax/sparql-star-annotation-07.rq | 5 - .../syntax/sparql-star-annotation-08.rq | 6 - .../syntax/sparql-star-annotation-09.rq | 5 - .../syntax/sparql-star-syntax-bad-01.rq | 5 - .../syntax/sparql-star-syntax-bad-02.rq | 5 - .../syntax/sparql-star-syntax-bad-03.rq | 5 - .../syntax/sparql-star-syntax-bad-04.rq | 5 - .../syntax/sparql-star-syntax-bad-05.rq | 5 - .../syntax/sparql-star-syntax-bad-06.rq | 5 - .../syntax/sparql-star-syntax-bad-07.rq | 5 - .../syntax/sparql-star-syntax-bad-08.rq | 5 - .../syntax/sparql-star-syntax-bad-09.rq | 5 - .../syntax/sparql-star-syntax-bad-10.rq | 5 - .../syntax/sparql-star-syntax-bad-11.rq | 6 - .../syntax/sparql-star-syntax-bad-12.rq | 6 - .../syntax/sparql-star-syntax-bad-ann-1.rq | 6 - .../syntax/sparql-star-syntax-bad-ann-2.rq | 6 - .../sparql-star-syntax-bad-ann-path-1.rq | 5 - .../sparql-star-syntax-bad-ann-path-2.rq | 5 - .../sparql-star-syntax-bad-ann-path-3.rq | 5 - .../sparql-star-syntax-bad-ann-path-4.rq | 5 - .../sparql-star-syntax-bad-ann-path-5.rq | 5 - .../sparql-star-syntax-bad-ann-path-6.rq | 7 - .../sparql-star-syntax-bad-ann-path-7.rq | 5 - .../syntax/sparql-star-syntax-bad-update-1.ru | 5 - .../syntax/sparql-star-syntax-bad-update-2.ru | 5 - .../syntax/sparql-star-syntax-bad-update-3.ru | 5 - .../syntax/sparql-star-syntax-bad-update-4.ru | 5 - .../syntax/sparql-star-syntax-basic-01.rq | 5 - .../syntax/sparql-star-syntax-basic-02.rq | 5 - .../syntax/sparql-star-syntax-basic-03.rq | 5 - .../syntax/sparql-star-syntax-basic-04.rq | 5 - .../syntax/sparql-star-syntax-basic-05.rq | 10 - .../syntax/sparql-star-syntax-basic-06.rq | 4 - .../syntax/sparql-star-syntax-basic-07.rq | 6 - .../syntax/sparql-star-syntax-bnode-01.rq | 5 - .../syntax/sparql-star-syntax-bnode-02.rq | 5 - .../syntax/sparql-star-syntax-bnode-03.rq | 5 - .../syntax/sparql-star-syntax-compound.rq | 10 - .../syntax/sparql-star-syntax-expr-01.rq | 6 - .../syntax/sparql-star-syntax-expr-02.rq | 6 - .../syntax/sparql-star-syntax-expr-03.rq | 6 - .../syntax/sparql-star-syntax-expr-04.rq | 6 - .../syntax/sparql-star-syntax-expr-05.rq | 9 - .../syntax/sparql-star-syntax-expr-06.rq | 10 - .../syntax/sparql-star-syntax-inside-01.rq | 5 - .../syntax/sparql-star-syntax-inside-02.rq | 5 - .../syntax/sparql-star-syntax-nested-01.rq | 6 - .../syntax/sparql-star-syntax-nested-02.rq | 6 - .../syntax/sparql-star-syntax-update-1.ru | 5 - .../syntax/sparql-star-syntax-update-2.ru | 5 - .../syntax/sparql-star-syntax-update-3.ru | 8 - .../syntax/sparql-star-syntax-update-4.ru | 8 - .../syntax/sparql-star-syntax-update-5.ru | 7 - .../syntax/sparql-star-syntax-update-6.ru | 7 - .../syntax/sparql-star-syntax-update-7.ru | 7 - .../syntax/sparql-star-syntax-update-8.ru | 11 - .../rdf-star-cg/trig/eval/manifest.ttl | 112 - .../trig/eval/trig-star-eval-01.nq | 1 - .../trig/eval/trig-star-eval-01.trig | 3 - .../trig/eval/trig-star-eval-02.nq | 1 - .../trig/eval/trig-star-eval-02.trig | 3 - .../trig/eval/trig-star-eval-annotation-1.nq | 2 - .../eval/trig-star-eval-annotation-1.trig | 3 - .../trig/eval/trig-star-eval-annotation-2.nq | 7 - .../eval/trig-star-eval-annotation-2.trig | 12 - .../trig/eval/trig-star-eval-annotation-3.nq | 6 - .../eval/trig-star-eval-annotation-3.trig | 7 - .../trig/eval/trig-star-eval-annotation-4.nq | 3 - .../eval/trig-star-eval-annotation-4.trig | 3 - .../trig/eval/trig-star-eval-annotation-5.nq | 3 - .../eval/trig-star-eval-annotation-5.trig | 4 - .../trig/eval/trig-star-eval-bnode-1.nq | 2 - .../trig/eval/trig-star-eval-bnode-1.trig | 6 - .../trig/eval/trig-star-eval-bnode-2.nq | 2 - .../trig/eval/trig-star-eval-bnode-2.trig | 6 - .../trig-star-eval-quoted-annotation-1.nq | 2 - .../trig-star-eval-quoted-annotation-1.trig | 3 - .../trig-star-eval-quoted-annotation-2.nq | 2 - .../trig-star-eval-quoted-annotation-2.trig | 3 - .../trig-star-eval-quoted-annotation-3.nq | 2 - .../trig-star-eval-quoted-annotation-3.trig | 3 - .../rdf-star-cg/trig/syntax/manifest.ttl | 175 - .../trig/syntax/trig-star-annotation-1.trig | 3 - .../trig/syntax/trig-star-annotation-2.trig | 12 - .../trig/syntax/trig-star-syntax-bad-01.trig | 6 - .../trig/syntax/trig-star-syntax-bad-02.trig | 6 - .../trig/syntax/trig-star-syntax-bad-03.trig | 6 - .../trig/syntax/trig-star-syntax-bad-04.trig | 6 - .../trig/syntax/trig-star-syntax-bad-05.trig | 5 - .../trig/syntax/trig-star-syntax-bad-06.trig | 5 - .../trig/syntax/trig-star-syntax-bad-07.trig | 4 - .../trig/syntax/trig-star-syntax-bad-08.trig | 3 - .../syntax/trig-star-syntax-bad-ann-1.trig | 4 - .../syntax/trig-star-syntax-bad-ann-2.trig | 3 - .../syntax/trig-star-syntax-basic-01.trig | 6 - .../syntax/trig-star-syntax-basic-02.trig | 6 - .../syntax/trig-star-syntax-bnode-01.trig | 6 - .../syntax/trig-star-syntax-bnode-02.trig | 6 - .../syntax/trig-star-syntax-bnode-03.trig | 3 - .../syntax/trig-star-syntax-compound.trig | 12 - .../syntax/trig-star-syntax-inside-01.trig | 6 - .../syntax/trig-star-syntax-inside-02.trig | 7 - .../syntax/trig-star-syntax-nested-01.trig | 9 - .../syntax/trig-star-syntax-nested-02.trig | 7 - .../rdf-star-cg/turtle/eval/manifest.ttl | 113 - .../turtle/eval/turtle-star-eval-01.nt | 1 - .../turtle/eval/turtle-star-eval-02.nt | 1 - .../turtle/eval/turtle-star-eval-02.ttl | 3 - .../eval/turtle-star-eval-annotation-1.nt | 2 - .../eval/turtle-star-eval-annotation-1.ttl | 3 - .../eval/turtle-star-eval-annotation-2.nt | 7 - .../eval/turtle-star-eval-annotation-2.ttl | 10 - .../eval/turtle-star-eval-annotation-3.nt | 6 - .../eval/turtle-star-eval-annotation-3.ttl | 5 - .../eval/turtle-star-eval-annotation-4.nt | 3 - .../eval/turtle-star-eval-annotation-4.ttl | 3 - .../eval/turtle-star-eval-annotation-5.nt | 3 - .../eval/turtle-star-eval-annotation-5.ttl | 4 - .../turtle/eval/turtle-star-eval-bnode-1.nt | 2 - .../turtle/eval/turtle-star-eval-bnode-1.ttl | 4 - .../turtle/eval/turtle-star-eval-bnode-2.nt | 2 - .../turtle/eval/turtle-star-eval-bnode-2.ttl | 4 - .../turtle-star-eval-quoted-annotation-1.nt | 2 - .../turtle-star-eval-quoted-annotation-1.ttl | 3 - .../turtle-star-eval-quoted-annotation-2.nt | 2 - .../turtle-star-eval-quoted-annotation-2.ttl | 3 - .../turtle-star-eval-quoted-annotation-3.nt | 2 - .../turtle-star-eval-quoted-annotation-3.ttl | 3 - .../rdf-star-cg/turtle/syntax/manifest.ttl | 268 -- .../syntax/nt-ttl-star-bad-syntax-1.ttl | 1 - .../syntax/nt-ttl-star-bad-syntax-2.ttl | 1 - .../syntax/nt-ttl-star-bad-syntax-3.ttl | 1 - .../syntax/nt-ttl-star-bad-syntax-4.ttl | 1 - .../turtle/syntax/nt-ttl-star-bnode-1.ttl | 2 - .../turtle/syntax/nt-ttl-star-bnode-2.ttl | 2 - .../turtle/syntax/nt-ttl-star-nested-1.ttl | 3 - .../turtle/syntax/nt-ttl-star-nested-2.ttl | 3 - .../turtle/syntax/nt-ttl-star-syntax-1.ttl | 1 - .../turtle/syntax/nt-ttl-star-syntax-2.ttl | 1 - .../turtle/syntax/nt-ttl-star-syntax-3.ttl | 1 - .../turtle/syntax/nt-ttl-star-syntax-4.ttl | 1 - .../turtle/syntax/nt-ttl-star-syntax-5.ttl | 1 - .../syntax/turtle-star-annotation-1.ttl | 3 - .../syntax/turtle-star-annotation-2.ttl | 10 - .../syntax/turtle-star-syntax-bad-01.ttl | 4 - .../syntax/turtle-star-syntax-bad-02.ttl | 4 - .../syntax/turtle-star-syntax-bad-03.ttl | 4 - .../syntax/turtle-star-syntax-bad-04.ttl | 4 - .../syntax/turtle-star-syntax-bad-05.ttl | 3 - .../syntax/turtle-star-syntax-bad-06.ttl | 4 - .../syntax/turtle-star-syntax-bad-07.ttl | 3 - .../syntax/turtle-star-syntax-bad-08.ttl | 3 - .../syntax/turtle-star-syntax-bad-ann-1.ttl | 6 - .../syntax/turtle-star-syntax-bad-ann-2.ttl | 3 - .../syntax/turtle-star-syntax-basic-01.ttl | 4 - .../syntax/turtle-star-syntax-basic-02.ttl | 4 - .../syntax/turtle-star-syntax-bnode-01.ttl | 4 - .../syntax/turtle-star-syntax-bnode-02.ttl | 4 - .../syntax/turtle-star-syntax-bnode-03.ttl | 3 - .../syntax/turtle-star-syntax-compound.ttl | 11 - .../syntax/turtle-star-syntax-inside-01.ttl | 4 - .../syntax/turtle-star-syntax-inside-02.ttl | 5 - .../syntax/turtle-star-syntax-nested-01.ttl | 7 - .../syntax/turtle-star-syntax-nested-02.ttl | 5 - .../rdf12-wg/Syntax-SPARQL_12/manifest.ttl | 43 + .../Syntax-SPARQL_12/syntax-sparql12-01.rq} | 3 +- .../Syntax-SPARQL_12/syntax-sparql12-02.rq} | 3 +- jena-arq/testing/rdf12-wg/gen-sparql-12.sh | 20 + jena-arq/testing/rdf12-wg/syn-func12.sh | 272 ++ jena-arq/testing/rdf12-wg/syn-sparql_12.sh | 137 + .../org/apache/jena/atlas/io/PeekReader.java | 1 + .../atlas/iterator/IteratorBlockingQueue.java | 59 +- .../jena/atlas/iterator/IteratorConcat.java | 4 +- .../jena/atlas/iterator/IteratorCons.java | 9 +- .../jena/atlas/iterator/IteratorInteger.java | 63 - .../jena/atlas/iterator/NullIterator.java | 2 + .../atlas/iterator/SingletonIterator.java | 35 +- .../org/apache/jena/enhanced/EnhNode.java | 4 +- .../main/java/org/apache/jena/graph/Node.java | 10 +- .../org/apache/jena/graph/NodeFactory.java | 95 +- .../org/apache/jena/graph/Node_Triple.java | 6 +- .../org/apache/jena/graph/TextDirection.java | 31 +- .../apache/jena/graph/langtag/LangTags.java | 2 - .../java/org/apache/jena/rdf/model/Model.java | 12 +- .../org/apache/jena/rdf/model/ModelCon.java | 95 +- .../apache/jena/rdf/model/impl/ModelCom.java | 44 +- .../jena/rdf/model/impl/ResourceImpl.java | 2 +- .../org/apache/jena/rdf/model/impl/Util.java | 4 +- .../rdfxml/xmloutput/impl/RDFXML_Basic.java | 4 + .../jena/rdfxml/xmloutput/impl/Unparser.java | 7 +- .../apache/jena/util/PrefixMappingUtils.java | 4 +- .../java/org/apache/jena/vocabulary/RDF.java | 13 +- .../org/apache/jena/graph/test/TestNode.java | 2 +- .../jena/graph/test/TestNodeEdgeCases.java | 2 +- .../jena/graph/test/TestNodeExtras.java | 35 +- .../graph/test/TestRDFStringLiterals.java | 35 +- .../org/apache/jena/test/TestModelUtil.java | 12 +- .../querybuilder/handlers/WhereHandler.java | 16 +- .../rewriters/BuildElementVisitor.java | 20 +- .../rewriters/ElementRewriter.java | 12 + .../querybuilder/rewriters/ExprRewriter.java | 4 +- .../rewriters/NodeValueRewriter.java | 19 +- .../querybuilder/rewriters/OpRewriter.java | 21 +- .../updatebuilder/QuadIteratorBuilder.java | 11 + .../updatebuilder/WhereQuadHolder.java | 12 +- .../jena/arq/querybuilder/ConvertersTest.java | 2 +- .../arq/querybuilder/ExprFactoryTest.java | 2 +- .../jena/arq/querybuilder/WhereValidator.java | 16 + .../clauses/ValuesClauseTest.java | 2 +- .../model/impl/SecuredModelImpl.java | 66 +- .../query/rewriter/OpRewriter.java | 30 +- .../binary/RDFChangesWriterBinary.java | 2 +- .../rdfpatch/binary/RDFPatchReaderBinary.java | 2 +- .../rdfpatch/text/RDFPatchReaderText.java | 12 +- .../jena/rdfpatch/text/TokenWriterText.java | 109 - .../jena/rdfpatch/AbstractTestPatchIO.java | 4 +- jena-rdfpatch/testing/files/syntax-bad-1.rdfp | 5 - .../org/apache/jena/tdb1/lib/DumpOps.java | 212 +- .../apache/jena/tdb1/solver/BindingTDB.java | 9 +- .../org/apache/jena/tdb1/store/NodeType.java | 2 +- .../jena/tdb1/store/nodetable/DecoderSSE.java | 8 +- .../tdb1/store/nodetable/NodeTableInline.java | 57 +- .../jena/tdb1/store/nodetable/NodecSSE.java | 4 +- .../org/apache/jena/tdb1/Scripts_TDB1.java | 5 +- .../jena/tdb1/store/TestQuadFilter.java | 14 +- .../nodetable/AbstractTestNodeTable.java | 2 +- .../jena/tdb1/store/nodetable/TestNodec.java | 2 +- .../org/apache/jena/tdb2/lib/DumpOps.java | 169 + .../org/apache/jena/tdb2/lib/NodeLib.java | 2 +- .../org/apache/jena/tdb2/Scripts_TDB2.java | 5 +- .../jena/tdb2/store/TestQuadFilter.java | 19 +- 546 files changed, 14002 insertions(+), 12872 deletions(-) create mode 100644 jena-arq/Grammar/README create mode 100755 jena-arq/Grammar/jj2bnf create mode 100755 jena-arq/Grammar/sparql2bnf delete mode 100644 jena-arq/Grammar/sparql_12.txt delete mode 100644 jena-arq/Grammar/sse/jj2html delete mode 100644 jena-arq/Grammar/sse/tokens.inc rename jena-arq/src/main/java/org/apache/jena/sparql/algebra/op/{OpDiff.java => OpAntiJoin.java} (83%) create mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/algebra/op/OpSemiJoin.java delete mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/engine/iterator/QueryIterDiff.java create mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/engine/iterator/QueryIterHalfJoin.java create mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/expr/E_HasLang.java create mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/expr/E_HasLangDir.java create mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/expr/E_LangDir.java create mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/expr/E_StrLangDir.java create mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/expr/nodevalue/NodeValueLangDir.java rename jena-arq/src/main/java/org/apache/jena/sparql/function/library/triple/{EmbeddedTripleFunctions.java => TripleTermOps.java} (93%) rename jena-arq/src/main/java/org/apache/jena/sparql/lang/sparql_12/{SPARQLParser11Base.java => SPARQLParser12Base.java} (89%) create mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/syntax/ElementAntiJoin.java create mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/syntax/ElementSemiJoin.java delete mode 100644 jena-arq/src/main/java/org/apache/jena/sparql/syntax/PatternVarsVisitor.java create mode 100644 jena-arq/src/test/java/org/apache/jena/arq/junit/LibTest.java create mode 100644 jena-arq/src/test/java/org/apache/jena/rdf12/AbstratTestSPARQL12Eval.java create mode 100644 jena-arq/src/test/java/org/apache/jena/rdf12/LibTestSPARQL12.java rename jena-arq/src/test/java/org/apache/jena/{external/Scripts_RDFStar.java => rdf12/TEST.java} (67%) create mode 100644 jena-arq/src/test/java/org/apache/jena/rdf12/TS_RDF12.java create mode 100644 jena-arq/src/test/java/org/apache/jena/rdf12/TestRDF12LangSyntax.java rename jena-base/src/main/java/org/apache/jena/atlas/iterator/IteratorNoRemove.java => jena-arq/src/test/java/org/apache/jena/rdf12/TestSPARQL12Eval.java (64%) rename jena-arq/src/test/java/org/apache/jena/{rdf_star/TestSPARQLStarExtra.java => rdf12/TestSPARQL12Results.java} (95%) create mode 100644 jena-arq/src/test/java/org/apache/jena/rdf12/TestSPARQL12Syntax.java rename jena-arq/src/test/java/org/apache/jena/{rdf_star/TS_RDF_Star.java => rdf12/basic/TS_RDFStar_Basic.java} (87%) rename jena-arq/src/test/java/org/apache/jena/{rdf_star => rdf12/basic}/TestNQuadsStarParse.java (63%) rename jena-arq/src/test/java/org/apache/jena/{rdf_star => rdf12/basic}/TestNTriplesStarParse.java (67%) create mode 100644 jena-arq/src/test/java/org/apache/jena/rdf12/basic/TestSPARQLStarParse.java rename jena-arq/src/test/java/org/apache/jena/{rdf_star => rdf12/basic}/TestTrigStarParse.java (59%) rename jena-arq/src/test/java/org/apache/jena/{rdf_star => rdf12/basic}/TestTurtleStarParse.java (84%) delete mode 100644 jena-arq/src/test/java/org/apache/jena/rdf_star/TestSPARQLStarParse.java create mode 100644 jena-arq/src/test/java/org/apache/jena/sparql/Scripts_DatasetMap.java create mode 100644 jena-arq/src/test/java/org/apache/jena/sparql/Scripts_DatasetMapLink.java create mode 100644 jena-arq/src/test/java/org/apache/jena/sparql/junit/RunnerSPARQL_DatasetMap.java create mode 100644 jena-arq/src/test/java/org/apache/jena/sparql/junit/RunnerSPARQL_DatasetMapLink.java delete mode 100644 jena-arq/testing/RIOT/Lang/TriX/trix-star-bad-emb-nested-1.trix delete mode 100644 jena-arq/testing/RIOT/Lang/TriX/trix-star-bad-emb-nested-2.trix delete mode 100644 jena-arq/testing/RIOT/Lang/TriX/trix-star-bad-emb-nested-3.trix rename jena-arq/testing/RIOT/Lang/TriX/{trix-star-bad-asserted-1.trix => trix-star-bad-triple-term-1.trix} (100%) rename jena-arq/testing/RIOT/Lang/TriX/{trix-star-bad-asserted-2.trix => trix-star-bad-triple-term-2.trix} (100%) rename jena-arq/testing/RIOT/Lang/TriX/{trix-star-bad-emb-1.trix => trix-star-bad-triple-term-3.trix} (51%) rename jena-arq/testing/RIOT/Lang/TriX/{trix-star-bad-emb-2.trix => trix-star-bad-triple-term-4.trix} (51%) delete mode 100644 jena-arq/testing/rdf-star-cg/manifest.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/manifest.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-bad-syntax-1.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-bad-syntax-2.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-bad-syntax-3.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-bad-syntax-4.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-bnode-1.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-bnode-2.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-nested-1.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-nested-2.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-syntax-1.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-syntax-2.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-syntax-3.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-syntax-4.nt delete mode 100644 jena-arq/testing/rdf-star-cg/nt/syntax/ntriples-star-syntax-5.nt delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/data-0.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/data-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/data-3.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/data-4.trig delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/data-5.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/data-6.trig delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/data-7.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/data-order-kind.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/data-order.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/empty.nq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/manifest.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-2.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-2.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-3.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-3.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-4.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-4.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-5.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-5.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-6.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-basic-6.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-1.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-2.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-3.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-3.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-4.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-4.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-5.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-construct-5.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-expr-01.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-expr-01.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-expr-02.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-expr-02.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-graphs-1.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-graphs-1.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-graphs-2.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-graphs-2.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-op-1.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-op-1.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-op-2.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-op-2.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-op-3.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-op-3.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-op-4.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-op-4.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-order-1.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-order-2.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-order-by.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-01.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-01.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-02.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-02.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-03.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-03.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-04.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-04.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-05.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-05.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-06.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-06.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-07.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-07.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-08.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-08.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-09.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-pattern-09.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-results-1.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-results-1.srj delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-results-1.srx delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-update-1.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-update-2.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/sparql-star-update-3.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/update-result-1.trig delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/update-result-2.trig delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/eval/update-result-3.trig delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/manifest.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-annotation-01.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-annotation-02.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-annotation-03.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-annotation-04.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-annotation-05.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-annotation-06.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-annotation-07.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-annotation-08.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-annotation-09.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-01.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-02.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-03.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-04.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-05.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-06.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-07.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-08.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-09.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-10.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-11.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-12.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-ann-1.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-ann-2.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-ann-path-1.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-ann-path-2.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-ann-path-3.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-ann-path-4.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-ann-path-5.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-ann-path-6.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-ann-path-7.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-update-1.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-update-2.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-update-3.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bad-update-4.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-basic-01.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-basic-02.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-basic-03.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-basic-04.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-basic-05.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-basic-06.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-basic-07.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bnode-01.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bnode-02.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-bnode-03.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-compound.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-expr-01.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-expr-02.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-expr-03.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-expr-04.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-expr-05.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-expr-06.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-inside-01.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-inside-02.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-nested-01.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-nested-02.rq delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-update-1.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-update-2.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-update-3.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-update-4.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-update-5.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-update-6.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-update-7.ru delete mode 100644 jena-arq/testing/rdf-star-cg/sparql/syntax/sparql-star-syntax-update-8.ru delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/manifest.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-01.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-01.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-02.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-02.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-1.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-1.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-2.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-2.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-3.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-3.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-4.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-4.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-5.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-annotation-5.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-bnode-1.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-bnode-1.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-bnode-2.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-bnode-2.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-quoted-annotation-1.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-quoted-annotation-1.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-quoted-annotation-2.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-quoted-annotation-2.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-quoted-annotation-3.nq delete mode 100644 jena-arq/testing/rdf-star-cg/trig/eval/trig-star-eval-quoted-annotation-3.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/manifest.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-annotation-1.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-annotation-2.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-01.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-02.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-03.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-04.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-05.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-06.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-07.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-08.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-ann-1.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bad-ann-2.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-basic-01.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-basic-02.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bnode-01.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bnode-02.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-bnode-03.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-compound.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-inside-01.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-inside-02.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-nested-01.trig delete mode 100644 jena-arq/testing/rdf-star-cg/trig/syntax/trig-star-syntax-nested-02.trig delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/manifest.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-01.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-02.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-02.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-1.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-2.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-3.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-3.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-4.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-4.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-5.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-annotation-5.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-bnode-1.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-bnode-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-bnode-2.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-bnode-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-quoted-annotation-1.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-quoted-annotation-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-quoted-annotation-2.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-quoted-annotation-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-quoted-annotation-3.nt delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/eval/turtle-star-eval-quoted-annotation-3.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/manifest.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-bad-syntax-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-bad-syntax-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-bad-syntax-3.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-bad-syntax-4.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-bnode-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-bnode-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-nested-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-nested-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-syntax-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-syntax-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-syntax-3.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-syntax-4.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/nt-ttl-star-syntax-5.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-annotation-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-annotation-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-01.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-02.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-03.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-04.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-05.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-06.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-07.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-08.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-ann-1.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bad-ann-2.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-basic-01.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-basic-02.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bnode-01.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bnode-02.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-bnode-03.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-compound.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-inside-01.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-inside-02.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-nested-01.ttl delete mode 100644 jena-arq/testing/rdf-star-cg/turtle/syntax/turtle-star-syntax-nested-02.ttl create mode 100644 jena-arq/testing/rdf12-wg/Syntax-SPARQL_12/manifest.ttl rename jena-arq/testing/{rdf-star-cg/sparql/eval/data-1.ttl => rdf12-wg/Syntax-SPARQL_12/syntax-sparql12-01.rq} (54%) rename jena-arq/testing/{rdf-star-cg/turtle/eval/turtle-star-eval-01.ttl => rdf12-wg/Syntax-SPARQL_12/syntax-sparql12-02.rq} (54%) create mode 100755 jena-arq/testing/rdf12-wg/gen-sparql-12.sh create mode 100644 jena-arq/testing/rdf12-wg/syn-func12.sh create mode 100644 jena-arq/testing/rdf12-wg/syn-sparql_12.sh delete mode 100644 jena-base/src/main/java/org/apache/jena/atlas/iterator/IteratorInteger.java delete mode 100644 jena-rdfpatch/testing/files/syntax-bad-1.rdfp create mode 100644 jena-tdb2/src/main/java/org/apache/jena/tdb2/lib/DumpOps.java diff --git a/jena-arq/Grammar/.gitignore b/jena-arq/Grammar/.gitignore index d1648fbab98..a786afe999c 100644 --- a/jena-arq/Grammar/.gitignore +++ b/jena-arq/Grammar/.gitignore @@ -9,5 +9,7 @@ Y12.html sparql-grammar.html # Grammar in BNF text sparql.bnf -# Grammar in HTML as a standalone web page. +## BNF +sparql.bnf +## Grammar in HTML as a standalone web page. sparql-html.html diff --git a/jena-arq/Grammar/README b/jena-arq/Grammar/README new file mode 100644 index 00000000000..65c77d522a8 --- /dev/null +++ b/jena-arq/Grammar/README @@ -0,0 +1,31 @@ +==== SPARQL Parser + +Run + + grammar + +This produces the code for the current version SPARQL +and the ARQ (SPARQL with extensions) parsers. + +== + +To produce the HTML for the SPARQL Grammar for the W3C spec: +produce the SPARQL 1.2 specific file + + grammar + +which also generates Java code and can be used for checking. + +Then run + + sparql2html + +The output is in sparql-grammar.html. + +This replaces the table between "" in the specific HTML. + +Running + + sparql2bnf + +produces a text BNF form. diff --git a/jena-arq/Grammar/Turtle/turtle.jj b/jena-arq/Grammar/Turtle/turtle.jj index 57296a15ed8..ca1c11e4ae5 100644 --- a/jena-arq/Grammar/Turtle/turtle.jj +++ b/jena-arq/Grammar/Turtle/turtle.jj @@ -80,9 +80,9 @@ void Statement() : {} { Directive() | DirectiveOld() -// | (TriplesSameSubject() ( | ) ) +// | (Triples() ( | ) ) // Strict - | (TriplesSameSubject() ) + | (Triples() ) } // Turtle [3] directive @@ -106,17 +106,15 @@ void DirectiveOld() : { Token t ; String iri ; } { setBase(iri, t.beginLine, t.beginColumn) ; } } -// Turtle [6] triples -void TriplesSameSubject() : { Node s ; } +void Triples() : { Node n; } { - s = Subject() - PredicateObjectList(s) + n = Subject() PredicateObjectList(n) | - s = BlankNodePropertyList() - ( PredicateObjectList(s) )? + n = BlankNodePropertyList() ( PredicateObjectList(n) )? +| + n = ReifiedTriple() ( PredicateObjectList(n) )? } -// Turtle [7] predicateObjectList void PredicateObjectList(Node s) : { Node p = null ; } { p = Verb() @@ -124,7 +122,6 @@ void PredicateObjectList(Node s) : { Node p = null ; } ( (p = Verb() ObjectList(s, p))? )* } -// Turtle [8] objectList void ObjectList(Node s, Node p): { Node o ; } { o = Object() @@ -137,17 +134,6 @@ void ObjectList(Node s, Node p): { Node o ; } )* } -// RDF-star Annotation Syntax -void Annotation(Node s, Node p, Node o) : {} -{ - ( - - { Node x = createQuotedTriple(s, p, o, token.beginLine, token.beginColumn); } - PredicateObjectList(x) - - )? -} - // Turtle [9] verb Node Verb() : { Node p ; } { @@ -163,13 +149,10 @@ Node Subject() : { Node s; String iri ; } s = BlankNode() | s = Collection() - | - s = QuotedTriple() ) { return s ; } } - // Turtle [11] predicate Node Predicate() : { String iri;} { @@ -185,43 +168,12 @@ Node Object(): { Node o ; String iri; } | o = Collection() | o = BlankNodePropertyList() | o = Literal() - | o = QuotedTriple() + | o = TripleTerm() + | o = ReifiedTriple() ) { return o; } } -Node QuotedTripleSubject(): { Node o ; String iri; } -{ - ( iri = iri() { o = createURI(iri, token.beginLine, token.beginColumn) ; } - | o = BlankNode() - | o = QuotedTriple() - ) - { return o; } -} - -Node QuotedTripleObject(): { Node o ; String iri; } -{ - ( iri = iri() { o = createURI(iri, token.beginLine, token.beginColumn) ; } - | o = BlankNode() - | o = Literal() - | o = QuotedTriple() - ) - { return o ; } -} - -// The syntax for RDF-star <<>> -Node QuotedTriple() : { Node s , p , o ; Token t ; } -{ - t = - s = QuotedTripleSubject() - p = Verb() - o = QuotedTripleObject() - - { Node n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); - return n; - } -} - // Turtle [13] literal Node Literal() : { Node n ;} { @@ -302,7 +254,7 @@ Node RDFLiteral() : { Token t ; String lex = null ; } String LangTag() : { Token t ; } { // Enumerate the directives here because they look like language tags. - ( t = | t = AnyDirective() ) + ( t = | t = AnyDirective() ) { String lang = stripChars(t.image, 1) ; return lang ; } } @@ -369,6 +321,106 @@ String IRIREF() : { Token t ; } { return resolveQuotedIRI(t.image, t.beginLine, t.beginColumn) ; } } +Node Reifier() : { Node n = null; String iriStr; Token t; } +{ + t = + ( + iriStr = iri() { n = createURI(iriStr, token.beginLine, token.beginColumn) ; } + | n = BlankNode() + )? + { if ( n == null ) n = createBNode(t.beginLine, t.beginColumn) ; } + { return n ; } +} + +Node ReifiedTriple() : { Node reifId = null ; Token tok ; Node s; Node p ; Node o ; } +{ + tok = + s = ReifiedTripleSubject() + p = Verb() + o = ReifiedTripleObject() + ( reifId = Reifier())? + { reifId = emitTripleReifier(tok.beginLine, tok.beginColumn, reifId, s, p, o); } + + { return reifId ; } +} + +// rtSubject +Node ReifiedTripleSubject() : { Node s; String iri; } { + ( iri = iri() { s = createURI(iri, token.beginLine, token.beginColumn) ; } + | s = BlankNode() + | s = ReifiedTriple() + ) + { return s; } +} + +// rtObject +Node ReifiedTripleObject() : { Node o; String iri; } { + ( iri = iri() { o = createURI(iri, token.beginLine, token.beginColumn) ; } + | o = BlankNode() + | o = Literal() + | o = TripleTerm() + | o = ReifiedTriple() + ) + { return o; } +} + +Node TripleTerm() : { Node n = null ; Token openToken ; String iri ; Node s , p , o ; } +{ + + s = TripleTermSubject() + p = Verb() + o = TripleTermObject() + + { return createTripleTerm(s, p, o, token.beginLine, token.beginColumn) ; } +} + +// ttSubject +Node TripleTermSubject(): { Node o ; String iri; } +{ + ( iri = iri() { o = createURI(iri, token.beginLine, token.beginColumn) ; } + | o = BlankNode() + ) + { return o; } +} + +// ttObject +Node TripleTermObject(): { Node o ; String iri; } +{ + ( iri = iri() { o = createURI(iri, token.beginLine, token.beginColumn) ; } + | o = BlankNode() + | o = Literal() + | o = TripleTerm() + ) + { return o ; } +} + +// RDF-star Annotation Syntax +void Annotation(Node s, Node p, Node o) : { Node reifId = null; } +{ + ( + reifId = Reifier() + { reifId = emitTripleReifier(token.beginLine, token.beginColumn, reifId, s, p, o) ; } + { setReifierId(reifId); } + | + { reifId = getOrAllocReifierId(s, p, o, token.beginLine, token.beginColumn); } + { clearReifierId(); } + AnnotationBlock(reifId) + ) * +} + +void AnnotationBlock( Node reifId ) : {} +{ + + PredicateObjectList(reifId) + +// ( +// +// { Node x = createQuotedTriple(s, p, o, token.beginLine, token.beginColumn); } +// PredicateObjectList(x) +// +// )? +} + // ------------------------------------------ // Tokens @@ -457,18 +509,23 @@ TOKEN : | < SEMICOLON: ";" > | < COMMA: "," > | < DOT: "." > + +| < DATATYPE: "^^"> +| < AT: "@"> + +| < L_TRIPLE: "<<(" > +| < R_TRIPLE: ")>>" > | < LT2: "<<" > | < GT2: ">>" > | < L_ANN: "{|" > | < R_ANN: "|}" > - -| < DATATYPE: "^^"> -| < AT: "@"> +| < TILDE: "~" > +| < VBAR: "|" > | )? ":" > | > | | ["0"-"9"]) ((|".")* )? > -| ()+("-" ()+)* > +| ()+("-" ()+)* ( "--" ()* )? > | <#A2Z: ["a"-"z","A"-"Z"]> | <#A2ZN: ["a"-"z","A"-"Z","0"-"9"]> diff --git a/jena-arq/Grammar/arq.jj b/jena-arq/Grammar/arq.jj index 4ffca766a36..96c41746932 100644 --- a/jena-arq/Grammar/arq.jj +++ b/jena-arq/Grammar/arq.jj @@ -628,6 +628,18 @@ Element TriplesBlock(ElementPathBlock acc) : { } ( (TriplesBlock(acc))? )? { return acc ; } } +Node ReifiedTripleBlock(TripleCollector acc) : { Node reifId ; } +{ + reifId = ReifiedTriple(acc) + PropertyList(reifId, acc) + { return reifId ; } +} +Node ReifiedTripleBlockPath(TripleCollector acc) : { Node reifId ; } +{ + reifId = ReifiedTriple(acc) + PropertyListPath(reifId, acc) + { return reifId ; } +} Element GraphPatternNotTriples() : { Element el = null ; } { ( @@ -636,6 +648,10 @@ Element GraphPatternNotTriples() : { Element el = null ; } el = OptionalGraphPattern() | el = LateralGraphPattern() + | + el = SemiJoinGraphPattern() + | + el = AntiJoinGraphPattern() | el = MinusGraphPattern() | @@ -667,6 +683,14 @@ Element LateralGraphPattern() : { Element el ; } { el = GroupGraphPattern() { return new ElementLateral(el) ; } } +Element SemiJoinGraphPattern() : { Element el ; } +{ el = GroupGraphPattern() + { return new ElementSemiJoin(el) ; } +} +Element AntiJoinGraphPattern() : { Element el ; } +{ el = GroupGraphPattern() + { return new ElementAntiJoin(el) ; } +} Element GraphGraphPattern() : { Element el ; Node n ;} { n = VarOrIri() el = GroupGraphPattern() @@ -756,7 +780,20 @@ Node DataBlockValue() : { Node n ; String iri ; } | n = NumericLiteral() { return n ; } | n = BooleanLiteral() { return n ; } | { return null ; } -| n = QuotedTripleData() { return n ; } +| n = TripleTermData() { return n ; } +} +Node Reifier() : { Token tok = null ; Node reifId = null ; } +{ + tok = + (reifId = VarOrReifierId() )? + { return reifId; } +} +Node VarOrReifierId() : { Node n = null; String iri = null; } +{ + ( n = Var() { return n; } + | iri = iri() { return createNode(iri) ; } + | n = BlankNode() { return n ; } + ) } Element Assignment() : { Var v ; Expr expr ; } { @@ -833,7 +870,7 @@ Expr FunctionCall() : { String fname ; Args a ; } { if ( AggregateRegistry.isRegistered(fname) ) { if ( ! getAllowAggregatesInExpressions() ) - throwParseException("Aggregate expression not legal at this point : "+fname, -1, -1) ; + throwParseException("Aggregate expression not legal at this point : "+fname, token.beginLine, token.beginColumn) ; Aggregator agg = AggregatorFactory.createCustom(fname, a) ; Expr exprAgg = getQuery().allocAggregate(agg) ; return exprAgg ; @@ -898,6 +935,8 @@ void TriplesSameSubject(TripleCollector acc) : { Node s ; } s = TriplesNode(tempAcc) PropertyList(s, tempAcc) { insert(acc, tempAcc) ; } +| + ReifiedTripleBlock(acc) } void PropertyList(Node s, TripleCollector acc) : { } { @@ -941,6 +980,8 @@ void TriplesSameSubjectPath(TripleCollector acc) : { Node s ; } s = TriplesNodePath(tempAcc) PropertyListPath(s, tempAcc) { insert(acc, tempAcc) ; } +| + ReifiedTripleBlockPath(acc) } void PropertyListPath(Node s, TripleCollector acc) : { } { @@ -1059,6 +1100,11 @@ Path PathMod(Path p) : { long i1 ; long i2 ; } ) ) } +long Integer() : {Token t ;} +{ + t = + { return integerValue(t.image) ; } +} Path PathPrimary() : { String str ; Path p ; Node n ; } { ( @@ -1109,16 +1155,11 @@ P_Path0 PathOneInPropertySet() : { String str ; Node n ; } ) ) } -long Integer() : {Token t ;} -{ - t = - { return integerValue(t.image) ; } -} Node TriplesNode(TripleCollectorMark acc) : { Node n ; } { - n = Collection(acc) { return n ; } + n = Collection(acc) { return n ; } | - n = BlankNodePropertyList(acc) { return n ; } + n = BlankNodePropertyList(acc) { return n ; } } Node BlankNodePropertyList(TripleCollector acc) : { Token t ; } { @@ -1130,9 +1171,9 @@ Node BlankNodePropertyList(TripleCollector acc) : { Token t ; } } Node TriplesNodePath(TripleCollectorMark acc) : { Node n ; } { - n = CollectionPath(acc) { return n ; } + n = CollectionPath(acc) { return n ; } | - n = BlankNodePropertyListPath(acc) { return n ; } + n = BlankNodePropertyListPath(acc) { return n ; } } Node BlankNodePropertyListPath(TripleCollector acc) : { Token t ; } { @@ -1190,80 +1231,177 @@ Node CollectionPath(TripleCollectorMark acc) : insert(acc, lastCell, nRDFrest, nRDFnil) ; return listHead ; } } -void AnnotationPath(TripleCollector acc, Node s, Node p, Path path, Node o) : {} +void AnnotationPath(TripleCollector acc, Node s, Node p, Path path, Node o) : { Node reifId = null ; } { ( - - { Node pAnn = preConditionAnnotation(s, p, path, o, token.beginLine, token.beginColumn) ; - Node x = createQuotedTriple(s, pAnn, o, token.beginLine, token.beginColumn); - } - PropertyListPathNotEmpty(x, acc) - - )? + { p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); } + reifId = Reifier() + { reifId = insertTripleReifier(acc, reifId, s, p, o, token.beginLine, token.beginColumn) ; } + { setReifierId(reifId); } + | + { + p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); + reifId = getOrAllocReifierId(acc, s, p, o, token.beginLine, token.beginColumn); + } + { clearReifierId(); } + AnnotationBlockPath(acc, reifId) + )* + { clearReifierId(); } +} +void AnnotationBlockPath(TripleCollector acc, Node reifId) : { } +{ + + PropertyListPathNotEmpty(reifId, acc) + } -void Annotation(TripleCollector acc, Node s, Node p, Path path, Node o) : { } +void Annotation(TripleCollector acc, Node s, Node p, Path path, Node o) : { Node reifId = null ; } { ( - - { Node pAnn = preConditionAnnotation(s, p, path, o, token.beginLine, token.beginColumn) ; - Node x = createQuotedTriple(s, p, o, token.beginLine, token.beginColumn); - } - PropertyListNotEmpty(x, acc) - - )? + { p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); } + reifId = Reifier() + { reifId = insertTripleReifier(acc, reifId, s, p, o, token.beginLine, token.beginColumn) ; } + { setReifierId(reifId); } + | + { + p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); + reifId = getOrAllocReifierId(acc, s, p, o, token.beginLine, token.beginColumn); + } + { clearReifierId(); } + AnnotationBlock(acc, reifId) + )* +} +void AnnotationBlock(TripleCollector acc, Node reifId) : { } +{ + + PropertyListNotEmpty(reifId, acc) + } Node GraphNode(TripleCollectorMark acc) : { Node n ; } { - n = VarOrTerm() { return n ; } + n = VarOrTerm() { return n ; } | - n = TriplesNode(acc) { return n ; } + n = TriplesNode(acc) { return n ; } + | + n = ReifiedTriple(acc) { return n ; } } Node GraphNodePath(TripleCollectorMark acc) : { Node n ; } { n = VarOrTerm() { return n ; } - | +| n = TriplesNodePath(acc) { return n ; } +| + n = ReifiedTriple(acc) { return n ; } } Node VarOrTerm() : { Node n = null ; String iri ; } { ( n = Var() | iri = iri() { return createNode(iri) ; } - | n = RDFLiteral() { return n ; } - | n = NumericLiteral() { return n ; } - | n = BooleanLiteral() { return n ; } - | n = BlankNode() { return n ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = BlankNode() | { return nRDFnil ; } - | n = QuotedTriple() -) - { return n ; } + | n = TripleTerm() { return n; } + ) + { return n; } } -Node QuotedTriple() : { Node n = null ; Token t ; Node s , p , o ; } +Node ReifiedTriple(TripleCollector acc) : { Node reifId = null ; Token tok ; Node s; Node p ; Node o ; } { - t = - s = VarOrTerm() + tok = + s = ReifiedTripleSubject(acc) p = Verb() - o = VarOrTerm() - { n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); } + o = ReifiedTripleObject(acc) + (reifId = Reifier())? + { reifId = insertTripleReifier(acc, reifId, s, p, o, tok.beginLine, tok.beginColumn) ; } + { return reifId; } +} +Node ReifiedTripleSubject(TripleCollector acc) : { Node s; String iri; } +{ + ( s = Var() + | iri = iri() { s = createNode(iri) ; } + | s = RDFLiteral() + | s = NumericLiteral() + | s = BooleanLiteral() + | s = BlankNode() + | s = ReifiedTriple(acc) + ) + { return s; } +} +Node ReifiedTripleObject(TripleCollector acc) : { Node o; String iri; } +{ + ( o = Var() + | iri = iri() { o = createNode(iri) ; } + | o = RDFLiteral() + | o = NumericLiteral() + | o = BooleanLiteral() + | o = BlankNode() + | o = ReifiedTriple(acc) + | o = TripleTerm() + ) + { return o; } +} +Node TripleTerm() : { Node n = null ; Token openToken ; String iri ; Node s , p , o ; } +{ + openToken = + s = TripleTermSubject() + p = Verb() + o = TripleTermObject() + { n = createTripleTerm(s, p, o, openToken.beginLine, openToken.beginColumn); } + + { return n ; } +} +Node TripleTermSubject() : { Node n; String iri; } +{ + ( n = Var() + | iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = BlankNode() + ) { return n; } } -Node QuotedTripleData() : { Node n = null ; Token t ; String iri ; Node s , p , o ; } +Node TripleTermObject() : { Node n; String iri; } { - t = - ( s = DataValueTerm() ) - ( iri = iri() { p = createNode(iri) ; } | { p = nRDFtype ; } ) - ( o = DataValueTerm() ) - { n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); } - + ( n = Var() + | iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = BlankNode() + | n = TripleTerm() { return n; } + ) { return n; } } -Node DataValueTerm() : { Node n = null ; String iri ; Node s , p , o ; } +Node TripleTermData() : { Node n = null ; Token openToken ; String iri ; Node s , p , o ; } { - iri = iri() { return createNode(iri) ; } -| n = RDFLiteral() { return n ; } -| n = NumericLiteral() { return n ; } -| n = BooleanLiteral() { return n ; } -| n = QuotedTripleData() { return n ; } + openToken = + s = TripleTermDataSubject() + ( iri = iri() { p = createNode(iri) ; } | { p = nRDFtype ; } ) + o = TripleTermDataObject() + { n = createTripleTerm(s, p, o, openToken.beginLine, openToken.beginColumn); } + + { return n ; } +} +Node TripleTermDataSubject() : { Node n = null; String iri; } +{ + ( iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + ) + { return n; } +} +Node TripleTermDataObject() : { Node n = null; String iri; } +{ + ( iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = TripleTermData() + ) + { return n; } } Node VarOrIri() : {Node n = null ; String iri ; } { @@ -1401,27 +1539,38 @@ Expr PrimaryExpression() : { Expr expr ; Node n ; } | n = NumericLiteral() { return asExpr(n) ; } | n = BooleanLiteral() { return asExpr(n) ; } | n = Var() { return asExpr(n) ; } - | n = ExprQuotedTriple() { return asExpr(n) ; } + | n = ExprTripleTerm() { return asExpr(n) ; } ) } -Node ExprVarOrTerm() : { Node n; String s;} +Node ExprTripleTerm() : { Token t ; Node s,p,o,n; } +{ + t = + s = ExprTripleTermSubject() + p = Verb() + o = ExprTripleTermObject() + { n = createTripleTerm(s, p, o, t.beginLine, t.beginColumn); } + + { return n; } +} +Node ExprTripleTermSubject() : { Node n; String iri; } { - ( s = iri() { n = createNode(s); } + ( iri = iri() { n = createNode(iri); } | n = RDFLiteral() | n = NumericLiteral() | n = BooleanLiteral() | n = Var() - | n = ExprQuotedTriple() ) { return n; } } -Node ExprQuotedTriple() : { Token t ; Node s,p,o,n; } -{ t = - s = ExprVarOrTerm() - p = Verb() - o = ExprVarOrTerm() - { n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); } - +Node ExprTripleTermObject() : { Node n; String iri; } +{ + ( iri = iri() { n = createNode(iri); } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = Var() + | n = ExprTripleTerm() + ) { return n; } } Expr BrackettedExpression() : { Expr expr ; } @@ -1441,6 +1590,8 @@ Expr BuiltInCall() : { Expr expr ; | expr1 = Expression() expr2 = Expression() { return new E_LangMatches(expr1, expr2) ; } + | expr = Expression() + { return new E_LangDir(expr) ; } | expr = Expression() { return new E_Datatype(expr) ; } | gn = Var() @@ -1514,6 +1665,10 @@ Expr BuiltInCall() : { Expr expr ; { return new E_Conditional(expr, expr1, expr2) ; } | expr1 = Expression() expr2 = Expression() { return new E_StrLang(expr1, expr2) ; } + | expr1 = Expression() + expr2 = Expression() + expr3 = Expression() + { return new E_StrLangDir(expr1, expr2, expr3) ; } | expr1 = Expression() expr2 = Expression() { return new E_StrDatatype(expr1, expr2) ; } | expr1 = Expression() expr2 = Expression() @@ -1528,13 +1683,19 @@ Expr BuiltInCall() : { Expr expr ; { return new E_IsLiteral(expr) ; } | expr = Expression() { return new E_IsNumeric(expr) ; } + | expr = Expression() + { return new E_HasLang(expr) ; } + | expr = Expression() + { return new E_HasLangDir(expr) ; } | expr = RegexExpression() { return expr ; } | expr = ExistsFunc() { return expr ; } | expr = NotExistsFunc() { return expr ; } -| expr = Expression() + | expr = Expression() { return new E_IsTriple(expr) ; } - | expr1 = Expression() expr2 = Expression() expr3 = Expression() + | expr1 = Expression() + expr2 = Expression() + expr3 = Expression() { return new E_TripleFn(expr1, expr2, expr3) ; } | expr = Expression() { return new E_TripleSubject(expr) ; } @@ -1689,7 +1850,7 @@ Expr iriOrFunction() : { String iri ; Args a = null ; } return asExpr(createNode(iri)) ; if ( AggregateRegistry.isRegistered(iri) ) { if ( ! getAllowAggregatesInExpressions() ) - throwParseException("Aggregate expression not legal at this point : "+iri, -1, -1) ; + throwParseException("Aggregate expression not legal at this point : "+iri, token.beginLine, token.beginColumn) ; Aggregator agg = AggregatorFactory.createCustom(iri, a) ; Expr exprAgg = getQuery().allocAggregate(agg) ; return exprAgg ; @@ -1697,16 +1858,17 @@ Expr iriOrFunction() : { String iri ; Args a = null ; } return new E_Function(iri, a) ; } } -Node RDFLiteral() : { Token t ; String lex = null ; } +Node RDFLiteral() : { Token t ; String lex = null ; String uri = null ; } { lex = String() - { String lang = null ; String uri = null ; } ( - ( t = { lang = stripChars(t.image, 1) ; } ) + t = + { return createLiteralLang(lex, t.image, token.beginLine, token.beginColumn); } | - ( uri = iri() ) + uri = iri() + { return createLiteralDT(lex, uri, token.beginLine, token.beginColumn); } )? - { return createLiteral(lex, lang, uri) ; } + { return createLiteralString(lex, token.beginLine, token.beginColumn) ; } } Node NumericLiteral() : { Node n ; } { @@ -1802,7 +1964,7 @@ TOKEN: | | ["0"-"9"]) ((|".")* )? > | > | > -| ()+("-" ()+)* > +| ()+("-" ()+)* ( "--" ()* )? > | <#A2Z: ["a"-"z","A"-"Z"]> | <#A2ZN: ["a"-"z","A"-"Z","0"-"9"]> } @@ -1837,7 +1999,9 @@ TOKEN [IGNORE_CASE] : | < BIND: "bind" > | < SERVICE: "service" > | < LET: "LET" > -| < LATERAL: "LATERAL" > +| < LATERAL: "lateral" > +| < SEMIJOIN: "semijoin" > +| < ANTIJOIN: "antijoin" > | < UNFOLD: "unfold" > | < TRIPLE: "TRIPLE" > | < IS_TRIPLE: "isTRIPLE" > @@ -1881,15 +2045,19 @@ TOKEN [IGNORE_CASE] : | < SHORTEST: "shortest" > | < STR: "str" > | < STRLANG: "strlang" > +| < STRLANGDIR: "strlangdir" > | < STRDT: "strdt" > | < DTYPE: "datatype" > | < LANG: "lang" > | < LANGMATCHES: "langmatches" > +| < LANGDIR: "langdir" > | < IS_URI: "isURI" > | < IS_IRI: "isIRI" > | < IS_BLANK: "isBlank" > | < IS_LITERAL: "isLiteral" > | < IS_NUMERIC: "isNumeric" > +| < HAS_LANG: "hasLang" > +| < HAS_LANGDIR: "hasLangDir" > | < REGEX: "regex" > | < SAME_TERM: "sameTerm" > | < RAND: "RAND" > @@ -2014,12 +2182,14 @@ TOKEN : | < LT: "<" > | < LE: "<=" > | < GE: ">=" > -| < GT2: ">>" > +| < L_TRIPLE: "<<(" > +| < R_TRIPLE: ")>>" > | < LT2: "<<" > -| -| -| < BANG: "!" > +| < GT2: ">>" > +| < L_ANN: "{|" > +| < R_ANN: "|}" > | < TILDE: "~" > +| < BANG: "!" > | < COLON: ":" > | < SC_OR: "||" > | < SC_AND: "&&" > diff --git a/jena-arq/Grammar/grammar b/jena-arq/Grammar/grammar index 08e07f7783a..92696e0d1dd 100755 --- a/jena-arq/Grammar/grammar +++ b/jena-arq/Grammar/grammar @@ -42,6 +42,7 @@ function grammar ## echo "---- Create HTML" ## jjdoc -OUTPUT_FILE=${FILE%%.jj}.html "${FILE}" + echo "---- Create text form" jjdoc -TEXT=true -OUTPUT_FILE=${FILE%%.jj}.txt "${FILE}" diff --git a/jena-arq/Grammar/jj2bnf b/jena-arq/Grammar/jj2bnf new file mode 100755 index 00000000000..0403e6e7dcd --- /dev/null +++ b/jena-arq/Grammar/jj2bnf @@ -0,0 +1,302 @@ +#!/usr/bin/perl +## 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. + +## TODO (2024) +## [ ] Why does ruleBodyStr have a newline? + +## Consider rewriting, preserving the inlining. +## Parse lines (and continuation lines). Fixup. + +# Grammar into BNF text +# Reads in sparql.txt and the tokens.txt file + +if ( $#ARGV != 1 ) +{ + print STDERR "Usage: grammar.txt tokens.txt\n" ; + exit 1 ; +} + +$/ = undef ; +# Just table or full page. + +$grammarFile = $ARGV[0] ; +$tokensFile = $ARGV[1] ; + +$grammar = &readFile($grammarFile) ; +$tokens = &readFile($tokensFile) ; + +$grammar =~ s!DOCUMENT START!! ; +# $grammar =~ s!NON-TERMINALS!! ; +$grammar =~ s!DOCUMENT END!! ; +$grammar =~ s!TOKENS.*NON-TERMINALS!!s ; + +$grammar =~ s!//.*!!g ; +$grammar =~ s!\r!!g ; + +# remove leading whitespace +$grammar =~ s!^[\n\s]*!\n! ; + +# Merge alts +$grammar =~ s!\n\s*\|!\ |!g ; + +$tokens =~ s!//.*!!g ; +$tokens =~ s!\r!!g ; + + +## Grammar + +@g = split(/\n\s*/, $grammar) ; + +@rules = () ; +%ruleMap = () ; +%tokenMap = () ; +%inline = () ; + +# Grammar rules +# Direct from "jjdoc -TEXT=true" + +for $g (@g) { + ($rulename, $rulebody) = split(/:=/,$g) ; + + $rulename =~ s!^\s*!! ; + $rulename =~ s!\s*$!! ; + + $rulebody =~ s!^\s*!! ; + $rulebody =~ s!\s*$!! ; + + # Remove outer brackets +# $rulebody =~ s!^\((.*)\)$!$1! ; + + next if $rulename eq '' ; + + push @rules, $rulename ; + warn "Duplicate rule (grammar): $rulename\n" if defined($ruleMap{$rulename}) ; + $ruleMap{$rulename} = $rulebody ; + +## print "----------\n" ; +## print $rulename,"\n" ; +## print $rulebody,"\n" ; +} + +# Tokens +# Produced by "jj2tokens" +# Hand edited to indicate the inlines + +$tokens =~ s/\n+/\n/g ; +$tokens =~ s/^\n// ; + +@t = split(/\n(?=\<|\[)/, $tokens) ; + +for $t (@t) { + ($tokenname,$tokenbody) = split(/::=/, $t) ; + $tokenname =~ s!^\s*!! ; + $tokenname =~ s!\s*$!! ; + $tokenname =~ s/#// ; + + $tokenbody =~ s!^\s*!! ; + $tokenbody =~ s!\s*$!! ; + + # Inline? + if ( $tokenname =~ /^\[\<\w*\>\]/ ) { + warn "Duplicate inline (token): $tokenname\n" if defined($inline{$tokenname}) ; + $tokenname =~ s/^\[//g ; + $tokenname =~ s/\]$//g ; + $tokenbody =~ s/"/'/g ; # '" -- But not literal " -- how? + $tokenbody =~ s/\<\>\'\{\}/\<\>\"\{\}/ ; # '" IRI fixup + $inline{$tokenname} = $tokenbody ; + + #print "INLINE: ",$tokenname," => ",$tokenbody,"\n" ; + } else { + ## Remove < > aroudn a token name. + my $inlinePlain = $tokenname ; + $inlinePlain =~ s%^<%%; + $inlinePlain =~ s%>$%%; + $inline{$tokenname} = $inlinePlain ; + push @rules, $tokenname ; + warn "Duplicate rule (token): $tokenname\n" if defined($tokenMap{$tokenname}) ; + $ruleMap{$tokenname} = $tokenbody ; + } +} + +$ruleNum = 0 ; + +for $r (@rules) { + $DEBUG = 0 ; + $ruleNum++ ; + $rulename = $r ; + $rulebody = $ruleMap{$rulename} ; + + if ( $DEBUG ) { + print STDERR "\n" ; + print STDERR "Rule: $rulename\n" ; + print STDERR "Body: $rulebody\n" ; + } + + $ruleBodyStr = $rulebody ; +## # Escape HTML chars before adding markup. +# $ruleBodyStr = esc($ruleBodyStr) ; + + # Inlines + for $k (keys %inline) { +## $s = esc($inline{$k}) ; +## $k = esc($k) ; +## # Assumes escaped <> round tokens. +## $k = quotemeta $k ; +## $ruleBodyStr =~ s/$k/$s/g ; + + $s = $inline{$k}; + $ruleBodyStr =~ s/$k/$s/g ; + } + + if ( $DEBUG ) { + print STDERR "After inlining\n" ; + print STDERR $ruleBodyStr,"\n" ; ; + } + + # Add hrefs - issue if one is a substring of another \W helps. + + #exit if $ruleNum > 2 ; + + ##$ruleId = sane("r".$rulename) ; + + if($rulename eq 'IRIREF') { + print "\n"; + print "\@terminals\n"; + print "\n" ; + } + ## First part of output. + ## $rlabel = '[' . $ruleNum . ']' ; + + $rn = $rulename; + $rn =~ s!^$!!; + ## Second part of output + + ## Third part of the output. + $ruleBodyStr = fixupRule($rulename, $ruleBodyStr) ; + + ##Why no NL needed? + ## printf "%-5s %-25s ::= %s\n", $rlabel, $rn, $ruleBodyStr ; + printf "%-25s ::= %s\n", $rn, $ruleBodyStr ; + +# $rule{$rulename, $rulebody) ; +# print $rulename , "\n" ; +} + +sub readFile { + my $f = $_[0] ; + open(F, "$f") || die "$f: $!"; + my $s = ; + return $s ; +} + +sub esc { + my $s = $_[0] ; + $s =~ s/&/&/g ; + $s =~ s//>/g ; + return $s ; +} + +sub sane { + my $a = $_[0] ; + $a =~ s/\W//g ; + return $a ; +} + +sub fixupRule { + my $head = $_[0] ; + my $body = $_[1] ; + + # Remove unnecessary () + $body =~ s/\(\s*([^()| ]*) \)/$1/g ; + + # Remove outer matching () where there are no inner () + $body =~ s/^\(\s+([^\(]*)\s+\)$/$1/ ; + + # There aren't any of these +## $body =~ s!\(\s+(\S*)\s+\)!$1!g ; + + # Remove <> around tokens. + $body =~ s/<(\w+)>/$1/g ; + + # Specials + # Split long bodies + if ( $head eq "CallExpression" || + $head eq "UnaryExpression" || + $head eq "" || + $head eq "PatternElement" || + $head eq "BuiltInCall" || + $head eq "Aggregate" ) + { + ## Except BNODE, STRLEN etc + ## [138] RegexExpression ::= 'REGEX' '(' Expression ',' Expression ( ',' Expression )? ')' + ## [139] SubstringExpression ::= 'SUBSTR' '(' Expression ',' Expression ( ',' Expression )? ')' + ## [140] StrReplaceExpression ::= 'REPLACE' '(' Expression ',' Expression ',' Expression ( ',' Expression )? ')' + ## [141] ExistsFunc ::= 'EXISTS' GroupGraphPattern + ## [142] NotExistsFunc ::= 'NOT' 'EXISTS' GroupGraphPattern + ## | 'BNODE' ( '(' Expression ')' | ) + + print STDERR "A:",$body,"\n" if $p ; + + ## Fix up for BNODE that uses "|" - put in marker. + $body =~ s%'BNODE' \( '\(' Expression '\)' \| \ \)%XXX-BNODE-XXX%; + + ## | followed by + $body =~ s%\|\s*%\n | %g ; + + ## Replace marker + $body =~ s%XXX-BNODE-XXX%'BNODE' \( '(' Expression ')' \| \ \)%; + } + + if ( $head eq "Aggregate" ) + { + # Strip outer () + $body =~ s/^\(\s*(.*)\s*\)$/$1/ ; + $body =~ s/^\s+// ; + } + + # These failed the outer () test because they have nested () in them + if ( $head eq "QueryPattern" || + $head eq "OrderCondition" ) + { + # Remove outer () + $body =~ s/^\((.*)\)$/$1/ ; + } + + ## Split? +## if ( $head eq "Query" ) +## { +## } + + #Rules where an outer () is unnecessary. + if ( $head eq "GroupCondition" || + $head eq "LimitOffsetClauses" || + $head eq "GraphOrDefault" || + $head eq "ArgList" || + $head eq "ExpressionList" || + $head eq "PathPrimary" || + $head eq "PathMod" || + $head eq "PathPrimary" || + $head eq "PathNegatedPropertySet" || + $head eq "PathOneInPropertySet") + { + $body =~ s/^\(\s*(.*)\s*\)$/$1/ ; + } + + return $body ; +} diff --git a/jena-arq/Grammar/main.jj b/jena-arq/Grammar/main.jj index 9f14ca63300..928d7d94cad 100644 --- a/jena-arq/Grammar/main.jj +++ b/jena-arq/Grammar/main.jj @@ -216,10 +216,6 @@ void SelectClause() : { Var v ; Expr expr ; Node n ; } | n = NumericLiteral() { getQuery().addResultVar((Var)null, NodeValue.makeNode(n)) ; } | n = BooleanLiteral() { getQuery().addResultVar((Var)null, NodeValue.makeNode(n)) ; } ) - // @@ PROBLEMS: expr = FunctionCall() - // (?x) - // looks like a function call and also a " ( ?v )" - //| expr = FunctionCall() { getQuery().addResultVar((Var)null, expr) ; } | #endif // Expressions with () @@ -894,21 +890,35 @@ Element TriplesBlock(ElementPathBlock acc) : { } { return acc ; } } +Node ReifiedTripleBlock(TripleCollector acc) : { Node reifId ; } +{ + reifId = ReifiedTriple(acc) + PropertyList(reifId, acc) // Maybe empty + { return reifId ; } +} + +Node ReifiedTripleBlockPath(TripleCollector acc) : { Node reifId ; } +{ + reifId = ReifiedTriple(acc) + PropertyListPath(reifId, acc) // Maybe empty + { return reifId ; } +} + // ----- Element GraphPatternNotTriples() : { Element el = null ; } { ( -// el = GroupGraphPattern() -// | -// el = UnionGraphPattern() -// | el = GroupOrUnionGraphPattern() | el = OptionalGraphPattern() #ifdef ARQ | el = LateralGraphPattern() + | + el = SemiJoinGraphPattern() + | + el = AntiJoinGraphPattern() #endif | el = MinusGraphPattern() @@ -948,6 +958,16 @@ Element LateralGraphPattern() : { Element el ; } { el = GroupGraphPattern() { return new ElementLateral(el) ; } } + +Element SemiJoinGraphPattern() : { Element el ; } +{ el = GroupGraphPattern() + { return new ElementSemiJoin(el) ; } +} + +Element AntiJoinGraphPattern() : { Element el ; } +{ el = GroupGraphPattern() + { return new ElementAntiJoin(el) ; } +} #endif Element GraphGraphPattern() : { Element el ; Node n ;} @@ -1046,8 +1066,49 @@ Node DataBlockValue() : { Node n ; String iri ; } | n = NumericLiteral() { return n ; } | n = BooleanLiteral() { return n ; } | { return null ; } -| n = QuotedTripleData() { return n ; } +| n = TripleTermData() { return n ; } + +} + +// ---- Reifier, various cases. +// May return null. + +Node Reifier() : { Token tok = null ; Node reifId = null ; } +{ + tok = + (reifId = VarOrReifierId() )? + { return reifId; } +} + +// // No variables. +// Node ReifierData() : { Token tok = null ; Node reifId = null ; } +// { +// tok = +// (reifId = ReifierId() )? +// { return reifId; } +// } +// +// Node ReifierId() : { Node n = null ; String iri ; } +// { +// // No variable +// ( iri = iri() { return createNode(iri) ; } +// | n = BlankNode() { return n ; } +// ) +// } +// +// Node VarOrReifierId() : { Node n = null; } +// { +// ( n = Var() { return n; } +// | n = ReifierId() { return n; } +// ) +// } +Node VarOrReifierId() : { Node n = null; String iri = null; } +{ + ( n = Var() { return n; } + | iri = iri() { return createNode(iri) ; } + | n = BlankNode() { return n ; } + ) } #ifdef ARQ @@ -1152,7 +1213,7 @@ Expr FunctionCall() : { String fname ; Args a ; } if ( AggregateRegistry.isRegistered(fname) ) { // aggregates if ( ! getAllowAggregatesInExpressions() ) - throwParseException("Aggregate expression not legal at this point : "+fname, -1, -1) ; + throwParseException("Aggregate expression not legal at this point : "+fname, token.beginLine, token.beginColumn) ; Aggregator agg = AggregatorFactory.createCustom(fname, a) ; Expr exprAgg = getQuery().allocAggregate(agg) ; return exprAgg ; @@ -1195,8 +1256,6 @@ ExprList ExpressionList() : { Expr expr = null ; ExprList exprList = new ExprLis { return exprList ; } } - - // -------- Construct patterns #ifdef ARQ Template ConstructTemplate() : { QuadAcc acc = new QuadAcc() ; @@ -1251,6 +1310,8 @@ void TriplesSameSubject(TripleCollector acc) : { Node s ; } s = TriplesNode(tempAcc) PropertyList(s, tempAcc) { insert(acc, tempAcc) ; } +| + ReifiedTripleBlock(acc) } void PropertyList(Node s, TripleCollector acc) : { } @@ -1289,7 +1350,7 @@ void Object(Node s, Node p, Path path, TripleCollector acc): { Node o ; } { { ElementPathBlock tempAcc = new ElementPathBlock() ; int mark = tempAcc.mark() ; } o = GraphNode(tempAcc) - { insert(tempAcc, mark, s, p, path, o) ; insert(acc, tempAcc) ; } + { insert(tempAcc, mark, s, p, path, o) ; insert(acc, tempAcc) ; } Annotation(acc, s, p, path, o) } @@ -1306,6 +1367,8 @@ void TriplesSameSubjectPath(TripleCollector acc) : { Node s ; } s = TriplesNodePath(tempAcc) PropertyListPath(s, tempAcc) { insert(acc, tempAcc) ; } +| + ReifiedTripleBlockPath(acc) } void PropertyListPath(Node s, TripleCollector acc) : { } @@ -1328,12 +1391,8 @@ void PropertyListPathNotEmpty(Node s, TripleCollector acc) : | p = VerbSimple() ) ObjectListPath(s, p, path, acc) - )? + )? )* -#if 0 - | - Reification(s, acc) -#endif } Path VerbPath() : {Node p ; Path path ; } @@ -1349,7 +1408,7 @@ Node VerbSimple() : { Node p ; } { return p ; } } -void ObjectListPath(Node s, Node p, Path path, TripleCollector acc): { Node o ; } +void ObjectListPath(Node s, Node p, Path path, TripleCollector acc): { Node o ; } { ObjectPath(s, p, path, acc) ( ObjectPath(s, p, path, acc) )* @@ -1461,6 +1520,16 @@ Path PathMod(Path p) : { long i1 ; long i2 ; } ) } +#ifdef ARQ +long Integer() : {Token t ;} +{ + t = + { return integerValue(t.image) ; } +} +#endif + + + Path PathPrimary() : { String str ; Path p ; Node n ; } { ( @@ -1518,12 +1587,6 @@ P_Path0 PathOneInPropertySet() : { String str ; Node n ; } ) } -long Integer() : {Token t ;} -{ - t = - { return integerValue(t.image) ; } -} - // -------- Triple expansions // Anything that can stand in a node slot and which is @@ -1531,13 +1594,9 @@ long Integer() : {Token t ;} Node TriplesNode(TripleCollectorMark acc) : { Node n ; } { - n = Collection(acc) { return n ; } - | - n = BlankNodePropertyList(acc) { return n ; } -#if 0 + n = Collection(acc) { return n ; } | - n = Reification(null, acc) { return n ; } -#endif + n = BlankNodePropertyList(acc) { return n ; } } Node BlankNodePropertyList(TripleCollector acc) : { Token t ; } @@ -1551,13 +1610,9 @@ Node BlankNodePropertyList(TripleCollector acc) : { Token t ; } Node TriplesNodePath(TripleCollectorMark acc) : { Node n ; } { - n = CollectionPath(acc) { return n ; } - | - n = BlankNodePropertyListPath(acc) { return n ; } -#if 0 + n = CollectionPath(acc) { return n ; } | - n = Reification(null, acc) { return n ; } -#endif + n = BlankNodePropertyListPath(acc) { return n ; } } Node BlankNodePropertyListPath(TripleCollector acc) : { Token t ; } @@ -1569,32 +1624,6 @@ Node BlankNodePropertyListPath(TripleCollector acc) : { Token t ; } { return n ; } } -// << >> as reification. Allows any subject/predicate/object nodes. -#if 0 -Node Reification(Node id, TripleCollectorMark acc) : - { Node s , p , o ; int mark ; Token t ; } -{ - // Insert reification triple before the resulting subtriples (if any) - t = - { int beginLine = t.beginLine; int beginColumn = t.beginColumn; t = null; } - { if ( id == null ) - id = createBNode(beginLine, beginColumn() ; - mark = acc.mark() ; } - s = GraphNode(acc) - { insert(acc, mark, id, nRDFsubject, s) ; - mark = acc.mark() ; - } - p = GraphNode(acc) - { insert(acc, mark, id, nRDFpredicate, p) ; - mark = acc.mark() ; - } - o = GraphNode(acc) - { insert(acc, mark, id, nRDFobject, o) ; } - - { return id ; } -} -#endif - // ------- RDF collections Node Collection(TripleCollectorMark acc) : @@ -1649,95 +1678,229 @@ Node CollectionPath(TripleCollectorMark acc) : return listHead ; } } -// RDF-star Annotation Syntax -void AnnotationPath(TripleCollector acc, Node s, Node p, Path path, Node o) : {} +// ---- RDF-star Annotation Syntax +// Allow paths. Query graph patterns. +void AnnotationPath(TripleCollector acc, Node s, Node p, Path path, Node o) : { Node reifId = null ; } { ( - - { Node pAnn = preConditionAnnotation(s, p, path, o, token.beginLine, token.beginColumn) ; - Node x = createQuotedTriple(s, pAnn, o, token.beginLine, token.beginColumn); - } - PropertyListPathNotEmpty(x, acc) - - )? + { p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); } + reifId = Reifier() + { reifId = insertTripleReifier(acc, reifId, s, p, o, token.beginLine, token.beginColumn) ; } + { setReifierId(reifId); } + | + { + p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); + reifId = getOrAllocReifierId(acc, s, p, o, token.beginLine, token.beginColumn); + } + { clearReifierId(); } + AnnotationBlockPath(acc, reifId) + )* + { clearReifierId(); } } -// RDF-star Annotation Syntax -void Annotation(TripleCollector acc, Node s, Node p, Path path, Node o) : { } +void AnnotationBlockPath(TripleCollector acc, Node reifId) : { } +{ + + PropertyListPathNotEmpty(reifId, acc) + +} + +// ---- RDF-star Annotation Syntax +// No paths. Construct templates. +void Annotation(TripleCollector acc, Node s, Node p, Path path, Node o) : { Node reifId = null ; } { - // path should be null. ( - - { Node pAnn = preConditionAnnotation(s, p, path, o, token.beginLine, token.beginColumn) ; - Node x = createQuotedTriple(s, p, o, token.beginLine, token.beginColumn); - } - PropertyListNotEmpty(x, acc) - - )? + { p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); } + reifId = Reifier() + // @@ Rewrite java? + { reifId = insertTripleReifier(acc, reifId, s, p, o, token.beginLine, token.beginColumn) ; } + { setReifierId(reifId); } + | + { + p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); + reifId = getOrAllocReifierId(acc, s, p, o, token.beginLine, token.beginColumn); + } + { clearReifierId(); } + AnnotationBlock(acc, reifId) + )* +} + +void AnnotationBlock(TripleCollector acc, Node reifId) : { } +{ + // Roll back into Annotation? + + PropertyListNotEmpty(reifId, acc) + } // -------- Nodes in a graph pattern or template +// Object position RDF term, element of a list +// No paths in TriplesNode Node GraphNode(TripleCollectorMark acc) : { Node n ; } { - n = VarOrTerm() { return n ; } + n = VarOrTerm() { return n ; } + | + n = TriplesNode(acc) { return n ; } | - n = TriplesNode(acc) { return n ; } + n = ReifiedTriple(acc) { return n ; } } +// Object position RDF term. NEW-SYNTAX Rename? Node GraphNodePath(TripleCollectorMark acc) : { Node n ; } { n = VarOrTerm() { return n ; } - | +| n = TriplesNodePath(acc) { return n ; } +| + n = ReifiedTriple(acc) { return n ; } } Node VarOrTerm() : { Node n = null ; String iri ; } { ( n = Var() | iri = iri() { return createNode(iri) ; } - | n = RDFLiteral() { return n ; } - | n = NumericLiteral() { return n ; } - | n = BooleanLiteral() { return n ; } - | n = BlankNode() { return n ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = BlankNode() // { return nRDFnil ; } | { return nRDFnil ; } - | n = QuotedTriple() -) - { return n ; } + | n = TripleTerm() { return n; } + ) + { return n; } } -Node QuotedTriple() : { Node n = null ; Token t ; Node s , p , o ; } +Node ReifiedTriple(TripleCollector acc) : { Node reifId = null ; Token tok ; Node s; Node p ; Node o ; } { - t = - s = VarOrTerm() + tok = + s = ReifiedTripleSubject(acc) p = Verb() - o = VarOrTerm() - { n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); } + o = ReifiedTripleObject(acc) + (reifId = Reifier())? + { reifId = insertTripleReifier(acc, reifId, s, p, o, tok.beginLine, tok.beginColumn) ; } + { return reifId; } +} + +Node ReifiedTripleSubject(TripleCollector acc) : { Node s; String iri; } +{ + ( s = Var() + | iri = iri() { s = createNode(iri) ; } + | s = RDFLiteral() + | s = NumericLiteral() + | s = BooleanLiteral() + | s = BlankNode() + | s = ReifiedTriple(acc) + // { s = RDFnil ; } + //| { s = nRDFnil ; } + ) + { return s; } +} + +Node ReifiedTripleObject(TripleCollector acc) : { Node o; String iri; } +{ + ( o = Var() + | iri = iri() { o = createNode(iri) ; } + | o = RDFLiteral() + | o = NumericLiteral() + | o = BooleanLiteral() + | o = BlankNode() + | o = ReifiedTriple(acc) + // { o = nRDFnil ; } + //| { o = nRDFnil ; } + | o = TripleTerm() + ) + { return o; } +} + +Node TripleTerm() : { Node n = null ; Token openToken ; String iri ; Node s , p , o ; } +{ + openToken = + // @@ Alt name. ttSubject()? + s = TripleTermSubject() + p = Verb() + o = TripleTermObject() + { n = createTripleTerm(s, p, o, openToken.beginLine, openToken.beginColumn); } + + { return n ; } +} + +Node TripleTermSubject() : { Node n; String iri; } +{ + ( n = Var() + | iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = BlankNode() + // { return nRDFnil ; } + //| { return nRDFnil ; } + //| n = TripleTerm() { return n; } + ) { return n; } } -Node QuotedTripleData() : { Node n = null ; Token t ; String iri ; Node s , p , o ; } +Node TripleTermObject() : { Node n; String iri; } { - t = - ( s = DataValueTerm() ) - ( iri = iri() { p = createNode(iri) ; } | { p = nRDFtype ; } ) - ( o = DataValueTerm() ) - { n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); } - + ( n = Var() + | iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = BlankNode() + // { return nRDFnil ; } + //| { return nRDFnil ; } + | n = TripleTerm() { return n; } + ) { return n; } } -Node DataValueTerm() : { Node n = null ; String iri ; Node s , p , o ; } +Node TripleTermData() : { Node n = null ; Token openToken ; String iri ; Node s , p , o ; } { - iri = iri() { return createNode(iri) ; } -| n = RDFLiteral() { return n ; } -| n = NumericLiteral() { return n ; } -| n = BooleanLiteral() { return n ; } -| n = QuotedTripleData() { return n ; } + openToken = + // @@ Alt name? ttDataValueTerm + s = TripleTermDataSubject() + ( iri = iri() { p = createNode(iri) ; } | { p = nRDFtype ; } ) + o = TripleTermDataObject() + { n = createTripleTerm(s, p, o, openToken.beginLine, openToken.beginColumn); } + + { return n ; } +} + +Node TripleTermDataSubject() : { Node n = null; String iri; } +{ + ( iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + //| n = TripleTermData() + ) + { return n; } } +Node TripleTermDataObject() : { Node n = null; String iri; } +{ + ( iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = TripleTermData() + ) + { return n; } +} + +// // VarOrTerm except no var, no bnodes +// // @@ Rename? +// Node DataValueTerm() : { Node n = null ; String iri ; Node s , p , o ; } +// { +// iri = iri() { return createNode(iri) ; } +// | n = RDFLiteral() { return n ; } +// | n = NumericLiteral() { return n ; } +// | n = BooleanLiteral() { return n ; } +// | n = TripleTermData() { return n; } +// } + // e.g. Property (if no bNodes) + DESCRIBE Node VarOrIri() : {Node n = null ; String iri ; } { @@ -1893,15 +2056,14 @@ Expr PrimaryExpression() : { Expr expr ; Node n ; } ( expr = BrackettedExpression() { return expr ; } | expr = BuiltInCall() { return expr ; } | expr = iriOrFunction() { return expr ; } -// NOT | n = VarOrTerm() { return asExpr(n) ; } +// NOT | n = ExprVarOrTerm() { return asExpr(n) ; } // Because of iriOrFunction // Can't use iri() here | n = RDFLiteral() { return asExpr(n) ; } | n = NumericLiteral() { return asExpr(n) ; } | n = BooleanLiteral() { return asExpr(n) ; } | n = Var() { return asExpr(n) ; } - | n = ExprQuotedTriple() { return asExpr(n) ; } - + | n = ExprTripleTerm() { return asExpr(n) ; } // and not SPARQL 12 // needs checking. // Use this for ?var(args) @@ -1909,28 +2071,56 @@ Expr PrimaryExpression() : { Expr expr ; Node n ; } ) } -Node ExprVarOrTerm() : { Node n; String s;} +// Node ExprVarOrTerm() : { Node n; String s;} +// { +// ( s = iri() { n = createNode(s); } +// | n = RDFLiteral() +// | n = NumericLiteral() +// | n = BooleanLiteral() +// | n = Var() +// | n = ExprTripleTerm() +// ) +// { return n; } +// } + +Node ExprTripleTerm() : { Token t ; Node s,p,o,n; } { - ( s = iri() { n = createNode(s); } + t = + s = ExprTripleTermSubject() + p = Verb() + o = ExprTripleTermObject() + { n = createTripleTerm(s, p, o, t.beginLine, t.beginColumn); } + + { return n; } +} + +Node ExprTripleTermSubject() : { Node n; String iri; } +{ + ( iri = iri() { n = createNode(iri); } | n = RDFLiteral() | n = NumericLiteral() | n = BooleanLiteral() | n = Var() - | n = ExprQuotedTriple() + //| n = ExprTripleTerm() ) { return n; } } -Node ExprQuotedTriple() : { Token t ; Node s,p,o,n; } -{ t = - s = ExprVarOrTerm() - p = Verb() - o = ExprVarOrTerm() - { n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); } - +Node ExprTripleTermObject() : { Node n; String iri; } +{ + ( iri = iri() { n = createNode(iri); } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = Var() + | n = ExprTripleTerm() + ) { return n; } } + + + Expr BrackettedExpression() : { Expr expr ; } { expr = Expression() { return expr ; } @@ -1944,6 +2134,7 @@ Expr BuiltInCall() : { Expr expr ; | expr = Expression() { return new E_Str(expr) ; } + | expr = Expression() { return new E_Lang(expr) ; } @@ -1951,6 +2142,9 @@ Expr BuiltInCall() : { Expr expr ; expr1 = Expression() expr2 = Expression() { return new E_LangMatches(expr1, expr2) ; } + | expr = Expression() + { return new E_LangDir(expr) ; } + | expr = Expression() { return new E_Datatype(expr) ; } @@ -2094,6 +2288,11 @@ Expr BuiltInCall() : { Expr expr ; | expr1 = Expression() expr2 = Expression() { return new E_StrLang(expr1, expr2) ; } + | expr1 = Expression() + expr2 = Expression() + expr3 = Expression() + { return new E_StrLangDir(expr1, expr2, expr3) ; } + | expr1 = Expression() expr2 = Expression() { return new E_StrDatatype(expr1, expr2) ; } @@ -2114,6 +2313,13 @@ Expr BuiltInCall() : { Expr expr ; | expr = Expression() { return new E_IsNumeric(expr) ; } + + | expr = Expression() + { return new E_HasLang(expr) ; } + + | expr = Expression() + { return new E_HasLangDir(expr) ; } + | // Regular expression matcher expr = RegexExpression() { return expr ; } @@ -2121,10 +2327,12 @@ Expr BuiltInCall() : { Expr expr ; | expr = NotExistsFunc() { return expr ; } -| expr = Expression() + | expr = Expression() { return new E_IsTriple(expr) ; } - | expr1 = Expression() expr2 = Expression() expr3 = Expression() + | expr1 = Expression() + expr2 = Expression() + expr3 = Expression() { return new E_TripleFn(expr1, expr2, expr3) ; } | expr = Expression() @@ -2327,7 +2535,7 @@ Expr iriOrFunction() : { String iri ; Args a = null ; } if ( AggregateRegistry.isRegistered(iri) ) { // aggregates if ( ! getAllowAggregatesInExpressions() ) - throwParseException("Aggregate expression not legal at this point : "+iri, -1, -1) ; + throwParseException("Aggregate expression not legal at this point : "+iri, token.beginLine, token.beginColumn) ; Aggregator agg = AggregatorFactory.createCustom(iri, a) ; Expr exprAgg = getQuery().allocAggregate(agg) ; return exprAgg ; @@ -2351,17 +2559,18 @@ Expr VarOrFunction() : { Var v ; ExprList a = null ; } #endif -Node RDFLiteral() : { Token t ; String lex = null ; } +Node RDFLiteral() : { Token t ; String lex = null ; String uri = null ; } { lex = String() // Optional lang tag and datatype. - { String lang = null ; String uri = null ; } ( - ( t = { lang = stripChars(t.image, 1) ; } ) + t = + { return createLiteralLang(lex, t.image, token.beginLine, token.beginColumn); } | - ( uri = iri() ) + uri = iri() + { return createLiteralDT(lex, uri, token.beginLine, token.beginColumn); } )? - { return createLiteral(lex, lang, uri) ; } + { return createLiteralString(lex, token.beginLine, token.beginColumn) ; } } @@ -2501,7 +2710,7 @@ TOKEN: | | ["0"-"9"]) ((|".")* )? > | > | > -| ()+("-" ()+)* > +| ()+("-" ()+)* ( "--" ()* )? > | <#A2Z: ["a"-"z","A"-"Z"]> | <#A2ZN: ["a"-"z","A"-"Z","0"-"9"]> } @@ -2556,7 +2765,9 @@ TOKEN [IGNORE_CASE] : #ifdef ARQ | < LET: "LET" > -| < LATERAL: "LATERAL" > +| < LATERAL: "lateral" > +| < SEMIJOIN: "semijoin" > +| < ANTIJOIN: "antijoin" > | < UNFOLD: "unfold" > #endif @@ -2615,15 +2826,20 @@ TOKEN [IGNORE_CASE] : | < STR: "str" > | < STRLANG: "strlang" > +| < STRLANGDIR: "strlangdir" > + | < STRDT: "strdt" > | < DTYPE: "datatype" > | < LANG: "lang" > | < LANGMATCHES: "langmatches" > +| < LANGDIR: "langdir" > | < IS_URI: "isURI" > | < IS_IRI: "isIRI" > | < IS_BLANK: "isBlank" > | < IS_LITERAL: "isLiteral" > | < IS_NUMERIC: "isNumeric" > +| < HAS_LANG: "hasLang" > +| < HAS_LANGDIR: "hasLangDir" > | < REGEX: "regex" > | < SAME_TERM: "sameTerm" > @@ -2796,13 +3012,15 @@ TOKEN : | < LE: "<=" > // Maybe: | "=>" > | < GE: ">=" > // Maybe: | "=<" > -| < GT2: ">>" > +| < L_TRIPLE: "<<(" > +| < R_TRIPLE: ")>>" > | < LT2: "<<" > -| -| +| < GT2: ">>" > +| < L_ANN: "{|" > +| < R_ANN: "|}" > -| < BANG: "!" > | < TILDE: "~" > +| < BANG: "!" > | < COLON: ":" > | < SC_OR: "||" > diff --git a/jena-arq/Grammar/sparql2bnf b/jena-arq/Grammar/sparql2bnf new file mode 100755 index 00000000000..74b1b9034db --- /dev/null +++ b/jena-arq/Grammar/sparql2bnf @@ -0,0 +1,7 @@ +#!/usr/bin/bash +## Licensed under the terms of http://www.apache.org/licenses/LICENSE-2.0 +echo "Grammar to sparql.bnf (text)" + +( + jj2bnf 'sparql_12.txt' 'tokens.txt' +) > sparql.bnf diff --git a/jena-arq/Grammar/sparql2html b/jena-arq/Grammar/sparql2html index 19320cd406a..e2d449bf978 100755 --- a/jena-arq/Grammar/sparql2html +++ b/jena-arq/Grammar/sparql2html @@ -1,13 +1,21 @@ +#!/usr/bin/bash ## Licensed under the terms of http://www.apache.org/licenses/LICENSE-2.0 -echo "Grammar to X.html, fragments file to Y.html" +echo "Grammar output in sparql-grammar.html" ##jj2html 'sparql_11.txt' 'tokens.txt' > X11.html ##grammarExtracts < X11.html > Y11.html -jj2html 'sparql_12.txt' 'tokens.txt' > X12.html -grammarExtracts < X12.html > Y12.html +( + echo " " + jj2html 'sparql_12.txt' 'tokens.txt' + echo " " +) > sparql-grammar.html + +## Produce a standlone web page +## mv sparql-grammar.html X12.hmtl +## grammarExtracts < sparql-grammar.html > sparql-html.thml ## jj2html 'arq_12.txt' 'tokens.txt' > X.html ## grammarExtracts < X.html > Y.html -echo "Check X and Y for IRI_REF because \" became '" \ No newline at end of file +##?? echo "Check X and Y for IRI_REF because \" became '" diff --git a/jena-arq/Grammar/sparql_12.jj b/jena-arq/Grammar/sparql_12.jj index 0073d7880b8..8154839f003 100644 --- a/jena-arq/Grammar/sparql_12.jj +++ b/jena-arq/Grammar/sparql_12.jj @@ -525,6 +525,18 @@ Element TriplesBlock(ElementPathBlock acc) : { } ( (TriplesBlock(acc))? )? { return acc ; } } +Node ReifiedTripleBlock(TripleCollector acc) : { Node reifId ; } +{ + reifId = ReifiedTriple(acc) + PropertyList(reifId, acc) + { return reifId ; } +} +Node ReifiedTripleBlockPath(TripleCollector acc) : { Node reifId ; } +{ + reifId = ReifiedTriple(acc) + PropertyListPath(reifId, acc) + { return reifId ; } +} Element GraphPatternNotTriples() : { Element el = null ; } { ( @@ -639,7 +651,20 @@ Node DataBlockValue() : { Node n ; String iri ; } | n = NumericLiteral() { return n ; } | n = BooleanLiteral() { return n ; } | { return null ; } -| n = QuotedTripleData() { return n ; } +| n = TripleTermData() { return n ; } +} +Node Reifier() : { Token tok = null ; Node reifId = null ; } +{ + tok = + (reifId = VarOrReifierId() )? + { return reifId; } +} +Node VarOrReifierId() : { Node n = null; String iri = null; } +{ + ( n = Var() { return n; } + | iri = iri() { return createNode(iri) ; } + | n = BlankNode() { return n ; } + ) } Element MinusGraphPattern() : { Element el ; } { @@ -683,7 +708,7 @@ Expr FunctionCall() : { String fname ; Args a ; } { if ( AggregateRegistry.isRegistered(fname) ) { if ( ! getAllowAggregatesInExpressions() ) - throwParseException("Aggregate expression not legal at this point : "+fname, -1, -1) ; + throwParseException("Aggregate expression not legal at this point : "+fname, token.beginLine, token.beginColumn) ; Aggregator agg = AggregatorFactory.createCustom(fname, a) ; Expr exprAgg = getQuery().allocAggregate(agg) ; return exprAgg ; @@ -747,6 +772,8 @@ void TriplesSameSubject(TripleCollector acc) : { Node s ; } s = TriplesNode(tempAcc) PropertyList(s, tempAcc) { insert(acc, tempAcc) ; } +| + ReifiedTripleBlock(acc) } void PropertyList(Node s, TripleCollector acc) : { } { @@ -790,6 +817,8 @@ void TriplesSameSubjectPath(TripleCollector acc) : { Node s ; } s = TriplesNodePath(tempAcc) PropertyListPath(s, tempAcc) { insert(acc, tempAcc) ; } +| + ReifiedTripleBlockPath(acc) } void PropertyListPath(Node s, TripleCollector acc) : { } { @@ -911,16 +940,11 @@ P_Path0 PathOneInPropertySet() : { String str ; Node n ; } ) ) } -long Integer() : {Token t ;} -{ - t = - { return integerValue(t.image) ; } -} Node TriplesNode(TripleCollectorMark acc) : { Node n ; } { - n = Collection(acc) { return n ; } + n = Collection(acc) { return n ; } | - n = BlankNodePropertyList(acc) { return n ; } + n = BlankNodePropertyList(acc) { return n ; } } Node BlankNodePropertyList(TripleCollector acc) : { Token t ; } { @@ -932,9 +956,9 @@ Node BlankNodePropertyList(TripleCollector acc) : { Token t ; } } Node TriplesNodePath(TripleCollectorMark acc) : { Node n ; } { - n = CollectionPath(acc) { return n ; } + n = CollectionPath(acc) { return n ; } | - n = BlankNodePropertyListPath(acc) { return n ; } + n = BlankNodePropertyListPath(acc) { return n ; } } Node BlankNodePropertyListPath(TripleCollector acc) : { Token t ; } { @@ -992,80 +1016,177 @@ Node CollectionPath(TripleCollectorMark acc) : insert(acc, lastCell, nRDFrest, nRDFnil) ; return listHead ; } } -void AnnotationPath(TripleCollector acc, Node s, Node p, Path path, Node o) : {} +void AnnotationPath(TripleCollector acc, Node s, Node p, Path path, Node o) : { Node reifId = null ; } { ( - - { Node pAnn = preConditionAnnotation(s, p, path, o, token.beginLine, token.beginColumn) ; - Node x = createQuotedTriple(s, pAnn, o, token.beginLine, token.beginColumn); - } - PropertyListPathNotEmpty(x, acc) - - )? + { p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); } + reifId = Reifier() + { reifId = insertTripleReifier(acc, reifId, s, p, o, token.beginLine, token.beginColumn) ; } + { setReifierId(reifId); } + | + { + p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); + reifId = getOrAllocReifierId(acc, s, p, o, token.beginLine, token.beginColumn); + } + { clearReifierId(); } + AnnotationBlockPath(acc, reifId) + )* + { clearReifierId(); } +} +void AnnotationBlockPath(TripleCollector acc, Node reifId) : { } +{ + + PropertyListPathNotEmpty(reifId, acc) + } -void Annotation(TripleCollector acc, Node s, Node p, Path path, Node o) : { } +void Annotation(TripleCollector acc, Node s, Node p, Path path, Node o) : { Node reifId = null ; } { ( - - { Node pAnn = preConditionAnnotation(s, p, path, o, token.beginLine, token.beginColumn) ; - Node x = createQuotedTriple(s, p, o, token.beginLine, token.beginColumn); - } - PropertyListNotEmpty(x, acc) - - )? + { p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); } + reifId = Reifier() + { reifId = insertTripleReifier(acc, reifId, s, p, o, token.beginLine, token.beginColumn) ; } + { setReifierId(reifId); } + | + { + p = preConditionReifier(s, p, path, o, token.beginLine, token.beginColumn); + reifId = getOrAllocReifierId(acc, s, p, o, token.beginLine, token.beginColumn); + } + { clearReifierId(); } + AnnotationBlock(acc, reifId) + )* +} +void AnnotationBlock(TripleCollector acc, Node reifId) : { } +{ + + PropertyListNotEmpty(reifId, acc) + } Node GraphNode(TripleCollectorMark acc) : { Node n ; } { - n = VarOrTerm() { return n ; } + n = VarOrTerm() { return n ; } + | + n = TriplesNode(acc) { return n ; } | - n = TriplesNode(acc) { return n ; } + n = ReifiedTriple(acc) { return n ; } } Node GraphNodePath(TripleCollectorMark acc) : { Node n ; } { n = VarOrTerm() { return n ; } - | +| n = TriplesNodePath(acc) { return n ; } +| + n = ReifiedTriple(acc) { return n ; } } Node VarOrTerm() : { Node n = null ; String iri ; } { ( n = Var() | iri = iri() { return createNode(iri) ; } - | n = RDFLiteral() { return n ; } - | n = NumericLiteral() { return n ; } - | n = BooleanLiteral() { return n ; } - | n = BlankNode() { return n ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = BlankNode() | { return nRDFnil ; } - | n = QuotedTriple() -) - { return n ; } + | n = TripleTerm() { return n; } + ) + { return n; } } -Node QuotedTriple() : { Node n = null ; Token t ; Node s , p , o ; } +Node ReifiedTriple(TripleCollector acc) : { Node reifId = null ; Token tok ; Node s; Node p ; Node o ; } { - t = - s = VarOrTerm() + tok = + s = ReifiedTripleSubject(acc) p = Verb() - o = VarOrTerm() - { n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); } + o = ReifiedTripleObject(acc) + (reifId = Reifier())? + { reifId = insertTripleReifier(acc, reifId, s, p, o, tok.beginLine, tok.beginColumn) ; } + { return reifId; } +} +Node ReifiedTripleSubject(TripleCollector acc) : { Node s; String iri; } +{ + ( s = Var() + | iri = iri() { s = createNode(iri) ; } + | s = RDFLiteral() + | s = NumericLiteral() + | s = BooleanLiteral() + | s = BlankNode() + | s = ReifiedTriple(acc) + ) + { return s; } +} +Node ReifiedTripleObject(TripleCollector acc) : { Node o; String iri; } +{ + ( o = Var() + | iri = iri() { o = createNode(iri) ; } + | o = RDFLiteral() + | o = NumericLiteral() + | o = BooleanLiteral() + | o = BlankNode() + | o = ReifiedTriple(acc) + | o = TripleTerm() + ) + { return o; } +} +Node TripleTerm() : { Node n = null ; Token openToken ; String iri ; Node s , p , o ; } +{ + openToken = + s = TripleTermSubject() + p = Verb() + o = TripleTermObject() + { n = createTripleTerm(s, p, o, openToken.beginLine, openToken.beginColumn); } + + { return n ; } +} +Node TripleTermSubject() : { Node n; String iri; } +{ + ( n = Var() + | iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = BlankNode() + ) { return n; } } -Node QuotedTripleData() : { Node n = null ; Token t ; String iri ; Node s , p , o ; } +Node TripleTermObject() : { Node n; String iri; } { - t = - ( s = DataValueTerm() ) - ( iri = iri() { p = createNode(iri) ; } | { p = nRDFtype ; } ) - ( o = DataValueTerm() ) - { n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); } - + ( n = Var() + | iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = BlankNode() + | n = TripleTerm() { return n; } + ) { return n; } } -Node DataValueTerm() : { Node n = null ; String iri ; Node s , p , o ; } +Node TripleTermData() : { Node n = null ; Token openToken ; String iri ; Node s , p , o ; } { - iri = iri() { return createNode(iri) ; } -| n = RDFLiteral() { return n ; } -| n = NumericLiteral() { return n ; } -| n = BooleanLiteral() { return n ; } -| n = QuotedTripleData() { return n ; } + openToken = + s = TripleTermDataSubject() + ( iri = iri() { p = createNode(iri) ; } | { p = nRDFtype ; } ) + o = TripleTermDataObject() + { n = createTripleTerm(s, p, o, openToken.beginLine, openToken.beginColumn); } + + { return n ; } +} +Node TripleTermDataSubject() : { Node n = null; String iri; } +{ + ( iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + ) + { return n; } +} +Node TripleTermDataObject() : { Node n = null; String iri; } +{ + ( iri = iri() { n = createNode(iri) ; } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = TripleTermData() + ) + { return n; } } Node VarOrIri() : {Node n = null ; String iri ; } { @@ -1194,27 +1315,38 @@ Expr PrimaryExpression() : { Expr expr ; Node n ; } | n = NumericLiteral() { return asExpr(n) ; } | n = BooleanLiteral() { return asExpr(n) ; } | n = Var() { return asExpr(n) ; } - | n = ExprQuotedTriple() { return asExpr(n) ; } + | n = ExprTripleTerm() { return asExpr(n) ; } ) } -Node ExprVarOrTerm() : { Node n; String s;} +Node ExprTripleTerm() : { Token t ; Node s,p,o,n; } { - ( s = iri() { n = createNode(s); } + t = + s = ExprTripleTermSubject() + p = Verb() + o = ExprTripleTermObject() + { n = createTripleTerm(s, p, o, t.beginLine, t.beginColumn); } + + { return n; } +} +Node ExprTripleTermSubject() : { Node n; String iri; } +{ + ( iri = iri() { n = createNode(iri); } | n = RDFLiteral() | n = NumericLiteral() | n = BooleanLiteral() | n = Var() - | n = ExprQuotedTriple() ) { return n; } } -Node ExprQuotedTriple() : { Token t ; Node s,p,o,n; } -{ t = - s = ExprVarOrTerm() - p = Verb() - o = ExprVarOrTerm() - { n = createQuotedTriple(s, p, o, t.beginLine, t.beginColumn); } - +Node ExprTripleTermObject() : { Node n; String iri; } +{ + ( iri = iri() { n = createNode(iri); } + | n = RDFLiteral() + | n = NumericLiteral() + | n = BooleanLiteral() + | n = Var() + | n = ExprTripleTerm() + ) { return n; } } Expr BrackettedExpression() : { Expr expr ; } @@ -1234,6 +1366,8 @@ Expr BuiltInCall() : { Expr expr ; | expr1 = Expression() expr2 = Expression() { return new E_LangMatches(expr1, expr2) ; } + | expr = Expression() + { return new E_LangDir(expr) ; } | expr = Expression() { return new E_Datatype(expr) ; } | gn = Var() @@ -1294,6 +1428,10 @@ Expr BuiltInCall() : { Expr expr ; { return new E_Conditional(expr, expr1, expr2) ; } | expr1 = Expression() expr2 = Expression() { return new E_StrLang(expr1, expr2) ; } + | expr1 = Expression() + expr2 = Expression() + expr3 = Expression() + { return new E_StrLangDir(expr1, expr2, expr3) ; } | expr1 = Expression() expr2 = Expression() { return new E_StrDatatype(expr1, expr2) ; } | expr1 = Expression() expr2 = Expression() @@ -1308,13 +1446,19 @@ Expr BuiltInCall() : { Expr expr ; { return new E_IsLiteral(expr) ; } | expr = Expression() { return new E_IsNumeric(expr) ; } + | expr = Expression() + { return new E_HasLang(expr) ; } + | expr = Expression() + { return new E_HasLangDir(expr) ; } | expr = RegexExpression() { return expr ; } | expr = ExistsFunc() { return expr ; } | expr = NotExistsFunc() { return expr ; } -| expr = Expression() + | expr = Expression() { return new E_IsTriple(expr) ; } - | expr1 = Expression() expr2 = Expression() expr3 = Expression() + | expr1 = Expression() + expr2 = Expression() + expr3 = Expression() { return new E_TripleFn(expr1, expr2, expr3) ; } | expr = Expression() { return new E_TripleSubject(expr) ; } @@ -1421,7 +1565,7 @@ Expr iriOrFunction() : { String iri ; Args a = null ; } return asExpr(createNode(iri)) ; if ( AggregateRegistry.isRegistered(iri) ) { if ( ! getAllowAggregatesInExpressions() ) - throwParseException("Aggregate expression not legal at this point : "+iri, -1, -1) ; + throwParseException("Aggregate expression not legal at this point : "+iri, token.beginLine, token.beginColumn) ; Aggregator agg = AggregatorFactory.createCustom(iri, a) ; Expr exprAgg = getQuery().allocAggregate(agg) ; return exprAgg ; @@ -1429,16 +1573,17 @@ Expr iriOrFunction() : { String iri ; Args a = null ; } return new E_Function(iri, a) ; } } -Node RDFLiteral() : { Token t ; String lex = null ; } +Node RDFLiteral() : { Token t ; String lex = null ; String uri = null ; } { lex = String() - { String lang = null ; String uri = null ; } ( - ( t = { lang = stripChars(t.image, 1) ; } ) + t = + { return createLiteralLang(lex, t.image, token.beginLine, token.beginColumn); } | - ( uri = iri() ) + uri = iri() + { return createLiteralDT(lex, uri, token.beginLine, token.beginColumn); } )? - { return createLiteral(lex, lang, uri) ; } + { return createLiteralString(lex, token.beginLine, token.beginColumn) ; } } Node NumericLiteral() : { Node n ; } { @@ -1532,7 +1677,7 @@ TOKEN: | | ["0"-"9"]) ((|".")* )? > | > | > -| ()+("-" ()+)* > +| ()+("-" ()+)* ( "--" ()* )? > | <#A2Z: ["a"-"z","A"-"Z"]> | <#A2ZN: ["a"-"z","A"-"Z","0"-"9"]> } @@ -1600,15 +1745,19 @@ TOKEN [IGNORE_CASE] : | < URI: "uri" > | < STR: "str" > | < STRLANG: "strlang" > +| < STRLANGDIR: "strlangdir" > | < STRDT: "strdt" > | < DTYPE: "datatype" > | < LANG: "lang" > | < LANGMATCHES: "langmatches" > +| < LANGDIR: "langdir" > | < IS_URI: "isURI" > | < IS_IRI: "isIRI" > | < IS_BLANK: "isBlank" > | < IS_LITERAL: "isLiteral" > | < IS_NUMERIC: "isNumeric" > +| < HAS_LANG: "hasLang" > +| < HAS_LANGDIR: "hasLangDir" > | < REGEX: "regex" > | < SAME_TERM: "sameTerm" > | < RAND: "RAND" > @@ -1729,12 +1878,14 @@ TOKEN : | < LT: "<" > | < LE: "<=" > | < GE: ">=" > -| < GT2: ">>" > +| < L_TRIPLE: "<<(" > +| < R_TRIPLE: ")>>" > | < LT2: "<<" > -| -| -| < BANG: "!" > +| < GT2: ">>" > +| < L_ANN: "{|" > +| < R_ANN: "|}" > | < TILDE: "~" > +| < BANG: "!" > | < COLON: ":" > | < SC_OR: "||" > | < SC_AND: "&&" > diff --git a/jena-arq/Grammar/sparql_12.txt b/jena-arq/Grammar/sparql_12.txt deleted file mode 100644 index 98411b5f43c..00000000000 --- a/jena-arq/Grammar/sparql_12.txt +++ /dev/null @@ -1,486 +0,0 @@ - -DOCUMENT START -TOKENS - SKIP : { -" " -| "\t" -| "\n" -| "\r" -| "\f" -} - - SPECIAL : { - -} - - TOKEN : { -<#WS: " " | "\t" | "\n" | "\r" | "\f"> -| <#WSC: | > -} - - TOKEN : { -","<","\"","{","}","^","\\","|","`","\u0000"-" "] | )* ">"> -| )? ":"> -| > -| | ["0"-"9"]) (( | ".")* )?> -| > -| > -| ()+ ("-" ()+)*> -| <#A2Z: ["a"-"z","A"-"Z"]> -| <#A2ZN: ["a"-"z","A"-"Z","0"-"9"]> -} - - TOKEN : { - -} - - TOKEN [IGNORE_CASE] : { - -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -} - - TOKEN [IGNORE_CASE] : { - -| -| -| ()* > -| ()* > -| ()* > -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -} - - TOKEN : { -<#DIGITS: (["0"-"9"])+> -| > -| )? "." > -| | "." (["0"-"9"])+ | (["0"-"9"])+ > -| > -| > -| > -| > -| > -| > -| <#EXPONENT: ["e","E"] (["+","-"])? (["0"-"9"])+> -| <#QUOTE_3D: "\"\"\""> -| <#QUOTE_3S: "\'\'\'"> -| -| <#UCHAR: > -| <#UCHAR4: "\\" "u" > -| <#UCHAR8: "\\" "U" > -| | )* "\'"> -| | )* "\""> -| (("\'" | "\'\'")? (~["\'","\\"] | | ))* > -| (("\"" | "\"\"")? (~["\"","\\"] | | ))* > -} - - TOKEN : { - -| -| ()* > -| -| -| -| -| ()* > -| -| -| -| "> -| -| ="> -| >"> -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| -| "> -| -| -} - - TOKEN : { -<#PN_CHARS_BASE: ["A"-"Z"] | ["a"-"z"] | ["\u00c0"-"\u00d6"] | ["\u00d8"-"\u00f6"] | ["\u00f8"-"\u02ff"] | ["\u0370"-"\u037d"] | ["\u037f"-"\u1fff"] | ["\u200c"-"\u200d"] | ["\u2070"-"\u218f"] | ["\u2c00"-"\u2fef"] | ["\u3001"-"\ud7ff"] | ["\uf900"-"\ufffd"]> -| <#PN_CHARS_U: | "_"> -| <#PN_CHARS: | "-" | ["0"-"9"] | "\u00b7" | ["\u0300"-"\u036f"] | ["\u203f"-"\u2040"]> -| <#PN_PREFIX: (( | ".")* )?> -| <#PN_LOCAL: ( | ":" | ["0"-"9"] | ) (( | "." | ":" | )* ( | ":" | ))?> -| <#VARNAME: ( | ["0"-"9"]) ( | ["0"-"9"] | "\u00b7" | ["\u0300"-"\u036f"] | ["\u203f"-"\u2040"])*> -| <#PN_LOCAL_ESC: "\\" ("_" | "~" | "." | "-" | "!" | "$" | "&" | "\'" | "(" | ")" | "*" | "+" | "," | ";" | "=" | "/" | "?" | "#" | "@" | "%")> -| <#PLX: | > -| <#HEX: ["0"-"9"] | ["A"-"F"] | ["a"-"f"]> -| <#PERCENT: "%" > -} - - TOKEN : { -<#UNKNOWN: (~[" ","\t","\n","\r","\f"])+> -} - -NON-TERMINALS - QueryUnit := Query - Query := Prologue ( SelectQuery | ConstructQuery | DescribeQuery | AskQuery ) ValuesClause - UpdateUnit := Update - Prologue := ( BaseDecl | PrefixDecl )* - BaseDecl := IRIREF - PrefixDecl := IRIREF - SelectQuery := SelectClause ( DatasetClause )* WhereClause SolutionModifier - SubSelect := SelectClause WhereClause SolutionModifier ValuesClause - SelectClause :=