|
|
//========= Copyright � 1996-2005, Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $NoKeywords: $
//=============================================================================//
#include "map_shared.h"
#include "bsplib.h"
#include "cmdlib.h"
CMapError g_MapError; int g_nMapFileVersion;
//-----------------------------------------------------------------------------
// Purpose:
// Input : *szKey -
// *szValue -
// *pLoadEntity -
// Output : ChunkFileResult_t
//-----------------------------------------------------------------------------
ChunkFileResult_t LoadEntityKeyCallback(const char *szKey, const char *szValue, LoadEntity_t *pLoadEntity) { if (!stricmp(szKey, "classname")) { if (!stricmp(szValue, "func_detail")) { pLoadEntity->nBaseContents = CONTENTS_DETAIL; } else if (!stricmp(szValue, "func_ladder")) { pLoadEntity->nBaseContents = CONTENTS_LADDER; } else if (!stricmp(szValue, "func_water")) { pLoadEntity->nBaseContents = CONTENTS_WATER; } } else if (!stricmp(szKey, "id")) { // UNDONE: flag entity errors by ID instead of index
//g_MapError.EntityState( atoi( szValue ) );
// rename this field since DME code uses this name
SetKeyValue( pLoadEntity->pEntity, "hammerid", szValue ); return(ChunkFile_Ok); } else if( !stricmp( szKey, "mapversion" ) ) { // .vmf map revision number
if ( g_MapRevision == 0 ) { // only take the first occurrence of this. func_instance will each have another occurrence but we want the root map's revision
g_MapRevision = atoi( szValue ); Msg("Map revision %d\n", g_MapRevision ); } SetKeyValue( pLoadEntity->pEntity, szKey, szValue ); return ( ChunkFile_Ok ); }
SetKeyValue( pLoadEntity->pEntity, szKey, szValue );
return(ChunkFile_Ok); }
static ChunkFileResult_t LoadEntityCallback( CChunkFile *pFile, int nParam ) { if (num_entities == MAX_MAP_ENTITIES) { // Exits.
g_MapError.ReportError ("num_entities == MAX_MAP_ENTITIES"); }
entity_t *mapent = &entities[num_entities]; num_entities++; memset(mapent, 0, sizeof(*mapent)); mapent->numbrushes = 0;
LoadEntity_t LoadEntity; LoadEntity.pEntity = mapent;
// No default flags/contents
LoadEntity.nBaseFlags = 0; LoadEntity.nBaseContents = 0;
//
// Read the entity chunk.
//
ChunkFileResult_t eResult = pFile->ReadChunk((KeyHandler_t)LoadEntityKeyCallback, &LoadEntity);
return eResult; }
bool LoadEntsFromMapFile( char const *pFilename ) { //
// Dummy this up for the texture handling. This can be removed when old .MAP file
// support is removed.
//
g_nMapFileVersion = 400;
//
// Open the file.
//
CChunkFile File; ChunkFileResult_t eResult = File.Open( pFilename, ChunkFile_Read );
if(eResult == ChunkFile_Ok) { num_entities = 0;
//
// Set up handlers for the subchunks that we are interested in.
//
CChunkHandlerMap Handlers; Handlers.AddHandler("entity", (ChunkHandler_t)LoadEntityCallback, 0);
File.PushHandlers(&Handlers);
//
// Read the sub-chunks. We ignore keys in the root of the file.
//
while (eResult == ChunkFile_Ok) { eResult = File.ReadChunk(); }
File.PopHandlers(); return true; } else { Error("Error in LoadEntsFromMapFile (in-memory file): %s.\n", File.GetErrorText(eResult)); return false; } }
|