view TileTable.cpp @ 1668:d17247968bd6

m
author Ritor1
date Tue, 17 Sep 2013 22:55:34 +0600
parents 75fafd8ced59
children c1c74df0a33e
line wrap: on
line source

#ifdef _MSC_VER
#define _CRT_SECURE_NO_WARNINGS
#endif

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include "TileFrameTable.h"
#include "FrameTableInc.h"
#include "PaletteManager.h"
#include "LOD.h"

#include "mm7_data.h"


//----- (00487E1D) --------------------------------------------------------
TileTable::~TileTable()
{
  if ( pTiles )
  {
    free(pTiles);
    pTiles = nullptr;
  }
  sNumTiles = 0;
}

//----- (00487E3B) --------------------------------------------------------
TileDesc *TileTable::GetTileById(unsigned int uTileID)
{
  Assert(uTileID < sNumTiles);
  return &pTiles[uTileID];
}

//----- (00487E58) --------------------------------------------------------
void TileTable::InitializeTileset(Tileset tileset)
{
  for (int i = 0; i < sNumTiles; ++i )
  {
    if (pTiles[i].tileset == tileset && pTiles[i].pTileName[0] )
    {
      pTiles[i].uBitmapID = pBitmaps_LOD->LoadTexture(pTiles[i].pTileName);
      if ( pTiles[i].uBitmapID != -1 )
        pBitmaps_LOD->pTextures[pTiles[i].uBitmapID].palette_id2 = pPaletteManager->LoadPalette(pBitmaps_LOD->pTextures[pTiles[i].uBitmapID].palette_id1);
    }
  }
}

//----- (00487ED6) --------------------------------------------------------
int TileTable::GetTileForTerrainType( signed int terrain_type, bool not_random )
    {
  int v5; // edx@3
  int v6; // edx@11

  if (  not_random || terrain_type > 8 )
  {
    return GetTileId(terrain_type, 0);
  }
   v5 = rand() % 50;
  if ( v5 < 20)
  {
    return GetTileId(terrain_type, 0);
  }
  else if ( v5 < 30 )
  {
    return GetTileId(terrain_type, 1);
  }
  else if ( v5 < 40 )
  {
    return GetTileId(terrain_type, 2);
  }
  else if ( v5 < 48 )
  {
    return GetTileId(terrain_type, 3);
  }
  v6 = rand() % 8;
  return GetTileId(terrain_type, v6+4);
  return 0;
}

//----- (00487F84) --------------------------------------------------------
unsigned int TileTable::GetTileId(unsigned int uTerrainType, unsigned int uSection)
{  
  for (int i=0; i<sNumTiles; ++i)
      {
      if( (pTiles[i].tileset==uTerrainType)&&(pTiles[i].uSection==uSection))
          return i;
      }
  return 0;
}

//----- (00487FB4) --------------------------------------------------------
void TileTable::ToFile()
{
  TileTable *v1; // esi@1
  FILE *v2; // eax@1
  FILE *v3; // edi@1

  auto Str = this;

  v1 = Str;
  v2 = fopen("data\\dtile.bin", "wb");
  v3 = v2;
  if ( !v2 )
    Error("Unable to save dtile.bin!");
  fwrite(v1, 4u, 1u, v2);
  fwrite(v1->pTiles, 0x1Au, v1->sNumTiles, v3);
  fclose(v3);
}

//----- (00488000) --------------------------------------------------------
void TileTable::FromFile(void *data_mm6, void *data_mm7, void *data_mm8)
{
  uint num_mm6_tiles = data_mm6 ? *(int *)data_mm6 : 0,
       num_mm7_tiles = data_mm7 ? *(int *)data_mm7 : 0,
       num_mm8_tiles = data_mm8 ? *(int *)data_mm8 : 0;
  sNumTiles = num_mm6_tiles + num_mm7_tiles + num_mm8_tiles;
  Assert(sNumTiles);
  Assert(!num_mm8_tiles);

  pTiles = (TileDesc *)malloc(sNumTiles * sizeof(TileDesc));
  memcpy(pTiles,                                 (char *)data_mm7 + 4, num_mm7_tiles * sizeof(TileDesc));
  memcpy(pTiles + num_mm7_tiles,                 (char *)data_mm6 + 4, num_mm6_tiles * sizeof(TileDesc));
  memcpy(pTiles + num_mm6_tiles + num_mm7_tiles, (char *)data_mm8 + 4, num_mm8_tiles * sizeof(TileDesc));
}

