summaryrefslogtreecommitdiffstats
path: root/src/com/iciql/TableInspector.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/iciql/TableInspector.java')
-rw-r--r--src/com/iciql/TableInspector.java18
1 files changed, 14 insertions, 4 deletions
diff --git a/src/com/iciql/TableInspector.java b/src/com/iciql/TableInspector.java
index 82b732a..a4b3b8f 100644
--- a/src/com/iciql/TableInspector.java
+++ b/src/com/iciql/TableInspector.java
@@ -180,7 +180,7 @@ public class TableInspector {
imports.add(IQTable.class.getCanonicalName());
imports.add(IQIndexes.class.getCanonicalName());
imports.add(IQIndex.class.getCanonicalName());
- imports.add(IQColumn.class.getCanonicalName());
+ imports.add(IQColumn.class.getCanonicalName());
imports.add(IndexType.class.getCanonicalName());
// fields
@@ -276,7 +276,8 @@ public class TableInspector {
AnnotationBuilder ap = new AnnotationBuilder();
if (indexes.size() == 1) {
// single index
- ap.append(generateIndexAnnotation(indexes.get(0)));
+ IndexInspector index = indexes.values().toArray(new IndexInspector[1])[0];
+ ap.append(generateIndexAnnotation(index));
ap.append(eol);
} else {
// multiple indexes
@@ -301,11 +302,11 @@ public class TableInspector {
ap.addParameter("name", index.name);
}
if (!index.type.equals(IndexType.STANDARD)) {
- ap.addParameter("type", IndexType.class.getSimpleName() + "." + index.type.name());
+ ap.addEnum("type", index.type);
}
if (ap.getCount() > 0) {
// multiple fields specified
- ap.addParameter("values", index.columns);
+ ap.addParameter("value", index.columns);
} else {
// default value
ap.addParameter(null, index.columns);
@@ -685,5 +686,14 @@ public class TableInspector {
}
}
}
+
+ void addEnum(String parameter, Enum value) {
+ appendExceptFirst(", ");
+ if (!StringUtils.isNullOrEmpty(parameter)) {
+ append(parameter);
+ append('=');
+ }
+ append(value.getClass().getSimpleName() + "." + value.name());
+ }
}
} \ No newline at end of file