aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--ClientHamr/GuiLua/skang.lua78
1 files changed, 54 insertions, 24 deletions
diff --git a/ClientHamr/GuiLua/skang.lua b/ClientHamr/GuiLua/skang.lua
index cd95f6a..7829055 100644
--- a/ClientHamr/GuiLua/skang.lua
+++ b/ClientHamr/GuiLua/skang.lua
@@ -254,31 +254,60 @@ Other Thing things are -
254]] 254]]
255 255
256 256
257--[[ TODO - Users might want to use two or more copies of this module. Keep that in mind. local a = require 'test', b = require 'test' might handle that though? 257--[[ TODO
258 Not unless skang.thing() knows about a and b, which it wont. 258 NOTE that skang.thing{} doesn't care what other names you pass in, they all get assigned to the thing.
259 Both a and b get the same table, not different copies of it. 259
260 Perhaps clone the table if it exists? Only clone the parameters, the rest can be linked back to the original. 260 Multiple copies of modules -
261 Then we have to deal with widgets linking to specific clones. 261 skang.new(test, 'pre')
262 Actually, not sure matrix-RAD solved that either. lol 262 local result = {}
263]] 263 setmetatable(result, test)
264 result.pre = 'pre'
265 -- loop through the Things in test
266 -- Will have to be a deeper copy if it's a Stuff.
267 skang.things['pre' .. '_' .. 'foo'] = skang.things.foo
268 skang.things['pre' .. '_' .. 'foo'].module = result
269 return result
270 end
264 271
265--[[ ideas 272 __index
266__newindex could catch a table being assigned - test.foo = {widget = '...', acl='...'} 273 local aKey = key
267 though that interferes with using tables for Stuff 274 if table.pre then aKey = table.pre .. '_' .. key end
268 test.someStuff = {key='blah', field0='something', field1=1, ...} 275 local thing = things[aKey]
269 test.someStuff.key 276 ...
270 happily Lua function call syntax supports test.foo{ ... } as a function call with a table argument. B-) 277 -- Then see if we can inherit it from Thing.
271 so maybe a use for __call after all, if the argument is that table 278 thing = Thing[key]
272 the table itself is passed to __call as the first argument, the rest of the arguments follow. 279
273 test.foo(1, 'two') -> __call(foo, 1, 'two') 280
274 foo has to be a table value though, with a metatable 281 __newindex
275 and the rest of skang is treating test.foo as a nil value so that __index and __newindex work. B-( 282 local aKey = key
276 test itself is a table, so all is not lost - 283 if table.pre then aKey = table.pre .. '_' .. key end
277 test{'foo', widget='...', acl='..'} -> __call(test, {'foo', ...}) -> skang.thing{'foo', ...} 284 local thing = things[aKey]
278 which would assign stuff to skang.things.foo.widget and skang.things.foo.acl 285 ...
279 as opposed to - 286
280 skang.things.foo = {widget='...', acl='...'} 287 skang.things.foo.value
281 which blanks out the other stuff. 288 skang.things.pre_foo.value
289
290 Stuff -
291 test{'foo', key='blah', field0='something', field1=1, ...} -> skang.things.foo.key='blah' skang.things.foo.field='something' ...
292 test{'foo', bar='...', baz='..'} -> __call(test, {'foo', ...}) -> skang.stuff{'foo', ...}
293 What we really want though is something like (if foo is defined as a table) -
294 -> skang.things.foo.value = {key='blah', field0='something', field1=1, ...}
295 or even (if foo is defined as a Stuff) -
296 -> skang.things.foo.value[blah] = {key = 'blah', field0='something', field1=1, ...}
297 Stuff is kinda rigid though, it's fields are fixed, not an everything goes Lua table. So it needs to be defined.
298 Reusing Thing semantics, with aliases.
299 Also, let's NOT mix skang.thing{} semantics with test{} semantics, make it a different function.
300 Then we can avoid conflicts with Thing.* names, and having to sort out where to put things.
301 skang.thing{'foo', stuff={{'key', 'The Stuff key', types='string', required=true},
302 {'field0,b' ... other Thing like stuff ... acl=''},
303 {'field1', 'field1 is a stufflet', 42, 'number'}} }
304 skang.thing('foo', stuff=someOtherThing)
305 skang.thing('foo', stuff=skang.new(someOtherThing, 'pre'))
306 skang.things.foo.things.field0
307 skang.things.foo.things.field1
308 test.foo[blah].field1
309
310 Widgets -
282 Use generic positional / named arguments for widget to, then we can do - 311 Use generic positional / named arguments for widget to, then we can do -
283 widget.button{'Cancel', 0.5, 0.5, 1, 0, look='cancel.edj', colour={1, 2, 3, 4}, action='...'} 312 widget.button{'Cancel', 0.5, 0.5, 1, 0, look='cancel.edj', colour={1, 2, 3, 4}, action='...'}
284 Using the Thing alias stuff, maybe we can do the "first stage tokenise" step after all - 313 Using the Thing alias stuff, maybe we can do the "first stage tokenise" step after all -
@@ -314,6 +343,7 @@ Thing.hasCrashed = 0 -- How many times this Thing has crashed.
314Thing.append = function (self,data) -- Append to the value of this Thing. 343Thing.append = function (self,data) -- Append to the value of this Thing.
315end 344end
316 345
346Thing.things = {} -- The sub things this Thing has, for modules and Stuff.
317Thing.errors = {} -- A list of errors returned by isValid(). 347Thing.errors = {} -- A list of errors returned by isValid().
318 348
319Thing.isValid = function (self) -- Check if this Thing is valid, return resulting error messages in errors. 349Thing.isValid = function (self) -- Check if this Thing is valid, return resulting error messages in errors.