1
0
mirror of https://github.com/tacigar/maidroid.git synced 2025-01-25 15:00:22 +01:00

[UPDATE] Update method APIs

This commit is contained in:
tacigar 2016-09-13 16:55:29 +09:00
parent d124511e0f
commit 806c3be15d
2 changed files with 14 additions and 14 deletions

View File

@ -34,9 +34,10 @@ end
-- maidroid.maidroid represents a table that contains common methods -- maidroid.maidroid represents a table that contains common methods
-- for maidroid object. -- for maidroid object.
-- this table must be a metatable of maidroid self tables. -- this table must be contains by a metatable.__index of maidroid self tables.
-- minetest.register_entity set initial properties as metatable, so
-- thie table's methods will be put there.
maidroid.maidroid = {} maidroid.maidroid = {}
maidroid.maidroid.__index = maidroid
-- maidroid.maidroid.get_inventory returns a inventory of a maidroid. -- maidroid.maidroid.get_inventory returns a inventory of a maidroid.
function maidroid.maidroid.get_inventory(self) function maidroid.maidroid.get_inventory(self)
@ -79,7 +80,6 @@ function maidroid.register_maidroid(product_name, def)
-- create_inventory creates a new inventory, and returns it. -- create_inventory creates a new inventory, and returns it.
function create_inventory(self) function create_inventory(self)
self.inventory_name = self.product_name .. tostring(self.manufacturing_number) self.inventory_name = self.product_name .. tostring(self.manufacturing_number)
local inventory = minetest.create_detached_inventory(self.inventory_name, { local inventory = minetest.create_detached_inventory(self.inventory_name, {
on_put = function(inv, listname, index, stack, player) on_put = function(inv, listname, index, stack, player)
if listname == "core" then if listname == "core" then
@ -126,12 +126,7 @@ function maidroid.register_maidroid(product_name, def)
-- on_activate is a callback function that is called when the object is created or recreated. -- on_activate is a callback function that is called when the object is created or recreated.
function on_activate(self, staticdata) function on_activate(self, staticdata)
-- first, set maidroid metatable to self table. -- parse the staticdata, and compose a inventory.
if getmetatable(self) == nil then
setmetatable(self, maidroid.maidroid)
end
-- second, parse the staticdata, and compose a inventory.
if staticdata == "" then if staticdata == "" then
self.product_name = product_name self.product_name = product_name
self.manufacturing_number = 0 self.manufacturing_number = 0
@ -166,7 +161,7 @@ function maidroid.register_maidroid(product_name, def)
-- get_staticdata is a callback function that is called when the object is destroyed. -- get_staticdata is a callback function that is called when the object is destroyed.
function get_staticdata(self) function get_staticdata(self)
local inventory = maidroid.get_inventory(self) local inventory = self:get_inventory()
local data = { local data = {
["product_name"] = self.product_name, ["product_name"] = self.product_name,
["manufacturing_number"] = self.manufacturing_number, ["manufacturing_number"] = self.manufacturing_number,
@ -247,10 +242,15 @@ function maidroid.register_maidroid(product_name, def)
on_rightclick = on_rightclick, on_rightclick = on_rightclick,
on_punch = on_punch, on_punch = on_punch,
get_staticdata = get_staticdata, get_staticdata = get_staticdata,
-- extra methods.
get_inventory = maidroid.maidroid.get_inventory,
get_core = maidroid.maidroid.get_core,
get_core_name = maidroid.maidroid.get_core_name,
}) })
minetest.register_craftitem(product_name .. "_spawner", { minetest.register_craftitem(product_name .. "_spawner", {
description = " Spawner", description = product_name .. " spawner",
inventory_image = def.inventory_image, inventory_image = def.inventory_image,
stack_max = 1, stack_max = 1,
on_use = function(item_stack, user, pointed_thing) on_use = function(item_stack, user, pointed_thing)

View File

@ -7,19 +7,19 @@ maidroid.register_maidroid("maidroid:maidroid_mk1", {
hp_max = 10, hp_max = 10,
weight = 20, weight = 20,
mesh = "maidroid.b3d", mesh = "maidroid.b3d",
textures = "maidroid_mk1.png", textures = {"maidroid_mk1.png"},
}) })
maidroid.register_maidroid("maidroid:maidroid_mk2", { maidroid.register_maidroid("maidroid:maidroid_mk2", {
hp_max = 10, hp_max = 10,
weight = 20, weight = 20,
mesh = "maidroid.b3d", mesh = "maidroid.b3d",
textures = "maidroid_mk2.png", textures = {"maidroid_mk2.png"},
}) })
maidroid.register_maidroid("maidroid:maidroid_mk3", { maidroid.register_maidroid("maidroid:maidroid_mk3", {
hp_max = 10, hp_max = 10,
weight = 20, weight = 20,
mesh = "maidroid.b3d", mesh = "maidroid.b3d",
textures = "maidroid_mk3.png", textures = {"maidroid_mk3.png"},
}) })