aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorDavid Walter Seikel2014-03-29 20:31:10 +1000
committerDavid Walter Seikel2014-03-29 20:31:10 +1000
commit07bbdba2da74c35bdc755e9c806fc9b06d51f8d8 (patch)
tree9dc664268288c3cf8e6dc1cd3d88effce184eca1
parentUpdate isValid() to deal with multiple Thing copies. (diff)
downloadSledjHamr-07bbdba2da74c35bdc755e9c806fc9b06d51f8d8.zip
SledjHamr-07bbdba2da74c35bdc755e9c806fc9b06d51f8d8.tar.gz
SledjHamr-07bbdba2da74c35bdc755e9c806fc9b06d51f8d8.tar.bz2
SledjHamr-07bbdba2da74c35bdc755e9c806fc9b06d51f8d8.tar.xz
Two alternate ideas for how to do Things.
-rw-r--r--ClientHamr/GuiLua/skang.lua87
1 files changed, 87 insertions, 0 deletions
diff --git a/ClientHamr/GuiLua/skang.lua b/ClientHamr/GuiLua/skang.lua
index 7ec7a64..3848093 100644
--- a/ClientHamr/GuiLua/skang.lua
+++ b/ClientHamr/GuiLua/skang.lua
@@ -257,6 +257,91 @@ Other Thing things are -
257--[[ TODO 257--[[ TODO
258 NOTE that skang.thing{} doesn't care what other names you pass in, they all get assigned to the thing. 258 NOTE that skang.thing{} doesn't care what other names you pass in, they all get assigned to the thing.
259 259
260Might be better to move skang.things.foo.value -> skang.values.module.foo
261but keep skang.things.foo.* for the Thing metadata.
262
263 test.pre
264 skang.things.test
265 skang.things.test.foo
266 skang.things.pre_test.foo -> skang.things.test.foo
267 skang.values.test.foo
268 skang.values.pre_test.foo
269
270 thing:isValid(module)
271 skang.things[module][key]:isValid(module)
272 skang.things.test.foo:isValid(test)
273 isValid(thing, module)
274 local value = values[module._NAME][self.names[1] ]
275
276 __index(module, key)
277 local thing = things[module._NAME][key]
278 local value = values[module._NAME][key]
279
280 __newindex(module, key, value)
281 local thing = things[module._NAME][key]
282 local oldValue = values[module._NAME][key]
283 ...
284 values[module._NAME][key] = value
285 ...
286 if not thing:isValid(module) then
287
288 module(...) or module{...}
289 __call(module, ...)
290
291 new = function (module, name)
292 local result = {}
293 setmetatable(result, {__index=module})
294 result._NAME = name
295 -- Loop through the Things in module.
296 for k, v in pairs(module.things) do
297 values[name][k] = values[module._NAME][k]
298 end
299
300On the other hand, might be better to now think of modules as a type?
301How much of OO are we willing to go with here? lol
302In Lua 5.1 and LuaJIT (?) metatables have no __type.
303What about userdata? We could hijack the type() function, and dig deeper if it's a userdata, or even if it's a Thing?
304
305
306 Things as a metatable field -
307 In this plan test.__something is short for metatable(test).__something.
308
309 C can set metatables to non table values. NOTE - values, not variables, so likely useless.
310
311 __index is used to look up things that don't exist in a table.
312 If table isn't actually a table, then use __index as well.
313 Actually, in that case, the environment is the "table".
314 Either way, if we get to __index, and it's a function, call the function.
315 If __index is not a function, then use __index as a table to start the lookup all over again.
316
317 __newindex is similar, it's used if table.key is nil, AND __newindex exists.
318 Otherwise, it just sets table.key.
319 Again, if __newindow is a table, then start the lookup all over again with that.
320
321 metatable(module).__thing
322 metatable(module).__stuff
323 metatable(module).__values
324
325 __thing is a table that is a Thing. It can be just a reference to a __thing elsewhere.
326 So module is free to be full of random variables that are anything.
327 If module.foo is a table, it can have it's own metatable(foo).__thing.
328 A table with __thing will use Thing as a proxy table via __index and __newindex, as it does now.
329
330 moduleBegin(test, ...) -> thing stuff goes into test.__thing
331 thing(test, 'foo', 'string' ...) -> thing stuff gous into thing; setmetatable(test, Thing); test.__stuff[foo] = thing; test.__values[foo] = default
332 thing(test, 'foo', 'table' ...) -> thing stuff goes into thing; setmetatable(foo, Thing); test.__stuff[foo] = thing; test.__values[foo] = {}; test.foo.__thing = thing
333 thing(test.foo, 'bar', ...) -> setmetatable(foo, Thing); foo.__stuff[bar] = thing; foo.__values[bar] = default
334 copy(test, 'c' -> c.__thing = test.__thing;, c.__stuff = test.__stuff; copy test.__values to c.__values; setmetatable(c, Thing)
335 test.foo -> test.__index(test, 'foo') -> test.__values[foo]; if that's nil, and test.__stuff[foo].__thing, then return an empty table instead?
336 test.foo = v -> test.__newindex(test, 'foo', v) -> test.__values[foo] = v; test.__stuff[foo]:isValid(test) -> local value = test.__values[ self.names[1] ]
337 Which should call self.__stuff[*]:isValid(self)
338 test.foo(a) -> test.__index(test, 'foo') -> test.__values[foo](a)
339 test.foo(a) -> test.__index(test, 'foo') -> test.__values[foo](a) (but it's not a function) -> test.__values[foo].__call(test.__values[foo], a)
340 Doesn't seem useful.
341 If test.foo is a table, with a __thing then that might be -> test.foo.__call(test.foo, a) -> could do something useful with this.
342 get(test.foo, 'help') -> return test.foo.__thing[help]
343 skang.thing{test, 'foo', required=true} -> test.__stuff[foo].required = true
344
260 345
261 Stuff - 346 Stuff -
262 test{'foo', key='blah', field0='something', field1=1, ...} -> skang.things.foo.key='blah' skang.things.foo.field='something' ... 347 test{'foo', key='blah', field0='something', field1=1, ...} -> skang.things.foo.key='blah' skang.things.foo.field='something' ...
@@ -511,6 +596,8 @@ end
511 596
512 skang.things.foo.value 597 skang.things.foo.value
513 skang.things.foo.pre_value 598 skang.things.foo.pre_value
599
600
514 ]] 601 ]]
515new = function (module, pre) 602new = function (module, pre)
516 local result = {} 603 local result = {}