middleclass & extras: middleclass 3.0 is out!

Showcase your libraries, tools and other projects that help your fellow love users.
User avatar
Roland_Yonaba
Inner party member
Posts: 1563
Joined: Tue Jun 21, 2011 6:08 pm
Location: Ouagadougou (Burkina Faso)
Contact:

Re: middleclass & middleclass-extras: OOP for LUA

Post by Roland_Yonaba »

A very long Post, but a nice abstract on how OOP works.
I used to design my game objects using tables and functions when I started Learning Lua...Metatables and thus Pseudo-OOP in Lua was quite frightening to me... Then, while I as working on a RTS Game for PSP, I jumped into it...

These abstracts helped me a lot...
Wikipedia
OOPBasics
OOPFundamentals

And the official Lua how-to tutorial...
PIL - OOP
LuaWeaver
Party member
Posts: 183
Joined: Wed Mar 02, 2011 11:15 pm
Location: Ohio, USA

Re: middleclass & middleclass-extras: OOP for LUA

Post by LuaWeaver »

I didn't want to make a huge post similar to that. I understand that tables in tables are just classes and subclasses without properties. Or methods. But, I didn't say what was in those. WeaverOOP uses just tables right now, no metatables. (Don't understand those yet: kind of new to metatables. ROBLOX locked them...) My TTB game so far has a class called "enity" and 2 instances, "character" and "enemy". Those are copies of the orginal to be changed and worked with without messing the class. They have all the properties of the orginal. So, if I want 10, I could use h1 or h2 and so forth=ball:new() 10 times, and have 10 copies of that. Not effective yet, but the basics of OOP are found within that. Thanks for trying to help,

LuaWeaver.
"your actions cause me to infer your ego is the size of three houses" -finley
jmazouri
Prole
Posts: 2
Joined: Sun Jul 17, 2011 3:46 am

Re: middleclass & middleclass-extras: OOP for LUA

Post by jmazouri »

Is it possible to add a callback to an instance of an inherited class? For example:

Code: Select all

Man = class("Man")

function Man:initialize()
       print("Man initialized")
end

Boy = Man:subclass("Boy")

function Boy:initialize()
       print("Boy initialized")
end

jim = Boy:new()
jim:after("initialize", function() print("Jim also initialized") end)
I ask this because it doesn't seem to be working in my implementation of it.
User avatar
BlackBulletIV
Inner party member
Posts: 1261
Joined: Wed Dec 29, 2010 8:19 pm
Location: Queensland, Australia
Contact:

Re: middleclass & middleclass-extras: OOP for LUA

Post by BlackBulletIV »

Your best bet is to redefine initialize in your instance like this:

Code: Select all

function jim:initialize()
  Boy.initialize(self)
  print("Jim also initialized")
end
User avatar
TechnoCat
Inner party member
Posts: 1612
Joined: Thu Jul 30, 2009 12:31 am
Location: Milwaukee, WI
Contact:

Re: middleclass & middleclass-extras: OOP for LUA

Post by TechnoCat »

Middleclass-extras lets you do lots of things: https://github.com/kikito/middleclass-extras
Callbacks is a powerful mixin that allows you to add ‘hooks’ to any existing method. For example, you can specify on runtime that you want to call a method after initializing one object.

Invoker is a very small mixin that can be used to ‘send’ methods to instances. It’s main advantage is that it accepts both method names and lua functions on its parameters.
Not really sure how relevant these are, but they seem like they are what you are asking for.
jmazouri
Prole
Posts: 2
Joined: Sun Jul 17, 2011 3:46 am

Re: middleclass & middleclass-extras: OOP for LUA

Post by jmazouri »

BlackBulletIV wrote:Your best bet is to redefine initialize in your instance like this:

Code: Select all

function jim:initialize()
  Boy.initialize(self)
  print("Jim also initialized")
end
Thanks, I was hoping that the callback mixin had built in support for that, but I suppose not.

TechnoCat wrote:Middleclass-extras lets you do lots of things: https://github.com/kikito/middleclass-extras
Callbacks is a powerful mixin that allows you to add ‘hooks’ to any existing method. For example, you can specify on runtime that you want to call a method after initializing one object.

Invoker is a very small mixin that can be used to ‘send’ methods to instances. It’s main advantage is that it accepts both method names and lua functions on its parameters.
Not really sure how relevant these are, but they seem like they are what you are asking for.
Yes, I was actually attempting to use callbacks for that, however it doesn't seem to work on instances. BlackBullet's method above works fine, however.
User avatar
BlackBulletIV
Inner party member
Posts: 1261
Joined: Wed Dec 29, 2010 8:19 pm
Location: Queensland, Australia
Contact:

Re: middleclass & middleclass-extras: OOP for LUA

Post by BlackBulletIV »

jmazouri wrote:
BlackBulletIV wrote:Your best bet is to redefine initialize in your instance like this:

Code: Select all

function jim:initialize()
  Boy.initialize(self)
  print("Jim also initialized")
end
Thanks, I was hoping that the callback mixin had built in support for that, but I suppose not.
I'm not sure, I haven't used many of the middleclass-extras mixins. But anyway, this method is certainly a bit cheaper performance-wise when compared to using some sort of callback system.
Last edited by BlackBulletIV on Mon Jul 18, 2011 9:22 am, edited 2 times in total.
User avatar
kikito
Inner party member
Posts: 3153
Joined: Sat Oct 03, 2009 5:22 pm
Location: Madrid, Spain
Contact:

Re: middleclass & middleclass-extras: OOP for LUA

Post by kikito »

jmazouri wrote:Yes, I was actually attempting to use callbacks for that, however it doesn't seem to work on instances. BlackBullet's method above works fine, however.
The callbacks module is supposed to be used with instances; it's its main use. If you are having trouble with it, then you are either not using it correctly, or you are using other modules that modify the class significantly (for example, Callbacks and Stateful have issues when included simultaneously in a class).

Independently of that, using the Callbacks module makes every call to a method slower; BlackBulletIV's option is the preferred solution to your problem.
When I write def I mean function.
User avatar
kikito
Inner party member
Posts: 3153
Joined: Sat Oct 03, 2009 5:22 pm
Location: Madrid, Spain
Contact:

middleclass 2.0 is out

Post by kikito »

Hi everyone, I've released version 2.0 of middleclass.

As always, it is on github: https://github.com/kikito/middleclass

Version 2.0 is a complete re-write of the library. I've done my best to keep the changes as little as possible, but there are some backwards-incompatible changes. Sorry about that.

Here is the changelog:
  • Static methods are now separated from instance methods
  • class.superclass has now become class.super
  • It's now possible to do class.subclasses
  • middleclass is now a single file; init.lua has dissapeared
  • I've moved the tests back to the project, where they should have been. I've also added some performance tests.
  • license is changed from BSD to MIT. License included inside middleclass.lua
The most obvious change is the first one; now there is a way to declare class methods (called static methods). On middleclass 1.x there was no difference between them and instance methods:

Code: Select all

function MyClass:myClassMethod(...)
end

function MyClass:myInstanceMethod(...)
end
Now the recommended way of declaring class methods is using static:

Code: Select all

function MyClass.static:myClassMethod(...)
end

function MyClass:myInstanceMethod(...)
end
Apart from the declaration, the usage is similar. You do instance:myInstanceMethod() and Class:myClassMethod(), just like before.

The advantage of this change is that now you can have a class method and a instance method called the same way. In that case, Class.methodName will refer to the instance method, and Class.static.methodName will refer to the class method. If methodName refers to a class method only, you can refer to it as Class.methodName, too.

An additional advantage is that the "old" way of declaring class methods (without using static) is deprecated, but it should still work; it is recommended to update to the new one, but do so at your own pace.

I've also made middleclass a single file, so it is easier to include - this should get rid of those "could not find middleclass" errors that some of you are experiencing. Also, I've included the license inside middleclass.lua, so the legal aspects are easier to handle now.

Should I use middleclass 2.0 on my new projects?

You should, unless you plan to use middleclass-extras; I haven't updated it yet. I will make another announcement when it is done. It's possible that middleclass-extras gets divided into smaller projects.

I'm using middleclass 1.4 on my project. Should I update?

Middleclass 1.4 is very tested, and it works just fine. There is no reason to rush to update, especially if you need middleclass-extras. However, keep in mind that I will not support that version in the future; In the unlikely event that you run into a bug, I might just point you to the new version. I don't have the means to support multiple versions simultaneously, since I do this in my free time. But as I was saying, 1.4 is very stable, and you shouldn't have any problems with it.

I hope this covers it. Feel free to ask if you have any questions!
When I write def I mean function.
User avatar
TechnoCat
Inner party member
Posts: 1612
Joined: Thu Jul 30, 2009 12:31 am
Location: Milwaukee, WI
Contact:

Re: middleclass & extras: middleclass 2.0 is out!

Post by TechnoCat »

Oh man, I'm an avid user of middleclass and stateful. Don't know what I would do without stateful!? It has ended up being the center piece of all my game state management.
Post Reply

Who is online

Users browsing this forum: rabbitboots and 4 guests