summaryrefslogtreecommitdiff
path: root/doc/nerv_class.md
diff options
context:
space:
mode:
authorTed Yin <[email protected]>2015-05-31 22:20:19 +0800
committerTed Yin <[email protected]>2015-05-31 22:20:19 +0800
commitae05d335f247ef2e83ad29ed9dca76260a9d7dff (patch)
tree51ce108a625ba1f72d28e589bac7b752e4eb2e05 /doc/nerv_class.md
parentab12a9583bdd39884fde9bc2444e6fd1bc5f518e (diff)
parent00c724864321be2b77891154d73fef18871182e1 (diff)
Merge pull request #10 from cloudygoose/master
add more contents to doc
Diffstat (limited to 'doc/nerv_class.md')
-rw-r--r--doc/nerv_class.md36
1 files changed, 36 insertions, 0 deletions
diff --git a/doc/nerv_class.md b/doc/nerv_class.md
new file mode 100644
index 0000000..99f63e7
--- /dev/null
+++ b/doc/nerv_class.md
@@ -0,0 +1,36 @@
+#The Nerv OOP#
+Part of the [Nerv](../README.md) toolkit.
+##Methods##
+* __metatable mt, metatable mpt = nerv.class(string tname, string parenttname)__
+This method is used to create a class by the name `tname`, which inherits `parenttname` in __Nerv__, then you create a new instance of this class by calling `obj=tname(...)`. The `tname.__init(...)` method(if defined) will be called in the constructing. The metatable of the class and its parent class will be returned.
+
+##Examples##
+* This example implements a simple `nerv.Counter` class which is inherited by `nerv.BetterCounter`.
+
+```
+do
+ nerv.class("nerv.Counter")
+ function nerv.Counter:__init(c)
+ if (c) then
+ self.c = c
+ else
+ self.c = 0
+ end
+ end
+end
+do
+ local mt, mpt = nerv.class("nerv.BetterCounter", "nerv.Counter")
+ function nerv.BetterCounter:__init(c, bc)
+ mpt.__init(self, c)
+ if (bc) then
+ self.bc = bc
+ else
+ self.bc = 0
+ end
+ end
+end
+c1 = nerv.Counter(1)
+print(c1.c)
+bc1 = nerv.BetterCounter(1, 1)
+print(bc1.c, bc1.bc)
+``` \ No newline at end of file