1
0
mirror of https://codeberg.org/tenplus1/mobs_animal.git synced 2025-01-06 16:20:17 +01:00

fix sheep dye bugs (nametag missing, double dye usage, dye'ing same colour sheep)

This commit is contained in:
tenplus1 2023-04-02 10:22:20 +01:00
parent 327bb4dd3d
commit 23839f9c16

View File

@ -32,13 +32,14 @@ for _, col in ipairs(all_colours) do
{name = "mobs:mutton_raw", chance = 1, min = 1, max = 2} {name = "mobs:mutton_raw", chance = 1, min = 1, max = 2}
} }
local function horn_texture_sel(horns, gotten) local function horn_texture_sel(horns, gotten, colr)
local base_text = "mobs_sheep_base.png" local base_text = "mobs_sheep_base.png"
local wool_shave_text = "mobs_sheep_wool.png" local wool_shave_text = "mobs_sheep_wool.png"
local shav_text = "mobs_sheep_shaved.png" local shav_text = "mobs_sheep_shaved.png"
local horn_text = "mobs_sheep_horns.png" local horn_text = "mobs_sheep_horns.png"
local col_text = "^[multiply:" .. col[3] local col_override = colr and colr or col[3]
local col_text = "^[multiply:" .. col_override
if gotten then if gotten then
wool_shave_text = shav_text wool_shave_text = shav_text
@ -296,28 +297,39 @@ for _, col in ipairs(all_colours) do
for _,c in pairs(all_colours) do for _,c in pairs(all_colours) do
if c[1] == colr then -- only dye if colour option available and sheep not same colour
if c[1] == colr
and self.name ~= "mobs_animal:sheep_" .. colr then
local pos = self.object:get_pos() local pos = self.object:get_pos()
-- save horns attribute -- add new coloured sheep
local horns = self.attribute_horns
self.object:remove()
local mob = minetest.add_entity(pos, "mobs_animal:sheep_" .. colr) local mob = minetest.add_entity(pos, "mobs_animal:sheep_" .. colr)
local ent = mob:get_luaentity() local ent = mob:get_luaentity()
ent.attribute_horns = horns if ent then
-- add old sheep attributes
ent.attribute_horns = self.attribute_horns
ent.nametag = self.nametag
ent.owner = name ent.owner = name
ent.tamed = true ent.tamed = true
ent.protected = self.protected ent.protected = self.protected
ent.fire_damage = self.fire_damage ent.fire_damage = self.fire_damage
local textures = horn_texture_sel(self.attribute_horns, false) -- set sheep texture with colour override since we're
-- calling function inside different sheep
local textures = horn_texture_sel(
self.attribute_horns, false, colr)
ent.object:set_properties({textures = {textures}})
ent.base_texture = {textures} ent.base_texture = {textures}
ent.object:set_properties({
textures = {textures},
nametag = self.nametag
})
-- remove old sheep
self.object:remove()
-- take item -- take item
if not mobs.is_creative(clicker:get_player_name()) then if not mobs.is_creative(clicker:get_player_name()) then
@ -329,6 +341,7 @@ for _, col in ipairs(all_colours) do
end end
end end
end end
end
return return
end end