Removed: useless backup files
parent
de9ba8fbe4
commit
e1242bffea
@ -1,24 +0,0 @@
|
|||||||
/** This file declare a pure nel module library */
|
|
||||||
|
|
||||||
|
|
||||||
#include "nel/net/module_manager.h"
|
|
||||||
#include "nel/net/module.h"
|
|
||||||
#include "nel/net/module_builder_parts.h"
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
using namespace NLMISC;
|
|
||||||
using namespace NLNET;
|
|
||||||
|
|
||||||
extern void as_forceLink();
|
|
||||||
extern void aes_forceLink();
|
|
||||||
extern void aesclient_forceLink();
|
|
||||||
|
|
||||||
void admin_modules_forceLink()
|
|
||||||
{
|
|
||||||
as_forceLink();
|
|
||||||
aes_forceLink();
|
|
||||||
aesclient_forceLink();
|
|
||||||
}
|
|
||||||
|
|
||||||
//NLMISC_DECL_PURE_LIB(CNelModuleLibrary);
|
|
||||||
|
|
@ -1,485 +0,0 @@
|
|||||||
/** \file actor_manager.cpp
|
|
||||||
*
|
|
||||||
* the actor manager for AgS_Test
|
|
||||||
*
|
|
||||||
* $Id: actor_manager.cpp,v 1.34 2004/06/14 12:34:17 brigand Exp $
|
|
||||||
* $Log: actor_manager.cpp,v $
|
|
||||||
* Revision 1.34 2004/06/14 12:34:17 brigand
|
|
||||||
* CHANGED : updated to new PDS people enum
|
|
||||||
*
|
|
||||||
* Revision 1.33 2004/03/01 19:18:37 lecroart
|
|
||||||
* REMOVED: bad headers
|
|
||||||
*
|
|
||||||
* Revision 1.32 2004/01/13 18:47:07 cado
|
|
||||||
* ADDED: Mirror tests
|
|
||||||
*
|
|
||||||
* Revision 1.31 2003/10/21 08:48:19 legros
|
|
||||||
* ADDED: multi target commands
|
|
||||||
*
|
|
||||||
* Revision 1.30 2003/10/02 16:13:15 legros
|
|
||||||
* no message
|
|
||||||
*
|
|
||||||
* Revision 1.29 2003/10/01 14:29:32 legros
|
|
||||||
* no message
|
|
||||||
*
|
|
||||||
* Revision 1.28 2003/09/30 16:03:15 legros
|
|
||||||
* CHANGED: ags test is now up to date...
|
|
||||||
*
|
|
||||||
* Revision 1.27 2003/07/16 15:51:19 cado
|
|
||||||
* CHANGED: First-pass to re-adapt to mirror system V1.4
|
|
||||||
*
|
|
||||||
* Revision 1.26 2003/07/16 14:34:06 boucher
|
|
||||||
* no message
|
|
||||||
*
|
|
||||||
* Revision 1.25 2003/02/26 10:24:19 cado
|
|
||||||
* CHANGED: changed all properties to new mirror, no more old mirror
|
|
||||||
*
|
|
||||||
* Revision 1.24 2003/02/24 10:44:44 cado
|
|
||||||
* ADDED: Adapted for new mirror system
|
|
||||||
*
|
|
||||||
* Revision 1.23 2003/01/28 20:36:51 miller
|
|
||||||
* Changed header comments from 'Nel Network Services' to Ryzom
|
|
||||||
*
|
|
||||||
* Revision 1.22 2002/11/29 10:17:50 portier
|
|
||||||
* #ADDED: ia_player.id
|
|
||||||
*
|
|
||||||
* Revision 1.21.2.1 2003/01/03 18:18:02 cado
|
|
||||||
* ADDED: Integration with new mirror system
|
|
||||||
*
|
|
||||||
* Revision 1.21 2002/11/15 16:22:42 fleury
|
|
||||||
* CHANGED : the OPS has been replaced by the EGS
|
|
||||||
*
|
|
||||||
* Revision 1.20 2002/08/30 08:47:34 miller
|
|
||||||
* another quick test (non destructive)
|
|
||||||
*
|
|
||||||
* Revision 1.19 2002/08/30 08:46:09 miller
|
|
||||||
* quick test (non destructive)
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Nel
|
|
||||||
//#include "nel/net/service.h"
|
|
||||||
|
|
||||||
|
|
||||||
// Local headers
|
|
||||||
#include "position_generator.h"
|
|
||||||
#include "actor_manager.h"
|
|
||||||
#include "sheets.h"
|
|
||||||
#include <nel/net/unified_network.h>
|
|
||||||
#include "game_share/people.h"
|
|
||||||
#include "game_share/synchronised_message.h"
|
|
||||||
|
|
||||||
#include "nel/misc/variable.h"
|
|
||||||
|
|
||||||
#include <set>
|
|
||||||
|
|
||||||
using namespace NLMISC;
|
|
||||||
using namespace NLNET;
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
|
|
||||||
namespace AGS_TEST
|
|
||||||
{
|
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
|
||||||
// Some global variables
|
|
||||||
extern uint32 GlobalActorCount;
|
|
||||||
extern uint32 GlobalActorUpdates;
|
|
||||||
extern uint32 GlobalActorMoves;
|
|
||||||
|
|
||||||
CEntityId LastActorId;
|
|
||||||
|
|
||||||
NLMISC_DYNVARIABLE(string, LastActorId, "Last created actor")
|
|
||||||
{
|
|
||||||
if (get)
|
|
||||||
*pointer = LastActorId.toString();
|
|
||||||
else
|
|
||||||
LastActorId.fromString((*pointer).c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
|
||||||
// Some function prototypes
|
|
||||||
|
|
||||||
static void cbServiceUp( const string& serviceName, uint16 serviceId, void * );
|
|
||||||
static void cbServiceDown( const string& serviceName, uint16 serviceId, void * );
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------
|
|
||||||
// static data for CActorManager
|
|
||||||
|
|
||||||
std::vector<CActor*> CActorManager::_actors;
|
|
||||||
std::vector<CActorGroup*> CActorManager::_actorGroups;
|
|
||||||
int CActorManager::_nextActorID=0;
|
|
||||||
std::set<uint> CActorManager::_visionHandlingServices;
|
|
||||||
CActorGroup *CActorManager::_defaultActorGroup;
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------
|
|
||||||
// basic functionality for CActorManager singleton
|
|
||||||
|
|
||||||
void CActorManager::init()
|
|
||||||
{
|
|
||||||
static bool first_time=true;
|
|
||||||
|
|
||||||
if (first_time)
|
|
||||||
{
|
|
||||||
// Init callback for service up / down
|
|
||||||
CUnifiedNetwork::getInstance()->setServiceUpCallback ("*", cbServiceUp, NULL);
|
|
||||||
CUnifiedNetwork::getInstance()->setServiceDownCallback("*", cbServiceDown, NULL);
|
|
||||||
first_time=false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
release();
|
|
||||||
|
|
||||||
_nextActorID=0;
|
|
||||||
/*
|
|
||||||
CPositionGenerator::setPattern(std::string("grid"));
|
|
||||||
CPositionGenerator::setPosition(17981,-33200);
|
|
||||||
CPositionGenerator::setSpacing(2000);
|
|
||||||
*/
|
|
||||||
_defaultActorGroup = newActorGroup("defaultGroup");
|
|
||||||
}
|
|
||||||
|
|
||||||
void CActorManager::update()
|
|
||||||
{
|
|
||||||
set< pair<sint32, sint32> > iaZones;
|
|
||||||
|
|
||||||
std::vector<CActorGroup*>::iterator itg;
|
|
||||||
for (itg=_actorGroups.begin(); itg!=_actorGroups.end(); ++itg)
|
|
||||||
(*itg)->update();
|
|
||||||
|
|
||||||
|
|
||||||
// iterate through all known actors, calling their update
|
|
||||||
uint16 positionChangeCount=0;
|
|
||||||
uint16 updateCount=0;
|
|
||||||
std::vector<CActor*>::iterator it;
|
|
||||||
for (it=_actors.begin(); it!=_actors.end(); ++it)
|
|
||||||
{
|
|
||||||
bool updated= (*it)->update();
|
|
||||||
if (updated)
|
|
||||||
updateCount++;
|
|
||||||
/*
|
|
||||||
if ((*it)->positionChanged())
|
|
||||||
positionChangeCount++;
|
|
||||||
|
|
||||||
sint32 zx = (*it)->getX()/160000;
|
|
||||||
sint32 zy = -(*it)->getY()/160000;
|
|
||||||
|
|
||||||
iaZones.insert(make_pair<sint32,sint32>(zx, zy));
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// for all entities, request vision zones
|
|
||||||
/*CMessage msg("AGENT_VISON");
|
|
||||||
sint64 fakeId = 0;
|
|
||||||
msg.serial(fakeId);
|
|
||||||
sint32 pos = msg.getPos();
|
|
||||||
set< pair<sint32, sint32> >::iterator itz;
|
|
||||||
for (itz=iaZones.begin(); itz!=iaZones.end(); ++itz)
|
|
||||||
{
|
|
||||||
sint32 x = (*itz).first,
|
|
||||||
y = (*itz).second;
|
|
||||||
msg.serial(x);
|
|
||||||
msg.serial(y);
|
|
||||||
}
|
|
||||||
if (msg.getPos() > pos)
|
|
||||||
CUnifiedNetwork::getInstance()->send("GPMS", msg);*/
|
|
||||||
/*
|
|
||||||
// build the position changed message and send it to GPMS
|
|
||||||
if (positionChangeCount>0)
|
|
||||||
{
|
|
||||||
NLNET::CMessage gpmPosMsg("UPDATE_ENTITIES_POSITIONS");
|
|
||||||
gpmPosMsg.serial(positionChangeCount);
|
|
||||||
for (it=_actors.begin(); it!=_actors.end(); ++it)
|
|
||||||
(*it)->addPositionChangesToMessage(gpmPosMsg);
|
|
||||||
|
|
||||||
sendMessageViaMirror( "GPMS", gpmPosMsg );
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
GlobalActorUpdates=updateCount;
|
|
||||||
//GlobalActorMoves=positionChangeCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CActorManager::release()
|
|
||||||
{
|
|
||||||
std::vector<CActor*>::iterator it;
|
|
||||||
for (it=_actors.begin(); it!=_actors.end(); ++it)
|
|
||||||
{
|
|
||||||
(*it)->removeFromOtherServices();
|
|
||||||
}
|
|
||||||
_actors.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Callback called at service connexion
|
|
||||||
static void cbServiceUp( const string& serviceName, uint16 serviceId, void * )
|
|
||||||
{
|
|
||||||
/*if (serviceName==std::string("EGS"))
|
|
||||||
CActorManager::reconnectEGS((uint8)serviceId);
|
|
||||||
|
|
||||||
if (serviceName==std::string("IOS"))
|
|
||||||
CActorManager::reconnectIOS((uint8)serviceId);
|
|
||||||
|
|
||||||
if (serviceName==std::string("GPMS"))
|
|
||||||
CActorManager::reconnectGPMS((uint8)serviceId);*/
|
|
||||||
|
|
||||||
/*CMessage reqVision("ASK_VISION_ZONE");
|
|
||||||
CUnifiedNetwork::getInstance()->send(serviceId, reqVision);*/
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
static void cbServiceDown( const string& serviceName, uint16 serviceId, void * )
|
|
||||||
{
|
|
||||||
CActorManager::removeVisionService(serviceId);
|
|
||||||
}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------
|
|
||||||
// methods for dealing with tardy connection of a key service
|
|
||||||
/*void CActorManager::reconnectEGS(uint8 serviceId)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void CActorManager::reconnectIOS(uint8 serviceId)
|
|
||||||
{
|
|
||||||
std::vector<CActor*>::iterator it;
|
|
||||||
for (it=_actors.begin(); it!=_actors.end(); ++it)
|
|
||||||
{
|
|
||||||
(*it)->addToIOS(serviceId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void CActorManager::reconnectGPMS(uint8 serviceId)
|
|
||||||
{
|
|
||||||
std::vector<CActor*>::iterator it;
|
|
||||||
for (it=_actors.begin(); it!=_actors.end(); ++it)
|
|
||||||
{
|
|
||||||
(*it)->addToGPMS(serviceId);
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------
|
|
||||||
// CActorManager methods for creating and killing actors
|
|
||||||
|
|
||||||
// method for adding a new actor to the scene
|
|
||||||
CActor *CActorManager::newActor(const std::string &type, const std::string &name)
|
|
||||||
{
|
|
||||||
LastActorId = CEntityId::Unknown;
|
|
||||||
|
|
||||||
if (getActor(name)!=NULL)
|
|
||||||
{
|
|
||||||
nlinfo("Actor already exists: %s",name.c_str());
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
CSheetId sheetId(type);
|
|
||||||
const CSheets::CSheet *sheet=CSheets::lookup(sheetId);
|
|
||||||
if (!sheet)
|
|
||||||
{
|
|
||||||
nlwarning("ERROR: Can't find static type data for '%s'(%d) for entity %s", type.c_str(), sheetId.asInt(), name.c_str());
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
// create a new actor record and COPY it into the actor vector
|
|
||||||
|
|
||||||
// EGSPD::CPeople::TPeople p_type = EGSPD::CPeople::fromString( type );
|
|
||||||
bool success = false;
|
|
||||||
CActor *aNewActor;
|
|
||||||
if ( sheet->isNpc /*EGSPD::CPeople::isPlayableRace( p_type )*/ )
|
|
||||||
aNewActor = new CActor(type,name,CEntityId(RYZOMID::npc,_nextActorID++),success);
|
|
||||||
else
|
|
||||||
aNewActor = new CActor(type,name,CEntityId(RYZOMID::creature,_nextActorID++),success);
|
|
||||||
|
|
||||||
if ( ! success )
|
|
||||||
{
|
|
||||||
if (aNewActor)
|
|
||||||
delete aNewActor;
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
LastActorId = aNewActor->_id;
|
|
||||||
|
|
||||||
int x,y;
|
|
||||||
CPositionGenerator::next(x,y);
|
|
||||||
aNewActor->setPos(x, y, 0);
|
|
||||||
aNewActor->setAngle(0);
|
|
||||||
_actors.push_back(aNewActor);
|
|
||||||
|
|
||||||
// get hold of a pointer of the copy of the actor in the actor vector
|
|
||||||
CActor *theActor=getActor(name);
|
|
||||||
|
|
||||||
// add the actor to the GPMS, the IOS, etc
|
|
||||||
if (theActor!=0)
|
|
||||||
theActor->addToOtherServices();
|
|
||||||
/*
|
|
||||||
CMessage msgMode("SET_MODE");
|
|
||||||
TDataSetRow index = CMirrors::DataSet->getDataSetRow(theActor->_id);
|
|
||||||
msgMode.serial(index);
|
|
||||||
MBEHAV::TMode mode(MBEHAV::NORMAL, x, y);
|
|
||||||
msgMode.serial(mode);
|
|
||||||
sendMessageViaMirror("EGS", msgMode);
|
|
||||||
*/
|
|
||||||
CMirrors::initSheet( aNewActor->getSid(), sheetId ); // initialize out the sheet
|
|
||||||
// Let the position & angle & tick be sent ("UPDATE_ENTITIES_POSITIONS") in update
|
|
||||||
//aNewActor->initMode();
|
|
||||||
|
|
||||||
MBEHAV::TMode mode(MBEHAV::NORMAL, x, y);
|
|
||||||
theActor->_mode = mode.RawModeAndParam;
|
|
||||||
|
|
||||||
aNewActor->display();
|
|
||||||
theActor->setGroup(_defaultActorGroup);
|
|
||||||
|
|
||||||
GlobalActorCount++;
|
|
||||||
return theActor;
|
|
||||||
}
|
|
||||||
|
|
||||||
// method for retrievng a pointer to a named actor
|
|
||||||
// returns NULL if the actor doesn't exist
|
|
||||||
CActor *CActorManager::getActor(const std::string &name)
|
|
||||||
{
|
|
||||||
std::vector<CActor*>::iterator it;
|
|
||||||
for (it=_actors.begin(); it!=_actors.end(); ++it)
|
|
||||||
{
|
|
||||||
if ((*it)->getName()==name)
|
|
||||||
return (*it);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// method for retrievng a pointer to given actor
|
|
||||||
CActor *CActorManager::getActor(unsigned index)
|
|
||||||
{
|
|
||||||
if (index>=_actors.size())
|
|
||||||
return NULL;
|
|
||||||
else
|
|
||||||
return (_actors[index]);
|
|
||||||
}
|
|
||||||
|
|
||||||
// method for retrievng a pointer to given actor
|
|
||||||
CActor *CActorManager::getActor(const NLMISC::CEntityId &id)
|
|
||||||
{
|
|
||||||
std::vector<CActor*>::iterator it;
|
|
||||||
for (it=_actors.begin(); it!=_actors.end(); ++it)
|
|
||||||
{
|
|
||||||
if ((*it)->getSid()==id)
|
|
||||||
return (*it);
|
|
||||||
}
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CActorManager::killActor(const std::string &name)
|
|
||||||
{
|
|
||||||
std::vector<CActor*>::iterator it;
|
|
||||||
for (it=_actors.begin(); it!=_actors.end(); ++it)
|
|
||||||
{
|
|
||||||
if ((*it)->getName()==name)
|
|
||||||
{
|
|
||||||
// remove from net refferences
|
|
||||||
(*it)->removeFromOtherServices();
|
|
||||||
|
|
||||||
// remove from vision xrefs
|
|
||||||
std::vector<CActor*>::iterator it2;
|
|
||||||
for (it2=_actors.begin(); it2!=_actors.end(); ++it2)
|
|
||||||
{
|
|
||||||
(*it2)->removeRefs(*it);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (int i=_actorGroups.size();i--;)
|
|
||||||
_actorGroups[i]->removeActor(*it);
|
|
||||||
|
|
||||||
// remove from container
|
|
||||||
delete *it;
|
|
||||||
_actors.erase(it);
|
|
||||||
GlobalActorCount--;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------
|
|
||||||
// basic functionality for actor group management
|
|
||||||
|
|
||||||
// method for adding a new actorGroup to the scene
|
|
||||||
CActorGroup *CActorManager::newActorGroup(const std::string &name)
|
|
||||||
{
|
|
||||||
if (!getActorGroup(name))
|
|
||||||
{
|
|
||||||
// create a new actorGroup record and COPY it into the actorGroup vector
|
|
||||||
CActorGroup *aNewActorGroup = new CActorGroup(name);
|
|
||||||
_actorGroups.push_back(aNewActorGroup);
|
|
||||||
aNewActorGroup->display();
|
|
||||||
}
|
|
||||||
|
|
||||||
// get hold of a pointer of the copy of the actorGroup in the actorGroup vector
|
|
||||||
return getActorGroup(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
// method for retrievng a pointer to a named actorGroup
|
|
||||||
// returns NULL if the actorGroup doesn't exist
|
|
||||||
CActorGroup *CActorManager::getActorGroup(const std::string &name)
|
|
||||||
{
|
|
||||||
std::vector<CActorGroup*>::iterator it;
|
|
||||||
for (it=_actorGroups.begin(); it!=_actorGroups.end(); ++it)
|
|
||||||
{
|
|
||||||
if ((*it)->getName()==name)
|
|
||||||
return (*it);
|
|
||||||
}
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
// method for retrievng a pointer to given actorGroup
|
|
||||||
CActorGroup *CActorManager::getActorGroup(unsigned index)
|
|
||||||
{
|
|
||||||
if (index>=_actorGroups.size())
|
|
||||||
return NULL;
|
|
||||||
else
|
|
||||||
return (_actorGroups[index]);
|
|
||||||
}
|
|
||||||
|
|
||||||
void CActorManager::removeActorGroup(const std::string &name)
|
|
||||||
{
|
|
||||||
std::vector<CActorGroup*>::iterator it;
|
|
||||||
for (it=_actorGroups.begin(); it!=_actorGroups.end(); ++it)
|
|
||||||
{
|
|
||||||
if ((*it)->getName()==name)
|
|
||||||
{
|
|
||||||
// remove all actors from this group into default group
|
|
||||||
uint i;
|
|
||||||
for (i=0; i<(*it)->actorCount(); ++i)
|
|
||||||
(*(*it))[i]->setGroup(_defaultActorGroup);
|
|
||||||
|
|
||||||
// remove from container
|
|
||||||
delete (*it);
|
|
||||||
_actorGroups.erase(it);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
void CActorManager::setActorsToGroup(const std::string &sourceActorGroup, const std::string &destActorGroup)
|
|
||||||
{
|
|
||||||
CActorGroup *srcGroup = getActorGroup(sourceActorGroup);
|
|
||||||
if (srcGroup == NULL)
|
|
||||||
{
|
|
||||||
nlwarning("source actor group '%s' is unknown, abort setActorsToGroup(%s, %s)", sourceActorGroup.c_str(), sourceActorGroup.c_str(), destActorGroup.c_str());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
CActorGroup *destGroup = getActorGroup(destActorGroup);
|
|
||||||
if (destGroup == NULL)
|
|
||||||
{
|
|
||||||
nlwarning("destination actor group '%s' is unknown, abort setActorsToGroup(%s, %s)", destActorGroup.c_str(), sourceActorGroup.c_str(), destActorGroup.c_str());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint i;
|
|
||||||
for (i=0; i<srcGroup->actorCount(); ++i)
|
|
||||||
(*srcGroup)[i]->setGroup(destGroup);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // end of namespace AGS_TEST
|
|
@ -1,61 +0,0 @@
|
|||||||
/** \file actor_manager.cpp
|
|
||||||
*
|
|
||||||
* the actor manager for AgS_Test
|
|
||||||
*
|
|
||||||
* $Id: ags_timer.cpp,v 1.3 2004/03/01 19:18:37 lecroart Exp $
|
|
||||||
* $Log: ags_timer.cpp,v $
|
|
||||||
* Revision 1.3 2004/03/01 19:18:37 lecroart
|
|
||||||
* REMOVED: bad headers
|
|
||||||
*
|
|
||||||
* Revision 1.2 2003/01/28 20:36:51 miller
|
|
||||||
* Changed header comments from 'Nel Network Services' to Ryzom
|
|
||||||
*
|
|
||||||
* Revision 1.1 2002/11/28 14:57:17 portier
|
|
||||||
* #ADDED: ia_player.id
|
|
||||||
*
|
|
||||||
* Revision 1.21 2002/11/15 16:22:42 fleury
|
|
||||||
* CHANGED : the OPS has been replaced by the EGS
|
|
||||||
*
|
|
||||||
* Revision 1.20 2002/08/30 08:47:34 miller
|
|
||||||
* another quick test (non destructive)
|
|
||||||
*
|
|
||||||
* Revision 1.19 2002/08/30 08:46:09 miller
|
|
||||||
* quick test (non destructive)
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#include "ags_timer.h"
|
|
||||||
#include "game_share/tick_event_handler.h"
|
|
||||||
|
|
||||||
namespace AGS_TEST
|
|
||||||
{
|
|
||||||
CAGSTimer::CAGSTimer(uint32 dt /*= 0*/)
|
|
||||||
{
|
|
||||||
_dt = dt;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CAGSTimer::set(uint32 dt)
|
|
||||||
{
|
|
||||||
_start = (uint32)CTickEventHandler::getGameCycle();
|
|
||||||
_dt = dt;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CAGSTimer::add(uint32 dt)
|
|
||||||
{
|
|
||||||
_start = (uint32)CTickEventHandler::getGameCycle();
|
|
||||||
_dt += dt;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool CAGSTimer::test()
|
|
||||||
{
|
|
||||||
uint32 curent = (uint32) CTickEventHandler::getGameCycle();
|
|
||||||
|
|
||||||
uint32 elapsed = curent - _start;
|
|
||||||
|
|
||||||
return ( elapsed >= _dt );
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -1,359 +0,0 @@
|
|||||||
/** \file ai_profile_fauna.h
|
|
||||||
*
|
|
||||||
* $Id: ai_profile_fauna.h,v 1.8 2005/08/09 12:38:24 vuarand Exp $
|
|
||||||
*
|
|
||||||
* This file defines the classes:
|
|
||||||
* - CPlanteIdleFaunaProfile
|
|
||||||
* - CStaticPlanteIdleFaunaProfile
|
|
||||||
* - CAIFaunaActivityBaseSpawnProfile
|
|
||||||
* - CWanderFaunaProfile
|
|
||||||
* - CStaticWanderFaunaProfile
|
|
||||||
* - CGrazeFaunaProfile
|
|
||||||
* - CStaticGrazeFaunaProfile
|
|
||||||
* - CRestFaunaProfile
|
|
||||||
* - CStaticRestFaunaProfile
|
|
||||||
* - CStaticFightFaunaProfile
|
|
||||||
* - CCorpseFaunaProfileFactory
|
|
||||||
* - CEatCorpseFaunaProfile
|
|
||||||
* - CStaticEatCorpseFaunaProfile
|
|
||||||
* - CCuriosityFaunaProfile
|
|
||||||
* - CStaticCuriosityFaunaProfile
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef AI_PROFILE_FAUNA_H
|
|
||||||
#define AI_PROFILE_FAUNA_H
|
|
||||||
|
|
||||||
#include "profile.h" // for CAIBaseProfile
|
|
||||||
#include "path_behaviors.h" // for CPathPosition
|
|
||||||
#include "ai_bot_fauna.h" // for CCorpseFaunaProfile
|
|
||||||
#include "ai_grp_fauna.h"
|
|
||||||
#include "ai_mgr_fauna.h"
|
|
||||||
|
|
||||||
class CSpawnBotFauna;
|
|
||||||
class CMovementMagnet;
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------
|
|
||||||
// Debug defines
|
|
||||||
// ---------------------------------------------------------------------------
|
|
||||||
// COMPACT_POS_WARNINGS compress flooding warnings concerning path problems.
|
|
||||||
// Positions where the problems occures are stored and displayed and cleared
|
|
||||||
// every minute.
|
|
||||||
// :TODO: /!\ As it cannot be tested without long-time run with several
|
|
||||||
// players the following define can be commented to restore previous behavior.
|
|
||||||
#define COMPACT_POS_WARNINGS 1
|
|
||||||
|
|
||||||
class CFaunaProfileFloodLogger
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
typedef std::map<std::string, int> TLogPositions;
|
|
||||||
|
|
||||||
public:
|
|
||||||
CFaunaProfileFloodLogger(int period)
|
|
||||||
: logLastTick(0)
|
|
||||||
, logPeriod(period)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
|
||||||
TLogPositions logPositions;
|
|
||||||
int logLastTick;
|
|
||||||
int logPeriod;
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CPlanteIdleFaunaProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CPlanteIdleFaunaProfile
|
|
||||||
: public CAIBaseProfile
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CPlanteIdleFaunaProfile(CProfileOwner* owner);
|
|
||||||
|
|
||||||
/// @name IAIProfile implementation
|
|
||||||
//@{
|
|
||||||
virtual void beginProfile();
|
|
||||||
virtual void updateProfile(uint ticksSinceLastUpdate);
|
|
||||||
virtual void endProfile();
|
|
||||||
virtual AITYPES::TProfiles getAIProfileType() const { return AITYPES::ACTIVITY_PLANTIDLE; }
|
|
||||||
virtual std::string getOneLineInfoString() const;
|
|
||||||
//@}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
CSpawnBotFauna* _Bot;
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CAIFaunaActivityBaseSpawnProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CAIFaunaActivityBaseSpawnProfile
|
|
||||||
: public CAIBaseProfile
|
|
||||||
, public IMouvementMagnetOwner
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CAIFaunaActivityBaseSpawnProfile(CProfileOwner* owner);
|
|
||||||
|
|
||||||
virtual NLMISC::CSmartPtr<CMovementMagnet> const& getMovementMagnet() const;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
NLMISC::CSmartPtr<CMovementMagnet> _MovementMagnet;
|
|
||||||
CPathPosition _PathPos;
|
|
||||||
bool _OutOfMagnet;
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CWanderFaunaProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CWanderFaunaProfile
|
|
||||||
: public CAIFaunaActivityBaseSpawnProfile
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CWanderFaunaProfile(CProfileOwner* owner);
|
|
||||||
|
|
||||||
/// @name IAIProfile implementation
|
|
||||||
//@{
|
|
||||||
virtual void beginProfile();
|
|
||||||
virtual void updateProfile(uint ticksSinceLastUpdate);
|
|
||||||
virtual void endProfile();
|
|
||||||
virtual AITYPES::TProfiles getAIProfileType() const { return AITYPES::ACTIVITY_WANDERING; }
|
|
||||||
virtual std::string getOneLineInfoString() const;
|
|
||||||
//@}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
RYAI_MAP_CRUNCH::TAStarFlag _DenyFlags;
|
|
||||||
CSpawnBotFauna* _Bot;
|
|
||||||
double _magnetDist; ///< distance from bot to his magnet at last move
|
|
||||||
static CFaunaProfileFloodLogger _FloodLogger;
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CGrazeFaunaProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CGrazeFaunaProfile
|
|
||||||
: public CAIFaunaActivityBaseSpawnProfile
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CGrazeFaunaProfile(CProfileOwner* owner);
|
|
||||||
|
|
||||||
/// @name IAIProfile implementation
|
|
||||||
//@{
|
|
||||||
virtual void beginProfile();
|
|
||||||
virtual void updateProfile(uint ticksSinceLastUpdate);
|
|
||||||
virtual void endProfile();
|
|
||||||
virtual AITYPES::TProfiles getAIProfileType() const { return AITYPES::ACTIVITY_GRAZING; }
|
|
||||||
virtual std::string getOneLineInfoString() const;
|
|
||||||
//@}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
CSpawnBotFauna* _Bot;
|
|
||||||
private:
|
|
||||||
CAITimer _CycleTimer;
|
|
||||||
uint _CycleTimerBaseTime;
|
|
||||||
bool _ArrivedInZone;
|
|
||||||
double _magnetDist; ///< distance from bot to his magnet at last move
|
|
||||||
RYAI_MAP_CRUNCH::TAStarFlag _DenyFlags;
|
|
||||||
static CFaunaProfileFloodLogger _FloodLogger;
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CRestFaunaProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CRestFaunaProfile
|
|
||||||
: public CAIFaunaActivityBaseSpawnProfile
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CRestFaunaProfile(CProfileOwner* owner);
|
|
||||||
|
|
||||||
/// @name IAIProfile implementation
|
|
||||||
//@{
|
|
||||||
virtual void beginProfile();
|
|
||||||
virtual void updateProfile(uint ticksSinceLastUpdate);
|
|
||||||
virtual void endProfile();
|
|
||||||
virtual AITYPES::TProfiles getAIProfileType() const { return AITYPES::ACTIVITY_RESTING; }
|
|
||||||
virtual std::string getOneLineInfoString() const;
|
|
||||||
//@}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
CSpawnBotFauna* _Bot;
|
|
||||||
private:
|
|
||||||
CAITimer _CycleTimer;
|
|
||||||
uint _CycleTimerBaseTime;
|
|
||||||
bool _ArrivedInZone;
|
|
||||||
double _magnetDist; // distance from bot to his magnet at last move
|
|
||||||
RYAI_MAP_CRUNCH::TAStarFlag _DenyFlags;
|
|
||||||
static CFaunaProfileFloodLogger _FloodLogger;
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CEatCorpseFaunaProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CEatCorpseFaunaProfile
|
|
||||||
: public CAIBaseProfile
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CEatCorpseFaunaProfile(CProfileOwner* owner, TDataSetRow const& corpse, RYAI_MAP_CRUNCH::TAStarFlag flag);
|
|
||||||
|
|
||||||
/// @name IAIProfile implementation
|
|
||||||
//@{
|
|
||||||
virtual void beginProfile();
|
|
||||||
virtual void updateProfile(uint ticksSinceLastUpdate);
|
|
||||||
virtual void endProfile();
|
|
||||||
virtual AITYPES::TProfiles getAIProfileType() const { return AITYPES::ACTIVITY_EAT_CORPSE; }
|
|
||||||
virtual std::string getOneLineInfoString() const;
|
|
||||||
//@}
|
|
||||||
|
|
||||||
TDataSetRow _eated;
|
|
||||||
protected:
|
|
||||||
CSpawnBotFauna* _Bot;
|
|
||||||
private:
|
|
||||||
bool _atGoodDist;
|
|
||||||
CAITimer _eatTimer;
|
|
||||||
CPathPosition _PathPos;
|
|
||||||
CPathCont _PathCont;
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CCuriosityFaunaProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CCuriosityFaunaProfile
|
|
||||||
: public CAIBaseProfile
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CCuriosityFaunaProfile(CProfileOwner* owner, TDataSetRow const& player, RYAI_MAP_CRUNCH::TAStarFlag flag);
|
|
||||||
|
|
||||||
/// @name IAIProfile implementation
|
|
||||||
//@{
|
|
||||||
virtual void beginProfile();
|
|
||||||
virtual void updateProfile(uint ticksSinceLastUpdate);
|
|
||||||
virtual void endProfile();
|
|
||||||
virtual AITYPES::TProfiles getAIProfileType() const { return AITYPES::ACTIVITY_CURIOSITY; }
|
|
||||||
virtual std::string getOneLineInfoString() const;
|
|
||||||
//@}
|
|
||||||
|
|
||||||
TDataSetRow _player;
|
|
||||||
protected:
|
|
||||||
CSpawnBotFauna* _Bot;
|
|
||||||
private:
|
|
||||||
bool _atGoodDist;
|
|
||||||
CAITimer _curiosityTimer;
|
|
||||||
CPathPosition _PathPos;
|
|
||||||
CPathCont _PathCont;
|
|
||||||
uint32 _addCuriosityTime;
|
|
||||||
bool _TooFar;
|
|
||||||
RYAI_MAP_CRUNCH::TAStarFlag _Flag;
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CCorpseFaunaProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CCorpseFaunaProfile
|
|
||||||
: public CAIBaseProfile
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CCorpseFaunaProfile(CProfileOwner* owner);
|
|
||||||
|
|
||||||
virtual void beginProfile();
|
|
||||||
|
|
||||||
virtual void endProfile() { }
|
|
||||||
|
|
||||||
virtual void updateProfile(uint ticksSinceLastUpdate) { }
|
|
||||||
|
|
||||||
virtual std::string getOneLineInfoString() const { return NLMISC::toString("corpse fauna profile"); }
|
|
||||||
|
|
||||||
virtual AITYPES::TProfiles getAIProfileType() const { return AITYPES::ACTIVITY_CORPSE; }
|
|
||||||
|
|
||||||
bool eated() const { return _Eated; }
|
|
||||||
void setEated(bool eated) { _Eated = eated; }
|
|
||||||
|
|
||||||
void setEater(bool eater) { _HaveEater = eater; }
|
|
||||||
bool haveEater() const { return _HaveEater; }
|
|
||||||
|
|
||||||
protected:
|
|
||||||
CSpawnBotFauna* _Bot;
|
|
||||||
|
|
||||||
private:
|
|
||||||
bool _HaveEater;
|
|
||||||
bool _Eated;
|
|
||||||
};
|
|
||||||
|
|
||||||
/****************************************************************************/
|
|
||||||
/* Profile factories */
|
|
||||||
/****************************************************************************/
|
|
||||||
|
|
||||||
//- Simple profile factories -------------------------------------------------
|
|
||||||
|
|
||||||
// CPlanteIdleFaunaProfileFactory
|
|
||||||
typedef CAIGenericProfileFactory<CPlanteIdleFaunaProfile> CPlanteIdleFaunaProfileFactory;
|
|
||||||
|
|
||||||
// CWanderFaunaProfileFactory
|
|
||||||
typedef CAIGenericProfileFactory<CWanderFaunaProfile> CWanderFaunaProfileFactory;
|
|
||||||
|
|
||||||
// CGrazeFaunaProfileFactory
|
|
||||||
typedef CAIGenericProfileFactory<CGrazeFaunaProfile> CGrazeFaunaProfileFactory;
|
|
||||||
|
|
||||||
// CRestFaunaProfileFactory
|
|
||||||
typedef CAIGenericProfileFactory<CRestFaunaProfile> CRestFaunaProfileFactory;
|
|
||||||
|
|
||||||
// CCorpseFaunaProfileFactory
|
|
||||||
typedef CAIGenericProfileFactory<CCorpseFaunaProfile> CCorpseFaunaProfileFactory;
|
|
||||||
|
|
||||||
//- Complex profile factories ------------------------------------------------
|
|
||||||
|
|
||||||
// CStaticFightFaunaProfile
|
|
||||||
class CFightFaunaProfileFactory
|
|
||||||
: public IAIProfileFactory
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
NLMISC::CSmartPtr<IAIProfile> createAIProfile(CProfileOwner* owner)
|
|
||||||
{
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// CStaticEatCorpseFaunaProfile
|
|
||||||
class CEatCorpseFaunaProfileFactory
|
|
||||||
: public IAIProfileFactory
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
NLMISC::CSmartPtr<IAIProfile> createAIProfile(CProfileOwner* owner)
|
|
||||||
{
|
|
||||||
#ifdef NL_DEBUG
|
|
||||||
nlassert(false);
|
|
||||||
#endif
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// CStaticCuriosityFaunaProfile
|
|
||||||
class CCuriosityFaunaProfileFactory
|
|
||||||
: public IAIProfileFactory
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
NLMISC::CSmartPtr<IAIProfile> createAIProfile(CProfileOwner* owner)
|
|
||||||
{
|
|
||||||
#ifdef NL_DEBUG
|
|
||||||
nlassert(false);
|
|
||||||
#endif
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
//- Profile factories singletons ---------------------------------------------
|
|
||||||
|
|
||||||
extern CPlanteIdleFaunaProfileFactory PlanteIdleFaunaProfileFactory;
|
|
||||||
extern CWanderFaunaProfileFactory WanderFaunaProfileFactory;
|
|
||||||
extern CGrazeFaunaProfileFactory GrazeFaunaProfileFactory;
|
|
||||||
extern CRestFaunaProfileFactory RestFaunaProfileFactory;
|
|
||||||
extern CFightFaunaProfileFactory FightFaunaProfileFactory;
|
|
||||||
extern CCorpseFaunaProfileFactory CorpseFaunaProfileFactory;
|
|
||||||
extern CEatCorpseFaunaProfileFactory EatCorpseFaunaProfileFactory;
|
|
||||||
extern CCuriosityFaunaProfileFactory CuriosityFaunaProfileFactory;
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,266 +0,0 @@
|
|||||||
/** \file profile.h
|
|
||||||
*
|
|
||||||
* $Id: profile.h,v 1.34 2006/10/31 16:09:01 blanchard Exp $
|
|
||||||
*
|
|
||||||
* This file defines the classes:
|
|
||||||
* - CProfileOwner
|
|
||||||
* - IAIProfileFactory
|
|
||||||
* - CAIGenericProfileFactory
|
|
||||||
* - CAIBaseProfile
|
|
||||||
* - CProfilePtr
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef RYAI_AI_PROFILE_H
|
|
||||||
#define RYAI_AI_PROFILE_H
|
|
||||||
|
|
||||||
|
|
||||||
//#pragma warning (disable : 4355) // warning C4355: 'this' : used in base member initializer list
|
|
||||||
|
|
||||||
// This is the base class for defining NPC behaviour profiles
|
|
||||||
// The team infrastructure manages the allocation of AI profiles to bots
|
|
||||||
|
|
||||||
class CProfilePtr;
|
|
||||||
class IAIProfile;
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CProfileOwner //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CProfileOwner
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
virtual ~CProfileOwner() { }
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// IAIProfileFactory //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class IAIProfileFactory
|
|
||||||
: public NLMISC::CDbgRefCount<IAIProfileFactory>
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
friend class CProfilePtr;
|
|
||||||
virtual ~IAIProfileFactory() { }
|
|
||||||
virtual NLMISC::CSmartPtr<IAIProfile> createAIProfile(CProfileOwner *owner) = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
#define RYAI_DECLARE_PROFILE_FACTORY(ProfileClass) RYAI_DECLARE_FACTORY(IAIProfileFactory, ProfileClass, std::string);
|
|
||||||
#define RYAI_REGISTER_PROFILE_FACTORY(ProfileClass, KeyValue) RYAI_REGISTER_FACTORY(IAIProfileFactory, ProfileClass, std::string, std::string(KeyValue));
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CAIGenericProfileFactory //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
template <class TProfile>
|
|
||||||
class CAIGenericProfileFactory
|
|
||||||
: public IAIProfileFactory
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
NLMISC::CSmartPtr<IAIProfile> createAIProfile(CProfileOwner* owner)
|
|
||||||
{
|
|
||||||
return new TProfile(owner);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CAIBaseProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class IAIProfile
|
|
||||||
: public NLMISC::CRefCount
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
virtual ~IAIProfile() { }
|
|
||||||
|
|
||||||
/// @name Virtual interface
|
|
||||||
//@{
|
|
||||||
// routine called when a profOwner starts to use a given profile
|
|
||||||
// note that bots have a data member called 'void *aiProfileData' reserved for the use of the profile code
|
|
||||||
// this data member should be setup here if it is to be used by the profile
|
|
||||||
virtual void beginProfile() = 0;
|
|
||||||
// routine called every time the profOwner is updated (frequency depends on player proximity, etc)
|
|
||||||
virtual void updateProfile(uint ticksSinceLastUpdate) = 0;
|
|
||||||
// routine called just before profOwner starts to use a new profile or when a profOwner dies
|
|
||||||
virtual void endProfile() = 0;
|
|
||||||
virtual AITYPES::TProfiles getAIProfileType() const = 0;
|
|
||||||
virtual std::string getOneLineInfoString() const = 0;
|
|
||||||
// routine called every time the profOwner's group changes state but profOwner maintains same ai profile
|
|
||||||
virtual void stateChangeProfile() = 0;
|
|
||||||
virtual void resumeProfile() = 0;
|
|
||||||
//@}
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CAIBaseProfile //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CAIBaseProfile
|
|
||||||
: public IAIProfile
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
virtual ~CAIBaseProfile() { }
|
|
||||||
|
|
||||||
/// @name IAIProfile base implementation
|
|
||||||
//@{
|
|
||||||
virtual void stateChangeProfile() { beginProfile(); }
|
|
||||||
virtual void resumeProfile() { }
|
|
||||||
//@}
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CProfilePtr //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
class CProfilePtr
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
enum TStartProfileType
|
|
||||||
{
|
|
||||||
START_BEGIN = 0,
|
|
||||||
START_RESUME
|
|
||||||
};
|
|
||||||
|
|
||||||
public:
|
|
||||||
CProfilePtr();
|
|
||||||
|
|
||||||
virtual ~CProfilePtr();
|
|
||||||
|
|
||||||
// std::string buildProfileDebugString() const;
|
|
||||||
virtual std::string getOneLineInfoString() const;
|
|
||||||
|
|
||||||
AITYPES::TProfiles getAIProfileType() const;
|
|
||||||
|
|
||||||
template <class T>
|
|
||||||
void setAIProfile(T* obj, IAIProfileFactory* profile, bool callStateChangedIfSame) const
|
|
||||||
{
|
|
||||||
if (profile)
|
|
||||||
{
|
|
||||||
setAIProfile(profile->createAIProfile(obj), callStateChangedIfSame);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setAIProfile(NLMISC::CSmartPtr<IAIProfile> profile, bool callStateChangedIfSame = false, TStartProfileType startType = START_BEGIN) const;
|
|
||||||
|
|
||||||
void updateProfile(uint ticks) const;
|
|
||||||
|
|
||||||
void mayUpdateProfile(uint ticks) const;
|
|
||||||
|
|
||||||
IAIProfile* getAIProfile() const { return _AiProfile; }
|
|
||||||
NLMISC::CSmartPtr<IAIProfile> const& getAISpawnProfile() const { return _AiProfile; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
mutable NLMISC::CSmartPtr<IAIProfile> _AiProfile;
|
|
||||||
mutable NLMISC::CSmartPtr<IAIProfile> _NextAiProfile;
|
|
||||||
mutable bool _NextAiProfileCallStateChangedIfSame;
|
|
||||||
|
|
||||||
mutable TStartProfileType _NextStartType;
|
|
||||||
mutable bool _IsUpdating;
|
|
||||||
};
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// Global functions //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
/// the lookup routine that serves as a kind of repository interface
|
|
||||||
IAIProfileFactory* lookupAIGrpProfile(char const* name);
|
|
||||||
|
|
||||||
/****************************************************************************/
|
|
||||||
/* Inlined methods */
|
|
||||||
/****************************************************************************/
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
// CProfilePtr //
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
inline
|
|
||||||
CProfilePtr::CProfilePtr()
|
|
||||||
: _AiProfile(NULL)
|
|
||||||
, _NextAiProfile(NULL)
|
|
||||||
, _NextStartType(START_BEGIN)
|
|
||||||
, _IsUpdating(false)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
CProfilePtr::~CProfilePtr()
|
|
||||||
{
|
|
||||||
_NextAiProfile = NULL;
|
|
||||||
_AiProfile = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
std::string CProfilePtr::getOneLineInfoString() const
|
|
||||||
{
|
|
||||||
if (_AiProfile.isNull())
|
|
||||||
return std::string("No Profile");
|
|
||||||
return _AiProfile->getOneLineInfoString();
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
AITYPES::TProfiles CProfilePtr::getAIProfileType() const
|
|
||||||
{
|
|
||||||
if (!_AiProfile.isNull())
|
|
||||||
return _AiProfile->getAIProfileType();
|
|
||||||
return AITYPES::BAD_TYPE; // unknown
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
void CProfilePtr::setAIProfile(NLMISC::CSmartPtr<IAIProfile> profile, bool callStateChangedIfSame, TStartProfileType startType) const
|
|
||||||
{
|
|
||||||
// :NOTE: profile can be NULL
|
|
||||||
if (_IsUpdating)
|
|
||||||
{
|
|
||||||
_NextAiProfileCallStateChangedIfSame = callStateChangedIfSame;
|
|
||||||
_NextAiProfile = profile;
|
|
||||||
_NextStartType = startType;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!_AiProfile.isNull())
|
|
||||||
{
|
|
||||||
// we may use the == operator because it doesn't take account of parameters (which is bad) :(
|
|
||||||
if (callStateChangedIfSame==true && _AiProfile->getAIProfileType ()==profile->getAIProfileType ()) // if we already have this profile, then call its stateChangeProfile method
|
|
||||||
{
|
|
||||||
_AiProfile->stateChangeProfile();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
_AiProfile->endProfile();
|
|
||||||
_AiProfile = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!profile.isNull())
|
|
||||||
{
|
|
||||||
_AiProfile = profile;
|
|
||||||
if (startType==START_BEGIN)
|
|
||||||
_AiProfile->beginProfile();
|
|
||||||
else
|
|
||||||
_AiProfile->resumeProfile();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
void CProfilePtr::updateProfile(uint ticks) const
|
|
||||||
{
|
|
||||||
BOMB_IF(_AiProfile.isNull(),"Attempting updateProfile() with _AiProfile.isNull()",return);
|
|
||||||
|
|
||||||
_IsUpdating = true;
|
|
||||||
_AiProfile->updateProfile(ticks);
|
|
||||||
_IsUpdating = false;
|
|
||||||
|
|
||||||
if (!_NextAiProfile.isNull())
|
|
||||||
{
|
|
||||||
setAIProfile(_NextAiProfile, _NextAiProfileCallStateChangedIfSame, _NextStartType);
|
|
||||||
_NextAiProfile = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline
|
|
||||||
void CProfilePtr::mayUpdateProfile(uint ticks) const
|
|
||||||
{
|
|
||||||
if (_AiProfile)
|
|
||||||
updateProfile(ticks);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,184 +0,0 @@
|
|||||||
/** \file stdpch.h
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* This is the ai_srevice executable's precopiled header controler file
|
|
||||||
*
|
|
||||||
*
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* $Id: stdpch.h,v 1.41 2006/02/24 17:29:11 guignot Exp $
|
|
||||||
*/
|
|
||||||
#ifndef STDPCH_H
|
|
||||||
#define STDPCH_H
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
|
||||||
// external files
|
|
||||||
//----------------------------------------------------------------
|
|
||||||
|
|
||||||
// this is up top because it contains a certain number of #pragmas to
|
|
||||||
// control compiler warnings with stlport
|
|
||||||
|
|
||||||
#include "nel/misc/types_nl.h"
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
|
||||||
// std libs
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <math.h>
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
|
||||||
// stl
|
|
||||||
|
|
||||||
#include <string>
|
|
||||||
#include <vector>
|
|
||||||
#include <list>
|
|
||||||
#include <map>
|
|
||||||
#include <set>
|
|
||||||
#include <algorithm>
|
|
||||||
//#include <sstream>
|
|
||||||
#include <exception>
|
|
||||||
#include <utility>
|
|
||||||
#include <deque>
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
|
||||||
// nel
|
|
||||||
|
|
||||||
#include "nel/misc/common.h"
|
|
||||||
#include "nel/misc/debug.h"
|
|
||||||
#include "nel/misc/command.h"
|
|
||||||
#include "nel/misc/variable.h"
|
|
||||||
#include "nel/misc/sheet_id.h"
|
|
||||||
#include "nel/misc/entity_id.h"
|
|
||||||
#include "nel/misc/file.h"
|
|
||||||
#include "nel/misc/path.h"
|
|
||||||
#include "nel/misc/time_nl.h"
|
|
||||||
#include "nel/misc/random.h"
|
|
||||||
#include "nel/misc/smart_ptr.h"
|
|
||||||
|
|
||||||
#include "nel/misc/vector_2d.h"
|
|
||||||
#include "nel/misc/vectord.h"
|
|
||||||
|
|
||||||
#include "nel/net/message.h"
|
|
||||||
#include "nel/net/unified_network.h"
|
|
||||||
|
|
||||||
// NeL/ligo
|
|
||||||
#include "nel/ligo/ligo_config.h"
|
|
||||||
#include "nel/ligo/primitive.h"
|
|
||||||
#include "nel/ligo/primitive_configuration.h"
|
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
|
||||||
// nel net
|
|
||||||
#include "nel/net/service.h"
|
|
||||||
//----------------------------------------------------------------
|
|
||||||
// service basics
|
|
||||||
|
|
||||||
#define FOREACH(__itvar,__conttype,__contvar) \
|
|
||||||
for (__conttype::iterator __itvar(__contvar.begin()),__itvar##end(__contvar.end()); __itvar!=__itvar##end; ++__itvar)
|
|
||||||
|
|
||||||
#define FOREACH_NOINC(__itvar,__conttype,__contvar) \
|
|
||||||
for (__conttype::iterator __itvar(__contvar.begin()),__itvar##end(__contvar.end()); __itvar!=__itvar##end;)
|
|
||||||
|
|
||||||
#define FOREACHC(__itvar,__conttype,__contvar) \
|
|
||||||
for (__conttype::const_iterator __itvar(__contvar.begin()),__itvar##end(__contvar.end()); __itvar!=__itvar##end; ++__itvar)
|
|
||||||
|
|
||||||
#define FOREACHC_NOINC(__itvar,__conttype,__contvar) \
|
|
||||||
for (__conttype::const_iterator __itvar(__contvar.begin()),__itvar##end(__contvar.end()); __itvar!=__itvar##end; )
|
|
||||||
|
|
||||||
|
|
||||||
class CStringWriter
|
|
||||||
:public NLMISC::CRefCount
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CStringWriter()
|
|
||||||
{}
|
|
||||||
virtual ~CStringWriter()
|
|
||||||
{}
|
|
||||||
virtual void append(const std::string &str) = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
class CTrashStringWriter
|
|
||||||
:public CStringWriter
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CTrashStringWriter(NLMISC::CLog *log=NLMISC::InfoLog)
|
|
||||||
{}
|
|
||||||
virtual ~CTrashStringWriter()
|
|
||||||
{}
|
|
||||||
void append(const std::string &str)
|
|
||||||
{}
|
|
||||||
};
|
|
||||||
|
|
||||||
class CLogStringWriter
|
|
||||||
:public CStringWriter
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CLogStringWriter(NLMISC::CLog *log=NLMISC::InfoLog)
|
|
||||||
:_Log(log)
|
|
||||||
{}
|
|
||||||
virtual ~CLogStringWriter()
|
|
||||||
{}
|
|
||||||
void append(const std::string &str)
|
|
||||||
{
|
|
||||||
#if !FINAL_VERSION
|
|
||||||
nlassert(_Log);
|
|
||||||
#endif
|
|
||||||
if (_Log)
|
|
||||||
_Log->displayNL(str.c_str());
|
|
||||||
}
|
|
||||||
NLMISC::CLog *_Log;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
class CArrayStringWriter
|
|
||||||
:public CStringWriter
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
CArrayStringWriter(std::vector<std::string> &stringVector)
|
|
||||||
:_StringVector(stringVector)
|
|
||||||
{}
|
|
||||||
virtual ~CArrayStringWriter()
|
|
||||||
{}
|
|
||||||
void append(const std::string &str)
|
|
||||||
{
|
|
||||||
_StringVector.push_back(str);
|
|
||||||
}
|
|
||||||
std::vector<std::string> &_StringVector;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
namespace MULTI_LINE_FORMATER {
|
|
||||||
void pushTitle(std::vector<std::string>& container, std::string const& text);
|
|
||||||
void pushEntry(std::vector<std::string>& container, std::string const& text);
|
|
||||||
void pushFooter(std::vector<std::string>& container);
|
|
||||||
}
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
|
||||||
// game share
|
|
||||||
|
|
||||||
#include "game_share/ryzom_entity_id.h"
|
|
||||||
#include "game_share/mode_and_behaviour.h"
|
|
||||||
#include "game_share/player_visual_properties.h"
|
|
||||||
#include "../ai_share/ai_event.h"
|
|
||||||
#include "../server_share/msg_ai_service.h"
|
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
|
||||||
// ai share
|
|
||||||
|
|
||||||
|
|
||||||
#include "ai_share/ai_share.h"
|
|
||||||
#include "ai_share/ai_types.h"
|
|
||||||
#include "ai_share/ai_alias_description_node.h"
|
|
||||||
#include "ai_share/ai_event_description.h"
|
|
||||||
#include "ai_share/ai_coord.h"
|
|
||||||
#include "ai_share/ai_vector.h"
|
|
||||||
#include "ai_share/angle.h"
|
|
||||||
#include "ai_share/world_map.h"
|
|
||||||
|
|
||||||
#endif /*STDPCH_H*/
|
|
@ -1,98 +0,0 @@
|
|||||||
/** \file stats_job_manager.h
|
|
||||||
*
|
|
||||||
* Part of STAT Module for GUS (general utilities service)
|
|
||||||
*
|
|
||||||
* This file is the header for a singleton 'job manager'. The job manager manages a list of jobs to be
|
|
||||||
* executed one after another. Each job is assumed to require one or more calls to its update() method
|
|
||||||
* in order to perform its work. Each job's finished() method returns true when the job is done
|
|
||||||
*
|
|
||||||
* $Id: stat_job_manager.h,v 1.3 2005/03/29 09:25:53 miller Exp $
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef STAT_JOB_MANAGER_H
|
|
||||||
#define STAT_JOB_MANAGER_H
|
|
||||||
|
|
||||||
#include "nel/misc/types_nl.h"
|
|
||||||
#include "nel/misc/debug.h"
|
|
||||||
#include "nel/misc/smart_ptr.h"
|
|
||||||
#include "game_share/singleton_registry.h"
|
|
||||||
|
|
||||||
class CJobManager: public IServiceSingleton
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
static CJobManager* getInstance();
|
|
||||||
|
|
||||||
public:
|
|
||||||
class IJob: public NLMISC::CRefCount
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
// virtual dtor
|
|
||||||
virtual ~IJob() {}
|
|
||||||
|
|
||||||
// start a job running (one that isn't in progress)
|
|
||||||
virtual void start()=0;
|
|
||||||
|
|
||||||
// return true if the job is finished -> the job object can be deleted
|
|
||||||
virtual bool finished()=0;
|
|
||||||
|
|
||||||
// return a status string that can be displayed in an update variable
|
|
||||||
virtual std::string getShortStatus()=0;
|
|
||||||
|
|
||||||
// get a detailed status string for display in a job list etc
|
|
||||||
virtual std::string getStatus()=0;
|
|
||||||
|
|
||||||
// display the details of the job... eg the list of files being processed with related info
|
|
||||||
virtual void display(NLMISC::CLog* log=NLMISC::InfoLog)=0;
|
|
||||||
|
|
||||||
// run the job's update to do a bit of work
|
|
||||||
virtual void update()=0;
|
|
||||||
};
|
|
||||||
|
|
||||||
public:
|
|
||||||
// add a job to the job vector and assign it a new id
|
|
||||||
uint32 addJob(NLMISC::CSmartPtr<IJob> job);
|
|
||||||
|
|
||||||
// move a job to the front of the queue - treat it as the active job
|
|
||||||
void promoteJob(uint32 idx);
|
|
||||||
|
|
||||||
// the update method used to call job updates
|
|
||||||
void serviceUpdate();
|
|
||||||
|
|
||||||
// do nothing during the service updates until 'resume()'
|
|
||||||
void pause();
|
|
||||||
|
|
||||||
// resume after a 'pause()'
|
|
||||||
void resume();
|
|
||||||
|
|
||||||
// accessors for the number of job updates per call to serviceUpdate()
|
|
||||||
void setJobUpdatesPerUpdate(uint32 count);
|
|
||||||
uint32 getJobUpdatesPerUpdate();
|
|
||||||
|
|
||||||
// get the 'pause'/'resume' state, the number of jobsUpdatesPerUpdate and the status of the active job
|
|
||||||
std::string getStatus();
|
|
||||||
|
|
||||||
// list the status of all jobs that are not finished
|
|
||||||
void listJobs(NLMISC::CLog* log=NLMISC::InfoLog);
|
|
||||||
|
|
||||||
// list the status of all jobs including those that are finished
|
|
||||||
void listJobHistory(NLMISC::CLog* log=NLMISC::InfoLog);
|
|
||||||
|
|
||||||
// call the currently active job's 'display' method
|
|
||||||
void displayCurrentJob(NLMISC::CLog* log=NLMISC::InfoLog);
|
|
||||||
|
|
||||||
// call the given job's 'display' method
|
|
||||||
void displayJob(uint32 jobId,NLMISC::CLog* log=NLMISC::InfoLog);
|
|
||||||
|
|
||||||
private:
|
|
||||||
CJobManager();
|
|
||||||
|
|
||||||
typedef std::list<uint32> TUnfinishedJobs;
|
|
||||||
typedef std::vector<NLMISC::CSmartPtr<IJob> > TJobs;
|
|
||||||
|
|
||||||
bool _Paused;
|
|
||||||
uint32 _JobUpdatesPerUpdate;
|
|
||||||
TJobs _Jobs;
|
|
||||||
TUnfinishedJobs _UnfinishedJobs;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,173 +0,0 @@
|
|||||||
/** \file file_repository.h
|
|
||||||
*
|
|
||||||
* ***********************************************************************
|
|
||||||
* ****************************** IMPORTANT ******************************
|
|
||||||
* ***********************************************************************
|
|
||||||
*
|
|
||||||
* The following set of routines all need to be called by the derived
|
|
||||||
* class for the repositry to function correctly:
|
|
||||||
* - init()
|
|
||||||
* - onModuleUp()
|
|
||||||
* - onModuleDown()
|
|
||||||
* - onModuleUpdate()
|
|
||||||
* - onDispatchMessage()
|
|
||||||
* - getModuleManifest()
|
|
||||||
*
|
|
||||||
* ***********************************************************************
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef FILE_REPOSITORY_H
|
|
||||||
#define FILE_REPOSITORY_H
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// includes
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// nel
|
|
||||||
#include "nel/misc/md5.h"
|
|
||||||
#include "nel/net/module_builder_parts.h"
|
|
||||||
|
|
||||||
// game share
|
|
||||||
#include "game_share/deployment_configuration.h"
|
|
||||||
|
|
||||||
// local
|
|
||||||
#include "module_admin_itf.h"
|
|
||||||
#include "administered_module.h"
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// namespace PATCHMAN
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
namespace PATCHMAN
|
|
||||||
{
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// class CFileRepository
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
class CFileRepository:
|
|
||||||
public CFileRepositorySkel,
|
|
||||||
public IFileRequestValidator,
|
|
||||||
public IFileInfoUpdateListener
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
// get the module manifest component required for CFileReceiver modules to recognise us
|
|
||||||
std::string buildModuleManifest() const;
|
|
||||||
|
|
||||||
public:
|
|
||||||
// ctor and init
|
|
||||||
CFileRepository();
|
|
||||||
|
|
||||||
// methods for use in derived classes
|
|
||||||
void init(NLNET::IModule* parent,const NLMISC::CSString& rootDirectory);
|
|
||||||
void onModuleUp(NLNET::IModuleProxy *module);
|
|
||||||
void onModuleDown(NLNET::IModuleProxy *module);
|
|
||||||
void onModuleUpdate();
|
|
||||||
|
|
||||||
// update methods
|
|
||||||
void rescanFull();
|
|
||||||
void rescanPartial();
|
|
||||||
void updateFile(const NLMISC::CSString& fileName);
|
|
||||||
|
|
||||||
// overloadable method for getting the file list for subscribers
|
|
||||||
virtual void getFileInfo(const NLMISC::CSString& fileSpec,TFileInfoVector& result,const NLNET::IModuleProxy* sender) const;
|
|
||||||
|
|
||||||
// query methods
|
|
||||||
TRepositoryDirectoryPtr getRepositoryDirectory();
|
|
||||||
void getFile(const NLMISC::CSString& fileName,NLMISC::CSString& resultData,const NLNET::IModuleProxy* sender) const;
|
|
||||||
void dump(NLMISC::CLog& log);
|
|
||||||
|
|
||||||
// stats system accessors
|
|
||||||
void setMaxHistorySize(uint32 maxHistorySize);
|
|
||||||
uint32 getMaxHistorySize() const;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
// treatment of incoming file requests
|
|
||||||
void requestFileInfo(NLNET::IModuleProxy *sender,const NLMISC::CSString& fileSpec);
|
|
||||||
void requestFileData(NLNET::IModuleProxy *sender, const NLMISC::CSString &fileName, uint32 startOffset, uint32 numBytes);
|
|
||||||
|
|
||||||
// treatment of subscriptions and unsubscriptions
|
|
||||||
void subscribe(NLNET::IModuleProxy *sender, const NLMISC::CSString &fileSpec);
|
|
||||||
void unsubscribe(NLNET::IModuleProxy *sender, const NLMISC::CSString &fileSpec);
|
|
||||||
void unsubscribeAll(NLNET::IModuleProxy *sender);
|
|
||||||
void getInfo(NLNET::IModuleProxy *sender, const NLMISC::CSString &fileSpec);
|
|
||||||
|
|
||||||
// IFileInfoUpdateListener specialisation implementation
|
|
||||||
void cbFileInfoUpdate(const SFileInfo& fileInfo);
|
|
||||||
void cbFileInfoErased(const NLMISC::CSString& fileName);
|
|
||||||
|
|
||||||
// broadcast a set of file info changes to all subscribers
|
|
||||||
void _broadcastFileInfoChanges(const TFileInfoVector& fileInfoChanges);
|
|
||||||
|
|
||||||
// overloadable method for treating my module down
|
|
||||||
virtual void onFileRepositoryModuleDown(NLNET::IModuleProxy *module);
|
|
||||||
|
|
||||||
private:
|
|
||||||
// private data
|
|
||||||
|
|
||||||
typedef NLNET::CInterceptorForwarder<CFileRepository> TInterceptor;
|
|
||||||
/// module interceptor forwarder
|
|
||||||
TInterceptor _Interceptor;
|
|
||||||
|
|
||||||
friend class NLNET::CInterceptorForwarder<CFileRepository>;
|
|
||||||
|
|
||||||
// the module object that this object is part of
|
|
||||||
NLNET::IModule* _Parent;
|
|
||||||
|
|
||||||
// a wrapper round '_Parent' to allow us to log to the parent's CAdministeredModuleBase interface
|
|
||||||
CAdministeredModuleWrapper _AdministeredModuleWrapper;
|
|
||||||
|
|
||||||
// the set of subscribers
|
|
||||||
typedef std::map<NLMISC::CSString,NLNET::IModuleProxy*> TSubscribers;
|
|
||||||
TSubscribers _Subscribers;
|
|
||||||
|
|
||||||
// the recent info changes that the subscribers may be interested in
|
|
||||||
TFileInfoVector _FileInfoChanges;
|
|
||||||
|
|
||||||
// system for history of recent info requests and data requests
|
|
||||||
uint32 _MaxHistorySize;
|
|
||||||
typedef std::list<NLMISC::CSString> THistory;
|
|
||||||
|
|
||||||
// the history for info requests
|
|
||||||
THistory _FileInfoHistory;
|
|
||||||
uint32 _FileInfoHistorySize;
|
|
||||||
uint32 _FileInfoCount;
|
|
||||||
|
|
||||||
// the history for file data requests
|
|
||||||
THistory _FileRequestHistory;
|
|
||||||
uint32 _FileRequestHistorySize;
|
|
||||||
uint32 _FileRequestCount;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
// data that may be accessed directlry by derived objects
|
|
||||||
|
|
||||||
// a smart pointers to our repository directory
|
|
||||||
TRepositoryDirectoryPtr _Directory;
|
|
||||||
|
|
||||||
|
|
||||||
protected:
|
|
||||||
// declaration of NLMISC_COMMANDS implemented by this class
|
|
||||||
NLMISC_CLASS_COMMAND_DECL(dump);
|
|
||||||
NLMISC_CLASS_COMMAND_DECL(incRescan);
|
|
||||||
NLMISC_CLASS_COMMAND_DECL(fullRescan);
|
|
||||||
NLMISC_CLASS_COMMAND_DECL(getFile);
|
|
||||||
NLMISC_CLASS_COMMAND_DECL(getFileInfo);
|
|
||||||
NLMISC_CLASS_COMMAND_DECL(updateFile);
|
|
||||||
NLMISC_CLASS_COMMAND_DECL(MaxHistorySize);
|
|
||||||
|
|
||||||
// macro for adding the NLMISC_COMMANDS provided here to the derived class's command table
|
|
||||||
#define NLMISC_COMMAND_HANDLER_ADDS_FOR_FILE_REPOSITORY(className) \
|
|
||||||
NLMISC_COMMAND_HANDLER_ADD(className, incRescan, "Perform next increment of incremental rescan", "no args")\
|
|
||||||
NLMISC_COMMAND_HANDLER_ADD(className, fullRescan, "Perform a full rescan", "no args")\
|
|
||||||
NLMISC_COMMAND_HANDLER_ADD(className, getFile, "get a file", "<file name>")\
|
|
||||||
NLMISC_COMMAND_HANDLER_ADD(className, getFileInfo, "get info on a set of files", "<file spec>")\
|
|
||||||
NLMISC_COMMAND_HANDLER_ADD(className, updateFile, "force a rescan of a given file", "<file name>")\
|
|
||||||
NLMISC_COMMAND_HANDLER_ADD(className, MaxHistorySize, "the maximum size allowed for the history buffers", "[<num entries>]")
|
|
||||||
};
|
|
||||||
|
|
||||||
} // end of namespace
|
|
||||||
|
|
||||||
#endif
|
|
@ -1,56 +0,0 @@
|
|||||||
#include "record.h"
|
|
||||||
|
|
||||||
CRecord::CRecord()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
CRecord::CRecord(std::vector<IValue *> &)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
CRecord::~CRecord()
|
|
||||||
{
|
|
||||||
/* std::vector<IValue *>::iterator it_val = _Values.begin();
|
|
||||||
while ( it_val != _Values.end() )
|
|
||||||
{
|
|
||||||
IValue *val = *it_val;
|
|
||||||
it_val++;
|
|
||||||
delete val;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
void CRecord::addValue(IValue *value)
|
|
||||||
{
|
|
||||||
_Values.push_back( value );
|
|
||||||
}
|
|
||||||
|
|
||||||
void CRecord::addValue(std::string &str)
|
|
||||||
{
|
|
||||||
_Values.push_back( new CValue<std::string>(str) );
|
|
||||||
}
|
|
||||||
|
|
||||||
void CRecord::addValue(bool b)
|
|
||||||
{
|
|
||||||
_Values.push_back( new CValue<bool>(b) );
|
|
||||||
}
|
|
||||||
|
|
||||||
void CRecord::addValue(int val)
|
|
||||||
{
|
|
||||||
_Values.push_back( new CValue<int>(val) );
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::vector<IValue *> &CRecord::getValues()
|
|
||||||
{
|
|
||||||
return _Values;
|
|
||||||
}
|
|
||||||
|
|
||||||
const IValue *CRecord::operator[](int index)
|
|
||||||
{
|
|
||||||
return _Values[index];
|
|
||||||
}
|
|
||||||
|
|
||||||
int CRecord::size()
|
|
||||||
{
|
|
||||||
return _Values.size();
|
|
||||||
}
|
|
@ -1,72 +0,0 @@
|
|||||||
// 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/>.
|
|
||||||
|
|
||||||
#include "record.h"
|
|
||||||
|
|
||||||
CRecord::CRecord()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
CRecord::CRecord(std::vector<IValue *> &)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
CRecord::~CRecord()
|
|
||||||
{
|
|
||||||
/* std::vector<IValue *>::iterator it_val = _Values.begin();
|
|
||||||
while ( it_val != _Values.end() )
|
|
||||||
{
|
|
||||||
IValue *val = *it_val;
|
|
||||||
it_val++;
|
|
||||||
delete val;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
void CRecord::addValue(IValue *value)
|
|
||||||
{
|
|
||||||
_Values.push_back( value );
|
|
||||||
}
|
|
||||||
|
|
||||||
void CRecord::addValue(std::string &str)
|
|
||||||
{
|
|
||||||
_Values.push_back( new CValue<std::string>(str) );
|
|
||||||
}
|
|
||||||
|
|
||||||
void CRecord::addValue(bool b)
|
|
||||||
{
|
|
||||||
_Values.push_back( new CValue<bool>(b) );
|
|
||||||
}
|
|
||||||
|
|
||||||
void CRecord::addValue(int val)
|
|
||||||
{
|
|
||||||
_Values.push_back( new CValue<int>(val) );
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::vector<IValue *> &CRecord::getValues()
|
|
||||||
{
|
|
||||||
return _Values;
|
|
||||||
}
|
|
||||||
|
|
||||||
const IValue *CRecord::operator[](int index)
|
|
||||||
{
|
|
||||||
return _Values[index];
|
|
||||||
}
|
|
||||||
|
|
||||||
int CRecord::size()
|
|
||||||
{
|
|
||||||
return _Values.size();
|
|
||||||
}
|
|
@ -1,546 +0,0 @@
|
|||||||
/*
|
|
||||||
author : Fabien Houlmann - houlmann@nevrax.com
|
|
||||||
date : 13/10/2005
|
|
||||||
|
|
||||||
named2csv: convert named_items.txt to .csv format and convert it back
|
|
||||||
to named_items.txt after changes.
|
|
||||||
|
|
||||||
use: named2csv.exe named_items.txt filter.script (to generate a .csv based on filter)
|
|
||||||
named2csv.exe named_items.txt named_items.csv (to modify .txt with .csv)
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "nel\misc\common.h"
|
|
||||||
#include "nel\misc\debug.h"
|
|
||||||
#include "nel\misc\sstring.h"
|
|
||||||
#include "nel\misc\path.h"
|
|
||||||
#include "nel\misc\file.h"
|
|
||||||
#include <iostream>
|
|
||||||
|
|
||||||
using namespace NLMISC;
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
// function declaration
|
|
||||||
int verifItemsFile (const char *filename);
|
|
||||||
int verifCsvFile (const char *filename);
|
|
||||||
void processItemLine (const string &s);
|
|
||||||
int getItemsFromFile (const char *filename);
|
|
||||||
int getFieldsFromFile(const char *filename);
|
|
||||||
int getNbItemFromFile(const char *filename);
|
|
||||||
int exportCsv (const char *filename);
|
|
||||||
int importCsv (const char *filename);
|
|
||||||
void getItemBounds (const CVectorSString &lines, uint num, uint &a, uint &b);
|
|
||||||
void updateItemField (CVectorSString &lines, uint itemIndex, uint fieldIndex, uint &a, uint &b);
|
|
||||||
void addNewItem (CVectorSString &lines, uint itemIndex);
|
|
||||||
int updateItems (const char *filename);
|
|
||||||
|
|
||||||
// global access
|
|
||||||
CVectorSString fields;
|
|
||||||
vector<CVectorSString> items;
|
|
||||||
|
|
||||||
// check the items file (locSlot and item number coherence)
|
|
||||||
int verifItemsFile (const char *filename)
|
|
||||||
{
|
|
||||||
FILE *f = fopen(filename, "r");
|
|
||||||
if (f == NULL)
|
|
||||||
nlerror("Can't open file : %s", filename);
|
|
||||||
|
|
||||||
char buffer[1024];
|
|
||||||
while (fgets(buffer, 1024, f))
|
|
||||||
{
|
|
||||||
string s(buffer);
|
|
||||||
|
|
||||||
// null or comment
|
|
||||||
if (s == "" || s.find("//") == 0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (s.find("_LocSlot") == string::npos)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// get item numbers
|
|
||||||
int n1, n2;
|
|
||||||
sscanf(buffer, "_Items#%d._LocSlot=%d", &n1, &n2);
|
|
||||||
|
|
||||||
// check
|
|
||||||
if (n1 != n2)
|
|
||||||
nlerror("item number (%d) and _LocSlot(%d) don't match !", n1, n2);
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(f);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// check csv file (locSlot and item number coherence)
|
|
||||||
int verifCsvFile (const char *filename)
|
|
||||||
{
|
|
||||||
FILE *f = fopen(filename, "r");
|
|
||||||
if (f == NULL)
|
|
||||||
nlerror("Can't open file : %s", filename);
|
|
||||||
|
|
||||||
uint prevId = -1;
|
|
||||||
char buffer[1024];
|
|
||||||
// skip first line
|
|
||||||
fgets(buffer, 1024, f);
|
|
||||||
while (fgets(buffer, 1024, f))
|
|
||||||
{
|
|
||||||
uint id = atoi(buffer);
|
|
||||||
if (id-1 != prevId)
|
|
||||||
nlerror("item number (%d) and previous item (%d) don't match !", id, prevId);
|
|
||||||
prevId = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(f);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// parse a line from source file
|
|
||||||
void processItemLine(const string &s)
|
|
||||||
{
|
|
||||||
// null or comment
|
|
||||||
if (s == "" || s.find("//") == 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// other stuff
|
|
||||||
if (s.find("_Items#") == string::npos)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// get item number
|
|
||||||
int n;
|
|
||||||
sscanf(s.c_str(), "_Items#%d", &n);
|
|
||||||
|
|
||||||
// check fields
|
|
||||||
for (uint i=0 ; i<fields.size() ; i++)
|
|
||||||
{
|
|
||||||
string field = "_Items#" + toString(n) + "." + fields[i];
|
|
||||||
|
|
||||||
// compare line with field
|
|
||||||
if (s.find(fields[i]) != string::npos)
|
|
||||||
{
|
|
||||||
// check is next char is not valid because of names like Protection in Protection1
|
|
||||||
if (!CSString::isValidFileNameChar(s[field.size()]))
|
|
||||||
{
|
|
||||||
// get value
|
|
||||||
int pos = s.find("=");
|
|
||||||
nlassert(pos != string::npos);
|
|
||||||
string val(s, pos+1);
|
|
||||||
|
|
||||||
items[n][i] = (CSString(val).strtok("\n")).strip();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// fill 'items' structure with values from file
|
|
||||||
int getItemsFromFile(const char *filename)
|
|
||||||
{
|
|
||||||
FILE *f = fopen(filename, "r");
|
|
||||||
if (f == NULL)
|
|
||||||
nlerror("Can't open file : %s", filename);
|
|
||||||
|
|
||||||
char buffer[1024];
|
|
||||||
while (fgets(buffer, 1024, f))
|
|
||||||
processItemLine(buffer);
|
|
||||||
|
|
||||||
fclose(f);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// fill 'fields' structure with values from file
|
|
||||||
int getFieldsFromFile(const char *filename)
|
|
||||||
{
|
|
||||||
FILE *f = fopen(filename, "r");
|
|
||||||
if (f == NULL)
|
|
||||||
nlerror("Can't open file : %s", filename);
|
|
||||||
|
|
||||||
char buffer[1024];
|
|
||||||
while (fgets(buffer, 1024, f))
|
|
||||||
{
|
|
||||||
CSString s(buffer);
|
|
||||||
s = s.strtok("\n");
|
|
||||||
|
|
||||||
// skip null or comment
|
|
||||||
if (s == "" || s.find("//") == 0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// add the field
|
|
||||||
fields.push_back(s);
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(f);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// parse the file to count the number of items
|
|
||||||
int getNbItemFromFile(const char *filename)
|
|
||||||
{
|
|
||||||
FILE *f = fopen(filename, "r");
|
|
||||||
if (f == NULL)
|
|
||||||
nlerror("Can't open file : %s", filename);
|
|
||||||
|
|
||||||
int max = 0;
|
|
||||||
char buffer[1024];
|
|
||||||
while (fgets(buffer, 1024, f))
|
|
||||||
{
|
|
||||||
int n;
|
|
||||||
fscanf(f, "_Items#%d", &n);
|
|
||||||
if (n > max)
|
|
||||||
max = n;
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(f);
|
|
||||||
return max;
|
|
||||||
}
|
|
||||||
|
|
||||||
// generate .csv file based on actual filled structure
|
|
||||||
int exportCsv(const char *filename)
|
|
||||||
{
|
|
||||||
nlassert(fields.size() != 0);
|
|
||||||
|
|
||||||
uint i, j;
|
|
||||||
FILE *f = fopen(filename, "w");
|
|
||||||
if (f == NULL)
|
|
||||||
nlerror("Can't open file : %s", filename);
|
|
||||||
|
|
||||||
// print fields name
|
|
||||||
for (i=0 ; i<fields.size()-1 ; i++)
|
|
||||||
fprintf(f, "%s;", fields[i].c_str());
|
|
||||||
fprintf(f, "%s\n", fields[fields.size()-1].c_str());
|
|
||||||
|
|
||||||
// print values for each item
|
|
||||||
for (i=0 ; i<items.size() ; i++)
|
|
||||||
{
|
|
||||||
for (j=0 ; j<items[i].size()-1 ; j++)
|
|
||||||
fprintf(f, "%s;", items[i][j].c_str());
|
|
||||||
fprintf(f, "%s\n", items[i][items[i].size()-1].c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(f);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// read .csv file to fill the structures 'items' and 'fields'
|
|
||||||
int importCsv(const char *filename)
|
|
||||||
{
|
|
||||||
verifCsvFile(filename);
|
|
||||||
|
|
||||||
char buffer[1024];
|
|
||||||
FILE *f = fopen(filename, "r");
|
|
||||||
if (f == NULL)
|
|
||||||
nlerror("Can't open file : %s", filename);
|
|
||||||
|
|
||||||
// read fields name
|
|
||||||
{
|
|
||||||
fgets(buffer, 1024, f);
|
|
||||||
CSString s(buffer);
|
|
||||||
s = s.strtok("\n");
|
|
||||||
|
|
||||||
do
|
|
||||||
{
|
|
||||||
fields.push_back(s.splitTo(';', true));
|
|
||||||
} while (s != "");
|
|
||||||
}
|
|
||||||
|
|
||||||
// read values for each item
|
|
||||||
while (fgets(buffer, 1024, f))
|
|
||||||
{
|
|
||||||
CSString s(buffer), val;
|
|
||||||
|
|
||||||
// first is the number
|
|
||||||
val = (s.splitTo(';', true));
|
|
||||||
uint n = val.atosi();
|
|
||||||
|
|
||||||
// resize if needed
|
|
||||||
if (n+1 > items.size())
|
|
||||||
items.resize(n+1);
|
|
||||||
|
|
||||||
// add item id
|
|
||||||
items[n].push_back(val);
|
|
||||||
|
|
||||||
// add others
|
|
||||||
do
|
|
||||||
{
|
|
||||||
val = s.splitTo(';', true);
|
|
||||||
items[n].push_back(val);
|
|
||||||
} while (s != "");
|
|
||||||
}
|
|
||||||
|
|
||||||
fclose(f);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// compute item boundary in the file (min and max lines)
|
|
||||||
void getItemBounds(const CVectorSString &lines, uint num, uint &a, uint &b)
|
|
||||||
{
|
|
||||||
a = b = 0;
|
|
||||||
uint i = -1;
|
|
||||||
bool ok = false;
|
|
||||||
|
|
||||||
while (++i < lines.size() && !ok)
|
|
||||||
{
|
|
||||||
if (lines[i] == "" || lines[i].find("//") != string::npos)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// get item number
|
|
||||||
uint n;
|
|
||||||
if (sscanf(lines[i].c_str(), "_Items#%d", &n) == 0)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// find it
|
|
||||||
if (n == num)
|
|
||||||
{
|
|
||||||
// frist line
|
|
||||||
if (a == 0)
|
|
||||||
a = b = i+1;
|
|
||||||
// more line
|
|
||||||
else
|
|
||||||
b++;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// end
|
|
||||||
if (a != 0)
|
|
||||||
ok = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// found it ?
|
|
||||||
if (a != 0)
|
|
||||||
{
|
|
||||||
ok = true;
|
|
||||||
b++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// update an item field with a new value
|
|
||||||
void updateItemField(CVectorSString &lines, uint itemIndex, uint fieldIndex, uint &a, uint &b)
|
|
||||||
{
|
|
||||||
string field = fields[fieldIndex];
|
|
||||||
string val = items[itemIndex][fieldIndex];
|
|
||||||
string s = "_Items#";
|
|
||||||
s += toString(itemIndex);
|
|
||||||
s += ".";
|
|
||||||
s += field;
|
|
||||||
|
|
||||||
// remove jump
|
|
||||||
val = CSString(val).strtok("\n");
|
|
||||||
|
|
||||||
uint craftLine = 0;
|
|
||||||
bool found = false;
|
|
||||||
uint i = a-1;
|
|
||||||
|
|
||||||
// first pass to check if param have changed
|
|
||||||
for (i=a ; i<b ; i++)
|
|
||||||
{
|
|
||||||
string line = s + "= " + val;
|
|
||||||
uint pos = pos = lines[i].find(line.c_str());
|
|
||||||
if (pos != string::npos)
|
|
||||||
{
|
|
||||||
found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// second pass if new value
|
|
||||||
i = a-1;
|
|
||||||
while (++i<b && !found)
|
|
||||||
{
|
|
||||||
uint pos;
|
|
||||||
|
|
||||||
// store the line "_CraftParameters" : reference line
|
|
||||||
if (craftLine == 0)
|
|
||||||
{
|
|
||||||
pos = lines[i].find("_CraftParameters");
|
|
||||||
if (pos != string::npos)
|
|
||||||
craftLine = i;
|
|
||||||
}
|
|
||||||
|
|
||||||
// search string
|
|
||||||
pos = lines[i].find(s.c_str());
|
|
||||||
if (pos == string::npos)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (val != "")
|
|
||||||
{
|
|
||||||
// check if the attribute is the right one and not included in another one
|
|
||||||
// for example: Protection is in ProtectionFactor
|
|
||||||
if (!CSString::isValidFileNameChar(lines[i][s.size()]))
|
|
||||||
{
|
|
||||||
found = true;
|
|
||||||
|
|
||||||
if (val != "nul")
|
|
||||||
{
|
|
||||||
// udpdate value
|
|
||||||
lines[i] = s;
|
|
||||||
lines[i] += "= ";
|
|
||||||
lines[i] += val;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// remove value
|
|
||||||
CVectorSString::iterator it = lines.begin() + i;
|
|
||||||
lines.erase(it);
|
|
||||||
i--;
|
|
||||||
b--;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// param not found
|
|
||||||
if (!found && val != "" && val != "nul")
|
|
||||||
{
|
|
||||||
// add it
|
|
||||||
if (field.find("_CraftParameters") == string::npos)
|
|
||||||
{
|
|
||||||
// before craftLine
|
|
||||||
CVectorSString::iterator it = lines.begin() + craftLine;
|
|
||||||
lines.insert(it, s + "= " + val);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// after craftLine
|
|
||||||
CVectorSString::iterator it = lines.begin() + craftLine + 1;
|
|
||||||
lines.insert(it, s + "= " + val);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// add a new item a the end of the file
|
|
||||||
void addNewItem(CVectorSString &lines, uint itemIndex)
|
|
||||||
{
|
|
||||||
CVectorSString::iterator it = lines.end();
|
|
||||||
|
|
||||||
string s = "_Items#" + toString(itemIndex);
|
|
||||||
lines.insert(lines.end(), s);
|
|
||||||
lines.insert(lines.end(), s + "._SheetId=undef");
|
|
||||||
lines.insert(lines.end(), s + "._ClientInventoryPosition= -1");
|
|
||||||
lines.insert(lines.end(), s + "._Recommended= 250");
|
|
||||||
lines.insert(lines.end(), s + "._LocSlot= " + toString(itemIndex));
|
|
||||||
lines.insert(lines.end(), s + "._PhraseId=undef");
|
|
||||||
lines.insert(lines.end(), s + "._CraftParameters");
|
|
||||||
lines.insert(lines.end(), "\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
// update all items with new values
|
|
||||||
int updateItems(const char *filename)
|
|
||||||
{
|
|
||||||
// verify file
|
|
||||||
verifItemsFile(filename);
|
|
||||||
|
|
||||||
CSString data;
|
|
||||||
data.readFromFile(filename);
|
|
||||||
|
|
||||||
CVectorSString lines;
|
|
||||||
data.splitLines(lines);
|
|
||||||
|
|
||||||
for (uint itemIndex=0 ; itemIndex<items.size() ; itemIndex++)
|
|
||||||
{
|
|
||||||
nlassert(fields.size() >= items[itemIndex].size());
|
|
||||||
cout << "Updating item " << itemIndex << endl;
|
|
||||||
|
|
||||||
uint a, b;
|
|
||||||
getItemBounds(lines, itemIndex, a, b);
|
|
||||||
|
|
||||||
// no bound found, it's a new item
|
|
||||||
if (b == 0)
|
|
||||||
{
|
|
||||||
addNewItem(lines, itemIndex);
|
|
||||||
getItemBounds(lines, itemIndex, a, b);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (uint fieldIndex=0 ; fieldIndex<items[itemIndex].size() ; fieldIndex++)
|
|
||||||
updateItemField(lines, itemIndex, fieldIndex, a, b);
|
|
||||||
}
|
|
||||||
|
|
||||||
// rewrite file
|
|
||||||
data.clear();
|
|
||||||
for (uint i=0 ; i<lines.size() ; i++)
|
|
||||||
data += lines[i] + "\n";
|
|
||||||
data.writeToFile(filename);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
NLMISC::CApplicationContext AppContext;
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
|
||||||
{
|
|
||||||
string csvFile, itemsFile, scriptFile, curDir;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// check number of arguments
|
|
||||||
if (argc != 3)
|
|
||||||
nlerror("Bad arguments number !");
|
|
||||||
|
|
||||||
curDir = CPath::standardizePath(CPath::getCurrentPath());
|
|
||||||
|
|
||||||
// check extensions
|
|
||||||
{
|
|
||||||
string ext = CFile::getExtension(argv[2]);
|
|
||||||
|
|
||||||
if (ext == "csv")
|
|
||||||
csvFile = argv[2];
|
|
||||||
else if (ext == "script")
|
|
||||||
scriptFile = argv[2];
|
|
||||||
else
|
|
||||||
nlerror("Bad extension : %s (use .csv or .script)", ext.c_str());
|
|
||||||
|
|
||||||
itemsFile = argv[1];
|
|
||||||
}
|
|
||||||
|
|
||||||
// create a .csv file
|
|
||||||
if (scriptFile != "")
|
|
||||||
{
|
|
||||||
if (CFile::getFilename(scriptFile) == scriptFile)
|
|
||||||
scriptFile = curDir + scriptFile;
|
|
||||||
|
|
||||||
if (CFile::getFilename(itemsFile) == itemsFile)
|
|
||||||
itemsFile = curDir + itemsFile;
|
|
||||||
|
|
||||||
// auto-add : _LocSlot & _PhraseId & _SheetId & _Recommended
|
|
||||||
fields.push_back("_LocSlot");
|
|
||||||
fields.push_back("_PhraseId");
|
|
||||||
fields.push_back("_SheetId");
|
|
||||||
fields.push_back("_Recommended");
|
|
||||||
|
|
||||||
// add other fields from file
|
|
||||||
getFieldsFromFile(scriptFile.c_str());
|
|
||||||
|
|
||||||
// verify file
|
|
||||||
verifItemsFile(itemsFile.c_str());
|
|
||||||
|
|
||||||
// How many items ?
|
|
||||||
uint n = getNbItemFromFile(itemsFile.c_str()) + 1;
|
|
||||||
items.resize(n);
|
|
||||||
|
|
||||||
// reserve memory
|
|
||||||
for (uint i=0 ; i<n ; i++)
|
|
||||||
items[i].resize(fields.size());
|
|
||||||
|
|
||||||
// read values from items file
|
|
||||||
getItemsFromFile(itemsFile.c_str());
|
|
||||||
|
|
||||||
// generate the new file
|
|
||||||
string csv = CFile::getFilename(itemsFile);
|
|
||||||
string ext = CFile::getExtension(csv);
|
|
||||||
exportCsv((CSString(csv).replace(string('.' + ext).c_str(), ".csv")).c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
// create a .txt file
|
|
||||||
if (csvFile != "")
|
|
||||||
{
|
|
||||||
if (CFile::getFilename(csvFile) == csvFile)
|
|
||||||
csvFile = curDir + csvFile;
|
|
||||||
|
|
||||||
// load csv values
|
|
||||||
importCsv(csvFile.c_str());
|
|
||||||
if (itemsFile != "" && CFile::isExists(itemsFile.c_str()))
|
|
||||||
updateItems(itemsFile.c_str());
|
|
||||||
else
|
|
||||||
nlerror("Can't find file : %s", itemsFile.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -1,290 +0,0 @@
|
|||||||
/*
|
|
||||||
Petite documentation sur le fonctionnement du plugin
|
|
||||||
|
|
||||||
1) Le WorldEditor se connecte au plugin (config dans WorldEditorPlugin.cfg)
|
|
||||||
|
|
||||||
2) Le plugin se connecte au World_Editor_Service
|
|
||||||
|
|
||||||
3) Le World_Editor_Service (config dans WorldEditorService.cfg) envoie des paquets contenant au maximum 100 joueurs.
|
|
||||||
Ces joueurs sont soit nouveaux, soit leurs coordonnées ont changé.
|
|
||||||
|
|
||||||
4) Les informations des joueurs sont envoyées (voir onIdle) sous forme de primitives "player":
|
|
||||||
|
|
||||||
Voici la définition de la primitive "player", dans WORLD_EDITOR_SCRIPT.XML
|
|
||||||
|
|
||||||
<PRIMITIVE CLASS_NAME="root" TYPE="node" AUTO_INIT="true" DELETABLE="true">
|
|
||||||
<DYNAMIC_CHILD CLASS_NAME="player"/>
|
|
||||||
</PRIMITIVE>
|
|
||||||
|
|
||||||
<!-- player node -->
|
|
||||||
<PRIMITIVE CLASS_NAME="player" TYPE="point" R="255" G="0" B="0" A="128" AUTO_INIT="true" DELETABLE="false" LINK_BROTHERS="false" SHOW_ARROW="false">
|
|
||||||
<PARAMETER NAME= "x" TYPE="string" VISIBLE="true"> <DEFAULT_VALUE VALUE= "0" /> </PARAMETER>
|
|
||||||
<PARAMETER NAME= "y" TYPE="string" VISIBLE="true"> <DEFAULT_VALUE VALUE= "0" /> </PARAMETER>
|
|
||||||
</PRIMITIVE>
|
|
||||||
|
|
||||||
5) World_Editor_Service utilise un cache pour stocker les déplacements des joueurs, afin de n'envoyer que ce qui bouge
|
|
||||||
|
|
||||||
6) World_Editor_Plugin utilise aussi un cache avec un pointeur sur les Primitives, afin de ne modifier dans WE que ce qui bouge
|
|
||||||
|
|
||||||
*/
|
|
||||||
#include "stdafx.h"
|
|
||||||
#include "plugin.h"
|
|
||||||
#include "resource.h"
|
|
||||||
#include "nel/misc/path.h"
|
|
||||||
#include "LoadDialog.h"
|
|
||||||
#include "nel/sound/u_listener.h"
|
|
||||||
|
|
||||||
using namespace NLMISC;
|
|
||||||
using namespace NLLIGO;
|
|
||||||
using namespace NLSOUND;
|
|
||||||
using namespace NLNET;
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
|
|
||||||
class Player
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
string _name;
|
|
||||||
float _x, _y;
|
|
||||||
const IPrimitive *primitive;
|
|
||||||
// Constructor
|
|
||||||
Player::Player()
|
|
||||||
{
|
|
||||||
primitive = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
Player::Player(string name, float x, float y)
|
|
||||||
{
|
|
||||||
primitive = NULL;
|
|
||||||
_name = name;
|
|
||||||
_x = x;
|
|
||||||
_y = y;
|
|
||||||
}
|
|
||||||
/// Destructor
|
|
||||||
Player::~Player()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
vector<Player> StackPlayers;
|
|
||||||
|
|
||||||
map<string, Player> StoredPlayers;
|
|
||||||
|
|
||||||
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
void *createPlugin()
|
|
||||||
{
|
|
||||||
return new CPlugin();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
CPlugin::CPlugin()
|
|
||||||
: _PluginAccess(0)
|
|
||||||
{
|
|
||||||
m_Initialized = false;
|
|
||||||
_Client = NULL;
|
|
||||||
StackPlayers.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
CPlugin::~CPlugin()
|
|
||||||
{
|
|
||||||
delete _Client;
|
|
||||||
|
|
||||||
if (m_Initialized)
|
|
||||||
{
|
|
||||||
_PluginAccess->deleteRootPluginPrimitive();
|
|
||||||
m_Initialized = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void CPlugin::progress (float progressValue)
|
|
||||||
{
|
|
||||||
/*char tmp[1024];
|
|
||||||
sprintf(tmp, "Initializing mixer : %i%%", int(progressValue * 100));
|
|
||||||
LoadDlg->Message = tmp;
|
|
||||||
LoadDlg->UpdateData(FALSE);
|
|
||||||
LoadDlg->RedrawWindow();*/
|
|
||||||
}
|
|
||||||
|
|
||||||
// ***************************************************************************
|
|
||||||
void serverSentPos (CMessage &msgin, TSockId from, CCallbackNetBase &netbase)
|
|
||||||
{
|
|
||||||
// Called when the server sent a POS message
|
|
||||||
uint32 count;
|
|
||||||
|
|
||||||
msgin.serial(count);
|
|
||||||
for (uint i = 0;i < count;++i)
|
|
||||||
{
|
|
||||||
string name;
|
|
||||||
msgin.serial(name);
|
|
||||||
|
|
||||||
float x, y;
|
|
||||||
msgin.serial(x);
|
|
||||||
msgin.serial(y);
|
|
||||||
// we received name, x, y, we save it in the stack
|
|
||||||
StackPlayers.push_back (Player(name, x, y));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// ***************************************************************************
|
|
||||||
void serverSentInfo (CMessage &msgin, TSockId from, CCallbackNetBase &netbase)
|
|
||||||
{
|
|
||||||
// Called when the server sent a INFO message
|
|
||||||
string text;
|
|
||||||
msgin.serial(text);
|
|
||||||
printf("%s\n", text.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
// ***************************************************************************
|
|
||||||
// All messages handled by this server
|
|
||||||
#define NB_CB 2
|
|
||||||
TCallbackItem CallbackArray[NB_CB] =
|
|
||||||
{
|
|
||||||
{ "POS", serverSentPos },
|
|
||||||
{ "INFO", serverSentInfo },
|
|
||||||
};
|
|
||||||
|
|
||||||
void CPlugin::init(IPluginAccess *pluginAccess)
|
|
||||||
{
|
|
||||||
CLoadDialog *LoadDlg;
|
|
||||||
|
|
||||||
AFX_MANAGE_STATE(AfxGetStaticModuleState());
|
|
||||||
AfxEnableControlContainer();
|
|
||||||
_PluginAccess = pluginAccess;
|
|
||||||
//#undef new
|
|
||||||
LoadDlg = new CLoadDialog;
|
|
||||||
//#define new NL_NEW
|
|
||||||
LoadDlg->Create(IDD_DIALOG_LOAD);
|
|
||||||
LoadDlg->Message = "Connecting...";
|
|
||||||
LoadDlg->UpdateData(FALSE);
|
|
||||||
//LoadDlg->Invalidate();
|
|
||||||
LoadDlg->ShowWindow(SW_SHOW);
|
|
||||||
//LoadDlg->RedrawWindow();
|
|
||||||
|
|
||||||
// connect to the server here...
|
|
||||||
|
|
||||||
// Read the host where to connect in the client.cfg file
|
|
||||||
CConfigFile ConfigFile;
|
|
||||||
ConfigFile.load ("client.cfg");
|
|
||||||
string LSHost(ConfigFile.getVar("LSHost").asString());
|
|
||||||
|
|
||||||
// Init and Connect the client to the server located on port 3333
|
|
||||||
_Client = new CCallbackClient();
|
|
||||||
_Client->addCallbackArray (CallbackArray, NB_CB);
|
|
||||||
|
|
||||||
//printf("Please wait connecting...\n");
|
|
||||||
try
|
|
||||||
{
|
|
||||||
CInetAddress addr(LSHost+":48888");
|
|
||||||
_Client->connect(addr);
|
|
||||||
}
|
|
||||||
catch(ESocket &e)
|
|
||||||
{
|
|
||||||
MessageBox (NULL, e.what(), "Error", MB_ICONERROR|MB_OK);
|
|
||||||
delete LoadDlg;
|
|
||||||
LoadDlg = 0;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
delete LoadDlg;
|
|
||||||
LoadDlg = 0;
|
|
||||||
|
|
||||||
if (!_Client->connected())
|
|
||||||
{
|
|
||||||
MessageBox (NULL, "The connection failed", "Error", MB_ICONERROR|MB_OK);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
//#undef new
|
|
||||||
_DialogFlag = new CDialogFlags(/*_Mixer*/);
|
|
||||||
//#define new NL_NEW
|
|
||||||
// open the dialog flag window
|
|
||||||
_DialogFlag->Create(IDD_DIALOG_FLAGS, CWnd::FromHandle(_PluginAccess->getMainWindow()->m_hWnd));
|
|
||||||
_DialogFlag->init(this);
|
|
||||||
_DialogFlag->ShowWindow(TRUE);
|
|
||||||
|
|
||||||
//
|
|
||||||
{
|
|
||||||
CMessage msg;
|
|
||||||
msg.setType("WINDOW");
|
|
||||||
float xmin = 0;
|
|
||||||
float xmax = 10000;
|
|
||||||
float ymin = 0;
|
|
||||||
float ymax = 10000;
|
|
||||||
msg.serial (xmin);
|
|
||||||
msg.serial (ymin);
|
|
||||||
msg.serial (xmax);
|
|
||||||
msg.serial (ymax);
|
|
||||||
_Client->send(msg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// The current region has changed.
|
|
||||||
void CPlugin::primitiveChanged(const NLLIGO::IPrimitive *root)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/// The listener has been moved on the map.
|
|
||||||
void CPlugin::positionMoved(const NLMISC::CVector &position)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void CPlugin::lostPositionControl()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void CPlugin::onIdle()
|
|
||||||
{
|
|
||||||
if (_Client && _Client->connected())
|
|
||||||
{
|
|
||||||
// during the first call, we create a Root primitive to store all players
|
|
||||||
if (!m_Initialized)
|
|
||||||
{
|
|
||||||
m_Initialized = true;
|
|
||||||
_PluginAccess->createRootPluginPrimitive();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// first, we receive the stack of messages, which is composed of players informations
|
|
||||||
_Client->update();
|
|
||||||
// now, we insert the players into the GUI
|
|
||||||
for (uint i = 0; i < StackPlayers.size(); ++i)
|
|
||||||
{
|
|
||||||
map<string, Player>::const_iterator ite;
|
|
||||||
ite = StoredPlayers.find(StackPlayers[i]._name);
|
|
||||||
if (ite == StoredPlayers.end())
|
|
||||||
{
|
|
||||||
// if the player doesn't exist in the static list, we add it
|
|
||||||
//StoredPlayers.insert(map<string, Player>::value_type(StackPlayers[i]._name, StackPlayers[i]));
|
|
||||||
StoredPlayers[StackPlayers[i]._name] = StackPlayers[i];
|
|
||||||
std::vector<CPrimitiveClass::CInitParameters> Parameters;
|
|
||||||
|
|
||||||
Parameters.push_back (CPrimitiveClass::CInitParameters ());
|
|
||||||
CPrimitiveClass::CInitParameters ¶m1 = Parameters.back ();
|
|
||||||
param1.DefaultValue.resize (1);
|
|
||||||
param1.Name = "x";
|
|
||||||
param1.DefaultValue[0].GenID = false;
|
|
||||||
param1.DefaultValue[0].Name = toString(StackPlayers[i]._x);
|
|
||||||
|
|
||||||
Parameters.push_back (CPrimitiveClass::CInitParameters ());
|
|
||||||
CPrimitiveClass::CInitParameters ¶m2 = Parameters.back ();
|
|
||||||
param2.DefaultValue.resize (1);
|
|
||||||
param2 = Parameters.back ();
|
|
||||||
param2.Name = "y";
|
|
||||||
param2.DefaultValue[0].GenID = false;
|
|
||||||
param2.DefaultValue[0].Name = toString(StackPlayers[i]._y);
|
|
||||||
|
|
||||||
// create a player in WorldEditor
|
|
||||||
StoredPlayers[StackPlayers[i]._name].primitive = _PluginAccess->createPluginPrimitive("player",StackPlayers[i]._name.c_str(),NLMISC::CVector(StackPlayers[i]._x,StackPlayers[i]._y,0),0,Parameters);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// the player has moved, we need to change its coordinates
|
|
||||||
_PluginAccess->movePluginPrimitive(StoredPlayers[StackPlayers[i]._name].primitive, CVector(StackPlayers[i]._x, StackPlayers[i]._y, 0));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// we clear the stack
|
|
||||||
StackPlayers.clear();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load Diff
@ -1,289 +0,0 @@
|
|||||||
/*#include "std_header.h"
|
|
||||||
//
|
|
||||||
#include "village.h"
|
|
||||||
#include "zone_util.h"
|
|
||||||
//
|
|
||||||
#include "nel/georges/u_form.h"
|
|
||||||
#include "nel/georges/u_form_elm.h"
|
|
||||||
#include "nel/georges/u_form_loader.h"
|
|
||||||
//
|
|
||||||
#include "nel/misc/path.h"
|
|
||||||
#include "nel/misc/file.h"
|
|
||||||
//
|
|
||||||
#include "3d/shape.h"
|
|
||||||
|
|
||||||
|
|
||||||
using namespace NLMISC;
|
|
||||||
using namespace NL3D;
|
|
||||||
|
|
||||||
//**********************************************************************************************
|
|
||||||
CVillageGrid::CVillageGrid()
|
|
||||||
{
|
|
||||||
_ZoneMinX = 0;
|
|
||||||
_ZoneMinY = 0;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
//**********************************************************************************************
|
|
||||||
void CVillageGrid::init(uint gridWidth, uint gridHeight, sint zoneMinX, sint zoneMinY)
|
|
||||||
{
|
|
||||||
reset();
|
|
||||||
nlassert(gridWidth > 0);
|
|
||||||
nlassert(gridHeight > 0);
|
|
||||||
_ZoneMinX = zoneMinX;
|
|
||||||
_ZoneMinY = zoneMinY;
|
|
||||||
VillageGrid.init(gridWidth, gridHeight);
|
|
||||||
}
|
|
||||||
|
|
||||||
//**********************************************************************************************
|
|
||||||
void CVillageGrid::reset()
|
|
||||||
{
|
|
||||||
NLMISC::contReset(*this);
|
|
||||||
}
|
|
||||||
|
|
||||||
//**********************************************************************************************
|
|
||||||
void CVillageGrid::addVillagesFromContinent(const std::string &continentSheetName)
|
|
||||||
{
|
|
||||||
// Load the form
|
|
||||||
NLGEORGES::UFormLoader *loader = NLGEORGES::UFormLoader::createLoader();
|
|
||||||
//
|
|
||||||
std::string path = CPath::lookup(continentSheetName, false, false);
|
|
||||||
if (path.empty())
|
|
||||||
{
|
|
||||||
nlwarning("Path not found for %s.", continentSheetName.c_str());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
NLGEORGES::UForm *villageForm;
|
|
||||||
villageForm = loader->loadForm(path.c_str());
|
|
||||||
if(villageForm != NULL)
|
|
||||||
{
|
|
||||||
NLGEORGES::UFormElm &rootItem = villageForm->getRootNode();
|
|
||||||
// try to get the village list
|
|
||||||
// Load the village list
|
|
||||||
NLGEORGES::UFormElm *villagesItem;
|
|
||||||
if(!(rootItem.getNodeByName (&villagesItem, "Villages") && villagesItem))
|
|
||||||
{
|
|
||||||
nlwarning("No villages where found in %s", continentSheetName.c_str());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get number of village
|
|
||||||
uint numVillage;
|
|
||||||
nlverify (villagesItem->getArraySize (numVillage));
|
|
||||||
|
|
||||||
// For each village
|
|
||||||
for(uint k = 0; k < numVillage; ++k)
|
|
||||||
{
|
|
||||||
NLGEORGES::UFormElm *currVillage;
|
|
||||||
if (!(villagesItem->getArrayNode (&currVillage, k) && currVillage))
|
|
||||||
{
|
|
||||||
nlwarning("Couldn't get village %d in continent %s", continentSheetName.c_str(), k);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// check that this village is in the dependency zones
|
|
||||||
NLGEORGES::UFormElm *zoneNameItem;
|
|
||||||
if (!currVillage->getNodeByName (&zoneNameItem, "Zone") && zoneNameItem)
|
|
||||||
{
|
|
||||||
nlwarning("Couldn't get zone item of village %d in continent %s", continentSheetName.c_str(), k);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
std::string zoneName;
|
|
||||||
if (!zoneNameItem->getValue(zoneName))
|
|
||||||
{
|
|
||||||
nlwarning("Couldn't get zone name of village %d in continent %s", continentSheetName.c_str(), k);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
sint zoneX, zoneY;
|
|
||||||
if (!getZonePos(zoneName, zoneX, zoneY))
|
|
||||||
{
|
|
||||||
nlwarning("Zone name of village %d in continent %s is invalid", continentSheetName.c_str(), k);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
sint villageMinX, villageMinY;
|
|
||||||
sint villageMaxX, villageMaxY;
|
|
||||||
|
|
||||||
|
|
||||||
// retrieve width & height of covered region
|
|
||||||
uint32 regionWidth;
|
|
||||||
uint32 regionHeight;
|
|
||||||
float centerX, centerY;
|
|
||||||
if (!currVillage->getValueByName(regionWidth, "Width") ||
|
|
||||||
!currVillage->getValueByName(regionHeight, "Height") ||
|
|
||||||
!currVillage->getValueByName(centerX, "CenterX") ||
|
|
||||||
!currVillage->getValueByName(centerY, "CenterY"))
|
|
||||||
{
|
|
||||||
nlwarning("Can't retrieve region covered by village %d in continent %s", continentSheetName.c_str(), k);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
//
|
|
||||||
villageMinX = villageMaxX = zoneX;
|
|
||||||
villageMinY = villageMaxY = zoneY;
|
|
||||||
// extends with bbox from center to min corner if leveldesigner forgot to enter good width & height
|
|
||||||
villageMaxX = std::max(villageMaxX, (sint) ((zoneX * 160.f + 2.f * centerX) / 160.f));
|
|
||||||
villageMaxY = std::max(villageMaxY, (sint) ((zoneY * 160.f + 2.f * centerY) / 160.f));
|
|
||||||
//
|
|
||||||
villageMinX -= _ZoneMinX;
|
|
||||||
villageMaxX -= _ZoneMinX;
|
|
||||||
villageMinY -= _ZoneMinY;
|
|
||||||
villageMaxY -= _ZoneMinY;
|
|
||||||
//
|
|
||||||
CVillage village;
|
|
||||||
if (loadVillageSheet(currVillage, continentSheetName, k, village))
|
|
||||||
{
|
|
||||||
//
|
|
||||||
village.FileModificationDate = std::max(village.FileModificationDate, CFile::getFileModificationDate(path));
|
|
||||||
//
|
|
||||||
Villages.push_back(CVillage());
|
|
||||||
Villages.back().swap(village);
|
|
||||||
//
|
|
||||||
for (sint y = villageMinY; y <= (sint) villageMaxY; ++y)
|
|
||||||
{
|
|
||||||
if (y < 0) continue;
|
|
||||||
if (y >= (sint) VillageGrid.getHeight()) continue;
|
|
||||||
for (sint x = villageMinX; x <= (sint) villageMaxX; ++x)
|
|
||||||
{
|
|
||||||
if (x < 0) continue;
|
|
||||||
if (x >= (sint) VillageGrid.getWidth()) continue;
|
|
||||||
VillageGrid(x, y).push_back(Villages.size() - 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
nlwarning("Can't load continent form : %s", continentSheetName.c_str());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//**********************************************************************************************
|
|
||||||
bool CVillageGrid::loadVillageSheet(const NLGEORGES::UFormElm *villageItem, const std::string &continentSheetName, uint villageIndex, CVillage &dest)
|
|
||||||
{
|
|
||||||
dest.IG.clear();
|
|
||||||
const NLGEORGES::UFormElm *igNamesItem;
|
|
||||||
if (! (villageItem->getNodeByName (&igNamesItem, "IgList") && igNamesItem) )
|
|
||||||
{
|
|
||||||
nlwarning("No list of IGs was found in the continent form %s, village #%d", continentSheetName.c_str(), (int) villageIndex);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get number of village
|
|
||||||
uint numIgs;
|
|
||||||
nlverify (igNamesItem->getArraySize (numIgs));
|
|
||||||
const NLGEORGES::UFormElm *currIg;
|
|
||||||
uint32 mostRecentIGDate = 0;
|
|
||||||
for(uint l = 0; l < numIgs; ++l)
|
|
||||||
{
|
|
||||||
if (!(igNamesItem->getArrayNode (&currIg, l) && currIg))
|
|
||||||
{
|
|
||||||
nlwarning("Couldn't get ig #%d in the continent form %s, in village #%d", l, continentSheetName.c_str(), (int) villageIndex);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
const NLGEORGES::UFormElm *igNameItem;
|
|
||||||
currIg->getNodeByName (&igNameItem, "IgName");
|
|
||||||
std::string igName;
|
|
||||||
if (!igNameItem->getValue (igName))
|
|
||||||
{
|
|
||||||
nlwarning("Couldn't get ig name of ig #%d in the continent form %s, in village #%d", l, continentSheetName.c_str(), (int) villageIndex);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (igName.empty())
|
|
||||||
{
|
|
||||||
nlwarning("Ig name of ig #%d in the continent form %s, in village #%d is an empty string", l, continentSheetName.c_str(), (int) villageIndex);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// ensure .ig
|
|
||||||
igName = CFile::getFilenameWithoutExtension(igName) + ".ig";
|
|
||||||
|
|
||||||
|
|
||||||
CIGInfo igInfo;
|
|
||||||
|
|
||||||
// add this ig
|
|
||||||
std::string nameLookup = CPath::lookup (igName, false, true);
|
|
||||||
if (!nameLookup.empty())
|
|
||||||
{
|
|
||||||
igInfo.Path = nameLookup;
|
|
||||||
dest.IG.push_back(igInfo);
|
|
||||||
mostRecentIGDate = std::max(mostRecentIGDate, CFile::getFileModificationDate(nameLookup));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
nlwarning("Couldn't find ig %s in continent form %s, in village %d", igName.c_str(), continentSheetName.c_str(), (int) villageIndex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
dest.FileModificationDate = mostRecentIGDate;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//**********************************************************************************************
|
|
||||||
void CVillage::load(TShapeCache &shapeCache)
|
|
||||||
{
|
|
||||||
for(std::vector<CIGInfo>::iterator it = IG.begin(); it != IG.end(); ++it)
|
|
||||||
{
|
|
||||||
it->load(shapeCache);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//**********************************************************************************************
|
|
||||||
void CIGInfo::load(TShapeCache &shapeCache)
|
|
||||||
{
|
|
||||||
if (Loaded) return;
|
|
||||||
Loaded = true; // even if loading fails, don't try twice to load it
|
|
||||||
try
|
|
||||||
{
|
|
||||||
CIFile stream;
|
|
||||||
stream.open(Path);
|
|
||||||
printf(Path.c_str());
|
|
||||||
CSmartPtr<CInstanceGroup> ig = new CInstanceGroup;
|
|
||||||
ig->serial(stream);
|
|
||||||
IG = ig; // commit
|
|
||||||
}
|
|
||||||
catch(EStream &e)
|
|
||||||
{
|
|
||||||
nlwarning(e.what());
|
|
||||||
}
|
|
||||||
if (IG)
|
|
||||||
{
|
|
||||||
// complete cache
|
|
||||||
for(uint k = 0; k < IG->getNumInstance(); ++k)
|
|
||||||
{
|
|
||||||
std::string shapeName = standardizeShapeName(IG->getShapeName(k));
|
|
||||||
if (NLMISC::strlwr(CFile::getExtension(shapeName)) == "pacs_prim")
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
TShapeCache::iterator it = shapeCache.find(shapeName);
|
|
||||||
CShapeInfo si;
|
|
||||||
bool buildOK = false;
|
|
||||||
if (it == shapeCache.end())
|
|
||||||
{
|
|
||||||
CShapeStream ss;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
|
|
||||||
CIFile stream;
|
|
||||||
std::string path = CPath::lookup(shapeName, false, false);
|
|
||||||
if (!path.empty())
|
|
||||||
{
|
|
||||||
stream.open(path);
|
|
||||||
ss.serial(stream);
|
|
||||||
CShapeInfo si;
|
|
||||||
si.build(*ss.getShapePointer());
|
|
||||||
delete ss.getShapePointer();
|
|
||||||
shapeCache[shapeName].swap(si);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch (EStream &e)
|
|
||||||
{
|
|
||||||
// shape not loaded
|
|
||||||
nlwarning(e.what());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
*/
|
|
@ -1,72 +0,0 @@
|
|||||||
/*#ifndef _VILLAGE_H
|
|
||||||
#define _VILLAGE_H
|
|
||||||
|
|
||||||
#include "nel/misc/array_2d.h"
|
|
||||||
#include "3d/shape_info.h"
|
|
||||||
//
|
|
||||||
#include "3d/scene_group.h"
|
|
||||||
//
|
|
||||||
#include "nel/misc/smart_ptr.h"
|
|
||||||
//
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
|
|
||||||
namespace NLGEORGES
|
|
||||||
{
|
|
||||||
class UFormElm;
|
|
||||||
}
|
|
||||||
|
|
||||||
class CIGInfo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
std::string Path;
|
|
||||||
NLMISC::CSmartPtr<NL3D::CInstanceGroup> IG; // NULL if not loaded yet
|
|
||||||
bool Loaded;
|
|
||||||
public:
|
|
||||||
CIGInfo() : Loaded(false) {}
|
|
||||||
// load data & complete shape cache. no-op if datas where already loaded
|
|
||||||
void load(NL3D::TShapeCache &shapeCache);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
class CVillage
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
std::vector<CIGInfo> IG;
|
|
||||||
uint32 FileModificationDate;
|
|
||||||
public:
|
|
||||||
void swap(CVillage &other)
|
|
||||||
{
|
|
||||||
IG.swap(other.IG);
|
|
||||||
std::swap(other.FileModificationDate, FileModificationDate);
|
|
||||||
}
|
|
||||||
// load data & complete shape cache. no-op if datas where already loaded
|
|
||||||
void load(NL3D::TShapeCache &shapeCache);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class CVillageGrid
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
std::vector<CVillage> Villages;
|
|
||||||
NLMISC::CArray2D<std::list<uint> > VillageGrid; // each grid cells gives the list of villages that overlap that cell (identified by their indices into 'Villages')
|
|
||||||
public:
|
|
||||||
CVillageGrid();
|
|
||||||
//
|
|
||||||
void init(uint gridWidth, uint gridHright, sint zoneMinX, sint zoneMinY);
|
|
||||||
void reset();
|
|
||||||
// Load & add all villages of a continent to the map
|
|
||||||
void addVillagesFromContinent(const std::string &continentSheetName);
|
|
||||||
private:
|
|
||||||
sint _ZoneMinX;
|
|
||||||
sint _ZoneMinY;
|
|
||||||
private:
|
|
||||||
bool loadVillageSheet(const NLGEORGES::UFormElm *villageItem, const std::string &continentSheetName, uint villageIndex, CVillage &dest);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
|
||||||
*/
|
|
@ -1,283 +0,0 @@
|
|||||||
/** \file char_commands.cpp
|
|
||||||
*
|
|
||||||
* $id$
|
|
||||||
*
|
|
||||||
* todo:
|
|
||||||
* - charScanScript commands
|
|
||||||
* * path for script files in cfg
|
|
||||||
* - charScanScriptNew <description>
|
|
||||||
* - charScanScriptLoad <file_name>
|
|
||||||
* - charScanScriptSave <file_name>
|
|
||||||
* - charScanScriptListFiles
|
|
||||||
* - charScanScriptListLines
|
|
||||||
* - charScanScriptDeleteLine <line_number>
|
|
||||||
* - charScanScriptAddInputFiles <directory> <wildcards>
|
|
||||||
* - charScanScriptAddInfoExtractor <infoExtractorName> [<args>]
|
|
||||||
* - charScanScriptAddFilter <filterName> [<args>]
|
|
||||||
* - charScanScriptAddPreInclude <include_file_name>
|
|
||||||
* - charScanScriptAddPostInclude <include_file_name>
|
|
||||||
* - charScanScriptSetOutputDirectory <directoryName>
|
|
||||||
* - charScanScriptSetDescription <description>
|
|
||||||
* - charScanScriptRun [-s <file_name>] [-o <output_directory>]
|
|
||||||
* - addJobCharScanScript [-s <file_name>] [-o <output_directory>]
|
|
||||||
* - charScanScriptListOutputFiles [<output_directory>]
|
|
||||||
* - charScanScriptListOutputFileContents <file_name> [<output_directory>]
|
|
||||||
* - charScanScriptTestFileList
|
|
||||||
* - charScanScriptTestOutput <test_input_file_path>
|
|
||||||
* - charScanScriptHelp
|
|
||||||
* - path for generated files (from cfg + override) => managed incrementally with directory numbering
|
|
||||||
* - add incremental update systems
|
|
||||||
* - add tables with a column per day ()
|
|
||||||
* - add tables with a column per week (limited number of weeks)
|
|
||||||
* - add tables with a column per month (limited number of months)
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
bool CCharFilterFactory::beginScanJob(const std::vector<std::string>& files, const std::vector<std::string>& filters)
|
|
||||||
{
|
|
||||||
bool noErrors= true;
|
|
||||||
|
|
||||||
// create a new job
|
|
||||||
NLMISC::CSmartPtr<CCharacterScanJob> job=new CCharacterScanJob;
|
|
||||||
|
|
||||||
// look after the filters
|
|
||||||
for (uint32 i=0;i<filters.size();++i)
|
|
||||||
{
|
|
||||||
// locate the info extractor corresponding to the given name
|
|
||||||
uint32 j=0;
|
|
||||||
for (j=0;j<_Filters.size();++j)
|
|
||||||
if (filters[i]==_Filters[j]->getName())
|
|
||||||
break;
|
|
||||||
|
|
||||||
// if none found then warn and skip passed
|
|
||||||
if(j>=_Filters.size())
|
|
||||||
{
|
|
||||||
nlwarning("Unknown info extractor: %s",filters[i].c_str());
|
|
||||||
noErrors=false;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// add the info extractor to the new job
|
|
||||||
job->addFilter(_Filters[j]);
|
|
||||||
}
|
|
||||||
|
|
||||||
// look after the files
|
|
||||||
job->addFiles(files);
|
|
||||||
|
|
||||||
// add the job to the job manager
|
|
||||||
if (noErrors==true)
|
|
||||||
CJobManager::getInstance()->addJob(&*job);
|
|
||||||
|
|
||||||
return noErrors;
|
|
||||||
}
|
|
||||||
|
|
||||||
*/
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// includes
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
#include "nel/misc/path.h"
|
|
||||||
#include "nel/misc/command.h"
|
|
||||||
#include "nel/misc/variable.h"
|
|
||||||
#include "nel/misc/algo.h"
|
|
||||||
#include "game_share/persistent_data.h"
|
|
||||||
|
|
||||||
#include "character.h"
|
|
||||||
#include "job_manager.h"
|
|
||||||
#include "char_info_extractor_factory.h"
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Namespaces
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
using namespace NLMISC;
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Variables
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
CVariable<string> SourceDirectory("variables", "SourceDirectory", "Directory we scan for files", string("."), 0, true);
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Commands - misc character related
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
NLMISC_COMMAND(listCharNames,"display the names of the characters int he listed save files","<input file name>")
|
|
||||||
{
|
|
||||||
if (args.size()!=1 && args.size()!=0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
std::string wildcard="pdr_account*";
|
|
||||||
if (args.size()==1)
|
|
||||||
wildcard=args[0];
|
|
||||||
|
|
||||||
std::vector<std::string> files;
|
|
||||||
NLMISC::CPath::getPathContent(SourceDirectory.get().c_str(),false,false,true,files);
|
|
||||||
for (uint32 i=files.size();i--;)
|
|
||||||
{
|
|
||||||
if (!NLMISC::testWildCard(NLMISC::CFile::getFilename(files[i]),wildcard))
|
|
||||||
{
|
|
||||||
files[i]=files.back();
|
|
||||||
files.pop_back();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
std::sort(files.begin(),files.end());
|
|
||||||
for (uint32 i=0;i<files.size();++i)
|
|
||||||
{
|
|
||||||
static CPersistentDataRecord pdr;
|
|
||||||
pdr.clear();
|
|
||||||
pdr.readFromFile(files[i].c_str());
|
|
||||||
|
|
||||||
CStatsScanCharacter c;
|
|
||||||
c.apply(pdr);
|
|
||||||
|
|
||||||
log.displayNL("%-40s Name: %s ",files[i].c_str(),c.EntityBase._Name.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Commands - charScanner
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
NLMISC_COMMAND(listCharInfoExtractors,"display the list of info extractors that exist for characters","")
|
|
||||||
{
|
|
||||||
if (args.size()!=0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
CCharInfoExtractorFactory::getInstance()->displayInfoExtractorList(&log);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Commands - jobsManager
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
NLMISC_COMMAND(jobsPause,"pause execution of jobs","")
|
|
||||||
{
|
|
||||||
if (args.size()!=0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
CJobManager::getInstance()->pause();
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
NLMISC_COMMAND(jobsResume,"resume execution of jobs","")
|
|
||||||
{
|
|
||||||
if (args.size()!=0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
CJobManager::getInstance()->resume();
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
NLMISC_COMMAND(jobsPromote,"pause execution of jobs","<jobId>")
|
|
||||||
{
|
|
||||||
if (args.size()!=1)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
uint32 idx= atoi(args[0].c_str());
|
|
||||||
if ( (idx==0 && args[0]!="0") )
|
|
||||||
{
|
|
||||||
nlwarning("Argument is not a valid job id - should be a number");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
CJobManager::getInstance()->promoteJob(idx);
|
|
||||||
CJobManager::getInstance()->listJobs(&log);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
NLMISC_COMMAND(JobUpdatesPerUpdate,"set or display the number of job updates per service update","[<count>]")
|
|
||||||
{
|
|
||||||
if (args.size()>1)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (args.size()==1)
|
|
||||||
{
|
|
||||||
uint32 count= atoi(args[0].c_str());
|
|
||||||
if ( (count==0 && args[0]!="0") )
|
|
||||||
{
|
|
||||||
nlwarning("Argument is not a valid number");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
CJobManager::getInstance()->setJobUpdatesPerUpdate(count);
|
|
||||||
}
|
|
||||||
|
|
||||||
nlinfo("JobUpdatesPerUpdate %d",CJobManager::getInstance()->getJobUpdatesPerUpdate());
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
NLMISC_COMMAND(jobsStatus,"display the status of the job manager","")
|
|
||||||
{
|
|
||||||
if (args.size()!=0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
log.displayNL("%s",CJobManager::getInstance()->getStatus().c_str());
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
NLMISC_COMMAND(jobsList,"display the list of unfinished jobs","")
|
|
||||||
{
|
|
||||||
if (args.size()!=0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
CJobManager::getInstance()->listJobs(&log);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
NLMISC_COMMAND(jobsListAll,"display the list of all jobs (unfinished jobs are marked with a '*')","")
|
|
||||||
{
|
|
||||||
if (args.size()!=0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
CJobManager::getInstance()->listJobHistory(&log);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
NLMISC_COMMAND(jobsDisplayDetails,"display detailed info for the current job (or a given job)","[<job id>]")
|
|
||||||
{
|
|
||||||
switch (args.size())
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
CJobManager::getInstance()->displayCurrentJob(&log);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 1:
|
|
||||||
{
|
|
||||||
uint32 idx= atoi(args[0].c_str());
|
|
||||||
if ( (idx==0 && args[0]!="0") )
|
|
||||||
{
|
|
||||||
nlwarning("Argument is not a valid job id - should be a number");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
CJobManager::getInstance()->displayJob(idx,&log);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
|
|
||||||
default:
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Commands - charScanScript
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
Loading…
Reference in New Issue