/* * Hibernate, Relational Persistence for Idiomatic Java * * License: GNU Lesser General Public License (LGPL), version 2.1 or later. * See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>. */ package org.hibernate.type; import java.io.Serializable; import org.hibernate.dialect.Dialect; import org.hibernate.type.descriptor.java.BooleanTypeDescriptor; import org.hibernate.type.descriptor.sql.CharTypeDescriptor; /** * A type that maps between {@link java.sql.Types#CHAR CHAR(1)} and {@link Boolean} (using 'T' and 'F') * * @author Gavin King * @author Steve Ebersole */ public class TrueFalseType extends AbstractSingleColumnStandardBasicType<Boolean> implements PrimitiveType<Boolean>, DiscriminatorType<Boolean> { public static final TrueFalseType INSTANCE = new TrueFalseType(); public TrueFalseType() { super( CharTypeDescriptor.INSTANCE, new BooleanTypeDescriptor( 'T', 'F' ) ); } @Override public String getName() { return "true_false"; } @Override public Class getPrimitiveClass() { return boolean.class; } @Override public Boolean stringToObject(String xml) throws Exception { return fromString( xml ); } @Override public Serializable getDefaultValue() { return Boolean.FALSE; } @Override public String objectToSQLString(Boolean value, Dialect dialect) throws Exception { return StringType.INSTANCE.objectToSQLString( value ? "T" : "F", dialect ); } }