aboutsummaryrefslogtreecommitdiffstats
path: root/configgen
diff options
context:
space:
mode:
authorgjoranv <gv@yahoo-inc.com>2017-04-24 13:19:43 +0200
committergjoranv <gv@yahoo-inc.com>2017-05-09 14:51:15 +0200
commit380966af69d8d61ad7b9907282d2b648c4aba6db (patch)
tree120a7e3d9c989654e76aad76862ad71f81be5f3f /configgen
parente8eaefebe609ff18f99b4f4ff5edb151549cc1ba (diff)
Remove the default ctor for the generated config classes.
- Removed for all inner nodes that are not arrays, because InnerNodeVector might still need it.
Diffstat (limited to 'configgen')
-rw-r--r--configgen/src/main/scala/com/yahoo/config/codegen/ConfigGenerator.scala12
1 files changed, 9 insertions, 3 deletions
diff --git a/configgen/src/main/scala/com/yahoo/config/codegen/ConfigGenerator.scala b/configgen/src/main/scala/com/yahoo/config/codegen/ConfigGenerator.scala
index 716f2a60c33..533b9b2be23 100644
--- a/configgen/src/main/scala/com/yahoo/config/codegen/ConfigGenerator.scala
+++ b/configgen/src/main/scala/com/yahoo/config/codegen/ConfigGenerator.scala
@@ -180,8 +180,14 @@ object ConfigGenerator {
}
}
- // TODO: The default ctor can be removed if the config library uses builders to set values from payload, but ...
- // a default ctor is also needed for all innerArrays, because of InnerNodeVector.createNew()
+ // TODO: The default ctor is possibly still needed for innerArrays, because of InnerNodeVector.createNew()
+ def defaultConstructorIfArray = {
+ inner match {
+ case array: InnerCNode if inner.isArray => defaultConstructor
+ case scalar: InnerCNode => ""
+ }
+ }
+
def defaultConstructor = {
// TODO @link gives javadoc warnings, although the syntax seems to be valid
//def link = "{@link " + {nodeClass(inner)} + "#" + {nodeClass(inner)} + "(Builder)}"
@@ -202,7 +208,7 @@ object ConfigGenerator {
// TODO: merge these two constructors into one when the config library uses builders to set values from payload.
<code>
- |{defaultConstructor}
+ |{defaultConstructorIfArray}
|
|public {nodeClass(inner)}(Builder builder) {{
| this(builder, true);