Quadcap Embeddable Database

com/quadcap/sql/FilterCursor.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.sql.SQLException; 00042 00043 import com.quadcap.util.Debug; 00044 00045 /** 00046 * Base class for all filter cursor types. 00047 * 00048 * @author Stan Bailes 00049 */ 00050 public class FilterCursor extends CursorImpl { 00051 Cursor cursor; 00052 00053 public FilterCursor(Session session) { 00054 super(session, null); 00055 } 00056 00057 public FilterCursor(Session session, String name, Cursor cursor) 00058 throws SQLException 00059 { 00060 super(session, name); 00061 this.cursor = cursor; 00062 addColumns(session, cursor); 00063 } 00064 00065 public FilterCursor(Session session, Cursor cursor) 00066 throws SQLException 00067 { 00068 super(session, cursor.getName(), cursor.getOuterCursor()); 00069 this.cursor = cursor; 00070 addColumns(session, cursor); 00071 } 00072 00073 protected void setCursor(Cursor cursor) { 00074 this.cursor = cursor; 00075 } 00076 00077 public Row getRow() throws SQLException { 00078 return cursor.getRow(); 00079 } 00080 00081 public long getRowId() { 00082 return cursor.getRowId(); 00083 } 00084 00085 public void updateRow(Row row) throws SQLException { 00086 cursor.updateRow(row); 00087 } 00088 00089 public void insertRow(Row row) throws SQLException { 00090 cursor.insertRow(row); 00091 } 00092 00093 public void deleteRow() throws SQLException { 00094 cursor.deleteRow(); 00095 } 00096 00097 public void beforeFirst() throws SQLException { 00098 cursor.beforeFirst(); 00099 } 00100 00101 public void afterLast() throws SQLException { 00102 cursor.afterLast(); 00103 } 00104 00105 public boolean absolute(int row) throws SQLException { 00106 return cursor.absolute(row); 00107 } 00108 00109 public boolean next() throws SQLException { 00110 return cursor.next(); 00111 } 00112 00113 public boolean prev() throws SQLException { 00114 return cursor.prev(); 00115 } 00116 00117 public boolean isWritable(int column) throws SQLException { 00118 return cursor.isWritable(column); 00119 } 00120 00121 public void setOuterCursor(Cursor c) { 00122 super.setOuterCursor(c); 00123 if (cursor != null) cursor.setOuterCursor(c); 00124 } 00125 00126 public void close() throws SQLException { 00127 cursor.close(); 00128 } 00129 00130 public long size() throws SQLException { 00131 return cursor.size(); 00132 } 00133 00134 //#ifdef DEBUG 00135 public String toString() { 00136 return super.toString() + " (filters: " + cursor + ")"; 00137 } 00138 //#endif 00139 }