+void BlockType::Copy(const BlockType &other) noexcept {
+ shape = other.shape;
+ textures = other.textures;
+ hsl_mod = other.hsl_mod;
+ rgb_mod = other.rgb_mod;
+ outline_color = other.outline_color;
+ place_sound = other.place_sound;
+ remove_sound = other.remove_sound;
+ luminosity = other.luminosity;
+ visible = other.visible;
+ block_light = other.block_light;
+ collision = other.collision;
+ collide_block = collide_block;
+ generate = other.generate;
+ min_solidity = other.min_solidity;
+ mid_solidity = other.mid_solidity;
+ max_solidity = other.max_solidity;
+ min_humidity = other.min_humidity;
+ mid_humidity = other.mid_humidity;
+ max_humidity = other.max_humidity;
+ min_temperature = other.min_temperature;
+ mid_temperature = other.mid_temperature;
+ max_temperature = other.max_temperature;
+ min_richness = other.min_richness;
+ mid_richness = other.mid_richness;
+ max_richness = other.max_richness;
+ commonness = other.commonness;
+}
+
+void BlockType::Read(
+ TokenStreamReader &in,
+ ResourceIndex &snd_index,
+ ResourceIndex &tex_index,
+ const ShapeRegistry &shapes
+) {
+ std::string name;
+ in.Skip(Token::ANGLE_BRACKET_OPEN);
+ glm::vec3 color_conv;
+ while (in.Peek().type != Token::ANGLE_BRACKET_CLOSE) {
+ in.ReadIdentifier(name);
+ in.Skip(Token::EQUALS);
+ if (name == "visible") {
+ visible = in.GetBool();
+ } else if (name == "texture") {
+ textures.clear();
+ in.ReadString(name);
+ textures.push_back(tex_index.GetID(name));
+ } else if (name == "textures") {
+ textures.clear();
+ in.Skip(Token::BRACKET_OPEN);
+ while (in.Peek().type != Token::BRACKET_CLOSE) {
+ in.ReadString(name);
+ textures.push_back(tex_index.GetID(name));
+ if (in.Peek().type == Token::COMMA) {
+ in.Skip(Token::COMMA);
+ }
+ }
+ in.Skip(Token::BRACKET_CLOSE);
+ } else if (name == "rgb_mod") {
+ in.ReadVec(color_conv);
+ rgb_mod = glm::tvec3<unsigned char>(color_conv * 255.0f);
+ } else if (name == "hsl_mod") {
+ in.ReadVec(color_conv);
+ hsl_mod = glm::tvec3<unsigned char>(color_conv * 255.0f);
+ } else if (name == "outline") {
+ in.ReadVec(color_conv);
+ outline_color = glm::tvec3<unsigned char>(color_conv * 255.0f);
+ } else if (name == "gravity") {
+ gravity = BlockGravity::Read(in);
+ } else if (name == "label") {
+ in.ReadString(label);
+ } else if (name == "place_sound") {
+ in.ReadString(name);
+ place_sound = snd_index.GetID(name);
+ } else if (name == "remove_sound") {
+ in.ReadString(name);
+ remove_sound = snd_index.GetID(name);
+ } else if (name == "luminosity") {
+ luminosity = in.GetInt();
+ } else if (name == "block_light") {
+ block_light = in.GetBool();
+ } else if (name == "collision") {
+ collision = in.GetBool();
+ } else if (name == "collide_block") {
+ collide_block = in.GetBool();
+ } else if (name == "generate") {
+ generate = in.GetBool();
+ } else if (name == "min_solidity") {
+ min_solidity = in.GetFloat();
+ } else if (name == "mid_solidity") {
+ mid_solidity = in.GetFloat();
+ } else if (name == "max_solidity") {
+ max_solidity = in.GetFloat();
+ } else if (name == "min_humidity") {
+ min_humidity = in.GetFloat();
+ } else if (name == "mid_humidity") {
+ mid_humidity = in.GetFloat();
+ } else if (name == "max_humidity") {
+ max_humidity = in.GetFloat();
+ } else if (name == "min_temperature") {
+ min_temperature = in.GetFloat();
+ } else if (name == "mid_temperature") {
+ mid_temperature = in.GetFloat();
+ } else if (name == "max_temperature") {
+ max_temperature = in.GetFloat();
+ } else if (name == "min_richness") {
+ min_richness = in.GetFloat();
+ } else if (name == "mid_richness") {
+ mid_richness = in.GetFloat();
+ } else if (name == "max_richness") {
+ max_richness = in.GetFloat();
+ } else if (name == "commonness") {
+ commonness = in.GetFloat();
+ } else if (name == "shape") {
+ in.ReadIdentifier(name);
+ shape = &shapes.Get(name);
+ } else {
+ std::cerr << "warning: unknown block type property " << name << std::endl;
+ while (in.Peek().type != Token::SEMICOLON) {
+ in.Next();
+ }
+ }
+ in.Skip(Token::SEMICOLON);
+ }
+ in.Skip(Token::ANGLE_BRACKET_CLOSE);
+}
+