mirror of
https://github.com/minetest/minetest.git
synced 2025-01-04 07:00:26 +01:00
Fix new texture properties not being sent for minetest.add_particle (#14760)
Co-authored-by: Lars Müller <appgurulars@gmx.de>
This commit is contained in:
parent
95e77bd7cb
commit
ea827e4c5d
@ -10657,7 +10657,10 @@ Used by `minetest.add_particle`.
|
|||||||
texture = "image.png",
|
texture = "image.png",
|
||||||
-- The texture of the particle
|
-- The texture of the particle
|
||||||
-- v5.6.0 and later: also supports the table format described in the
|
-- v5.6.0 and later: also supports the table format described in the
|
||||||
-- following section
|
-- following section, but due to a bug this did not take effect
|
||||||
|
-- (beyond the texture name).
|
||||||
|
-- v5.9.0 and later: fixes the bug.
|
||||||
|
-- Note: "texture.animation" is ignored here. Use "animation" below instead.
|
||||||
|
|
||||||
playername = "singleplayer",
|
playername = "singleplayer",
|
||||||
-- Optional, if specified spawns particle only on the player's client
|
-- Optional, if specified spawns particle only on the player's client
|
||||||
|
@ -197,7 +197,8 @@ enum class ParticleTextureFlags : u8 {
|
|||||||
* decltype everywhere */
|
* decltype everywhere */
|
||||||
using FlagT = std::underlying_type_t<ParticleTextureFlags>;
|
using FlagT = std::underlying_type_t<ParticleTextureFlags>;
|
||||||
|
|
||||||
void ServerParticleTexture::serialize(std::ostream &os, u16 protocol_ver, bool newPropertiesOnly) const
|
void ServerParticleTexture::serialize(std::ostream &os, u16 protocol_ver,
|
||||||
|
bool newPropertiesOnly, bool skipAnimation) const
|
||||||
{
|
{
|
||||||
/* newPropertiesOnly is used to de/serialize parameters of the legacy texture
|
/* newPropertiesOnly is used to de/serialize parameters of the legacy texture
|
||||||
* field, which are encoded separately from the texspec string */
|
* field, which are encoded separately from the texspec string */
|
||||||
@ -213,14 +214,19 @@ void ServerParticleTexture::serialize(std::ostream &os, u16 protocol_ver, bool n
|
|||||||
if (!newPropertiesOnly)
|
if (!newPropertiesOnly)
|
||||||
os << serializeString32(string);
|
os << serializeString32(string);
|
||||||
|
|
||||||
if (animated)
|
if (!skipAnimation && animated)
|
||||||
animation.serialize(os, protocol_ver);
|
animation.serialize(os, protocol_ver);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ServerParticleTexture::deSerialize(std::istream &is, u16 protocol_ver, bool newPropertiesOnly)
|
void ServerParticleTexture::deSerialize(std::istream &is, u16 protocol_ver,
|
||||||
|
bool newPropertiesOnly, bool skipAnimation)
|
||||||
{
|
{
|
||||||
FlagT flags = 0;
|
FlagT flags = 0;
|
||||||
deSerializeParameterValue(is, flags);
|
deSerializeParameterValue(is, flags);
|
||||||
|
// new texture properties were missing in ParticleParameters::serialize
|
||||||
|
// before Minetest 5.9.0
|
||||||
|
if (is.eof())
|
||||||
|
return;
|
||||||
|
|
||||||
animated = !!(flags & FlagT(ParticleTextureFlags::animated));
|
animated = !!(flags & FlagT(ParticleTextureFlags::animated));
|
||||||
blendmode = BlendMode((flags & FlagT(ParticleTextureFlags::blend)) >> 1);
|
blendmode = BlendMode((flags & FlagT(ParticleTextureFlags::blend)) >> 1);
|
||||||
@ -230,7 +236,7 @@ void ServerParticleTexture::deSerialize(std::istream &is, u16 protocol_ver, bool
|
|||||||
if (!newPropertiesOnly)
|
if (!newPropertiesOnly)
|
||||||
string = deSerializeString32(is);
|
string = deSerializeString32(is);
|
||||||
|
|
||||||
if (animated)
|
if (!skipAnimation && animated)
|
||||||
animation.deSerialize(is, protocol_ver);
|
animation.deSerialize(is, protocol_ver);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -254,6 +260,7 @@ void ParticleParameters::serialize(std::ostream &os, u16 protocol_ver) const
|
|||||||
writeV3F32(os, drag);
|
writeV3F32(os, drag);
|
||||||
jitter.serialize(os);
|
jitter.serialize(os);
|
||||||
bounce.serialize(os);
|
bounce.serialize(os);
|
||||||
|
texture.serialize(os, protocol_ver, true, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, T (reader)(std::istream& is)>
|
template <typename T, T (reader)(std::istream& is)>
|
||||||
@ -291,4 +298,5 @@ void ParticleParameters::deSerialize(std::istream &is, u16 protocol_ver)
|
|||||||
return;
|
return;
|
||||||
jitter.deSerialize(is);
|
jitter.deSerialize(is);
|
||||||
bounce.deSerialize(is);
|
bounce.deSerialize(is);
|
||||||
|
texture.deSerialize(is, protocol_ver, true, true);
|
||||||
}
|
}
|
||||||
|
@ -276,8 +276,10 @@ struct ParticleTexture
|
|||||||
struct ServerParticleTexture : public ParticleTexture
|
struct ServerParticleTexture : public ParticleTexture
|
||||||
{
|
{
|
||||||
std::string string;
|
std::string string;
|
||||||
void serialize(std::ostream &os, u16 protocol_ver, bool newPropertiesOnly = false) const;
|
void serialize(std::ostream &os, u16 protocol_ver, bool newPropertiesOnly = false,
|
||||||
void deSerialize(std::istream &is, u16 protocol_ver, bool newPropertiesOnly = false);
|
bool skipAnimation = false) const;
|
||||||
|
void deSerialize(std::istream &is, u16 protocol_ver, bool newPropertiesOnly = false,
|
||||||
|
bool skipAnimation = false);
|
||||||
};
|
};
|
||||||
|
|
||||||
struct CommonParticleParams
|
struct CommonParticleParams
|
||||||
|
Loading…
Reference in New Issue
Block a user