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>
|
2022-08-27 13:07:59 +02:00
|
|
|
#include <string_view>
|
2010-08-03 18:44:52 +02:00
|
|
|
|
|
|
|
#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
|
|
|
{
|
2023-02-19 17:42:37 +01:00
|
|
|
ESM::RefId mCellId;
|
2010-08-03 18:44:52 +02:00
|
|
|
ESM::Position mPosition;
|
2015-05-22 19:56:39 +02:00
|
|
|
bool mTeleportFollowers;
|
2022-09-22 21:26:05 +03: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;
|
2022-09-22 21:26:05 +03:00
|
|
|
|
2014-08-24 22:51:47 +02:00
|
|
|
/// Teleports only the given actor (internal use).
|
|
|
|
void teleport(const Ptr& actor);
|
2022-09-22 21:26:05 +03:00
|
|
|
|
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.
|
2023-02-19 17:42:37 +01:00
|
|
|
ActionTeleport(ESM::RefId cellId, const ESM::Position& position, bool teleportFollowers);
|
2022-09-22 21:26:05 +03:00
|
|
|
|
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.
|
2021-10-06 18:25:28 +02:00
|
|
|
static void getFollowers(
|
|
|
|
const MWWorld::Ptr& actor, std::set<MWWorld::Ptr>& out, bool toExterior, bool includeHostiles = false);
|
2010-08-03 18:44:52 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|