Compare commits
3 Commits
commands_a
...
master
Author | SHA1 | Date | |
---|---|---|---|
|
97da2dc191 | ||
|
dfaa904ba8 | ||
|
166db4b5e5 |
@ -201,7 +201,7 @@ function npc.actions.freeze(self, args)
|
||||
local freeze_mobs_api = args.freeze
|
||||
local disable_rightclick = args.disable_rightclick
|
||||
if disable_rightclick ~= nil then
|
||||
npc.log("INFO", "Enabling interactions for NPC "..self.npc_name..": "..dump(not(disable_rightclick)))
|
||||
--npc.log("INFO", "Enabling interactions for NPC "..self.npc_name..": "..dump(not(disable_rightclick)))
|
||||
self.enable_rightclick_interaction = not(disable_rightclick)
|
||||
end
|
||||
-- minetest.log("Received: "..dump(freeze_mobs_api))
|
||||
@ -649,7 +649,7 @@ function npc.actions.use_openable(self, args)
|
||||
local node = minetest.get_node(pos)
|
||||
local state = npc.actions.get_openable_node_state(node, pos, dir)
|
||||
|
||||
local clicker = self.object
|
||||
local clicker = self.object.npc_name
|
||||
if action ~= state then
|
||||
minetest.registered_nodes[node.name].on_rightclick(pos, node, clicker, nil, nil)
|
||||
end
|
||||
@ -751,7 +751,7 @@ end
|
||||
function npc.actions.use_furnace(self, args)
|
||||
local pos = get_pos_argument(self, args.pos)
|
||||
if pos == nil then
|
||||
npc.log("WARNING", "Got nil position in 'use_furnace' using args.pos: "..dump(args.pos))
|
||||
-- npc.log("WARNING", "Got nil position in 'use_furnace' using args.pos: "..dump(args.pos))
|
||||
return
|
||||
end
|
||||
|
||||
@ -787,16 +787,16 @@ function npc.actions.use_furnace(self, args)
|
||||
local fuel_time =
|
||||
minetest.get_craft_result({method="fuel", width=1, items={ItemStack(fuel_item.item_string)}}).time
|
||||
local total_fuel_time = fuel_time * npc.get_item_count(fuel_item.item_string)
|
||||
npc.log("DEBUG", "Fuel time: "..dump(fuel_time))
|
||||
--npc.log("DEBUG", "Fuel time: "..dump(fuel_time))
|
||||
|
||||
-- Get item to cook's cooking time
|
||||
local cook_result =
|
||||
minetest.get_craft_result({method="cooking", width=1, items={ItemStack(src_item.item_string)}})
|
||||
local total_cook_time = cook_result.time * npc.get_item_count(item)
|
||||
npc.log("DEBUG", "Cook: "..dump(cook_result))
|
||||
--npc.log("DEBUG", "Cook: "..dump(cook_result))
|
||||
|
||||
npc.log("DEBUG", "Total cook time: "..total_cook_time
|
||||
..", total fuel burn time: "..dump(total_fuel_time))
|
||||
-- npc.log("DEBUG", "Total cook time: "..total_cook_time
|
||||
-- ..", total fuel burn time: "..dump(total_fuel_time))
|
||||
|
||||
-- Check if there is enough fuel to cook all items
|
||||
if total_cook_time > total_fuel_time then
|
||||
@ -844,7 +844,7 @@ function npc.actions.use_furnace(self, args)
|
||||
npc.add_action(self, npc.actions.cmd.PUT_ITEM, args)
|
||||
|
||||
-- Now, set NPC to wait until furnace is done.
|
||||
npc.log("DEBUG", "Setting wait action for "..dump(total_cook_time))
|
||||
-- npc.log("DEBUG", "Setting wait action for "..dump(total_cook_time))
|
||||
npc.add_action(self, npc.actions.cmd.SET_INTERVAL, {interval=total_cook_time, freeze=freeze})
|
||||
|
||||
-- Reset timer
|
||||
@ -853,7 +853,7 @@ function npc.actions.use_furnace(self, args)
|
||||
-- If freeze is false, then we will have to find the way back to the furnace
|
||||
-- once cooking is done.
|
||||
if freeze == false then
|
||||
npc.log("DEBUG", "Adding walk to position to wandering: "..dump(pos))
|
||||
-- npc.log("DEBUG", "Adding walk to position to wandering: "..dump(pos))
|
||||
npc.add_task(self, npc.actions.cmd.WALK_TO_POS, {end_pos=pos, walkable={}})
|
||||
end
|
||||
|
||||
@ -870,7 +870,7 @@ function npc.actions.use_furnace(self, args)
|
||||
npc.log("DEBUG", "Taking item back: "..minetest.pos_to_string(pos))
|
||||
npc.add_action(self, npc.actions.cmd.TAKE_ITEM, args)
|
||||
|
||||
npc.log("DEBUG", "Inventory: "..dump(self.inventory))
|
||||
-- npc.log("DEBUG", "Inventory: "..dump(self.inventory))
|
||||
|
||||
-- Set furnace as unused if flag is enabled
|
||||
if enable_usage_marking then
|
||||
@ -890,7 +890,7 @@ end
|
||||
function npc.actions.use_bed(self, args)
|
||||
local pos = get_pos_argument(self, args.pos)
|
||||
if pos == nil then
|
||||
npc.log("WARNING", "Got nil position in 'use_bed' using args.pos: "..dump(args.pos))
|
||||
-- npc.log("WARNING", "Got nil position in 'use_bed' using args.pos: "..dump(args.pos))
|
||||
return
|
||||
end
|
||||
local action = args.action
|
||||
@ -973,7 +973,7 @@ end
|
||||
function npc.actions.use_sittable(self, args)
|
||||
local pos = get_pos_argument(self, args.pos)
|
||||
if pos == nil then
|
||||
npc.log("WARNING", "Got nil position in 'use_sittable' using args.pos: "..dump(args.pos))
|
||||
-- npc.log("WARNING", "Got nil position in 'use_sittable' using args.pos: "..dump(args.pos))
|
||||
return
|
||||
end
|
||||
local action = args.action
|
||||
@ -1068,7 +1068,7 @@ function npc.actions.walk_to_pos(self, args)
|
||||
local use_access_node = args.use_access_node or true
|
||||
local end_pos, node_pos = get_pos_argument(self, args.end_pos, use_access_node)
|
||||
if end_pos == nil then
|
||||
npc.log("WARNING", "Got nil position in 'walk_to_pos' using args.pos: "..dump(args.end_pos))
|
||||
-- npc.log("WARNING", "Got nil position in 'walk_to_pos' using args.pos: "..dump(args.end_pos))
|
||||
return
|
||||
end
|
||||
local enforce_move = args.enforce_move or true
|
||||
@ -1128,7 +1128,7 @@ function npc.actions.walk_to_pos(self, args)
|
||||
if use_access_node == true then
|
||||
dir = npc.actions.get_direction(end_pos, node_pos)
|
||||
end
|
||||
minetest.log("Dir: "..dump(dir))
|
||||
-- minetest.log("Dir: "..dump(dir))
|
||||
-- Change dir if using access_node
|
||||
npc.add_action(self, npc.actions.cmd.STAND, {dir = dir})
|
||||
break
|
||||
@ -1146,6 +1146,8 @@ function npc.actions.walk_to_pos(self, args)
|
||||
-- Open door
|
||||
npc.add_action(self, npc.actions.cmd.USE_OPENABLE, {pos=path[i+1].pos, dir=dir, action=npc.actions.const.doors.action.OPEN})
|
||||
|
||||
door_opened = true
|
||||
else
|
||||
door_opened = true
|
||||
end
|
||||
|
||||
@ -1170,9 +1172,10 @@ function npc.actions.walk_to_pos(self, args)
|
||||
-- Add extra walk step to ensure that one is standing at other side of openable node
|
||||
-- npc.add_action(self, npc.actions.cmd.WALK_STEP, {dir = dir, speed = speed, target_pos = path[i+2].pos})
|
||||
-- Stop to close the door
|
||||
npc.add_action(self, npc.actions.cmd.STAND, {dir=(dir + 2) % 4 })--, pos=pos_on_close})
|
||||
--npc.add_action(self, npc.actions.cmd.STAND, {dir=(dir + 2) % 4 })--, pos=pos_on_close})
|
||||
npc.add_action(self, npc.actions.cmd.STAND, {dir=dir })--, pos=pos_on_close})
|
||||
-- Close door
|
||||
npc.add_action(self, npc.actions.cmd.USE_OPENABLE, {pos=path[i+1].pos, action=npc.actions.const.doors.action.CLOSE})
|
||||
npc.add_action(self, npc.actions.cmd.USE_OPENABLE, {pos=path[i+1].pos, dir=dir, action=npc.actions.const.doors.action.CLOSE})
|
||||
|
||||
door_opened = false
|
||||
end
|
||||
@ -1192,4 +1195,4 @@ function npc.actions.walk_to_pos(self, args)
|
||||
self.object:moveto({x=end_pos.x, y=end_pos.y+1, z=end_pos.z})
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
@ -67,7 +67,7 @@ function pathfinder.get_decorated_path(path)
|
||||
type=pathfinder.is_good_node(node, {})})
|
||||
end
|
||||
|
||||
npc.log("DEBUG", "Detailed path: "..dump(path_detail))
|
||||
--npc.log("DEBUG", "Detailed path: "..dump(path_detail))
|
||||
return path_detail
|
||||
end
|
||||
|
||||
|
@ -179,8 +179,8 @@ function npc.places.add_owned_accessible_place(self, nodes, place_type, walkable
|
||||
-- Assign node to NPC
|
||||
npc.places.add_owned(self, place_type, place_type,
|
||||
nodes[i].node_pos, empty_nodes[1].pos)
|
||||
npc.log("DEBUG", "Added node at "..minetest.pos_to_string(nodes[i].node_pos)
|
||||
.." to NPC "..dump(self.npc_name))
|
||||
-- npc.log("DEBUG", "Added node at "..minetest.pos_to_string(nodes[i].node_pos)
|
||||
-- .." to NPC "..dump(self.npc_name))
|
||||
break
|
||||
end
|
||||
end
|
||||
@ -227,12 +227,12 @@ function npc.places.mark_place_used(pos, value)
|
||||
local meta = minetest.get_meta(pos)
|
||||
local used = meta:get_string("advanced_npc:used")
|
||||
if value == used then
|
||||
npc.log("WARNING", "Attempted to set 'used' property of node at "
|
||||
..minetest.pos_to_string(pos).." to the same value: '"..dump(value).."'")
|
||||
-- npc.log("WARNING", "Attempted to set 'used' property of node at "
|
||||
-- ..minetest.pos_to_string(pos).." to the same value: '"..dump(value).."'")
|
||||
return false
|
||||
else
|
||||
meta:set_string("advanced_npc:used", value)
|
||||
npc.log("DEBUG", "'Used' value at pos "..minetest.pos_to_string(pos)..": "..dump(meta:get_string("advanced_npc:used")))
|
||||
-- npc.log("DEBUG", "'Used' value at pos "..minetest.pos_to_string(pos)..": "..dump(meta:get_string("advanced_npc:used")))
|
||||
return true
|
||||
end
|
||||
end
|
||||
@ -259,9 +259,10 @@ function npc.places.find_unused_place(self, place_category, place_type, original
|
||||
return alternative_places[i]
|
||||
end
|
||||
end
|
||||
else
|
||||
result = original_place
|
||||
--else
|
||||
end
|
||||
result = original_place
|
||||
|
||||
return result
|
||||
end
|
||||
|
||||
|
@ -233,7 +233,7 @@ npc.relationships.register_disliked_item("default:cobble", "male", {
|
||||
hints = {"If I really hate something, that's cobblestone!"}
|
||||
})
|
||||
|
||||
npc.log("DEBUG", "Registered gift items: "..dump(npc.relationships.gift_items))
|
||||
npc.log("DEBUG", "Registered dialogues: "..dump(npc.dialogue.registered_dialogues))
|
||||
--npc.log("DEBUG", "Registered gift items: "..dump(npc.relationships.gift_items))
|
||||
--npc.log("DEBUG", "Registered dialogues: "..dump(npc.dialogue.registered_dialogues))
|
||||
npc.log("INFO", "Registered gift items count: "..dump(#npc.relationships.gift_items))
|
||||
npc.log("INFO", "Registered dialogues count: "..dump(#npc.dialogue.registered_dialogues))
|
||||
npc.log("INFO", "Registered dialogues count: "..dump(#npc.dialogue.registered_dialogues))
|
||||
|
@ -325,7 +325,7 @@ function npc.dialogue.select_random_dialogues_for_npc(self, phase)
|
||||
for i = 1, number_of_dialogues do
|
||||
local key_id = math.random(1, #keys)
|
||||
result.normal[i] = keys[key_id]
|
||||
npc.log("DEBUG", "Adding dialogue: "..dump(dialogues[keys[key_id]]))
|
||||
--npc.log("DEBUG", "Adding dialogue: "..dump(dialogues[keys[key_id]]))
|
||||
end
|
||||
|
||||
-- Add item hints.
|
||||
@ -352,7 +352,7 @@ function npc.dialogue.select_random_dialogues_for_npc(self, phase)
|
||||
end
|
||||
end
|
||||
|
||||
npc.log("DEBUG", "Dialogue results:"..dump(result))
|
||||
--npc.log("DEBUG", "Dialogue results:"..dump(result))
|
||||
return result
|
||||
end
|
||||
|
||||
@ -446,7 +446,7 @@ function npc.dialogue.start_dialogue(self, player, show_married_dialogue)
|
||||
dialogue = self.dialogues.normal[math.random(1, #self.dialogues.normal)]
|
||||
elseif chance >= 90 then
|
||||
-- Check if gift items hints are enabled
|
||||
minetest.log("Self gift data enable: "..dump(self.gift_data.enable_gift_items_hints))
|
||||
--minetest.log("Self gift data enable: "..dump(self.gift_data.enable_gift_items_hints))
|
||||
if self.gift_data.enable_gift_items_hints then
|
||||
-- Choose a random dialogue line from the favorite/disliked item hints
|
||||
dialogue = self.dialogues.hints[math.random(1, 4)]
|
||||
@ -669,7 +669,7 @@ minetest.register_on_player_receive_fields(function (player, formname, fields)
|
||||
elseif player_response.is_custom_trade_dialogue == true then
|
||||
-- Functions for a custom trade should be available from the same dialogue
|
||||
-- object as they are created on demand
|
||||
minetest.log("Player response: "..dump(player_response.options[i]))
|
||||
--minetest.log("Player response: "..dump(player_response.options[i]))
|
||||
player_response.options[i].action(player_response.npc, player)
|
||||
else
|
||||
-- Get dialogue from registered dialogues
|
||||
|
53
npc.lua
53
npc.lua
@ -556,9 +556,9 @@ function npc.initialize(entity, pos, is_lua_entity, npc_stats, occupation_name)
|
||||
-- Set initialized flag on
|
||||
ent.initialized = true
|
||||
--npc.log("WARNING", "Spawned entity: "..dump(ent))
|
||||
npc.log("INFO", "Successfully initialized NPC with name "..dump(ent.npc_name)
|
||||
..", sex: "..ent.sex..", is child: "..dump(ent.is_child)
|
||||
..", texture: "..dump(ent.textures))
|
||||
-- npc.log("INFO", "Successfully initialized NPC with name "..dump(ent.npc_name)
|
||||
-- ..", sex: "..ent.sex..", is child: "..dump(ent.is_child)
|
||||
-- ..", texture: "..dump(ent.textures))
|
||||
-- Refreshes entity
|
||||
ent.object:set_properties(ent)
|
||||
end
|
||||
@ -745,10 +745,10 @@ end
|
||||
-- This function removes the first action in the action queue
|
||||
-- and then executes it
|
||||
function npc.execute_action(self)
|
||||
npc.log("DEBUG_ACTION", "Current actions queue: "..dump(self.actions.queue))
|
||||
--npc.log("DEBUG_ACTION", "Current actions queue: "..dump(self.actions.queue))
|
||||
-- Check if an action was interrupted
|
||||
if self.actions.current_action_state == npc.action_state.interrupted then
|
||||
npc.log("DEBUG_ACTION", "Re-inserting interrupted action for NPC: '"..dump(self.npc_name).."': "..dump(self.actions.state_before_lock.interrupted_action))
|
||||
--npc.log("DEBUG_ACTION", "Re-inserting interrupted action for NPC: '"..dump(self.npc_name).."': "..dump(self.actions.state_before_lock.interrupted_action))
|
||||
-- Insert into queue the interrupted action
|
||||
table.insert(self.actions.queue, 1, self.actions.state_before_lock.interrupted_action)
|
||||
-- Clear the action
|
||||
@ -780,7 +780,7 @@ function npc.execute_action(self)
|
||||
-- If the entry is a task, then push all this new operations in
|
||||
-- stack fashion
|
||||
if action_obj.is_task == true then
|
||||
npc.log("DEBUG_ACTION", "Executing task for NPC '"..dump(self.npc_name).."': "..dump(action_obj))
|
||||
--npc.log("DEBUG_ACTION", "Executing task for NPC '"..dump(self.npc_name).."': "..dump(action_obj))
|
||||
-- Backup current queue
|
||||
local backup_queue = self.actions.queue
|
||||
-- Remove this "task" action from queue
|
||||
@ -796,7 +796,7 @@ function npc.execute_action(self)
|
||||
table.insert(self.actions.queue, backup_queue[i])
|
||||
end
|
||||
else
|
||||
npc.log("DEBUG_ACTION", "Executing action for NPC '"..dump(self.npc_name).."': "..dump(action_obj))
|
||||
--npc.log("DEBUG_ACTION", "Executing action for NPC '"..dump(self.npc_name).."': "..dump(action_obj))
|
||||
-- Store the action that is being executed
|
||||
self.actions.state_before_lock.interrupted_action = action_obj
|
||||
-- Store current position
|
||||
@ -854,7 +854,7 @@ function npc.lock_actions(self)
|
||||
-- Freeze mobs_redo API
|
||||
self.freeze = false
|
||||
|
||||
npc.log("DEBUG_ACTION", "Locking NPC "..dump(self.npc_id).." actions")
|
||||
--npc.log("DEBUG_ACTION", "Locking NPC "..dump(self.npc_id).." actions")
|
||||
end
|
||||
|
||||
function npc.unlock_actions(self)
|
||||
@ -883,7 +883,7 @@ function npc.unlock_actions(self)
|
||||
self.freeze = true
|
||||
end
|
||||
|
||||
npc.log("DEBUG_ACTION", "Unlocked NPC "..dump(self.npc_id).." actions")
|
||||
--npc.log("DEBUG_ACTION", "Unlocked NPC "..dump(self.npc_id).." actions")
|
||||
end
|
||||
|
||||
---------------------------------------------------------------------------------------
|
||||
@ -1044,8 +1044,8 @@ function npc.schedule_change_property(self, property, args)
|
||||
local itemlist_entry = itemlist[i]
|
||||
local current_itemstring = itemlist[i].name
|
||||
if itemlist_entry.random == true then
|
||||
current_itemstring = current_itemstring
|
||||
.." "..dump(math.random(itemlist_entry.min, itemlist_entry.max))
|
||||
-- current_itemstring = current_itemstring
|
||||
-- .." "..dump(math.random(itemlist_entry.min, itemlist_entry.max))
|
||||
else
|
||||
current_itemstring = current_itemstring.." "..tostring(itemlist_entry.count)
|
||||
end
|
||||
@ -1118,7 +1118,7 @@ end
|
||||
-- None-action: array of entries {action=<action_enum>, args={}}.
|
||||
-- Will be executed when no node is found.
|
||||
function npc.schedule_check(self)
|
||||
npc.log("DEBUG_SCHEDULE", "Prev Actions queue: "..dump(self.actions.queue))
|
||||
--npc.log("DEBUG_SCHEDULE", "Prev Actions queue: "..dump(self.actions.queue))
|
||||
local range = self.schedules.current_check_params.range
|
||||
local walkable_nodes = self.schedules.current_check_params.walkable_nodes
|
||||
local nodes = self.schedules.current_check_params.nodes
|
||||
@ -1129,7 +1129,7 @@ function npc.schedule_check(self)
|
||||
-- Search nodes
|
||||
local found_nodes = npc.places.find_node_nearby(start_pos, nodes, range)
|
||||
-- Check if any node was found
|
||||
npc.log("DEBUG_SCHEDULE", "Found nodes using radius: "..dump(found_nodes))
|
||||
--npc.log("DEBUG_SCHEDULE", "Found nodes using radius: "..dump(found_nodes))
|
||||
if found_nodes and #found_nodes > 0 then
|
||||
local node_pos
|
||||
local node
|
||||
@ -1155,7 +1155,7 @@ function npc.schedule_check(self)
|
||||
-- Set node as a place
|
||||
-- Note: Code below isn't *adding* a node, but overwriting the
|
||||
-- place with "schedule_target_pos" place type
|
||||
npc.log("DEBUG_SCHEDULE", "Found "..dump(node.name).." at pos: "..minetest.pos_to_string(node_pos))
|
||||
--npc.log("DEBUG_SCHEDULE", "Found "..dump(node.name).." at pos: "..minetest.pos_to_string(node_pos))
|
||||
npc.places.add_shared_accessible_place(
|
||||
self, {owner="", node_pos=node_pos}, npc.places.PLACE_TYPE.SCHEDULE.TARGET, true, walkable_nodes)
|
||||
-- Get actions related to node and enqueue them
|
||||
@ -1209,7 +1209,7 @@ function npc.schedule_check(self)
|
||||
-- Speed is default wandering speed. Target pos is node_pos
|
||||
-- Calculate dir if dir is random
|
||||
local dir = npc.actions.get_direction(start_pos, node_pos)
|
||||
minetest.log("actions: "..dump(actions[node.name][i]))
|
||||
--minetest.log("actions: "..dump(actions[node.name][i]))
|
||||
if actions[node.name][i].args.dir == "random" then
|
||||
dir = math.random(0,7)
|
||||
elseif type(actions[node.name][i].args.dir) == "number" then
|
||||
@ -1271,7 +1271,7 @@ function npc.schedule_check(self)
|
||||
< self.schedules.current_check_params.execution_times then
|
||||
npc.add_schedule_check(self)
|
||||
end
|
||||
npc.log("DEBUG_SCHEDULE", "Actions queue: "..dump(self.actions.queue))
|
||||
--npc.log("DEBUG_SCHEDULE", "Actions queue: "..dump(self.actions.queue))
|
||||
else
|
||||
-- No nodes found, enqueue none_actions
|
||||
for i = 1, #none_actions do
|
||||
@ -1289,7 +1289,7 @@ function npc.schedule_check(self)
|
||||
npc.add_schedule_check(self)
|
||||
end
|
||||
-- No nodes found
|
||||
npc.log("DEBUG_SCHEDULE", "Actions queue: "..dump(self.actions.queue))
|
||||
--npc.log("DEBUG_SCHEDULE", "Actions queue: "..dump(self.actions.queue))
|
||||
end
|
||||
end
|
||||
|
||||
@ -1311,7 +1311,8 @@ function npc.after_activate(self)
|
||||
if self.yaw_before_interaction then
|
||||
self.object:setyaw(self.yaw_before_interaction)
|
||||
end
|
||||
else
|
||||
else
|
||||
if not self.actions then self.actions = {} end
|
||||
-- Temporary code - adds the new state variables
|
||||
self.actions.move_state = {
|
||||
is_sitting = false,
|
||||
@ -1332,7 +1333,7 @@ function npc.rightclick_interaction(self, clicker)
|
||||
local item = clicker:get_wielded_item()
|
||||
local name = clicker:get_player_name()
|
||||
|
||||
npc.log("DEBUG", "Right-clicked NPC: "..dump(self))
|
||||
--npc.log("DEBUG", "Right-clicked NPC: "..dump(self))
|
||||
|
||||
-- Receive gift or start chat. If player has no item in hand
|
||||
-- then it is going to start chat directly
|
||||
@ -1388,7 +1389,7 @@ function npc.step(self, dtime)
|
||||
self.texture = {self.selected_texture}
|
||||
self.base_texture = {self.selected_texture}
|
||||
self.object:set_properties(self)
|
||||
npc.log("WARNING", "Corrected textures on NPC child "..dump(self.npc_name))
|
||||
--npc.log("WARNING", "Corrected textures on NPC child "..dump(self.npc_name))
|
||||
-- Set interval to large interval so this code isn't called frequently
|
||||
npc.texture_check.interval = 60
|
||||
end
|
||||
@ -1475,7 +1476,7 @@ function npc.step(self, dtime)
|
||||
time = (time) - (time % 1)
|
||||
-- Check if there is a schedule entry for this time
|
||||
-- Note: Currently only one schedule is supported, for day 0
|
||||
npc.log("DEBUG_SCHEDULE", "Time: "..dump(time))
|
||||
--npc.log("DEBUG_SCHEDULE", "Time: "..dump(time))
|
||||
local schedule = self.schedules.generic[0]
|
||||
if schedule ~= nil then
|
||||
-- Check if schedule for this time exists
|
||||
@ -1486,7 +1487,7 @@ function npc.step(self, dtime)
|
||||
-- Check if schedule has a check function
|
||||
if schedule[time][i].check then
|
||||
-- Add parameters for check function and run for first time
|
||||
npc.log("DEBUG", "NPC "..dump(self.npc_id).." is starting check on "..minetest.pos_to_string(self.object:getpos()))
|
||||
--npc.log("DEBUG", "NPC "..dump(self.npc_id).." is starting check on "..minetest.pos_to_string(self.object:getpos()))
|
||||
local check_params = schedule[time][i]
|
||||
-- Calculates how many times check will be executed
|
||||
local execution_times = check_params.count
|
||||
@ -1508,8 +1509,8 @@ function npc.step(self, dtime)
|
||||
-- Enqueue the schedule check
|
||||
npc.add_schedule_check(self)
|
||||
else
|
||||
npc.log("DEBUG_SCHEDULE", "Executing schedule entry for NPC "..dump(self.npc_id)..": "
|
||||
..dump(schedule[time][i]))
|
||||
--npc.log("DEBUG_SCHEDULE", "Executing schedule entry for NPC "..dump(self.npc_id)..": "
|
||||
--..dump(schedule[time][i]))
|
||||
-- Run usual schedule entry
|
||||
-- Check chance
|
||||
local execution_chance = math.random(1, 100)
|
||||
@ -1544,13 +1545,13 @@ function npc.step(self, dtime)
|
||||
end
|
||||
else
|
||||
-- TODO: Change to debug
|
||||
npc.log("DEBUG", "Skipping schedule entry for time "..dump(time)..": "..dump(schedule[time][i]))
|
||||
--npc.log("DEBUG", "Skipping schedule entry for time "..dump(time)..": "..dump(schedule[time][i]))
|
||||
end
|
||||
end
|
||||
end
|
||||
-- Clear execution queue
|
||||
self.schedules.temp_executed_queue = {}
|
||||
npc.log("DEBUG", "New action queue: "..dump(self.actions.queue))
|
||||
--npc.log("DEBUG", "New action queue: "..dump(self.actions.queue))
|
||||
end
|
||||
end
|
||||
else
|
||||
|
@ -260,7 +260,7 @@ function npc.occupations.register_occupation(name, def)
|
||||
-- Add to the dialogue tags the "occupation name"
|
||||
table.insert(dialogue.tags, name)
|
||||
-- Register dialogue
|
||||
npc.log("INFO", "Registering dialogue for occupation "..dump(name)..": "..dump(dialogue))
|
||||
--npc.log("INFO", "Registering dialogue for occupation "..dump(name)..": "..dump(dialogue))
|
||||
local key = npc.dialogue.register_dialogue(dialogue)
|
||||
-- Add key to set of dialogue keys
|
||||
table.insert(dialogue_keys, key)
|
||||
@ -287,7 +287,7 @@ function npc.occupations.register_occupation(name, def)
|
||||
-- Save the definition
|
||||
npc.occupations.registered_occupations[name] = def
|
||||
|
||||
npc.log("INFO", "Successfully registered occupation with name: "..dump(name))
|
||||
--npc.log("INFO", "Successfully registered occupation with name: "..dump(name))
|
||||
end
|
||||
|
||||
-- This function scans all registered occupations and filter them by
|
||||
@ -345,11 +345,11 @@ function npc.occupations.initialize_occupation_values(self, occupation_name)
|
||||
local def = npc.occupations.registered_occupations[occupation_name]
|
||||
|
||||
if not def then
|
||||
npc.log("WARNING", "No definition found for occupation name: "..dump(occupation_name))
|
||||
--npc.log("WARNING", "No definition found for occupation name: "..dump(occupation_name))
|
||||
return
|
||||
end
|
||||
|
||||
npc.log("INFO", "Overriding NPC values using occupation '"..dump(occupation_name).."' values")
|
||||
--npc.log("INFO", "Overriding NPC values using occupation '"..dump(occupation_name).."' values")
|
||||
|
||||
-- Initialize textures, else it will leave the current textures
|
||||
if def.textures and table.getn(def.textures) > 0 then
|
||||
@ -439,7 +439,7 @@ function npc.occupations.initialize_occupation_values(self, occupation_name)
|
||||
end
|
||||
|
||||
-- Initialize properties
|
||||
minetest.log("def.properties: "..dump(def.properties))
|
||||
--minetest.log("def.properties: "..dump(def.properties))
|
||||
if def.properties then
|
||||
-- Initialize trader status
|
||||
if def.properties.initial_trader_status then
|
||||
|
@ -209,7 +209,7 @@ function npc.relationships.get_dialogues_for_gift_item(item_name, dialogue_type,
|
||||
if phase ~= nil then
|
||||
tags[5] = phase
|
||||
end
|
||||
npc.log("DEBUG","Searching with tags: "..dump(tags))
|
||||
--npc.log("DEBUG","Searching with tags: "..dump(tags))
|
||||
|
||||
return npc.dialogue.search_dialogue_by_tags(tags, true)
|
||||
end
|
||||
@ -237,7 +237,7 @@ function npc.relationships.get_response_for_disliked_item(item_name, sex)
|
||||
end
|
||||
|
||||
for i = 1, #items do
|
||||
minetest.log(dump(items[i]))
|
||||
--minetest.log(dump(items[i]))
|
||||
if items[i].item == item_name then
|
||||
--minetest.log("Returning: "..dump(items[i].response))
|
||||
return items[i].response
|
||||
@ -641,7 +641,7 @@ function npc.relationships.receive_gift(self, clicker)
|
||||
clicker:set_wielded_item(item)
|
||||
end
|
||||
|
||||
npc.log("DEBUG", "NPC: "..dump(self))
|
||||
--npc.log("DEBUG", "NPC: "..dump(self))
|
||||
-- Reset gift timer
|
||||
reset_gift_timer(self, clicker_name)
|
||||
return true
|
||||
|
44
spawner.lua
44
spawner.lua
@ -212,8 +212,8 @@ function npc.spawner.determine_npc_occupation(building_type, workplace_nodes, np
|
||||
building_type,
|
||||
surrounding_buildings_map
|
||||
)
|
||||
npc.log("DEBUG", "Found occupations: "..dump(occupation_names).."\nfor local building type: "
|
||||
..dump(building_type).."\nAnd surrounding building types: "..dump(surrounding_buildings_map))
|
||||
--npc.log("DEBUG", "Found occupations: "..dump(occupation_names).."\nfor local building type: "
|
||||
--..dump(building_type).."\nAnd surrounding building types: "..dump(surrounding_buildings_map))
|
||||
|
||||
-- Insert default occupation into result
|
||||
table.insert(result, {name=npc.occupations.basic_name, node={node_pos={}}})
|
||||
@ -272,10 +272,10 @@ function npc.spawner.determine_npc_occupation(building_type, workplace_nodes, np
|
||||
-- used by another NPC, then, use it
|
||||
local meta = minetest.get_meta(workplace_nodes[j].node_pos)
|
||||
local worker_data = minetest.deserialize(meta:get_string("work_data") or "")
|
||||
npc.log("DEBUG", "Found worker data: "..dump(worker_data))
|
||||
--npc.log("DEBUG", "Found worker data: "..dump(worker_data))
|
||||
-- If no worker data is found, then create it
|
||||
if not worker_data then
|
||||
npc.log("INFO", "Found suitable occupation and workplace: "..dump(result))
|
||||
--npc.log("INFO", "Found suitable occupation and workplace: "..dump(result))
|
||||
table.insert(result, {name=occupation_names[i], node=workplace_nodes[j]})
|
||||
end
|
||||
end
|
||||
@ -381,7 +381,7 @@ function npc.spawner.spawn_npc_on_plotmarker(pos)
|
||||
else
|
||||
-- Start another timer to spawn more NPC
|
||||
local new_delay = math.random(npc.spawner.spawn_delay)
|
||||
npc.log("INFO", "Spawning one more NPC in "..dump(npc.spawner.spawn_delay).."s")
|
||||
--npc.log("INFO", "Spawning one more NPC in "..dump(npc.spawner.spawn_delay).."s")
|
||||
timer:start(new_delay)
|
||||
end
|
||||
end
|
||||
@ -404,7 +404,7 @@ function npc.spawner.spawn_npc(pos, area_info, occupation_name, occupation_workp
|
||||
-- this is a manually spawned NPC
|
||||
local can_spawn = false
|
||||
if npc_count and spawned_npc_count then
|
||||
npc.log("INFO", "Currently spawned "..dump(spawned_npc_count).." of "..dump(npc_count).." NPCs")
|
||||
--npc.log("INFO", "Currently spawned "..dump(spawned_npc_count).." of "..dump(npc_count).." NPCs")
|
||||
if spawned_npc_count < npc_count then
|
||||
can_spawn = true
|
||||
end
|
||||
@ -429,7 +429,7 @@ function npc.spawner.spawn_npc(pos, area_info, occupation_name, occupation_workp
|
||||
npc.initialize(ent, pos, nil, nil, occupation)
|
||||
end
|
||||
-- If node_data is present, assign nodes
|
||||
minetest.log("Node data: "..dump(node_data))
|
||||
--minetest.log("Node data: "..dump(node_data))
|
||||
if node_data then
|
||||
npc.spawner.assign_places(ent:get_luaentity(), entrance, node_data, pos)
|
||||
end
|
||||
@ -448,7 +448,7 @@ function npc.spawner.spawn_npc(pos, area_info, occupation_name, occupation_workp
|
||||
workplace = occupation_workplace_pos,
|
||||
born_day = minetest.get_day_count()
|
||||
}
|
||||
minetest.log("Area info: "..dump(area_info))
|
||||
--minetest.log("Area info: "..dump(area_info))
|
||||
table.insert(area_info.npcs, entry)
|
||||
-- Update and store stats
|
||||
-- Increase total of NPCs for specific sex
|
||||
@ -569,9 +569,9 @@ function npc.spawner.assign_places(self, entrance, node_data, pos)
|
||||
if #node_data.workplace_type > 0 then
|
||||
-- First, find the workplace_node that was marked
|
||||
for i = 1, #node_data.workplace_type do
|
||||
minetest.log("In assign places: workplace nodes: "..dump(node_data.workplace_type))
|
||||
minetest.log("Condition? "..dump(node_data.workplace_type[i].occupation
|
||||
and node_data.workplace_type[i].occupation == self.occupation_name))
|
||||
--minetest.log("In assign places: workplace nodes: "..dump(node_data.workplace_type))
|
||||
--minetest.log("Condition? "..dump(node_data.workplace_type[i].occupation
|
||||
-- and node_data.workplace_type[i].occupation == self.occupation_name))
|
||||
if node_data.workplace_type[i].occupation
|
||||
and node_data.workplace_type[i].occupation == self.occupation_name then
|
||||
-- Walkable nodes from occupation
|
||||
@ -592,7 +592,7 @@ function npc.spawner.assign_places(self, entrance, node_data, pos)
|
||||
end
|
||||
end
|
||||
|
||||
npc.log("DEBUG", "Places for NPC "..self.npc_name..": "..dump(self.places_map))
|
||||
--npc.log("DEBUG", "Places for NPC "..self.npc_name..": "..dump(self.places_map))
|
||||
|
||||
-- Make NPC go into their house
|
||||
-- If entrance is available let NPC
|
||||
@ -626,7 +626,7 @@ function npc.spawner.calculate_npc_spawning_on_plotmarker(pos)
|
||||
-- Check number of beds
|
||||
local beds_count = #node_data.bed_type--#spawner.filter_first_floor_nodes(node_data.bed_type, pos)
|
||||
|
||||
npc.log("DEBUG", "Found "..dump(beds_count).." beds in the building at "..minetest.pos_to_string(pos))
|
||||
--npc.log("DEBUG", "Found "..dump(beds_count).." beds in the building at "..minetest.pos_to_string(pos))
|
||||
local npc_count = 0
|
||||
-- If number of beds is zero or beds/2 is less than one, spawn
|
||||
-- a single NPC.
|
||||
@ -637,7 +637,7 @@ function npc.spawner.calculate_npc_spawning_on_plotmarker(pos)
|
||||
-- Spawn (beds_count/2) NPCs
|
||||
npc_count = ((beds_count / 2) - ((beds_count / 2) % 1))
|
||||
end
|
||||
npc.log("INFO", "Will spawn "..dump(npc_count).." NPCs at "..minetest.pos_to_string(pos))
|
||||
--npc.log("INFO", "Will spawn "..dump(npc_count).." NPCs at "..minetest.pos_to_string(pos))
|
||||
-- Store amount of NPCs to spawn
|
||||
meta:set_int("npc_count", npc_count)
|
||||
-- Store amount of NPCs spawned
|
||||
@ -873,14 +873,14 @@ if minetest.get_modpath("mg_villages") ~= nil then
|
||||
--minetest.set_node({x=pos.x,y=pos.y,z=pos.z + (z_sign * z_size)}, {name = "wool:blue"})
|
||||
--minetest.get_meta({x=pos.x,y=pos.y,z=pos.z + (z_sign * z_size)}):set_string("infotext", minetest.get_meta(pos):get_string("infotext")..", Axis: z, Sign: "..dump(z_sign))
|
||||
|
||||
npc.log("DEBUG", "Start pos: "..minetest.pos_to_string(start_pos))
|
||||
npc.log("DEBUG", "Plot: "..dump(minetest.get_meta(start_pos):get_string("infotext")))
|
||||
--npc.log("DEBUG", "Start pos: "..minetest.pos_to_string(start_pos))
|
||||
--npc.log("DEBUG", "Plot: "..dump(minetest.get_meta(start_pos):get_string("infotext")))
|
||||
|
||||
npc.log("DEBUG", "Brotate: "..dump(brotate))
|
||||
npc.log("DEBUG", "X_sign: "..dump(x_sign))
|
||||
npc.log("DEBUG", "X_adj: "..dump(x_sign*x_size))
|
||||
npc.log("DEBUG", "Z_sign: "..dump(z_sign))
|
||||
npc.log("DEBUG", "Z_adj: "..dump(z_sign*z_size))
|
||||
--npc.log("DEBUG", "Brotate: "..dump(brotate))
|
||||
--npc.log("DEBUG", "X_sign: "..dump(x_sign))
|
||||
--npc.log("DEBUG", "X_adj: "..dump(x_sign*x_size))
|
||||
--npc.log("DEBUG", "Z_sign: "..dump(z_sign))
|
||||
--npc.log("DEBUG", "Z_adj: "..dump(z_sign*z_size))
|
||||
|
||||
local end_pos = {x=pos.x + (x_sign * x_size), y=pos.y + y_size, z=pos.z + (z_sign * z_size)}
|
||||
|
||||
@ -1099,7 +1099,7 @@ minetest.register_chatcommand("restore_area", {
|
||||
privs = {server = true},
|
||||
func = function(name, param)
|
||||
local args = npc.utils.split(param, " ")
|
||||
minetest.log("Params: "..dump(args))
|
||||
--minetest.log("Params: "..dump(args))
|
||||
if #args < 2 then
|
||||
minetest.chat_send_player("Please specify horizontal and vertical radius.")
|
||||
return
|
||||
|
@ -440,7 +440,7 @@ function npc.trade.get_dedicated_trade_offers(self)
|
||||
|
||||
local trade_list = self.trader_data.trade_list
|
||||
|
||||
npc.log("INFO", "NPC Inventory: "..dump(self.inventory))
|
||||
--npc.log("INFO", "NPC Inventory: "..dump(self.inventory))
|
||||
|
||||
for item_name, trade_info in pairs(trade_list) do
|
||||
-- Abort if more than 12 buy or sell offers are made
|
||||
@ -451,8 +451,8 @@ function npc.trade.get_dedicated_trade_offers(self)
|
||||
-- If it is, create a sell offer, else create a buy offer if possible.
|
||||
-- Also, avoid creating sell offers immediately if the item was just bought
|
||||
local item = npc.inventory_contains(self, item_name)
|
||||
minetest.log("Searched item: "..dump(item_name))
|
||||
minetest.log("Found: "..dump(item))
|
||||
--minetest.log("Searched item: "..dump(item_name))
|
||||
--minetest.log("Found: "..dump(item))
|
||||
if item ~= nil and trade_info.last_offer_type ~= npc.trade.OFFER_BUY then
|
||||
-- Check if item can be sold
|
||||
if trade_info.item_sold_count == nil
|
||||
@ -764,4 +764,4 @@ minetest.register_on_player_receive_fields(function (player, formname, fields)
|
||||
|
||||
end
|
||||
end
|
||||
end)
|
||||
end)
|
||||
|
Loading…
Reference in New Issue
Block a user