diff options
-rw-r--r-- | src/changes/changes.xml | 5 | ||||
-rw-r--r-- | src/main/java/com/healthmarketscience/jackcess/ColumnBuilder.java | 74 |
2 files changed, 55 insertions, 24 deletions
diff --git a/src/changes/changes.xml b/src/changes/changes.xml index dcd9f90..1155d41 100644 --- a/src/changes/changes.xml +++ b/src/changes/changes.xml @@ -31,6 +31,11 @@ <action dev="jahlborn" type="add" system="SourceForge2Features" issue="29"> Implement support for indexes on BINARY fields. </action> + <action dev="jahlborn" type="fix" system="SourceForge2" issue="120"> + Remove useless warning for fixed length columns lengths with longer + length. Cleanup some other stuff related to copying existing columns + in ColumnBuilder. + </action> </release> <release version="2.0.8" date="2014-12-26"> <action dev="jahlborn" type="fix" system="SourceForge2" issue="113"> diff --git a/src/main/java/com/healthmarketscience/jackcess/ColumnBuilder.java b/src/main/java/com/healthmarketscience/jackcess/ColumnBuilder.java index 84092b4..041a3c8 100644 --- a/src/main/java/com/healthmarketscience/jackcess/ColumnBuilder.java +++ b/src/main/java/com/healthmarketscience/jackcess/ColumnBuilder.java @@ -27,6 +27,7 @@ King of Prussia, PA 19406 package com.healthmarketscience.jackcess; +import java.io.IOException; import java.sql.SQLException; import java.util.HashMap; import java.util.Map; @@ -273,10 +274,7 @@ public class ColumnBuilder { * Sets the column property with the given name and type to the given value. */ public ColumnBuilder putProperty(String name, DataType type, Object value) { - if(_props == null) { - _props = new HashMap<String,PropertyMap.Property>(); - } - _props.put(name, PropertyMapImpl.createProperty(name, type, value)); + setProperty(name, PropertyMapImpl.createProperty(name, type, value)); return this; } @@ -284,14 +282,27 @@ public class ColumnBuilder { return _props; } + private void setProperty(String name, PropertyMap.Property prop) { + if(prop == null) { + return; + } + if(_props == null) { + _props = new HashMap<String,PropertyMap.Property>(); + } + _props.put(name, prop); + } + private PropertyMap.Property getProperty(String name) { return ((_props != null) ? _props.get(name) : null); } /** - * Sets all attributes except name from the given Column template. + * Sets all attributes except name from the given Column template (including + * all column properties except GUID). */ - public ColumnBuilder setFromColumn(Column template) { + public ColumnBuilder setFromColumn(Column template) + throws IOException + { DataType type = template.getType(); setType(type); setLength(template.getLength()); @@ -300,8 +311,20 @@ public class ColumnBuilder { setScale(template.getScale()); setPrecision(template.getPrecision()); } + setCalculated(template.isCalculated()); setCompressedUnicode(template.isCompressedUnicode()); setHyperlink(template.isHyperlink()); + if(template instanceof ColumnImpl) { + setTextSortOrder(((ColumnImpl)template).getTextSortOrder()); + } + + PropertyMap colProps = template.getProperties(); + for(PropertyMap.Property colProp : colProps) { + // copy everything but guid + if(!PropertyMap.GUID_PROP.equalsIgnoreCase(colProp.getName())) { + setProperty(colProp.getName(), colProp); + } + } return this; } @@ -311,15 +334,21 @@ public class ColumnBuilder { */ public ColumnBuilder setFromColumn(ColumnBuilder template) { DataType type = template.getType(); - setType(type); - setLength(template.getLength()); - setAutoNumber(template.isAutoNumber()); + _type = type; + _length = template._length; + _autoNumber = template._autoNumber; if(type.getHasScalePrecision()) { - setScale(template.getScale()); - setPrecision(template.getPrecision()); + _scale = template._scale; + _precision = template._precision; + } + _calculated = template._calculated; + _compressedUnicode = template._compressedUnicode; + _hyperlink = template._hyperlink; + _sortOrder = template._sortOrder; + + if(template._props != null) { + _props = new HashMap<String,PropertyMap.Property>(template._props); } - setCompressedUnicode(template.isCompressedUnicode()); - setHyperlink(template.isHyperlink()); return this; } @@ -383,19 +412,15 @@ public class ColumnBuilder { } if(!getType().isVariableLength()) { - if(getLength() != getType().getFixedSize()) { - if(getLength() < getType().getFixedSize()) { - throw new IllegalArgumentException(withErrorContext( - "invalid fixed length size")); - } - LOG.warn(withErrorContext( - "Column length " + getLength() + - " longer than expected fixed size " + getType().getFixedSize())); + if(getLength() < getType().getFixedSize()) { + throw new IllegalArgumentException(withErrorContext( + "Invalid fixed length size " + getLength())); } } else if(!getType().isLongValue()) { if(!getType().isValidSize(getLength())) { throw new IllegalArgumentException(withErrorContext( - "var length out of range")); + "Var length must be from " + getType().getMinSize() + " to " + + getType().getMaxSize() + " inclusive, found " + getLength())); } } @@ -403,12 +428,13 @@ public class ColumnBuilder { if(!getType().isValidScale(getScale())) { throw new IllegalArgumentException(withErrorContext( "Scale must be from " + getType().getMinScale() + " to " + - getType().getMaxScale() + " inclusive")); + getType().getMaxScale() + " inclusive, found " + getScale())); } if(!getType().isValidPrecision(getPrecision())) { throw new IllegalArgumentException(withErrorContext( "Precision must be from " + getType().getMinPrecision() + " to " + - getType().getMaxPrecision() + " inclusive")); + getType().getMaxPrecision() + " inclusive, found " + + getPrecision())); } } |