Object-orientation for Lua
Go to file
2018-01-21 20:57:51 -06:00
performance fixed perf tests 2013-09-18 23:13:41 +02:00
rockspecs updates rockspec 2016-07-02 06:13:25 +02:00
spec simplifies isInstanceOf & isSubclassOf. Fixes #39 2016-07-02 06:00:03 +02:00
.travis.yml fixes luacheck errors 2016-01-02 09:57:00 +01:00
CHANGELOG.md bump version to 4.1.0 2016-07-02 06:08:20 +02:00
middleclass.lua adds string arg for isInstanceOf and isSubclassOf 2018-01-21 20:57:51 -06:00
MIT-LICENSE.txt changed from BSD to MIT license 2011-09-19 00:24:00 +02:00
README.md restores :allocate and adds more documentation 2015-12-31 00:47:37 +01:00
UPDATING.md Update UPDATING.md 2016-03-20 18:49:56 +01:00

middleclass

Build Status Coverage Status

A simple OOP library for Lua. It has inheritance, metamethods (operators), class variables and weak mixin support.

Quick Look

local class = require 'middleclass'

local Fruit = class('Fruit') -- 'Fruit' is the class' name

function Fruit:initialize(sweetness)
  self.sweetness = sweetness
end

Fruit.static.sweetness_threshold = 5 -- class variable (also admits methods)

function Fruit:isSweet()
  return self.sweetness > Fruit.sweetness_threshold
end

local Lemon = class('Lemon', Fruit) -- subclassing

function Lemon:initialize()
  Fruit.initialize(self, 1) -- invoking the superclass' initializer
end

local lemon = Lemon:new()

print(lemon:isSweet()) -- false

Documentation

See the github wiki page for examples & documentation.

You can read the CHANGELOG.md file to see what has changed on each version of this library.

If you need help updating to a new middleclass version, read UPDATING.md.

Installation

Just copy the middleclass.lua file wherever you want it (for example on a lib/ folder). Then write this in any Lua file where you want to use it:

local class = require 'middleclass'

Specs

This project uses busted for its specs. If you want to run the specs, you will have to install it first. Then just execute the following:

cd /folder/where/the/spec/folder/is
busted

Performance tests

Middleclass also comes with a small performance test suite. Just run the following command:

lua performance/run.lua

License

Middleclass is distributed under the MIT license.