Implement proper dog feeding

This commit is contained in:
Wuzzy 2017-07-05 21:08:20 +02:00
parent dc68f0eee8
commit 6672c1d761
3 changed files with 35 additions and 20 deletions

View File

@ -160,6 +160,11 @@ mobs_mc.follow = {
ocelot = { mobs_mc.items.fish_raw, mobs_mc.items.salmon_raw, mobs_mc.items.clownfish_raw, mobs_mc.items.pufferfish_raw,
mobs_mc.items.chicken_raw, -- Minetest Game extra
},
wolf = { mobs_mc.items.bone },
dog = { mobs_mc.items.rabbit_raw, mobs_mc.items.rabbit_cooked, mobs_mc.items.mutton_raw, mobs_mc.items.mutton_cooked, mobs_mc.items.beef_raw, mobs_mc.items.beef_cooked, mobs_mc.items.chicken_raw, mobs_mc.items.chicken_cooked, mobs_mc.items.rotten_flesh,
-- Mobs Redo items
"mobs:meat", "mobs:meat_raw" },
e
}
-- Contents for replace_what

View File

@ -24,6 +24,7 @@ local is_food = function(itemstring)
return true
end
end
return false
end
-- Ocelot

View File

@ -8,20 +8,15 @@ local default_walk_chance = 50
local pr = PseudoRandom(os.time()*10)
local is_flesh = function(itemstring)
-- Minecraft items
return (itemstring == mobs_mc.items.rabbit_raw or
itemstring == mobs_mc.items.rabbit_cooked or
itemstring == mobs_mc.items.mutton_raw or
itemstring == mobs_mc.items.mutton_cooked or
itemstring == mobs_mc.items.beef_raw or
itemstring == mobs_mc.items.beef_cooked or
itemstring == mobs_mc.items.chicken_raw or
itemstring == mobs_mc.items.chicken_cooked or
itemstring == mobs_mc.items.rotten_flesh or
-- Mobs Redo items
itemstring == "mobs:meat" or
itemstring == "mobs:meat_raw")
local is_food = function(itemstring)
for f=1, #mobs_mc.follow.dog do
if itemstring == mobs_mc.follow.dog[f] then
return true
elseif string.sub(itemstring, 1, 6) == "group:" and minetest.get_item_group(itemstring, string.sub(itemstring, 7, -1)) ~= 0 then
return true
end
end
return false
end
-- Wolf
@ -57,7 +52,7 @@ local wolf = {
water_damage = 0,
lava_damage = 4,
light_damage = 0,
follow = mobs_mc.items.bone,
follow = mobs_mc.follow.wolf,
on_rightclick = function(self, clicker)
-- Try to tame wolf (intentionally does NOT use mobs:feed_tame)
local tool = clicker:get_wielded_item()
@ -136,6 +131,7 @@ dog.order = "roam"
dog.owner_loyal = true
-- Automatically teleport dog to owner
dog.do_custom = mobs_mc.make_owner_teleport_function(12)
dog.follow = mobs_mc.follow.dog
dog.on_rightclick = function(self, clicker)
local item = clicker:get_wielded_item()
@ -143,15 +139,28 @@ dog.on_rightclick = function(self, clicker)
return
elseif item:get_name() ~= "" and mobs:capture_mob(self, clicker, 0, 2, 80, false, nil) then
return
elseif is_flesh(item:get_name()) then
-- Feed
local hp = self.object:get_hp()
if hp + 4 > self.hp_max then return end
elseif is_food(item:get_name()) then
-- Feed to increase health
local hp = self.health
local hp_add = 0
-- Use eatable group to determine health boost
local eatable = minetest.get_item_group(item, "eatable")
if eatable > 0 then
hp_add = eatable
elseif item:get_name() == mobs_mc.items.rotten_flesh then
hp_add = 4
else
hp_add = 4
end
local new_hp = hp + hp_add
if new_hp > self.hp_max then
new_hp = self.hp_max
end
if not minetest.settings:get_bool("creative_mode") then
item:take_item()
clicker:set_wielded_item(item)
end
self.object:set_hp(hp+4)
self.health = new_hp
return
elseif minetest.get_item_group(item:get_name(), "dye") == 1 then
-- Dye (if possible)