khanat-opennel-code/code/ryzom/server/src/ai_service/ais_spawn_ctrl.cpp
acemtp@users.sourceforge.net d5c601ffa5 initial version
2010-05-06 02:08:41 +02:00

315 lines
8.6 KiB
C++

// Ryzom - MMORPG Framework <http://dev.ryzom.com/projects/ryzom/>
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
//-------------------------------------------------------------------------
// Includes & namespaces
#include "stdpch.h"
#include "ai_share/ai_spawn_commands.h"
#include "ai_grp.h"
using namespace NLMISC;
using namespace std;
//-------------------------------------------------------------------------
// The CAISpawnCtrl sub-class
//class CAISSpawnCtrl: public CAISpawnCtrl
//{
//protected:
// virtual bool _spawn (int aiInstance, const std::string &name);
// virtual bool _spawnMap (int aiInstance, const std::string &name);
// virtual bool _spawnMgr (int aiInstance, const std::string &name);
// virtual bool _spawnGrp (int aiInstance, const std::string &name);
// virtual bool _spawnAll (int aiInstance);
//
// virtual bool _despawn (int aiInstance, const std::string &name);
// virtual bool _despawnMap (int aiInstance, const std::string &name);
// virtual bool _despawnMgr (int aiInstance, const std::string &name);
// virtual bool _despawnGrp (int aiInstance, const std::string &name);
// virtual bool _despawnAll (int aiInstance);
//
//} AIServiceSpawnCtrl;
//-------------------------------------------------------------------------
// The CAISpawnCtrl singleton data
//CAISpawnCtrl *CAISpawnCtrl::_instance=&AIServiceSpawnCtrl;
//-------------------------------------------------------------------------
// SPAWNING
//bool CAISSpawnCtrl::_spawn(int aiInstance, const std::string &name)
//{
// if (_spawnMap(aiInstance, name)) return true;
// if (_spawnMgr(aiInstance, name)) return true;
// if (_spawnGrp(aiInstance, name)) return true;
// return false;
//}
//
//bool CAISSpawnCtrl::_spawnGrp(int aiInstance, const std::string &name)
//{
// bool returnVal=false;
//
// if (aiInstance==-1) // all aiInstance are concerned.
// {
// CCont<CAIInstance>::iterator instanceIt=CAIS::instance().AIList().begin(), instanceItEnd=CAIS::instance().AIList().end();
// while (instanceIt!=instanceItEnd)
// {
// CGroup* grpPtr=(*instanceIt)->tryToGetGroup(name.c_str());
// if (grpPtr)
// {
// grpPtr->spawn (); // check error only if not a npc group.
// returnVal=true;
// }
// ++instanceIt;
// }
//
// }
// else
// {
// if (CAIS::instance().AIList()[aiInstance])
// {
// CGroup* grpPtr=CAIS::instance().AIList()[aiInstance]->tryToGetGroup(name.c_str());
// if (grpPtr)
// {
// grpPtr->spawn (); // check error only if not a npc group.
// returnVal=true;
// }
//
// }
//
// }
//
// if (!returnVal)
// {
// nlinfo("Failed to identify groupe from id: %s",name.c_str());
// }
// return returnVal;
//}
//
//bool CAISSpawnCtrl::_spawnMgr(int aiInstance, const std::string &name)
//{
// bool returnVal=false;
//
// if (aiInstance==-1) // all aiInstance are concerned.
// {
// CCont<CAIInstance>::iterator instanceIt=CAIS::instance().AIList().begin(), instanceItEnd=CAIS::instance().AIList().end();
// while (instanceIt!=instanceItEnd)
// {
// CManager* mgrPtr=(*instanceIt)->tryToGetManager(name.c_str());
// if (mgrPtr)
// {
// mgrPtr->spawn (); // check error only if not a npc group.
// returnVal=true;
// }
// ++instanceIt;
// }
//
// }
// else
// {
// if (CAIS::instance().AIList()[aiInstance])
// {
// CManager* mgrPtr=CAIS::instance().AIList()[aiInstance]->tryToGetManager(name.c_str());
// if (mgrPtr)
// {
// mgrPtr->spawn (); // check error only if not a npc group.
// returnVal=true;
// }
//
// }
//
// }
//
// if (!returnVal)
// {
// nlinfo("Failed to identify mgr from id: %s",name.c_str());
// }
// return returnVal;
//}
//
//bool CAISSpawnCtrl::_spawnMap(int aiInstance, const std::string &name)
//{
//#ifdef NL_DEBUG
// nlassert(false);
//#endif
//// // for each manager if map's name found in the command arguments then spawn()
//// for (CAIEntityId it=CAIEntityId::firstMgr();!it.isInvalid();it=it.nextMgr())
//// if (it.mgrPtr()->getMap()->Name==name)
//// it.mgrPtr()->spawn();
// return true;
//}
//
//bool CAISSpawnCtrl::_spawnAll (int aiInstance)
//{
// if (aiInstance==-1) // all aiInstance are concerned.
// {
// CCont<CAIInstance>::iterator instanceIt=CAIS::instance().AIList().begin(), instanceItEnd=CAIS::instance().AIList().end();
// while (instanceIt!=instanceItEnd)
// {
// (*instanceIt)->spawnAll();
// ++instanceIt;
// }
//
// }
// else
// {
// if (CAIS::instance().AIList()[aiInstance])
// {
// CAIS::instance().AIList()[aiInstance]->spawnAll();
// }
//
// }
// return true;
//}
//
//
////-------------------------------------------------------------------------
//// DESPAWNING
//
//bool CAISSpawnCtrl::_despawn(int aiInstance, const std::string &name)
//{
// if (_despawnMap(aiInstance, name)) return true;
// if (_despawnMgr(aiInstance, name)) return true;
// if (_despawnGrp(aiInstance, name)) return true;
// return false;
//}
//
//bool CAISSpawnCtrl::_despawnGrp(int aiInstance, const std::string &name)
//{
//
// bool returnVal=false;
//
// if (aiInstance==-1) // all aiInstance are concerned.
// {
// CCont<CAIInstance>::iterator instanceIt=CAIS::instance().AIList().begin(), instanceItEnd=CAIS::instance().AIList().end();
// while (instanceIt!=instanceItEnd)
// {
// CGroup* grpPtr=(*instanceIt)->tryToGetGroup(name.c_str());
// if (grpPtr)
// {
// grpPtr->despawnGrp (); // check error only if not a npc group.
// returnVal=true;
// }
// ++instanceIt;
// }
//
// }
// else
// {
// if (CAIS::instance().AIList()[aiInstance])
// {
// CGroup* grpPtr=CAIS::instance().AIList()[aiInstance]->tryToGetGroup(name.c_str());
// if (grpPtr)
// {
// grpPtr->despawnGrp (); // check error only if not a npc group.
// returnVal=true;
// }
//
// }
//
// }
//
// if (!returnVal)
// {
// nlinfo("Failed to identify groupe from id: %s",name.c_str());
// }
// return returnVal;
//}
//
//bool CAISSpawnCtrl::_despawnMgr(int aiInstance, const std::string &name)
//{
// bool returnVal=false;
//
// if (aiInstance==-1) // all aiInstance are concerned.
// {
// CCont<CAIInstance>::iterator instanceIt=CAIS::instance().AIList().begin(), instanceItEnd=CAIS::instance().AIList().end();
// while (instanceIt!=instanceItEnd)
// {
// CManager* mgrPtr=(*instanceIt)->tryToGetManager(name.c_str());
// if (mgrPtr)
// {
// mgrPtr->despawnMgr(); // check error only if not a npc group.
// returnVal=true;
// }
// ++instanceIt;
// }
//
// }
// else
// {
// if (CAIS::instance().AIList()[aiInstance])
// {
// CManager* mgrPtr=CAIS::instance().AIList()[aiInstance]->tryToGetManager(name.c_str());
// if (mgrPtr)
// {
// mgrPtr->despawnMgr(); // check error only if not a npc group.
// returnVal=true;
// }
//
// }
//
// }
//
// if (!returnVal)
// {
// nlinfo("Failed to identify mgr from id: %s",name.c_str());
// }
// return returnVal;
//}
//
//bool CAISSpawnCtrl::_despawnMap(int aiInstance, const std::string &name)
//{
//#ifdef NL_DEBUG
// nlwarning("Not Implemented");
//#endif
//
//// // for each manager if map's name found in the command arguments then spawn()
//// for (CAIEntityId it=CAIEntityId::firstMgr();!it.isInvalid();it=it.nextMgr())
//// if (it.mgrPtr()->getMap()->Name==name)
//// it.mgrPtr()->despawn();
//
// return true;
//}
//
//bool CAISSpawnCtrl::_despawnAll(int aiInstance)
//{
// if (aiInstance==-1) // all aiInstance are concerned.
// {
// CCont<CAIInstance>::iterator instanceIt=CAIS::instance().AIList().begin(), instanceItEnd=CAIS::instance().AIList().end();
// while (instanceIt!=instanceItEnd)
// {
//// NLMEMORY::CheckHeap(true);
// (*instanceIt)->despawnAll();
// ++instanceIt;
// }
//
// }
// else
// {
// if (CAIS::instance().AIList()[aiInstance])
// {
// CAIS::instance().AIList()[aiInstance]->despawnAll();
// }
//
// }
// return true;
//}