From bd6d735170d5451a869ce72acfc53da588819080 Mon Sep 17 00:00:00 2001 From: zorman2000 Date: Thu, 9 Mar 2017 19:41:44 -0500 Subject: [PATCH] Actions: Change use sittable and use bed interface to use them as tasks. Schedules: Allow tasks to be added as well as actions. --- actions/actions.lua | 9 +++++++-- npc.lua | 40 ++++++++++++++++++++++++---------------- 2 files changed, 31 insertions(+), 18 deletions(-) diff --git a/actions/actions.lua b/actions/actions.lua index 5a5890b..c4a3a59 100644 --- a/actions/actions.lua +++ b/actions/actions.lua @@ -315,7 +315,10 @@ end -- with the fuel items the NPC will take whatever was cooked and whatever -- remained to cook. The function received the position of the furnace -- to use, and the item to cook in furnace. Item is an itemstring -function npc.actions.use_furnace(self, pos, item, freeze) +function npc.actions.use_furnace(self, args) + local pos = args.pos + local item = args.item + local freeze = args.freeze -- Define which items are usable as fuels. The NPC -- will mainly use this as fuels to avoid getting useful -- items (such as coal lumps) for burning @@ -487,7 +490,9 @@ end -- This function makes the NPC lay or stand up from a bed. The -- pos is the location of the bed, action can be lay or get up -function npc.actions.use_sittable(self, pos, action) +function npc.actions.use_sittable(self, args) + local pos = args.pos + local action = args.action local node = minetest.get_node(pos) if action == npc.actions.const.sittable.SIT then diff --git a/npc.lua b/npc.lua index 357f52d..a125cd0 100755 --- a/npc.lua +++ b/npc.lua @@ -659,7 +659,7 @@ local function npc_spawn(self, pos) } -- Temporary initialization of actions for testing - local nodes = npc.places.find_node_nearby(ent.object:getpos(), {"default:furnace"}, 20) + local nodes = npc.places.find_node_nearby(ent.object:getpos(), {"cottages:bench"}, 20) minetest.log("Found nodes: "..dump(nodes)) --local path = pathfinder.find_path(ent.object:getpos(), nodes[1], 20) @@ -667,17 +667,17 @@ local function npc_spawn(self, pos) --npc.add_action(ent, npc.actions.use_door, {self = ent, pos = nodes[1], action = npc.actions.door_action.OPEN}) --npc.add_action(ent, npc.actions.stand, {self = ent}) --npc.add_action(ent, npc.actions.stand, {self = ent}) - if nodes[1] ~= nil then - npc.add_task(ent, npc.actions.walk_to_pos, {end_pos=nodes[1], walkable={}}) - npc.actions.use_furnace(ent, nodes[1], "default:cobble 5", false) - --npc.add_action(ent, npc.actions.sit, {self = ent}) - -- npc.add_action(ent, npc.actions.lay, {self = ent}) - -- npc.add_action(ent, npc.actions.lay, {self = ent}) - -- npc.add_action(ent, npc.actions.lay, {self = ent}) - --npc.actions.use_sittable(ent, nodes[1], npc.actions.const.sittable.GET_UP) - --npc.add_action(ent, npc.actions.set_interval, {self=ent, interval=10, freeze=true}) - npc.add_action(ent, npc.actions.freeze, {freeze = false}) - end + -- if nodes[1] ~= nil then + -- npc.add_task(ent, npc.actions.walk_to_pos, {end_pos=nodes[1], walkable={}}) + -- npc.actions.use_furnace(ent, nodes[1], "default:cobble 5", false) + -- --npc.add_action(ent, npc.actions.sit, {self = ent}) + -- -- npc.add_action(ent, npc.actions.lay, {self = ent}) + -- -- npc.add_action(ent, npc.actions.lay, {self = ent}) + -- -- npc.add_action(ent, npc.actions.lay, {self = ent}) + -- --npc.actions.use_sittable(ent, nodes[1], npc.actions.const.sittable.GET_UP) + -- --npc.add_action(ent, npc.actions.set_interval, {self=ent, interval=10, freeze=true}) + -- npc.add_action(ent, npc.actions.freeze, {freeze = false}) + -- end -- Dedicated trade test ent.trader_data.trade_list.both = { @@ -707,7 +707,11 @@ local function npc_spawn(self, pos) -- Add a simple schedule for testing npc.create_schedule(ent, npc.schedule_types.generic, 0) -- Add schedule entries - local morning_actions = { [1] = {action = npc.actions.sit, args = {}} } + local morning_actions = { + [1] = {task = npc.actions.walk_to_pos, args = {end_pos=nodes[1], walkable={}} } , + [2] = {task = npc.actions.use_sittable, args = {pos=nodes[1], action=npc.actions.const.sittable.SIT} }, + [3] = {action = npc.actions.freeze, args = {freeze = true}} + } npc.add_schedule_entry(ent, npc.schedule_types.generic, 0, 7, nil, morning_actions) local afternoon_actions = { [1] = {action = npc.actions.stand, args = {}} } npc.add_schedule_entry(ent, npc.schedule_types.generic, 0, 9, nil, afternoon_actions) @@ -922,8 +926,6 @@ mobs:register_mob("advanced_npc:npc", { -- Check if schedule for this time exists minetest.log("Found default schedule") if schedule[time] ~= nil then - minetest.log("Found schedule for time "..dump(time)..": "..dump(schedule[time])) - minetest.log("Check: "..dump(schedule[time].check)) -- Check if schedule has a check function if schedule[time].check ~= nil then -- Execute check function and then add corresponding action @@ -933,7 +935,13 @@ mobs:register_mob("advanced_npc:npc", { minetest.log("Adding actions to action queue") -- Add to action queue all actions on schedule for i = 1, #schedule[time] do - npc.add_action(self, schedule[time][i].action, schedule[time][i].args) + if schedule[time][i].action == nil then + -- Add task + npc.add_task(self, schedule[time][i].task, schedule[time][i].args) + else + -- Add action + npc.add_action(self, schedule[time][i].action, schedule[time][i].args) + end end minetest.log("New action queue: "..dump(self.actions)) end