aboutsummaryrefslogtreecommitdiff
path: root/src/common/Collision/Maps/TileAssembler.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/common/Collision/Maps/TileAssembler.cpp')
-rw-r--r--src/common/Collision/Maps/TileAssembler.cpp46
1 files changed, 33 insertions, 13 deletions
diff --git a/src/common/Collision/Maps/TileAssembler.cpp b/src/common/Collision/Maps/TileAssembler.cpp
index 6c102af97bc..37dc0ee55a4 100644
--- a/src/common/Collision/Maps/TileAssembler.cpp
+++ b/src/common/Collision/Maps/TileAssembler.cpp
@@ -220,7 +220,7 @@ namespace VMAP
ModelSpawn spawn;
while (!feof(dirf))
{
- // read mapID, tileX, tileY, Flags, adtID, ID, Pos, Rot, Scale, Bound_lo, Bound_hi, name
+ // read mapID, tileX, tileY, Flags, NameSet, UniqueId, Pos, Rot, Scale, Bound_lo, Bound_hi, name
check = fread(&mapID, sizeof(uint32), 1, dirf);
if (check == 0) // EoF...
break;
@@ -296,14 +296,16 @@ namespace VMAP
return true;
}
+#pragma pack(push, 1)
struct WMOLiquidHeader
{
int xverts, yverts, xtiles, ytiles;
float pos_x;
float pos_y;
float pos_z;
- short type;
+ short material;
};
+#pragma pack(pop)
//=================================================================
bool TileAssembler::convertRawFile(const std::string& pModelFilename)
{
@@ -347,6 +349,10 @@ namespace VMAP
if (!model_list)
return;
+ char ident[8];
+ if (fread(ident, 1, 8, model_list) != 8 || memcmp(ident, VMAP::RAW_VMAP_MAGIC, 8) != 0)
+ return;
+
FILE* model_list_copy = fopen((iDestDir + "/" + GAMEOBJECT_MODELS).c_str(), "wb");
if (!model_list_copy)
{
@@ -354,7 +360,10 @@ namespace VMAP
return;
}
+ fwrite(VMAP::VMAP_MAGIC, 1, 8, model_list_copy);
+
uint32 name_length, displayId;
+ uint8 isWmo;
char buff[500];
while (true)
{
@@ -362,7 +371,8 @@ namespace VMAP
if (feof(model_list)) // EOF flag is only set after failed reading attempt
break;
- if (fread(&name_length, sizeof(uint32), 1, model_list) != 1
+ if (fread(&isWmo, sizeof(uint8), 1, model_list) != 1
+ || fread(&name_length, sizeof(uint32), 1, model_list) != 1
|| name_length >= sizeof(buff)
|| fread(&buff, sizeof(char), name_length, model_list) != name_length)
{
@@ -407,6 +417,7 @@ namespace VMAP
}
fwrite(&displayId, sizeof(uint32), 1, model_list_copy);
+ fwrite(&isWmo, sizeof(uint8), 1, model_list_copy);
fwrite(&name_length, sizeof(uint32), 1, model_list_copy);
fwrite(&buff, sizeof(char), name_length, model_list_copy);
fwrite(&bounds.low(), sizeof(Vector3), 1, model_list_copy);
@@ -491,25 +502,34 @@ namespace VMAP
delete[] vectorarray;
}
// ----- liquid
- liquid = 0;
- if (liquidflags& 1)
+ liquid = nullptr;
+ if (liquidflags & 3)
{
- WMOLiquidHeader hlq;
READ_OR_RETURN(&blockId, 4);
CMP_OR_RETURN(blockId, "LIQU");
READ_OR_RETURN(&blocksize, sizeof(int));
- READ_OR_RETURN(&hlq, sizeof(WMOLiquidHeader));
- liquid = new WmoLiquid(hlq.xtiles, hlq.ytiles, Vector3(hlq.pos_x, hlq.pos_y, hlq.pos_z), hlq.type);
- uint32 size = hlq.xverts*hlq.yverts;
- READ_OR_RETURN(liquid->GetHeightStorage(), size*sizeof(float));
- size = hlq.xtiles*hlq.ytiles;
- READ_OR_RETURN(liquid->GetFlagsStorage(), size);
+ uint32 liquidType;
+ READ_OR_RETURN(&liquidType, sizeof(uint32));
+ if (liquidflags & 1)
+ {
+ WMOLiquidHeader hlq;
+ READ_OR_RETURN(&hlq, sizeof(WMOLiquidHeader));
+ liquid = new WmoLiquid(hlq.xtiles, hlq.ytiles, Vector3(hlq.pos_x, hlq.pos_y, hlq.pos_z), liquidType);
+ uint32 size = hlq.xverts * hlq.yverts;
+ READ_OR_RETURN(liquid->GetHeightStorage(), size * sizeof(float));
+ size = hlq.xtiles * hlq.ytiles;
+ READ_OR_RETURN(liquid->GetFlagsStorage(), size);
+ }
+ else
+ {
+ liquid = new WmoLiquid(0, 0, Vector3::zero(), liquidType);
+ liquid->GetHeightStorage()[0] = bounds.high().z;
+ }
}
return true;
}
-
GroupModel_Raw::~GroupModel_Raw()
{
delete liquid;