X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=src%2Forg%2Fz3950%2Fzing%2Fcql%2FCQLBooleanNode.java;h=9462914e3b55602f6d04f8110e0bcdb179d2d8a9;hb=f57d48d060411f662eea823b97cc45038bda0def;hp=b0ca761d8d0414df3c5bc2101d049874ba83a79c;hpb=fc82b225d39cc66cb85c2557db0c0d4a4c5a6e27;p=cql-java-moved-to-github.git
diff --git a/src/org/z3950/zing/cql/CQLBooleanNode.java b/src/org/z3950/zing/cql/CQLBooleanNode.java
index b0ca761..9462914 100644
--- a/src/org/z3950/zing/cql/CQLBooleanNode.java
+++ b/src/org/z3950/zing/cql/CQLBooleanNode.java
@@ -1,17 +1,16 @@
-// $Id: CQLBooleanNode.java,v 1.8 2002-11-06 20:13:45 mike Exp $
+// $Id: CQLBooleanNode.java,v 1.17 2007-07-03 13:40:13 mike Exp $
package org.z3950.zing.cql;
import java.util.Properties;
+import java.util.Vector;
/**
* Represents a boolean node in a CQL parse-tree.
*
- * @version $Id: CQLBooleanNode.java,v 1.8 2002-11-06 20:13:45 mike Exp $
+ * @version $Id: CQLBooleanNode.java,v 1.17 2007-07-03 13:40:13 mike Exp $
*/
public abstract class CQLBooleanNode extends CQLNode {
- CQLBooleanNode() {} // prevent javadoc from documenting this
-
/**
* The root of a parse-tree representing the left-hand side.
*/
@@ -22,24 +21,38 @@ public abstract class CQLBooleanNode extends CQLNode {
*/
public CQLNode right;
- public String toXCQL(int level) {
- return (indent(level) + "\n" +
- opXQL(level+1) +
- left.toXCQL(level+1) +
- right.toXCQL(level+1) +
- indent(level) + "\n");
+ /**
+ * The set of modifiers that are applied to this boolean.
+ */
+ public ModifierSet ms;
+
+ protected CQLBooleanNode(CQLNode left, CQLNode right, ModifierSet ms) {
+ this.left = left;
+ this.right = right;
+ this.ms = ms;
}
- // Represents the boolean operation itself: overridden for CQLProxNode
- String opXQL(int level) {
- return(indent(level) + "\n" +
- indent(level+1) + "" + op() + "\n" +
- indent(level) + "\n");
+ public String toXCQL(int level, Vector prefixes, Vector sortkeys) {
+ if (sortkeys != null)
+ throw new Error("CQLBooleanNode.toXCQL() called with sortkeys");
+
+ return (indent(level) + "\n" +
+ renderPrefixes(level+1, prefixes) +
+ ms.toXCQL(level+1, "boolean") +
+ indent(level+1) + "\n" +
+ left.toXCQL(level+2) +
+ indent(level+1) + "\n" +
+ indent(level+1) + "\n" +
+ right.toXCQL(level+2) +
+ indent(level+1) + "\n" +
+ indent(level) + "\n");
}
public String toCQL() {
// ### We don't always need parens around the operands
- return "(" + left.toCQL() + ") " + op() + " (" + right.toCQL() + ")";
+ return ("(" + left.toCQL() + ")" +
+ " " + ms.toCQL() + " " +
+ "(" + right.toCQL() + ")");
}
public String toPQF(Properties config) throws PQFTranslationException {
@@ -49,7 +62,30 @@ public abstract class CQLBooleanNode extends CQLNode {
}
// represents the operation for PQF: overridden for CQLProxNode
- String opPQF() { return op(); }
+ String opPQF() { return ms.getBase(); }
+
+ public byte[] toType1BER(Properties config) throws PQFTranslationException {
+ System.out.println("in CQLBooleanNode.toType1BER(): PQF=" +
+ toPQF(config));
+ byte[] rpn1 = left.toType1BER(config);
+ byte[] rpn2 = right.toType1BER(config);
+ byte[] op = opType1();
+ byte[] rpnStructure = new byte[rpn1.length+rpn2.length+op.length+4];
+
+ // rpnRpnOp
+ int offset = putTag(CONTEXT, 1, CONSTRUCTED, rpnStructure, 0);
+
+ rpnStructure[offset++] = (byte)(0x80&0xff); // indefinite length
+ System.arraycopy(rpn1, 0, rpnStructure, offset, rpn1.length);
+ offset += rpn1.length;
+ System.arraycopy(rpn2, 0, rpnStructure, offset, rpn2.length);
+ offset += rpn2.length;
+ System.arraycopy(op, 0, rpnStructure, offset, op.length);
+ offset += op.length;
+ rpnStructure[offset++] = 0x00; // end rpnRpnOp
+ rpnStructure[offset++] = 0x00;
+ return rpnStructure;
+ }
- abstract String op();
+ abstract byte[] opType1();
}