You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@jena.apache.org by "Michael Cochez (Jira)" <ji...@apache.org> on 2020/07/30 16:55:00 UTC
[jira] [Created] (JENA-1941) Parsed query cannot get serialized
Michael Cochez created JENA-1941:
------------------------------------
Summary: Parsed query cannot get serialized
Key: JENA-1941
URL: https://issues.apache.org/jira/browse/JENA-1941
Project: Apache Jena
Issue Type: Bug
Components: ARQ, Jena
Affects Versions: Jena 3.16.0
Environment: Oracle jdk-14.0.1
Reporter: Michael Cochez
The following query can be parsed, but cannot be serialized back:
{code:java}
import org.apache.jena.query.Query;
import org.apache.jena.query.QueryFactory;
public class MinimalTest {
public static void main(String[] args) {
String queryString = "SELECT ?a WHERE { <%s> <http://ex.com> <http://ex.com> }";
Query q = QueryFactory.create(queryString);
String serialized = q.serialize();
System.out.println(serialized);
}
}
{code}
{noformat}
Exception in thread "main" java.lang.StringIndexOutOfBoundsException: begin 0, end 51, length 50
at java.base/java.lang.String.checkBoundsBeginEnd(String.java:3756)
at java.base/java.lang.String.substring(String.java:1902)
at org.apache.jena.shared.impl.PrefixMappingImpl.qnameFor(PrefixMappingImpl.java:235)
at org.apache.jena.sparql.util.FmtUtils.prefixFor(FmtUtils.java:494)
at org.apache.jena.sparql.util.FmtUtils.stringForURI(FmtUtils.java:448)
at org.apache.jena.sparql.util.FmtUtils.stringForURI(FmtUtils.java:431)
at org.apache.jena.sparql.util.FmtUtils.stringForNode(FmtUtils.java:374)
at org.apache.jena.sparql.util.FmtUtils.stringForNode(FmtUtils.java:348)
at org.apache.jena.sparql.serializer.FormatterBase.slotToString(FormatterBase.java:57)
at org.apache.jena.sparql.serializer.FormatterElement.setWidths(FormatterElement.java:615)
at org.apache.jena.sparql.serializer.FormatterElement.formatTriples(FormatterElement.java:503)
at org.apache.jena.sparql.serializer.FormatterElement.flush(FormatterElement.java:558)
at org.apache.jena.sparql.serializer.FormatterElement.visit(FormatterElement.java:165)
at org.apache.jena.sparql.syntax.ElementPathBlock.visit(ElementPathBlock.java:94)
at org.apache.jena.sparql.serializer.FormatterElement.visit(FormatterElement.java:321)
at org.apache.jena.sparql.syntax.ElementGroup.visit(ElementGroup.java:120)
at org.apache.jena.sparql.serializer.FormatterElement.visitAsGroup(FormatterElement.java:453)
at org.apache.jena.sparql.serializer.QuerySerializer.visitQueryPattern(QuerySerializer.java:207)
at org.apache.jena.query.Query.visit(Query.java:770)
at org.apache.jena.query.Query.serialize(Query.java:928)
at org.apache.jena.query.Query.serialize(Query.java:905)
at org.apache.jena.query.Query.serialize(Query.java:895)
at org.apache.jena.query.Query.serialize(Query.java:856)
at MinimalTest.main(MinimalTest.java:10)
{noformat}
I am not entirely sure whether it is
# The query which is invalid, in which case there is a bug in the parser
# The serialization which should not fail, in which case the serializer has a bug.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)