diff options
author | Fernando Carmona Varo <ferkiwi@gmail.com> | 2015-10-21 20:41:56 +0200 |
---|---|---|
committer | Fernando Carmona Varo <ferkiwi@gmail.com> | 2015-10-21 20:41:56 +0200 |
commit | 6d338337d362af15f1038cf73ca154daa57b6b2b (patch) | |
tree | 2514e201b867632f460202875905837de0d0c7a4 /init.lua | |
parent | 3c9ac0cbc10d8d43cb5cc0ba7580d326aedddace (diff) |
Some cleanup and refactoring, it should be possible now to have multiple pacman games running simultaneously in different boards
Diffstat (limited to 'init.lua')
-rw-r--r-- | init.lua | 141 |
1 files changed, 12 insertions, 129 deletions
@@ -1,71 +1,14 @@ ---Save Table -function save_table() - local data = mypacman - local f, err = io.open(minetest.get_worldpath().."/mypacman_data", "w") - if err then return err end - f:write(minetest.serialize(data)) - f:close() -end ---Read Table -local function read_table() - local f, err = io.open(minetest.get_worldpath().."/mypacman_data", "r") - local data = minetest.deserialize(f:read("*a")) - f:close() - return data -end -local tmr = 0 ---Save Table every 10 seconds -minetest.register_globalstep(function(dtime) - tmr = tmr + dtime; - if tmr >= 10 then - tmr = 0 - save_table() - end -end) ---removes the ghosts from the game -local function remove_ghosts() - local pos = mypacman.start - for index, object in ipairs(minetest.get_objects_inside_radius({x=pos.x+13,y=pos.y+0.5,z=pos.z+15},20)) do - if object:is_player() ~= true then - object:remove() - end - end -end +-- This variable will be exported to other mods when they "depend" on this mod +mypacman = {} -local function spawn_ghosts() - local pos = mypacman.start - minetest.after(2, function() - minetest.add_entity({x=pos.x+13,y=pos.y+0.5,z=pos.z+19}, "mypacman:inky") - end) - minetest.after(12, function() - minetest.add_entity({x=pos.x+15,y=pos.y+0.5,z=pos.z+19}, "mypacman:pinky") - end) - minetest.after(22, function() - minetest.add_entity({x=pos.x+13,y=pos.y+0.5,z=pos.z+18}, "mypacman:blinky") - end) - minetest.after(32, function() - minetest.add_entity({x=pos.x+15,y=pos.y+0.5,z=pos.z+18}, "mypacman:clyde") - end) -end ---Check to see if table exists. Need to see if there is a better way -local f, err = io.open(minetest.get_worldpath().."/mypacman_data", "r") -if f == nil then -mypacman = {} -mypacman.start = {} -mypacman.pellet_count = 0 -mypacman.level = 1 -mypacman.spd = 2 -mypacman.board_num = 1 -else -mypacman = read_table().start -mypacman.start = read_table().start -mypacman.pellet_count = read_table().pellet_count -mypacman.level = read_table().level -mypacman.spd = read_table().spd -mypacman.board_num = read_table().board_num -end +dofile(minetest.get_modpath("mypacman").."/craftitems.lua") +dofile(minetest.get_modpath("mypacman").."/ghost.lua") +dofile(minetest.get_modpath("mypacman").."/blocks.lua") +dofile(minetest.get_modpath("mypacman").."/portals.lua") +dofile(minetest.get_modpath("mypacman").."/gamestate.lua") + --Yellow Pellets minetest.register_node("mypacman:pellet_1", { @@ -92,25 +35,7 @@ minetest.register_node("mypacman:pellet_1", { }) end, after_dig_node = function(pos, oldnode, oldmetadata, digger) - local name = digger:get_player_name() - local pos = mypacman.start - local schem = minetest.get_modpath("mypacman").."/schems/mypacman_3.mts" - mypacman.pellet_count = mypacman.pellet_count + 1 - if mypacman.pellet_count >= 1 then --252 - remove_ghosts() - minetest.chat_send_player(name, "You cleared the board!") - mypacman.pellet_count = 0 - mypacman.level = mypacman.level + 1 - mypacman.spd = mypacman.level + 1 - minetest.after(3.0, function() - local pos = mypacman.start - digger:setpos({x=pos.x+13,y=pos.y+0.5,z=pos.z+15.5}) - minetest.chat_send_player(name, "Starting Level "..mypacman.level) - minetest.sound_play("mypacman_beginning", {pos = pos,max_hear_distance = 40,gain = 10.0,}) - spawn_ghosts() - end) - minetest.place_schematic({x=pos.x,y=pos.y-1,z=pos.z-2},schem,0, "air", true) - end + mypacman.on_player_got_pellet(digger) end, }) @@ -165,49 +90,7 @@ minetest.register_node("mypacman:block2",{ paramtype2 = "facedir", light_source = 8, groups = {cracky = 1}, - - -on_rightclick = function(pos, node, player, itemstack, pointed_thing) -local schem = minetest.get_modpath("mypacman").."/schems/mypacman_3.mts" - minetest.place_schematic({x=pos.x,y=pos.y-1,z=pos.z-2},schem,0, "air", true) - mypacman.start = {x=pos.x, y=pos.y, z=pos.z} - mypacman.pellet_count = 0 - mypacman.level = 1 - mypacman.spd = 2 - remove_ghosts() - player:setpos({x=pos.x+14,y=pos.y+0.5,z=pos.z+16}) - mypacman.pellet_count = 0 - if mypacman.pellet_count >= 252 then - remove_ghosts() - end - minetest.sound_play("mypacman_beginning", {pos = pos,max_hear_distance = 40,gain = 10.0,}) - - minetest.after(2, function() - minetest.add_entity({x=pos.x+13,y=pos.y+0.5,z=pos.z+19}, "mypacman:inky") - end) - minetest.after(12, function() - minetest.add_entity({x=pos.x+15,y=pos.y+0.5,z=pos.z+19}, "mypacman:pinky") - end) - minetest.after(22, function() - minetest.add_entity({x=pos.x+13,y=pos.y+0.5,z=pos.z+18}, "mypacman:blinky") - end) - minetest.after(32, function() - minetest.add_entity({x=pos.x+15,y=pos.y+0.5,z=pos.z+18}, "mypacman:clyde") - end) -end, + on_rightclick = function(pos, node, player, itemstack, pointed_thing) + mypacman.game_start(pos, player) + end, }) - - -dofile(minetest.get_modpath("mypacman").."/craftitems.lua") -dofile(minetest.get_modpath("mypacman").."/ghost.lua") -dofile(minetest.get_modpath("mypacman").."/blocks.lua") -dofile(minetest.get_modpath("mypacman").."/portals.lua") - - - - - - - - - |