Package org.apache.derby.client.net
Class CcsidManager
java.lang.Object
org.apache.derby.client.net.CcsidManager
- Direct Known Subclasses:
EbcdicCcsidManager
,Utf8CcsidManager
-
Field Summary
FieldsModifier and TypeFieldDescription(package private) byte
(package private) byte[]
(package private) byte[]
(package private) byte
(package private) static final int
-
Constructor Summary
ConstructorsConstructorDescriptionCcsidManager
(byte space, byte dot, byte[] numToCharRepresentation, byte[] numToSnaRequiredCrrtknChar) -
Method Summary
Modifier and TypeMethodDescriptionabstract byte[]
convertFromJavaString
(String sourceString, Agent agent) (package private) abstract String
convertToJavaString
(byte[] sourceBytes, int offset, int numToConvert) abstract boolean
encode
(CharBuffer src, ByteBuffer dest, Agent agent) Encode the contents of aCharBuffer
into aByteBuffer
.abstract void
Initialize this instance for encoding a new string.
-
Field Details
-
space_
byte space_ -
dot_
byte dot_ -
numToCharRepresentation_
byte[] numToCharRepresentation_ -
numToSnaRequiredCrrtknChar_
byte[] numToSnaRequiredCrrtknChar_ -
UTF8_CCSID
static final int UTF8_CCSID- See Also:
-
-
Constructor Details
-
CcsidManager
CcsidManager(byte space, byte dot, byte[] numToCharRepresentation, byte[] numToSnaRequiredCrrtknChar)
-
-
Method Details
-
convertFromJavaString
- Throws:
SqlException
-
convertToJavaString
-
startEncoding
public abstract void startEncoding()Initialize this instance for encoding a new string. This method resets any internal state that may be left after earlier calls toencode(java.nio.CharBuffer, java.nio.ByteBuffer, org.apache.derby.client.am.Agent)
on this instance. For example, it may reset the internaljava.nio.charset.CharsetEncoder
, if the implementation uses one to do the encoding. -
encode
Encode the contents of aCharBuffer
into aByteBuffer
. The method will returntrue
if all the characters were encoded and copied to the destination. If the receiving byte buffer is too small to hold the entire encoded representation of the character buffer, the method will returnfalse
. The caller should then allocate a larger byte buffer, copy the contents from the old byte buffer to the new one, and then call this method again to get the remaining characters encoded.- Parameters:
src
- buffer holding the characters to encodedest
- buffer receiving the encoded bytesagent
- where to report errors- Returns:
true
if all characters were encoded,false
if the destination buffer is full and there still are more characters to encode- Throws:
SqlException
- if the characters cannot be encoded using this CCSID manager's character encoding
-