/* * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.sun.rowset.internal; import com.sun.rowset.JdbcRowSetResourceBundle; import java.sql.*; import javax.sql.*; import java.io.*; import java.util.*; /** * A class used internally to manage a CachedRowSet object's * insert row. This class keeps track of the number of columns in the * insert row and which columns have had a value inserted. It provides * methods for retrieving a column value, setting a column value, and finding * out whether the insert row is complete. */ public class InsertRow extends BaseRow implements Serializable, Cloneable { /** * An internal BitSet object used to keep track of the * columns in this InsertRow object that have had a value * inserted. */ private BitSet colsInserted; /** * The number of columns in this InsertRow object. */ private int cols; private JdbcRowSetResourceBundle resBundle; /** * Creates an InsertRow object initialized with the * given number of columns, an array for keeping track of the * original values in this insert row, and a * BitSet object with the same number of bits as * there are columns. * * @param numCols an int indicating the number of columns * in this InsertRow object */ public InsertRow(int numCols) { origVals = new Object[numCols]; colsInserted = new BitSet(numCols); cols = numCols; try { resBundle = JdbcRowSetResourceBundle.getJdbcRowSetResourceBundle(); } catch(IOException ioe) { throw new RuntimeException(ioe); } } /** * Sets the bit in this InsertRow object's internal * BitSet object that corresponds to the specified column * in this InsertRow object. Setting a bit indicates * that a value has been set. * * @param col the number of the column to be marked as inserted; * the first column is 1 */ protected void markColInserted(int col) { colsInserted.set(col); } /** * Indicates whether this InsertRow object has a value * for every column that cannot be null. * @param RowSetMD the RowSetMetaData object for the * CachedRowSet object that maintains this * InsertRow object * @return true if this InsertRow object is * complete; false otherwise * @throws SQLException if there is an error accessing data */ public boolean isCompleteRow(RowSetMetaData RowSetMD) throws SQLException { for (int i = 0; i < cols; i++) { if (colsInserted.get(i) == false && RowSetMD.isNullable(i + 1) == ResultSetMetaData.columnNoNulls) { return false; } } return true; } /** * Clears all the bits in the internal BitSet object * maintained by this InsertRow object. Clearing all the bits * indicates that none of the columns have had a value inserted. */ public void initInsertRow() { for (int i = 0; i < cols; i++) { colsInserted.clear(i); } } /** * Retrieves the value of the designated column in this * InsertRow object. If no value has been inserted * into the designated column, this method throws an * SQLException. * * @param idx the column number of the value to be retrieved; * the first column is 1 * @throws SQLException if no value has been inserted into * the designated column */ public Object getColumnObject(int idx) throws SQLException { if (colsInserted.get(idx - 1) == false) { throw new SQLException(resBundle.handleGetObject("insertrow.novalue").toString()); } return (origVals[idx - 1]); } /** * Sets the element in this InsertRow object's * internal array of original values that corresponds to the * designated column with the given value. If the third * argument is true, * which means that the cursor is on the insert row, this * InsertRow object's internal BitSet object * is set so that the bit corresponding to the column being set is * turned on. * * @param idx the number of the column in the insert row to be set; * the first column is 1 * @param val the value to be set */ public void setColumnObject(int idx, Object val) { origVals[idx - 1] = val; markColInserted(idx - 1); } /** * This method re populates the resBundle * during the deserialization process * */ private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { // Default state initialization happens here ois.defaultReadObject(); // Initialization of transient Res Bundle happens here . try { resBundle = JdbcRowSetResourceBundle.getJdbcRowSetResourceBundle(); } catch(IOException ioe) { throw new RuntimeException(ioe); } } static final long serialVersionUID = 1066099658102869344L; }