1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139
|
/*
Derby - Class org.apache.derbyTesting.unitTests.store.T_AccessRow
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package org.apache.derbyTesting.unitTests.store;
import org.apache.derby.iapi.store.access.*;
import org.apache.derby.iapi.services.io.Storable;
import org.apache.derby.iapi.types.DataValueDescriptor;
import org.apache.derby.iapi.types.SQLInteger;
import org.apache.derby.iapi.error.StandardException;
public class T_AccessRow
{
protected DataValueDescriptor column[];
/**
Construct a new row which can hold the provided number of columns.
**/
public T_AccessRow(int ncols)
{
column = new DataValueDescriptor[ncols];
for (int i = 0; i < ncols; i++)
column[i] = new SQLInteger(0);
}
/**
Construct a new row with three integer columns which
have the column values provided.
**/
public T_AccessRow(int col0value, int col1value, int col2value)
{
column = new DataValueDescriptor[3];
column[0] = new SQLInteger(col0value);
column[1] = new SQLInteger(col1value);
column[2] = new SQLInteger(col2value);
}
public DataValueDescriptor getCol(int colid)
{
if (colid >= column.length)
return null;
else
return column[colid];
}
public void setCol(int colid, DataValueDescriptor val)
{
if (colid >= column.length)
realloc(colid + 1);
column[colid] = val;
}
public boolean equals(T_AccessRow other) throws StandardException
{
if (other == null)
return false;
if (other.column.length != this.column.length)
return false;
for (int i = 0; i < this.column.length; i++)
if (this.column[i].compare(other.column[i]) != 0)
return false;
return true;
}
public String toString()
{
String s = "{ ";
for (int i = 0; i < column.length; i++)
{
s += column[i].toString();
if (i < (column.length - 1))
s += ", ";
}
s += " }";
return s;
}
// Set the number of columns in the row to ncols, preserving
// the existing contents.
protected void realloc(int ncols)
{
DataValueDescriptor newcol[] = new DataValueDescriptor[ncols];
for (int i = 0; i < column.length; i++)
newcol[i] = column[i];
column = newcol;
}
public Storable getStorableColumn(int colid)
{
return column[colid];
}
public void setStorableColumn(int colid, Storable value) {
column[colid] = (DataValueDescriptor) value;
}
public int nColumns()
{
return column.length;
}
public DataValueDescriptor[] getRowArray() {
return column;
}
public DataValueDescriptor[] getRowArrayClone() {
DataValueDescriptor[] retval = new DataValueDescriptor[column.length];
for (int index = 0; index < column.length; index++)
retval[index] = column[index].cloneValue(false);
return retval;
}
}
|