com.aoindustries.aoserv.client.PostgresEncoding Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aoserv-client Show documentation
Show all versions of aoserv-client Show documentation
Java client for the AOServ Platform.
/*
* aoserv-client - Java client for the AOServ platform.
* Copyright (C) 2001-2009, 2016 AO Industries, Inc.
* support@aoindustries.com
* 7262 Bull Pen Cir
* Mobile, AL 36695
*
* This file is part of aoserv-client.
*
* aoserv-client is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* aoserv-client is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with aoserv-client. If not, see .
*/
package com.aoindustries.aoserv.client;
import com.aoindustries.io.CompressedDataInputStream;
import com.aoindustries.io.CompressedDataOutputStream;
import java.io.IOException;
import java.sql.ResultSet;
import java.sql.SQLException;
/**
* Beginning with PostgreSQL 7.1, multiple character encoding formats are
* supported, the PostgresEncoding
s represent the possible
* formats.
*
* @see PostgresDatabase
*
* @author AO Industries, Inc.
*/
final public class PostgresEncoding extends GlobalObjectIntegerKey {
static final int
COLUMN_PKEY=0,
COLUMN_POSTGRES_VERSION=2
;
static final String COLUMN_ENCODING_name = "encoding";
static final String COLUMN_POSTGRES_VERSION_name = "postgres_version";
static final String COLUMN_PKEY_name = "pkey";
/**
* The supported encodings.
*/
public static final String
ALT="ALT", // 7.1 7.2 7.3 8.0
BIG5="BIG5", // 7.1 7.2 7.3
EUC_CN="EUC_CN", // 7.1 7.2 7.3 8.0 9.4
EUC_JIS_2004="EUC_JIS_2004", // 9.4
EUC_JP="EUC_JP", // 7.1 7.2 7.3 8.0 9.4
EUC_KR="EUC_KR", // 7.1 7.2 7.3 8.0 9.4
EUC_TW="EUC_TW", // 7.1 7.2 7.3 8.0 9.4
GB18030="GB18030", // 7.3
GBK="GBK", // 7.3
ISO_8859_5="ISO_8859_5", // 7.2 7.3 8.0 9.4
ISO_8859_6="ISO_8859_6", // 7.2 7.3 8.0 9.4
ISO_8859_7="ISO_8859_7", // 7.2 7.3 8.0 9.4
ISO_8859_8="ISO_8859_8", // 7.2 7.3 8.0 9.4
JOHAB="JOHAB", // 7.3 8.0
KOI8="KOI8", // 7.1 7.2 7.3 8.0
KOI8R="KOI8R", // 9.4
KOI8U="KOI8U", // 9.4
LATIN1="LATIN1", // 7.1 7.2 7.3 8.0 9.4
LATIN2="LATIN2", // 7.1 7.2 7.3 8.0 9.4
LATIN3="LATIN3", // 7.1 7.2 7.3 8.0 9.4
LATIN4="LATIN4", // 7.1 7.2 7.3 8.0 9.4
LATIN5="LATIN5", // 7.1 7.2 7.3 8.0 9.4
LATIN6="LATIN6", // 7.2 7.3 8.0 9.4
LATIN7="LATIN7", // 7.2 7.3 8.0 9.4
LATIN8="LATIN8", // 7.2 7.3 8.0 9.4
LATIN9="LATIN9", // 7.2 7.3 8.0 9.4
LATIN10="LATIN10", // 7.2 7.3 8.0 9.4
MULE_INTERNAL="MULE_INTERNAL", // 7.1 7.2 7.3 8.0 9.4
SJIS="SJIS", // 7.1 7.2 7.3
SQL_ASCII="SQL_ASCII", // 7.1 7.2 7.3 8.0 9.4
UTF8="UTF8", // 9.4
TCVN="TCVN", // 7.3 8.0
UHC="UHC", // 7.3
UNICODE="UNICODE", // 7.1 7.2 7.3 8.0
WIN="WIN", // 7.1 7.2 7.3 8.0
WIN866="WIN866", // 9.4
WIN874="WIN874", // 7.3 8.0 9.4
WIN1250="WIN1250", // 7.1 7.2 7.3 8.0 9.4
WIN1251="WIN1251", // 9.4
WIN1252="WIN1252", // 9.4
WIN1253="WIN1253", // 9.4
WIN1254="WIN1254", // 9.4
WIN1255="WIN1255", // 9.4
WIN1256="WIN1256", // 7.3 8.0 9.4
WIN1257="WIN1257", // 9.4
WIN1258="WIN1258" // 9.4
;
/**
* Gets the default PostgreSQL encoding for the given database version.
* Version <= 8.3: SQL_ASCII.
* Version >= 9.4: UTF8
*/
public static String getDefaultEncoding(String version) {
if(
version.startsWith("7.")
|| version.startsWith("8.")
) {
return SQL_ASCII;
} else {
return UTF8;
}
}
String encoding;
int postgres_version;
@Override
Object getColumnImpl(int i) {
switch(i) {
case COLUMN_PKEY: return pkey;
case 1: return encoding;
case COLUMN_POSTGRES_VERSION: return postgres_version;
default: throw new IllegalArgumentException("Invalid index: "+i);
}
}
public String getEncoding() {
return encoding;
}
public PostgresVersion getPostgresVersion(AOServConnector connector) throws SQLException, IOException {
PostgresVersion pv=connector.getPostgresVersions().get(postgres_version);
if(pv==null) throw new SQLException("Unable to find PostgresVersion: "+postgres_version);
return pv;
}
@Override
public SchemaTable.TableID getTableID() {
return SchemaTable.TableID.POSTGRES_ENCODINGS;
}
@Override
public void init(ResultSet result) throws SQLException {
pkey=result.getInt(1);
encoding=result.getString(2);
postgres_version=result.getInt(3);
}
@Override
public void read(CompressedDataInputStream in) throws IOException {
pkey=in.readCompressedInt();
encoding=in.readUTF().intern();
postgres_version=in.readCompressedInt();
}
@Override
public void write(CompressedDataOutputStream out, AOServProtocol.Version version) throws IOException {
out.writeCompressedInt(pkey);
out.writeUTF(encoding);
out.writeCompressedInt(postgres_version);
}
}