package com.quadcap.sql.types;
/* Copyright 1999 - 2003 Quadcap Software. All rights reserved.
*
* This software is distributed under the Quadcap Free Software License.
* This software may be used or modified for any purpose, personal or
* commercial. Open Source redistributions are permitted. Commercial
* redistribution of larger works derived from, or works which bundle
* this software requires a "Commercial Redistribution License"; see
* http://www.quadcap.com/purchase.
*
* Redistributions qualify as "Open Source" under one of the following terms:
*
* Redistributions are made at no charge beyond the reasonable cost of
* materials and delivery.
*
* Redistributions are accompanied by a copy of the Source Code or by an
* irrevocable offer to provide a copy of the Source Code for up to three
* years at the cost of materials and delivery. Such redistributions
* must allow further use, modification, and redistribution of the Source
* Code under substantially the same terms as this license.
*
* Redistributions of source code must retain the copyright notices as they
* appear in each source code file, these license terms, and the
* disclaimer/limitation of liability set forth as paragraph 6 below.
*
* Redistributions in binary form must reproduce this Copyright Notice,
* these license terms, and the disclaimer/limitation of liability set
* forth as paragraph 6 below, in the documentation and/or other materials
* provided with the distribution.
*
* The Software is provided on an "AS IS" basis. No warranty is
* provided that the Software is free of defects, or fit for a
* particular purpose.
*
* Limitation of Liability. Quadcap Software shall not be liable
* for any damages suffered by the Licensee or any third party resulting
* from use of the Software.
*/
import java.io.Externalizable;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;
import com.quadcap.util.Debug;
/**
* The SQL <b>BIT</b> type.
*
* @author Stan Bailes
*/
public class TypeBinary implements Type, Externalizable {
public static final TypeBinary typeBinary = new TypeBinary();
int max = 1;
public TypeBinary() {}
public TypeBinary(int max) {
this.max = max;
}
public String getTypeName() {
return "BIT";
}
public int getMax() { return max; }
public int getJDBCType() { return Types.BINARY; }
public String getJDBCClassName() { return "byte[]"; }
public int getPrecision() { return max; }
public int getScale() { return 0; }
public int getMaxPrecision() { return -1; }
public int getMinScale() { return -1; }
public int getMaxScale() { return -1; }
public boolean isCharType() { return false; }
public boolean isCaseSensitive() { return false; }
public boolean isCurrency() { return false; }
public boolean isSigned() { return false; }
public int getDisplayWidth() { return (max + 3) / 4; }
public String toString() {
StringBuffer sb = new StringBuffer();
sb.append("BIT");
if (max > 1) {
sb.append('(');
sb.append(Integer.toString(max));
sb.append(')');
}
return sb.toString();
}
/**
* We don't bother serializing the data, since Java serialization is
* only used for the type portion of a table column.
*/
public void readExternal(ObjectInput in) throws IOException {
max = in.readInt();
}
public void writeExternal(ObjectOutput out) throws IOException {
out.writeInt(max);
}
public Value convert(Value v) throws ValueException {
return v.convert(this);
}
public Value convert(ValueBoolean v) throws ValueException {
return v.convert(this);
}
public String getCreateParams() {
return "length";
}
}
|