/*
* Copyright 2006 Le Duc Bao, Ralf Joachim
*
* Licensed 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.castor.ddlgen;
import java.util.HashMap;
import java.util.Map;
import org.castor.ddlgen.typeinfo.TypeInfo;
/**
* AbstractTypeMapper is the base class for mapping JDBC supported type and
* RDBMS data type.
* <p/>The initialize(Configuration) is used to defined the mapping table in which
* the configuration is handled parameters for TypeInfo. Please refer to
* org.castor.ddl.typeinfo for TypeInfo definitions
*
* @author <a href="mailto:leducbao AT gmail DOT com">Le Duc Bao</a>
* @author <a href="mailto:ralf DOT joachim AT syscon DOT eu">Ralf Joachim</a>
* @version $Revision: 5951 $ $Date: 2006-04-25 16:09:10 -0600 (Tue, 25 Apr 2006) $
* @since 1.1
*/
public abstract class AbstractTypeMapper implements TypeMapper {
//--------------------------------------------------------------------------
/** Map of known types which associates JDBC type to corresponding TypeInfo. */
private final Map<String, TypeInfo> _types = new HashMap<String, TypeInfo>();
//--------------------------------------------------------------------------
/**
* Construct an abstract TypeMapper using given configuration to get default
* parameters for parameterized types.
*
* @param conf The configuration to get default parameter values from.
*/
protected AbstractTypeMapper(final DDLGenConfiguration conf) {
initialize(conf);
}
/**
* Initialize map of known types using given configuration to get default parameters
* for parameterized types.
*
* @param conf The configuration to get default parameter values from.
*/
protected abstract void initialize(final DDLGenConfiguration conf);
//--------------------------------------------------------------------------
/**
* Add TypeInfo to map of known types.
*
* @param type The TypeInfo to add.
*/
protected final void add(final TypeInfo type) {
_types.put(type.getJdbcType(), type);
}
/**
* {@inheritDoc}
*/
public final TypeInfo getType(final String jdcbType) {
String ddlJdbcType = jdcbType.toLowerCase();
if (ddlJdbcType.matches(".*\\Q[\\E.*")) {
ddlJdbcType = ddlJdbcType.substring(0, ddlJdbcType.indexOf("["));
}
return _types.get(ddlJdbcType);
}
//--------------------------------------------------------------------------
}