Improve treatment of nregativity in SpanWithinQueries

Change-Id: I84ca40cdaef150211963da857cd6eab9c9e44db7
diff --git a/Changes b/Changes
index 47f9b2f..06d3996 100644
--- a/Changes
+++ b/Changes
@@ -10,6 +10,7 @@
           a single extension, if possible (diewald)
         - [bugfix] Fixed paths in test suite for supporting
           spaces (margaretha)
+        - [bugfix] Warn on empty elements in positional queries (diewald)
 
 0.55.6 2016-08-10
         - [bugfix] distance with key "t" uses default foundry (diewald)
diff --git a/misc/errorcodes.md b/misc/errorcodes.md
index 1ef94c6..0a01892 100644
--- a/misc/errorcodes.md
+++ b/misc/errorcodes.md
@@ -8,6 +8,7 @@
 603: "Unable to commit staged data to index"
 604: "Unable to connect to database"
 610: "Missing request parameters"
+613: Arbitrary deserialization error
 620: "Unable to generate JSON"
 621: "Unable to parse JSON"
 630: "Document not found"
@@ -62,6 +63,8 @@
 769: "Overlap variant currently interpreted as overlap"
 770: "Arity attributes are currently not supported - results may not be correct"
 771: "Arbitrary elements with attributes are currently not supported"
+772: "'Any' elements are currently not supported in position operations"
+773: "Negative elements are currently not supported in position operations"
 780: "This query matches everywhere"
 781: "Optionality of query is ignored"
 782: "Exclusivity of query is ignored"
diff --git a/src/main/java/de/ids_mannheim/korap/query/wrap/SpanWithinQueryWrapper.java b/src/main/java/de/ids_mannheim/korap/query/wrap/SpanWithinQueryWrapper.java
index 576b1e0..ceb58f2 100644
--- a/src/main/java/de/ids_mannheim/korap/query/wrap/SpanWithinQueryWrapper.java
+++ b/src/main/java/de/ids_mannheim/korap/query/wrap/SpanWithinQueryWrapper.java
@@ -96,6 +96,15 @@
 
         // TODO: if (wrap.isNegative())
 
+		if (this.element.isEmpty() || this.wrap.isEmpty()) {
+			throw new QueryException(772, "'Any' elements are currently not supported in position operations");
+		};
+
+		if (this.element.isNegative() || this.wrap.isNegative()) {
+			throw new QueryException(773, "Negative elements are currently not supported in position operations");
+		};
+		
+		
         return new SpanWithinQuery(
                 this.element.retrieveNode(this.retrieveNode).toFragmentQuery(),
                 this.wrap.retrieveNode(this.retrieveNode).toFragmentQuery(),
@@ -118,7 +127,7 @@
 
     @Override
     public boolean isNegative () {
-        if (this.element.isNegative())
+        if (this.element.isNegative() || this.wrap.isNegative())
             return true;
         return false;
     };
diff --git a/src/test/java/de/ids_mannheim/korap/query/TestSpanWithinQuery.java b/src/test/java/de/ids_mannheim/korap/query/TestSpanWithinQuery.java
index 24f296c..829167f 100644
--- a/src/test/java/de/ids_mannheim/korap/query/TestSpanWithinQuery.java
+++ b/src/test/java/de/ids_mannheim/korap/query/TestSpanWithinQuery.java
@@ -4,7 +4,9 @@
 import de.ids_mannheim.korap.query.wrap.SpanSequenceQueryWrapper;
 import de.ids_mannheim.korap.query.SpanWithinQuery;
 import de.ids_mannheim.korap.query.SpanElementQuery;
+import de.ids_mannheim.korap.query.QueryBuilder;
 
+import org.apache.lucene.search.spans.SpanQuery;
 import de.ids_mannheim.korap.util.QueryException;
 
 import static org.junit.Assert.*;
@@ -47,4 +49,17 @@
                 "spanStartsWith(<field:s />, spanNext(spanNext(field:a, field:b), field:c))",
                 ssequery.toString());
     };
+
+	@Test
+    public void spanSegmentStartsWithEmptyQuery () {
+
+		QueryBuilder qb = new QueryBuilder("field1");
+		
+		try {
+			SpanQuery sq = qb.startswith(qb.tag("base/s"), qb.empty()).toQuery();
+		}
+		catch (QueryException qe) {
+			assertEquals(qe.getErrorCode(), 772);
+		};
+    };
 };