2010-01-09 20:20:14 +01:00
|
|
|
/* Copyright (C) 2010 Wildfire Games.
|
|
|
|
* This file is part of 0 A.D.
|
|
|
|
*
|
|
|
|
* 0 A.D. is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* 0 A.D. 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 General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with 0 A.D. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef INCLUDED_MESSAGETYPES
|
|
|
|
#define INCLUDED_MESSAGETYPES
|
|
|
|
|
|
|
|
#include "simulation2/system/Components.h"
|
2010-01-22 21:03:14 +01:00
|
|
|
#include "simulation2/system/Entity.h"
|
2010-01-09 20:20:14 +01:00
|
|
|
#include "simulation2/system/Message.h"
|
|
|
|
|
2010-03-18 00:13:21 +01:00
|
|
|
#include "simulation2/helpers/Position.h"
|
2010-01-09 20:20:14 +01:00
|
|
|
|
2010-09-03 11:55:14 +02:00
|
|
|
#include "simulation2/components/ICmpPathfinder.h"
|
|
|
|
|
2010-01-09 20:20:14 +01:00
|
|
|
#define DEFAULT_MESSAGE_IMPL(name) \
|
2010-07-18 17:19:49 +02:00
|
|
|
virtual int GetType() const { return MT_##name; } \
|
2010-01-09 20:20:14 +01:00
|
|
|
virtual const char* GetScriptHandlerName() const { return "On" #name; } \
|
2010-01-22 21:03:14 +01:00
|
|
|
virtual const char* GetScriptGlobalHandlerName() const { return "OnGlobal" #name; } \
|
2010-01-09 20:20:14 +01:00
|
|
|
virtual jsval ToJSVal(ScriptInterface& scriptInterface) const; \
|
|
|
|
static CMessage* FromJSVal(ScriptInterface&, jsval val);
|
|
|
|
|
|
|
|
class SceneCollector;
|
|
|
|
class CFrustum;
|
|
|
|
|
|
|
|
class CMessageTurnStart : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(TurnStart)
|
|
|
|
|
|
|
|
CMessageTurnStart()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2010-09-03 11:55:14 +02:00
|
|
|
// The update process is split into a number of phases, in an attempt
|
|
|
|
// to cope with dependencies between components. Each phase is implemented
|
|
|
|
// as a separate message. Simulation2.cpp sends them in sequence.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generic per-turn update message, for things that don't care much about ordering.
|
|
|
|
*/
|
2010-01-09 20:20:14 +01:00
|
|
|
class CMessageUpdate : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(Update)
|
|
|
|
|
2010-05-02 22:32:37 +02:00
|
|
|
CMessageUpdate(fixed turnLength) :
|
2010-01-09 20:20:14 +01:00
|
|
|
turnLength(turnLength)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2010-05-02 22:32:37 +02:00
|
|
|
fixed turnLength;
|
2010-01-09 20:20:14 +01:00
|
|
|
};
|
|
|
|
|
2010-09-03 11:55:14 +02:00
|
|
|
/**
|
|
|
|
* Update phase for formation controller movement (must happen before individual
|
|
|
|
* units move to follow their formation).
|
|
|
|
*/
|
|
|
|
class CMessageUpdate_MotionFormation : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(Update_MotionFormation)
|
|
|
|
|
|
|
|
CMessageUpdate_MotionFormation(fixed turnLength) :
|
|
|
|
turnLength(turnLength)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
fixed turnLength;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update phase for non-formation-controller unit movement.
|
|
|
|
*/
|
|
|
|
class CMessageUpdate_MotionUnit : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(Update_MotionUnit)
|
|
|
|
|
|
|
|
CMessageUpdate_MotionUnit(fixed turnLength) :
|
|
|
|
turnLength(turnLength)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
fixed turnLength;
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Final update phase, after all other updates.
|
|
|
|
*/
|
|
|
|
class CMessageUpdate_Final : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(Update_Final)
|
|
|
|
|
|
|
|
CMessageUpdate_Final(fixed turnLength) :
|
|
|
|
turnLength(turnLength)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
fixed turnLength;
|
|
|
|
};
|
|
|
|
|
2010-01-09 20:20:14 +01:00
|
|
|
class CMessageInterpolate : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(Interpolate)
|
|
|
|
|
2010-02-07 21:06:16 +01:00
|
|
|
CMessageInterpolate(float frameTime, float offset) :
|
|
|
|
frameTime(frameTime), offset(offset)
|
2010-01-09 20:20:14 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2010-02-10 20:28:46 +01:00
|
|
|
float frameTime; // time in seconds since previous interpolate
|
|
|
|
float offset; // range [0, 1] (inclusive); fractional time of current frame between previous/next simulation turns
|
2010-01-09 20:20:14 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
class CMessageRenderSubmit : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(RenderSubmit)
|
|
|
|
|
|
|
|
CMessageRenderSubmit(SceneCollector& collector, const CFrustum& frustum, bool culling) :
|
|
|
|
collector(collector), frustum(frustum), culling(culling)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
SceneCollector& collector;
|
|
|
|
const CFrustum& frustum;
|
|
|
|
bool culling;
|
|
|
|
};
|
|
|
|
|
2010-07-18 17:19:49 +02:00
|
|
|
/**
|
2010-07-29 22:39:23 +02:00
|
|
|
* This is sent immediately after a new entity's components have all been created
|
2010-07-18 17:19:49 +02:00
|
|
|
* and initialised.
|
|
|
|
*/
|
|
|
|
class CMessageCreate : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(Create)
|
|
|
|
|
|
|
|
CMessageCreate(entity_id_t entity) :
|
|
|
|
entity(entity)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
entity_id_t entity;
|
|
|
|
};
|
|
|
|
|
2010-01-22 21:03:14 +01:00
|
|
|
/**
|
|
|
|
* This is sent immediately before a destroyed entity is flushed and really destroyed.
|
|
|
|
* (That is, after CComponentManager::DestroyComponentsSoon and inside FlushDestroyedComponents).
|
|
|
|
* The entity will still exist at the time this message is sent.
|
|
|
|
* It's possible for this message to be sent multiple times for one entity, but all its components
|
|
|
|
* will have been deleted after the first time.
|
|
|
|
*/
|
|
|
|
class CMessageDestroy : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(Destroy)
|
|
|
|
|
2010-03-07 21:14:30 +01:00
|
|
|
CMessageDestroy(entity_id_t entity) :
|
|
|
|
entity(entity)
|
2010-01-22 21:03:14 +01:00
|
|
|
{
|
|
|
|
}
|
2010-03-07 21:14:30 +01:00
|
|
|
|
|
|
|
entity_id_t entity;
|
2010-01-22 21:03:14 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
class CMessageOwnershipChanged : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(OwnershipChanged)
|
|
|
|
|
|
|
|
CMessageOwnershipChanged(entity_id_t entity, int32_t from, int32_t to) :
|
|
|
|
entity(entity), from(from), to(to)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
entity_id_t entity;
|
|
|
|
int32_t from;
|
|
|
|
int32_t to;
|
|
|
|
};
|
|
|
|
|
2010-01-29 22:13:18 +01:00
|
|
|
/**
|
|
|
|
* Sent during TurnStart.
|
|
|
|
*
|
|
|
|
* If @c inWorld is false, then the other fields are invalid and meaningless.
|
|
|
|
* Otherwise they represent the current position.
|
|
|
|
*/
|
|
|
|
class CMessagePositionChanged : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(PositionChanged)
|
|
|
|
|
2010-07-29 22:39:23 +02:00
|
|
|
CMessagePositionChanged(entity_id_t entity, bool inWorld, entity_pos_t x, entity_pos_t z, entity_angle_t a) :
|
|
|
|
entity(entity), inWorld(inWorld), x(x), z(z), a(a)
|
2010-01-29 22:13:18 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2010-07-29 22:39:23 +02:00
|
|
|
entity_id_t entity;
|
2010-01-29 22:13:18 +01:00
|
|
|
bool inWorld;
|
|
|
|
entity_pos_t x, z;
|
|
|
|
entity_angle_t a;
|
|
|
|
};
|
|
|
|
|
2010-02-10 20:28:46 +01:00
|
|
|
/**
|
|
|
|
* Sent by CCmpUnitMotion during Update, whenever the motion status has changed
|
|
|
|
* since the previous update.
|
|
|
|
*/
|
|
|
|
class CMessageMotionChanged : public CMessage
|
2010-02-07 21:06:16 +01:00
|
|
|
{
|
|
|
|
public:
|
2010-02-10 20:28:46 +01:00
|
|
|
DEFAULT_MESSAGE_IMPL(MotionChanged)
|
2010-02-07 21:06:16 +01:00
|
|
|
|
2010-09-03 11:55:14 +02:00
|
|
|
CMessageMotionChanged(bool starting, bool error) :
|
|
|
|
starting(starting), error(error)
|
2010-02-07 21:06:16 +01:00
|
|
|
{
|
|
|
|
}
|
2010-02-10 20:28:46 +01:00
|
|
|
|
2010-09-03 11:55:14 +02:00
|
|
|
bool starting; // whether this is a start or end of movement
|
|
|
|
bool error; // whether we failed to start moving (couldn't find any path)
|
2010-02-07 21:06:16 +01:00
|
|
|
};
|
2010-01-22 21:03:14 +01:00
|
|
|
|
2010-05-28 01:31:03 +02:00
|
|
|
/**
|
|
|
|
* Sent when terrain (texture or elevation) has been changed.
|
|
|
|
*/
|
|
|
|
class CMessageTerrainChanged : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(TerrainChanged)
|
|
|
|
|
|
|
|
CMessageTerrainChanged(ssize_t i0, ssize_t j0, ssize_t i1, ssize_t j1) :
|
|
|
|
i0(i0), j0(j0), i1(i1), j1(j1)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
ssize_t i0, j0, i1, j1; // inclusive lower bound, exclusive upper bound, in tiles
|
|
|
|
};
|
|
|
|
|
2010-07-29 22:39:23 +02:00
|
|
|
/**
|
|
|
|
* Sent by CCmpRangeManager at most once per turn, when an active range query
|
|
|
|
* has had matching units enter/leave the range since the last RangeUpdate.
|
|
|
|
*/
|
|
|
|
class CMessageRangeUpdate : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(RangeUpdate)
|
|
|
|
|
|
|
|
CMessageRangeUpdate(u32 tag, const std::vector<entity_id_t>& added, const std::vector<entity_id_t>& removed) :
|
|
|
|
tag(tag), added(added), removed(removed)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
u32 tag;
|
|
|
|
std::vector<entity_id_t> added;
|
|
|
|
std::vector<entity_id_t> removed;
|
|
|
|
|
|
|
|
// CCmpRangeManager wants to store a vector of messages and wants to
|
|
|
|
// swap vectors instead of copying (to save on memory allocations),
|
|
|
|
// so add some constructors for it:
|
|
|
|
|
|
|
|
CMessageRangeUpdate(u32 tag) :
|
|
|
|
tag(tag)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
CMessageRangeUpdate(const CMessageRangeUpdate& other) :
|
|
|
|
CMessage(), tag(other.tag), added(other.added), removed(other.removed)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
CMessageRangeUpdate& operator=(const CMessageRangeUpdate& other)
|
|
|
|
{
|
|
|
|
tag = other.tag;
|
|
|
|
added = other.added;
|
|
|
|
removed = other.removed;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2010-09-03 11:55:14 +02:00
|
|
|
/**
|
|
|
|
* Sent by CCmpPathfinder after async path requests.
|
|
|
|
*/
|
|
|
|
class CMessagePathResult : public CMessage
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
DEFAULT_MESSAGE_IMPL(PathResult)
|
|
|
|
|
|
|
|
CMessagePathResult(u32 ticket, const ICmpPathfinder::Path& path) :
|
|
|
|
ticket(ticket), path(path)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
u32 ticket;
|
|
|
|
ICmpPathfinder::Path path;
|
|
|
|
};
|
|
|
|
|
2010-01-09 20:20:14 +01:00
|
|
|
#endif // INCLUDED_MESSAGETYPES
|