//----- (00488047) --------------------------------------------------------
int TileTable::FromFileTxt(const char *pFilename)
{
  TileTable *v2; // ebp@1
  FILE *v3; // eax@1
  unsigned int v4; // ebx@3
  void *v5; // eax@9
  unsigned __int16 v6; // ax@14
  const char *v7; // ST14_4@14
  unsigned __int16 v8; // ax@14
  const char *v9; // esi@14
  int v10; // eax@17
  int v11; // eax@20
  int v12; // eax@22
  int v13; // eax@24
  int v14; // eax@26
  int v15; // eax@28
  int v16; // eax@30
  int v17; // eax@32
  int v18; // eax@34
  int v19; // eax@36
  int v20; // eax@38
  int v21; // eax@40
  int v22; // eax@42
  int v23; // eax@44
  int v24; // eax@46
  int v25; // eax@48
  int v26; // eax@50
  int v27; // eax@52
  int v28; // eax@54
  int v29; // eax@56
  int v30; // eax@58
  int v31; // eax@60
  int v32; // eax@62
  int v33; // eax@64
  int v34; // eax@66
  const char *v35; // esi@67
  int v36; // eax@70
  int v37; // eax@73
  int v38; // eax@75
  int v39; // eax@77
  int v40; // eax@79
  int v41; // eax@81
  int v42; // eax@83
  int v43; // eax@85
  int v44; // eax@87
  int v45; // eax@89
  int v46; // eax@91
  int v47; // eax@93
  int v48; // eax@108
  int v49; // eax@110
  int v50; // eax@112
  int v51; // eax@114
  int v52; // eax@116
  int v53; // eax@118
  int v54; // eax@120
  int v55; // eax@122
  int v56; // eax@124
  int v57; // eax@126
  int v58; // eax@128
  int v59; // eax@130
  int v60; // eax@132
  int v61; // eax@134
  int v62; // eax@136
  int v63; // eax@138
  int v64; // eax@140
  int v65; // eax@142
  int v66; // eax@144
  int v67; // eax@146
  int v68; // eax@148
  int v69; // eax@150
  int v70; // eax@151
  int j; // edi@152
  const char *v72; // esi@153
  int v73; // eax@154
  int v74; // eax@156
  int v75; // eax@160
  int v76; // eax@162
  int v77; // eax@164
  int v78; // eax@166
  int v79; // eax@168
  int v80; // eax@170
  FILE *i; // [sp-10h] [bp-304h]@3
  FILE *File; // [sp+4h] [bp-2F0h]@1
  FrameTableTxtLine v84; // [sp+8h] [bp-2ECh]@4
  FrameTableTxtLine v85; // [sp+84h] [bp-270h]@4
  char Buf; // [sp+100h] [bp-1F4h]@4

  v2 = this;
  v3 = fopen(pFilename, "r");
  File = v3;
  if ( !v3 )
    Error("TileTable::load - Unable to open file: %s.");
  v4 = 0;
  for ( i = v3; fgets(&Buf, 490, i); i = File )
  {
    *strchr(&Buf, 10) = 0;
    memcpy(&v84, txt_file_frametable_parser(&Buf, &v85), sizeof(v84));
    if ( v84.uPropCount && *v84.pProperties[0] != 47 )
      ++v4;
  }
  v2->sNumTiles = v4;
  v5 = malloc(26 * v4);
  v2->pTiles = (TileDesc *)v5;
  if ( !v5 )
    Error("TileTable::Load - Out of Memory!");
  memset(v5, 0, 26 * v2->sNumTiles);
  v2->sNumTiles = 0;
  fseek(File, 0, 0);
  if ( fgets(&Buf, 490, File) )
  {
    while ( 1 )
    {
      *strchr(&Buf, 10) = 0;
      memcpy(&v84, txt_file_frametable_parser(&Buf, &v85), sizeof(v84));
      if ( v84.uPropCount )
      {
        if ( *v84.pProperties[0] != 47 )
          break;
      }
LABEL_173:
      if ( !fgets(&Buf, 490, File) )
        goto LABEL_174;
    }
    strcpy(v2->pTiles[v2->sNumTiles].pTileName, v84.pProperties[0]);
    v6 = atoi(v84.pProperties[1]);
    v7 = v84.pProperties[2];
    v2->pTiles[v2->sNumTiles].uTileID = v6;
    v8 = atoi(v7);
    v9 = v84.pProperties[3];
    v2->pTiles[v2->sNumTiles].uBitmapID = v8;
    v2->pTiles[v2->sNumTiles].tileset = Tileset_Grass;
    if ( _stricmp(v9, "TTtype_NULL") )
    {
      if ( _stricmp(v9, "TTtype_Start") )
      {
        if ( _stricmp(v9, "TTtype_Grass") )
        {
          if ( _stricmp(v9, "TTtype_Cracked") )
          {
            if ( _stricmp(v9, "TTtype_Snow") )
            {
              if ( _stricmp(v9, "TTtype_Sand") )
              {
                if ( _stricmp(v9, "TTtype_Volcano") )
                {
                  if ( _stricmp(v9, "TTtype_Dirt") )
                  {
                    if ( _stricmp(v9, "TTtype_Water") )
                    {
                      if ( _stricmp(v9, "TTtype_Tropical") )
                      {
                        if ( _stricmp(v9, "TTtype_Swamp") )
                        {
                          if ( _stricmp(v9, "TTtype_City") )
                          {
                            if ( _stricmp(v9, "TTtype_RoadGrassCobble") )
                            {
                              if ( _stricmp(v9, "TTtype_RoadGrassDirt") )
                              {
                                if ( _stricmp(v9, "TTtype_RoadCrackedCobble") )
                                {
                                  if ( _stricmp(v9, "TTtype_RoadCrackedDirt") )
                                  {
                                    if ( _stricmp(v9, "TTtype_RoadSandCobble") )
                                    {
                                      if ( _stricmp(v9, "TTtype_RoadSandDirt") )
                                      {
                                        if ( _stricmp(v9, "TTtype_RoadVolcanoCobble") )
                                        {
                                          if ( _stricmp(v9, "TTtype_RoadVolcanoDirt") )
                                          {
                                            if ( _stricmp(v9, "TTtype_RoadSwampCobble") )
                                            {
                                              if ( _stricmp(v9, "TTtype_RoadSwampDirt") )
                                              {
                                                if ( _stricmp(v9, "TTtype_RoadTropicalCobble") )
                                                {
                                                  if ( _stricmp(v9, "TTtype_RoadTropicalDirt") )
                                                  {
                                                    if ( _stricmp(v9, "TTtype_RoadSnowCobble") )
                                                    {
                                                      if ( _stricmp(v9, "TTtype_RoadSnowDirt") )
                                                      {
                                                        if ( !_stricmp(v9, "TTtype_RoadCityStone") )
                                                        {
                                                          v34 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                                          *(char *)v34 |= 0x1Cu;
                                                        }
                                                      }
                                                      else
                                                      {
                                                        v33 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                                        *(char *)v33 |= 0xDu;
                                                      }
                                                    }
                                                    else
                                                    {
                                                      v32 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                                      *(char *)v32 |= 0xCu;
                                                    }
                                                  }
                                                  else
                                                  {
                                                    v31 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                                    *(char *)v31 |= 0x1Bu;
                                                  }
                                                }
                                                else
                                                {
                                                  v30 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                                  *(char *)v30 |= 0x1Au;
                                                }
                                              }
                                              else
                                              {
                                                v29 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                                *(char *)v29 |= 0x19u;
                                              }
                                            }
                                            else
                                            {
                                              v28 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                              *(char *)v28 |= 0x18u;
                                            }
                                          }
                                          else
                                          {
                                            v27 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                            *(char *)v27 |= 0x11u;
                                          }
                                        }
                                        else
                                        {
                                          v26 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                          *(char *)v26 |= 0x10u;
                                        }
                                      }
                                      else
                                      {
                                        v25 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                        *(char *)v25 |= 0xFu;
                                      }
                                    }
                                    else
                                    {
                                      v24 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                      *(char *)v24 |= 0xEu;
                                    }
                                  }
                                  else
                                  {
                                    v23 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                    *(char *)v23 |= 0x17u;
                                  }
                                }
                                else
                                {
                                  v22 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                  *(char *)v22 |= 0x16u;
                                }
                              }
                              else
                              {
                                v21 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                                *(char *)v21 |= 0xBu;
                              }
                            }
                            else
                            {
                              v20 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                              *(char *)v20 |= 0xAu;
                            }
                          }
                          else
                          {
                            v19 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                            *(char *)v19 |= 9u;
                          }
                        }
                        else
                        {
                          v18 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                          *(char *)v18 |= 7u;
                        }
                      }
                      else
                      {
                        v17 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                        *(char *)v17 |= 8u;
                      }
                    }
                    else
                    {
                      v16 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                      *(char *)v16 |= 5u;
                    }
                  }
                  else
                  {
                    v15 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                    *(char *)v15 |= 4u;
                  }
                }
                else
                {
                  v14 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                  *(char *)v14 |= 3u;
                }
              }
              else
              {
                v13 = (int)&v2->pTiles[v2->sNumTiles].tileset;
                *(char *)v13 |= 2u;
              }
            }
            else
            {
              v12 = (int)&v2->pTiles[v2->sNumTiles].tileset;
              *(char *)v12 |= 1u;
            }
          }
          else
          {
            v11 = (int)&v2->pTiles[v2->sNumTiles].tileset;
            *(char *)v11 |= 6u;
          }
        }
      }
      else
      {
        v10 = (int)&v2->pTiles[v2->sNumTiles].uSection;
        *(char *)v10 |= 0xFEu;
      }
    }
    else
    {
      LOBYTE(v2->pTiles[v2->sNumTiles].tileset) = -1;
    }
    v35 = v84.pProperties[4];
    v2->pTiles[v2->sNumTiles].uSection = 0;
    v2->pTiles[v2->sNumTiles].uAttributes = 0;
    if ( !_stricmp(v35, "TTsect_NULL") )
    {
      LOBYTE(v2->pTiles[v2->sNumTiles].uSection) = -1;
LABEL_152:
      for ( j = 5; j < v84.uPropCount; ++j )
      {
        v72 = v84.pProperties[j];
        if ( _stricmp(v84.pProperties[j], "TTattr_Burn") )
        {
          if ( _stricmp(v72, "TTattr_Water") )
          {
            if ( _stricmp(v72, "TTattr_Water2") )
            {
              if ( _stricmp(v72, "TTattr_Block") )
              {
                if ( _stricmp(v72, "TTattr_Repulse") )
                {
                  if ( _stricmp(v72, "TTattr_Flat") )
                  {
                    if ( _stricmp(v72, "TTattr_Wave") )
                    {
                      if ( _stricmp(v72, "TTattr_NoDraw") )
                      {
                        if ( !_stricmp(v72, "TTattr_Transition") )
                        {
                          v80 = (int)&v2->pTiles[v2->sNumTiles].uAttributes;
                          *(short *)v80 |= 0x200u;
                        }
                      }
                      else
                      {
                        v79 = (int)&v2->pTiles[v2->sNumTiles].uAttributes;
                        *(char *)v79 |= 0x40u;
                      }
                    }
                    else
                    {
                      v78 = (int)&v2->pTiles[v2->sNumTiles].uAttributes;
                      *(char *)v78 |= 0x20u;
                    }
                  }
                  else
                  {
                    v77 = (int)&v2->pTiles[v2->sNumTiles].uAttributes;
                    *(char *)v77 |= 0x10u;
                  }
                }
                else
                {
                  v76 = (int)&v2->pTiles[v2->sNumTiles].uAttributes;
                  *(char *)v76 |= 8u;
                }
              }
              else
              {
                v75 = (int)&v2->pTiles[v2->sNumTiles].uAttributes;
                *(char *)v75 |= 4u;
              }
            }
            else
            {
              HIBYTE(v2->pTiles[v2->sNumTiles].uAttributes) |= 1u;
            }
          }
          else
          {
            v74 = (int)&v2->pTiles[v2->sNumTiles].uAttributes;
            *(char *)v74 |= 2u;
          }
        }
        else
        {
          v73 = (int)&v2->pTiles[v2->sNumTiles].uAttributes;
          *(char *)v73 |= 1u;
        }
      }
      ++v2->sNumTiles;
      goto LABEL_173;
    }
    if ( !_stricmp(v35, "TTsect_Start") )
    {
      v36 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v36 |= 0xFEu;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Base1") )
      goto LABEL_152;
    if ( !_stricmp(v35, "TTsect_Base2") )
    {
      v37 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v37 |= 1u;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Base3") )
    {
      v38 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v38 |= 2u;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Base4") )
    {
      v39 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v39 |= 3u;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Special1") )
    {
      v40 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v40 |= 4u;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Special2") )
    {
      v41 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v41 |= 5u;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Special3") )
    {
      v42 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v42 |= 6u;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Special4") )
    {
      v43 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v43 |= 7u;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Special5") )
    {
      v44 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v44 |= 8u;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Special6") )
    {
      v45 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v45 |= 9u;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Special7") )
    {
      v46 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v46 |= 0xAu;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_Special8") )
    {
      v47 = (int)&v2->pTiles[v2->sNumTiles].uSection;
      *(char *)v47 |= 0xBu;
      goto LABEL_152;
    }
    if ( !_stricmp(v35, "TTsect_NE1") )
      goto LABEL_130;
    if ( !_stricmp(v35, "TTsect_NW1") )
      goto LABEL_134;
    if ( !_stricmp(v35, "TTsect_SE1") )
      goto LABEL_130;
    if ( !_stricmp(v35, "TTsect_SW1") )
      goto LABEL_134;
    if ( !_stricmp(v35, "TTsect_E1") )
      goto LABEL_138;
    if ( !_stricmp(v35, "TTsect_W1") )
      goto LABEL_140;
    if ( !_stricmp(v35, "TTsect_N1") )
      goto LABEL_142;
    if ( !_stricmp(v35, "TTsect_S1") )
      goto LABEL_144;
    if ( !_stricmp(v35, "TTsect_XNE1") )
      goto LABEL_146;
    if ( _stricmp(v35, "TTsect_XNW1") )
    {
      if ( !_stricmp(v35, "TTsect_XSE1") )
        goto LABEL_146;
      if ( _stricmp(v35, "TTsect_XSW1") )
      {
        if ( !_stricmp(v35, "TTsect_CROS") )
        {
LABEL_151:
          v70 = (int)&v2->pTiles[v2->sNumTiles].uAttributes;
          *(short *)v70 |= 0x200u;
          goto LABEL_152;
        }
        if ( !_stricmp(v35, "TTsect_NS") )
        {
          v48 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v48 |= 1u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_EW") )
        {
          v49 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v49 |= 2u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_N_E") )
        {
          v50 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v50 |= 3u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_N_W") )
        {
          v51 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v51 |= 4u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_S_E") )
        {
          v52 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v52 |= 5u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_S_W") )
        {
          v53 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v53 |= 6u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_NS_E") )
        {
          v54 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v54 |= 7u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_NS_W") )
        {
          v55 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v55 |= 8u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_EW_N") )
        {
          v56 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v56 |= 9u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_EW_S") )
        {
          v57 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v57 |= 0xAu;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_NCAP") )
        {
          v58 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v58 |= 0xBu;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_ECAP") )
        {
LABEL_130:
          v59 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v59 |= 0xCu;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_SCAP") )
        {
          v60 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v60 |= 0xDu;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_WCAP") )
        {
LABEL_134:
          v61 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v61 |= 0xEu;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_DN") )
        {
          v62 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v62 |= 0xFu;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_DS") )
        {
LABEL_138:
          v63 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v63 |= 0x10u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_DW") )
        {
LABEL_140:
          v64 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v64 |= 0x11u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_DE") )
        {
LABEL_142:
          v65 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v65 |= 0x12u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_DSW") )
        {
LABEL_144:
          v66 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v66 |= 0x13u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_DNE") )
        {
LABEL_146:
          v67 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v67 |= 0x14u;
          goto LABEL_151;
        }
        if ( !_stricmp(v35, "TTsect_DSE") )
        {
          v68 = (int)&v2->pTiles[v2->sNumTiles].uSection;
          *(char *)v68 |= 0x15u;
          goto LABEL_151;
        }
        if ( _stricmp(v35, "TTsect_DNW") )
          goto LABEL_152;
      }
    }
    v69 = (int)&v2->pTiles[v2->sNumTiles].uSection;
    *(char *)v69 |= 0x16u;
    goto LABEL_151;
  }
LABEL_174:
  fclose(File);
  return 1;
}