2010-08-03 18:44:52 +02:00
|
|
|
#ifndef GAME_MWWORLD_ACTIONTELEPORT_H
|
|
|
|
#define GAME_MWWORLD_ACTIONTELEPORT_H
|
|
|
|
|
2016-12-23 21:27:29 +01:00
|
|
|
#include <set>
|
2010-08-03 18:44:52 +02:00
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include <components/esm/defs.hpp>
|
|
|
|
|
|
|
|
#include "action.hpp"
|
|
|
|
|
|
|
|
namespace MWWorld
|
|
|
|
{
|
2012-07-27 12:00:10 +02:00
|
|
|
class ActionTeleport : public Action
|
2010-08-03 18:44:52 +02:00
|
|
|
{
|
|
|
|
std::string mCellName;
|
|
|
|
ESM::Position mPosition;
|
2015-05-22 19:56:39 +02:00
|
|
|
bool mTeleportFollowers;
|
2010-08-03 18:44:52 +02:00
|
|
|
|
2014-08-24 22:51:47 +02:00
|
|
|
/// Teleports this actor and also teleports anyone following that actor.
|
2020-10-16 22:18:54 +04:00
|
|
|
void executeImp (const Ptr& actor) override;
|
2012-07-27 12:00:10 +02:00
|
|
|
|
2014-08-24 22:51:47 +02:00
|
|
|
/// Teleports only the given actor (internal use).
|
|
|
|
void teleport(const Ptr &actor);
|
|
|
|
|
2010-08-03 18:44:52 +02:00
|
|
|
public:
|
|
|
|
|
2016-12-26 21:46:43 +01:00
|
|
|
/// If cellName is empty, an exterior cell is assumed.
|
2015-05-22 19:56:39 +02:00
|
|
|
/// @param teleportFollowers Whether to teleport any following actors of the target actor as well.
|
2016-12-23 21:27:29 +01:00
|
|
|
ActionTeleport (const std::string& cellName, const ESM::Position& position, bool teleportFollowers);
|
|
|
|
|
2020-10-03 20:05:17 +00:00
|
|
|
/// @param includeHostiles If true, include hostile followers (which won't actually be teleported) in the output,
|
|
|
|
/// e.g. so that the teleport action can calm them.
|
|
|
|
static void getFollowers(const MWWorld::Ptr& actor, std::set<MWWorld::Ptr>& out, bool includeHostiles = false);
|
2010-08-03 18:44:52 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|