2004-06-03 20:38:14 +02:00
|
|
|
#include "precompiled.h"
|
|
|
|
|
2004-05-22 01:46:16 +02:00
|
|
|
#include "BaseEntityCollection.h"
|
|
|
|
#include "ObjectManager.h"
|
|
|
|
#include "Model.h"
|
2004-06-03 03:43:33 +02:00
|
|
|
#include "CLogger.h"
|
2004-05-22 01:46:16 +02:00
|
|
|
|
2004-08-15 22:57:31 +02:00
|
|
|
#define LOG_CATEGORY "entity"
|
|
|
|
|
2004-05-22 01:46:16 +02:00
|
|
|
void CBaseEntityCollection::loadTemplates()
|
|
|
|
{
|
2004-06-02 18:06:19 +02:00
|
|
|
Handle handle;
|
2004-08-03 01:14:54 +02:00
|
|
|
vfsDirEnt type, file;
|
2004-05-22 01:46:16 +02:00
|
|
|
|
2004-08-03 01:14:54 +02:00
|
|
|
CStr basepath = "entities/";
|
|
|
|
CStr pathname;
|
|
|
|
|
|
|
|
// Iterate through all subdirectories
|
|
|
|
|
|
|
|
Handle maindir = vfs_open_dir( basepath );
|
|
|
|
|
|
|
|
if( maindir > 0 )
|
2004-06-02 18:06:19 +02:00
|
|
|
{
|
2004-08-03 01:14:54 +02:00
|
|
|
while( !vfs_next_dirent( maindir, &type, "/" ) )
|
2004-05-22 01:46:16 +02:00
|
|
|
{
|
2004-08-03 01:14:54 +02:00
|
|
|
pathname = basepath + type.name;
|
|
|
|
|
|
|
|
handle = vfs_open_dir( pathname );
|
|
|
|
|
|
|
|
pathname += "/";
|
|
|
|
|
|
|
|
if( handle > 0 )
|
2004-06-02 18:06:19 +02:00
|
|
|
{
|
2004-08-03 01:14:54 +02:00
|
|
|
while( !vfs_next_dirent(handle, &file, ".xml") )
|
|
|
|
{
|
|
|
|
CBaseEntity* newTemplate = new CBaseEntity();
|
|
|
|
if( newTemplate->loadXML( pathname + file.name ) )
|
|
|
|
{
|
|
|
|
addTemplate( newTemplate );
|
2004-08-15 22:57:31 +02:00
|
|
|
LOG(NORMAL, LOG_CATEGORY, "CBaseEntityCollection::loadTemplates(): Loaded template \"%s%s\"", pathname.c_str(), file.name);
|
2004-08-03 01:14:54 +02:00
|
|
|
}
|
|
|
|
else
|
2004-08-15 22:57:31 +02:00
|
|
|
LOG(ERROR, LOG_CATEGORY, "CBaseEntityCollection::loadTemplates(): Couldn't load template \"%s%s\"", pathname.c_str(), file.name);
|
2004-08-03 01:14:54 +02:00
|
|
|
}
|
|
|
|
vfs_close_dir( handle );
|
2004-06-02 18:06:19 +02:00
|
|
|
}
|
|
|
|
else
|
2004-08-03 01:14:54 +02:00
|
|
|
{
|
2004-08-15 22:57:31 +02:00
|
|
|
LOG(ERROR, LOG_CATEGORY, "CBaseEntityCollection::loadTemplates(): Failed to enumerate entity template directory");
|
2004-08-03 01:14:54 +02:00
|
|
|
return;
|
|
|
|
}
|
2004-06-02 18:06:19 +02:00
|
|
|
}
|
2004-08-03 01:14:54 +02:00
|
|
|
vfs_close_dir( maindir );
|
2004-05-22 01:46:16 +02:00
|
|
|
}
|
2004-06-02 18:06:19 +02:00
|
|
|
else
|
2004-10-07 21:23:35 +02:00
|
|
|
LOG(ERROR, LOG_CATEGORY, "CBaseEntityCollection::loadTemplates(): Unable to open directory entities/");
|
|
|
|
|
|
|
|
// Fix up parent links in the templates.
|
|
|
|
|
|
|
|
std::vector<CBaseEntity*>::iterator it;
|
|
|
|
for( it = m_templates.begin(); it != m_templates.end(); it++ )
|
|
|
|
{
|
|
|
|
if( !( (*it)->m_Base_Name.Length() ) )
|
|
|
|
continue;
|
|
|
|
|
|
|
|
CBaseEntity* Base = getTemplate( (*it)->m_Base_Name );
|
|
|
|
if( Base )
|
|
|
|
{
|
|
|
|
(*it)->m_base = Base;
|
|
|
|
(*it)->loadBase();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
LOG( WARNING, LOG_CATEGORY, "Parent template %s does not exist in template %s", CStr8( (*it)->m_Base_Name ).c_str(), CStr8( (*it)->m_Tag ).c_str() );
|
|
|
|
}
|
|
|
|
|
2004-05-22 01:46:16 +02:00
|
|
|
}
|
|
|
|
|
2004-06-11 00:24:03 +02:00
|
|
|
void CBaseEntityCollection::addTemplate( CBaseEntity* temp )
|
2004-05-22 01:46:16 +02:00
|
|
|
{
|
|
|
|
m_templates.push_back( temp );
|
|
|
|
}
|
|
|
|
|
2004-08-03 01:14:54 +02:00
|
|
|
CBaseEntity* CBaseEntityCollection::getTemplate( CStrW name )
|
2004-05-22 01:46:16 +02:00
|
|
|
{
|
2004-05-24 23:01:50 +02:00
|
|
|
for( u16 t = 0; t < m_templates.size(); t++ )
|
2004-10-07 21:23:35 +02:00
|
|
|
if( m_templates[t]->m_Tag == name ) return( m_templates[t] );
|
2004-05-22 01:46:16 +02:00
|
|
|
|
|
|
|
return( NULL );
|
|
|
|
}
|
|
|
|
|
|
|
|
CBaseEntity* CBaseEntityCollection::getTemplateByActor( CObjectEntry* actor )
|
|
|
|
{
|
2004-05-24 23:01:50 +02:00
|
|
|
for( u16 t = 0; t < m_templates.size(); t++ )
|
2004-06-11 00:24:03 +02:00
|
|
|
if( m_templates[t]->m_actorObject == actor ) return( m_templates[t] );
|
2004-05-22 01:46:16 +02:00
|
|
|
|
|
|
|
return( NULL );
|
|
|
|
}
|
2004-06-11 00:24:03 +02:00
|
|
|
|
|
|
|
CBaseEntityCollection::~CBaseEntityCollection()
|
|
|
|
{
|
|
|
|
for( u16 t = 0; t < m_templates.size(); t++ )
|
|
|
|
delete( m_templates[t] );
|
|
|
|
}
|