diff options
author | James Ahlborn <jtahlborn@yahoo.com> | 2006-08-03 12:59:39 +0000 |
---|---|---|
committer | James Ahlborn <jtahlborn@yahoo.com> | 2006-08-03 12:59:39 +0000 |
commit | b624ca971b748bfbc7c891ed8f154b4270790148 (patch) | |
tree | 46453ba94b4168e8a2ccebadff0707282920c979 | |
parent | eba7b7286ca8183c7b7091be1f437946e03367b9 (diff) | |
download | jackcess-b624ca971b748bfbc7c891ed8f154b4270790148.tar.gz jackcess-b624ca971b748bfbc7c891ed8f154b4270790148.zip |
add toCharSequence method
git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/trunk@82 f203690c-595d-4dc9-a70b-905162fa7fd2
-rw-r--r-- | src/java/com/healthmarketscience/jackcess/Column.java | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/src/java/com/healthmarketscience/jackcess/Column.java b/src/java/com/healthmarketscience/jackcess/Column.java index d121336..a15bdc1 100644 --- a/src/java/com/healthmarketscience/jackcess/Column.java +++ b/src/java/com/healthmarketscience/jackcess/Column.java @@ -553,7 +553,7 @@ public class Column implements Comparable<Column> { private void writeGUIDValue(ByteBuffer buffer, Object value) throws IOException { - Matcher m = GUID_PATTERN.matcher((CharSequence)value); + Matcher m = GUID_PATTERN.matcher(toCharSequence(value)); if(m.matches()) { ByteUtil.writeHexString(buffer, m.group(1)); ByteUtil.writeHexString(buffer, m.group(2)); @@ -635,7 +635,7 @@ public class Column implements Comparable<Column> { if (_type == DataType.OLE) { size += ((byte[]) obj).length; } else if(_type == DataType.MEMO) { - byte[] encodedData = encodeUncompressedText((CharSequence) obj).array(); + byte[] encodedData = encodeUncompressedText(toCharSequence(obj)).array(); size += encodedData.length; obj = encodedData; } else if(_type == DataType.TEXT) { @@ -663,8 +663,7 @@ public class Column implements Comparable<Column> { } else if (_type == DataType.BINARY) { buffer.put((byte[]) obj); } else if (_type == DataType.TEXT) { - CharSequence text = ((obj instanceof CharSequence) ? - (CharSequence)obj : obj.toString()); + CharSequence text = toCharSequence(obj); int maxChars = size / 2; if (text.length() > maxChars) { throw new IOException("Text is too big for column"); @@ -894,6 +893,20 @@ public class Column implements Comparable<Column> { } /** + * @return an appropriate CharSequence representation of the given object. + */ + private static CharSequence toCharSequence(Object value) + { + if(value == null) { + return null; + } else if(value instanceof CharSequence) { + return (CharSequence)value; + } else { + return value.toString(); + } + } + + /** * Swaps the bytes of the given numeric in place. */ private static void fixNumericByteOrder(byte[] bytes) |