Quadcap Embeddable Database

com/quadcap/sql/PredicateCursor.java

Go to the documentation of this file.
00001 package com.quadcap.sql; 00002 00003 /* Copyright 1999 - 2003 Quadcap Software. All rights reserved. 00004 * 00005 * This software is distributed under the Quadcap Free Software License. 00006 * This software may be used or modified for any purpose, personal or 00007 * commercial. Open Source redistributions are permitted. Commercial 00008 * redistribution of larger works derived from, or works which bundle 00009 * this software requires a "Commercial Redistribution License"; see 00010 * http://www.quadcap.com/purchase. 00011 * 00012 * Redistributions qualify as "Open Source" under one of the following terms: 00013 * 00014 * Redistributions are made at no charge beyond the reasonable cost of 00015 * materials and delivery. 00016 * 00017 * Redistributions are accompanied by a copy of the Source Code or by an 00018 * irrevocable offer to provide a copy of the Source Code for up to three 00019 * years at the cost of materials and delivery. Such redistributions 00020 * must allow further use, modification, and redistribution of the Source 00021 * Code under substantially the same terms as this license. 00022 * 00023 * Redistributions of source code must retain the copyright notices as they 00024 * appear in each source code file, these license terms, and the 00025 * disclaimer/limitation of liability set forth as paragraph 6 below. 00026 * 00027 * Redistributions in binary form must reproduce this Copyright Notice, 00028 * these license terms, and the disclaimer/limitation of liability set 00029 * forth as paragraph 6 below, in the documentation and/or other materials 00030 * provided with the distribution. 00031 * 00032 * The Software is provided on an "AS IS" basis. No warranty is 00033 * provided that the Software is free of defects, or fit for a 00034 * particular purpose. 00035 * 00036 * Limitation of Liability. Quadcap Software shall not be liable 00037 * for any damages suffered by the Licensee or any third party resulting 00038 * from use of the Software. 00039 */ 00040 00041 import java.util.Vector; 00042 00043 import java.sql.SQLException; 00044 00045 import com.quadcap.sql.types.Value; 00046 import com.quadcap.sql.types.ValueBoolean; 00047 import com.quadcap.sql.types.ValueUnknown; 00048 00049 import com.quadcap.util.Debug; 00050 00051 /** 00052 * Cursor for <b>WHERE</b> predicates. 00053 * 00054 * @author Stan Bailes 00055 */ 00056 public class PredicateCursor extends FilterCursor { 00057 Expression predicate = null; 00058 Row row = null; 00059 00060 /** 00061 * A PredicateCursor is a kind of FilterCursor which only returns 00062 * rows which match a predicate 00063 */ 00064 public PredicateCursor(Session session, Cursor cursor, 00065 Expression predicate) throws SQLException { 00066 super(session, cursor); 00067 this.predicate = predicate; 00068 } 00069 00070 /** 00071 * Return the current cursor row 00072 */ 00073 public Row getRow() throws SQLException { 00074 return row; 00075 } 00076 00077 /** 00078 * Cursor.next() Advance the cursor and return 'true' if the cursor 00079 * advances past a valid item. This item becomes the current row. 00080 */ 00081 public boolean next() throws SQLException { 00082 row = null; 00083 while (row == null && cursor.next()) { 00084 Value val = predicate.getValue(session, cursor); 00085 //Debug.println("[" + predicate + "] on " + cursor.getRow() + " " + 00086 // (outer == null ? "{}" : outer.getRow().toString()) + " = " + val); 00087 if (Value.isTrue(val)) { 00088 row = cursor.getRow(); 00089 } 00090 } 00091 return row != null; 00092 } 00093 00094 /** 00095 * Cursor.next() Retreat the cursor and return 'true' if the cursor 00096 * moves past a valid item. This item becomes the current row. 00097 */ 00098 public boolean prev() throws SQLException { 00099 row = null; 00100 while (row == null && cursor.prev()) { 00101 Value val = predicate.getValue(session, cursor); 00102 if (Value.isTrue(val)) { 00103 row = cursor.getRow(); 00104 } 00105 } 00106 return row != null; 00107 } 00108 00109 /** 00110 * Position the cursor to the specified absolute row. The first row 00111 * is row '1', and the last row is '-1', as in JDBC. 00112 */ 00113 public boolean absolute(int row) throws SQLException { 00114 if (row > 0) { 00115 beforeFirst(); 00116 while (row-- > 0) if (!next()) return false; 00117 } else { 00118 afterLast(); 00119 while (row++ < 0) if (!prev()) return false; 00120 } 00121 return true; 00122 } 00123 00124 00125 //#ifdef DEBUG 00126 public String toString() { 00127 return "PredicateCursor: " + super.toString(); 00128 } 00129 //#endif 00130 00131 }