*/
static void serializeSimpleSoundSpec(const SimpleSoundSpec &ss,
- std::ostream &os)
+ std::ostream &os, u8 version)
{
os<<serializeString(ss.name);
writeF1000(os, ss.gain);
- writeF1000(os, ss.pitch);
+
+ if (version >= 11)
+ writeF1000(os, ss.pitch);
}
-static void deSerializeSimpleSoundSpec(SimpleSoundSpec &ss, std::istream &is)
+static void deSerializeSimpleSoundSpec(SimpleSoundSpec &ss, std::istream &is, u8 version)
{
ss.name = deSerializeString(is);
ss.gain = readF1000(is);
- ss.pitch = readF1000(is);
+
+ if (version >= 11)
+ ss.pitch = readF1000(is);
}
void TextureSettings::readSettings()
}
// version
- writeU8(os, 10);
+ u8 version = (protocol_version >= 34) ? 11 : 10;
+ writeU8(os, version);
// general
os << serializeString(name);
collision_box.serialize(os, protocol_version);
// sound
- serializeSimpleSoundSpec(sound_footstep, os);
- serializeSimpleSoundSpec(sound_dig, os);
- serializeSimpleSoundSpec(sound_dug, os);
+ serializeSimpleSoundSpec(sound_footstep, os, version);
+ serializeSimpleSoundSpec(sound_dig, os, version);
+ serializeSimpleSoundSpec(sound_dug, os, version);
// legacy
writeU8(os, legacy_facedir_simple);
if (version < 9) {
deSerializeOld(is, version);
return;
- } else if (version > 10) {
+ } else if (version > 11) {
throw SerializationError("unsupported ContentFeatures version");
}
collision_box.deSerialize(is);
// sounds
- deSerializeSimpleSoundSpec(sound_footstep, is);
- deSerializeSimpleSoundSpec(sound_dig, is);
- deSerializeSimpleSoundSpec(sound_dug, is);
+ deSerializeSimpleSoundSpec(sound_footstep, is, version);
+ deSerializeSimpleSoundSpec(sound_dig, is, version);
+ deSerializeSimpleSoundSpec(sound_dug, is, version);
// read legacy properties
legacy_facedir_simple = readU8(is);
selection_box.serialize(os, protocol_version);
writeU8(os, legacy_facedir_simple);
writeU8(os, legacy_wallmounted);
- serializeSimpleSoundSpec(sound_footstep, os);
- serializeSimpleSoundSpec(sound_dig, os);
- serializeSimpleSoundSpec(sound_dug, os);
+ serializeSimpleSoundSpec(sound_footstep, os, 10);
+ serializeSimpleSoundSpec(sound_dig, os, 10);
+ serializeSimpleSoundSpec(sound_dug, os, 10);
writeU8(os, rightclickable);
writeU8(os, drowning);
writeU8(os, leveled);
selection_box.deSerialize(is);
legacy_facedir_simple = readU8(is);
legacy_wallmounted = readU8(is);
- deSerializeSimpleSoundSpec(sound_footstep, is);
- deSerializeSimpleSoundSpec(sound_dig, is);
- deSerializeSimpleSoundSpec(sound_dug, is);
+ deSerializeSimpleSoundSpec(sound_footstep, is, version);
+ deSerializeSimpleSoundSpec(sound_dig, is, version);
+ deSerializeSimpleSoundSpec(sound_dug, is, version);
} else if (version == 6) {
name = deSerializeString(is);
groups.clear();
selection_box.deSerialize(is);
legacy_facedir_simple = readU8(is);
legacy_wallmounted = readU8(is);
- deSerializeSimpleSoundSpec(sound_footstep, is);
- deSerializeSimpleSoundSpec(sound_dig, is);
- deSerializeSimpleSoundSpec(sound_dug, is);
+ deSerializeSimpleSoundSpec(sound_footstep, is, version);
+ deSerializeSimpleSoundSpec(sound_dig, is, version);
+ deSerializeSimpleSoundSpec(sound_dug, is, version);
rightclickable = readU8(is);
drowning = readU8(is);
leveled = readU8(is);
selection_box.deSerialize(is);
legacy_facedir_simple = readU8(is);
legacy_wallmounted = readU8(is);
- deSerializeSimpleSoundSpec(sound_footstep, is);
- deSerializeSimpleSoundSpec(sound_dig, is);
- deSerializeSimpleSoundSpec(sound_dug, is);
+ deSerializeSimpleSoundSpec(sound_footstep, is, version);
+ deSerializeSimpleSoundSpec(sound_dig, is, version);
+ deSerializeSimpleSoundSpec(sound_dug, is, version);
rightclickable = readU8(is);
drowning = readU8(is);
leveled = readU8(is);