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-08-15 22:57:31 +02:00
|
|
|
LOG(ERROR, LOG_CATEGORY, "CBaseEntityCollection::loadTemplates(): Unable to open directory entities/");
|
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-06-11 00:24:03 +02:00
|
|
|
if( m_templates[t]->m_name == 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] );
|
|
|
|
}
|