/* * Copyright 2004-2008 the Seasar Foundation and the Others. * * 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.seasar.extension.jdbc.impl; import java.sql.ResultSet; import java.sql.SQLException; import org.seasar.framework.util.StringConversionUtil; /** * PostgreSQLでEUCを使う場合用の {@link ResultSet}です。 FULLWIDTH TILDE(U+FF5E)をWAVE * DASH(U+301C)に、FULLWIDTH HYPHEN-MINUS(U+FF0D)をMINUS SIGN(U+2212)に変換します。 * * @author koichik */ public class PostgreEucResultSet extends ResultSetWrapper { /** * FULLWIDTH TILDEです。 */ public static final char FULLWIDTH_TILDE = '\uFF5E'; /** * WAVE DASHです。 */ public static final int WAVE_DASH = '\u301C'; /** * FULLWIDTH HYPHEN-MINUSです。 */ public static final int FULLWIDTH_HYPHEN_MINUS = '\uFF0D'; /** * MINUS SIGNです。 */ public static final int MINUS_SIGN = '\u2212'; /** * {@link PostgreEucResultSet}を作成します。 * * @param resultSet * 結果セット */ public PostgreEucResultSet(ResultSet resultSet) { super(resultSet); } public String getString(int columnIndex) throws SQLException { return convert(super.getString(columnIndex)); } public String getString(String columnName) throws SQLException { return convert(super.getString(columnName)); } /** * WAVE DASH(U+301C)をFULLWIDTH TILDE(U+FF5E)に変換します。 * * @param source * ソース * @return 変換結果 * @see StringConversionUtil#fromWaveDashToFullwidthTilde(String) */ protected String convert(String source) { if (source == null) { return null; } StringBuffer result = new StringBuffer(source.length()); for (int i = 0; i < source.length(); i++) { char ch = source.charAt(i); switch (ch) { case FULLWIDTH_TILDE: ch = WAVE_DASH; break; case FULLWIDTH_HYPHEN_MINUS: ch = MINUS_SIGN; break; default: break; } result.append(ch); } return result.toString(); } }