summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKaarle Ritvanen <kaarle.ritvanen@datakunkku.fi>2013-05-08 22:57:51 +0300
committerKaarle Ritvanen <kaarle.ritvanen@datakunkku.fi>2013-05-08 23:07:00 +0300
commit161f76a3b9f6a3073b7dd397db6b26f431fc8734 (patch)
tree19641ec2d84337f620f8a1077b73a551e455c3ed
parent0d0a3bb94877049d6c79af5ae7c27f09f6483158 (diff)
downloadaconf-161f76a3b9f6a3073b7dd397db6b26f431fc8734.tar.bz2
aconf-161f76a3b9f6a3073b7dd397db6b26f431fc8734.tar.xz
optional automatic removal of empty collections
-rw-r--r--acf/model/init.lua2
-rw-r--r--acf/model/node.lua7
2 files changed, 6 insertions, 3 deletions
diff --git a/acf/model/init.lua b/acf/model/init.lua
index 895ed62..f325053 100644
--- a/acf/model/init.lua
+++ b/acf/model/init.lua
@@ -195,7 +195,7 @@ function Collection:init(params, itype)
assert(self.type)
self.itype = itype or node.Collection
- self.iparams = {required=self.required}
+ self.iparams = {required=self.required, destroy=self.destroy}
self.dtype = 'collection'
self.widget = self.dtype
diff --git a/acf/model/node.lua b/acf/model/node.lua
index afc3e0f..47a15c7 100644
--- a/acf/model/node.lua
+++ b/acf/model/node.lua
@@ -117,8 +117,11 @@ function Collection:init(context, params)
function mt.members() return mt.txn:get(mt.addr, 'table') or {} end
function mt.validate()
- if params.required and #mt.members() == 0 then
- raise(mt.path, 'Collection cannot be empty')
+ if #mt.members() > 0 then return end
+ if params.required then raise(mt.path, 'Collection cannot be empty') end
+ if params.destroy then
+ mt.txn:set(mt.addr)
+ validate(mt.parent)
end
end