mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-16 17:59:56 +00:00
Merge branch 'renormalise' into 'master'
Renormalise line endings See merge request OpenMW/openmw!2412
This commit is contained in:
commit
46935e9e97
63 changed files with 9899 additions and 9894 deletions
|
@ -5,3 +5,8 @@
|
||||||
# Date: Fri Sep 2 02:52:49 2022 +0000
|
# Date: Fri Sep 2 02:52:49 2022 +0000
|
||||||
# Reformat NIF record type mapping
|
# Reformat NIF record type mapping
|
||||||
8df0587793a07ec556dc9cb575cd2af4204c456b
|
8df0587793a07ec556dc9cb575cd2af4204c456b
|
||||||
|
|
||||||
|
# Author: AnyOldName3 <krizdjali@gmail.com>
|
||||||
|
# Date: Fri Sep 16 00:53:24 2022 +0100
|
||||||
|
# Renormalise line endings
|
||||||
|
84f8a6848a8b05502d7618ca7af8cca74f2c3bae
|
||||||
|
|
|
@ -1,63 +1,63 @@
|
||||||
#include "aiactivate.hpp"
|
#include "aiactivate.hpp"
|
||||||
|
|
||||||
#include <components/esm3/aisequence.hpp>
|
#include <components/esm3/aisequence.hpp>
|
||||||
|
|
||||||
#include "../mwbase/world.hpp"
|
#include "../mwbase/world.hpp"
|
||||||
#include "../mwbase/environment.hpp"
|
#include "../mwbase/environment.hpp"
|
||||||
|
|
||||||
#include "../mwworld/class.hpp"
|
#include "../mwworld/class.hpp"
|
||||||
|
|
||||||
#include "creaturestats.hpp"
|
#include "creaturestats.hpp"
|
||||||
#include "movement.hpp"
|
#include "movement.hpp"
|
||||||
#include "steering.hpp"
|
#include "steering.hpp"
|
||||||
|
|
||||||
namespace MWMechanics
|
namespace MWMechanics
|
||||||
{
|
{
|
||||||
AiActivate::AiActivate(std::string_view objectId, bool repeat)
|
AiActivate::AiActivate(std::string_view objectId, bool repeat)
|
||||||
: TypedAiPackage<AiActivate>(repeat), mObjectId(objectId)
|
: TypedAiPackage<AiActivate>(repeat), mObjectId(objectId)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AiActivate::execute(const MWWorld::Ptr& actor, CharacterController& characterController, AiState& state, float duration)
|
bool AiActivate::execute(const MWWorld::Ptr& actor, CharacterController& characterController, AiState& state, float duration)
|
||||||
{
|
{
|
||||||
const MWWorld::Ptr target = MWBase::Environment::get().getWorld()->searchPtr(mObjectId, false); //The target to follow
|
const MWWorld::Ptr target = MWBase::Environment::get().getWorld()->searchPtr(mObjectId, false); //The target to follow
|
||||||
|
|
||||||
actor.getClass().getCreatureStats(actor).setDrawState(DrawState::Nothing);
|
actor.getClass().getCreatureStats(actor).setDrawState(DrawState::Nothing);
|
||||||
|
|
||||||
// Stop if the target doesn't exist
|
// Stop if the target doesn't exist
|
||||||
// Really we should be checking whether the target is currently registered with the MechanicsManager
|
// Really we should be checking whether the target is currently registered with the MechanicsManager
|
||||||
if (target == MWWorld::Ptr() || !target.getRefData().getCount() || !target.getRefData().isEnabled())
|
if (target == MWWorld::Ptr() || !target.getRefData().getCount() || !target.getRefData().isEnabled())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
// Turn to target and move to it directly, without pathfinding.
|
// Turn to target and move to it directly, without pathfinding.
|
||||||
const osg::Vec3f targetDir = target.getRefData().getPosition().asVec3() - actor.getRefData().getPosition().asVec3();
|
const osg::Vec3f targetDir = target.getRefData().getPosition().asVec3() - actor.getRefData().getPosition().asVec3();
|
||||||
|
|
||||||
zTurn(actor, std::atan2(targetDir.x(), targetDir.y()), 0.f);
|
zTurn(actor, std::atan2(targetDir.x(), targetDir.y()), 0.f);
|
||||||
actor.getClass().getMovementSettings(actor).mPosition[1] = 1;
|
actor.getClass().getMovementSettings(actor).mPosition[1] = 1;
|
||||||
actor.getClass().getMovementSettings(actor).mPosition[0] = 0;
|
actor.getClass().getMovementSettings(actor).mPosition[0] = 0;
|
||||||
|
|
||||||
if (MWBase::Environment::get().getWorld()->getMaxActivationDistance() >= targetDir.length())
|
if (MWBase::Environment::get().getWorld()->getMaxActivationDistance() >= targetDir.length())
|
||||||
{
|
{
|
||||||
// Note: we intentionally do not cancel package after activation here for backward compatibility with original engine.
|
// Note: we intentionally do not cancel package after activation here for backward compatibility with original engine.
|
||||||
MWBase::Environment::get().getWorld()->activate(target, actor);
|
MWBase::Environment::get().getWorld()->activate(target, actor);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AiActivate::writeState(ESM::AiSequence::AiSequence &sequence) const
|
void AiActivate::writeState(ESM::AiSequence::AiSequence &sequence) const
|
||||||
{
|
{
|
||||||
auto activate = std::make_unique<ESM::AiSequence::AiActivate>();
|
auto activate = std::make_unique<ESM::AiSequence::AiActivate>();
|
||||||
activate->mTargetId = mObjectId;
|
activate->mTargetId = mObjectId;
|
||||||
activate->mRepeat = getRepeat();
|
activate->mRepeat = getRepeat();
|
||||||
|
|
||||||
ESM::AiSequence::AiPackageContainer package;
|
ESM::AiSequence::AiPackageContainer package;
|
||||||
package.mType = ESM::AiSequence::Ai_Activate;
|
package.mType = ESM::AiSequence::Ai_Activate;
|
||||||
package.mPackage = std::move(activate);
|
package.mPackage = std::move(activate);
|
||||||
sequence.mPackages.push_back(std::move(package));
|
sequence.mPackages.push_back(std::move(package));
|
||||||
}
|
}
|
||||||
|
|
||||||
AiActivate::AiActivate(const ESM::AiSequence::AiActivate *activate)
|
AiActivate::AiActivate(const ESM::AiSequence::AiActivate *activate)
|
||||||
: AiActivate(activate->mTargetId, activate->mRepeat)
|
: AiActivate(activate->mTargetId, activate->mRepeat)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,40 +1,40 @@
|
||||||
#ifndef GAME_MWMECHANICS_AIACTIVATE_H
|
#ifndef GAME_MWMECHANICS_AIACTIVATE_H
|
||||||
#define GAME_MWMECHANICS_AIACTIVATE_H
|
#define GAME_MWMECHANICS_AIACTIVATE_H
|
||||||
|
|
||||||
#include "typedaipackage.hpp"
|
#include "typedaipackage.hpp"
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <string_view>
|
#include <string_view>
|
||||||
|
|
||||||
namespace ESM
|
namespace ESM
|
||||||
{
|
{
|
||||||
namespace AiSequence
|
namespace AiSequence
|
||||||
{
|
{
|
||||||
struct AiActivate;
|
struct AiActivate;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace MWMechanics
|
namespace MWMechanics
|
||||||
{
|
{
|
||||||
/// \brief Causes actor to walk to activatable object and activate it
|
/// \brief Causes actor to walk to activatable object and activate it
|
||||||
/** Will activate when close to object **/
|
/** Will activate when close to object **/
|
||||||
class AiActivate final : public TypedAiPackage<AiActivate>
|
class AiActivate final : public TypedAiPackage<AiActivate>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/// Constructor
|
/// Constructor
|
||||||
/** \param objectId Reference to object to activate **/
|
/** \param objectId Reference to object to activate **/
|
||||||
explicit AiActivate(std::string_view objectId, bool repeat);
|
explicit AiActivate(std::string_view objectId, bool repeat);
|
||||||
|
|
||||||
explicit AiActivate(const ESM::AiSequence::AiActivate* activate);
|
explicit AiActivate(const ESM::AiSequence::AiActivate* activate);
|
||||||
|
|
||||||
bool execute (const MWWorld::Ptr& actor, CharacterController& characterController, AiState& state, float duration) override;
|
bool execute (const MWWorld::Ptr& actor, CharacterController& characterController, AiState& state, float duration) override;
|
||||||
|
|
||||||
static constexpr AiPackageTypeId getTypeId() { return AiPackageTypeId::Activate; }
|
static constexpr AiPackageTypeId getTypeId() { return AiPackageTypeId::Activate; }
|
||||||
|
|
||||||
void writeState(ESM::AiSequence::AiSequence& sequence) const override;
|
void writeState(ESM::AiSequence::AiSequence& sequence) const override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const std::string mObjectId;
|
const std::string mObjectId;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
#endif // GAME_MWMECHANICS_AIACTIVATE_H
|
#endif // GAME_MWMECHANICS_AIACTIVATE_H
|
||||||
|
|
|
@ -1,123 +1,123 @@
|
||||||
#include "aiescort.hpp"
|
#include "aiescort.hpp"
|
||||||
|
|
||||||
#include <components/esm3/aisequence.hpp>
|
#include <components/esm3/aisequence.hpp>
|
||||||
#include <components/esm3/loadcell.hpp>
|
#include <components/esm3/loadcell.hpp>
|
||||||
|
|
||||||
#include "../mwbase/world.hpp"
|
#include "../mwbase/world.hpp"
|
||||||
#include "../mwbase/environment.hpp"
|
#include "../mwbase/environment.hpp"
|
||||||
#include "../mwbase/mechanicsmanager.hpp"
|
#include "../mwbase/mechanicsmanager.hpp"
|
||||||
|
|
||||||
#include "../mwworld/class.hpp"
|
#include "../mwworld/class.hpp"
|
||||||
#include "../mwworld/cellstore.hpp"
|
#include "../mwworld/cellstore.hpp"
|
||||||
|
|
||||||
#include "creaturestats.hpp"
|
#include "creaturestats.hpp"
|
||||||
#include "movement.hpp"
|
#include "movement.hpp"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
TODO: Different behavior for AIEscort a d x y z and AIEscortCell a c d x y z.
|
TODO: Different behavior for AIEscort a d x y z and AIEscortCell a c d x y z.
|
||||||
TODO: Take account for actors being in different cells.
|
TODO: Take account for actors being in different cells.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace MWMechanics
|
namespace MWMechanics
|
||||||
{
|
{
|
||||||
AiEscort::AiEscort(std::string_view actorId, int duration, float x, float y, float z, bool repeat)
|
AiEscort::AiEscort(std::string_view actorId, int duration, float x, float y, float z, bool repeat)
|
||||||
: TypedAiPackage<AiEscort>(repeat), mX(x), mY(y), mZ(z), mDuration(duration), mRemainingDuration(static_cast<float>(duration))
|
: TypedAiPackage<AiEscort>(repeat), mX(x), mY(y), mZ(z), mDuration(duration), mRemainingDuration(static_cast<float>(duration))
|
||||||
, mCellX(std::numeric_limits<int>::max())
|
, mCellX(std::numeric_limits<int>::max())
|
||||||
, mCellY(std::numeric_limits<int>::max())
|
, mCellY(std::numeric_limits<int>::max())
|
||||||
{
|
{
|
||||||
mTargetActorRefId = std::string(actorId);
|
mTargetActorRefId = std::string(actorId);
|
||||||
}
|
}
|
||||||
|
|
||||||
AiEscort::AiEscort(std::string_view actorId, std::string_view cellId, int duration, float x, float y, float z, bool repeat)
|
AiEscort::AiEscort(std::string_view actorId, std::string_view cellId, int duration, float x, float y, float z, bool repeat)
|
||||||
: TypedAiPackage<AiEscort>(repeat), mCellId(cellId), mX(x), mY(y), mZ(z), mDuration(duration), mRemainingDuration(static_cast<float>(duration))
|
: TypedAiPackage<AiEscort>(repeat), mCellId(cellId), mX(x), mY(y), mZ(z), mDuration(duration), mRemainingDuration(static_cast<float>(duration))
|
||||||
, mCellX(std::numeric_limits<int>::max())
|
, mCellX(std::numeric_limits<int>::max())
|
||||||
, mCellY(std::numeric_limits<int>::max())
|
, mCellY(std::numeric_limits<int>::max())
|
||||||
{
|
{
|
||||||
mTargetActorRefId = std::string(actorId);
|
mTargetActorRefId = std::string(actorId);
|
||||||
}
|
}
|
||||||
|
|
||||||
AiEscort::AiEscort(const ESM::AiSequence::AiEscort *escort)
|
AiEscort::AiEscort(const ESM::AiSequence::AiEscort *escort)
|
||||||
: TypedAiPackage<AiEscort>(escort->mRepeat), mCellId(escort->mCellId), mX(escort->mData.mX), mY(escort->mData.mY), mZ(escort->mData.mZ)
|
: TypedAiPackage<AiEscort>(escort->mRepeat), mCellId(escort->mCellId), mX(escort->mData.mX), mY(escort->mData.mY), mZ(escort->mData.mZ)
|
||||||
, mDuration(escort->mData.mDuration)
|
, mDuration(escort->mData.mDuration)
|
||||||
, mRemainingDuration(escort->mRemainingDuration)
|
, mRemainingDuration(escort->mRemainingDuration)
|
||||||
, mCellX(std::numeric_limits<int>::max())
|
, mCellX(std::numeric_limits<int>::max())
|
||||||
, mCellY(std::numeric_limits<int>::max())
|
, mCellY(std::numeric_limits<int>::max())
|
||||||
{
|
{
|
||||||
mTargetActorRefId = escort->mTargetId;
|
mTargetActorRefId = escort->mTargetId;
|
||||||
mTargetActorId = escort->mTargetActorId;
|
mTargetActorId = escort->mTargetActorId;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AiEscort::execute (const MWWorld::Ptr& actor, CharacterController& characterController, AiState& state, float duration)
|
bool AiEscort::execute (const MWWorld::Ptr& actor, CharacterController& characterController, AiState& state, float duration)
|
||||||
{
|
{
|
||||||
// If AiEscort has ran for as long or longer then the duration specified
|
// If AiEscort has ran for as long or longer then the duration specified
|
||||||
// and the duration is not infinite, the package is complete.
|
// and the duration is not infinite, the package is complete.
|
||||||
if (mDuration > 0)
|
if (mDuration > 0)
|
||||||
{
|
{
|
||||||
mRemainingDuration -= ((duration*MWBase::Environment::get().getWorld()->getTimeScaleFactor()) / 3600);
|
mRemainingDuration -= ((duration*MWBase::Environment::get().getWorld()->getTimeScaleFactor()) / 3600);
|
||||||
if (mRemainingDuration <= 0)
|
if (mRemainingDuration <= 0)
|
||||||
{
|
{
|
||||||
mRemainingDuration = mDuration;
|
mRemainingDuration = mDuration;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!mCellId.empty() && mCellId != actor.getCell()->getCell()->getCellId().mWorldspace)
|
if (!mCellId.empty() && mCellId != actor.getCell()->getCell()->getCellId().mWorldspace)
|
||||||
return false; // Not in the correct cell, pause and rely on the player to go back through a teleport door
|
return false; // Not in the correct cell, pause and rely on the player to go back through a teleport door
|
||||||
|
|
||||||
actor.getClass().getCreatureStats(actor).setDrawState(DrawState::Nothing);
|
actor.getClass().getCreatureStats(actor).setDrawState(DrawState::Nothing);
|
||||||
actor.getClass().getCreatureStats(actor).setMovementFlag(CreatureStats::Flag_Run, false);
|
actor.getClass().getCreatureStats(actor).setMovementFlag(CreatureStats::Flag_Run, false);
|
||||||
|
|
||||||
const MWWorld::Ptr follower = MWBase::Environment::get().getWorld()->getPtr(mTargetActorRefId, false);
|
const MWWorld::Ptr follower = MWBase::Environment::get().getWorld()->getPtr(mTargetActorRefId, false);
|
||||||
const osg::Vec3f leaderPos = actor.getRefData().getPosition().asVec3();
|
const osg::Vec3f leaderPos = actor.getRefData().getPosition().asVec3();
|
||||||
const osg::Vec3f followerPos = follower.getRefData().getPosition().asVec3();
|
const osg::Vec3f followerPos = follower.getRefData().getPosition().asVec3();
|
||||||
const osg::Vec3f halfExtents = MWBase::Environment::get().getWorld()->getHalfExtents(actor);
|
const osg::Vec3f halfExtents = MWBase::Environment::get().getWorld()->getHalfExtents(actor);
|
||||||
const float maxHalfExtent = std::max(halfExtents.x(), std::max(halfExtents.y(), halfExtents.z()));
|
const float maxHalfExtent = std::max(halfExtents.x(), std::max(halfExtents.y(), halfExtents.z()));
|
||||||
|
|
||||||
if ((leaderPos - followerPos).length2() <= mMaxDist * mMaxDist)
|
if ((leaderPos - followerPos).length2() <= mMaxDist * mMaxDist)
|
||||||
{
|
{
|
||||||
const osg::Vec3f dest(mX, mY, mZ);
|
const osg::Vec3f dest(mX, mY, mZ);
|
||||||
if (pathTo(actor, dest, duration, maxHalfExtent)) //Returns true on path complete
|
if (pathTo(actor, dest, duration, maxHalfExtent)) //Returns true on path complete
|
||||||
{
|
{
|
||||||
mRemainingDuration = mDuration;
|
mRemainingDuration = mDuration;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
mMaxDist = maxHalfExtent + 450.0f;
|
mMaxDist = maxHalfExtent + 450.0f;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Stop moving if the player is too far away
|
// Stop moving if the player is too far away
|
||||||
MWBase::Environment::get().getMechanicsManager()->playAnimationGroup(actor, "idle3", 0, 1);
|
MWBase::Environment::get().getMechanicsManager()->playAnimationGroup(actor, "idle3", 0, 1);
|
||||||
actor.getClass().getMovementSettings(actor).mPosition[1] = 0;
|
actor.getClass().getMovementSettings(actor).mPosition[1] = 0;
|
||||||
mMaxDist = maxHalfExtent + 250.0f;
|
mMaxDist = maxHalfExtent + 250.0f;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AiEscort::writeState(ESM::AiSequence::AiSequence &sequence) const
|
void AiEscort::writeState(ESM::AiSequence::AiSequence &sequence) const
|
||||||
{
|
{
|
||||||
auto escort = std::make_unique<ESM::AiSequence::AiEscort>();
|
auto escort = std::make_unique<ESM::AiSequence::AiEscort>();
|
||||||
escort->mData.mX = mX;
|
escort->mData.mX = mX;
|
||||||
escort->mData.mY = mY;
|
escort->mData.mY = mY;
|
||||||
escort->mData.mZ = mZ;
|
escort->mData.mZ = mZ;
|
||||||
escort->mData.mDuration = mDuration;
|
escort->mData.mDuration = mDuration;
|
||||||
escort->mTargetId = mTargetActorRefId;
|
escort->mTargetId = mTargetActorRefId;
|
||||||
escort->mTargetActorId = mTargetActorId;
|
escort->mTargetActorId = mTargetActorId;
|
||||||
escort->mRemainingDuration = mRemainingDuration;
|
escort->mRemainingDuration = mRemainingDuration;
|
||||||
escort->mCellId = mCellId;
|
escort->mCellId = mCellId;
|
||||||
escort->mRepeat = getRepeat();
|
escort->mRepeat = getRepeat();
|
||||||
|
|
||||||
ESM::AiSequence::AiPackageContainer package;
|
ESM::AiSequence::AiPackageContainer package;
|
||||||
package.mType = ESM::AiSequence::Ai_Escort;
|
package.mType = ESM::AiSequence::Ai_Escort;
|
||||||
package.mPackage = std::move(escort);
|
package.mPackage = std::move(escort);
|
||||||
sequence.mPackages.push_back(std::move(package));
|
sequence.mPackages.push_back(std::move(package));
|
||||||
}
|
}
|
||||||
|
|
||||||
void AiEscort::fastForward(const MWWorld::Ptr& actor, AiState &state)
|
void AiEscort::fastForward(const MWWorld::Ptr& actor, AiState &state)
|
||||||
{
|
{
|
||||||
// Update duration counter if this package has a duration
|
// Update duration counter if this package has a duration
|
||||||
if (mDuration > 0)
|
if (mDuration > 0)
|
||||||
mRemainingDuration--;
|
mRemainingDuration--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,71 +1,71 @@
|
||||||
#ifndef GAME_MWMECHANICS_AITRAVEL_H
|
#ifndef GAME_MWMECHANICS_AITRAVEL_H
|
||||||
#define GAME_MWMECHANICS_AITRAVEL_H
|
#define GAME_MWMECHANICS_AITRAVEL_H
|
||||||
|
|
||||||
#include "typedaipackage.hpp"
|
#include "typedaipackage.hpp"
|
||||||
|
|
||||||
namespace ESM
|
namespace ESM
|
||||||
{
|
{
|
||||||
namespace AiSequence
|
namespace AiSequence
|
||||||
{
|
{
|
||||||
struct AiTravel;
|
struct AiTravel;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace MWMechanics
|
namespace MWMechanics
|
||||||
{
|
{
|
||||||
struct AiInternalTravel;
|
struct AiInternalTravel;
|
||||||
|
|
||||||
/// \brief Causes the AI to travel to the specified point
|
/// \brief Causes the AI to travel to the specified point
|
||||||
class AiTravel : public TypedAiPackage<AiTravel>
|
class AiTravel : public TypedAiPackage<AiTravel>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
AiTravel(float x, float y, float z, bool repeat, AiTravel* derived);
|
AiTravel(float x, float y, float z, bool repeat, AiTravel* derived);
|
||||||
|
|
||||||
AiTravel(float x, float y, float z, AiInternalTravel* derived);
|
AiTravel(float x, float y, float z, AiInternalTravel* derived);
|
||||||
|
|
||||||
AiTravel(float x, float y, float z, bool repeat);
|
AiTravel(float x, float y, float z, bool repeat);
|
||||||
|
|
||||||
explicit AiTravel(const ESM::AiSequence::AiTravel* travel);
|
explicit AiTravel(const ESM::AiSequence::AiTravel* travel);
|
||||||
|
|
||||||
/// Simulates the passing of time
|
/// Simulates the passing of time
|
||||||
void fastForward(const MWWorld::Ptr& actor, AiState& state) override;
|
void fastForward(const MWWorld::Ptr& actor, AiState& state) override;
|
||||||
|
|
||||||
void writeState(ESM::AiSequence::AiSequence &sequence) const override;
|
void writeState(ESM::AiSequence::AiSequence &sequence) const override;
|
||||||
|
|
||||||
bool execute (const MWWorld::Ptr& actor, CharacterController& characterController, AiState& state, float duration) override;
|
bool execute (const MWWorld::Ptr& actor, CharacterController& characterController, AiState& state, float duration) override;
|
||||||
|
|
||||||
static constexpr AiPackageTypeId getTypeId() { return AiPackageTypeId::Travel; }
|
static constexpr AiPackageTypeId getTypeId() { return AiPackageTypeId::Travel; }
|
||||||
|
|
||||||
static constexpr Options makeDefaultOptions()
|
static constexpr Options makeDefaultOptions()
|
||||||
{
|
{
|
||||||
AiPackage::Options options;
|
AiPackage::Options options;
|
||||||
options.mUseVariableSpeed = true;
|
options.mUseVariableSpeed = true;
|
||||||
options.mAlwaysActive = true;
|
options.mAlwaysActive = true;
|
||||||
return options;
|
return options;
|
||||||
}
|
}
|
||||||
|
|
||||||
osg::Vec3f getDestination() const override { return osg::Vec3f(mX, mY, mZ); }
|
osg::Vec3f getDestination() const override { return osg::Vec3f(mX, mY, mZ); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const float mX;
|
const float mX;
|
||||||
const float mY;
|
const float mY;
|
||||||
const float mZ;
|
const float mZ;
|
||||||
|
|
||||||
const bool mHidden;
|
const bool mHidden;
|
||||||
|
|
||||||
float mDestinationTimer;
|
float mDestinationTimer;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct AiInternalTravel final : public AiTravel
|
struct AiInternalTravel final : public AiTravel
|
||||||
{
|
{
|
||||||
AiInternalTravel(float x, float y, float z);
|
AiInternalTravel(float x, float y, float z);
|
||||||
|
|
||||||
explicit AiInternalTravel(const ESM::AiSequence::AiTravel* travel);
|
explicit AiInternalTravel(const ESM::AiSequence::AiTravel* travel);
|
||||||
|
|
||||||
static constexpr AiPackageTypeId getTypeId() { return AiPackageTypeId::InternalTravel; }
|
static constexpr AiPackageTypeId getTypeId() { return AiPackageTypeId::InternalTravel; }
|
||||||
|
|
||||||
std::unique_ptr<AiPackage> clone() const override;
|
std::unique_ptr<AiPackage> clone() const override;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,75 +1,75 @@
|
||||||
#include "weatherstate.hpp"
|
#include "weatherstate.hpp"
|
||||||
|
|
||||||
#include "esmreader.hpp"
|
#include "esmreader.hpp"
|
||||||
#include "esmwriter.hpp"
|
#include "esmwriter.hpp"
|
||||||
|
|
||||||
namespace ESM
|
namespace ESM
|
||||||
{
|
{
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
constexpr NAME currentRegionRecord = "CREG";
|
constexpr NAME currentRegionRecord = "CREG";
|
||||||
constexpr NAME timePassedRecord = "TMPS";
|
constexpr NAME timePassedRecord = "TMPS";
|
||||||
constexpr NAME fastForwardRecord = "FAST";
|
constexpr NAME fastForwardRecord = "FAST";
|
||||||
constexpr NAME weatherUpdateTimeRecord = "WUPD";
|
constexpr NAME weatherUpdateTimeRecord = "WUPD";
|
||||||
constexpr NAME transitionFactorRecord = "TRFC";
|
constexpr NAME transitionFactorRecord = "TRFC";
|
||||||
constexpr NAME currentWeatherRecord = "CWTH";
|
constexpr NAME currentWeatherRecord = "CWTH";
|
||||||
constexpr NAME nextWeatherRecord = "NWTH";
|
constexpr NAME nextWeatherRecord = "NWTH";
|
||||||
constexpr NAME queuedWeatherRecord = "QWTH";
|
constexpr NAME queuedWeatherRecord = "QWTH";
|
||||||
constexpr NAME regionNameRecord = "RGNN";
|
constexpr NAME regionNameRecord = "RGNN";
|
||||||
constexpr NAME regionWeatherRecord = "RGNW";
|
constexpr NAME regionWeatherRecord = "RGNW";
|
||||||
constexpr NAME regionChanceRecord = "RGNC";
|
constexpr NAME regionChanceRecord = "RGNC";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace ESM
|
namespace ESM
|
||||||
{
|
{
|
||||||
void WeatherState::load(ESMReader& esm)
|
void WeatherState::load(ESMReader& esm)
|
||||||
{
|
{
|
||||||
mCurrentRegion = esm.getHNString(currentRegionRecord);
|
mCurrentRegion = esm.getHNString(currentRegionRecord);
|
||||||
esm.getHNT(mTimePassed, timePassedRecord);
|
esm.getHNT(mTimePassed, timePassedRecord);
|
||||||
esm.getHNT(mFastForward, fastForwardRecord);
|
esm.getHNT(mFastForward, fastForwardRecord);
|
||||||
esm.getHNT(mWeatherUpdateTime, weatherUpdateTimeRecord);
|
esm.getHNT(mWeatherUpdateTime, weatherUpdateTimeRecord);
|
||||||
esm.getHNT(mTransitionFactor, transitionFactorRecord);
|
esm.getHNT(mTransitionFactor, transitionFactorRecord);
|
||||||
esm.getHNT(mCurrentWeather, currentWeatherRecord);
|
esm.getHNT(mCurrentWeather, currentWeatherRecord);
|
||||||
esm.getHNT(mNextWeather, nextWeatherRecord);
|
esm.getHNT(mNextWeather, nextWeatherRecord);
|
||||||
esm.getHNT(mQueuedWeather, queuedWeatherRecord);
|
esm.getHNT(mQueuedWeather, queuedWeatherRecord);
|
||||||
|
|
||||||
while (esm.isNextSub(regionNameRecord))
|
while (esm.isNextSub(regionNameRecord))
|
||||||
{
|
{
|
||||||
std::string regionID = esm.getHString();
|
std::string regionID = esm.getHString();
|
||||||
RegionWeatherState region;
|
RegionWeatherState region;
|
||||||
esm.getHNT(region.mWeather, regionWeatherRecord);
|
esm.getHNT(region.mWeather, regionWeatherRecord);
|
||||||
while (esm.isNextSub(regionChanceRecord))
|
while (esm.isNextSub(regionChanceRecord))
|
||||||
{
|
{
|
||||||
char chance;
|
char chance;
|
||||||
esm.getHT(chance);
|
esm.getHT(chance);
|
||||||
region.mChances.push_back(chance);
|
region.mChances.push_back(chance);
|
||||||
}
|
}
|
||||||
|
|
||||||
mRegions.insert(std::make_pair(regionID, region));
|
mRegions.insert(std::make_pair(regionID, region));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void WeatherState::save(ESMWriter& esm) const
|
void WeatherState::save(ESMWriter& esm) const
|
||||||
{
|
{
|
||||||
esm.writeHNCString(currentRegionRecord, mCurrentRegion);
|
esm.writeHNCString(currentRegionRecord, mCurrentRegion);
|
||||||
esm.writeHNT(timePassedRecord, mTimePassed);
|
esm.writeHNT(timePassedRecord, mTimePassed);
|
||||||
esm.writeHNT(fastForwardRecord, mFastForward);
|
esm.writeHNT(fastForwardRecord, mFastForward);
|
||||||
esm.writeHNT(weatherUpdateTimeRecord, mWeatherUpdateTime);
|
esm.writeHNT(weatherUpdateTimeRecord, mWeatherUpdateTime);
|
||||||
esm.writeHNT(transitionFactorRecord, mTransitionFactor);
|
esm.writeHNT(transitionFactorRecord, mTransitionFactor);
|
||||||
esm.writeHNT(currentWeatherRecord, mCurrentWeather);
|
esm.writeHNT(currentWeatherRecord, mCurrentWeather);
|
||||||
esm.writeHNT(nextWeatherRecord, mNextWeather);
|
esm.writeHNT(nextWeatherRecord, mNextWeather);
|
||||||
esm.writeHNT(queuedWeatherRecord, mQueuedWeather);
|
esm.writeHNT(queuedWeatherRecord, mQueuedWeather);
|
||||||
|
|
||||||
std::map<std::string, RegionWeatherState>::const_iterator it = mRegions.begin();
|
std::map<std::string, RegionWeatherState>::const_iterator it = mRegions.begin();
|
||||||
for(; it != mRegions.end(); ++it)
|
for(; it != mRegions.end(); ++it)
|
||||||
{
|
{
|
||||||
esm.writeHNCString(regionNameRecord, it->first.c_str());
|
esm.writeHNCString(regionNameRecord, it->first.c_str());
|
||||||
esm.writeHNT(regionWeatherRecord, it->second.mWeather);
|
esm.writeHNT(regionWeatherRecord, it->second.mWeather);
|
||||||
for(size_t i = 0; i < it->second.mChances.size(); ++i)
|
for(size_t i = 0; i < it->second.mChances.size(); ++i)
|
||||||
{
|
{
|
||||||
esm.writeHNT(regionChanceRecord, it->second.mChances[i]);
|
esm.writeHNT(regionChanceRecord, it->second.mChances[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,36 +1,36 @@
|
||||||
#ifndef OPENMW_ESM_WEATHERSTATE_H
|
#ifndef OPENMW_ESM_WEATHERSTATE_H
|
||||||
#define OPENMW_ESM_WEATHERSTATE_H
|
#define OPENMW_ESM_WEATHERSTATE_H
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace ESM
|
namespace ESM
|
||||||
{
|
{
|
||||||
class ESMReader;
|
class ESMReader;
|
||||||
class ESMWriter;
|
class ESMWriter;
|
||||||
|
|
||||||
struct RegionWeatherState
|
struct RegionWeatherState
|
||||||
{
|
{
|
||||||
int mWeather;
|
int mWeather;
|
||||||
std::vector<char> mChances;
|
std::vector<char> mChances;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct WeatherState
|
struct WeatherState
|
||||||
{
|
{
|
||||||
std::string mCurrentRegion;
|
std::string mCurrentRegion;
|
||||||
float mTimePassed;
|
float mTimePassed;
|
||||||
bool mFastForward;
|
bool mFastForward;
|
||||||
float mWeatherUpdateTime;
|
float mWeatherUpdateTime;
|
||||||
float mTransitionFactor;
|
float mTransitionFactor;
|
||||||
int mCurrentWeather;
|
int mCurrentWeather;
|
||||||
int mNextWeather;
|
int mNextWeather;
|
||||||
int mQueuedWeather;
|
int mQueuedWeather;
|
||||||
std::map<std::string, RegionWeatherState> mRegions;
|
std::map<std::string, RegionWeatherState> mRegions;
|
||||||
|
|
||||||
void load(ESMReader& esm);
|
void load(ESMReader& esm);
|
||||||
void save(ESMWriter& esm) const;
|
void save(ESMWriter& esm) const;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,40 +1,40 @@
|
||||||
#include "myguiloglistener.hpp"
|
#include "myguiloglistener.hpp"
|
||||||
|
|
||||||
#include <iomanip>
|
#include <iomanip>
|
||||||
|
|
||||||
#include <components/debug/debuglog.hpp>
|
#include <components/debug/debuglog.hpp>
|
||||||
|
|
||||||
namespace osgMyGUI
|
namespace osgMyGUI
|
||||||
{
|
{
|
||||||
void CustomLogListener::open()
|
void CustomLogListener::open()
|
||||||
{
|
{
|
||||||
mStream.open(mFileName, std::ios_base::out);
|
mStream.open(mFileName, std::ios_base::out);
|
||||||
if (!mStream.is_open())
|
if (!mStream.is_open())
|
||||||
Log(Debug::Error) << "Unable to create MyGUI log with path " << mFileName;
|
Log(Debug::Error) << "Unable to create MyGUI log with path " << mFileName;
|
||||||
}
|
}
|
||||||
|
|
||||||
void CustomLogListener::close()
|
void CustomLogListener::close()
|
||||||
{
|
{
|
||||||
if (mStream.is_open())
|
if (mStream.is_open())
|
||||||
mStream.close();
|
mStream.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CustomLogListener::flush()
|
void CustomLogListener::flush()
|
||||||
{
|
{
|
||||||
if (mStream.is_open())
|
if (mStream.is_open())
|
||||||
mStream.flush();
|
mStream.flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CustomLogListener::log(const std::string& _section, MyGUI::LogLevel _level, const struct tm* _time, const std::string& _message, const char* _file, int _line)
|
void CustomLogListener::log(const std::string& _section, MyGUI::LogLevel _level, const struct tm* _time, const std::string& _message, const char* _file, int _line)
|
||||||
{
|
{
|
||||||
if (mStream.is_open())
|
if (mStream.is_open())
|
||||||
{
|
{
|
||||||
const char* separator = " | ";
|
const char* separator = " | ";
|
||||||
mStream << std::setw(2) << std::setfill('0') << _time->tm_hour << ":"
|
mStream << std::setw(2) << std::setfill('0') << _time->tm_hour << ":"
|
||||||
<< std::setw(2) << std::setfill('0') << _time->tm_min << ":"
|
<< std::setw(2) << std::setfill('0') << _time->tm_min << ":"
|
||||||
<< std::setw(2) << std::setfill('0') << _time->tm_sec << separator
|
<< std::setw(2) << std::setfill('0') << _time->tm_sec << separator
|
||||||
<< _section << separator << _level.print() << separator
|
<< _section << separator << _level.print() << separator
|
||||||
<< _message << separator << _file << separator << _line << std::endl;
|
<< _message << separator << _file << separator << _line << std::endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,68 +1,68 @@
|
||||||
#ifndef OPENMW_COMPONENTS_MYGUIPLATFORM_LOGLISTENER_H
|
#ifndef OPENMW_COMPONENTS_MYGUIPLATFORM_LOGLISTENER_H
|
||||||
#define OPENMW_COMPONENTS_MYGUIPLATFORM_LOGLISTENER_H
|
#define OPENMW_COMPONENTS_MYGUIPLATFORM_LOGLISTENER_H
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <filesystem>
|
#include <filesystem>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
|
|
||||||
#include <MyGUI_ILogListener.h>
|
#include <MyGUI_ILogListener.h>
|
||||||
#include <MyGUI_LogSource.h>
|
#include <MyGUI_LogSource.h>
|
||||||
#include <MyGUI_ConsoleLogListener.h>
|
#include <MyGUI_ConsoleLogListener.h>
|
||||||
#include <MyGUI_LevelLogFilter.h>
|
#include <MyGUI_LevelLogFilter.h>
|
||||||
|
|
||||||
namespace osgMyGUI
|
namespace osgMyGUI
|
||||||
{
|
{
|
||||||
|
|
||||||
/// \brief Custom MyGUI::ILogListener interface implementation
|
/// \brief Custom MyGUI::ILogListener interface implementation
|
||||||
/// being able to portably handle UTF-8 encoded path.
|
/// being able to portably handle UTF-8 encoded path.
|
||||||
/// \todo try patching MyGUI to make this easier
|
/// \todo try patching MyGUI to make this easier
|
||||||
class CustomLogListener : public MyGUI::ILogListener
|
class CustomLogListener : public MyGUI::ILogListener
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
CustomLogListener(const std::filesystem::path &name)
|
CustomLogListener(const std::filesystem::path &name)
|
||||||
: mFileName(name)
|
: mFileName(name)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
~CustomLogListener() {}
|
~CustomLogListener() {}
|
||||||
|
|
||||||
void open() override;
|
void open() override;
|
||||||
void close() override;
|
void close() override;
|
||||||
void flush() override;
|
void flush() override;
|
||||||
|
|
||||||
void log(const std::string& _section, MyGUI::LogLevel _level, const struct tm* _time, const std::string& _message, const char* _file, int _line) override;
|
void log(const std::string& _section, MyGUI::LogLevel _level, const struct tm* _time, const std::string& _message, const char* _file, int _line) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::ofstream mStream;
|
std::ofstream mStream;
|
||||||
std::filesystem::path mFileName;
|
std::filesystem::path mFileName;
|
||||||
};
|
};
|
||||||
|
|
||||||
/// \brief Helper class holding data that required during
|
/// \brief Helper class holding data that required during
|
||||||
/// MyGUI log creation
|
/// MyGUI log creation
|
||||||
class LogFacility
|
class LogFacility
|
||||||
{
|
{
|
||||||
MyGUI::ConsoleLogListener mConsole;
|
MyGUI::ConsoleLogListener mConsole;
|
||||||
CustomLogListener mFile;
|
CustomLogListener mFile;
|
||||||
MyGUI::LevelLogFilter mFilter;
|
MyGUI::LevelLogFilter mFilter;
|
||||||
MyGUI::LogSource mSource;
|
MyGUI::LogSource mSource;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
LogFacility(const std::filesystem::path &output, bool console)
|
LogFacility(const std::filesystem::path &output, bool console)
|
||||||
: mFile(output)
|
: mFile(output)
|
||||||
{
|
{
|
||||||
mConsole.setEnabled(console);
|
mConsole.setEnabled(console);
|
||||||
mFilter.setLoggingLevel(MyGUI::LogLevel::Info);
|
mFilter.setLoggingLevel(MyGUI::LogLevel::Info);
|
||||||
|
|
||||||
mSource.addLogListener(&mFile);
|
mSource.addLogListener(&mFile);
|
||||||
mSource.addLogListener(&mConsole);
|
mSource.addLogListener(&mConsole);
|
||||||
mSource.setLogFilter(&mFilter);
|
mSource.setLogFilter(&mFilter);
|
||||||
|
|
||||||
mSource.open();
|
mSource.open();
|
||||||
}
|
}
|
||||||
|
|
||||||
MyGUI::LogSource *getSource() { return &mSource; }
|
MyGUI::LogSource *getSource() { return &mSource; }
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,42 +1,42 @@
|
||||||
#ifndef OPENMW_COMPONENTS_SCENEUTIL_CLEARCOLOR_H
|
#ifndef OPENMW_COMPONENTS_SCENEUTIL_CLEARCOLOR_H
|
||||||
#define OPENMW_COMPONENTS_SCENEUTIL_CLEARCOLOR_H
|
#define OPENMW_COMPONENTS_SCENEUTIL_CLEARCOLOR_H
|
||||||
|
|
||||||
#include <osg/StateAttribute>
|
#include <osg/StateAttribute>
|
||||||
#include <osg/Vec4f>
|
#include <osg/Vec4f>
|
||||||
|
|
||||||
namespace SceneUtil
|
namespace SceneUtil
|
||||||
{
|
{
|
||||||
class ClearColor : public osg::StateAttribute
|
class ClearColor : public osg::StateAttribute
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ClearColor() : mMask(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT) {}
|
ClearColor() : mMask(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT) {}
|
||||||
ClearColor(const osg::Vec4f& color, GLbitfield mask) : mColor(color), mMask(mask) {}
|
ClearColor(const osg::Vec4f& color, GLbitfield mask) : mColor(color), mMask(mask) {}
|
||||||
|
|
||||||
ClearColor(const ClearColor& copy,const osg::CopyOp& copyop=osg::CopyOp::SHALLOW_COPY)
|
ClearColor(const ClearColor& copy,const osg::CopyOp& copyop=osg::CopyOp::SHALLOW_COPY)
|
||||||
: osg::StateAttribute(copy,copyop), mColor(copy.mColor), mMask(copy.mMask) {}
|
: osg::StateAttribute(copy,copyop), mColor(copy.mColor), mMask(copy.mMask) {}
|
||||||
|
|
||||||
META_StateAttribute(fx, ClearColor, static_cast<osg::StateAttribute::Type>(100))
|
META_StateAttribute(fx, ClearColor, static_cast<osg::StateAttribute::Type>(100))
|
||||||
|
|
||||||
int compare(const StateAttribute& sa) const override
|
int compare(const StateAttribute& sa) const override
|
||||||
{
|
{
|
||||||
COMPARE_StateAttribute_Types(ClearColor, sa);
|
COMPARE_StateAttribute_Types(ClearColor, sa);
|
||||||
|
|
||||||
COMPARE_StateAttribute_Parameter(mColor);
|
COMPARE_StateAttribute_Parameter(mColor);
|
||||||
COMPARE_StateAttribute_Parameter(mMask);
|
COMPARE_StateAttribute_Parameter(mMask);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void apply(osg::State& state) const override
|
void apply(osg::State& state) const override
|
||||||
{
|
{
|
||||||
glClearColor(mColor[0], mColor[1], mColor[2], mColor[3]);
|
glClearColor(mColor[0], mColor[1], mColor[2], mColor[3]);
|
||||||
glClear(mMask);
|
glClear(mMask);
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
osg::Vec4f mColor;
|
osg::Vec4f mColor;
|
||||||
GLbitfield mMask;
|
GLbitfield mMask;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
530
extern/oics/ICSChannel.cpp
vendored
530
extern/oics/ICSChannel.cpp
vendored
|
@ -1,265 +1,265 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#include "ICSInputControlSystem.h"
|
#include "ICSInputControlSystem.h"
|
||||||
|
|
||||||
#define B1(t) (t*t)
|
#define B1(t) (t*t)
|
||||||
#define B2(t) (2*t*(1-t))
|
#define B2(t) (2*t*(1-t))
|
||||||
#define B3(t) ((1-t)*(1-t))
|
#define B3(t) ((1-t)*(1-t))
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
Channel::Channel(int number, float initialValue
|
Channel::Channel(int number, float initialValue
|
||||||
, float bezierMidPointY, float bezierMidPointX, float symmetricAt, float bezierStep)
|
, float bezierMidPointY, float bezierMidPointX, float symmetricAt, float bezierStep)
|
||||||
: mNumber(number)
|
: mNumber(number)
|
||||||
, mValue(initialValue)
|
, mValue(initialValue)
|
||||||
, mSymmetricAt(symmetricAt)
|
, mSymmetricAt(symmetricAt)
|
||||||
, mBezierStep(bezierStep)
|
, mBezierStep(bezierStep)
|
||||||
, mEnabled(true)
|
, mEnabled(true)
|
||||||
{
|
{
|
||||||
mBezierMidPoint.x = bezierMidPointX;
|
mBezierMidPoint.x = bezierMidPointX;
|
||||||
mBezierMidPoint.y = bezierMidPointY;
|
mBezierMidPoint.y = bezierMidPointY;
|
||||||
|
|
||||||
setBezierFunction(bezierMidPointY, bezierMidPointX, symmetricAt, bezierStep);
|
setBezierFunction(bezierMidPointY, bezierMidPointX, symmetricAt, bezierStep);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Channel::setEnabled(bool enabled)
|
void Channel::setEnabled(bool enabled)
|
||||||
{
|
{
|
||||||
mEnabled = enabled;
|
mEnabled = enabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
float Channel::getValue()
|
float Channel::getValue()
|
||||||
{
|
{
|
||||||
if(mValue == 0 || mValue == 1)
|
if(mValue == 0 || mValue == 1)
|
||||||
{
|
{
|
||||||
return mValue;
|
return mValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
assert (!mBezierFunction.empty());
|
assert (!mBezierFunction.empty());
|
||||||
BezierFunction::iterator it = mBezierFunction.begin();
|
BezierFunction::iterator it = mBezierFunction.begin();
|
||||||
//size_t size_minus_1 = mBezierFunction.size() - 1;
|
//size_t size_minus_1 = mBezierFunction.size() - 1;
|
||||||
BezierFunction::iterator last = mBezierFunction.end();
|
BezierFunction::iterator last = mBezierFunction.end();
|
||||||
--last;
|
--last;
|
||||||
for ( ; it != last ; )
|
for ( ; it != last ; )
|
||||||
{
|
{
|
||||||
BezierPoint left = (*it);
|
BezierPoint left = (*it);
|
||||||
BezierPoint right = (*(++it));
|
BezierPoint right = (*(++it));
|
||||||
|
|
||||||
if( (left.x <= mValue) && (right.x > mValue) )
|
if( (left.x <= mValue) && (right.x > mValue) )
|
||||||
{
|
{
|
||||||
float val = left.y - (left.x - mValue) * (left.y - right.y) / (left.x - right.x);
|
float val = left.y - (left.x - mValue) * (left.y - right.y) / (left.x - right.x);
|
||||||
|
|
||||||
return std::max<float>(0.0,std::min<float>(1.0, val));
|
return std::max<float>(0.0,std::min<float>(1.0, val));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Channel::setValue(float value)
|
void Channel::setValue(float value)
|
||||||
{
|
{
|
||||||
float previousValue = this->getValue();
|
float previousValue = this->getValue();
|
||||||
|
|
||||||
mValue = value;
|
mValue = value;
|
||||||
|
|
||||||
if(previousValue != value && mEnabled)
|
if(previousValue != value && mEnabled)
|
||||||
{
|
{
|
||||||
notifyListeners(previousValue);
|
notifyListeners(previousValue);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Channel::notifyListeners(float previousValue)
|
void Channel::notifyListeners(float previousValue)
|
||||||
{
|
{
|
||||||
std::list<ChannelListener*>::iterator pos = mListeners.begin();
|
std::list<ChannelListener*>::iterator pos = mListeners.begin();
|
||||||
while (pos != mListeners.end())
|
while (pos != mListeners.end())
|
||||||
{
|
{
|
||||||
(*pos)->channelChanged((Channel*)this, this->getValue(), previousValue);
|
(*pos)->channelChanged((Channel*)this, this->getValue(), previousValue);
|
||||||
++pos;
|
++pos;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Channel::addControl(Control* control, Channel::ChannelDirection dir, float percentage)
|
void Channel::addControl(Control* control, Channel::ChannelDirection dir, float percentage)
|
||||||
{
|
{
|
||||||
ControlChannelBinderItem ccBinderItem;
|
ControlChannelBinderItem ccBinderItem;
|
||||||
ccBinderItem.control = control;
|
ccBinderItem.control = control;
|
||||||
ccBinderItem.direction = dir;
|
ccBinderItem.direction = dir;
|
||||||
ccBinderItem.percentage = percentage;
|
ccBinderItem.percentage = percentage;
|
||||||
|
|
||||||
mAttachedControls.push_back(ccBinderItem);
|
mAttachedControls.push_back(ccBinderItem);
|
||||||
}
|
}
|
||||||
|
|
||||||
Channel::ControlChannelBinderItem Channel::getAttachedControlBinding(Control* control)
|
Channel::ControlChannelBinderItem Channel::getAttachedControlBinding(Control* control)
|
||||||
{
|
{
|
||||||
for(std::vector<ControlChannelBinderItem>::iterator it = mAttachedControls.begin() ;
|
for(std::vector<ControlChannelBinderItem>::iterator it = mAttachedControls.begin() ;
|
||||||
it != mAttachedControls.end() ; it++)
|
it != mAttachedControls.end() ; it++)
|
||||||
{
|
{
|
||||||
if((*it).control == control)
|
if((*it).control == control)
|
||||||
{
|
{
|
||||||
return (*it);
|
return (*it);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ControlChannelBinderItem nullBinderItem;
|
ControlChannelBinderItem nullBinderItem;
|
||||||
nullBinderItem.control = NULL;
|
nullBinderItem.control = NULL;
|
||||||
nullBinderItem.direction = Channel/*::ChannelDirection*/::DIRECT;
|
nullBinderItem.direction = Channel/*::ChannelDirection*/::DIRECT;
|
||||||
nullBinderItem.percentage = 0;
|
nullBinderItem.percentage = 0;
|
||||||
return nullBinderItem;
|
return nullBinderItem;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Channel::update()
|
void Channel::update()
|
||||||
{
|
{
|
||||||
if(this->getControlsCount() == 1)
|
if(this->getControlsCount() == 1)
|
||||||
{
|
{
|
||||||
ControlChannelBinderItem ccBinderItem = mAttachedControls.back();
|
ControlChannelBinderItem ccBinderItem = mAttachedControls.back();
|
||||||
float diff = ccBinderItem.control->getValue() - ccBinderItem.control->getInitialValue();
|
float diff = ccBinderItem.control->getValue() - ccBinderItem.control->getInitialValue();
|
||||||
|
|
||||||
if(ccBinderItem.direction == ICS::Channel::DIRECT)
|
if(ccBinderItem.direction == ICS::Channel::DIRECT)
|
||||||
{
|
{
|
||||||
this->setValue(ccBinderItem.control->getInitialValue() + (ccBinderItem.percentage * diff));
|
this->setValue(ccBinderItem.control->getInitialValue() + (ccBinderItem.percentage * diff));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this->setValue(ccBinderItem.control->getInitialValue() - (ccBinderItem.percentage * diff));
|
this->setValue(ccBinderItem.control->getInitialValue() - (ccBinderItem.percentage * diff));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
float val = 0;
|
float val = 0;
|
||||||
std::vector<ControlChannelBinderItem>::const_iterator it;
|
std::vector<ControlChannelBinderItem>::const_iterator it;
|
||||||
for(it=mAttachedControls.begin(); it!=mAttachedControls.end(); ++it)
|
for(it=mAttachedControls.begin(); it!=mAttachedControls.end(); ++it)
|
||||||
{
|
{
|
||||||
ControlChannelBinderItem ccBinderItem = (*it);
|
ControlChannelBinderItem ccBinderItem = (*it);
|
||||||
float diff = ccBinderItem.control->getValue() - ccBinderItem.control->getInitialValue();
|
float diff = ccBinderItem.control->getValue() - ccBinderItem.control->getInitialValue();
|
||||||
|
|
||||||
if(ccBinderItem.direction == ICS::Channel::DIRECT)
|
if(ccBinderItem.direction == ICS::Channel::DIRECT)
|
||||||
{
|
{
|
||||||
val += (ccBinderItem.percentage * diff);
|
val += (ccBinderItem.percentage * diff);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
val -= (ccBinderItem.percentage * diff);
|
val -= (ccBinderItem.percentage * diff);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(mAttachedControls.size() > 0)
|
if(mAttachedControls.size() > 0)
|
||||||
{
|
{
|
||||||
this->setValue(mAttachedControls.begin()->control->getInitialValue() + val);
|
this->setValue(mAttachedControls.begin()->control->getInitialValue() + val);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Channel::setBezierFunction(float bezierMidPointY, float bezierMidPointX, float symmetricAt, float bezierStep)
|
void Channel::setBezierFunction(float bezierMidPointY, float bezierMidPointX, float symmetricAt, float bezierStep)
|
||||||
{
|
{
|
||||||
mBezierMidPoint.x = bezierMidPointX;
|
mBezierMidPoint.x = bezierMidPointX;
|
||||||
mBezierMidPoint.y = bezierMidPointY;
|
mBezierMidPoint.y = bezierMidPointY;
|
||||||
mBezierStep = bezierStep;
|
mBezierStep = bezierStep;
|
||||||
mSymmetricAt = symmetricAt;
|
mSymmetricAt = symmetricAt;
|
||||||
|
|
||||||
mBezierFunction.clear();
|
mBezierFunction.clear();
|
||||||
|
|
||||||
BezierPoint start;
|
BezierPoint start;
|
||||||
start.x = 0;
|
start.x = 0;
|
||||||
start.y = 0;
|
start.y = 0;
|
||||||
|
|
||||||
BezierPoint end;
|
BezierPoint end;
|
||||||
end.x = 1;
|
end.x = 1;
|
||||||
end.y = 1;
|
end.y = 1;
|
||||||
mBezierFunction.push_front(end);
|
mBezierFunction.push_front(end);
|
||||||
|
|
||||||
FilterInterval interval;
|
FilterInterval interval;
|
||||||
interval.startX = start.x;
|
interval.startX = start.x;
|
||||||
interval.startY = start.y;
|
interval.startY = start.y;
|
||||||
interval.midX = mBezierMidPoint.x;
|
interval.midX = mBezierMidPoint.x;
|
||||||
interval.midY = mBezierMidPoint.y;
|
interval.midY = mBezierMidPoint.y;
|
||||||
interval.endX = end.x;
|
interval.endX = end.x;
|
||||||
interval.endY = end.y;
|
interval.endY = end.y;
|
||||||
interval.step = bezierStep;
|
interval.step = bezierStep;
|
||||||
mIntervals.push_back(interval);
|
mIntervals.push_back(interval);
|
||||||
|
|
||||||
if(!(mBezierMidPoint.x == 0.5 && mBezierMidPoint.y == 0.5))
|
if(!(mBezierMidPoint.x == 0.5 && mBezierMidPoint.y == 0.5))
|
||||||
{
|
{
|
||||||
float t = mBezierStep;
|
float t = mBezierStep;
|
||||||
while(t < 1)
|
while(t < 1)
|
||||||
{
|
{
|
||||||
BezierPoint p;
|
BezierPoint p;
|
||||||
p.x = start.x * B1(t) + mBezierMidPoint.x * B2(t) + end.x * B3(t);
|
p.x = start.x * B1(t) + mBezierMidPoint.x * B2(t) + end.x * B3(t);
|
||||||
p.y = start.y * B1(t) + mBezierMidPoint.y * B2(t) + end.y * B3(t);
|
p.y = start.y * B1(t) + mBezierMidPoint.y * B2(t) + end.y * B3(t);
|
||||||
mBezierFunction.push_front(p);
|
mBezierFunction.push_front(p);
|
||||||
|
|
||||||
t += mBezierStep;
|
t += mBezierStep;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mBezierFunction.push_front(start);
|
mBezierFunction.push_front(start);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Channel::addBezierInterval(float startX, float startY, float midX, float midY
|
void Channel::addBezierInterval(float startX, float startY, float midX, float midY
|
||||||
, float endX, float endY, float step)
|
, float endX, float endY, float step)
|
||||||
{
|
{
|
||||||
FilterInterval interval;
|
FilterInterval interval;
|
||||||
interval.startX = startX;
|
interval.startX = startX;
|
||||||
interval.startY = startY;
|
interval.startY = startY;
|
||||||
interval.midX = midX;
|
interval.midX = midX;
|
||||||
interval.midY = midY;
|
interval.midY = midY;
|
||||||
interval.endX = endX;
|
interval.endX = endX;
|
||||||
interval.endY = endY;
|
interval.endY = endY;
|
||||||
interval.step = step;
|
interval.step = step;
|
||||||
mIntervals.push_back(interval);
|
mIntervals.push_back(interval);
|
||||||
|
|
||||||
float t = 0;
|
float t = 0;
|
||||||
while(t <= 1)
|
while(t <= 1)
|
||||||
{
|
{
|
||||||
BezierPoint p;
|
BezierPoint p;
|
||||||
p.x = startX * B1(t) + midX * B2(t) + endX * B3(t);
|
p.x = startX * B1(t) + midX * B2(t) + endX * B3(t);
|
||||||
p.y = startY * B1(t) + midY * B2(t) + endY * B3(t);
|
p.y = startY * B1(t) + midY * B2(t) + endY * B3(t);
|
||||||
|
|
||||||
BezierFunction::iterator it = mBezierFunction.begin();
|
BezierFunction::iterator it = mBezierFunction.begin();
|
||||||
while( it != mBezierFunction.end() )
|
while( it != mBezierFunction.end() )
|
||||||
{
|
{
|
||||||
BezierPoint left = (*it);
|
BezierPoint left = (*it);
|
||||||
BezierPoint right;
|
BezierPoint right;
|
||||||
++it;
|
++it;
|
||||||
if( it != mBezierFunction.end() )
|
if( it != mBezierFunction.end() )
|
||||||
{
|
{
|
||||||
right = (*it);
|
right = (*it);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
right.x = endX;
|
right.x = endX;
|
||||||
right.y = endY;
|
right.y = endY;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(p.x > left.x && p.x < right.x)
|
if(p.x > left.x && p.x < right.x)
|
||||||
{
|
{
|
||||||
mBezierFunction.insert(it, p);
|
mBezierFunction.insert(it, p);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
t += 1.0f / ((endX-startX)/step);
|
t += 1.0f / ((endX-startX)/step);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
252
extern/oics/ICSChannel.h
vendored
252
extern/oics/ICSChannel.h
vendored
|
@ -1,126 +1,126 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#ifndef OICS_Channel_H_
|
#ifndef OICS_Channel_H_
|
||||||
#define OICS_Channel_H_
|
#define OICS_Channel_H_
|
||||||
|
|
||||||
#include "ICSPrerequisites.h"
|
#include "ICSPrerequisites.h"
|
||||||
|
|
||||||
#include "ICSChannelListener.h"
|
#include "ICSChannelListener.h"
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
struct FilterInterval{
|
struct FilterInterval{
|
||||||
//std::string type; //! @todo uncomment when more types implemented
|
//std::string type; //! @todo uncomment when more types implemented
|
||||||
float startX;
|
float startX;
|
||||||
float startY;
|
float startY;
|
||||||
float midX;
|
float midX;
|
||||||
float midY;
|
float midY;
|
||||||
float endX;
|
float endX;
|
||||||
float endY;
|
float endY;
|
||||||
float step;
|
float step;
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef std::list<FilterInterval> IntervalList;
|
typedef std::list<FilterInterval> IntervalList;
|
||||||
|
|
||||||
class DllExport Channel
|
class DllExport Channel
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
enum ChannelDirection
|
enum ChannelDirection
|
||||||
{
|
{
|
||||||
INVERSE = -1, DIRECT = 1
|
INVERSE = -1, DIRECT = 1
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
ChannelDirection direction;
|
ChannelDirection direction;
|
||||||
float percentage;
|
float percentage;
|
||||||
Control* control;
|
Control* control;
|
||||||
} ControlChannelBinderItem;
|
} ControlChannelBinderItem;
|
||||||
|
|
||||||
|
|
||||||
Channel(int number, float initialValue = 0.5
|
Channel(int number, float initialValue = 0.5
|
||||||
, float bezierMidPointY = 0.5, float bezierMidPointX = 0.5
|
, float bezierMidPointY = 0.5, float bezierMidPointX = 0.5
|
||||||
, float symmetricAt = 0, float bezierStep = 0.2); //! @todo implement symetry
|
, float symmetricAt = 0, float bezierStep = 0.2); //! @todo implement symetry
|
||||||
~Channel(){};
|
~Channel(){};
|
||||||
|
|
||||||
void setValue(float value);
|
void setValue(float value);
|
||||||
float getValue();
|
float getValue();
|
||||||
|
|
||||||
inline int getNumber(){ return mNumber; };
|
inline int getNumber(){ return mNumber; };
|
||||||
|
|
||||||
void addControl(Control* control, Channel::ChannelDirection dir, float percentage);
|
void addControl(Control* control, Channel::ChannelDirection dir, float percentage);
|
||||||
inline size_t getControlsCount(){ return mAttachedControls.size(); };
|
inline size_t getControlsCount(){ return mAttachedControls.size(); };
|
||||||
std::vector<ControlChannelBinderItem> getAttachedControls(){ return mAttachedControls; };
|
std::vector<ControlChannelBinderItem> getAttachedControls(){ return mAttachedControls; };
|
||||||
ControlChannelBinderItem getAttachedControlBinding(Control* control);
|
ControlChannelBinderItem getAttachedControlBinding(Control* control);
|
||||||
|
|
||||||
void addListener(ChannelListener* ob){ mListeners.push_back(ob); };
|
void addListener(ChannelListener* ob){ mListeners.push_back(ob); };
|
||||||
void removeListener(ChannelListener* ob){ mListeners.remove(ob); };
|
void removeListener(ChannelListener* ob){ mListeners.remove(ob); };
|
||||||
|
|
||||||
void update();
|
void update();
|
||||||
|
|
||||||
void setBezierFunction(float bezierMidPointY, float bezierMidPointX = 0.5
|
void setBezierFunction(float bezierMidPointY, float bezierMidPointX = 0.5
|
||||||
, float symmetricAt = 0, float bezierStep = 0.2);
|
, float symmetricAt = 0, float bezierStep = 0.2);
|
||||||
|
|
||||||
void addBezierInterval(float startX, float startY, float midX, float midY
|
void addBezierInterval(float startX, float startY, float midX, float midY
|
||||||
, float endX, float endY, float step = 0.1);
|
, float endX, float endY, float step = 0.1);
|
||||||
|
|
||||||
IntervalList& getIntervals(){ return mIntervals; };
|
IntervalList& getIntervals(){ return mIntervals; };
|
||||||
|
|
||||||
void setEnabled(bool enabled);
|
void setEnabled(bool enabled);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
int mNumber;
|
int mNumber;
|
||||||
float mValue;
|
float mValue;
|
||||||
|
|
||||||
struct BezierPoint{
|
struct BezierPoint{
|
||||||
float x;
|
float x;
|
||||||
float y;
|
float y;
|
||||||
bool operator < (const BezierPoint& other){ return x < other.x; }
|
bool operator < (const BezierPoint& other){ return x < other.x; }
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef std::list<BezierPoint> BezierFunction;
|
typedef std::list<BezierPoint> BezierFunction;
|
||||||
|
|
||||||
BezierPoint mBezierMidPoint;
|
BezierPoint mBezierMidPoint;
|
||||||
BezierFunction mBezierFunction;
|
BezierFunction mBezierFunction;
|
||||||
float mSymmetricAt;
|
float mSymmetricAt;
|
||||||
float mBezierStep;
|
float mBezierStep;
|
||||||
|
|
||||||
IntervalList mIntervals;
|
IntervalList mIntervals;
|
||||||
|
|
||||||
std::vector<ControlChannelBinderItem> mAttachedControls;
|
std::vector<ControlChannelBinderItem> mAttachedControls;
|
||||||
|
|
||||||
std::list<ChannelListener* > mListeners;
|
std::list<ChannelListener* > mListeners;
|
||||||
void notifyListeners(float previousValue);
|
void notifyListeners(float previousValue);
|
||||||
|
|
||||||
bool mEnabled;
|
bool mEnabled;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
96
extern/oics/ICSChannelListener.h
vendored
96
extern/oics/ICSChannelListener.h
vendored
|
@ -1,48 +1,48 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#ifndef _ChannelListener_H_
|
#ifndef _ChannelListener_H_
|
||||||
#define _ChannelListener_H_
|
#define _ChannelListener_H_
|
||||||
|
|
||||||
#include "ICSPrerequisites.h"
|
#include "ICSPrerequisites.h"
|
||||||
|
|
||||||
#include "ICSChannel.h"
|
#include "ICSChannel.h"
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
|
|
||||||
class DllExport ChannelListener
|
class DllExport ChannelListener
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual void channelChanged(Channel* channel, float currentValue, float previousValue) = 0;
|
virtual void channelChanged(Channel* channel, float currentValue, float previousValue) = 0;
|
||||||
|
|
||||||
virtual ~ChannelListener() = default;
|
virtual ~ChannelListener() = default;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
322
extern/oics/ICSControl.cpp
vendored
322
extern/oics/ICSControl.cpp
vendored
|
@ -1,161 +1,161 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#include "ICSInputControlSystem.h"
|
#include "ICSInputControlSystem.h"
|
||||||
|
|
||||||
#include "ICSControl.h"
|
#include "ICSControl.h"
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
Control::Control(const std::string& name, bool autoChangeDirectionOnLimitsAfterStop, bool autoReverseToInitialValue
|
Control::Control(const std::string& name, bool autoChangeDirectionOnLimitsAfterStop, bool autoReverseToInitialValue
|
||||||
, float initialValue, float stepSize, float stepsPerSeconds, bool axisBindable)
|
, float initialValue, float stepSize, float stepsPerSeconds, bool axisBindable)
|
||||||
: mValue(initialValue)
|
: mValue(initialValue)
|
||||||
, mInitialValue(initialValue)
|
, mInitialValue(initialValue)
|
||||||
, mName(name)
|
, mName(name)
|
||||||
, mStepSize(stepSize)
|
, mStepSize(stepSize)
|
||||||
, mStepsPerSeconds(stepsPerSeconds)
|
, mStepsPerSeconds(stepsPerSeconds)
|
||||||
, mAutoReverseToInitialValue(autoReverseToInitialValue)
|
, mAutoReverseToInitialValue(autoReverseToInitialValue)
|
||||||
, mIgnoreAutoReverse(false)
|
, mIgnoreAutoReverse(false)
|
||||||
, mAutoChangeDirectionOnLimitsAfterStop(autoChangeDirectionOnLimitsAfterStop)
|
, mAutoChangeDirectionOnLimitsAfterStop(autoChangeDirectionOnLimitsAfterStop)
|
||||||
, mAxisBindable(axisBindable)
|
, mAxisBindable(axisBindable)
|
||||||
, currentChangingDirection(STOP)
|
, currentChangingDirection(STOP)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Control::~Control()
|
Control::~Control()
|
||||||
{
|
{
|
||||||
mAttachedChannels.clear();
|
mAttachedChannels.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Control::setValue(float value)
|
void Control::setValue(float value)
|
||||||
{
|
{
|
||||||
float previousValue = mValue;
|
float previousValue = mValue;
|
||||||
|
|
||||||
mValue = std::max<float>(0.0,std::min<float>(1.0,value));
|
mValue = std::max<float>(0.0,std::min<float>(1.0,value));
|
||||||
|
|
||||||
if(mValue != previousValue)
|
if(mValue != previousValue)
|
||||||
{
|
{
|
||||||
updateChannels();
|
updateChannels();
|
||||||
|
|
||||||
notifyListeners(previousValue);
|
notifyListeners(previousValue);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Control::attachChannel(Channel* channel, Channel::ChannelDirection direction, float percentage)
|
void Control::attachChannel(Channel* channel, Channel::ChannelDirection direction, float percentage)
|
||||||
{
|
{
|
||||||
mAttachedChannels.push_back(channel);
|
mAttachedChannels.push_back(channel);
|
||||||
channel->addControl(this, direction, percentage);
|
channel->addControl(this, direction, percentage);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Control::updateChannels()
|
void Control::updateChannels()
|
||||||
{
|
{
|
||||||
std::list<Channel*>::iterator pos = mAttachedChannels.begin();
|
std::list<Channel*>::iterator pos = mAttachedChannels.begin();
|
||||||
while (pos != mAttachedChannels.end())
|
while (pos != mAttachedChannels.end())
|
||||||
{
|
{
|
||||||
((Channel* )(*pos))->update();
|
((Channel* )(*pos))->update();
|
||||||
++pos;
|
++pos;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Control::notifyListeners(float previousValue)
|
void Control::notifyListeners(float previousValue)
|
||||||
{
|
{
|
||||||
std::list<ControlListener*>::iterator pos = mListeners.begin();
|
std::list<ControlListener*>::iterator pos = mListeners.begin();
|
||||||
while (pos != mListeners.end())
|
while (pos != mListeners.end())
|
||||||
{
|
{
|
||||||
(*pos)->controlChanged((Control*)this, this->getValue(), previousValue);
|
(*pos)->controlChanged((Control*)this, this->getValue(), previousValue);
|
||||||
++pos;
|
++pos;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Control::setChangingDirection(ControlChangingDirection direction)
|
void Control::setChangingDirection(ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
currentChangingDirection = direction;
|
currentChangingDirection = direction;
|
||||||
mPendingActions.push_back(direction);
|
mPendingActions.push_back(direction);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Control::update(float timeSinceLastFrame)
|
void Control::update(float timeSinceLastFrame)
|
||||||
{
|
{
|
||||||
if(!mPendingActions.empty())
|
if(!mPendingActions.empty())
|
||||||
{
|
{
|
||||||
size_t timedActionsCount = 0;
|
size_t timedActionsCount = 0;
|
||||||
|
|
||||||
std::list<Control::ControlChangingDirection>::iterator cached_end = mPendingActions.end();
|
std::list<Control::ControlChangingDirection>::iterator cached_end = mPendingActions.end();
|
||||||
for(std::list<Control::ControlChangingDirection>::iterator it = mPendingActions.begin() ;
|
for(std::list<Control::ControlChangingDirection>::iterator it = mPendingActions.begin() ;
|
||||||
it != cached_end ; ++it)
|
it != cached_end ; ++it)
|
||||||
{
|
{
|
||||||
if( (*it) != Control::STOP )
|
if( (*it) != Control::STOP )
|
||||||
{
|
{
|
||||||
timedActionsCount++;
|
timedActionsCount++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
float timeSinceLastFramePart = timeSinceLastFrame / std::max<size_t>(1, timedActionsCount);
|
float timeSinceLastFramePart = timeSinceLastFrame / std::max<size_t>(1, timedActionsCount);
|
||||||
for(std::list<Control::ControlChangingDirection>::iterator it = mPendingActions.begin() ;
|
for(std::list<Control::ControlChangingDirection>::iterator it = mPendingActions.begin() ;
|
||||||
it != cached_end ; ++it)
|
it != cached_end ; ++it)
|
||||||
{
|
{
|
||||||
if( (*it) != Control::STOP )
|
if( (*it) != Control::STOP )
|
||||||
{
|
{
|
||||||
this->setValue(mValue +
|
this->setValue(mValue +
|
||||||
(((int)(*it)) * mStepSize * mStepsPerSeconds * (timeSinceLastFramePart)));
|
(((int)(*it)) * mStepSize * mStepsPerSeconds * (timeSinceLastFramePart)));
|
||||||
}
|
}
|
||||||
else if(mAutoReverseToInitialValue && !mIgnoreAutoReverse && mValue != mInitialValue )
|
else if(mAutoReverseToInitialValue && !mIgnoreAutoReverse && mValue != mInitialValue )
|
||||||
{
|
{
|
||||||
|
|
||||||
if(mValue > mInitialValue)
|
if(mValue > mInitialValue)
|
||||||
{
|
{
|
||||||
this->setValue( std::max<float>( mInitialValue,
|
this->setValue( std::max<float>( mInitialValue,
|
||||||
mValue - (mStepSize * mStepsPerSeconds * (timeSinceLastFramePart))));
|
mValue - (mStepSize * mStepsPerSeconds * (timeSinceLastFramePart))));
|
||||||
}
|
}
|
||||||
else if(mValue < mInitialValue)
|
else if(mValue < mInitialValue)
|
||||||
{
|
{
|
||||||
this->setValue( std::min<float>( mInitialValue,
|
this->setValue( std::min<float>( mInitialValue,
|
||||||
mValue + (mStepSize * mStepsPerSeconds * (timeSinceLastFramePart))));
|
mValue + (mStepSize * mStepsPerSeconds * (timeSinceLastFramePart))));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mPendingActions.clear();
|
mPendingActions.clear();
|
||||||
}
|
}
|
||||||
else if( currentChangingDirection != Control::STOP )
|
else if( currentChangingDirection != Control::STOP )
|
||||||
{
|
{
|
||||||
this->setValue(mValue +
|
this->setValue(mValue +
|
||||||
(((int)currentChangingDirection) * mStepSize * mStepsPerSeconds * (timeSinceLastFrame)));
|
(((int)currentChangingDirection) * mStepSize * mStepsPerSeconds * (timeSinceLastFrame)));
|
||||||
}
|
}
|
||||||
else if(mAutoReverseToInitialValue && !mIgnoreAutoReverse && mValue != mInitialValue )
|
else if(mAutoReverseToInitialValue && !mIgnoreAutoReverse && mValue != mInitialValue )
|
||||||
{
|
{
|
||||||
if(mValue > mInitialValue)
|
if(mValue > mInitialValue)
|
||||||
{
|
{
|
||||||
this->setValue( std::max<float>( mInitialValue,
|
this->setValue( std::max<float>( mInitialValue,
|
||||||
mValue - (mStepSize * mStepsPerSeconds * (timeSinceLastFrame))));
|
mValue - (mStepSize * mStepsPerSeconds * (timeSinceLastFrame))));
|
||||||
}
|
}
|
||||||
else if(mValue < mInitialValue)
|
else if(mValue < mInitialValue)
|
||||||
{
|
{
|
||||||
this->setValue( std::min<float>( mInitialValue,
|
this->setValue( std::min<float>( mInitialValue,
|
||||||
mValue + (mStepSize * mStepsPerSeconds * (timeSinceLastFrame))));
|
mValue + (mStepSize * mStepsPerSeconds * (timeSinceLastFrame))));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
214
extern/oics/ICSControl.h
vendored
214
extern/oics/ICSControl.h
vendored
|
@ -1,108 +1,108 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#ifndef OICS_Control_H_
|
#ifndef OICS_Control_H_
|
||||||
#define OICS_Control_H_
|
#define OICS_Control_H_
|
||||||
|
|
||||||
#include "ICSPrerequisites.h"
|
#include "ICSPrerequisites.h"
|
||||||
|
|
||||||
#include "ICSChannel.h"
|
#include "ICSChannel.h"
|
||||||
#include "ICSControlListener.h"
|
#include "ICSControlListener.h"
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
|
|
||||||
class DllExport Control
|
class DllExport Control
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
enum ControlChangingDirection
|
enum ControlChangingDirection
|
||||||
{
|
{
|
||||||
DECREASE = -1, STOP = 0, INCREASE = 1
|
DECREASE = -1, STOP = 0, INCREASE = 1
|
||||||
};
|
};
|
||||||
|
|
||||||
Control(const std::string& name, bool autoChangeDirectionOnLimitsAfterStop = false, bool autoReverseToInitialValue = false, float initialValue = 0.5, float stepSize = 0.1, float stepsPerSeconds = 2.0, bool axisBindable = true);
|
Control(const std::string& name, bool autoChangeDirectionOnLimitsAfterStop = false, bool autoReverseToInitialValue = false, float initialValue = 0.5, float stepSize = 0.1, float stepsPerSeconds = 2.0, bool axisBindable = true);
|
||||||
~Control();
|
~Control();
|
||||||
|
|
||||||
void setChangingDirection(ControlChangingDirection direction);
|
void setChangingDirection(ControlChangingDirection direction);
|
||||||
inline ControlChangingDirection getChangingDirection(){ return currentChangingDirection; };
|
inline ControlChangingDirection getChangingDirection(){ return currentChangingDirection; };
|
||||||
|
|
||||||
void setValue(float value);
|
void setValue(float value);
|
||||||
inline float getValue(){ return mValue; };
|
inline float getValue(){ return mValue; };
|
||||||
inline float getInitialValue(){ return mInitialValue; };
|
inline float getInitialValue(){ return mInitialValue; };
|
||||||
inline void setInitialValue(float i) {mInitialValue = i;};
|
inline void setInitialValue(float i) {mInitialValue = i;};
|
||||||
|
|
||||||
void attachChannel(Channel* channel, Channel::ChannelDirection direction, float percentage = 1.0);
|
void attachChannel(Channel* channel, Channel::ChannelDirection direction, float percentage = 1.0);
|
||||||
std::list<Channel*> getAttachedChannels(){ return mAttachedChannels; };
|
std::list<Channel*> getAttachedChannels(){ return mAttachedChannels; };
|
||||||
|
|
||||||
inline float getStepSize(){ return mStepSize; };
|
inline float getStepSize(){ return mStepSize; };
|
||||||
inline float getStepsPerSeconds(){ return mStepsPerSeconds; };
|
inline float getStepsPerSeconds(){ return mStepsPerSeconds; };
|
||||||
|
|
||||||
inline void setIgnoreAutoReverse(bool value){ mIgnoreAutoReverse = value; }; // mouse disable autoreverse
|
inline void setIgnoreAutoReverse(bool value){ mIgnoreAutoReverse = value; }; // mouse disable autoreverse
|
||||||
inline bool isAutoReverseIgnored(){ return mIgnoreAutoReverse; };
|
inline bool isAutoReverseIgnored(){ return mIgnoreAutoReverse; };
|
||||||
inline bool getAutoReverse(){ return mAutoReverseToInitialValue; };
|
inline bool getAutoReverse(){ return mAutoReverseToInitialValue; };
|
||||||
|
|
||||||
inline bool getAutoChangeDirectionOnLimitsAfterStop(){ return mAutoChangeDirectionOnLimitsAfterStop; };
|
inline bool getAutoChangeDirectionOnLimitsAfterStop(){ return mAutoChangeDirectionOnLimitsAfterStop; };
|
||||||
|
|
||||||
inline std::string getName(){ return mName; };
|
inline std::string getName(){ return mName; };
|
||||||
|
|
||||||
inline bool isAxisBindable(){ return mAxisBindable; };
|
inline bool isAxisBindable(){ return mAxisBindable; };
|
||||||
inline void setAxisBindable(bool value){ mAxisBindable = value; };
|
inline void setAxisBindable(bool value){ mAxisBindable = value; };
|
||||||
|
|
||||||
inline void addListener(ControlListener* ob){ mListeners.push_back(ob); };
|
inline void addListener(ControlListener* ob){ mListeners.push_back(ob); };
|
||||||
inline void removeListener(ControlListener* ob){ mListeners.remove(ob); };
|
inline void removeListener(ControlListener* ob){ mListeners.remove(ob); };
|
||||||
|
|
||||||
void update(float timeSinceLastFrame);
|
void update(float timeSinceLastFrame);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
float mValue;
|
float mValue;
|
||||||
float mInitialValue;
|
float mInitialValue;
|
||||||
std::string mName;
|
std::string mName;
|
||||||
float mStepSize;
|
float mStepSize;
|
||||||
float mStepsPerSeconds;
|
float mStepsPerSeconds;
|
||||||
bool mAutoReverseToInitialValue;
|
bool mAutoReverseToInitialValue;
|
||||||
bool mIgnoreAutoReverse;
|
bool mIgnoreAutoReverse;
|
||||||
bool mAutoChangeDirectionOnLimitsAfterStop;
|
bool mAutoChangeDirectionOnLimitsAfterStop;
|
||||||
bool mAxisBindable;
|
bool mAxisBindable;
|
||||||
|
|
||||||
Control::ControlChangingDirection currentChangingDirection;
|
Control::ControlChangingDirection currentChangingDirection;
|
||||||
std::list<Channel*> mAttachedChannels;
|
std::list<Channel*> mAttachedChannels;
|
||||||
|
|
||||||
std::list<ControlListener*> mListeners;
|
std::list<ControlListener*> mListeners;
|
||||||
|
|
||||||
std::list<Control::ControlChangingDirection> mPendingActions;
|
std::list<Control::ControlChangingDirection> mPendingActions;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
void updateChannels();
|
void updateChannels();
|
||||||
void notifyListeners(float previousValue);
|
void notifyListeners(float previousValue);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
96
extern/oics/ICSControlListener.h
vendored
96
extern/oics/ICSControlListener.h
vendored
|
@ -1,48 +1,48 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#ifndef _ControlListener_H_
|
#ifndef _ControlListener_H_
|
||||||
#define _ControlListener_H_
|
#define _ControlListener_H_
|
||||||
|
|
||||||
#include "ICSPrerequisites.h"
|
#include "ICSPrerequisites.h"
|
||||||
|
|
||||||
#include "ICSControl.h"
|
#include "ICSControl.h"
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
|
|
||||||
class DllExport ControlListener
|
class DllExport ControlListener
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual void controlChanged(Control* control, float currentValue, float previousValue) = 0;
|
virtual void controlChanged(Control* control, float currentValue, float previousValue) = 0;
|
||||||
|
|
||||||
virtual ~ControlListener() = default;
|
virtual ~ControlListener() = default;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
1634
extern/oics/ICSInputControlSystem.cpp
vendored
1634
extern/oics/ICSInputControlSystem.cpp
vendored
File diff suppressed because it is too large
Load diff
562
extern/oics/ICSInputControlSystem.h
vendored
562
extern/oics/ICSInputControlSystem.h
vendored
|
@ -1,281 +1,281 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#ifndef OICS_InputControlSystem_H_
|
#ifndef OICS_InputControlSystem_H_
|
||||||
#define OICS_InputControlSystem_H_
|
#define OICS_InputControlSystem_H_
|
||||||
|
|
||||||
#include "ICSPrerequisites.h"
|
#include "ICSPrerequisites.h"
|
||||||
|
|
||||||
#include "ICSControl.h"
|
#include "ICSControl.h"
|
||||||
#include "ICSChannel.h"
|
#include "ICSChannel.h"
|
||||||
|
|
||||||
#define ICS_LOG(text) if(mLog) mLog->logMessage( ("ICS: " + std::string(text)).c_str() );
|
#define ICS_LOG(text) if(mLog) mLog->logMessage( ("ICS: " + std::string(text)).c_str() );
|
||||||
#define ICS_MAX_JOYSTICK_AXIS 16
|
#define ICS_MAX_JOYSTICK_AXIS 16
|
||||||
#define ICS_MOUSE_BINDING_MARGIN 30
|
#define ICS_MOUSE_BINDING_MARGIN 30
|
||||||
#define ICS_JOYSTICK_AXIS_BINDING_MARGIN 10000
|
#define ICS_JOYSTICK_AXIS_BINDING_MARGIN 10000
|
||||||
#define ICS_JOYSTICK_SLIDER_BINDING_MARGIN 10000
|
#define ICS_JOYSTICK_SLIDER_BINDING_MARGIN 10000
|
||||||
#define ICS_MOUSE_AXIS_BINDING_NULL_VALUE std::numeric_limits<int>::max()
|
#define ICS_MOUSE_AXIS_BINDING_NULL_VALUE std::numeric_limits<int>::max()
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
class DllExport InputControlSystemLog
|
class DllExport InputControlSystemLog
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual void logMessage(const char* text) = 0;
|
virtual void logMessage(const char* text) = 0;
|
||||||
|
|
||||||
virtual ~InputControlSystemLog() = default;
|
virtual ~InputControlSystemLog() = default;
|
||||||
};
|
};
|
||||||
|
|
||||||
class DllExport InputControlSystem
|
class DllExport InputControlSystem
|
||||||
{
|
{
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
enum NamedAxis { X = -1, Y = -2, Z = -3, UNASSIGNED = -4 };
|
enum NamedAxis { X = -1, Y = -2, Z = -3, UNASSIGNED = -4 };
|
||||||
enum POVAxis { NorthSouth = 0, EastWest = 1 };
|
enum POVAxis { NorthSouth = 0, EastWest = 1 };
|
||||||
|
|
||||||
typedef NamedAxis MouseAxis; // MouseAxis is deprecated. It will be removed in future versions
|
typedef NamedAxis MouseAxis; // MouseAxis is deprecated. It will be removed in future versions
|
||||||
|
|
||||||
typedef std::map<int, SDL_GameController*> JoystickInstanceMap;
|
typedef std::map<int, SDL_GameController*> JoystickInstanceMap;
|
||||||
typedef std::list<int> JoystickIDList;
|
typedef std::list<int> JoystickIDList;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
int index;
|
int index;
|
||||||
POVAxis axis;
|
POVAxis axis;
|
||||||
} POVBindingPair;
|
} POVBindingPair;
|
||||||
|
|
||||||
InputControlSystem(std::string file = "", bool active = true
|
InputControlSystem(std::string file = "", bool active = true
|
||||||
, DetectingBindingListener* detectingBindingListener = NULL
|
, DetectingBindingListener* detectingBindingListener = NULL
|
||||||
, InputControlSystemLog* log = NULL, size_t channelCount = 16);
|
, InputControlSystemLog* log = NULL, size_t channelCount = 16);
|
||||||
~InputControlSystem();
|
~InputControlSystem();
|
||||||
|
|
||||||
std::string getFileName(){ return mFileName; };
|
std::string getFileName(){ return mFileName; };
|
||||||
std::string getBaseFileName();
|
std::string getBaseFileName();
|
||||||
|
|
||||||
void setDetectingBindingListener(DetectingBindingListener* detectingBindingListener){ mDetectingBindingListener = detectingBindingListener; };
|
void setDetectingBindingListener(DetectingBindingListener* detectingBindingListener){ mDetectingBindingListener = detectingBindingListener; };
|
||||||
DetectingBindingListener* getDetectingBindingListener(){ return mDetectingBindingListener; };
|
DetectingBindingListener* getDetectingBindingListener(){ return mDetectingBindingListener; };
|
||||||
|
|
||||||
void setJoystickDeadZone(float deadZone){ mDeadZone = deadZone; };
|
void setJoystickDeadZone(float deadZone){ mDeadZone = deadZone; };
|
||||||
|
|
||||||
// in seconds
|
// in seconds
|
||||||
void update(float timeSinceLastFrame);
|
void update(float timeSinceLastFrame);
|
||||||
|
|
||||||
inline Channel* getChannel(int i){ return mChannels[i]; };
|
inline Channel* getChannel(int i){ return mChannels[i]; };
|
||||||
float getChannelValue(int i);
|
float getChannelValue(int i);
|
||||||
inline int getChannelCount(){ return (int)mChannels.size(); };
|
inline int getChannelCount(){ return (int)mChannels.size(); };
|
||||||
|
|
||||||
inline Control* getControl(int i){ return mControls[i]; };
|
inline Control* getControl(int i){ return mControls[i]; };
|
||||||
float getControlValue(int i);
|
float getControlValue(int i);
|
||||||
inline int getControlCount(){ return (int)mControls.size(); };
|
inline int getControlCount(){ return (int)mControls.size(); };
|
||||||
inline void addControl(Control* control){ mControls.push_back(control); };
|
inline void addControl(Control* control){ mControls.push_back(control); };
|
||||||
|
|
||||||
Control* findControl(std::string name);
|
Control* findControl(std::string name);
|
||||||
|
|
||||||
inline void activate(){ this->mActive = true; };
|
inline void activate(){ this->mActive = true; };
|
||||||
inline void deactivate(){ this->mActive = false; };
|
inline void deactivate(){ this->mActive = false; };
|
||||||
|
|
||||||
void controllerAdded (int deviceID, const SDL_ControllerDeviceEvent &args);
|
void controllerAdded (int deviceID, const SDL_ControllerDeviceEvent &args);
|
||||||
void controllerRemoved(const SDL_ControllerDeviceEvent &args);
|
void controllerRemoved(const SDL_ControllerDeviceEvent &args);
|
||||||
JoystickIDList& getJoystickIdList(){ return mJoystickIDList; };
|
JoystickIDList& getJoystickIdList(){ return mJoystickIDList; };
|
||||||
JoystickInstanceMap& getJoystickInstanceMap(){ return mJoystickInstanceMap; };
|
JoystickInstanceMap& getJoystickInstanceMap(){ return mJoystickInstanceMap; };
|
||||||
|
|
||||||
// MouseListener
|
// MouseListener
|
||||||
void mouseMoved(const SDL_MouseMotionEvent &evt);
|
void mouseMoved(const SDL_MouseMotionEvent &evt);
|
||||||
void mousePressed(const SDL_MouseButtonEvent &evt, Uint8);
|
void mousePressed(const SDL_MouseButtonEvent &evt, Uint8);
|
||||||
void mouseReleased(const SDL_MouseButtonEvent &evt, Uint8);
|
void mouseReleased(const SDL_MouseButtonEvent &evt, Uint8);
|
||||||
|
|
||||||
// KeyListener
|
// KeyListener
|
||||||
void keyPressed(const SDL_KeyboardEvent &evt);
|
void keyPressed(const SDL_KeyboardEvent &evt);
|
||||||
void keyReleased(const SDL_KeyboardEvent &evt);
|
void keyReleased(const SDL_KeyboardEvent &evt);
|
||||||
|
|
||||||
// ControllerListener
|
// ControllerListener
|
||||||
void buttonPressed(int deviceID, const SDL_ControllerButtonEvent &evt);
|
void buttonPressed(int deviceID, const SDL_ControllerButtonEvent &evt);
|
||||||
void buttonReleased(int deviceID, const SDL_ControllerButtonEvent &evt);
|
void buttonReleased(int deviceID, const SDL_ControllerButtonEvent &evt);
|
||||||
void axisMoved(int deviceID, const SDL_ControllerAxisEvent &evt);
|
void axisMoved(int deviceID, const SDL_ControllerAxisEvent &evt);
|
||||||
|
|
||||||
void addKeyBinding(Control* control, SDL_Scancode key, Control::ControlChangingDirection direction);
|
void addKeyBinding(Control* control, SDL_Scancode key, Control::ControlChangingDirection direction);
|
||||||
bool isKeyBound(SDL_Scancode key) const;
|
bool isKeyBound(SDL_Scancode key) const;
|
||||||
void addMouseAxisBinding(Control* control, NamedAxis axis, Control::ControlChangingDirection direction);
|
void addMouseAxisBinding(Control* control, NamedAxis axis, Control::ControlChangingDirection direction);
|
||||||
void addMouseButtonBinding(Control* control, unsigned int button, Control::ControlChangingDirection direction);
|
void addMouseButtonBinding(Control* control, unsigned int button, Control::ControlChangingDirection direction);
|
||||||
bool isMouseButtonBound(unsigned int button) const;
|
bool isMouseButtonBound(unsigned int button) const;
|
||||||
void addJoystickAxisBinding(Control* control, int deviceID, int axis, Control::ControlChangingDirection direction);
|
void addJoystickAxisBinding(Control* control, int deviceID, int axis, Control::ControlChangingDirection direction);
|
||||||
void addJoystickButtonBinding(Control* control, int deviceID, unsigned int button, Control::ControlChangingDirection direction);
|
void addJoystickButtonBinding(Control* control, int deviceID, unsigned int button, Control::ControlChangingDirection direction);
|
||||||
bool isJoystickButtonBound(int deviceID, unsigned int button) const;
|
bool isJoystickButtonBound(int deviceID, unsigned int button) const;
|
||||||
bool isJoystickAxisBound(int deviceID, unsigned int axis) const;
|
bool isJoystickAxisBound(int deviceID, unsigned int axis) const;
|
||||||
void removeKeyBinding(SDL_Scancode key);
|
void removeKeyBinding(SDL_Scancode key);
|
||||||
void removeMouseAxisBinding(NamedAxis axis);
|
void removeMouseAxisBinding(NamedAxis axis);
|
||||||
void removeMouseButtonBinding(unsigned int button);
|
void removeMouseButtonBinding(unsigned int button);
|
||||||
void removeJoystickAxisBinding(int deviceID, int axis);
|
void removeJoystickAxisBinding(int deviceID, int axis);
|
||||||
void removeJoystickButtonBinding(int deviceID, unsigned int button);
|
void removeJoystickButtonBinding(int deviceID, unsigned int button);
|
||||||
|
|
||||||
SDL_Scancode getKeyBinding(Control* control, ICS::Control::ControlChangingDirection direction);
|
SDL_Scancode getKeyBinding(Control* control, ICS::Control::ControlChangingDirection direction);
|
||||||
NamedAxis getMouseAxisBinding(Control* control, ICS::Control::ControlChangingDirection direction);
|
NamedAxis getMouseAxisBinding(Control* control, ICS::Control::ControlChangingDirection direction);
|
||||||
unsigned int getMouseButtonBinding(Control* control, ICS::Control::ControlChangingDirection direction);
|
unsigned int getMouseButtonBinding(Control* control, ICS::Control::ControlChangingDirection direction);
|
||||||
int getJoystickAxisBinding(Control* control, int deviceID, ICS::Control::ControlChangingDirection direction);
|
int getJoystickAxisBinding(Control* control, int deviceID, ICS::Control::ControlChangingDirection direction);
|
||||||
unsigned int getJoystickButtonBinding(Control* control, int deviceID, ICS::Control::ControlChangingDirection direction);
|
unsigned int getJoystickButtonBinding(Control* control, int deviceID, ICS::Control::ControlChangingDirection direction);
|
||||||
|
|
||||||
std::string scancodeToString(SDL_Scancode key);
|
std::string scancodeToString(SDL_Scancode key);
|
||||||
|
|
||||||
void enableDetectingBindingState(Control* control, Control::ControlChangingDirection direction);
|
void enableDetectingBindingState(Control* control, Control::ControlChangingDirection direction);
|
||||||
void cancelDetectingBindingState();
|
void cancelDetectingBindingState();
|
||||||
bool detectingBindingState();
|
bool detectingBindingState();
|
||||||
|
|
||||||
bool save(std::string fileName = "");
|
bool save(std::string fileName = "");
|
||||||
|
|
||||||
void adjustMouseRegion (Uint16 width, Uint16 height);
|
void adjustMouseRegion (Uint16 width, Uint16 height);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
void loadKeyBinders(TiXmlElement* xmlControlNode);
|
void loadKeyBinders(TiXmlElement* xmlControlNode);
|
||||||
void loadMouseAxisBinders(TiXmlElement* xmlControlNode);
|
void loadMouseAxisBinders(TiXmlElement* xmlControlNode);
|
||||||
void loadMouseButtonBinders(TiXmlElement* xmlControlNode);
|
void loadMouseButtonBinders(TiXmlElement* xmlControlNode);
|
||||||
void loadJoystickAxisBinders(TiXmlElement* xmlControlNode);
|
void loadJoystickAxisBinders(TiXmlElement* xmlControlNode);
|
||||||
void loadJoystickButtonBinders(TiXmlElement* xmlControlNode);
|
void loadJoystickButtonBinders(TiXmlElement* xmlControlNode);
|
||||||
void loadJoystickPOVBinders(TiXmlElement* xmlControlNode);
|
void loadJoystickPOVBinders(TiXmlElement* xmlControlNode);
|
||||||
void loadJoystickSliderBinders(TiXmlElement* xmlControlNode);
|
void loadJoystickSliderBinders(TiXmlElement* xmlControlNode);
|
||||||
|
|
||||||
void addMouseAxisBinding_(Control* control, int axis, Control::ControlChangingDirection direction);
|
void addMouseAxisBinding_(Control* control, int axis, Control::ControlChangingDirection direction);
|
||||||
void removeMouseAxisBinding_(int axis);
|
void removeMouseAxisBinding_(int axis);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
Control::ControlChangingDirection direction;
|
Control::ControlChangingDirection direction;
|
||||||
Control* control;
|
Control* control;
|
||||||
} ControlKeyBinderItem;
|
} ControlKeyBinderItem;
|
||||||
|
|
||||||
typedef ControlKeyBinderItem ControlAxisBinderItem;
|
typedef ControlKeyBinderItem ControlAxisBinderItem;
|
||||||
typedef ControlKeyBinderItem ControlButtonBinderItem;
|
typedef ControlKeyBinderItem ControlButtonBinderItem;
|
||||||
typedef ControlKeyBinderItem ControlPOVBinderItem;
|
typedef ControlKeyBinderItem ControlPOVBinderItem;
|
||||||
typedef ControlKeyBinderItem ControlSliderBinderItem;
|
typedef ControlKeyBinderItem ControlSliderBinderItem;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
Control* control;
|
Control* control;
|
||||||
Control::ControlChangingDirection direction;
|
Control::ControlChangingDirection direction;
|
||||||
} PendingActionItem;
|
} PendingActionItem;
|
||||||
|
|
||||||
std::list<PendingActionItem> mPendingActions;
|
std::list<PendingActionItem> mPendingActions;
|
||||||
|
|
||||||
std::string mFileName;
|
std::string mFileName;
|
||||||
|
|
||||||
float mDeadZone;
|
float mDeadZone;
|
||||||
|
|
||||||
typedef std::map<SDL_Scancode, ControlKeyBinderItem> ControlsKeyBinderMapType; // <Scancode, [direction, control]>
|
typedef std::map<SDL_Scancode, ControlKeyBinderItem> ControlsKeyBinderMapType; // <Scancode, [direction, control]>
|
||||||
typedef std::map<int, ControlAxisBinderItem> ControlsAxisBinderMapType; // <axis, [direction, control]>
|
typedef std::map<int, ControlAxisBinderItem> ControlsAxisBinderMapType; // <axis, [direction, control]>
|
||||||
typedef std::map<int, ControlButtonBinderItem> ControlsButtonBinderMapType; // <button, [direction, control]>
|
typedef std::map<int, ControlButtonBinderItem> ControlsButtonBinderMapType; // <button, [direction, control]>
|
||||||
|
|
||||||
typedef std::map<int, ControlsAxisBinderMapType> JoystickAxisBinderMapType; // <joystick_id, <axis, [direction, control]> >
|
typedef std::map<int, ControlsAxisBinderMapType> JoystickAxisBinderMapType; // <joystick_id, <axis, [direction, control]> >
|
||||||
typedef std::map<int, ControlsButtonBinderMapType> JoystickButtonBinderMapType; // <joystick_id, <button, [direction, control]> >
|
typedef std::map<int, ControlsButtonBinderMapType> JoystickButtonBinderMapType; // <joystick_id, <button, [direction, control]> >
|
||||||
|
|
||||||
ControlsAxisBinderMapType mControlsMouseAxisBinderMap; // <axis, [direction, control]>
|
ControlsAxisBinderMapType mControlsMouseAxisBinderMap; // <axis, [direction, control]>
|
||||||
ControlsButtonBinderMapType mControlsMouseButtonBinderMap; // <int, [direction, control]>
|
ControlsButtonBinderMapType mControlsMouseButtonBinderMap; // <int, [direction, control]>
|
||||||
JoystickAxisBinderMapType mControlsJoystickAxisBinderMap; // <axis, [direction, control]>
|
JoystickAxisBinderMapType mControlsJoystickAxisBinderMap; // <axis, [direction, control]>
|
||||||
JoystickButtonBinderMapType mControlsJoystickButtonBinderMap; // <button, [direction, control]>
|
JoystickButtonBinderMapType mControlsJoystickButtonBinderMap; // <button, [direction, control]>
|
||||||
|
|
||||||
std::vector<Control *> mControls;
|
std::vector<Control *> mControls;
|
||||||
std::vector<Channel *> mChannels;
|
std::vector<Channel *> mChannels;
|
||||||
|
|
||||||
ControlsKeyBinderMapType mControlsKeyBinderMap;
|
ControlsKeyBinderMapType mControlsKeyBinderMap;
|
||||||
|
|
||||||
bool mActive;
|
bool mActive;
|
||||||
InputControlSystemLog* mLog;
|
InputControlSystemLog* mLog;
|
||||||
|
|
||||||
DetectingBindingListener* mDetectingBindingListener;
|
DetectingBindingListener* mDetectingBindingListener;
|
||||||
Control* mDetectingBindingControl;
|
Control* mDetectingBindingControl;
|
||||||
Control::ControlChangingDirection mDetectingBindingDirection;
|
Control::ControlChangingDirection mDetectingBindingDirection;
|
||||||
|
|
||||||
bool mXmouseAxisBinded;
|
bool mXmouseAxisBinded;
|
||||||
bool mYmouseAxisBinded;
|
bool mYmouseAxisBinded;
|
||||||
|
|
||||||
JoystickIDList mJoystickIDList;
|
JoystickIDList mJoystickIDList;
|
||||||
JoystickInstanceMap mJoystickInstanceMap;
|
JoystickInstanceMap mJoystickInstanceMap;
|
||||||
|
|
||||||
int mMouseAxisBindingInitialValues[3];
|
int mMouseAxisBindingInitialValues[3];
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
Uint16 mClientWidth;
|
Uint16 mClientWidth;
|
||||||
Uint16 mClientHeight;
|
Uint16 mClientHeight;
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------------------------
|
/* ----------------------------------------------------------------------------------------
|
||||||
* OPENMW CODE STARTS HERE
|
* OPENMW CODE STARTS HERE
|
||||||
* Mouse Wheel support added by Michael Stopa (Stomy) */
|
* Mouse Wheel support added by Michael Stopa (Stomy) */
|
||||||
|
|
||||||
public:
|
public:
|
||||||
enum class MouseWheelClick : int { UNASSIGNED = 0, UP = 1, DOWN = 2, LEFT = 3, RIGHT = 4};
|
enum class MouseWheelClick : int { UNASSIGNED = 0, UP = 1, DOWN = 2, LEFT = 3, RIGHT = 4};
|
||||||
|
|
||||||
void mouseWheelMoved(const SDL_MouseWheelEvent &evt);
|
void mouseWheelMoved(const SDL_MouseWheelEvent &evt);
|
||||||
void addMouseWheelBinding(Control* control, MouseWheelClick click, Control::ControlChangingDirection direction);
|
void addMouseWheelBinding(Control* control, MouseWheelClick click, Control::ControlChangingDirection direction);
|
||||||
void removeMouseWheelBinding(MouseWheelClick click);
|
void removeMouseWheelBinding(MouseWheelClick click);
|
||||||
MouseWheelClick getMouseWheelBinding(Control* control, ICS::Control::ControlChangingDirection direction);
|
MouseWheelClick getMouseWheelBinding(Control* control, ICS::Control::ControlChangingDirection direction);
|
||||||
bool isMouseWheelBound(MouseWheelClick button) const;
|
bool isMouseWheelBound(MouseWheelClick button) const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void loadMouseWheelBinders(TiXmlElement* xmlControlNode);
|
void loadMouseWheelBinders(TiXmlElement* xmlControlNode);
|
||||||
ControlsButtonBinderMapType mControlsMouseWheelBinderMap;
|
ControlsButtonBinderMapType mControlsMouseWheelBinderMap;
|
||||||
|
|
||||||
/* OPENMW CODE ENDS HERE
|
/* OPENMW CODE ENDS HERE
|
||||||
* ------------------------------------------------------------------------------------- */
|
* ------------------------------------------------------------------------------------- */
|
||||||
};
|
};
|
||||||
|
|
||||||
class DllExport DetectingBindingListener
|
class DllExport DetectingBindingListener
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual void keyBindingDetected(InputControlSystem* ICS, Control* control
|
virtual void keyBindingDetected(InputControlSystem* ICS, Control* control
|
||||||
, SDL_Scancode key, Control::ControlChangingDirection direction);
|
, SDL_Scancode key, Control::ControlChangingDirection direction);
|
||||||
|
|
||||||
virtual void mouseAxisBindingDetected(InputControlSystem* ICS, Control* control
|
virtual void mouseAxisBindingDetected(InputControlSystem* ICS, Control* control
|
||||||
, InputControlSystem::NamedAxis axis, Control::ControlChangingDirection direction);
|
, InputControlSystem::NamedAxis axis, Control::ControlChangingDirection direction);
|
||||||
|
|
||||||
virtual void mouseButtonBindingDetected(InputControlSystem* ICS, Control* control
|
virtual void mouseButtonBindingDetected(InputControlSystem* ICS, Control* control
|
||||||
, unsigned int button, Control::ControlChangingDirection direction);
|
, unsigned int button, Control::ControlChangingDirection direction);
|
||||||
|
|
||||||
virtual void joystickAxisBindingDetected(InputControlSystem* ICS, int deviceID, Control* control
|
virtual void joystickAxisBindingDetected(InputControlSystem* ICS, int deviceID, Control* control
|
||||||
, int axis, Control::ControlChangingDirection direction);
|
, int axis, Control::ControlChangingDirection direction);
|
||||||
|
|
||||||
virtual void joystickButtonBindingDetected(InputControlSystem* ICS, int deviceID, Control* control
|
virtual void joystickButtonBindingDetected(InputControlSystem* ICS, int deviceID, Control* control
|
||||||
, unsigned int button, Control::ControlChangingDirection direction);
|
, unsigned int button, Control::ControlChangingDirection direction);
|
||||||
|
|
||||||
/* ----------------------------------------------------------------------------------------
|
/* ----------------------------------------------------------------------------------------
|
||||||
* OPENMW CODE STARTS HERE
|
* OPENMW CODE STARTS HERE
|
||||||
* Mouse Wheel support added by Michael Stopa (Stomy) */
|
* Mouse Wheel support added by Michael Stopa (Stomy) */
|
||||||
|
|
||||||
virtual void mouseWheelBindingDetected(InputControlSystem* ICS, Control* control,
|
virtual void mouseWheelBindingDetected(InputControlSystem* ICS, Control* control,
|
||||||
InputControlSystem::MouseWheelClick click,
|
InputControlSystem::MouseWheelClick click,
|
||||||
Control::ControlChangingDirection direction);
|
Control::ControlChangingDirection direction);
|
||||||
|
|
||||||
virtual ~DetectingBindingListener() = default;
|
virtual ~DetectingBindingListener() = default;
|
||||||
|
|
||||||
/* OPENMW CODE ENDS HERE
|
/* OPENMW CODE ENDS HERE
|
||||||
* ------------------------------------------------------------------------------------- */
|
* ------------------------------------------------------------------------------------- */
|
||||||
};
|
};
|
||||||
|
|
||||||
extern const float ICS_MAX;
|
extern const float ICS_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
620
extern/oics/ICSInputControlSystem_joystick.cpp
vendored
620
extern/oics/ICSInputControlSystem_joystick.cpp
vendored
|
@ -1,266 +1,266 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#include "ICSInputControlSystem.h"
|
#include "ICSInputControlSystem.h"
|
||||||
|
|
||||||
#define SDL_JOY_AXIS_MIN -32768
|
#define SDL_JOY_AXIS_MIN -32768
|
||||||
#define SDL_JOY_AXIS_MAX 32767
|
#define SDL_JOY_AXIS_MAX 32767
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
// load xml
|
// load xml
|
||||||
void InputControlSystem::loadJoystickAxisBinders(TiXmlElement* xmlControlNode)
|
void InputControlSystem::loadJoystickAxisBinders(TiXmlElement* xmlControlNode)
|
||||||
{
|
{
|
||||||
TiXmlElement* xmlJoystickBinder = xmlControlNode->FirstChildElement("JoystickAxisBinder");
|
TiXmlElement* xmlJoystickBinder = xmlControlNode->FirstChildElement("JoystickAxisBinder");
|
||||||
while(xmlJoystickBinder)
|
while(xmlJoystickBinder)
|
||||||
{
|
{
|
||||||
Control::ControlChangingDirection dir = Control::STOP;
|
Control::ControlChangingDirection dir = Control::STOP;
|
||||||
if(std::string(xmlJoystickBinder->Attribute("direction")) == "INCREASE")
|
if(std::string(xmlJoystickBinder->Attribute("direction")) == "INCREASE")
|
||||||
{
|
{
|
||||||
dir = Control::INCREASE;
|
dir = Control::INCREASE;
|
||||||
}
|
}
|
||||||
else if(std::string(xmlJoystickBinder->Attribute("direction")) == "DECREASE")
|
else if(std::string(xmlJoystickBinder->Attribute("direction")) == "DECREASE")
|
||||||
{
|
{
|
||||||
dir = Control::DECREASE;
|
dir = Control::DECREASE;
|
||||||
}
|
}
|
||||||
|
|
||||||
addJoystickAxisBinding(mControls.back(), FromString<int>(xmlJoystickBinder->Attribute("deviceId")), FromString<int>(xmlJoystickBinder->Attribute("axis")), dir);
|
addJoystickAxisBinding(mControls.back(), FromString<int>(xmlJoystickBinder->Attribute("deviceId")), FromString<int>(xmlJoystickBinder->Attribute("axis")), dir);
|
||||||
|
|
||||||
xmlJoystickBinder = xmlJoystickBinder->NextSiblingElement("JoystickAxisBinder");
|
xmlJoystickBinder = xmlJoystickBinder->NextSiblingElement("JoystickAxisBinder");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputControlSystem::loadJoystickButtonBinders(TiXmlElement* xmlControlNode)
|
void InputControlSystem::loadJoystickButtonBinders(TiXmlElement* xmlControlNode)
|
||||||
{
|
{
|
||||||
TiXmlElement* xmlJoystickButtonBinder = xmlControlNode->FirstChildElement("JoystickButtonBinder");
|
TiXmlElement* xmlJoystickButtonBinder = xmlControlNode->FirstChildElement("JoystickButtonBinder");
|
||||||
while(xmlJoystickButtonBinder)
|
while(xmlJoystickButtonBinder)
|
||||||
{
|
{
|
||||||
Control::ControlChangingDirection dir = Control::STOP;
|
Control::ControlChangingDirection dir = Control::STOP;
|
||||||
if(std::string(xmlJoystickButtonBinder->Attribute("direction")) == "INCREASE")
|
if(std::string(xmlJoystickButtonBinder->Attribute("direction")) == "INCREASE")
|
||||||
{
|
{
|
||||||
dir = Control::INCREASE;
|
dir = Control::INCREASE;
|
||||||
}
|
}
|
||||||
else if(std::string(xmlJoystickButtonBinder->Attribute("direction")) == "DECREASE")
|
else if(std::string(xmlJoystickButtonBinder->Attribute("direction")) == "DECREASE")
|
||||||
{
|
{
|
||||||
dir = Control::DECREASE;
|
dir = Control::DECREASE;
|
||||||
}
|
}
|
||||||
|
|
||||||
addJoystickButtonBinding(mControls.back(), FromString<int>(xmlJoystickButtonBinder->Attribute("deviceId")), FromString<int>(xmlJoystickButtonBinder->Attribute("button")), dir);
|
addJoystickButtonBinding(mControls.back(), FromString<int>(xmlJoystickButtonBinder->Attribute("deviceId")), FromString<int>(xmlJoystickButtonBinder->Attribute("button")), dir);
|
||||||
|
|
||||||
xmlJoystickButtonBinder = xmlJoystickButtonBinder->NextSiblingElement("JoystickButtonBinder");
|
xmlJoystickButtonBinder = xmlJoystickButtonBinder->NextSiblingElement("JoystickButtonBinder");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// add bindings
|
// add bindings
|
||||||
void InputControlSystem::addJoystickAxisBinding(Control* control, int deviceID, int axis, Control::ControlChangingDirection direction)
|
void InputControlSystem::addJoystickAxisBinding(Control* control, int deviceID, int axis, Control::ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
if (std::find(mJoystickIDList.begin(), mJoystickIDList.end(), deviceID) == mJoystickIDList.end())
|
if (std::find(mJoystickIDList.begin(), mJoystickIDList.end(), deviceID) == mJoystickIDList.end())
|
||||||
mJoystickIDList.push_back(deviceID);
|
mJoystickIDList.push_back(deviceID);
|
||||||
|
|
||||||
ICS_LOG("\tAdding AxisBinder [axis="
|
ICS_LOG("\tAdding AxisBinder [axis="
|
||||||
+ ToString<int>(axis) + ", deviceID="
|
+ ToString<int>(axis) + ", deviceID="
|
||||||
+ ToString<int>(deviceID) + ", direction="
|
+ ToString<int>(deviceID) + ", direction="
|
||||||
+ ToString<int>(direction) + "]");
|
+ ToString<int>(direction) + "]");
|
||||||
|
|
||||||
control->setValue(0.5f); //all joystick axis start at .5, so do that
|
control->setValue(0.5f); //all joystick axis start at .5, so do that
|
||||||
|
|
||||||
ControlAxisBinderItem controlAxisBinderItem;
|
ControlAxisBinderItem controlAxisBinderItem;
|
||||||
controlAxisBinderItem.control = control;
|
controlAxisBinderItem.control = control;
|
||||||
controlAxisBinderItem.direction = direction;
|
controlAxisBinderItem.direction = direction;
|
||||||
mControlsJoystickAxisBinderMap[deviceID][axis] = controlAxisBinderItem;
|
mControlsJoystickAxisBinderMap[deviceID][axis] = controlAxisBinderItem;
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputControlSystem::addJoystickButtonBinding(Control* control, int deviceID, unsigned int button, Control::ControlChangingDirection direction)
|
void InputControlSystem::addJoystickButtonBinding(Control* control, int deviceID, unsigned int button, Control::ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
if (std::find(mJoystickIDList.begin(), mJoystickIDList.end(), deviceID) == mJoystickIDList.end())
|
if (std::find(mJoystickIDList.begin(), mJoystickIDList.end(), deviceID) == mJoystickIDList.end())
|
||||||
mJoystickIDList.push_back(deviceID); // Hack: add the device to the list so bindings are saved in save() even when joystick is not connected
|
mJoystickIDList.push_back(deviceID); // Hack: add the device to the list so bindings are saved in save() even when joystick is not connected
|
||||||
|
|
||||||
ICS_LOG("\tAdding JoystickButtonBinder [button="
|
ICS_LOG("\tAdding JoystickButtonBinder [button="
|
||||||
+ ToString<int>(button) + ", deviceID="
|
+ ToString<int>(button) + ", deviceID="
|
||||||
+ ToString<int>(deviceID) + ", direction="
|
+ ToString<int>(deviceID) + ", direction="
|
||||||
+ ToString<int>(direction) + "]");
|
+ ToString<int>(direction) + "]");
|
||||||
|
|
||||||
ControlButtonBinderItem controlJoystickButtonBinderItem;
|
ControlButtonBinderItem controlJoystickButtonBinderItem;
|
||||||
controlJoystickButtonBinderItem.direction = direction;
|
controlJoystickButtonBinderItem.direction = direction;
|
||||||
controlJoystickButtonBinderItem.control = control;
|
controlJoystickButtonBinderItem.control = control;
|
||||||
mControlsJoystickButtonBinderMap[deviceID][button] = controlJoystickButtonBinderItem;
|
mControlsJoystickButtonBinderMap[deviceID][button] = controlJoystickButtonBinderItem;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool InputControlSystem::isJoystickButtonBound(int deviceID, unsigned int button) const
|
bool InputControlSystem::isJoystickButtonBound(int deviceID, unsigned int button) const
|
||||||
{
|
{
|
||||||
JoystickButtonBinderMapType::const_iterator found = mControlsJoystickButtonBinderMap.find(deviceID);
|
JoystickButtonBinderMapType::const_iterator found = mControlsJoystickButtonBinderMap.find(deviceID);
|
||||||
if (found == mControlsJoystickButtonBinderMap.end())
|
if (found == mControlsJoystickButtonBinderMap.end())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return (found->second.find(button) != found->second.end());
|
return (found->second.find(button) != found->second.end());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool InputControlSystem::isJoystickAxisBound(int deviceID, unsigned int axis) const
|
bool InputControlSystem::isJoystickAxisBound(int deviceID, unsigned int axis) const
|
||||||
{
|
{
|
||||||
JoystickAxisBinderMapType::const_iterator found = mControlsJoystickAxisBinderMap.find(deviceID);
|
JoystickAxisBinderMapType::const_iterator found = mControlsJoystickAxisBinderMap.find(deviceID);
|
||||||
if (found == mControlsJoystickAxisBinderMap.end())
|
if (found == mControlsJoystickAxisBinderMap.end())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return (found->second.find(axis) != found->second.end());
|
return (found->second.find(axis) != found->second.end());
|
||||||
}
|
}
|
||||||
|
|
||||||
// get bindings
|
// get bindings
|
||||||
int InputControlSystem::getJoystickAxisBinding(Control* control, int deviceID, ICS::Control::ControlChangingDirection direction)
|
int InputControlSystem::getJoystickAxisBinding(Control* control, int deviceID, ICS::Control::ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
if(mControlsJoystickAxisBinderMap.find(deviceID) != mControlsJoystickAxisBinderMap.end())
|
if(mControlsJoystickAxisBinderMap.find(deviceID) != mControlsJoystickAxisBinderMap.end())
|
||||||
{
|
{
|
||||||
ControlsAxisBinderMapType::iterator it = mControlsJoystickAxisBinderMap[deviceID].begin();
|
ControlsAxisBinderMapType::iterator it = mControlsJoystickAxisBinderMap[deviceID].begin();
|
||||||
while(it != mControlsJoystickAxisBinderMap[deviceID].end())
|
while(it != mControlsJoystickAxisBinderMap[deviceID].end())
|
||||||
{
|
{
|
||||||
if(it->first >= 0 && it->second.control == control && it->second.direction == direction)
|
if(it->first >= 0 && it->second.control == control && it->second.direction == direction)
|
||||||
{
|
{
|
||||||
return it->first;
|
return it->first;
|
||||||
}
|
}
|
||||||
++it;
|
++it;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return /*NamedAxis::*/UNASSIGNED;
|
return /*NamedAxis::*/UNASSIGNED;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int InputControlSystem::getJoystickButtonBinding(Control* control, int deviceID, ICS::Control::ControlChangingDirection direction)
|
unsigned int InputControlSystem::getJoystickButtonBinding(Control* control, int deviceID, ICS::Control::ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
if(mControlsJoystickButtonBinderMap.find(deviceID) != mControlsJoystickButtonBinderMap.end())
|
if(mControlsJoystickButtonBinderMap.find(deviceID) != mControlsJoystickButtonBinderMap.end())
|
||||||
{
|
{
|
||||||
ControlsButtonBinderMapType::iterator it = mControlsJoystickButtonBinderMap[deviceID].begin();
|
ControlsButtonBinderMapType::iterator it = mControlsJoystickButtonBinderMap[deviceID].begin();
|
||||||
while(it != mControlsJoystickButtonBinderMap[deviceID].end())
|
while(it != mControlsJoystickButtonBinderMap[deviceID].end())
|
||||||
{
|
{
|
||||||
if(it->second.control == control && it->second.direction == direction)
|
if(it->second.control == control && it->second.direction == direction)
|
||||||
{
|
{
|
||||||
return it->first;
|
return it->first;
|
||||||
}
|
}
|
||||||
++it;
|
++it;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return ICS_MAX_DEVICE_BUTTONS;
|
return ICS_MAX_DEVICE_BUTTONS;
|
||||||
}
|
}
|
||||||
|
|
||||||
// remove bindings
|
// remove bindings
|
||||||
void InputControlSystem::removeJoystickAxisBinding(int deviceID, int axis)
|
void InputControlSystem::removeJoystickAxisBinding(int deviceID, int axis)
|
||||||
{
|
{
|
||||||
if(mControlsJoystickAxisBinderMap.find(deviceID) != mControlsJoystickAxisBinderMap.end())
|
if(mControlsJoystickAxisBinderMap.find(deviceID) != mControlsJoystickAxisBinderMap.end())
|
||||||
{
|
{
|
||||||
ControlsAxisBinderMapType::iterator it = mControlsJoystickAxisBinderMap[deviceID].find(axis);
|
ControlsAxisBinderMapType::iterator it = mControlsJoystickAxisBinderMap[deviceID].find(axis);
|
||||||
if(it != mControlsJoystickAxisBinderMap[deviceID].end())
|
if(it != mControlsJoystickAxisBinderMap[deviceID].end())
|
||||||
{
|
{
|
||||||
mControlsJoystickAxisBinderMap[deviceID].erase(it);
|
mControlsJoystickAxisBinderMap[deviceID].erase(it);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputControlSystem::removeJoystickButtonBinding(int deviceID, unsigned int button)
|
void InputControlSystem::removeJoystickButtonBinding(int deviceID, unsigned int button)
|
||||||
{
|
{
|
||||||
if(mControlsJoystickButtonBinderMap.find(deviceID) != mControlsJoystickButtonBinderMap.end())
|
if(mControlsJoystickButtonBinderMap.find(deviceID) != mControlsJoystickButtonBinderMap.end())
|
||||||
{
|
{
|
||||||
ControlsButtonBinderMapType::iterator it = mControlsJoystickButtonBinderMap[deviceID].find(button);
|
ControlsButtonBinderMapType::iterator it = mControlsJoystickButtonBinderMap[deviceID].find(button);
|
||||||
if(it != mControlsJoystickButtonBinderMap[deviceID].end())
|
if(it != mControlsJoystickButtonBinderMap[deviceID].end())
|
||||||
{
|
{
|
||||||
mControlsJoystickButtonBinderMap[deviceID].erase(it);
|
mControlsJoystickButtonBinderMap[deviceID].erase(it);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// joyStick listeners
|
// joyStick listeners
|
||||||
void InputControlSystem::buttonPressed(int deviceID, const SDL_ControllerButtonEvent &evt)
|
void InputControlSystem::buttonPressed(int deviceID, const SDL_ControllerButtonEvent &evt)
|
||||||
{
|
{
|
||||||
if(mActive)
|
if(mActive)
|
||||||
{
|
{
|
||||||
if(!mDetectingBindingControl)
|
if(!mDetectingBindingControl)
|
||||||
{
|
{
|
||||||
if(mControlsJoystickButtonBinderMap.find(deviceID) != mControlsJoystickButtonBinderMap.end())
|
if(mControlsJoystickButtonBinderMap.find(deviceID) != mControlsJoystickButtonBinderMap.end())
|
||||||
{
|
{
|
||||||
ControlsButtonBinderMapType::const_iterator it = mControlsJoystickButtonBinderMap[deviceID].find(evt.button);
|
ControlsButtonBinderMapType::const_iterator it = mControlsJoystickButtonBinderMap[deviceID].find(evt.button);
|
||||||
if(it != mControlsJoystickButtonBinderMap[deviceID].end())
|
if(it != mControlsJoystickButtonBinderMap[deviceID].end())
|
||||||
{
|
{
|
||||||
it->second.control->setIgnoreAutoReverse(false);
|
it->second.control->setIgnoreAutoReverse(false);
|
||||||
if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop())
|
if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop())
|
||||||
{
|
{
|
||||||
it->second.control->setChangingDirection(it->second.direction);
|
it->second.control->setChangingDirection(it->second.direction);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(it->second.control->getValue() == 1)
|
if(it->second.control->getValue() == 1)
|
||||||
{
|
{
|
||||||
it->second.control->setChangingDirection(Control::DECREASE);
|
it->second.control->setChangingDirection(Control::DECREASE);
|
||||||
}
|
}
|
||||||
else if(it->second.control->getValue() == 0)
|
else if(it->second.control->getValue() == 0)
|
||||||
{
|
{
|
||||||
it->second.control->setChangingDirection(Control::INCREASE);
|
it->second.control->setChangingDirection(Control::INCREASE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputControlSystem::buttonReleased(int deviceID, const SDL_ControllerButtonEvent &evt)
|
void InputControlSystem::buttonReleased(int deviceID, const SDL_ControllerButtonEvent &evt)
|
||||||
{
|
{
|
||||||
if(mActive)
|
if(mActive)
|
||||||
{
|
{
|
||||||
if(!mDetectingBindingControl)
|
if(!mDetectingBindingControl)
|
||||||
{
|
{
|
||||||
if(mControlsJoystickButtonBinderMap.find(deviceID) != mControlsJoystickButtonBinderMap.end())
|
if(mControlsJoystickButtonBinderMap.find(deviceID) != mControlsJoystickButtonBinderMap.end())
|
||||||
{
|
{
|
||||||
ControlsButtonBinderMapType::const_iterator it = mControlsJoystickButtonBinderMap[deviceID].find(evt.button);
|
ControlsButtonBinderMapType::const_iterator it = mControlsJoystickButtonBinderMap[deviceID].find(evt.button);
|
||||||
if(it != mControlsJoystickButtonBinderMap[deviceID].end())
|
if(it != mControlsJoystickButtonBinderMap[deviceID].end())
|
||||||
{
|
{
|
||||||
it->second.control->setChangingDirection(Control::STOP);
|
it->second.control->setChangingDirection(Control::STOP);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(mDetectingBindingListener)
|
else if(mDetectingBindingListener)
|
||||||
{
|
{
|
||||||
mDetectingBindingListener->joystickButtonBindingDetected(this, deviceID,
|
mDetectingBindingListener->joystickButtonBindingDetected(this, deviceID,
|
||||||
mDetectingBindingControl, evt.button, mDetectingBindingDirection);
|
mDetectingBindingControl, evt.button, mDetectingBindingDirection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputControlSystem::axisMoved(int deviceID, const SDL_ControllerAxisEvent &evt)
|
void InputControlSystem::axisMoved(int deviceID, const SDL_ControllerAxisEvent &evt)
|
||||||
{
|
{
|
||||||
if(mActive)
|
if(mActive)
|
||||||
{
|
{
|
||||||
if(!mDetectingBindingControl)
|
if(!mDetectingBindingControl)
|
||||||
{
|
{
|
||||||
if(mControlsJoystickAxisBinderMap.find(deviceID) != mControlsJoystickAxisBinderMap.end())
|
if(mControlsJoystickAxisBinderMap.find(deviceID) != mControlsJoystickAxisBinderMap.end())
|
||||||
{
|
{
|
||||||
ControlAxisBinderItem joystickBinderItem = mControlsJoystickAxisBinderMap[deviceID][evt.axis]; // joystic axis start at 0 index
|
ControlAxisBinderItem joystickBinderItem = mControlsJoystickAxisBinderMap[deviceID][evt.axis]; // joystic axis start at 0 index
|
||||||
Control* ctrl = joystickBinderItem.control;
|
Control* ctrl = joystickBinderItem.control;
|
||||||
if(ctrl)
|
if(ctrl)
|
||||||
{
|
{
|
||||||
ctrl->setIgnoreAutoReverse(true);
|
ctrl->setIgnoreAutoReverse(true);
|
||||||
|
|
||||||
float axisRange = SDL_JOY_AXIS_MAX - SDL_JOY_AXIS_MIN;
|
float axisRange = SDL_JOY_AXIS_MAX - SDL_JOY_AXIS_MIN;
|
||||||
float valDisplaced = (float)(evt.value - SDL_JOY_AXIS_MIN);
|
float valDisplaced = (float)(evt.value - SDL_JOY_AXIS_MIN);
|
||||||
float percent = valDisplaced / axisRange * (1+mDeadZone*2) - mDeadZone; //Assures all values, 0 through 1, are seen
|
float percent = valDisplaced / axisRange * (1+mDeadZone*2) - mDeadZone; //Assures all values, 0 through 1, are seen
|
||||||
if(percent > .5-mDeadZone && percent < .5+mDeadZone) //close enough to center
|
if(percent > .5-mDeadZone && percent < .5+mDeadZone) //close enough to center
|
||||||
|
@ -268,57 +268,57 @@ namespace ICS
|
||||||
else if(percent > .5)
|
else if(percent > .5)
|
||||||
percent -= mDeadZone;
|
percent -= mDeadZone;
|
||||||
else
|
else
|
||||||
percent += mDeadZone;
|
percent += mDeadZone;
|
||||||
|
|
||||||
if(joystickBinderItem.direction == Control::INCREASE)
|
if(joystickBinderItem.direction == Control::INCREASE)
|
||||||
{
|
{
|
||||||
ctrl->setValue( percent );
|
ctrl->setValue( percent );
|
||||||
}
|
}
|
||||||
else if(joystickBinderItem.direction == Control::DECREASE)
|
else if(joystickBinderItem.direction == Control::DECREASE)
|
||||||
{
|
{
|
||||||
ctrl->setValue( 1 - ( percent ) );
|
ctrl->setValue( 1 - ( percent ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(mDetectingBindingListener)
|
else if(mDetectingBindingListener)
|
||||||
{
|
{
|
||||||
//ControlAxisBinderItem joystickBinderItem = mControlsJoystickAxisBinderMap[ evt.which ][ axis ]; // joystic axis start at 0 index
|
//ControlAxisBinderItem joystickBinderItem = mControlsJoystickAxisBinderMap[ evt.which ][ axis ]; // joystic axis start at 0 index
|
||||||
//Control* ctrl = joystickBinderItem.control;
|
//Control* ctrl = joystickBinderItem.control;
|
||||||
//if(ctrl && ctrl->isAxisBindable())
|
//if(ctrl && ctrl->isAxisBindable())
|
||||||
if(mDetectingBindingControl->isAxisBindable())
|
if(mDetectingBindingControl->isAxisBindable())
|
||||||
{
|
{
|
||||||
if( abs( evt.value ) > ICS_JOYSTICK_AXIS_BINDING_MARGIN)
|
if( abs( evt.value ) > ICS_JOYSTICK_AXIS_BINDING_MARGIN)
|
||||||
{
|
{
|
||||||
mDetectingBindingListener->joystickAxisBindingDetected(this, deviceID,
|
mDetectingBindingListener->joystickAxisBindingDetected(this, deviceID,
|
||||||
mDetectingBindingControl, evt.axis, mDetectingBindingDirection);
|
mDetectingBindingControl, evt.axis, mDetectingBindingDirection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputControlSystem::controllerAdded(int deviceID, const SDL_ControllerDeviceEvent &args)
|
void InputControlSystem::controllerAdded(int deviceID, const SDL_ControllerDeviceEvent &args)
|
||||||
{
|
{
|
||||||
ICS_LOG("Adding joystick (index: " + ToString<int>(args.which) + ")");
|
ICS_LOG("Adding joystick (index: " + ToString<int>(args.which) + ")");
|
||||||
SDL_GameController* cntrl = SDL_GameControllerOpen(args.which);
|
SDL_GameController* cntrl = SDL_GameControllerOpen(args.which);
|
||||||
int instanceID = SDL_JoystickInstanceID(SDL_GameControllerGetJoystick(cntrl));
|
int instanceID = SDL_JoystickInstanceID(SDL_GameControllerGetJoystick(cntrl));
|
||||||
if(std::find(mJoystickIDList.begin(), mJoystickIDList.end(), deviceID)==mJoystickIDList.end())
|
if(std::find(mJoystickIDList.begin(), mJoystickIDList.end(), deviceID)==mJoystickIDList.end())
|
||||||
{
|
{
|
||||||
for(int j = 0 ; j < ICS_MAX_JOYSTICK_AXIS ; j++)
|
for(int j = 0 ; j < ICS_MAX_JOYSTICK_AXIS ; j++)
|
||||||
{
|
{
|
||||||
if(mControlsJoystickAxisBinderMap[deviceID].find(j) == mControlsJoystickAxisBinderMap[deviceID].end())
|
if(mControlsJoystickAxisBinderMap[deviceID].find(j) == mControlsJoystickAxisBinderMap[deviceID].end())
|
||||||
{
|
{
|
||||||
ControlAxisBinderItem controlJoystickBinderItem;
|
ControlAxisBinderItem controlJoystickBinderItem;
|
||||||
controlJoystickBinderItem.direction = Control::STOP;
|
controlJoystickBinderItem.direction = Control::STOP;
|
||||||
controlJoystickBinderItem.control = NULL;
|
controlJoystickBinderItem.control = NULL;
|
||||||
mControlsJoystickAxisBinderMap[deviceID][j] = controlJoystickBinderItem;
|
mControlsJoystickAxisBinderMap[deviceID][j] = controlJoystickBinderItem;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
mJoystickIDList.push_front(deviceID);
|
mJoystickIDList.push_front(deviceID);
|
||||||
}
|
}
|
||||||
|
|
||||||
mJoystickInstanceMap[instanceID] = cntrl;
|
mJoystickInstanceMap[instanceID] = cntrl;
|
||||||
}
|
}
|
||||||
void InputControlSystem::controllerRemoved(const SDL_ControllerDeviceEvent &args)
|
void InputControlSystem::controllerRemoved(const SDL_ControllerDeviceEvent &args)
|
||||||
{
|
{
|
||||||
|
@ -328,38 +328,38 @@ namespace ICS
|
||||||
SDL_GameControllerClose(mJoystickInstanceMap.at(args.which));
|
SDL_GameControllerClose(mJoystickInstanceMap.at(args.which));
|
||||||
mJoystickInstanceMap.erase(args.which);
|
mJoystickInstanceMap.erase(args.which);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// joystick auto bindings
|
// joystick auto bindings
|
||||||
void DetectingBindingListener::joystickAxisBindingDetected(InputControlSystem* ICS, int deviceID, Control* control, int axis, Control::ControlChangingDirection direction)
|
void DetectingBindingListener::joystickAxisBindingDetected(InputControlSystem* ICS, int deviceID, Control* control, int axis, Control::ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
// if the joystick axis is used by another control, remove it
|
// if the joystick axis is used by another control, remove it
|
||||||
ICS->removeJoystickAxisBinding(deviceID, axis);
|
ICS->removeJoystickAxisBinding(deviceID, axis);
|
||||||
|
|
||||||
// if the control has an axis assigned, remove it
|
// if the control has an axis assigned, remove it
|
||||||
int oldAxis = ICS->getJoystickAxisBinding(control, deviceID, direction);
|
int oldAxis = ICS->getJoystickAxisBinding(control, deviceID, direction);
|
||||||
if(oldAxis != InputControlSystem::UNASSIGNED)
|
if(oldAxis != InputControlSystem::UNASSIGNED)
|
||||||
{
|
{
|
||||||
ICS->removeJoystickAxisBinding(deviceID, oldAxis);
|
ICS->removeJoystickAxisBinding(deviceID, oldAxis);
|
||||||
}
|
}
|
||||||
|
|
||||||
ICS->addJoystickAxisBinding(control, deviceID, axis, direction);
|
ICS->addJoystickAxisBinding(control, deviceID, axis, direction);
|
||||||
ICS->cancelDetectingBindingState();
|
ICS->cancelDetectingBindingState();
|
||||||
}
|
}
|
||||||
void DetectingBindingListener::joystickButtonBindingDetected(InputControlSystem* ICS, int deviceID, Control* control
|
void DetectingBindingListener::joystickButtonBindingDetected(InputControlSystem* ICS, int deviceID, Control* control
|
||||||
, unsigned int button, Control::ControlChangingDirection direction)
|
, unsigned int button, Control::ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
// if the joystick button is used by another control, remove it
|
// if the joystick button is used by another control, remove it
|
||||||
ICS->removeJoystickButtonBinding(deviceID, button);
|
ICS->removeJoystickButtonBinding(deviceID, button);
|
||||||
|
|
||||||
// if the control has a joystick button assigned, remove it
|
// if the control has a joystick button assigned, remove it
|
||||||
unsigned int oldButton = ICS->getJoystickButtonBinding(control, deviceID, direction);
|
unsigned int oldButton = ICS->getJoystickButtonBinding(control, deviceID, direction);
|
||||||
if(oldButton != ICS_MAX_DEVICE_BUTTONS)
|
if(oldButton != ICS_MAX_DEVICE_BUTTONS)
|
||||||
{
|
{
|
||||||
ICS->removeJoystickButtonBinding(deviceID, oldButton);
|
ICS->removeJoystickButtonBinding(deviceID, oldButton);
|
||||||
}
|
}
|
||||||
|
|
||||||
ICS->addJoystickButtonBinding(control, deviceID, button, direction);
|
ICS->addJoystickButtonBinding(control, deviceID, button, direction);
|
||||||
ICS->cancelDetectingBindingState();
|
ICS->cancelDetectingBindingState();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
314
extern/oics/ICSInputControlSystem_keyboard.cpp
vendored
314
extern/oics/ICSInputControlSystem_keyboard.cpp
vendored
|
@ -1,157 +1,157 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#include "ICSInputControlSystem.h"
|
#include "ICSInputControlSystem.h"
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
void InputControlSystem::loadKeyBinders(TiXmlElement* xmlControlNode)
|
void InputControlSystem::loadKeyBinders(TiXmlElement* xmlControlNode)
|
||||||
{
|
{
|
||||||
TiXmlElement* xmlKeyBinder = xmlControlNode->FirstChildElement("KeyBinder");
|
TiXmlElement* xmlKeyBinder = xmlControlNode->FirstChildElement("KeyBinder");
|
||||||
while(xmlKeyBinder)
|
while(xmlKeyBinder)
|
||||||
{
|
{
|
||||||
Control::ControlChangingDirection dir = Control::STOP;
|
Control::ControlChangingDirection dir = Control::STOP;
|
||||||
if(std::string(xmlKeyBinder->Attribute("direction")) == "INCREASE")
|
if(std::string(xmlKeyBinder->Attribute("direction")) == "INCREASE")
|
||||||
{
|
{
|
||||||
dir = Control::INCREASE;
|
dir = Control::INCREASE;
|
||||||
}
|
}
|
||||||
else if(std::string(xmlKeyBinder->Attribute("direction")) == "DECREASE")
|
else if(std::string(xmlKeyBinder->Attribute("direction")) == "DECREASE")
|
||||||
{
|
{
|
||||||
dir = Control::DECREASE;
|
dir = Control::DECREASE;
|
||||||
}
|
}
|
||||||
|
|
||||||
addKeyBinding(mControls.back(), SDL_Scancode(FromString<int>(xmlKeyBinder->Attribute("key"))), dir);
|
addKeyBinding(mControls.back(), SDL_Scancode(FromString<int>(xmlKeyBinder->Attribute("key"))), dir);
|
||||||
|
|
||||||
xmlKeyBinder = xmlKeyBinder->NextSiblingElement("KeyBinder");
|
xmlKeyBinder = xmlKeyBinder->NextSiblingElement("KeyBinder");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputControlSystem::addKeyBinding(Control* control, SDL_Scancode key, Control::ControlChangingDirection direction)
|
void InputControlSystem::addKeyBinding(Control* control, SDL_Scancode key, Control::ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
ICS_LOG("\tAdding KeyBinder [key="
|
ICS_LOG("\tAdding KeyBinder [key="
|
||||||
+ scancodeToString(key) + ", direction="
|
+ scancodeToString(key) + ", direction="
|
||||||
+ ToString<int>(direction) + "]");
|
+ ToString<int>(direction) + "]");
|
||||||
|
|
||||||
ControlKeyBinderItem controlKeyBinderItem;
|
ControlKeyBinderItem controlKeyBinderItem;
|
||||||
controlKeyBinderItem.control = control;
|
controlKeyBinderItem.control = control;
|
||||||
controlKeyBinderItem.direction = direction;
|
controlKeyBinderItem.direction = direction;
|
||||||
mControlsKeyBinderMap[ key ] = controlKeyBinderItem;
|
mControlsKeyBinderMap[ key ] = controlKeyBinderItem;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool InputControlSystem::isKeyBound(SDL_Scancode key) const
|
bool InputControlSystem::isKeyBound(SDL_Scancode key) const
|
||||||
{
|
{
|
||||||
return mControlsKeyBinderMap.find(key) != mControlsKeyBinderMap.end();
|
return mControlsKeyBinderMap.find(key) != mControlsKeyBinderMap.end();
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputControlSystem::removeKeyBinding(SDL_Scancode key)
|
void InputControlSystem::removeKeyBinding(SDL_Scancode key)
|
||||||
{
|
{
|
||||||
ControlsKeyBinderMapType::iterator it = mControlsKeyBinderMap.find(key);
|
ControlsKeyBinderMapType::iterator it = mControlsKeyBinderMap.find(key);
|
||||||
if(it != mControlsKeyBinderMap.end())
|
if(it != mControlsKeyBinderMap.end())
|
||||||
{
|
{
|
||||||
mControlsKeyBinderMap.erase(it);
|
mControlsKeyBinderMap.erase(it);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SDL_Scancode InputControlSystem::getKeyBinding(Control* control
|
SDL_Scancode InputControlSystem::getKeyBinding(Control* control
|
||||||
, ICS::Control::ControlChangingDirection direction)
|
, ICS::Control::ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
ControlsKeyBinderMapType::iterator it = mControlsKeyBinderMap.begin();
|
ControlsKeyBinderMapType::iterator it = mControlsKeyBinderMap.begin();
|
||||||
while(it != mControlsKeyBinderMap.end())
|
while(it != mControlsKeyBinderMap.end())
|
||||||
{
|
{
|
||||||
if(it->second.control == control && it->second.direction == direction)
|
if(it->second.control == control && it->second.direction == direction)
|
||||||
{
|
{
|
||||||
return it->first;
|
return it->first;
|
||||||
}
|
}
|
||||||
++it;
|
++it;
|
||||||
}
|
}
|
||||||
|
|
||||||
return SDL_SCANCODE_UNKNOWN;
|
return SDL_SCANCODE_UNKNOWN;
|
||||||
}
|
}
|
||||||
void InputControlSystem::keyPressed(const SDL_KeyboardEvent &evt)
|
void InputControlSystem::keyPressed(const SDL_KeyboardEvent &evt)
|
||||||
{
|
{
|
||||||
if(mActive)
|
if(mActive)
|
||||||
{
|
{
|
||||||
if(!mDetectingBindingControl)
|
if(!mDetectingBindingControl)
|
||||||
{
|
{
|
||||||
ControlsKeyBinderMapType::const_iterator it = mControlsKeyBinderMap.find(evt.keysym.scancode);
|
ControlsKeyBinderMapType::const_iterator it = mControlsKeyBinderMap.find(evt.keysym.scancode);
|
||||||
if(it != mControlsKeyBinderMap.end())
|
if(it != mControlsKeyBinderMap.end())
|
||||||
{
|
{
|
||||||
it->second.control->setIgnoreAutoReverse(false);
|
it->second.control->setIgnoreAutoReverse(false);
|
||||||
if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop())
|
if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop())
|
||||||
{
|
{
|
||||||
it->second.control->setChangingDirection(it->second.direction);
|
it->second.control->setChangingDirection(it->second.direction);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if(it->second.control->getValue() == 1)
|
if(it->second.control->getValue() == 1)
|
||||||
{
|
{
|
||||||
it->second.control->setChangingDirection(Control::DECREASE);
|
it->second.control->setChangingDirection(Control::DECREASE);
|
||||||
}
|
}
|
||||||
else if(it->second.control->getValue() == 0)
|
else if(it->second.control->getValue() == 0)
|
||||||
{
|
{
|
||||||
it->second.control->setChangingDirection(Control::INCREASE);
|
it->second.control->setChangingDirection(Control::INCREASE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(mDetectingBindingListener)
|
else if(mDetectingBindingListener)
|
||||||
{
|
{
|
||||||
mDetectingBindingListener->keyBindingDetected(this,
|
mDetectingBindingListener->keyBindingDetected(this,
|
||||||
mDetectingBindingControl, evt.keysym.scancode, mDetectingBindingDirection);
|
mDetectingBindingControl, evt.keysym.scancode, mDetectingBindingDirection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void InputControlSystem::keyReleased(const SDL_KeyboardEvent &evt)
|
void InputControlSystem::keyReleased(const SDL_KeyboardEvent &evt)
|
||||||
{
|
{
|
||||||
if(mActive)
|
if(mActive)
|
||||||
{
|
{
|
||||||
ControlsKeyBinderMapType::const_iterator it = mControlsKeyBinderMap.find(evt.keysym.scancode);
|
ControlsKeyBinderMapType::const_iterator it = mControlsKeyBinderMap.find(evt.keysym.scancode);
|
||||||
if(it != mControlsKeyBinderMap.end())
|
if(it != mControlsKeyBinderMap.end())
|
||||||
{
|
{
|
||||||
it->second.control->setChangingDirection(Control::STOP);
|
it->second.control->setChangingDirection(Control::STOP);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void DetectingBindingListener::keyBindingDetected(InputControlSystem* ICS, Control* control
|
void DetectingBindingListener::keyBindingDetected(InputControlSystem* ICS, Control* control
|
||||||
, SDL_Scancode key, Control::ControlChangingDirection direction)
|
, SDL_Scancode key, Control::ControlChangingDirection direction)
|
||||||
{
|
{
|
||||||
// if the key is used by another control, remove it
|
// if the key is used by another control, remove it
|
||||||
ICS->removeKeyBinding(key);
|
ICS->removeKeyBinding(key);
|
||||||
|
|
||||||
// if the control has a key assigned, remove it
|
// if the control has a key assigned, remove it
|
||||||
SDL_Scancode oldKey = ICS->getKeyBinding(control, direction);
|
SDL_Scancode oldKey = ICS->getKeyBinding(control, direction);
|
||||||
if(oldKey != SDL_SCANCODE_UNKNOWN)
|
if(oldKey != SDL_SCANCODE_UNKNOWN)
|
||||||
{
|
{
|
||||||
ICS->removeKeyBinding(oldKey);
|
ICS->removeKeyBinding(oldKey);
|
||||||
}
|
}
|
||||||
|
|
||||||
ICS->addKeyBinding(control, key, direction);
|
ICS->addKeyBinding(control, key, direction);
|
||||||
ICS->cancelDetectingBindingState();
|
ICS->cancelDetectingBindingState();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
1132
extern/oics/ICSInputControlSystem_mouse.cpp
vendored
1132
extern/oics/ICSInputControlSystem_mouse.cpp
vendored
File diff suppressed because it is too large
Load diff
54
extern/oics/ICSPrerequisites.cpp
vendored
54
extern/oics/ICSPrerequisites.cpp
vendored
|
@ -1,27 +1,27 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
#include "ICSPrerequisites.h"
|
#include "ICSPrerequisites.h"
|
||||||
|
|
220
extern/oics/ICSPrerequisites.h
vendored
220
extern/oics/ICSPrerequisites.h
vendored
|
@ -1,110 +1,110 @@
|
||||||
/* -------------------------------------------------------
|
/* -------------------------------------------------------
|
||||||
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
Copyright (c) 2011 Alberto G. Salguero (alberto.salguero (at) uca.es)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any
|
Permission is hereby granted, free of charge, to any
|
||||||
person obtaining a copy of this software and associated
|
person obtaining a copy of this software and associated
|
||||||
documentation files (the "Software"), to deal in the
|
documentation files (the "Software"), to deal in the
|
||||||
Software without restriction, including without limitation
|
Software without restriction, including without limitation
|
||||||
the rights to use, copy, modify, merge, publish,
|
the rights to use, copy, modify, merge, publish,
|
||||||
distribute, sublicense, and/or sell copies of the
|
distribute, sublicense, and/or sell copies of the
|
||||||
Software, and to permit persons to whom the Software is
|
Software, and to permit persons to whom the Software is
|
||||||
furnished to do so, subject to the following conditions:
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice
|
The above copyright notice and this permission notice
|
||||||
shall be included in all copies or substantial portions of
|
shall be included in all copies or substantial portions of
|
||||||
the Software.
|
the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
|
||||||
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
|
||||||
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
|
||||||
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS
|
||||||
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------- */
|
------------------------------------------------------- */
|
||||||
|
|
||||||
//! @todo add mouse wheel support
|
//! @todo add mouse wheel support
|
||||||
|
|
||||||
#ifndef _InputControlSystem_Prerequisites_H_
|
#ifndef _InputControlSystem_Prerequisites_H_
|
||||||
#define _InputControlSystem_Prerequisites_H_
|
#define _InputControlSystem_Prerequisites_H_
|
||||||
|
|
||||||
/// Include external headers
|
/// Include external headers
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <list>
|
#include <list>
|
||||||
#include <limits>
|
#include <limits>
|
||||||
#include <algorithm> /* std::min and std::max for MSVC 2013 */
|
#include <algorithm> /* std::min and std::max for MSVC 2013 */
|
||||||
|
|
||||||
#include "tinyxml.h"
|
#include "tinyxml.h"
|
||||||
|
|
||||||
#include "SDL_keyboard.h"
|
#include "SDL_keyboard.h"
|
||||||
#include "SDL_mouse.h"
|
#include "SDL_mouse.h"
|
||||||
#include "SDL_joystick.h"
|
#include "SDL_joystick.h"
|
||||||
#include "SDL_events.h"
|
#include "SDL_events.h"
|
||||||
|
|
||||||
/// Define the dll export qualifier if compiling for Windows
|
/// Define the dll export qualifier if compiling for Windows
|
||||||
|
|
||||||
/*
|
/*
|
||||||
#ifdef ICS_PLATFORM_WIN32
|
#ifdef ICS_PLATFORM_WIN32
|
||||||
#ifdef ICS_LIB
|
#ifdef ICS_LIB
|
||||||
#define DllExport __declspec (dllexport)
|
#define DllExport __declspec (dllexport)
|
||||||
#else
|
#else
|
||||||
#define DllExport __declspec (dllimport)
|
#define DllExport __declspec (dllimport)
|
||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
#define DllExport
|
#define DllExport
|
||||||
#endif
|
#endif
|
||||||
*/
|
*/
|
||||||
#define DllExport
|
#define DllExport
|
||||||
|
|
||||||
// Define some macros
|
// Define some macros
|
||||||
#define ICS_DEPRECATED __declspec(deprecated("Deprecated. It will be removed in future versions."))
|
#define ICS_DEPRECATED __declspec(deprecated("Deprecated. It will be removed in future versions."))
|
||||||
|
|
||||||
/// Version defines
|
/// Version defines
|
||||||
#define ICS_VERSION_MAJOR 0
|
#define ICS_VERSION_MAJOR 0
|
||||||
#define ICS_VERSION_MINOR 4
|
#define ICS_VERSION_MINOR 4
|
||||||
#define ICS_VERSION_PATCH 0
|
#define ICS_VERSION_PATCH 0
|
||||||
|
|
||||||
#define ICS_MAX_DEVICE_BUTTONS 30
|
#define ICS_MAX_DEVICE_BUTTONS 30
|
||||||
|
|
||||||
namespace ICS
|
namespace ICS
|
||||||
{
|
{
|
||||||
template <typename T>
|
template <typename T>
|
||||||
bool StringIsNumber ( const std::string &Text )
|
bool StringIsNumber ( const std::string &Text )
|
||||||
{
|
{
|
||||||
std::stringstream ss(Text);
|
std::stringstream ss(Text);
|
||||||
T result;
|
T result;
|
||||||
return (ss >> result) ? true : false;
|
return (ss >> result) ? true : false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// from http://www.cplusplus.com/forum/articles/9645/
|
// from http://www.cplusplus.com/forum/articles/9645/
|
||||||
template <typename T>
|
template <typename T>
|
||||||
std::string ToString ( T value )
|
std::string ToString ( T value )
|
||||||
{
|
{
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
ss << value;
|
ss << value;
|
||||||
return ss.str();
|
return ss.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
// from http://www.cplusplus.com/forum/articles/9645/
|
// from http://www.cplusplus.com/forum/articles/9645/
|
||||||
template <typename T>
|
template <typename T>
|
||||||
T FromString ( const std::string &Text )//Text not by const reference so that the function can be used with a
|
T FromString ( const std::string &Text )//Text not by const reference so that the function can be used with a
|
||||||
{ //character array as argument
|
{ //character array as argument
|
||||||
std::stringstream ss(Text);
|
std::stringstream ss(Text);
|
||||||
T result;
|
T result;
|
||||||
return (ss >> result) ? result : 0;
|
return (ss >> result) ? result : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
class InputControlSystem;
|
class InputControlSystem;
|
||||||
class Channel;
|
class Channel;
|
||||||
class ChannelListener;
|
class ChannelListener;
|
||||||
class Control;
|
class Control;
|
||||||
class ControlListener;
|
class ControlListener;
|
||||||
class DetectingBindingListener;
|
class DetectingBindingListener;
|
||||||
class InputControlSystemLog;
|
class InputControlSystemLog;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
198
extern/sol3/sol/assert.hpp
vendored
198
extern/sol3/sol/assert.hpp
vendored
|
@ -1,99 +1,99 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#ifndef SOL_ASSERT_HPP
|
#ifndef SOL_ASSERT_HPP
|
||||||
#define SOL_ASSERT_HPP
|
#define SOL_ASSERT_HPP
|
||||||
|
|
||||||
#include <sol/forward.hpp>
|
#include <sol/forward.hpp>
|
||||||
|
|
||||||
#if SOL_IS_ON(SOL2_CI_I_)
|
#if SOL_IS_ON(SOL2_CI_I_)
|
||||||
|
|
||||||
struct pre_main {
|
struct pre_main {
|
||||||
pre_main() {
|
pre_main() {
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
_set_abort_behavior(0, _WRITE_ABORT_MSG);
|
_set_abort_behavior(0, _WRITE_ABORT_MSG);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
} inline sol2_ci_dont_lock_ci_please = {};
|
} inline sol2_ci_dont_lock_ci_please = {};
|
||||||
|
|
||||||
#endif // Prevent lockup when doing Continuous Integration
|
#endif // Prevent lockup when doing Continuous Integration
|
||||||
|
|
||||||
|
|
||||||
// clang-format off
|
// clang-format off
|
||||||
|
|
||||||
#if SOL_IS_ON(SOL_USER_C_ASSERT_I_)
|
#if SOL_IS_ON(SOL_USER_C_ASSERT_I_)
|
||||||
#define sol_c_assert(...) SOL_C_ASSERT(__VA_ARGS__)
|
#define sol_c_assert(...) SOL_C_ASSERT(__VA_ARGS__)
|
||||||
#else
|
#else
|
||||||
#if SOL_IS_ON(SOL_DEBUG_BUILD_I_)
|
#if SOL_IS_ON(SOL_DEBUG_BUILD_I_)
|
||||||
#include <exception>
|
#include <exception>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
|
||||||
#define sol_c_assert(...) \
|
#define sol_c_assert(...) \
|
||||||
do { \
|
do { \
|
||||||
if (!(__VA_ARGS__)) { \
|
if (!(__VA_ARGS__)) { \
|
||||||
std::cerr << "Assertion `" #__VA_ARGS__ "` failed in " << __FILE__ << " line " << __LINE__ << std::endl; \
|
std::cerr << "Assertion `" #__VA_ARGS__ "` failed in " << __FILE__ << " line " << __LINE__ << std::endl; \
|
||||||
std::terminate(); \
|
std::terminate(); \
|
||||||
} \
|
} \
|
||||||
} while (false)
|
} while (false)
|
||||||
#else
|
#else
|
||||||
#define sol_c_assert(...) \
|
#define sol_c_assert(...) \
|
||||||
do { \
|
do { \
|
||||||
if (false) { \
|
if (false) { \
|
||||||
(void)(__VA_ARGS__); \
|
(void)(__VA_ARGS__); \
|
||||||
} \
|
} \
|
||||||
} while (false)
|
} while (false)
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if SOL_IS_ON(SOL_USER_M_ASSERT_I_)
|
#if SOL_IS_ON(SOL_USER_M_ASSERT_I_)
|
||||||
#define sol_m_assert(message, ...) SOL_M_ASSERT(message, __VA_ARGS__)
|
#define sol_m_assert(message, ...) SOL_M_ASSERT(message, __VA_ARGS__)
|
||||||
#else
|
#else
|
||||||
#if SOL_IS_ON(SOL_DEBUG_BUILD_I_)
|
#if SOL_IS_ON(SOL_DEBUG_BUILD_I_)
|
||||||
#include <exception>
|
#include <exception>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
|
||||||
#define sol_m_assert(message, ...) \
|
#define sol_m_assert(message, ...) \
|
||||||
do { \
|
do { \
|
||||||
if (!(__VA_ARGS__)) { \
|
if (!(__VA_ARGS__)) { \
|
||||||
std::cerr << "Assertion `" #__VA_ARGS__ "` failed in " << __FILE__ << " line " << __LINE__ << ": " << message << std::endl; \
|
std::cerr << "Assertion `" #__VA_ARGS__ "` failed in " << __FILE__ << " line " << __LINE__ << ": " << message << std::endl; \
|
||||||
std::terminate(); \
|
std::terminate(); \
|
||||||
} \
|
} \
|
||||||
} while (false)
|
} while (false)
|
||||||
#else
|
#else
|
||||||
#define sol_m_assert(message, ...) \
|
#define sol_m_assert(message, ...) \
|
||||||
do { \
|
do { \
|
||||||
if (false) { \
|
if (false) { \
|
||||||
(void)(__VA_ARGS__); \
|
(void)(__VA_ARGS__); \
|
||||||
(void)sizeof(message); \
|
(void)sizeof(message); \
|
||||||
} \
|
} \
|
||||||
} while (false)
|
} while (false)
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
#endif // SOL_ASSERT_HPP
|
#endif // SOL_ASSERT_HPP
|
||||||
|
|
246
extern/sol3/sol/base_traits.hpp
vendored
246
extern/sol3/sol/base_traits.hpp
vendored
|
@ -1,123 +1,123 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_BASE_TRAITS_HPP
|
#ifndef SOL_BASE_TRAITS_HPP
|
||||||
#define SOL_BASE_TRAITS_HPP
|
#define SOL_BASE_TRAITS_HPP
|
||||||
|
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
struct unchecked_t { };
|
struct unchecked_t { };
|
||||||
const unchecked_t unchecked = unchecked_t {};
|
const unchecked_t unchecked = unchecked_t {};
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
namespace meta {
|
namespace meta {
|
||||||
using sfinae_yes_t = std::true_type;
|
using sfinae_yes_t = std::true_type;
|
||||||
using sfinae_no_t = std::false_type;
|
using sfinae_no_t = std::false_type;
|
||||||
|
|
||||||
template <typename...>
|
template <typename...>
|
||||||
using void_t = void;
|
using void_t = void;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using unqualified = std::remove_cv<std::remove_reference_t<T>>;
|
using unqualified = std::remove_cv<std::remove_reference_t<T>>;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using unqualified_t = typename unqualified<T>::type;
|
using unqualified_t = typename unqualified<T>::type;
|
||||||
|
|
||||||
namespace meta_detail {
|
namespace meta_detail {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unqualified_non_alias : unqualified<T> { };
|
struct unqualified_non_alias : unqualified<T> { };
|
||||||
|
|
||||||
template <template <class...> class Test, class, class... Args>
|
template <template <class...> class Test, class, class... Args>
|
||||||
struct is_detected : std::false_type { };
|
struct is_detected : std::false_type { };
|
||||||
|
|
||||||
template <template <class...> class Test, class... Args>
|
template <template <class...> class Test, class... Args>
|
||||||
struct is_detected<Test, void_t<Test<Args...>>, Args...> : std::true_type { };
|
struct is_detected<Test, void_t<Test<Args...>>, Args...> : std::true_type { };
|
||||||
} // namespace meta_detail
|
} // namespace meta_detail
|
||||||
|
|
||||||
template <template <class...> class Trait, class... Args>
|
template <template <class...> class Trait, class... Args>
|
||||||
using is_detected = typename meta_detail::is_detected<Trait, void, Args...>::type;
|
using is_detected = typename meta_detail::is_detected<Trait, void, Args...>::type;
|
||||||
|
|
||||||
template <template <class...> class Trait, class... Args>
|
template <template <class...> class Trait, class... Args>
|
||||||
constexpr inline bool is_detected_v = is_detected<Trait, Args...>::value;
|
constexpr inline bool is_detected_v = is_detected<Trait, Args...>::value;
|
||||||
|
|
||||||
template <std::size_t I>
|
template <std::size_t I>
|
||||||
using index_value = std::integral_constant<std::size_t, I>;
|
using index_value = std::integral_constant<std::size_t, I>;
|
||||||
|
|
||||||
template <bool>
|
template <bool>
|
||||||
struct conditional {
|
struct conditional {
|
||||||
template <typename T, typename U>
|
template <typename T, typename U>
|
||||||
using type = T;
|
using type = T;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct conditional<false> {
|
struct conditional<false> {
|
||||||
template <typename T, typename U>
|
template <typename T, typename U>
|
||||||
using type = U;
|
using type = U;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <bool B, typename T, typename U>
|
template <bool B, typename T, typename U>
|
||||||
using conditional_t = typename conditional<B>::template type<T, U>;
|
using conditional_t = typename conditional<B>::template type<T, U>;
|
||||||
|
|
||||||
namespace meta_detail {
|
namespace meta_detail {
|
||||||
template <typename T, template <typename...> class Templ>
|
template <typename T, template <typename...> class Templ>
|
||||||
struct is_specialization_of : std::false_type { };
|
struct is_specialization_of : std::false_type { };
|
||||||
template <typename... T, template <typename...> class Templ>
|
template <typename... T, template <typename...> class Templ>
|
||||||
struct is_specialization_of<Templ<T...>, Templ> : std::true_type { };
|
struct is_specialization_of<Templ<T...>, Templ> : std::true_type { };
|
||||||
} // namespace meta_detail
|
} // namespace meta_detail
|
||||||
|
|
||||||
template <typename T, template <typename...> class Templ>
|
template <typename T, template <typename...> class Templ>
|
||||||
using is_specialization_of = meta_detail::is_specialization_of<std::remove_cv_t<T>, Templ>;
|
using is_specialization_of = meta_detail::is_specialization_of<std::remove_cv_t<T>, Templ>;
|
||||||
|
|
||||||
template <typename T, template <typename...> class Templ>
|
template <typename T, template <typename...> class Templ>
|
||||||
inline constexpr bool is_specialization_of_v = is_specialization_of<std::remove_cv_t<T>, Templ>::value;
|
inline constexpr bool is_specialization_of_v = is_specialization_of<std::remove_cv_t<T>, Templ>::value;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct identity {
|
struct identity {
|
||||||
typedef T type;
|
typedef T type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using identity_t = typename identity<T>::type;
|
using identity_t = typename identity<T>::type;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using is_builtin_type = std::integral_constant<bool, std::is_arithmetic<T>::value || std::is_pointer<T>::value || std::is_array<T>::value>;
|
using is_builtin_type = std::integral_constant<bool, std::is_arithmetic<T>::value || std::is_pointer<T>::value || std::is_array<T>::value>;
|
||||||
|
|
||||||
namespace meta_detail {
|
namespace meta_detail {
|
||||||
template <typename T, typename = void>
|
template <typename T, typename = void>
|
||||||
struct has_internal_marker_impl : std::false_type { };
|
struct has_internal_marker_impl : std::false_type { };
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct has_internal_marker_impl<T, void_t<typename T::SOL_INTERNAL_UNSPECIALIZED_MARKER_>> : std::true_type { };
|
struct has_internal_marker_impl<T, void_t<typename T::SOL_INTERNAL_UNSPECIALIZED_MARKER_>> : std::true_type { };
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using has_internal_marker = has_internal_marker_impl<T>;
|
using has_internal_marker = has_internal_marker_impl<T>;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
constexpr inline bool has_internal_marker_v = has_internal_marker<T>::value;
|
constexpr inline bool has_internal_marker_v = has_internal_marker<T>::value;
|
||||||
} // namespace meta_detail
|
} // namespace meta_detail
|
||||||
|
|
||||||
} // namespace meta
|
} // namespace meta
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_BASE_TRAITS_HPP
|
#endif // SOL_BASE_TRAITS_HPP
|
||||||
|
|
242
extern/sol3/sol/bytecode.hpp
vendored
242
extern/sol3/sol/bytecode.hpp
vendored
|
@ -1,121 +1,121 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_BYTECODE_HPP
|
#ifndef SOL_BYTECODE_HPP
|
||||||
#define SOL_BYTECODE_HPP
|
#define SOL_BYTECODE_HPP
|
||||||
|
|
||||||
#include <sol/compatibility.hpp>
|
#include <sol/compatibility.hpp>
|
||||||
#include <sol/string_view.hpp>
|
#include <sol/string_view.hpp>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
|
|
||||||
template <typename Allocator = std::allocator<std::byte>>
|
template <typename Allocator = std::allocator<std::byte>>
|
||||||
class basic_bytecode : private std::vector<std::byte, Allocator> {
|
class basic_bytecode : private std::vector<std::byte, Allocator> {
|
||||||
private:
|
private:
|
||||||
using base_t = std::vector<std::byte, Allocator>;
|
using base_t = std::vector<std::byte, Allocator>;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
using typename base_t::allocator_type;
|
using typename base_t::allocator_type;
|
||||||
using typename base_t::const_iterator;
|
using typename base_t::const_iterator;
|
||||||
using typename base_t::const_pointer;
|
using typename base_t::const_pointer;
|
||||||
using typename base_t::const_reference;
|
using typename base_t::const_reference;
|
||||||
using typename base_t::const_reverse_iterator;
|
using typename base_t::const_reverse_iterator;
|
||||||
using typename base_t::difference_type;
|
using typename base_t::difference_type;
|
||||||
using typename base_t::iterator;
|
using typename base_t::iterator;
|
||||||
using typename base_t::pointer;
|
using typename base_t::pointer;
|
||||||
using typename base_t::reference;
|
using typename base_t::reference;
|
||||||
using typename base_t::reverse_iterator;
|
using typename base_t::reverse_iterator;
|
||||||
using typename base_t::size_type;
|
using typename base_t::size_type;
|
||||||
using typename base_t::value_type;
|
using typename base_t::value_type;
|
||||||
|
|
||||||
using base_t::base_t;
|
using base_t::base_t;
|
||||||
using base_t::operator=;
|
using base_t::operator=;
|
||||||
|
|
||||||
using base_t::data;
|
using base_t::data;
|
||||||
using base_t::empty;
|
using base_t::empty;
|
||||||
using base_t::max_size;
|
using base_t::max_size;
|
||||||
using base_t::size;
|
using base_t::size;
|
||||||
|
|
||||||
using base_t::at;
|
using base_t::at;
|
||||||
using base_t::operator[];
|
using base_t::operator[];
|
||||||
using base_t::back;
|
using base_t::back;
|
||||||
using base_t::front;
|
using base_t::front;
|
||||||
|
|
||||||
using base_t::begin;
|
using base_t::begin;
|
||||||
using base_t::cbegin;
|
using base_t::cbegin;
|
||||||
using base_t::cend;
|
using base_t::cend;
|
||||||
using base_t::end;
|
using base_t::end;
|
||||||
|
|
||||||
using base_t::crbegin;
|
using base_t::crbegin;
|
||||||
using base_t::crend;
|
using base_t::crend;
|
||||||
using base_t::rbegin;
|
using base_t::rbegin;
|
||||||
using base_t::rend;
|
using base_t::rend;
|
||||||
|
|
||||||
|
|
||||||
using base_t::get_allocator;
|
using base_t::get_allocator;
|
||||||
using base_t::swap;
|
using base_t::swap;
|
||||||
|
|
||||||
using base_t::clear;
|
using base_t::clear;
|
||||||
using base_t::emplace;
|
using base_t::emplace;
|
||||||
using base_t::emplace_back;
|
using base_t::emplace_back;
|
||||||
using base_t::erase;
|
using base_t::erase;
|
||||||
using base_t::insert;
|
using base_t::insert;
|
||||||
using base_t::pop_back;
|
using base_t::pop_back;
|
||||||
using base_t::push_back;
|
using base_t::push_back;
|
||||||
using base_t::reserve;
|
using base_t::reserve;
|
||||||
using base_t::resize;
|
using base_t::resize;
|
||||||
using base_t::shrink_to_fit;
|
using base_t::shrink_to_fit;
|
||||||
|
|
||||||
string_view as_string_view() const {
|
string_view as_string_view() const {
|
||||||
return string_view(reinterpret_cast<const char*>(this->data()), this->size());
|
return string_view(reinterpret_cast<const char*>(this->data()), this->size());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename Container>
|
template <typename Container>
|
||||||
inline int basic_insert_dump_writer(lua_State*, const void* memory, size_t memory_size, void* userdata_pointer) {
|
inline int basic_insert_dump_writer(lua_State*, const void* memory, size_t memory_size, void* userdata_pointer) {
|
||||||
using storage_t = Container;
|
using storage_t = Container;
|
||||||
const std::byte* p_code = static_cast<const std::byte*>(memory);
|
const std::byte* p_code = static_cast<const std::byte*>(memory);
|
||||||
storage_t& bc = *static_cast<storage_t*>(userdata_pointer);
|
storage_t& bc = *static_cast<storage_t*>(userdata_pointer);
|
||||||
#if SOL_IS_OFF(SOL_EXCEPTIONS_I_)
|
#if SOL_IS_OFF(SOL_EXCEPTIONS_I_)
|
||||||
bc.insert(bc.cend(), p_code, p_code + memory_size);
|
bc.insert(bc.cend(), p_code, p_code + memory_size);
|
||||||
#else
|
#else
|
||||||
try {
|
try {
|
||||||
bc.insert(bc.cend(), p_code, p_code + memory_size);
|
bc.insert(bc.cend(), p_code, p_code + memory_size);
|
||||||
}
|
}
|
||||||
catch (...) {
|
catch (...) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
using bytecode = basic_bytecode<>;
|
using bytecode = basic_bytecode<>;
|
||||||
|
|
||||||
constexpr inline auto bytecode_dump_writer = &basic_insert_dump_writer<bytecode>;
|
constexpr inline auto bytecode_dump_writer = &basic_insert_dump_writer<bytecode>;
|
||||||
|
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_BYTECODE_HPP
|
#endif // SOL_BYTECODE_HPP
|
||||||
|
|
1800
extern/sol3/sol/compatibility/compat-5.3.c.h
vendored
1800
extern/sol3/sol/compatibility/compat-5.3.c.h
vendored
File diff suppressed because it is too large
Load diff
848
extern/sol3/sol/compatibility/compat-5.3.h
vendored
848
extern/sol3/sol/compatibility/compat-5.3.h
vendored
|
@ -1,424 +1,424 @@
|
||||||
#ifndef KEPLER_PROJECT_COMPAT53_H_
|
#ifndef KEPLER_PROJECT_COMPAT53_H_
|
||||||
#define KEPLER_PROJECT_COMPAT53_H_
|
#define KEPLER_PROJECT_COMPAT53_H_
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#if defined(__cplusplus) && !defined(COMPAT53_LUA_CPP)
|
#if defined(__cplusplus) && !defined(COMPAT53_LUA_CPP)
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
#include <lua.h>
|
#include <lua.h>
|
||||||
#include <lauxlib.h>
|
#include <lauxlib.h>
|
||||||
#include <lualib.h>
|
#include <lualib.h>
|
||||||
#if defined(__cplusplus) && !defined(COMPAT53_LUA_CPP)
|
#if defined(__cplusplus) && !defined(COMPAT53_LUA_CPP)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef COMPAT53_PREFIX
|
#ifndef COMPAT53_PREFIX
|
||||||
/* we chose this name because many other lua bindings / libs have
|
/* we chose this name because many other lua bindings / libs have
|
||||||
* their own compatibility layer, and that use the compat53 declaration
|
* their own compatibility layer, and that use the compat53 declaration
|
||||||
* frequently, causing all kinds of linker / compiler issues
|
* frequently, causing all kinds of linker / compiler issues
|
||||||
*/
|
*/
|
||||||
# define COMPAT53_PREFIX kp_compat53
|
# define COMPAT53_PREFIX kp_compat53
|
||||||
#endif // COMPAT53_PREFIX
|
#endif // COMPAT53_PREFIX
|
||||||
|
|
||||||
#ifndef COMPAT53_API
|
#ifndef COMPAT53_API
|
||||||
# if defined(COMPAT53_INCLUDE_SOURCE) && COMPAT53_INCLUDE_SOURCE
|
# if defined(COMPAT53_INCLUDE_SOURCE) && COMPAT53_INCLUDE_SOURCE
|
||||||
# if defined(__GNUC__) || defined(__clang__)
|
# if defined(__GNUC__) || defined(__clang__)
|
||||||
# define COMPAT53_API __attribute__((__unused__)) static inline
|
# define COMPAT53_API __attribute__((__unused__)) static inline
|
||||||
# else
|
# else
|
||||||
# define COMPAT53_API static inline
|
# define COMPAT53_API static inline
|
||||||
# endif /* Clang/GCC */
|
# endif /* Clang/GCC */
|
||||||
# else /* COMPAT53_INCLUDE_SOURCE */
|
# else /* COMPAT53_INCLUDE_SOURCE */
|
||||||
/* we are not including source, so everything is extern */
|
/* we are not including source, so everything is extern */
|
||||||
# define COMPAT53_API extern
|
# define COMPAT53_API extern
|
||||||
# endif /* COMPAT53_INCLUDE_SOURCE */
|
# endif /* COMPAT53_INCLUDE_SOURCE */
|
||||||
#endif /* COMPAT53_PREFIX */
|
#endif /* COMPAT53_PREFIX */
|
||||||
|
|
||||||
|
|
||||||
#define COMPAT53_CONCAT_HELPER(a, b) a##b
|
#define COMPAT53_CONCAT_HELPER(a, b) a##b
|
||||||
#define COMPAT53_CONCAT(a, b) COMPAT53_CONCAT_HELPER(a, b)
|
#define COMPAT53_CONCAT(a, b) COMPAT53_CONCAT_HELPER(a, b)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* declarations for Lua 5.1 */
|
/* declarations for Lua 5.1 */
|
||||||
#if defined(LUA_VERSION_NUM) && LUA_VERSION_NUM == 501
|
#if defined(LUA_VERSION_NUM) && LUA_VERSION_NUM == 501
|
||||||
|
|
||||||
/* XXX not implemented:
|
/* XXX not implemented:
|
||||||
* lua_arith (new operators)
|
* lua_arith (new operators)
|
||||||
* lua_upvalueid
|
* lua_upvalueid
|
||||||
* lua_upvaluejoin
|
* lua_upvaluejoin
|
||||||
* lua_version
|
* lua_version
|
||||||
* lua_yieldk
|
* lua_yieldk
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LUA_OK
|
#ifndef LUA_OK
|
||||||
# define LUA_OK 0
|
# define LUA_OK 0
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPADD
|
#ifndef LUA_OPADD
|
||||||
# define LUA_OPADD 0
|
# define LUA_OPADD 0
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPSUB
|
#ifndef LUA_OPSUB
|
||||||
# define LUA_OPSUB 1
|
# define LUA_OPSUB 1
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPMUL
|
#ifndef LUA_OPMUL
|
||||||
# define LUA_OPMUL 2
|
# define LUA_OPMUL 2
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPDIV
|
#ifndef LUA_OPDIV
|
||||||
# define LUA_OPDIV 3
|
# define LUA_OPDIV 3
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPMOD
|
#ifndef LUA_OPMOD
|
||||||
# define LUA_OPMOD 4
|
# define LUA_OPMOD 4
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPPOW
|
#ifndef LUA_OPPOW
|
||||||
# define LUA_OPPOW 5
|
# define LUA_OPPOW 5
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPUNM
|
#ifndef LUA_OPUNM
|
||||||
# define LUA_OPUNM 6
|
# define LUA_OPUNM 6
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPEQ
|
#ifndef LUA_OPEQ
|
||||||
# define LUA_OPEQ 0
|
# define LUA_OPEQ 0
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPLT
|
#ifndef LUA_OPLT
|
||||||
# define LUA_OPLT 1
|
# define LUA_OPLT 1
|
||||||
#endif
|
#endif
|
||||||
#ifndef LUA_OPLE
|
#ifndef LUA_OPLE
|
||||||
# define LUA_OPLE 2
|
# define LUA_OPLE 2
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* LuaJIT/Lua 5.1 does not have the updated
|
/* LuaJIT/Lua 5.1 does not have the updated
|
||||||
* error codes for thread status/function returns (but some patched versions do)
|
* error codes for thread status/function returns (but some patched versions do)
|
||||||
* define it only if it's not found
|
* define it only if it's not found
|
||||||
*/
|
*/
|
||||||
#if !defined(LUA_ERRGCMM)
|
#if !defined(LUA_ERRGCMM)
|
||||||
/* Use + 2 because in some versions of Lua (Lua 5.1)
|
/* Use + 2 because in some versions of Lua (Lua 5.1)
|
||||||
* LUA_ERRFILE is defined as (LUA_ERRERR+1)
|
* LUA_ERRFILE is defined as (LUA_ERRERR+1)
|
||||||
* so we need to avoid it (LuaJIT might have something at this
|
* so we need to avoid it (LuaJIT might have something at this
|
||||||
* integer value too)
|
* integer value too)
|
||||||
*/
|
*/
|
||||||
# define LUA_ERRGCMM (LUA_ERRERR + 2)
|
# define LUA_ERRGCMM (LUA_ERRERR + 2)
|
||||||
#endif /* LUA_ERRGCMM define */
|
#endif /* LUA_ERRGCMM define */
|
||||||
|
|
||||||
#if !defined(MOONJIT_VERSION)
|
#if !defined(MOONJIT_VERSION)
|
||||||
typedef size_t lua_Unsigned;
|
typedef size_t lua_Unsigned;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef struct luaL_Buffer_53 {
|
typedef struct luaL_Buffer_53 {
|
||||||
luaL_Buffer b; /* make incorrect code crash! */
|
luaL_Buffer b; /* make incorrect code crash! */
|
||||||
char *ptr;
|
char *ptr;
|
||||||
size_t nelems;
|
size_t nelems;
|
||||||
size_t capacity;
|
size_t capacity;
|
||||||
lua_State *L2;
|
lua_State *L2;
|
||||||
} luaL_Buffer_53;
|
} luaL_Buffer_53;
|
||||||
#define luaL_Buffer luaL_Buffer_53
|
#define luaL_Buffer luaL_Buffer_53
|
||||||
|
|
||||||
/* In PUC-Rio 5.1, userdata is a simple FILE*
|
/* In PUC-Rio 5.1, userdata is a simple FILE*
|
||||||
* In LuaJIT, it's a struct where the first member is a FILE*
|
* In LuaJIT, it's a struct where the first member is a FILE*
|
||||||
* We can't support the `closef` member
|
* We can't support the `closef` member
|
||||||
*/
|
*/
|
||||||
typedef struct luaL_Stream {
|
typedef struct luaL_Stream {
|
||||||
FILE *f;
|
FILE *f;
|
||||||
} luaL_Stream;
|
} luaL_Stream;
|
||||||
|
|
||||||
#define lua_absindex COMPAT53_CONCAT(COMPAT53_PREFIX, _absindex)
|
#define lua_absindex COMPAT53_CONCAT(COMPAT53_PREFIX, _absindex)
|
||||||
COMPAT53_API int lua_absindex(lua_State *L, int i);
|
COMPAT53_API int lua_absindex(lua_State *L, int i);
|
||||||
|
|
||||||
#define lua_arith COMPAT53_CONCAT(COMPAT53_PREFIX, _arith)
|
#define lua_arith COMPAT53_CONCAT(COMPAT53_PREFIX, _arith)
|
||||||
COMPAT53_API void lua_arith(lua_State *L, int op);
|
COMPAT53_API void lua_arith(lua_State *L, int op);
|
||||||
|
|
||||||
#define lua_compare COMPAT53_CONCAT(COMPAT53_PREFIX, _compare)
|
#define lua_compare COMPAT53_CONCAT(COMPAT53_PREFIX, _compare)
|
||||||
COMPAT53_API int lua_compare(lua_State *L, int idx1, int idx2, int op);
|
COMPAT53_API int lua_compare(lua_State *L, int idx1, int idx2, int op);
|
||||||
|
|
||||||
#define lua_copy COMPAT53_CONCAT(COMPAT53_PREFIX, _copy)
|
#define lua_copy COMPAT53_CONCAT(COMPAT53_PREFIX, _copy)
|
||||||
COMPAT53_API void lua_copy(lua_State *L, int from, int to);
|
COMPAT53_API void lua_copy(lua_State *L, int from, int to);
|
||||||
|
|
||||||
#define lua_getuservalue(L, i) \
|
#define lua_getuservalue(L, i) \
|
||||||
(lua_getfenv((L), (i)), lua_type((L), -1))
|
(lua_getfenv((L), (i)), lua_type((L), -1))
|
||||||
#define lua_setuservalue(L, i) \
|
#define lua_setuservalue(L, i) \
|
||||||
(luaL_checktype((L), -1, LUA_TTABLE), lua_setfenv((L), (i)))
|
(luaL_checktype((L), -1, LUA_TTABLE), lua_setfenv((L), (i)))
|
||||||
|
|
||||||
#define lua_len COMPAT53_CONCAT(COMPAT53_PREFIX, _len)
|
#define lua_len COMPAT53_CONCAT(COMPAT53_PREFIX, _len)
|
||||||
COMPAT53_API void lua_len(lua_State *L, int i);
|
COMPAT53_API void lua_len(lua_State *L, int i);
|
||||||
|
|
||||||
#define lua_pushstring(L, s) \
|
#define lua_pushstring(L, s) \
|
||||||
(lua_pushstring((L), (s)), lua_tostring((L), -1))
|
(lua_pushstring((L), (s)), lua_tostring((L), -1))
|
||||||
|
|
||||||
#define lua_pushlstring(L, s, len) \
|
#define lua_pushlstring(L, s, len) \
|
||||||
((((len) == 0) ? lua_pushlstring((L), "", 0) : lua_pushlstring((L), (s), (len))), lua_tostring((L), -1))
|
((((len) == 0) ? lua_pushlstring((L), "", 0) : lua_pushlstring((L), (s), (len))), lua_tostring((L), -1))
|
||||||
|
|
||||||
#ifndef luaL_newlibtable
|
#ifndef luaL_newlibtable
|
||||||
# define luaL_newlibtable(L, l) \
|
# define luaL_newlibtable(L, l) \
|
||||||
(lua_createtable((L), 0, sizeof((l))/sizeof(*(l))-1))
|
(lua_createtable((L), 0, sizeof((l))/sizeof(*(l))-1))
|
||||||
#endif
|
#endif
|
||||||
#ifndef luaL_newlib
|
#ifndef luaL_newlib
|
||||||
# define luaL_newlib(L, l) \
|
# define luaL_newlib(L, l) \
|
||||||
(luaL_newlibtable((L), (l)), luaL_register((L), NULL, (l)))
|
(luaL_newlibtable((L), (l)), luaL_register((L), NULL, (l)))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef lua_pushglobaltable
|
#ifndef lua_pushglobaltable
|
||||||
# define lua_pushglobaltable(L) \
|
# define lua_pushglobaltable(L) \
|
||||||
lua_pushvalue((L), LUA_GLOBALSINDEX)
|
lua_pushvalue((L), LUA_GLOBALSINDEX)
|
||||||
#endif
|
#endif
|
||||||
#define lua_rawgetp COMPAT53_CONCAT(COMPAT53_PREFIX, _rawgetp)
|
#define lua_rawgetp COMPAT53_CONCAT(COMPAT53_PREFIX, _rawgetp)
|
||||||
COMPAT53_API int lua_rawgetp(lua_State *L, int i, const void *p);
|
COMPAT53_API int lua_rawgetp(lua_State *L, int i, const void *p);
|
||||||
|
|
||||||
#define lua_rawsetp COMPAT53_CONCAT(COMPAT53_PREFIX, _rawsetp)
|
#define lua_rawsetp COMPAT53_CONCAT(COMPAT53_PREFIX, _rawsetp)
|
||||||
COMPAT53_API void lua_rawsetp(lua_State *L, int i, const void *p);
|
COMPAT53_API void lua_rawsetp(lua_State *L, int i, const void *p);
|
||||||
|
|
||||||
#define lua_rawlen(L, i) lua_objlen((L), (i))
|
#define lua_rawlen(L, i) lua_objlen((L), (i))
|
||||||
|
|
||||||
#define lua_tointeger(L, i) lua_tointegerx((L), (i), NULL)
|
#define lua_tointeger(L, i) lua_tointegerx((L), (i), NULL)
|
||||||
|
|
||||||
#define lua_tonumberx COMPAT53_CONCAT(COMPAT53_PREFIX, _tonumberx)
|
#define lua_tonumberx COMPAT53_CONCAT(COMPAT53_PREFIX, _tonumberx)
|
||||||
COMPAT53_API lua_Number lua_tonumberx(lua_State *L, int i, int *isnum);
|
COMPAT53_API lua_Number lua_tonumberx(lua_State *L, int i, int *isnum);
|
||||||
|
|
||||||
#define luaL_checkversion COMPAT53_CONCAT(COMPAT53_PREFIX, L_checkversion)
|
#define luaL_checkversion COMPAT53_CONCAT(COMPAT53_PREFIX, L_checkversion)
|
||||||
COMPAT53_API void luaL_checkversion(lua_State *L);
|
COMPAT53_API void luaL_checkversion(lua_State *L);
|
||||||
|
|
||||||
#define lua_load COMPAT53_CONCAT(COMPAT53_PREFIX, _load_53)
|
#define lua_load COMPAT53_CONCAT(COMPAT53_PREFIX, _load_53)
|
||||||
COMPAT53_API int lua_load(lua_State *L, lua_Reader reader, void *data, const char* source, const char* mode);
|
COMPAT53_API int lua_load(lua_State *L, lua_Reader reader, void *data, const char* source, const char* mode);
|
||||||
|
|
||||||
#define luaL_loadfilex COMPAT53_CONCAT(COMPAT53_PREFIX, L_loadfilex)
|
#define luaL_loadfilex COMPAT53_CONCAT(COMPAT53_PREFIX, L_loadfilex)
|
||||||
COMPAT53_API int luaL_loadfilex(lua_State *L, const char *filename, const char *mode);
|
COMPAT53_API int luaL_loadfilex(lua_State *L, const char *filename, const char *mode);
|
||||||
|
|
||||||
#define luaL_loadbufferx COMPAT53_CONCAT(COMPAT53_PREFIX, L_loadbufferx)
|
#define luaL_loadbufferx COMPAT53_CONCAT(COMPAT53_PREFIX, L_loadbufferx)
|
||||||
COMPAT53_API int luaL_loadbufferx(lua_State *L, const char *buff, size_t sz, const char *name, const char *mode);
|
COMPAT53_API int luaL_loadbufferx(lua_State *L, const char *buff, size_t sz, const char *name, const char *mode);
|
||||||
|
|
||||||
#define luaL_checkstack COMPAT53_CONCAT(COMPAT53_PREFIX, L_checkstack_53)
|
#define luaL_checkstack COMPAT53_CONCAT(COMPAT53_PREFIX, L_checkstack_53)
|
||||||
COMPAT53_API void luaL_checkstack(lua_State *L, int sp, const char *msg);
|
COMPAT53_API void luaL_checkstack(lua_State *L, int sp, const char *msg);
|
||||||
|
|
||||||
#define luaL_getsubtable COMPAT53_CONCAT(COMPAT53_PREFIX, L_getsubtable)
|
#define luaL_getsubtable COMPAT53_CONCAT(COMPAT53_PREFIX, L_getsubtable)
|
||||||
COMPAT53_API int luaL_getsubtable(lua_State* L, int i, const char *name);
|
COMPAT53_API int luaL_getsubtable(lua_State* L, int i, const char *name);
|
||||||
|
|
||||||
#define luaL_len COMPAT53_CONCAT(COMPAT53_PREFIX, L_len)
|
#define luaL_len COMPAT53_CONCAT(COMPAT53_PREFIX, L_len)
|
||||||
COMPAT53_API lua_Integer luaL_len(lua_State *L, int i);
|
COMPAT53_API lua_Integer luaL_len(lua_State *L, int i);
|
||||||
|
|
||||||
#define luaL_setfuncs COMPAT53_CONCAT(COMPAT53_PREFIX, L_setfuncs)
|
#define luaL_setfuncs COMPAT53_CONCAT(COMPAT53_PREFIX, L_setfuncs)
|
||||||
COMPAT53_API void luaL_setfuncs(lua_State *L, const luaL_Reg *l, int nup);
|
COMPAT53_API void luaL_setfuncs(lua_State *L, const luaL_Reg *l, int nup);
|
||||||
|
|
||||||
#define luaL_setmetatable COMPAT53_CONCAT(COMPAT53_PREFIX, L_setmetatable)
|
#define luaL_setmetatable COMPAT53_CONCAT(COMPAT53_PREFIX, L_setmetatable)
|
||||||
COMPAT53_API void luaL_setmetatable(lua_State *L, const char *tname);
|
COMPAT53_API void luaL_setmetatable(lua_State *L, const char *tname);
|
||||||
|
|
||||||
#define luaL_testudata COMPAT53_CONCAT(COMPAT53_PREFIX, L_testudata)
|
#define luaL_testudata COMPAT53_CONCAT(COMPAT53_PREFIX, L_testudata)
|
||||||
COMPAT53_API void *luaL_testudata(lua_State *L, int i, const char *tname);
|
COMPAT53_API void *luaL_testudata(lua_State *L, int i, const char *tname);
|
||||||
|
|
||||||
#define luaL_traceback COMPAT53_CONCAT(COMPAT53_PREFIX, L_traceback)
|
#define luaL_traceback COMPAT53_CONCAT(COMPAT53_PREFIX, L_traceback)
|
||||||
COMPAT53_API void luaL_traceback(lua_State *L, lua_State *L1, const char *msg, int level);
|
COMPAT53_API void luaL_traceback(lua_State *L, lua_State *L1, const char *msg, int level);
|
||||||
|
|
||||||
#define luaL_fileresult COMPAT53_CONCAT(COMPAT53_PREFIX, L_fileresult)
|
#define luaL_fileresult COMPAT53_CONCAT(COMPAT53_PREFIX, L_fileresult)
|
||||||
COMPAT53_API int luaL_fileresult(lua_State *L, int stat, const char *fname);
|
COMPAT53_API int luaL_fileresult(lua_State *L, int stat, const char *fname);
|
||||||
|
|
||||||
#define luaL_execresult COMPAT53_CONCAT(COMPAT53_PREFIX, L_execresult)
|
#define luaL_execresult COMPAT53_CONCAT(COMPAT53_PREFIX, L_execresult)
|
||||||
COMPAT53_API int luaL_execresult(lua_State *L, int stat);
|
COMPAT53_API int luaL_execresult(lua_State *L, int stat);
|
||||||
|
|
||||||
#define lua_callk(L, na, nr, ctx, cont) \
|
#define lua_callk(L, na, nr, ctx, cont) \
|
||||||
((void)(ctx), (void)(cont), lua_call((L), (na), (nr)))
|
((void)(ctx), (void)(cont), lua_call((L), (na), (nr)))
|
||||||
#define lua_pcallk(L, na, nr, err, ctx, cont) \
|
#define lua_pcallk(L, na, nr, err, ctx, cont) \
|
||||||
((void)(ctx), (void)(cont), lua_pcall((L), (na), (nr), (err)))
|
((void)(ctx), (void)(cont), lua_pcall((L), (na), (nr), (err)))
|
||||||
|
|
||||||
#define lua_resume(L, from, nargs) \
|
#define lua_resume(L, from, nargs) \
|
||||||
((void)(from), lua_resume((L), (nargs)))
|
((void)(from), lua_resume((L), (nargs)))
|
||||||
|
|
||||||
#define luaL_buffinit COMPAT53_CONCAT(COMPAT53_PREFIX, _buffinit_53)
|
#define luaL_buffinit COMPAT53_CONCAT(COMPAT53_PREFIX, _buffinit_53)
|
||||||
COMPAT53_API void luaL_buffinit(lua_State *L, luaL_Buffer_53 *B);
|
COMPAT53_API void luaL_buffinit(lua_State *L, luaL_Buffer_53 *B);
|
||||||
|
|
||||||
#define luaL_prepbuffsize COMPAT53_CONCAT(COMPAT53_PREFIX, _prepbufsize_53)
|
#define luaL_prepbuffsize COMPAT53_CONCAT(COMPAT53_PREFIX, _prepbufsize_53)
|
||||||
COMPAT53_API char *luaL_prepbuffsize(luaL_Buffer_53 *B, size_t s);
|
COMPAT53_API char *luaL_prepbuffsize(luaL_Buffer_53 *B, size_t s);
|
||||||
|
|
||||||
#define luaL_addlstring COMPAT53_CONCAT(COMPAT53_PREFIX, _addlstring_53)
|
#define luaL_addlstring COMPAT53_CONCAT(COMPAT53_PREFIX, _addlstring_53)
|
||||||
COMPAT53_API void luaL_addlstring(luaL_Buffer_53 *B, const char *s, size_t l);
|
COMPAT53_API void luaL_addlstring(luaL_Buffer_53 *B, const char *s, size_t l);
|
||||||
|
|
||||||
#define luaL_addvalue COMPAT53_CONCAT(COMPAT53_PREFIX, _addvalue_53)
|
#define luaL_addvalue COMPAT53_CONCAT(COMPAT53_PREFIX, _addvalue_53)
|
||||||
COMPAT53_API void luaL_addvalue(luaL_Buffer_53 *B);
|
COMPAT53_API void luaL_addvalue(luaL_Buffer_53 *B);
|
||||||
|
|
||||||
#define luaL_pushresult COMPAT53_CONCAT(COMPAT53_PREFIX, _pushresult_53)
|
#define luaL_pushresult COMPAT53_CONCAT(COMPAT53_PREFIX, _pushresult_53)
|
||||||
COMPAT53_API void luaL_pushresult(luaL_Buffer_53 *B);
|
COMPAT53_API void luaL_pushresult(luaL_Buffer_53 *B);
|
||||||
|
|
||||||
#undef luaL_buffinitsize
|
#undef luaL_buffinitsize
|
||||||
#define luaL_buffinitsize(L, B, s) \
|
#define luaL_buffinitsize(L, B, s) \
|
||||||
(luaL_buffinit((L), (B)), luaL_prepbuffsize((B), (s)))
|
(luaL_buffinit((L), (B)), luaL_prepbuffsize((B), (s)))
|
||||||
|
|
||||||
#undef luaL_prepbuffer
|
#undef luaL_prepbuffer
|
||||||
#define luaL_prepbuffer(B) \
|
#define luaL_prepbuffer(B) \
|
||||||
luaL_prepbuffsize((B), LUAL_BUFFERSIZE)
|
luaL_prepbuffsize((B), LUAL_BUFFERSIZE)
|
||||||
|
|
||||||
#undef luaL_addchar
|
#undef luaL_addchar
|
||||||
#define luaL_addchar(B, c) \
|
#define luaL_addchar(B, c) \
|
||||||
((void)((B)->nelems < (B)->capacity || luaL_prepbuffsize((B), 1)), \
|
((void)((B)->nelems < (B)->capacity || luaL_prepbuffsize((B), 1)), \
|
||||||
((B)->ptr[(B)->nelems++] = (c)))
|
((B)->ptr[(B)->nelems++] = (c)))
|
||||||
|
|
||||||
#undef luaL_addsize
|
#undef luaL_addsize
|
||||||
#define luaL_addsize(B, s) \
|
#define luaL_addsize(B, s) \
|
||||||
((B)->nelems += (s))
|
((B)->nelems += (s))
|
||||||
|
|
||||||
#undef luaL_addstring
|
#undef luaL_addstring
|
||||||
#define luaL_addstring(B, s) \
|
#define luaL_addstring(B, s) \
|
||||||
luaL_addlstring((B), (s), strlen((s)))
|
luaL_addlstring((B), (s), strlen((s)))
|
||||||
|
|
||||||
#undef luaL_pushresultsize
|
#undef luaL_pushresultsize
|
||||||
#define luaL_pushresultsize(B, s) \
|
#define luaL_pushresultsize(B, s) \
|
||||||
(luaL_addsize((B), (s)), luaL_pushresult((B)))
|
(luaL_addsize((B), (s)), luaL_pushresult((B)))
|
||||||
|
|
||||||
#if defined(LUA_COMPAT_APIINTCASTS)
|
#if defined(LUA_COMPAT_APIINTCASTS)
|
||||||
#define lua_pushunsigned(L, n) \
|
#define lua_pushunsigned(L, n) \
|
||||||
lua_pushinteger((L), (lua_Integer)(n))
|
lua_pushinteger((L), (lua_Integer)(n))
|
||||||
#define lua_tounsignedx(L, i, is) \
|
#define lua_tounsignedx(L, i, is) \
|
||||||
((lua_Unsigned)lua_tointegerx((L), (i), (is)))
|
((lua_Unsigned)lua_tointegerx((L), (i), (is)))
|
||||||
#define lua_tounsigned(L, i) \
|
#define lua_tounsigned(L, i) \
|
||||||
lua_tounsignedx((L), (i), NULL)
|
lua_tounsignedx((L), (i), NULL)
|
||||||
#define luaL_checkunsigned(L, a) \
|
#define luaL_checkunsigned(L, a) \
|
||||||
((lua_Unsigned)luaL_checkinteger((L), (a)))
|
((lua_Unsigned)luaL_checkinteger((L), (a)))
|
||||||
#define luaL_optunsigned(L, a, d) \
|
#define luaL_optunsigned(L, a, d) \
|
||||||
((lua_Unsigned)luaL_optinteger((L), (a), (lua_Integer)(d)))
|
((lua_Unsigned)luaL_optinteger((L), (a), (lua_Integer)(d)))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* Lua 5.1 only */
|
#endif /* Lua 5.1 only */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* declarations for Lua 5.1 and 5.2 */
|
/* declarations for Lua 5.1 and 5.2 */
|
||||||
#if defined(LUA_VERSION_NUM) && LUA_VERSION_NUM <= 502
|
#if defined(LUA_VERSION_NUM) && LUA_VERSION_NUM <= 502
|
||||||
|
|
||||||
typedef int lua_KContext;
|
typedef int lua_KContext;
|
||||||
|
|
||||||
typedef int(*lua_KFunction)(lua_State *L, int status, lua_KContext ctx);
|
typedef int(*lua_KFunction)(lua_State *L, int status, lua_KContext ctx);
|
||||||
|
|
||||||
#define lua_dump(L, w, d, s) \
|
#define lua_dump(L, w, d, s) \
|
||||||
((void)(s), lua_dump((L), (w), (d)))
|
((void)(s), lua_dump((L), (w), (d)))
|
||||||
|
|
||||||
#define lua_getfield(L, i, k) \
|
#define lua_getfield(L, i, k) \
|
||||||
(lua_getfield((L), (i), (k)), lua_type((L), -1))
|
(lua_getfield((L), (i), (k)), lua_type((L), -1))
|
||||||
|
|
||||||
#define lua_gettable(L, i) \
|
#define lua_gettable(L, i) \
|
||||||
(lua_gettable((L), (i)), lua_type((L), -1))
|
(lua_gettable((L), (i)), lua_type((L), -1))
|
||||||
|
|
||||||
#define lua_geti COMPAT53_CONCAT(COMPAT53_PREFIX, _geti)
|
#define lua_geti COMPAT53_CONCAT(COMPAT53_PREFIX, _geti)
|
||||||
COMPAT53_API int lua_geti(lua_State *L, int index, lua_Integer i);
|
COMPAT53_API int lua_geti(lua_State *L, int index, lua_Integer i);
|
||||||
|
|
||||||
#define lua_isinteger COMPAT53_CONCAT(COMPAT53_PREFIX, _isinteger)
|
#define lua_isinteger COMPAT53_CONCAT(COMPAT53_PREFIX, _isinteger)
|
||||||
COMPAT53_API int lua_isinteger(lua_State *L, int index);
|
COMPAT53_API int lua_isinteger(lua_State *L, int index);
|
||||||
|
|
||||||
#define lua_tointegerx COMPAT53_CONCAT(COMPAT53_PREFIX, _tointegerx_53)
|
#define lua_tointegerx COMPAT53_CONCAT(COMPAT53_PREFIX, _tointegerx_53)
|
||||||
COMPAT53_API lua_Integer lua_tointegerx(lua_State *L, int i, int *isnum);
|
COMPAT53_API lua_Integer lua_tointegerx(lua_State *L, int i, int *isnum);
|
||||||
|
|
||||||
#define lua_numbertointeger(n, p) \
|
#define lua_numbertointeger(n, p) \
|
||||||
((*(p) = (lua_Integer)(n)), 1)
|
((*(p) = (lua_Integer)(n)), 1)
|
||||||
|
|
||||||
#define lua_rawget(L, i) \
|
#define lua_rawget(L, i) \
|
||||||
(lua_rawget((L), (i)), lua_type((L), -1))
|
(lua_rawget((L), (i)), lua_type((L), -1))
|
||||||
|
|
||||||
#define lua_rawgeti(L, i, n) \
|
#define lua_rawgeti(L, i, n) \
|
||||||
(lua_rawgeti((L), (i), (n)), lua_type((L), -1))
|
(lua_rawgeti((L), (i), (n)), lua_type((L), -1))
|
||||||
|
|
||||||
#define lua_rotate COMPAT53_CONCAT(COMPAT53_PREFIX, _rotate)
|
#define lua_rotate COMPAT53_CONCAT(COMPAT53_PREFIX, _rotate)
|
||||||
COMPAT53_API void lua_rotate(lua_State *L, int idx, int n);
|
COMPAT53_API void lua_rotate(lua_State *L, int idx, int n);
|
||||||
|
|
||||||
#define lua_seti COMPAT53_CONCAT(COMPAT53_PREFIX, _seti)
|
#define lua_seti COMPAT53_CONCAT(COMPAT53_PREFIX, _seti)
|
||||||
COMPAT53_API void lua_seti(lua_State *L, int index, lua_Integer i);
|
COMPAT53_API void lua_seti(lua_State *L, int index, lua_Integer i);
|
||||||
|
|
||||||
#define lua_stringtonumber COMPAT53_CONCAT(COMPAT53_PREFIX, _stringtonumber)
|
#define lua_stringtonumber COMPAT53_CONCAT(COMPAT53_PREFIX, _stringtonumber)
|
||||||
COMPAT53_API size_t lua_stringtonumber(lua_State *L, const char *s);
|
COMPAT53_API size_t lua_stringtonumber(lua_State *L, const char *s);
|
||||||
|
|
||||||
#define luaL_tolstring COMPAT53_CONCAT(COMPAT53_PREFIX, L_tolstring)
|
#define luaL_tolstring COMPAT53_CONCAT(COMPAT53_PREFIX, L_tolstring)
|
||||||
COMPAT53_API const char *luaL_tolstring(lua_State *L, int idx, size_t *len);
|
COMPAT53_API const char *luaL_tolstring(lua_State *L, int idx, size_t *len);
|
||||||
|
|
||||||
#define luaL_getmetafield(L, o, e) \
|
#define luaL_getmetafield(L, o, e) \
|
||||||
(luaL_getmetafield((L), (o), (e)) ? lua_type((L), -1) : LUA_TNIL)
|
(luaL_getmetafield((L), (o), (e)) ? lua_type((L), -1) : LUA_TNIL)
|
||||||
|
|
||||||
#define luaL_newmetatable(L, tn) \
|
#define luaL_newmetatable(L, tn) \
|
||||||
(luaL_newmetatable((L), (tn)) ? (lua_pushstring((L), (tn)), lua_setfield((L), -2, "__name"), 1) : 0)
|
(luaL_newmetatable((L), (tn)) ? (lua_pushstring((L), (tn)), lua_setfield((L), -2, "__name"), 1) : 0)
|
||||||
|
|
||||||
#define luaL_requiref COMPAT53_CONCAT(COMPAT53_PREFIX, L_requiref_53)
|
#define luaL_requiref COMPAT53_CONCAT(COMPAT53_PREFIX, L_requiref_53)
|
||||||
COMPAT53_API void luaL_requiref(lua_State *L, const char *modname,
|
COMPAT53_API void luaL_requiref(lua_State *L, const char *modname,
|
||||||
lua_CFunction openf, int glb);
|
lua_CFunction openf, int glb);
|
||||||
|
|
||||||
#endif /* Lua 5.1 and Lua 5.2 */
|
#endif /* Lua 5.1 and Lua 5.2 */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* declarations for Lua 5.2 */
|
/* declarations for Lua 5.2 */
|
||||||
#if defined(LUA_VERSION_NUM) && LUA_VERSION_NUM == 502
|
#if defined(LUA_VERSION_NUM) && LUA_VERSION_NUM == 502
|
||||||
|
|
||||||
/* XXX not implemented:
|
/* XXX not implemented:
|
||||||
* lua_isyieldable
|
* lua_isyieldable
|
||||||
* lua_getextraspace
|
* lua_getextraspace
|
||||||
* lua_arith (new operators)
|
* lua_arith (new operators)
|
||||||
* lua_pushfstring (new formats)
|
* lua_pushfstring (new formats)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define lua_getglobal(L, n) \
|
#define lua_getglobal(L, n) \
|
||||||
(lua_getglobal((L), (n)), lua_type((L), -1))
|
(lua_getglobal((L), (n)), lua_type((L), -1))
|
||||||
|
|
||||||
#define lua_getuservalue(L, i) \
|
#define lua_getuservalue(L, i) \
|
||||||
(lua_getuservalue((L), (i)), lua_type((L), -1))
|
(lua_getuservalue((L), (i)), lua_type((L), -1))
|
||||||
|
|
||||||
#define lua_pushlstring(L, s, len) \
|
#define lua_pushlstring(L, s, len) \
|
||||||
(((len) == 0) ? lua_pushlstring((L), "", 0) : lua_pushlstring((L), (s), (len)))
|
(((len) == 0) ? lua_pushlstring((L), "", 0) : lua_pushlstring((L), (s), (len)))
|
||||||
|
|
||||||
#define lua_rawgetp(L, i, p) \
|
#define lua_rawgetp(L, i, p) \
|
||||||
(lua_rawgetp((L), (i), (p)), lua_type((L), -1))
|
(lua_rawgetp((L), (i), (p)), lua_type((L), -1))
|
||||||
|
|
||||||
#define LUA_KFUNCTION(_name) \
|
#define LUA_KFUNCTION(_name) \
|
||||||
static int (_name)(lua_State *L, int status, lua_KContext ctx); \
|
static int (_name)(lua_State *L, int status, lua_KContext ctx); \
|
||||||
static int (_name ## _52)(lua_State *L) { \
|
static int (_name ## _52)(lua_State *L) { \
|
||||||
lua_KContext ctx; \
|
lua_KContext ctx; \
|
||||||
int status = lua_getctx(L, &ctx); \
|
int status = lua_getctx(L, &ctx); \
|
||||||
return (_name)(L, status, ctx); \
|
return (_name)(L, status, ctx); \
|
||||||
} \
|
} \
|
||||||
static int (_name)(lua_State *L, int status, lua_KContext ctx)
|
static int (_name)(lua_State *L, int status, lua_KContext ctx)
|
||||||
|
|
||||||
#define lua_pcallk(L, na, nr, err, ctx, cont) \
|
#define lua_pcallk(L, na, nr, err, ctx, cont) \
|
||||||
lua_pcallk((L), (na), (nr), (err), (ctx), cont ## _52)
|
lua_pcallk((L), (na), (nr), (err), (ctx), cont ## _52)
|
||||||
|
|
||||||
#define lua_callk(L, na, nr, ctx, cont) \
|
#define lua_callk(L, na, nr, ctx, cont) \
|
||||||
lua_callk((L), (na), (nr), (ctx), cont ## _52)
|
lua_callk((L), (na), (nr), (ctx), cont ## _52)
|
||||||
|
|
||||||
#define lua_yieldk(L, nr, ctx, cont) \
|
#define lua_yieldk(L, nr, ctx, cont) \
|
||||||
lua_yieldk((L), (nr), (ctx), cont ## _52)
|
lua_yieldk((L), (nr), (ctx), cont ## _52)
|
||||||
|
|
||||||
#ifdef lua_call
|
#ifdef lua_call
|
||||||
# undef lua_call
|
# undef lua_call
|
||||||
# define lua_call(L, na, nr) \
|
# define lua_call(L, na, nr) \
|
||||||
(lua_callk)((L), (na), (nr), 0, NULL)
|
(lua_callk)((L), (na), (nr), 0, NULL)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef lua_pcall
|
#ifdef lua_pcall
|
||||||
# undef lua_pcall
|
# undef lua_pcall
|
||||||
# define lua_pcall(L, na, nr, err) \
|
# define lua_pcall(L, na, nr, err) \
|
||||||
(lua_pcallk)((L), (na), (nr), (err), 0, NULL)
|
(lua_pcallk)((L), (na), (nr), (err), 0, NULL)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef lua_yield
|
#ifdef lua_yield
|
||||||
# undef lua_yield
|
# undef lua_yield
|
||||||
# define lua_yield(L, nr) \
|
# define lua_yield(L, nr) \
|
||||||
(lua_yieldk)((L), (nr), 0, NULL)
|
(lua_yieldk)((L), (nr), 0, NULL)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* Lua 5.2 only */
|
#endif /* Lua 5.2 only */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* other Lua versions */
|
/* other Lua versions */
|
||||||
#if !defined(LUA_VERSION_NUM) || LUA_VERSION_NUM < 501 || LUA_VERSION_NUM > 504
|
#if !defined(LUA_VERSION_NUM) || LUA_VERSION_NUM < 501 || LUA_VERSION_NUM > 504
|
||||||
|
|
||||||
# error "unsupported Lua version (i.e. not Lua 5.1, 5.2, 5.3, or 5.4)"
|
# error "unsupported Lua version (i.e. not Lua 5.1, 5.2, 5.3, or 5.4)"
|
||||||
|
|
||||||
#endif /* other Lua versions except 5.1, 5.2, 5.3, and 5.4 */
|
#endif /* other Lua versions except 5.1, 5.2, 5.3, and 5.4 */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* helper macro for defining continuation functions (for every version
|
/* helper macro for defining continuation functions (for every version
|
||||||
* *except* Lua 5.2) */
|
* *except* Lua 5.2) */
|
||||||
#ifndef LUA_KFUNCTION
|
#ifndef LUA_KFUNCTION
|
||||||
#define LUA_KFUNCTION(_name) \
|
#define LUA_KFUNCTION(_name) \
|
||||||
static int (_name)(lua_State *L, int status, lua_KContext ctx)
|
static int (_name)(lua_State *L, int status, lua_KContext ctx)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#if defined(COMPAT53_INCLUDE_SOURCE) && COMPAT53_INCLUDE_SOURCE == 1
|
#if defined(COMPAT53_INCLUDE_SOURCE) && COMPAT53_INCLUDE_SOURCE == 1
|
||||||
# include "compat-5.3.c.h"
|
# include "compat-5.3.c.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#endif /* KEPLER_PROJECT_COMPAT53_H_ */
|
#endif /* KEPLER_PROJECT_COMPAT53_H_ */
|
||||||
|
|
||||||
|
|
48
extern/sol3/sol/compatibility/compat-5.4.h
vendored
48
extern/sol3/sol/compatibility/compat-5.4.h
vendored
|
@ -1,25 +1,25 @@
|
||||||
#ifndef NOT_KEPLER_PROJECT_COMPAT54_H_
|
#ifndef NOT_KEPLER_PROJECT_COMPAT54_H_
|
||||||
#define NOT_KEPLER_PROJECT_COMPAT54_H_
|
#define NOT_KEPLER_PROJECT_COMPAT54_H_
|
||||||
|
|
||||||
#if defined(__cplusplus) && !defined(COMPAT53_LUA_CPP)
|
#if defined(__cplusplus) && !defined(COMPAT53_LUA_CPP)
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
#include <lua.h>
|
#include <lua.h>
|
||||||
#include <lauxlib.h>
|
#include <lauxlib.h>
|
||||||
#include <lualib.h>
|
#include <lualib.h>
|
||||||
#if defined(__cplusplus) && !defined(COMPAT53_LUA_CPP)
|
#if defined(__cplusplus) && !defined(COMPAT53_LUA_CPP)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(LUA_VERSION_NUM) && LUA_VERSION_NUM == 504
|
#if defined(LUA_VERSION_NUM) && LUA_VERSION_NUM == 504
|
||||||
|
|
||||||
#if !defined(LUA_ERRGCMM)
|
#if !defined(LUA_ERRGCMM)
|
||||||
/* So Lua 5.4 actually removes this, which breaks sol2...
|
/* So Lua 5.4 actually removes this, which breaks sol2...
|
||||||
man, this API is quite unstable...!
|
man, this API is quite unstable...!
|
||||||
*/
|
*/
|
||||||
# define LUA_ERRGCMM (LUA_ERRERR + 2)
|
# define LUA_ERRGCMM (LUA_ERRERR + 2)
|
||||||
#endif /* LUA_ERRGCMM define */
|
#endif /* LUA_ERRGCMM define */
|
||||||
|
|
||||||
#endif // Lua 5.4 only
|
#endif // Lua 5.4 only
|
||||||
|
|
||||||
#endif // NOT_KEPLER_PROJECT_COMPAT54_H_
|
#endif // NOT_KEPLER_PROJECT_COMPAT54_H_
|
104
extern/sol3/sol/debug.hpp
vendored
104
extern/sol3/sol/debug.hpp
vendored
|
@ -1,52 +1,52 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_DEBUG_HPP
|
#ifndef SOL_DEBUG_HPP
|
||||||
#define SOL_DEBUG_HPP
|
#define SOL_DEBUG_HPP
|
||||||
|
|
||||||
#include <sol/stack.hpp>
|
#include <sol/stack.hpp>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
namespace sol { namespace detail { namespace debug {
|
namespace sol { namespace detail { namespace debug {
|
||||||
inline std::string dump_types(lua_State* L) {
|
inline std::string dump_types(lua_State* L) {
|
||||||
std::string visual;
|
std::string visual;
|
||||||
std::size_t size = lua_gettop(L) + 1;
|
std::size_t size = lua_gettop(L) + 1;
|
||||||
for (std::size_t i = 1; i < size; ++i) {
|
for (std::size_t i = 1; i < size; ++i) {
|
||||||
if (i != 1) {
|
if (i != 1) {
|
||||||
visual += " | ";
|
visual += " | ";
|
||||||
}
|
}
|
||||||
visual += type_name(L, stack::get<type>(L, static_cast<int>(i)));
|
visual += type_name(L, stack::get<type>(L, static_cast<int>(i)));
|
||||||
}
|
}
|
||||||
return visual;
|
return visual;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void print_stack(lua_State* L) {
|
inline void print_stack(lua_State* L) {
|
||||||
std::cout << dump_types(L) << std::endl;
|
std::cout << dump_types(L) << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void print_section(const std::string& message, lua_State* L) {
|
inline void print_section(const std::string& message, lua_State* L) {
|
||||||
std::cout << "-- " << message << " -- [ " << dump_types(L) << " ]" << std::endl;
|
std::cout << "-- " << message << " -- [ " << dump_types(L) << " ]" << std::endl;
|
||||||
}
|
}
|
||||||
}}} // namespace sol::detail::debug
|
}}} // namespace sol::detail::debug
|
||||||
|
|
||||||
#endif // SOL_DEBUG_HPP
|
#endif // SOL_DEBUG_HPP
|
||||||
|
|
88
extern/sol3/sol/deprecate.hpp
vendored
88
extern/sol3/sol/deprecate.hpp
vendored
|
@ -1,44 +1,44 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_DEPRECATE_HPP
|
#ifndef SOL_DEPRECATE_HPP
|
||||||
#define SOL_DEPRECATE_HPP
|
#define SOL_DEPRECATE_HPP
|
||||||
|
|
||||||
#ifndef SOL_DEPRECATED
|
#ifndef SOL_DEPRECATED
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
#define SOL_DEPRECATED __declspec(deprecated)
|
#define SOL_DEPRECATED __declspec(deprecated)
|
||||||
#elif __GNUC__
|
#elif __GNUC__
|
||||||
#define SOL_DEPRECATED __attribute__((deprecated))
|
#define SOL_DEPRECATED __attribute__((deprecated))
|
||||||
#else
|
#else
|
||||||
#define SOL_DEPRECATED [[deprecated]]
|
#define SOL_DEPRECATED [[deprecated]]
|
||||||
#endif // compilers
|
#endif // compilers
|
||||||
#endif // SOL_DEPRECATED
|
#endif // SOL_DEPRECATED
|
||||||
|
|
||||||
namespace sol { namespace detail {
|
namespace sol { namespace detail {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct SOL_DEPRECATED deprecate_type {
|
struct SOL_DEPRECATED deprecate_type {
|
||||||
using type = T;
|
using type = T;
|
||||||
};
|
};
|
||||||
}} // namespace sol::detail
|
}} // namespace sol::detail
|
||||||
|
|
||||||
#endif // SOL_DEPRECATE_HPP
|
#endif // SOL_DEPRECATE_HPP
|
||||||
|
|
464
extern/sol3/sol/detail/build_version.hpp
vendored
464
extern/sol3/sol/detail/build_version.hpp
vendored
|
@ -1,232 +1,232 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#ifndef SOL_DETAIL_BUILD_VERSION_HPP
|
#ifndef SOL_DETAIL_BUILD_VERSION_HPP
|
||||||
#define SOL_DETAIL_BUILD_VERSION_HPP
|
#define SOL_DETAIL_BUILD_VERSION_HPP
|
||||||
|
|
||||||
#include <sol/version.hpp>
|
#include <sol/version.hpp>
|
||||||
|
|
||||||
// clang-format off
|
// clang-format off
|
||||||
|
|
||||||
#if defined(SOL_DLL)
|
#if defined(SOL_DLL)
|
||||||
#if (SOL_DLL != 0)
|
#if (SOL_DLL != 0)
|
||||||
#define SOL_DLL_I_ SOL_ON
|
#define SOL_DLL_I_ SOL_ON
|
||||||
#else
|
#else
|
||||||
#define SOL_DLL_I_ SOL_OFF
|
#define SOL_DLL_I_ SOL_OFF
|
||||||
#endif
|
#endif
|
||||||
#elif SOL_IS_ON(SOL_COMPILER_VCXX_I_) && (defined(DLL_) || defined(_DLL))
|
#elif SOL_IS_ON(SOL_COMPILER_VCXX_I_) && (defined(DLL_) || defined(_DLL))
|
||||||
#define SOL_DLL_I_ SOL_DEFAULT_ON
|
#define SOL_DLL_I_ SOL_DEFAULT_ON
|
||||||
#else
|
#else
|
||||||
#define SOL_DLL_I_ SOL_DEFAULT_OFF
|
#define SOL_DLL_I_ SOL_DEFAULT_OFF
|
||||||
#endif // DLL definition
|
#endif // DLL definition
|
||||||
|
|
||||||
#if defined(SOL_HEADER_ONLY)
|
#if defined(SOL_HEADER_ONLY)
|
||||||
#if (SOL_HEADER_ONLY != 0)
|
#if (SOL_HEADER_ONLY != 0)
|
||||||
#define SOL_HEADER_ONLY_I_ SOL_ON
|
#define SOL_HEADER_ONLY_I_ SOL_ON
|
||||||
#else
|
#else
|
||||||
#define SOL_HEADER_ONLY_I_ SOL_OFF
|
#define SOL_HEADER_ONLY_I_ SOL_OFF
|
||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
#define SOL_HEADER_ONLY_I_ SOL_DEFAULT_OFF
|
#define SOL_HEADER_ONLY_I_ SOL_DEFAULT_OFF
|
||||||
#endif // Header only library
|
#endif // Header only library
|
||||||
|
|
||||||
#if defined(SOL_BUILD)
|
#if defined(SOL_BUILD)
|
||||||
#if (SOL_BUILD != 0)
|
#if (SOL_BUILD != 0)
|
||||||
#define SOL_BUILD_I_ SOL_ON
|
#define SOL_BUILD_I_ SOL_ON
|
||||||
#else
|
#else
|
||||||
#define SOL_BUILD_I_ SOL_OFF
|
#define SOL_BUILD_I_ SOL_OFF
|
||||||
#endif
|
#endif
|
||||||
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
||||||
#define SOL_BUILD_I_ SOL_DEFAULT_OFF
|
#define SOL_BUILD_I_ SOL_DEFAULT_OFF
|
||||||
#else
|
#else
|
||||||
#define SOL_BUILD_I_ SOL_DEFAULT_ON
|
#define SOL_BUILD_I_ SOL_DEFAULT_ON
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(SOL_UNITY_BUILD)
|
#if defined(SOL_UNITY_BUILD)
|
||||||
#if (SOL_UNITY_BUILD != 0)
|
#if (SOL_UNITY_BUILD != 0)
|
||||||
#define SOL_UNITY_BUILD_I_ SOL_ON
|
#define SOL_UNITY_BUILD_I_ SOL_ON
|
||||||
#else
|
#else
|
||||||
#define SOL_UNITY_BUILD_I_ SOL_OFF
|
#define SOL_UNITY_BUILD_I_ SOL_OFF
|
||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
#define SOL_UNITY_BUILD_I_ SOL_DEFAULT_OFF
|
#define SOL_UNITY_BUILD_I_ SOL_DEFAULT_OFF
|
||||||
#endif // Header only library
|
#endif // Header only library
|
||||||
|
|
||||||
#if defined(SOL_C_FUNCTION_LINKAGE)
|
#if defined(SOL_C_FUNCTION_LINKAGE)
|
||||||
#define SOL_C_FUNCTION_LINKAGE_I_ SOL_C_FUNCTION_LINKAGE
|
#define SOL_C_FUNCTION_LINKAGE_I_ SOL_C_FUNCTION_LINKAGE
|
||||||
#else
|
#else
|
||||||
#if SOL_IS_ON(SOL_BUILD_CXX_MODE_I_)
|
#if SOL_IS_ON(SOL_BUILD_CXX_MODE_I_)
|
||||||
// C++
|
// C++
|
||||||
#define SOL_C_FUNCTION_LINKAGE_I_ extern "C"
|
#define SOL_C_FUNCTION_LINKAGE_I_ extern "C"
|
||||||
#else
|
#else
|
||||||
// normal
|
// normal
|
||||||
#define SOL_C_FUNCTION_LINKAGE_I_
|
#define SOL_C_FUNCTION_LINKAGE_I_
|
||||||
#endif // C++ or not
|
#endif // C++ or not
|
||||||
#endif // Linkage specification for C functions
|
#endif // Linkage specification for C functions
|
||||||
|
|
||||||
#if defined(SOL_API_LINKAGE)
|
#if defined(SOL_API_LINKAGE)
|
||||||
#define SOL_API_LINKAGE_I_ SOL_API_LINKAGE
|
#define SOL_API_LINKAGE_I_ SOL_API_LINKAGE
|
||||||
#else
|
#else
|
||||||
#if SOL_IS_ON(SOL_DLL_I_)
|
#if SOL_IS_ON(SOL_DLL_I_)
|
||||||
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_) || SOL_IS_ON(SOL_PLATFORM_WINDOWS_I_) || SOL_IS_ON(SOL_PLATFORM_CYGWIN_I_)
|
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_) || SOL_IS_ON(SOL_PLATFORM_WINDOWS_I_) || SOL_IS_ON(SOL_PLATFORM_CYGWIN_I_)
|
||||||
// MSVC Compiler; or, Windows, or Cygwin platforms
|
// MSVC Compiler; or, Windows, or Cygwin platforms
|
||||||
#if SOL_IS_ON(SOL_BUILD_I_)
|
#if SOL_IS_ON(SOL_BUILD_I_)
|
||||||
// Building the library
|
// Building the library
|
||||||
#if SOL_IS_ON(SOL_COMPILER_GCC_I_)
|
#if SOL_IS_ON(SOL_COMPILER_GCC_I_)
|
||||||
// Using GCC
|
// Using GCC
|
||||||
#define SOL_API_LINKAGE_I_ __attribute__((dllexport))
|
#define SOL_API_LINKAGE_I_ __attribute__((dllexport))
|
||||||
#else
|
#else
|
||||||
// Using Clang, MSVC, etc...
|
// Using Clang, MSVC, etc...
|
||||||
#define SOL_API_LINKAGE_I_ __declspec(dllexport)
|
#define SOL_API_LINKAGE_I_ __declspec(dllexport)
|
||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
#if SOL_IS_ON(SOL_COMPILER_GCC_I_)
|
#if SOL_IS_ON(SOL_COMPILER_GCC_I_)
|
||||||
#define SOL_API_LINKAGE_I_ __attribute__((dllimport))
|
#define SOL_API_LINKAGE_I_ __attribute__((dllimport))
|
||||||
#else
|
#else
|
||||||
#define SOL_API_LINKAGE_I_ __declspec(dllimport)
|
#define SOL_API_LINKAGE_I_ __declspec(dllimport)
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
// extern if building normally on non-MSVC
|
// extern if building normally on non-MSVC
|
||||||
#define SOL_API_LINKAGE_I_ extern
|
#define SOL_API_LINKAGE_I_ extern
|
||||||
#endif
|
#endif
|
||||||
#elif SOL_IS_ON(SOL_UNITY_BUILD_I_)
|
#elif SOL_IS_ON(SOL_UNITY_BUILD_I_)
|
||||||
// Built-in library, like how stb typical works
|
// Built-in library, like how stb typical works
|
||||||
#if SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
#if SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
||||||
// Header only, so functions are defined "inline"
|
// Header only, so functions are defined "inline"
|
||||||
#define SOL_API_LINKAGE_I_ inline
|
#define SOL_API_LINKAGE_I_ inline
|
||||||
#else
|
#else
|
||||||
// Not header only, so seperately compiled files
|
// Not header only, so seperately compiled files
|
||||||
#define SOL_API_LINKAGE_I_ extern
|
#define SOL_API_LINKAGE_I_ extern
|
||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
// Normal static library
|
// Normal static library
|
||||||
#if SOL_IS_ON(SOL_BUILD_CXX_MODE_I_)
|
#if SOL_IS_ON(SOL_BUILD_CXX_MODE_I_)
|
||||||
#define SOL_API_LINKAGE_I_
|
#define SOL_API_LINKAGE_I_
|
||||||
#else
|
#else
|
||||||
#define SOL_API_LINKAGE_I_ extern
|
#define SOL_API_LINKAGE_I_ extern
|
||||||
#endif
|
#endif
|
||||||
#endif // DLL or not
|
#endif // DLL or not
|
||||||
#endif // Build definitions
|
#endif // Build definitions
|
||||||
|
|
||||||
#if defined(SOL_PUBLIC_FUNC_DECL)
|
#if defined(SOL_PUBLIC_FUNC_DECL)
|
||||||
#define SOL_PUBLIC_FUNC_DECL_I_ SOL_PUBLIC_FUNC_DECL
|
#define SOL_PUBLIC_FUNC_DECL_I_ SOL_PUBLIC_FUNC_DECL
|
||||||
#else
|
#else
|
||||||
#define SOL_PUBLIC_FUNC_DECL_I_ SOL_API_LINKAGE_I_
|
#define SOL_PUBLIC_FUNC_DECL_I_ SOL_API_LINKAGE_I_
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(SOL_INTERNAL_FUNC_DECL_)
|
#if defined(SOL_INTERNAL_FUNC_DECL_)
|
||||||
#define SOL_INTERNAL_FUNC_DECL_I_ SOL_INTERNAL_FUNC_DECL_
|
#define SOL_INTERNAL_FUNC_DECL_I_ SOL_INTERNAL_FUNC_DECL_
|
||||||
#else
|
#else
|
||||||
#define SOL_INTERNAL_FUNC_DECL_I_ SOL_API_LINKAGE_I_
|
#define SOL_INTERNAL_FUNC_DECL_I_ SOL_API_LINKAGE_I_
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(SOL_PUBLIC_FUNC_DEF)
|
#if defined(SOL_PUBLIC_FUNC_DEF)
|
||||||
#define SOL_PUBLIC_FUNC_DEF_I_ SOL_PUBLIC_FUNC_DEF
|
#define SOL_PUBLIC_FUNC_DEF_I_ SOL_PUBLIC_FUNC_DEF
|
||||||
#else
|
#else
|
||||||
#define SOL_PUBLIC_FUNC_DEF_I_ SOL_API_LINKAGE_I_
|
#define SOL_PUBLIC_FUNC_DEF_I_ SOL_API_LINKAGE_I_
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(SOL_INTERNAL_FUNC_DEF)
|
#if defined(SOL_INTERNAL_FUNC_DEF)
|
||||||
#define SOL_INTERNAL_FUNC_DEF_I_ SOL_INTERNAL_FUNC_DEF
|
#define SOL_INTERNAL_FUNC_DEF_I_ SOL_INTERNAL_FUNC_DEF
|
||||||
#else
|
#else
|
||||||
#define SOL_INTERNAL_FUNC_DEF_I_ SOL_API_LINKAGE_I_
|
#define SOL_INTERNAL_FUNC_DEF_I_ SOL_API_LINKAGE_I_
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(SOL_FUNC_DECL)
|
#if defined(SOL_FUNC_DECL)
|
||||||
#define SOL_FUNC_DECL_I_ SOL_FUNC_DECL
|
#define SOL_FUNC_DECL_I_ SOL_FUNC_DECL
|
||||||
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
||||||
#define SOL_FUNC_DECL_I_
|
#define SOL_FUNC_DECL_I_
|
||||||
#elif SOL_IS_ON(SOL_DLL_I_)
|
#elif SOL_IS_ON(SOL_DLL_I_)
|
||||||
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_)
|
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_)
|
||||||
#if SOL_IS_ON(SOL_BUILD_I_)
|
#if SOL_IS_ON(SOL_BUILD_I_)
|
||||||
#define SOL_FUNC_DECL_I_ extern __declspec(dllexport)
|
#define SOL_FUNC_DECL_I_ extern __declspec(dllexport)
|
||||||
#else
|
#else
|
||||||
#define SOL_FUNC_DECL_I_ extern __declspec(dllimport)
|
#define SOL_FUNC_DECL_I_ extern __declspec(dllimport)
|
||||||
#endif
|
#endif
|
||||||
#elif SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
#elif SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
||||||
#define SOL_FUNC_DECL_I_ extern __attribute__((visibility("default")))
|
#define SOL_FUNC_DECL_I_ extern __attribute__((visibility("default")))
|
||||||
#else
|
#else
|
||||||
#define SOL_FUNC_DECL_I_ extern
|
#define SOL_FUNC_DECL_I_ extern
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(SOL_FUNC_DEFN)
|
#if defined(SOL_FUNC_DEFN)
|
||||||
#define SOL_FUNC_DEFN_I_ SOL_FUNC_DEFN
|
#define SOL_FUNC_DEFN_I_ SOL_FUNC_DEFN
|
||||||
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
||||||
#define SOL_FUNC_DEFN_I_ inline
|
#define SOL_FUNC_DEFN_I_ inline
|
||||||
#elif SOL_IS_ON(SOL_DLL_I_)
|
#elif SOL_IS_ON(SOL_DLL_I_)
|
||||||
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_)
|
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_)
|
||||||
#if SOL_IS_ON(SOL_BUILD_I_)
|
#if SOL_IS_ON(SOL_BUILD_I_)
|
||||||
#define SOL_FUNC_DEFN_I_ __declspec(dllexport)
|
#define SOL_FUNC_DEFN_I_ __declspec(dllexport)
|
||||||
#else
|
#else
|
||||||
#define SOL_FUNC_DEFN_I_ __declspec(dllimport)
|
#define SOL_FUNC_DEFN_I_ __declspec(dllimport)
|
||||||
#endif
|
#endif
|
||||||
#elif SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
#elif SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
||||||
#define SOL_FUNC_DEFN_I_ __attribute__((visibility("default")))
|
#define SOL_FUNC_DEFN_I_ __attribute__((visibility("default")))
|
||||||
#else
|
#else
|
||||||
#define SOL_FUNC_DEFN_I_
|
#define SOL_FUNC_DEFN_I_
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(SOL_HIDDEN_FUNC_DECL)
|
#if defined(SOL_HIDDEN_FUNC_DECL)
|
||||||
#define SOL_HIDDEN_FUNC_DECL_I_ SOL_HIDDEN_FUNC_DECL
|
#define SOL_HIDDEN_FUNC_DECL_I_ SOL_HIDDEN_FUNC_DECL
|
||||||
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
||||||
#define SOL_HIDDEN_FUNC_DECL_I_
|
#define SOL_HIDDEN_FUNC_DECL_I_
|
||||||
#elif SOL_IS_ON(SOL_DLL_I_)
|
#elif SOL_IS_ON(SOL_DLL_I_)
|
||||||
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_)
|
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_)
|
||||||
#if SOL_IS_ON(SOL_BUILD_I_)
|
#if SOL_IS_ON(SOL_BUILD_I_)
|
||||||
#define SOL_HIDDEN_FUNC_DECL_I_ extern __declspec(dllexport)
|
#define SOL_HIDDEN_FUNC_DECL_I_ extern __declspec(dllexport)
|
||||||
#else
|
#else
|
||||||
#define SOL_HIDDEN_FUNC_DECL_I_ extern __declspec(dllimport)
|
#define SOL_HIDDEN_FUNC_DECL_I_ extern __declspec(dllimport)
|
||||||
#endif
|
#endif
|
||||||
#elif SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
#elif SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
||||||
#define SOL_HIDDEN_FUNC_DECL_I_ extern __attribute__((visibility("default")))
|
#define SOL_HIDDEN_FUNC_DECL_I_ extern __attribute__((visibility("default")))
|
||||||
#else
|
#else
|
||||||
#define SOL_HIDDEN_FUNC_DECL_I_ extern
|
#define SOL_HIDDEN_FUNC_DECL_I_ extern
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(SOL_HIDDEN_FUNC_DEFN)
|
#if defined(SOL_HIDDEN_FUNC_DEFN)
|
||||||
#define SOL_HIDDEN_FUNC_DEFN_I_ SOL_HIDDEN_FUNC_DEFN
|
#define SOL_HIDDEN_FUNC_DEFN_I_ SOL_HIDDEN_FUNC_DEFN
|
||||||
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
#elif SOL_IS_ON(SOL_HEADER_ONLY_I_)
|
||||||
#define SOL_HIDDEN_FUNC_DEFN_I_ inline
|
#define SOL_HIDDEN_FUNC_DEFN_I_ inline
|
||||||
#elif SOL_IS_ON(SOL_DLL_I_)
|
#elif SOL_IS_ON(SOL_DLL_I_)
|
||||||
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_)
|
#if SOL_IS_ON(SOL_COMPILER_VCXX_I_)
|
||||||
#if SOL_IS_ON(SOL_BUILD_I_)
|
#if SOL_IS_ON(SOL_BUILD_I_)
|
||||||
#define SOL_HIDDEN_FUNC_DEFN_I_
|
#define SOL_HIDDEN_FUNC_DEFN_I_
|
||||||
#else
|
#else
|
||||||
#define SOL_HIDDEN_FUNC_DEFN_I_
|
#define SOL_HIDDEN_FUNC_DEFN_I_
|
||||||
#endif
|
#endif
|
||||||
#elif SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
#elif SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
||||||
#define SOL_HIDDEN_FUNC_DEFN_I_ __attribute__((visibility("hidden")))
|
#define SOL_HIDDEN_FUNC_DEFN_I_ __attribute__((visibility("hidden")))
|
||||||
#else
|
#else
|
||||||
#define SOL_HIDDEN_FUNC_DEFN_I_
|
#define SOL_HIDDEN_FUNC_DEFN_I_
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
#endif // SOL_DETAIL_BUILD_VERSION_HPP
|
#endif // SOL_DETAIL_BUILD_VERSION_HPP
|
||||||
|
|
154
extern/sol3/sol/dump_handler.hpp
vendored
154
extern/sol3/sol/dump_handler.hpp
vendored
|
@ -1,77 +1,77 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_DUMP_HANDLER_HPP
|
#ifndef SOL_DUMP_HANDLER_HPP
|
||||||
#define SOL_DUMP_HANDLER_HPP
|
#define SOL_DUMP_HANDLER_HPP
|
||||||
|
|
||||||
#include <sol/compatibility.hpp>
|
#include <sol/compatibility.hpp>
|
||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <exception>
|
#include <exception>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
|
|
||||||
class dump_error : public error {
|
class dump_error : public error {
|
||||||
private:
|
private:
|
||||||
int m_ec;
|
int m_ec;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
dump_error(int error_code_) : error("dump returned non-zero error of " + std::to_string(error_code_)), m_ec(error_code_) {
|
dump_error(int error_code_) : error("dump returned non-zero error of " + std::to_string(error_code_)), m_ec(error_code_) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int error_code() const {
|
int error_code() const {
|
||||||
return m_ec;
|
return m_ec;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
inline int dump_pass_on_error(lua_State* L_, int result_code, lua_Writer writer_function, void* userdata_pointer_, bool strip) {
|
inline int dump_pass_on_error(lua_State* L_, int result_code, lua_Writer writer_function, void* userdata_pointer_, bool strip) {
|
||||||
(void)L_;
|
(void)L_;
|
||||||
(void)writer_function;
|
(void)writer_function;
|
||||||
(void)userdata_pointer_;
|
(void)userdata_pointer_;
|
||||||
(void)strip;
|
(void)strip;
|
||||||
return result_code;
|
return result_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int dump_panic_on_error(lua_State* L_, int result_code, lua_Writer writer_function, void* userdata_pointer_, bool strip) {
|
inline int dump_panic_on_error(lua_State* L_, int result_code, lua_Writer writer_function, void* userdata_pointer_, bool strip) {
|
||||||
(void)L_;
|
(void)L_;
|
||||||
(void)writer_function;
|
(void)writer_function;
|
||||||
(void)userdata_pointer_;
|
(void)userdata_pointer_;
|
||||||
(void)strip;
|
(void)strip;
|
||||||
return luaL_error(L_, "a non-zero error code (%d) was returned by the lua_Writer for the dump function", result_code);
|
return luaL_error(L_, "a non-zero error code (%d) was returned by the lua_Writer for the dump function", result_code);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int dump_throw_on_error(lua_State* L_, int result_code, lua_Writer writer_function, void* userdata_pointer_, bool strip) {
|
inline int dump_throw_on_error(lua_State* L_, int result_code, lua_Writer writer_function, void* userdata_pointer_, bool strip) {
|
||||||
#if SOL_IS_OFF(SOL_EXCEPTIONS_I_)
|
#if SOL_IS_OFF(SOL_EXCEPTIONS_I_)
|
||||||
return dump_panic_on_error(L_, result_code, writer_function, userdata_pointer_, strip);
|
return dump_panic_on_error(L_, result_code, writer_function, userdata_pointer_, strip);
|
||||||
#else
|
#else
|
||||||
(void)L_;
|
(void)L_;
|
||||||
(void)writer_function;
|
(void)writer_function;
|
||||||
(void)userdata_pointer_;
|
(void)userdata_pointer_;
|
||||||
(void)strip;
|
(void)strip;
|
||||||
throw dump_error(result_code);
|
throw dump_error(result_code);
|
||||||
#endif // no exceptions stuff
|
#endif // no exceptions stuff
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_DUMP_HANDLER_HPP
|
#endif // SOL_DUMP_HANDLER_HPP
|
||||||
|
|
320
extern/sol3/sol/ebco.hpp
vendored
320
extern/sol3/sol/ebco.hpp
vendored
|
@ -1,160 +1,160 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_EBCO_HPP
|
#ifndef SOL_EBCO_HPP
|
||||||
#define SOL_EBCO_HPP
|
#define SOL_EBCO_HPP
|
||||||
|
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
namespace sol { namespace detail {
|
namespace sol { namespace detail {
|
||||||
|
|
||||||
template <typename T, std::size_t tag = 0, typename = void>
|
template <typename T, std::size_t tag = 0, typename = void>
|
||||||
struct ebco {
|
struct ebco {
|
||||||
T m_value;
|
T m_value;
|
||||||
|
|
||||||
ebco() = default;
|
ebco() = default;
|
||||||
ebco(const ebco&) = default;
|
ebco(const ebco&) = default;
|
||||||
ebco(ebco&&) = default;
|
ebco(ebco&&) = default;
|
||||||
ebco& operator=(const ebco&) = default;
|
ebco& operator=(const ebco&) = default;
|
||||||
ebco& operator=(ebco&&) = default;
|
ebco& operator=(ebco&&) = default;
|
||||||
ebco(const T& v) noexcept(std::is_nothrow_copy_constructible_v<T>) : m_value(v) {};
|
ebco(const T& v) noexcept(std::is_nothrow_copy_constructible_v<T>) : m_value(v) {};
|
||||||
ebco(T&& v) noexcept(std::is_nothrow_move_constructible_v<T>) : m_value(std::move(v)) {};
|
ebco(T&& v) noexcept(std::is_nothrow_move_constructible_v<T>) : m_value(std::move(v)) {};
|
||||||
ebco& operator=(const T& v) noexcept(std::is_nothrow_copy_assignable_v<T>) {
|
ebco& operator=(const T& v) noexcept(std::is_nothrow_copy_assignable_v<T>) {
|
||||||
m_value = v;
|
m_value = v;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
ebco& operator=(T&& v) noexcept(std::is_nothrow_move_assignable_v<T>) {
|
ebco& operator=(T&& v) noexcept(std::is_nothrow_move_assignable_v<T>) {
|
||||||
m_value = std::move(v);
|
m_value = std::move(v);
|
||||||
return *this;
|
return *this;
|
||||||
};
|
};
|
||||||
template <typename Arg, typename... Args,
|
template <typename Arg, typename... Args,
|
||||||
typename = std::enable_if_t<
|
typename = std::enable_if_t<
|
||||||
!std::is_same_v<std::remove_reference_t<std::remove_cv_t<Arg>>,
|
!std::is_same_v<std::remove_reference_t<std::remove_cv_t<Arg>>,
|
||||||
ebco> && !std::is_same_v<std::remove_reference_t<std::remove_cv_t<Arg>>, T> && (sizeof...(Args) > 0 || !std::is_convertible_v<Arg, T>)>>
|
ebco> && !std::is_same_v<std::remove_reference_t<std::remove_cv_t<Arg>>, T> && (sizeof...(Args) > 0 || !std::is_convertible_v<Arg, T>)>>
|
||||||
ebco(Arg&& arg, Args&&... args) noexcept(std::is_nothrow_constructible_v<T, Arg, Args...>)
|
ebco(Arg&& arg, Args&&... args) noexcept(std::is_nothrow_constructible_v<T, Arg, Args...>)
|
||||||
: m_value(std::forward<Arg>(arg), std::forward<Args>(args)...) {
|
: m_value(std::forward<Arg>(arg), std::forward<Args>(args)...) {
|
||||||
}
|
}
|
||||||
|
|
||||||
T& value() & noexcept {
|
T& value() & noexcept {
|
||||||
return m_value;
|
return m_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
T const& value() const& noexcept {
|
T const& value() const& noexcept {
|
||||||
return m_value;
|
return m_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
T&& value() && noexcept {
|
T&& value() && noexcept {
|
||||||
return std::move(m_value);
|
return std::move(m_value);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T, std::size_t tag>
|
template <typename T, std::size_t tag>
|
||||||
struct ebco<T, tag, std::enable_if_t<!std::is_reference_v<T> && std::is_class_v<T> && !std::is_final_v<T>>> : T {
|
struct ebco<T, tag, std::enable_if_t<!std::is_reference_v<T> && std::is_class_v<T> && !std::is_final_v<T>>> : T {
|
||||||
ebco() = default;
|
ebco() = default;
|
||||||
ebco(const ebco&) = default;
|
ebco(const ebco&) = default;
|
||||||
ebco(ebco&&) = default;
|
ebco(ebco&&) = default;
|
||||||
ebco(const T& v) noexcept(std::is_nothrow_copy_constructible_v<T>) : T(v) {};
|
ebco(const T& v) noexcept(std::is_nothrow_copy_constructible_v<T>) : T(v) {};
|
||||||
ebco(T&& v) noexcept(std::is_nothrow_move_constructible_v<T>) : T(std::move(v)) {};
|
ebco(T&& v) noexcept(std::is_nothrow_move_constructible_v<T>) : T(std::move(v)) {};
|
||||||
template <typename Arg, typename... Args,
|
template <typename Arg, typename... Args,
|
||||||
typename = std::enable_if_t<
|
typename = std::enable_if_t<
|
||||||
!std::is_same_v<std::remove_reference_t<std::remove_cv_t<Arg>>,
|
!std::is_same_v<std::remove_reference_t<std::remove_cv_t<Arg>>,
|
||||||
ebco> && !std::is_same_v<std::remove_reference_t<std::remove_cv_t<Arg>>, T> && (sizeof...(Args) > 0 || !std::is_convertible_v<Arg, T>)>>
|
ebco> && !std::is_same_v<std::remove_reference_t<std::remove_cv_t<Arg>>, T> && (sizeof...(Args) > 0 || !std::is_convertible_v<Arg, T>)>>
|
||||||
ebco(Arg&& arg, Args&&... args) noexcept(std::is_nothrow_constructible_v<T, Arg, Args...>) : T(std::forward<Arg>(arg), std::forward<Args>(args)...) {
|
ebco(Arg&& arg, Args&&... args) noexcept(std::is_nothrow_constructible_v<T, Arg, Args...>) : T(std::forward<Arg>(arg), std::forward<Args>(args)...) {
|
||||||
}
|
}
|
||||||
|
|
||||||
ebco& operator=(const ebco&) = default;
|
ebco& operator=(const ebco&) = default;
|
||||||
ebco& operator=(ebco&&) = default;
|
ebco& operator=(ebco&&) = default;
|
||||||
ebco& operator=(const T& v) noexcept(std::is_nothrow_copy_assignable_v<T>) {
|
ebco& operator=(const T& v) noexcept(std::is_nothrow_copy_assignable_v<T>) {
|
||||||
static_cast<T&>(*this) = v;
|
static_cast<T&>(*this) = v;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
ebco& operator=(T&& v) noexcept(std::is_nothrow_move_assignable_v<T>) {
|
ebco& operator=(T&& v) noexcept(std::is_nothrow_move_assignable_v<T>) {
|
||||||
static_cast<T&>(*this) = std::move(v);
|
static_cast<T&>(*this) = std::move(v);
|
||||||
return *this;
|
return *this;
|
||||||
};
|
};
|
||||||
|
|
||||||
T& value() & noexcept {
|
T& value() & noexcept {
|
||||||
return static_cast<T&>(*this);
|
return static_cast<T&>(*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
T const& value() const& noexcept {
|
T const& value() const& noexcept {
|
||||||
return static_cast<T const&>(*this);
|
return static_cast<T const&>(*this);
|
||||||
}
|
}
|
||||||
|
|
||||||
T&& value() && noexcept {
|
T&& value() && noexcept {
|
||||||
return std::move(static_cast<T&>(*this));
|
return std::move(static_cast<T&>(*this));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T, std::size_t tag>
|
template <typename T, std::size_t tag>
|
||||||
struct ebco<T&, tag> {
|
struct ebco<T&, tag> {
|
||||||
private:
|
private:
|
||||||
T* m_ref;
|
T* m_ref;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ebco() = default;
|
ebco() = default;
|
||||||
ebco(const ebco&) = default;
|
ebco(const ebco&) = default;
|
||||||
ebco(ebco&&) = default;
|
ebco(ebco&&) = default;
|
||||||
ebco(T& v) noexcept : m_ref(std::addressof(v)) {};
|
ebco(T& v) noexcept : m_ref(std::addressof(v)) {};
|
||||||
|
|
||||||
ebco& operator=(const ebco&) = default;
|
ebco& operator=(const ebco&) = default;
|
||||||
ebco& operator=(ebco&&) = default;
|
ebco& operator=(ebco&&) = default;
|
||||||
ebco& operator=(T& v) noexcept {
|
ebco& operator=(T& v) noexcept {
|
||||||
m_ref = std::addressof(v);
|
m_ref = std::addressof(v);
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
T& value() const noexcept {
|
T& value() const noexcept {
|
||||||
return *(const_cast<ebco<T&, tag>&>(*this).m_ref);
|
return *(const_cast<ebco<T&, tag>&>(*this).m_ref);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T, std::size_t tag>
|
template <typename T, std::size_t tag>
|
||||||
struct ebco<T&&, tag> {
|
struct ebco<T&&, tag> {
|
||||||
T&& ref;
|
T&& ref;
|
||||||
|
|
||||||
ebco() = default;
|
ebco() = default;
|
||||||
ebco(const ebco&) = delete;
|
ebco(const ebco&) = delete;
|
||||||
ebco(ebco&&) = default;
|
ebco(ebco&&) = default;
|
||||||
ebco(T&& v) noexcept : ref(v) {};
|
ebco(T&& v) noexcept : ref(v) {};
|
||||||
|
|
||||||
ebco& operator=(const ebco&) = delete;
|
ebco& operator=(const ebco&) = delete;
|
||||||
ebco& operator=(ebco&&) = delete;
|
ebco& operator=(ebco&&) = delete;
|
||||||
|
|
||||||
T& value() & noexcept {
|
T& value() & noexcept {
|
||||||
return ref;
|
return ref;
|
||||||
}
|
}
|
||||||
|
|
||||||
const T& value() const& noexcept {
|
const T& value() const& noexcept {
|
||||||
return ref;
|
return ref;
|
||||||
}
|
}
|
||||||
|
|
||||||
T&& value() && noexcept {
|
T&& value() && noexcept {
|
||||||
return std::move(ref);
|
return std::move(ref);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
}} // namespace sol::detail
|
}} // namespace sol::detail
|
||||||
|
|
||||||
#endif // SOL_EBCO_HPP
|
#endif // SOL_EBCO_HPP
|
||||||
|
|
78
extern/sol3/sol/epilogue.hpp
vendored
78
extern/sol3/sol/epilogue.hpp
vendored
|
@ -1,39 +1,39 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
// clang-format off
|
// clang-format off
|
||||||
|
|
||||||
#if !defined(SOL_PROLOGUE_I_)
|
#if !defined(SOL_PROLOGUE_I_)
|
||||||
#error "[sol2] Library Prologue is missing from this translation unit."
|
#error "[sol2] Library Prologue is missing from this translation unit."
|
||||||
#else
|
#else
|
||||||
#undef SOL_PROLOGUE_I_
|
#undef SOL_PROLOGUE_I_
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if SOL_IS_ON(SOL_BUILD_CXX_MODE_I_)
|
#if SOL_IS_ON(SOL_BUILD_CXX_MODE_I_)
|
||||||
#undef _FWD
|
#undef _FWD
|
||||||
#undef _MOVE
|
#undef _MOVE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
178
extern/sol3/sol/error.hpp
vendored
178
extern/sol3/sol/error.hpp
vendored
|
@ -1,89 +1,89 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_ERROR_HPP
|
#ifndef SOL_ERROR_HPP
|
||||||
#define SOL_ERROR_HPP
|
#define SOL_ERROR_HPP
|
||||||
|
|
||||||
#include <sol/compatibility.hpp>
|
#include <sol/compatibility.hpp>
|
||||||
|
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
struct direct_error_tag { };
|
struct direct_error_tag { };
|
||||||
const auto direct_error = direct_error_tag {};
|
const auto direct_error = direct_error_tag {};
|
||||||
|
|
||||||
struct error_result {
|
struct error_result {
|
||||||
int results;
|
int results;
|
||||||
const char* format_string;
|
const char* format_string;
|
||||||
std::array<const char*, 4> argument_strings;
|
std::array<const char*, 4> argument_strings;
|
||||||
|
|
||||||
error_result() : results(0), format_string(nullptr) {
|
error_result() : results(0), format_string(nullptr) {
|
||||||
}
|
}
|
||||||
|
|
||||||
error_result(int results_) : results(results_), format_string(nullptr) {
|
error_result(int results_) : results(results_), format_string(nullptr) {
|
||||||
}
|
}
|
||||||
|
|
||||||
error_result(const char* format_string_, const char* first_message_) : results(0), format_string(format_string_), argument_strings() {
|
error_result(const char* format_string_, const char* first_message_) : results(0), format_string(format_string_), argument_strings() {
|
||||||
argument_strings[0] = first_message_;
|
argument_strings[0] = first_message_;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
inline int handle_errors(lua_State* L, const error_result& er) {
|
inline int handle_errors(lua_State* L, const error_result& er) {
|
||||||
if (er.format_string == nullptr) {
|
if (er.format_string == nullptr) {
|
||||||
return er.results;
|
return er.results;
|
||||||
}
|
}
|
||||||
return luaL_error(L, er.format_string, er.argument_strings[0], er.argument_strings[1], er.argument_strings[2], er.argument_strings[3]);
|
return luaL_error(L, er.format_string, er.argument_strings[0], er.argument_strings[1], er.argument_strings[2], er.argument_strings[3]);
|
||||||
}
|
}
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
class error : public std::runtime_error {
|
class error : public std::runtime_error {
|
||||||
private:
|
private:
|
||||||
// Because VC++ is upsetting, most of the time!
|
// Because VC++ is upsetting, most of the time!
|
||||||
std::string what_reason;
|
std::string what_reason;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
error(const std::string& str) : error(detail::direct_error, "lua: error: " + str) {
|
error(const std::string& str) : error(detail::direct_error, "lua: error: " + str) {
|
||||||
}
|
}
|
||||||
error(std::string&& str) : error(detail::direct_error, "lua: error: " + std::move(str)) {
|
error(std::string&& str) : error(detail::direct_error, "lua: error: " + std::move(str)) {
|
||||||
}
|
}
|
||||||
error(detail::direct_error_tag, const std::string& str) : std::runtime_error(""), what_reason(str) {
|
error(detail::direct_error_tag, const std::string& str) : std::runtime_error(""), what_reason(str) {
|
||||||
}
|
}
|
||||||
error(detail::direct_error_tag, std::string&& str) : std::runtime_error(""), what_reason(std::move(str)) {
|
error(detail::direct_error_tag, std::string&& str) : std::runtime_error(""), what_reason(std::move(str)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
error(const error& e) = default;
|
error(const error& e) = default;
|
||||||
error(error&& e) = default;
|
error(error&& e) = default;
|
||||||
error& operator=(const error& e) = default;
|
error& operator=(const error& e) = default;
|
||||||
error& operator=(error&& e) = default;
|
error& operator=(error&& e) = default;
|
||||||
|
|
||||||
virtual const char* what() const noexcept override {
|
virtual const char* what() const noexcept override {
|
||||||
return what_reason.c_str();
|
return what_reason.c_str();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_ERROR_HPP
|
#endif // SOL_ERROR_HPP
|
||||||
|
|
284
extern/sol3/sol/function.hpp
vendored
284
extern/sol3/sol/function.hpp
vendored
|
@ -1,142 +1,142 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_FUNCTION_HPP
|
#ifndef SOL_FUNCTION_HPP
|
||||||
#define SOL_FUNCTION_HPP
|
#define SOL_FUNCTION_HPP
|
||||||
|
|
||||||
#include <sol/stack.hpp>
|
#include <sol/stack.hpp>
|
||||||
#include <sol/unsafe_function.hpp>
|
#include <sol/unsafe_function.hpp>
|
||||||
#include <sol/protected_function.hpp>
|
#include <sol/protected_function.hpp>
|
||||||
#include <sol/bytecode.hpp>
|
#include <sol/bytecode.hpp>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
template <typename... Ret, typename... Args>
|
template <typename... Ret, typename... Args>
|
||||||
decltype(auto) stack_proxy::call(Args&&... args) {
|
decltype(auto) stack_proxy::call(Args&&... args) {
|
||||||
stack_function sf(this->lua_state(), this->stack_index());
|
stack_function sf(this->lua_state(), this->stack_index());
|
||||||
return sf.template call<Ret...>(std::forward<Args>(args)...);
|
return sf.template call<Ret...>(std::forward<Args>(args)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline protected_function_result::protected_function_result(unsafe_function_result&& o) noexcept
|
inline protected_function_result::protected_function_result(unsafe_function_result&& o) noexcept
|
||||||
: L(o.lua_state()), index(o.stack_index()), returncount(o.return_count()), popcount(o.return_count()), err(o.status()) {
|
: L(o.lua_state()), index(o.stack_index()), returncount(o.return_count()), popcount(o.return_count()), err(o.status()) {
|
||||||
// Must be manual, otherwise destructor will screw us
|
// Must be manual, otherwise destructor will screw us
|
||||||
// return count being 0 is enough to keep things clean
|
// return count being 0 is enough to keep things clean
|
||||||
// but we will be thorough
|
// but we will be thorough
|
||||||
o.abandon();
|
o.abandon();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline protected_function_result& protected_function_result::operator=(unsafe_function_result&& o) noexcept {
|
inline protected_function_result& protected_function_result::operator=(unsafe_function_result&& o) noexcept {
|
||||||
L = o.lua_state();
|
L = o.lua_state();
|
||||||
index = o.stack_index();
|
index = o.stack_index();
|
||||||
returncount = o.return_count();
|
returncount = o.return_count();
|
||||||
popcount = o.return_count();
|
popcount = o.return_count();
|
||||||
err = o.status();
|
err = o.status();
|
||||||
// Must be manual, otherwise destructor will screw us
|
// Must be manual, otherwise destructor will screw us
|
||||||
// return count being 0 is enough to keep things clean
|
// return count being 0 is enough to keep things clean
|
||||||
// but we will be thorough
|
// but we will be thorough
|
||||||
o.abandon();
|
o.abandon();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline unsafe_function_result::unsafe_function_result(protected_function_result&& o) noexcept
|
inline unsafe_function_result::unsafe_function_result(protected_function_result&& o) noexcept
|
||||||
: L(o.lua_state()), index(o.stack_index()), returncount(o.return_count()) {
|
: L(o.lua_state()), index(o.stack_index()), returncount(o.return_count()) {
|
||||||
// Must be manual, otherwise destructor will screw us
|
// Must be manual, otherwise destructor will screw us
|
||||||
// return count being 0 is enough to keep things clean
|
// return count being 0 is enough to keep things clean
|
||||||
// but we will be thorough
|
// but we will be thorough
|
||||||
o.abandon();
|
o.abandon();
|
||||||
}
|
}
|
||||||
inline unsafe_function_result& unsafe_function_result::operator=(protected_function_result&& o) noexcept {
|
inline unsafe_function_result& unsafe_function_result::operator=(protected_function_result&& o) noexcept {
|
||||||
L = o.lua_state();
|
L = o.lua_state();
|
||||||
index = o.stack_index();
|
index = o.stack_index();
|
||||||
returncount = o.return_count();
|
returncount = o.return_count();
|
||||||
// Must be manual, otherwise destructor will screw us
|
// Must be manual, otherwise destructor will screw us
|
||||||
// return count being 0 is enough to keep things clean
|
// return count being 0 is enough to keep things clean
|
||||||
// but we will be thorough
|
// but we will be thorough
|
||||||
o.abandon();
|
o.abandon();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
template <typename... R>
|
template <typename... R>
|
||||||
struct std_shim {
|
struct std_shim {
|
||||||
unsafe_function lua_func_;
|
unsafe_function lua_func_;
|
||||||
|
|
||||||
std_shim(unsafe_function lua_func) : lua_func_(std::move(lua_func)) {
|
std_shim(unsafe_function lua_func) : lua_func_(std::move(lua_func)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
meta::return_type_t<R...> operator()(Args&&... args) {
|
meta::return_type_t<R...> operator()(Args&&... args) {
|
||||||
return lua_func_.call<R...>(std::forward<Args>(args)...);
|
return lua_func_.call<R...>(std::forward<Args>(args)...);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct std_shim<void> {
|
struct std_shim<void> {
|
||||||
unsafe_function lua_func_;
|
unsafe_function lua_func_;
|
||||||
|
|
||||||
std_shim(unsafe_function lua_func) : lua_func_(std::move(lua_func)) {
|
std_shim(unsafe_function lua_func) : lua_func_(std::move(lua_func)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
void operator()(Args&&... args) {
|
void operator()(Args&&... args) {
|
||||||
lua_func_.call<void>(std::forward<Args>(args)...);
|
lua_func_.call<void>(std::forward<Args>(args)...);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
namespace stack {
|
namespace stack {
|
||||||
template <typename Signature>
|
template <typename Signature>
|
||||||
struct unqualified_getter<std::function<Signature>> {
|
struct unqualified_getter<std::function<Signature>> {
|
||||||
typedef meta::bind_traits<Signature> fx_t;
|
typedef meta::bind_traits<Signature> fx_t;
|
||||||
typedef typename fx_t::args_list args_lists;
|
typedef typename fx_t::args_list args_lists;
|
||||||
typedef meta::tuple_types<typename fx_t::return_type> return_types;
|
typedef meta::tuple_types<typename fx_t::return_type> return_types;
|
||||||
|
|
||||||
template <typename... R>
|
template <typename... R>
|
||||||
static std::function<Signature> get_std_func(types<R...>, lua_State* L, int index) {
|
static std::function<Signature> get_std_func(types<R...>, lua_State* L, int index) {
|
||||||
detail::std_shim<R...> fx(unsafe_function(L, index));
|
detail::std_shim<R...> fx(unsafe_function(L, index));
|
||||||
return fx;
|
return fx;
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::function<Signature> get(lua_State* L, int index, record& tracking) {
|
static std::function<Signature> get(lua_State* L, int index, record& tracking) {
|
||||||
tracking.use(1);
|
tracking.use(1);
|
||||||
type t = type_of(L, index);
|
type t = type_of(L, index);
|
||||||
if (t == type::none || t == type::lua_nil) {
|
if (t == type::none || t == type::lua_nil) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return get_std_func(return_types(), L, index);
|
return get_std_func(return_types(), L, index);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename Allocator>
|
template <typename Allocator>
|
||||||
struct unqualified_getter<basic_bytecode<Allocator>> {
|
struct unqualified_getter<basic_bytecode<Allocator>> {
|
||||||
static basic_bytecode<Allocator> get(lua_State* L, int index, record& tracking) {
|
static basic_bytecode<Allocator> get(lua_State* L, int index, record& tracking) {
|
||||||
tracking.use(1);
|
tracking.use(1);
|
||||||
stack_function sf(L, index);
|
stack_function sf(L, index);
|
||||||
return sf.dump(&dump_panic_on_error);
|
return sf.dump(&dump_panic_on_error);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace stack
|
} // namespace stack
|
||||||
|
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_FUNCTION_HPP
|
#endif // SOL_FUNCTION_HPP
|
||||||
|
|
390
extern/sol3/sol/inheritance.hpp
vendored
390
extern/sol3/sol/inheritance.hpp
vendored
|
@ -1,195 +1,195 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_INHERITANCE_HPP
|
#ifndef SOL_INHERITANCE_HPP
|
||||||
#define SOL_INHERITANCE_HPP
|
#define SOL_INHERITANCE_HPP
|
||||||
|
|
||||||
#include <sol/types.hpp>
|
#include <sol/types.hpp>
|
||||||
#include <sol/usertype_traits.hpp>
|
#include <sol/usertype_traits.hpp>
|
||||||
#include <sol/unique_usertype_traits.hpp>
|
#include <sol/unique_usertype_traits.hpp>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
struct base_list { };
|
struct base_list { };
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
using bases = base_list<Args...>;
|
using bases = base_list<Args...>;
|
||||||
|
|
||||||
typedef bases<> base_classes_tag;
|
typedef bases<> base_classes_tag;
|
||||||
const auto base_classes = base_classes_tag();
|
const auto base_classes = base_classes_tag();
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
struct is_to_stringable<base_list<Args...>> : std::false_type { };
|
struct is_to_stringable<base_list<Args...>> : std::false_type { };
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
|
|
||||||
inline decltype(auto) base_class_check_key() {
|
inline decltype(auto) base_class_check_key() {
|
||||||
static const auto& key = "class_check";
|
static const auto& key = "class_check";
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline decltype(auto) base_class_cast_key() {
|
inline decltype(auto) base_class_cast_key() {
|
||||||
static const auto& key = "class_cast";
|
static const auto& key = "class_cast";
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline decltype(auto) base_class_index_propogation_key() {
|
inline decltype(auto) base_class_index_propogation_key() {
|
||||||
static const auto& key = u8"\xF0\x9F\x8C\xB2.index";
|
static const auto& key = u8"\xF0\x9F\x8C\xB2.index";
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline decltype(auto) base_class_new_index_propogation_key() {
|
inline decltype(auto) base_class_new_index_propogation_key() {
|
||||||
static const auto& key = u8"\xF0\x9F\x8C\xB2.new_index";
|
static const auto& key = u8"\xF0\x9F\x8C\xB2.new_index";
|
||||||
return key;
|
return key;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct inheritance {
|
struct inheritance {
|
||||||
typedef typename base<T>::type bases_t;
|
typedef typename base<T>::type bases_t;
|
||||||
|
|
||||||
static bool type_check_bases(types<>, const string_view&) {
|
static bool type_check_bases(types<>, const string_view&) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Base, typename... Args>
|
template <typename Base, typename... Args>
|
||||||
static bool type_check_bases(types<Base, Args...>, const string_view& ti) {
|
static bool type_check_bases(types<Base, Args...>, const string_view& ti) {
|
||||||
return ti == usertype_traits<Base>::qualified_name() || type_check_bases(types<Args...>(), ti);
|
return ti == usertype_traits<Base>::qualified_name() || type_check_bases(types<Args...>(), ti);
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool type_check(const string_view& ti) {
|
static bool type_check(const string_view& ti) {
|
||||||
return ti == usertype_traits<T>::qualified_name() || type_check_bases(bases_t(), ti);
|
return ti == usertype_traits<T>::qualified_name() || type_check_bases(bases_t(), ti);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename... Bases>
|
template <typename... Bases>
|
||||||
static bool type_check_with(const string_view& ti) {
|
static bool type_check_with(const string_view& ti) {
|
||||||
return ti == usertype_traits<T>::qualified_name() || type_check_bases(types<Bases...>(), ti);
|
return ti == usertype_traits<T>::qualified_name() || type_check_bases(types<Bases...>(), ti);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void* type_cast_bases(types<>, T*, const string_view&) {
|
static void* type_cast_bases(types<>, T*, const string_view&) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Base, typename... Args>
|
template <typename Base, typename... Args>
|
||||||
static void* type_cast_bases(types<Base, Args...>, T* data, const string_view& ti) {
|
static void* type_cast_bases(types<Base, Args...>, T* data, const string_view& ti) {
|
||||||
// Make sure to convert to T first, and then dynamic cast to the proper type
|
// Make sure to convert to T first, and then dynamic cast to the proper type
|
||||||
return ti != usertype_traits<Base>::qualified_name() ? type_cast_bases(types<Args...>(), data, ti)
|
return ti != usertype_traits<Base>::qualified_name() ? type_cast_bases(types<Args...>(), data, ti)
|
||||||
: static_cast<void*>(static_cast<Base*>(data));
|
: static_cast<void*>(static_cast<Base*>(data));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void* type_cast(void* voiddata, const string_view& ti) {
|
static void* type_cast(void* voiddata, const string_view& ti) {
|
||||||
T* data = static_cast<T*>(voiddata);
|
T* data = static_cast<T*>(voiddata);
|
||||||
return static_cast<void*>(ti != usertype_traits<T>::qualified_name() ? type_cast_bases(bases_t(), data, ti) : data);
|
return static_cast<void*>(ti != usertype_traits<T>::qualified_name() ? type_cast_bases(bases_t(), data, ti) : data);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename... Bases>
|
template <typename... Bases>
|
||||||
static void* type_cast_with(void* voiddata, const string_view& ti) {
|
static void* type_cast_with(void* voiddata, const string_view& ti) {
|
||||||
T* data = static_cast<T*>(voiddata);
|
T* data = static_cast<T*>(voiddata);
|
||||||
return static_cast<void*>(ti != usertype_traits<T>::qualified_name() ? type_cast_bases(types<Bases...>(), data, ti) : data);
|
return static_cast<void*>(ti != usertype_traits<T>::qualified_name() ? type_cast_bases(types<Bases...>(), data, ti) : data);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename U>
|
template <typename U>
|
||||||
static bool type_unique_cast_bases(types<>, void*, void*, const string_view&) {
|
static bool type_unique_cast_bases(types<>, void*, void*, const string_view&) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename U, typename Base, typename... Args>
|
template <typename U, typename Base, typename... Args>
|
||||||
static int type_unique_cast_bases(types<Base, Args...>, void* source_data, void* target_data, const string_view& ti) {
|
static int type_unique_cast_bases(types<Base, Args...>, void* source_data, void* target_data, const string_view& ti) {
|
||||||
using uu_traits = unique_usertype_traits<U>;
|
using uu_traits = unique_usertype_traits<U>;
|
||||||
using base_ptr = typename uu_traits::template rebind_actual_type<Base>;
|
using base_ptr = typename uu_traits::template rebind_actual_type<Base>;
|
||||||
string_view base_ti = usertype_traits<Base>::qualified_name();
|
string_view base_ti = usertype_traits<Base>::qualified_name();
|
||||||
if (base_ti == ti) {
|
if (base_ti == ti) {
|
||||||
if (target_data != nullptr) {
|
if (target_data != nullptr) {
|
||||||
U* source = static_cast<U*>(source_data);
|
U* source = static_cast<U*>(source_data);
|
||||||
base_ptr* target = static_cast<base_ptr*>(target_data);
|
base_ptr* target = static_cast<base_ptr*>(target_data);
|
||||||
// perform proper derived -> base conversion
|
// perform proper derived -> base conversion
|
||||||
*target = *source;
|
*target = *source;
|
||||||
}
|
}
|
||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
return type_unique_cast_bases<U>(types<Args...>(), source_data, target_data, ti);
|
return type_unique_cast_bases<U>(types<Args...>(), source_data, target_data, ti);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename U>
|
template <typename U>
|
||||||
static int type_unique_cast(void* source_data, void* target_data, const string_view& ti, const string_view& rebind_ti) {
|
static int type_unique_cast(void* source_data, void* target_data, const string_view& ti, const string_view& rebind_ti) {
|
||||||
if constexpr (is_actual_type_rebindable_for_v<U>) {
|
if constexpr (is_actual_type_rebindable_for_v<U>) {
|
||||||
using rebound_actual_type = unique_usertype_rebind_actual_t<U>;
|
using rebound_actual_type = unique_usertype_rebind_actual_t<U>;
|
||||||
using maybe_bases_or_empty = meta::conditional_t<std::is_void_v<rebound_actual_type>, types<>, bases_t>;
|
using maybe_bases_or_empty = meta::conditional_t<std::is_void_v<rebound_actual_type>, types<>, bases_t>;
|
||||||
string_view this_rebind_ti = usertype_traits<rebound_actual_type>::qualified_name();
|
string_view this_rebind_ti = usertype_traits<rebound_actual_type>::qualified_name();
|
||||||
if (rebind_ti != this_rebind_ti) {
|
if (rebind_ti != this_rebind_ti) {
|
||||||
// this is not even of the same unique type
|
// this is not even of the same unique type
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
string_view this_ti = usertype_traits<T>::qualified_name();
|
string_view this_ti = usertype_traits<T>::qualified_name();
|
||||||
if (ti == this_ti) {
|
if (ti == this_ti) {
|
||||||
// direct match, return 1
|
// direct match, return 1
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
return type_unique_cast_bases<U>(maybe_bases_or_empty(), source_data, target_data, ti);
|
return type_unique_cast_bases<U>(maybe_bases_or_empty(), source_data, target_data, ti);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
(void)rebind_ti;
|
(void)rebind_ti;
|
||||||
string_view this_ti = usertype_traits<T>::qualified_name();
|
string_view this_ti = usertype_traits<T>::qualified_name();
|
||||||
if (ti == this_ti) {
|
if (ti == this_ti) {
|
||||||
// direct match, return 1
|
// direct match, return 1
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
return type_unique_cast_bases<U>(types<>(), source_data, target_data, ti);
|
return type_unique_cast_bases<U>(types<>(), source_data, target_data, ti);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename U, typename... Bases>
|
template <typename U, typename... Bases>
|
||||||
static int type_unique_cast_with(void* source_data, void* target_data, const string_view& ti, const string_view& rebind_ti) {
|
static int type_unique_cast_with(void* source_data, void* target_data, const string_view& ti, const string_view& rebind_ti) {
|
||||||
using uc_bases_t = types<Bases...>;
|
using uc_bases_t = types<Bases...>;
|
||||||
if constexpr (is_actual_type_rebindable_for_v<U>) {
|
if constexpr (is_actual_type_rebindable_for_v<U>) {
|
||||||
using rebound_actual_type = unique_usertype_rebind_actual_t<U>;
|
using rebound_actual_type = unique_usertype_rebind_actual_t<U>;
|
||||||
using cond_bases_t = meta::conditional_t<std::is_void_v<rebound_actual_type>, types<>, uc_bases_t>;
|
using cond_bases_t = meta::conditional_t<std::is_void_v<rebound_actual_type>, types<>, uc_bases_t>;
|
||||||
string_view this_rebind_ti = usertype_traits<rebound_actual_type>::qualified_name();
|
string_view this_rebind_ti = usertype_traits<rebound_actual_type>::qualified_name();
|
||||||
if (rebind_ti != this_rebind_ti) {
|
if (rebind_ti != this_rebind_ti) {
|
||||||
// this is not even of the same unique type
|
// this is not even of the same unique type
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
string_view this_ti = usertype_traits<T>::qualified_name();
|
string_view this_ti = usertype_traits<T>::qualified_name();
|
||||||
if (ti == this_ti) {
|
if (ti == this_ti) {
|
||||||
// direct match, return 1
|
// direct match, return 1
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
return type_unique_cast_bases<U>(cond_bases_t(), source_data, target_data, ti);
|
return type_unique_cast_bases<U>(cond_bases_t(), source_data, target_data, ti);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
(void)rebind_ti;
|
(void)rebind_ti;
|
||||||
string_view this_ti = usertype_traits<T>::qualified_name();
|
string_view this_ti = usertype_traits<T>::qualified_name();
|
||||||
if (ti == this_ti) {
|
if (ti == this_ti) {
|
||||||
// direct match, return 1
|
// direct match, return 1
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
return type_unique_cast_bases<U>(types<>(), source_data, target_data, ti);
|
return type_unique_cast_bases<U>(types<>(), source_data, target_data, ti);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
using inheritance_check_function = decltype(&inheritance<void>::type_check);
|
using inheritance_check_function = decltype(&inheritance<void>::type_check);
|
||||||
using inheritance_cast_function = decltype(&inheritance<void>::type_cast);
|
using inheritance_cast_function = decltype(&inheritance<void>::type_cast);
|
||||||
using inheritance_unique_cast_function = decltype(&inheritance<void>::type_unique_cast<void>);
|
using inheritance_unique_cast_function = decltype(&inheritance<void>::type_unique_cast<void>);
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_INHERITANCE_HPP
|
#endif // SOL_INHERITANCE_HPP
|
||||||
|
|
190
extern/sol3/sol/lua_table.hpp
vendored
190
extern/sol3/sol/lua_table.hpp
vendored
|
@ -1,95 +1,95 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_LUA_TABLE_HPP
|
#ifndef SOL_LUA_TABLE_HPP
|
||||||
#define SOL_LUA_TABLE_HPP
|
#define SOL_LUA_TABLE_HPP
|
||||||
|
|
||||||
#include <sol/table_core.hpp>
|
#include <sol/table_core.hpp>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
|
|
||||||
template <typename ref_t>
|
template <typename ref_t>
|
||||||
struct basic_lua_table : basic_table_core<false, ref_t> {
|
struct basic_lua_table : basic_table_core<false, ref_t> {
|
||||||
private:
|
private:
|
||||||
using base_t = basic_table_core<false, ref_t>;
|
using base_t = basic_table_core<false, ref_t>;
|
||||||
|
|
||||||
friend class state;
|
friend class state;
|
||||||
friend class state_view;
|
friend class state_view;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
using base_t::lua_state;
|
using base_t::lua_state;
|
||||||
|
|
||||||
basic_lua_table() noexcept = default;
|
basic_lua_table() noexcept = default;
|
||||||
basic_lua_table(const basic_lua_table&) = default;
|
basic_lua_table(const basic_lua_table&) = default;
|
||||||
basic_lua_table(basic_lua_table&&) = default;
|
basic_lua_table(basic_lua_table&&) = default;
|
||||||
basic_lua_table& operator=(const basic_lua_table&) = default;
|
basic_lua_table& operator=(const basic_lua_table&) = default;
|
||||||
basic_lua_table& operator=(basic_lua_table&&) = default;
|
basic_lua_table& operator=(basic_lua_table&&) = default;
|
||||||
basic_lua_table(const stack_reference& r) : basic_lua_table(r.lua_state(), r.stack_index()) {
|
basic_lua_table(const stack_reference& r) : basic_lua_table(r.lua_state(), r.stack_index()) {
|
||||||
}
|
}
|
||||||
basic_lua_table(stack_reference&& r) : basic_lua_table(r.lua_state(), r.stack_index()) {
|
basic_lua_table(stack_reference&& r) : basic_lua_table(r.lua_state(), r.stack_index()) {
|
||||||
}
|
}
|
||||||
template <typename T, meta::enable_any<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
template <typename T, meta::enable_any<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
||||||
basic_lua_table(lua_State* L, T&& r) : base_t(L, std::forward<T>(r)) {
|
basic_lua_table(lua_State* L, T&& r) : base_t(L, std::forward<T>(r)) {
|
||||||
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
||||||
auto pp = stack::push_pop(*this);
|
auto pp = stack::push_pop(*this);
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_lua_table>(lua_state(), -1, handler);
|
stack::check<basic_lua_table>(lua_state(), -1, handler);
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
basic_lua_table(lua_State* L, const new_table& nt) : base_t(L, nt) {
|
basic_lua_table(lua_State* L, const new_table& nt) : base_t(L, nt) {
|
||||||
if (!is_stack_based<meta::unqualified_t<ref_t>>::value) {
|
if (!is_stack_based<meta::unqualified_t<ref_t>>::value) {
|
||||||
lua_pop(L, 1);
|
lua_pop(L, 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
basic_lua_table(lua_State* L, int index = -1) : base_t(detail::no_safety, L, index) {
|
basic_lua_table(lua_State* L, int index = -1) : base_t(detail::no_safety, L, index) {
|
||||||
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_lua_table>(L, index, handler);
|
stack::check<basic_lua_table>(L, index, handler);
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
basic_lua_table(lua_State* L, ref_index index) : base_t(detail::no_safety, L, index) {
|
basic_lua_table(lua_State* L, ref_index index) : base_t(detail::no_safety, L, index) {
|
||||||
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
||||||
auto pp = stack::push_pop(*this);
|
auto pp = stack::push_pop(*this);
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_lua_table>(lua_state(), -1, handler);
|
stack::check<basic_lua_table>(lua_state(), -1, handler);
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
template <typename T,
|
template <typename T,
|
||||||
meta::enable<meta::neg<meta::any_same<meta::unqualified_t<T>, basic_lua_table>>, meta::neg<std::is_same<ref_t, stack_reference>>,
|
meta::enable<meta::neg<meta::any_same<meta::unqualified_t<T>, basic_lua_table>>, meta::neg<std::is_same<ref_t, stack_reference>>,
|
||||||
meta::neg<std::is_same<lua_nil_t, meta::unqualified_t<T>>>, is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
meta::neg<std::is_same<lua_nil_t, meta::unqualified_t<T>>>, is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
||||||
basic_lua_table(T&& r) noexcept : basic_lua_table(detail::no_safety, std::forward<T>(r)) {
|
basic_lua_table(T&& r) noexcept : basic_lua_table(detail::no_safety, std::forward<T>(r)) {
|
||||||
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
||||||
if (!is_table<meta::unqualified_t<T>>::value) {
|
if (!is_table<meta::unqualified_t<T>>::value) {
|
||||||
auto pp = stack::push_pop(*this);
|
auto pp = stack::push_pop(*this);
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_lua_table>(lua_state(), -1, handler);
|
stack::check<basic_lua_table>(lua_state(), -1, handler);
|
||||||
}
|
}
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
basic_lua_table(lua_nil_t r) noexcept : basic_lua_table(detail::no_safety, r) {
|
basic_lua_table(lua_nil_t r) noexcept : basic_lua_table(detail::no_safety, r) {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_LUA_TABLE_HPP
|
#endif // SOL_LUA_TABLE_HPP
|
||||||
|
|
324
extern/sol3/sol/lua_value.hpp
vendored
324
extern/sol3/sol/lua_value.hpp
vendored
|
@ -1,162 +1,162 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_LUA_VALUE_HPP
|
#ifndef SOL_LUA_VALUE_HPP
|
||||||
#define SOL_LUA_VALUE_HPP
|
#define SOL_LUA_VALUE_HPP
|
||||||
|
|
||||||
#include <sol/stack.hpp>
|
#include <sol/stack.hpp>
|
||||||
#include <sol/reference.hpp>
|
#include <sol/reference.hpp>
|
||||||
#include <sol/make_reference.hpp>
|
#include <sol/make_reference.hpp>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
struct lua_value {
|
struct lua_value {
|
||||||
public:
|
public:
|
||||||
struct arr : detail::ebco<std::initializer_list<lua_value>> {
|
struct arr : detail::ebco<std::initializer_list<lua_value>> {
|
||||||
private:
|
private:
|
||||||
using base_t = detail::ebco<std::initializer_list<lua_value>>;
|
using base_t = detail::ebco<std::initializer_list<lua_value>>;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
using base_t::base_t;
|
using base_t::base_t;
|
||||||
};
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using is_reference_or_lua_value_init_list
|
using is_reference_or_lua_value_init_list
|
||||||
= meta::any<meta::is_specialization_of<T, std::initializer_list>, std::is_same<T, reference>, std::is_same<T, arr>>;
|
= meta::any<meta::is_specialization_of<T, std::initializer_list>, std::is_same<T, reference>, std::is_same<T, arr>>;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using is_lua_value_single_constructible = meta::any<std::is_same<T, lua_value>, is_reference_or_lua_value_init_list<T>>;
|
using is_lua_value_single_constructible = meta::any<std::is_same<T, lua_value>, is_reference_or_lua_value_init_list<T>>;
|
||||||
|
|
||||||
static lua_State*& thread_local_lua_state() {
|
static lua_State*& thread_local_lua_state() {
|
||||||
#if SOL_IS_ON(SOL_USE_THREAD_LOCAL_I_)
|
#if SOL_IS_ON(SOL_USE_THREAD_LOCAL_I_)
|
||||||
static thread_local lua_State* L = nullptr;
|
static thread_local lua_State* L = nullptr;
|
||||||
#else
|
#else
|
||||||
static lua_State* L = nullptr;
|
static lua_State* L = nullptr;
|
||||||
#endif
|
#endif
|
||||||
return L;
|
return L;
|
||||||
}
|
}
|
||||||
|
|
||||||
reference ref_value;
|
reference ref_value;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static void set_lua_state(lua_State* L) {
|
static void set_lua_state(lua_State* L) {
|
||||||
thread_local_lua_state() = L;
|
thread_local_lua_state() = L;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, meta::disable<is_reference_or_lua_value_init_list<meta::unqualified_t<T>>> = meta::enabler>
|
template <typename T, meta::disable<is_reference_or_lua_value_init_list<meta::unqualified_t<T>>> = meta::enabler>
|
||||||
lua_value(lua_State* L_, T&& value) : lua_value(((set_lua_state(L_)), std::forward<T>(value))) {
|
lua_value(lua_State* L_, T&& value) : lua_value(((set_lua_state(L_)), std::forward<T>(value))) {
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, meta::disable<is_lua_value_single_constructible<meta::unqualified_t<T>>> = meta::enabler>
|
template <typename T, meta::disable<is_lua_value_single_constructible<meta::unqualified_t<T>>> = meta::enabler>
|
||||||
lua_value(T&& value) : ref_value(make_reference(thread_local_lua_state(), std::forward<T>(value))) {
|
lua_value(T&& value) : ref_value(make_reference(thread_local_lua_state(), std::forward<T>(value))) {
|
||||||
}
|
}
|
||||||
|
|
||||||
lua_value(lua_State* L_, std::initializer_list<std::pair<lua_value, lua_value>> il)
|
lua_value(lua_State* L_, std::initializer_list<std::pair<lua_value, lua_value>> il)
|
||||||
: lua_value([&L_, &il]() {
|
: lua_value([&L_, &il]() {
|
||||||
set_lua_state(L_);
|
set_lua_state(L_);
|
||||||
return std::move(il);
|
return std::move(il);
|
||||||
}()) {
|
}()) {
|
||||||
}
|
}
|
||||||
|
|
||||||
lua_value(std::initializer_list<std::pair<lua_value, lua_value>> il) : ref_value(make_reference(thread_local_lua_state(), std::move(il))) {
|
lua_value(std::initializer_list<std::pair<lua_value, lua_value>> il) : ref_value(make_reference(thread_local_lua_state(), std::move(il))) {
|
||||||
}
|
}
|
||||||
|
|
||||||
lua_value(lua_State* L_, arr il)
|
lua_value(lua_State* L_, arr il)
|
||||||
: lua_value([&L_, &il]() {
|
: lua_value([&L_, &il]() {
|
||||||
set_lua_state(L_);
|
set_lua_state(L_);
|
||||||
return std::move(il);
|
return std::move(il);
|
||||||
}()) {
|
}()) {
|
||||||
}
|
}
|
||||||
|
|
||||||
lua_value(arr il) : ref_value(make_reference(thread_local_lua_state(), std::move(il.value()))) {
|
lua_value(arr il) : ref_value(make_reference(thread_local_lua_state(), std::move(il.value()))) {
|
||||||
}
|
}
|
||||||
|
|
||||||
lua_value(lua_State* L_, reference r)
|
lua_value(lua_State* L_, reference r)
|
||||||
: lua_value([&L_, &r]() {
|
: lua_value([&L_, &r]() {
|
||||||
set_lua_state(L_);
|
set_lua_state(L_);
|
||||||
return std::move(r);
|
return std::move(r);
|
||||||
}()) {
|
}()) {
|
||||||
}
|
}
|
||||||
|
|
||||||
lua_value(reference r) : ref_value(std::move(r)) {
|
lua_value(reference r) : ref_value(std::move(r)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
lua_value(const lua_value&) noexcept = default;
|
lua_value(const lua_value&) noexcept = default;
|
||||||
lua_value(lua_value&&) = default;
|
lua_value(lua_value&&) = default;
|
||||||
lua_value& operator=(const lua_value&) = default;
|
lua_value& operator=(const lua_value&) = default;
|
||||||
lua_value& operator=(lua_value&&) = default;
|
lua_value& operator=(lua_value&&) = default;
|
||||||
|
|
||||||
const reference& value() const& {
|
const reference& value() const& {
|
||||||
return ref_value;
|
return ref_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
reference& value() & {
|
reference& value() & {
|
||||||
return ref_value;
|
return ref_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
reference&& value() && {
|
reference&& value() && {
|
||||||
return std::move(ref_value);
|
return std::move(ref_value);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
decltype(auto) as() const {
|
decltype(auto) as() const {
|
||||||
ref_value.push();
|
ref_value.push();
|
||||||
return stack::pop<T>(ref_value.lua_state());
|
return stack::pop<T>(ref_value.lua_state());
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
bool is() const {
|
bool is() const {
|
||||||
int r = ref_value.registry_index();
|
int r = ref_value.registry_index();
|
||||||
if (r == LUA_REFNIL)
|
if (r == LUA_REFNIL)
|
||||||
return meta::any_same<meta::unqualified_t<T>, lua_nil_t, nullopt_t, std::nullptr_t>::value ? true : false;
|
return meta::any_same<meta::unqualified_t<T>, lua_nil_t, nullopt_t, std::nullptr_t>::value ? true : false;
|
||||||
if (r == LUA_NOREF)
|
if (r == LUA_NOREF)
|
||||||
return false;
|
return false;
|
||||||
auto pp = stack::push_pop(ref_value);
|
auto pp = stack::push_pop(ref_value);
|
||||||
return stack::check<T>(ref_value.lua_state(), -1, &no_panic);
|
return stack::check<T>(ref_value.lua_state(), -1, &no_panic);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
using array_value = typename lua_value::arr;
|
using array_value = typename lua_value::arr;
|
||||||
|
|
||||||
namespace stack {
|
namespace stack {
|
||||||
template <>
|
template <>
|
||||||
struct unqualified_pusher<lua_value> {
|
struct unqualified_pusher<lua_value> {
|
||||||
static int push(lua_State* L, const lua_value& lv) {
|
static int push(lua_State* L, const lua_value& lv) {
|
||||||
return stack::push(L, lv.value());
|
return stack::push(L, lv.value());
|
||||||
}
|
}
|
||||||
|
|
||||||
static int push(lua_State* L, lua_value&& lv) {
|
static int push(lua_State* L, lua_value&& lv) {
|
||||||
return stack::push(L, std::move(lv).value());
|
return stack::push(L, std::move(lv).value());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
struct unqualified_getter<lua_value> {
|
struct unqualified_getter<lua_value> {
|
||||||
static lua_value get(lua_State* L, int index, record& tracking) {
|
static lua_value get(lua_State* L, int index, record& tracking) {
|
||||||
return lua_value(L, stack::get<reference>(L, index, tracking));
|
return lua_value(L, stack::get<reference>(L, index, tracking));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace stack
|
} // namespace stack
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_LUA_VALUE_HPP
|
#endif // SOL_LUA_VALUE_HPP
|
||||||
|
|
524
extern/sol3/sol/packaged_coroutine.hpp
vendored
524
extern/sol3/sol/packaged_coroutine.hpp
vendored
|
@ -1,262 +1,262 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_PACKAGED_COROUTINE_HPP
|
#ifndef SOL_PACKAGED_COROUTINE_HPP
|
||||||
#define SOL_PACKAGED_COROUTINE_HPP
|
#define SOL_PACKAGED_COROUTINE_HPP
|
||||||
|
|
||||||
#include <sol/reference.hpp>
|
#include <sol/reference.hpp>
|
||||||
#include <sol/object.hpp>
|
#include <sol/object.hpp>
|
||||||
#include <sol/stack.hpp>
|
#include <sol/stack.hpp>
|
||||||
#include <sol/function_result.hpp>
|
#include <sol/function_result.hpp>
|
||||||
#include <sol/thread.hpp>
|
#include <sol/thread.hpp>
|
||||||
#include <sol/protected_handler.hpp>
|
#include <sol/protected_handler.hpp>
|
||||||
#include <sol/coroutine.hpp>
|
#include <sol/coroutine.hpp>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
|
||||||
class packaged_coroutine {
|
class packaged_coroutine {
|
||||||
private:
|
private:
|
||||||
lua_State* m_L;
|
lua_State* m_L;
|
||||||
sol::stateless_reference m_coroutine_reference;
|
sol::stateless_reference m_coroutine_reference;
|
||||||
sol::stateless_reference m_error_handler;
|
sol::stateless_reference m_error_handler;
|
||||||
sol::thread m_thread_reference;
|
sol::thread m_thread_reference;
|
||||||
|
|
||||||
void luacall(std::ptrdiff_t argcount, std::ptrdiff_t) {
|
void luacall(std::ptrdiff_t argcount, std::ptrdiff_t) {
|
||||||
#if SOL_LUA_VERSION_I_ >= 504
|
#if SOL_LUA_VERSION_I_ >= 504
|
||||||
int nresults;
|
int nresults;
|
||||||
stats = static_cast<call_status>(lua_resume(lua_state(), nullptr, static_cast<int>(argcount), &nresults));
|
stats = static_cast<call_status>(lua_resume(lua_state(), nullptr, static_cast<int>(argcount), &nresults));
|
||||||
#else
|
#else
|
||||||
stats = static_cast<call_status>(lua_resume(lua_state(), nullptr, static_cast<int>(argcount)));
|
stats = static_cast<call_status>(lua_resume(lua_state(), nullptr, static_cast<int>(argcount)));
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
template <std::size_t... I, typename... Ret>
|
template <std::size_t... I, typename... Ret>
|
||||||
auto invoke(types<Ret...>, std::index_sequence<I...>, std::ptrdiff_t n) {
|
auto invoke(types<Ret...>, std::index_sequence<I...>, std::ptrdiff_t n) {
|
||||||
luacall(n, sizeof...(Ret));
|
luacall(n, sizeof...(Ret));
|
||||||
return stack::pop<std::tuple<Ret...>>(lua_state());
|
return stack::pop<std::tuple<Ret...>>(lua_state());
|
||||||
}
|
}
|
||||||
|
|
||||||
template <std::size_t I, typename Ret>
|
template <std::size_t I, typename Ret>
|
||||||
Ret invoke(types<Ret>, std::index_sequence<I>, std::ptrdiff_t n) {
|
Ret invoke(types<Ret>, std::index_sequence<I>, std::ptrdiff_t n) {
|
||||||
luacall(n, 1);
|
luacall(n, 1);
|
||||||
return stack::pop<Ret>(lua_state());
|
return stack::pop<Ret>(lua_state());
|
||||||
}
|
}
|
||||||
|
|
||||||
template <std::size_t I>
|
template <std::size_t I>
|
||||||
void invoke(types<void>, std::index_sequence<I>, std::ptrdiff_t n) {
|
void invoke(types<void>, std::index_sequence<I>, std::ptrdiff_t n) {
|
||||||
luacall(n, 0);
|
luacall(n, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected_function_result invoke(types<>, std::index_sequence<>, std::ptrdiff_t n) {
|
protected_function_result invoke(types<>, std::index_sequence<>, std::ptrdiff_t n) {
|
||||||
int firstreturn = 1;
|
int firstreturn = 1;
|
||||||
luacall(n, LUA_MULTRET);
|
luacall(n, LUA_MULTRET);
|
||||||
int poststacksize = lua_gettop(this->lua_state());
|
int poststacksize = lua_gettop(this->lua_state());
|
||||||
int returncount = poststacksize - (firstreturn - 1);
|
int returncount = poststacksize - (firstreturn - 1);
|
||||||
if (error()) {
|
if (error()) {
|
||||||
if (m_error_handler.valid()) {
|
if (m_error_handler.valid()) {
|
||||||
string_view err = stack::get<string_view>(this->lua_state(), poststacksize);
|
string_view err = stack::get<string_view>(this->lua_state(), poststacksize);
|
||||||
m_error_handler.push();
|
m_error_handler.push();
|
||||||
stack::push(this->lua_state(), err);
|
stack::push(this->lua_state(), err);
|
||||||
lua_call(lua_state(), 1, 1);
|
lua_call(lua_state(), 1, 1);
|
||||||
}
|
}
|
||||||
return protected_function_result(this->lua_state(), lua_absindex(this->lua_state(), -1), 1, returncount, status());
|
return protected_function_result(this->lua_state(), lua_absindex(this->lua_state(), -1), 1, returncount, status());
|
||||||
}
|
}
|
||||||
return protected_function_result(this->lua_state(), firstreturn, returncount, returncount, status());
|
return protected_function_result(this->lua_state(), firstreturn, returncount, returncount, status());
|
||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
using base_t::lua_state;
|
using base_t::lua_state;
|
||||||
|
|
||||||
basic_packaged_coroutine() = default;
|
basic_packaged_coroutine() = default;
|
||||||
template <typename T,
|
template <typename T,
|
||||||
meta::enable<meta::neg<std::is_same<meta::unqualified_t<T>, basic_packaged_coroutine>>,
|
meta::enable<meta::neg<std::is_same<meta::unqualified_t<T>, basic_packaged_coroutine>>,
|
||||||
meta::neg<std::is_base_of<proxy_base_tag, meta::unqualified_t<T>>>, meta::neg<std::is_same<base_t, stack_reference>>,
|
meta::neg<std::is_base_of<proxy_base_tag, meta::unqualified_t<T>>>, meta::neg<std::is_same<base_t, stack_reference>>,
|
||||||
meta::neg<std::is_same<lua_nil_t, meta::unqualified_t<T>>>, is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
meta::neg<std::is_same<lua_nil_t, meta::unqualified_t<T>>>, is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
||||||
basic_packaged_coroutine(T&& r) noexcept
|
basic_packaged_coroutine(T&& r) noexcept
|
||||||
: base_t(std::forward<T>(r)), m_error_handler(detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) {
|
: base_t(std::forward<T>(r)), m_error_handler(detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) {
|
||||||
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
||||||
if (!is_function<meta::unqualified_t<T>>::value) {
|
if (!is_function<meta::unqualified_t<T>>::value) {
|
||||||
auto pp = stack::push_pop(*this);
|
auto pp = stack::push_pop(*this);
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_packaged_coroutine>(lua_state(), -1, handler);
|
stack::check<basic_packaged_coroutine>(lua_state(), -1, handler);
|
||||||
}
|
}
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
|
|
||||||
basic_packaged_coroutine(const basic_packaged_coroutine& other) = default;
|
basic_packaged_coroutine(const basic_packaged_coroutine& other) = default;
|
||||||
basic_packaged_coroutine& operator=(const basic_packaged_coroutine&) = default;
|
basic_packaged_coroutine& operator=(const basic_packaged_coroutine&) = default;
|
||||||
|
|
||||||
basic_packaged_coroutine(basic_packaged_coroutine&& other) noexcept
|
basic_packaged_coroutine(basic_packaged_coroutine&& other) noexcept
|
||||||
: base_t(std::move(other)), m_error_handler(this->lua_state(), std::move(other.m_error_handler)) {
|
: base_t(std::move(other)), m_error_handler(this->lua_state(), std::move(other.m_error_handler)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
basic_packaged_coroutine& operator=(basic_packaged_coroutine&& other) noexcept {
|
basic_packaged_coroutine& operator=(basic_packaged_coroutine&& other) noexcept {
|
||||||
base_t::operator=(std::move(other));
|
base_t::operator=(std::move(other));
|
||||||
// must change the state, since it could change on the coroutine type
|
// must change the state, since it could change on the coroutine type
|
||||||
m_error_handler.abandon();
|
m_error_handler.abandon();
|
||||||
m_error_handler = handler_t(this->lua_state(), std::move(other.m_error_handler));
|
m_error_handler = handler_t(this->lua_state(), std::move(other.m_error_handler));
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
basic_packaged_coroutine(const basic_function<base_t>& b) noexcept
|
basic_packaged_coroutine(const basic_function<base_t>& b) noexcept
|
||||||
: basic_packaged_coroutine(b, detail::get_default_handler<reference, is_main_threaded_v<base_t>>(b.lua_state())) {
|
: basic_packaged_coroutine(b, detail::get_default_handler<reference, is_main_threaded_v<base_t>>(b.lua_state())) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(basic_function<base_t>&& b) noexcept
|
basic_packaged_coroutine(basic_function<base_t>&& b) noexcept
|
||||||
: basic_packaged_coroutine(std::move(b), detail::get_default_handler<reference, is_main_threaded_v<base_t>>(b.lua_state())) {
|
: basic_packaged_coroutine(std::move(b), detail::get_default_handler<reference, is_main_threaded_v<base_t>>(b.lua_state())) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(const basic_function<base_t>& b, handler_t eh) noexcept : base_t(b), m_error_handler(std::move(eh)) {
|
basic_packaged_coroutine(const basic_function<base_t>& b, handler_t eh) noexcept : base_t(b), m_error_handler(std::move(eh)) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(basic_function<base_t>&& b, handler_t eh) noexcept : base_t(std::move(b)), m_error_handler(std::move(eh)) {
|
basic_packaged_coroutine(basic_function<base_t>&& b, handler_t eh) noexcept : base_t(std::move(b)), m_error_handler(std::move(eh)) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(const stack_reference& r) noexcept
|
basic_packaged_coroutine(const stack_reference& r) noexcept
|
||||||
: basic_packaged_coroutine(r.lua_state(), r.stack_index(), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) {
|
: basic_packaged_coroutine(r.lua_state(), r.stack_index(), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(stack_reference&& r) noexcept
|
basic_packaged_coroutine(stack_reference&& r) noexcept
|
||||||
: basic_packaged_coroutine(r.lua_state(), r.stack_index(), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) {
|
: basic_packaged_coroutine(r.lua_state(), r.stack_index(), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(const stack_reference& r, handler_t eh) noexcept : basic_packaged_coroutine(r.lua_state(), r.stack_index(), std::move(eh)) {
|
basic_packaged_coroutine(const stack_reference& r, handler_t eh) noexcept : basic_packaged_coroutine(r.lua_state(), r.stack_index(), std::move(eh)) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(stack_reference&& r, handler_t eh) noexcept : basic_packaged_coroutine(r.lua_state(), r.stack_index(), std::move(eh)) {
|
basic_packaged_coroutine(stack_reference&& r, handler_t eh) noexcept : basic_packaged_coroutine(r.lua_state(), r.stack_index(), std::move(eh)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Super>
|
template <typename Super>
|
||||||
basic_packaged_coroutine(const proxy_base<Super>& p)
|
basic_packaged_coroutine(const proxy_base<Super>& p)
|
||||||
: basic_packaged_coroutine(p, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(p.lua_state())) {
|
: basic_packaged_coroutine(p, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(p.lua_state())) {
|
||||||
}
|
}
|
||||||
template <typename Super>
|
template <typename Super>
|
||||||
basic_packaged_coroutine(proxy_base<Super>&& p)
|
basic_packaged_coroutine(proxy_base<Super>&& p)
|
||||||
: basic_packaged_coroutine(std::move(p), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(p.lua_state())) {
|
: basic_packaged_coroutine(std::move(p), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(p.lua_state())) {
|
||||||
}
|
}
|
||||||
template <typename Proxy, typename HandlerReference,
|
template <typename Proxy, typename HandlerReference,
|
||||||
meta::enable<std::is_base_of<proxy_base_tag, meta::unqualified_t<Proxy>>, meta::neg<is_lua_index<meta::unqualified_t<HandlerReference>>>> = meta::enabler>
|
meta::enable<std::is_base_of<proxy_base_tag, meta::unqualified_t<Proxy>>, meta::neg<is_lua_index<meta::unqualified_t<HandlerReference>>>> = meta::enabler>
|
||||||
basic_packaged_coroutine(Proxy&& p, HandlerReference&& eh) : basic_packaged_coroutine(detail::force_cast<base_t>(p), std::forward<HandlerReference>(eh)) {
|
basic_packaged_coroutine(Proxy&& p, HandlerReference&& eh) : basic_packaged_coroutine(detail::force_cast<base_t>(p), std::forward<HandlerReference>(eh)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
||||||
basic_packaged_coroutine(lua_State* L, T&& r) noexcept
|
basic_packaged_coroutine(lua_State* L, T&& r) noexcept
|
||||||
: basic_packaged_coroutine(L, std::forward<T>(r), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
: basic_packaged_coroutine(L, std::forward<T>(r), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
||||||
}
|
}
|
||||||
template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
|
||||||
basic_packaged_coroutine(lua_State* L, T&& r, handler_t eh) : base_t(L, std::forward<T>(r)), m_error_handler(std::move(eh)) {
|
basic_packaged_coroutine(lua_State* L, T&& r, handler_t eh) : base_t(L, std::forward<T>(r)), m_error_handler(std::move(eh)) {
|
||||||
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
||||||
auto pp = stack::push_pop(*this);
|
auto pp = stack::push_pop(*this);
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_packaged_coroutine>(lua_state(), -1, handler);
|
stack::check<basic_packaged_coroutine>(lua_state(), -1, handler);
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
|
|
||||||
basic_packaged_coroutine(lua_nil_t n) : base_t(n), m_error_handler(n) {
|
basic_packaged_coroutine(lua_nil_t n) : base_t(n), m_error_handler(n) {
|
||||||
}
|
}
|
||||||
|
|
||||||
basic_packaged_coroutine(lua_State* L, int index = -1)
|
basic_packaged_coroutine(lua_State* L, int index = -1)
|
||||||
: basic_packaged_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
: basic_packaged_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(lua_State* L, int index, handler_t eh) : base_t(L, index), m_error_handler(std::move(eh)) {
|
basic_packaged_coroutine(lua_State* L, int index, handler_t eh) : base_t(L, index), m_error_handler(std::move(eh)) {
|
||||||
#ifdef SOL_SAFE_REFERENCES
|
#ifdef SOL_SAFE_REFERENCES
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_packaged_coroutine>(L, index, handler);
|
stack::check<basic_packaged_coroutine>(L, index, handler);
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(lua_State* L, absolute_index index)
|
basic_packaged_coroutine(lua_State* L, absolute_index index)
|
||||||
: basic_packaged_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
: basic_packaged_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(lua_State* L, absolute_index index, handler_t eh) : base_t(L, index), m_error_handler(std::move(eh)) {
|
basic_packaged_coroutine(lua_State* L, absolute_index index, handler_t eh) : base_t(L, index), m_error_handler(std::move(eh)) {
|
||||||
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_packaged_coroutine>(L, index, handler);
|
stack::check<basic_packaged_coroutine>(L, index, handler);
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(lua_State* L, raw_index index)
|
basic_packaged_coroutine(lua_State* L, raw_index index)
|
||||||
: basic_packaged_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
: basic_packaged_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(lua_State* L, raw_index index, handler_t eh) : base_t(L, index), m_error_handler(std::move(eh)) {
|
basic_packaged_coroutine(lua_State* L, raw_index index, handler_t eh) : base_t(L, index), m_error_handler(std::move(eh)) {
|
||||||
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_packaged_coroutine>(L, index, handler);
|
stack::check<basic_packaged_coroutine>(L, index, handler);
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(lua_State* L, ref_index index)
|
basic_packaged_coroutine(lua_State* L, ref_index index)
|
||||||
: basic_packaged_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
: basic_packaged_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
|
||||||
}
|
}
|
||||||
basic_packaged_coroutine(lua_State* L, ref_index index, handler_t eh) : base_t(L, index), m_error_handler(std::move(eh)) {
|
basic_packaged_coroutine(lua_State* L, ref_index index, handler_t eh) : base_t(L, index), m_error_handler(std::move(eh)) {
|
||||||
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
|
||||||
auto pp = stack::push_pop(*this);
|
auto pp = stack::push_pop(*this);
|
||||||
constructor_handler handler {};
|
constructor_handler handler {};
|
||||||
stack::check<basic_packaged_coroutine>(lua_state(), -1, handler);
|
stack::check<basic_packaged_coroutine>(lua_state(), -1, handler);
|
||||||
#endif // Safety
|
#endif // Safety
|
||||||
}
|
}
|
||||||
|
|
||||||
call_status status() const noexcept {
|
call_status status() const noexcept {
|
||||||
return stats;
|
return stats;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool error() const noexcept {
|
bool error() const noexcept {
|
||||||
call_status cs = status();
|
call_status cs = status();
|
||||||
return cs != call_status::ok && cs != call_status::yielded;
|
return cs != call_status::ok && cs != call_status::yielded;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool runnable() const noexcept {
|
bool runnable() const noexcept {
|
||||||
return base_t::valid() && (status() == call_status::yielded);
|
return base_t::valid() && (status() == call_status::yielded);
|
||||||
}
|
}
|
||||||
|
|
||||||
reference error_handler() const noexcept {
|
reference error_handler() const noexcept {
|
||||||
return reference(m_L, registry_index(m_error_handler.index));
|
return reference(m_L, registry_index(m_error_handler.index));
|
||||||
}
|
}
|
||||||
|
|
||||||
set_error_handler(reference new_error_handler) noexcept {
|
set_error_handler(reference new_error_handler) noexcept {
|
||||||
this->m_error_handler = stateless_reference(this->m_L, std::move(new_error_handler));
|
this->m_error_handler = stateless_reference(this->m_L, std::move(new_error_handler));
|
||||||
}
|
}
|
||||||
|
|
||||||
explicit operator bool() const noexcept {
|
explicit operator bool() const noexcept {
|
||||||
return runnable();
|
return runnable();
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
protected_function_result operator()(Args&&... args) {
|
protected_function_result operator()(Args&&... args) {
|
||||||
return call<>(std::forward<Args>(args)...);
|
return call<>(std::forward<Args>(args)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename... Ret, typename... Args>
|
template <typename... Ret, typename... Args>
|
||||||
decltype(auto) operator()(types<Ret...>, Args&&... args) {
|
decltype(auto) operator()(types<Ret...>, Args&&... args) {
|
||||||
return call<Ret...>(std::forward<Args>(args)...);
|
return call<Ret...>(std::forward<Args>(args)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename... Ret, typename... Args>
|
template <typename... Ret, typename... Args>
|
||||||
decltype(auto) call(Args&&... args) {
|
decltype(auto) call(Args&&... args) {
|
||||||
// some users screw up coroutine.create
|
// some users screw up coroutine.create
|
||||||
// and try to use it with sol::coroutine without ever calling the first resume in Lua
|
// and try to use it with sol::coroutine without ever calling the first resume in Lua
|
||||||
// this makes the stack incompatible with other kinds of stacks: protect against this
|
// this makes the stack incompatible with other kinds of stacks: protect against this
|
||||||
// make sure coroutines don't screw us over
|
// make sure coroutines don't screw us over
|
||||||
base_t::push();
|
base_t::push();
|
||||||
int pushcount = stack::multi_push_reference(lua_state(), std::forward<Args>(args)...);
|
int pushcount = stack::multi_push_reference(lua_state(), std::forward<Args>(args)...);
|
||||||
return invoke(types<Ret...>(), std::make_index_sequence<sizeof...(Ret)>(), pushcount);
|
return invoke(types<Ret...>(), std::make_index_sequence<sizeof...(Ret)>(), pushcount);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_PACKAGED_COROUTINE_HPP
|
#endif // SOL_PACKAGED_COROUTINE_HPP
|
||||||
|
|
550
extern/sol3/sol/pairs_iterator.hpp
vendored
550
extern/sol3/sol/pairs_iterator.hpp
vendored
|
@ -1,275 +1,275 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_PAIRS_ITERATOR_HPP
|
#ifndef SOL_PAIRS_ITERATOR_HPP
|
||||||
#define SOL_PAIRS_ITERATOR_HPP
|
#define SOL_PAIRS_ITERATOR_HPP
|
||||||
|
|
||||||
#include <sol/version.hpp>
|
#include <sol/version.hpp>
|
||||||
|
|
||||||
#include <sol/reference.hpp>
|
#include <sol/reference.hpp>
|
||||||
#include <sol/stack_reference.hpp>
|
#include <sol/stack_reference.hpp>
|
||||||
#include <sol/table_iterator.hpp>
|
#include <sol/table_iterator.hpp>
|
||||||
#include <sol/protected_function.hpp>
|
#include <sol/protected_function.hpp>
|
||||||
|
|
||||||
#include <sol/stack/detail/pairs.hpp>
|
#include <sol/stack/detail/pairs.hpp>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
|
|
||||||
struct pairs_sentinel { };
|
struct pairs_sentinel { };
|
||||||
|
|
||||||
class pairs_iterator {
|
class pairs_iterator {
|
||||||
private:
|
private:
|
||||||
inline static constexpr int empty_key_index = -1;
|
inline static constexpr int empty_key_index = -1;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
using key_type = object;
|
using key_type = object;
|
||||||
using mapped_type = object;
|
using mapped_type = object;
|
||||||
using value_type = std::pair<object, object>;
|
using value_type = std::pair<object, object>;
|
||||||
using iterator_category = std::input_iterator_tag;
|
using iterator_category = std::input_iterator_tag;
|
||||||
using difference_type = std::ptrdiff_t;
|
using difference_type = std::ptrdiff_t;
|
||||||
using pointer = value_type*;
|
using pointer = value_type*;
|
||||||
using const_pointer = value_type const*;
|
using const_pointer = value_type const*;
|
||||||
using reference = value_type&;
|
using reference = value_type&;
|
||||||
using const_reference = const value_type&;
|
using const_reference = const value_type&;
|
||||||
|
|
||||||
pairs_iterator() noexcept
|
pairs_iterator() noexcept
|
||||||
: m_L(nullptr)
|
: m_L(nullptr)
|
||||||
, m_next_function_ref(lua_nil)
|
, m_next_function_ref(lua_nil)
|
||||||
, m_table_ref(lua_nil)
|
, m_table_ref(lua_nil)
|
||||||
, m_cached_key_value_pair({ lua_nil, lua_nil })
|
, m_cached_key_value_pair({ lua_nil, lua_nil })
|
||||||
, m_key_index(empty_key_index)
|
, m_key_index(empty_key_index)
|
||||||
, m_iteration_index(0) {
|
, m_iteration_index(0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
pairs_iterator(const pairs_iterator&) = delete;
|
pairs_iterator(const pairs_iterator&) = delete;
|
||||||
pairs_iterator& operator=(const pairs_iterator&) = delete;
|
pairs_iterator& operator=(const pairs_iterator&) = delete;
|
||||||
|
|
||||||
pairs_iterator(pairs_iterator&& right) noexcept
|
pairs_iterator(pairs_iterator&& right) noexcept
|
||||||
: m_L(right.m_L)
|
: m_L(right.m_L)
|
||||||
, m_next_function_ref(std::move(right.m_next_function_ref))
|
, m_next_function_ref(std::move(right.m_next_function_ref))
|
||||||
, m_table_ref(std::move(right.m_table_ref))
|
, m_table_ref(std::move(right.m_table_ref))
|
||||||
, m_cached_key_value_pair(std::move(right.m_cached_key_value_pair))
|
, m_cached_key_value_pair(std::move(right.m_cached_key_value_pair))
|
||||||
, m_key_index(right.m_key_index)
|
, m_key_index(right.m_key_index)
|
||||||
, m_iteration_index(right.m_iteration_index) {
|
, m_iteration_index(right.m_iteration_index) {
|
||||||
right.m_key_index = empty_key_index;
|
right.m_key_index = empty_key_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
pairs_iterator& operator=(pairs_iterator&& right) noexcept {
|
pairs_iterator& operator=(pairs_iterator&& right) noexcept {
|
||||||
m_L = right.m_L;
|
m_L = right.m_L;
|
||||||
m_next_function_ref = std::move(right.m_next_function_ref);
|
m_next_function_ref = std::move(right.m_next_function_ref);
|
||||||
m_table_ref = std::move(right.m_table_ref);
|
m_table_ref = std::move(right.m_table_ref);
|
||||||
m_cached_key_value_pair = std::move(right.m_cached_key_value_pair);
|
m_cached_key_value_pair = std::move(right.m_cached_key_value_pair);
|
||||||
m_key_index = right.m_key_index;
|
m_key_index = right.m_key_index;
|
||||||
m_iteration_index = right.m_iteration_index;
|
m_iteration_index = right.m_iteration_index;
|
||||||
right.m_key_index = empty_key_index;
|
right.m_key_index = empty_key_index;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Source>
|
template <typename Source>
|
||||||
pairs_iterator(const Source& source_) noexcept : m_L(source_.lua_state()), m_key_index(empty_key_index), m_iteration_index(0) {
|
pairs_iterator(const Source& source_) noexcept : m_L(source_.lua_state()), m_key_index(empty_key_index), m_iteration_index(0) {
|
||||||
if (m_L == nullptr || !source_.valid()) {
|
if (m_L == nullptr || !source_.valid()) {
|
||||||
m_key_index = empty_key_index;
|
m_key_index = empty_key_index;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
int source_index = -source_.push(m_L);
|
int source_index = -source_.push(m_L);
|
||||||
int abs_source_index = lua_absindex(m_L, source_index);
|
int abs_source_index = lua_absindex(m_L, source_index);
|
||||||
int metatable_exists = lua_getmetatable(m_L, abs_source_index);
|
int metatable_exists = lua_getmetatable(m_L, abs_source_index);
|
||||||
lua_remove(m_L, abs_source_index);
|
lua_remove(m_L, abs_source_index);
|
||||||
if (metatable_exists == 1) {
|
if (metatable_exists == 1) {
|
||||||
// just has a metatable, but does it have __pairs ?
|
// just has a metatable, but does it have __pairs ?
|
||||||
stack_reference metatable(m_L, raw_index(abs_source_index));
|
stack_reference metatable(m_L, raw_index(abs_source_index));
|
||||||
stack::get_field<is_global_table_v<Source>, true>(m_L, meta_function::pairs, metatable.stack_index());
|
stack::get_field<is_global_table_v<Source>, true>(m_L, meta_function::pairs, metatable.stack_index());
|
||||||
optional<protected_function> maybe_pairs_function = stack::pop<optional<protected_function>>(m_L);
|
optional<protected_function> maybe_pairs_function = stack::pop<optional<protected_function>>(m_L);
|
||||||
if (maybe_pairs_function.has_value()) {
|
if (maybe_pairs_function.has_value()) {
|
||||||
protected_function& pairs_function = *maybe_pairs_function;
|
protected_function& pairs_function = *maybe_pairs_function;
|
||||||
protected_function_result next_fn_and_table_and_first_key = pairs_function(source_);
|
protected_function_result next_fn_and_table_and_first_key = pairs_function(source_);
|
||||||
if (next_fn_and_table_and_first_key.valid()) {
|
if (next_fn_and_table_and_first_key.valid()) {
|
||||||
m_next_function_ref = next_fn_and_table_and_first_key.get<protected_function>(0);
|
m_next_function_ref = next_fn_and_table_and_first_key.get<protected_function>(0);
|
||||||
m_table_ref = next_fn_and_table_and_first_key.get<sol::reference>(1);
|
m_table_ref = next_fn_and_table_and_first_key.get<sol::reference>(1);
|
||||||
m_key_index = next_fn_and_table_and_first_key.stack_index() - 1;
|
m_key_index = next_fn_and_table_and_first_key.stack_index() - 1;
|
||||||
// remove next function and table
|
// remove next function and table
|
||||||
lua_remove(m_L, m_key_index);
|
lua_remove(m_L, m_key_index);
|
||||||
lua_remove(m_L, m_key_index);
|
lua_remove(m_L, m_key_index);
|
||||||
next_fn_and_table_and_first_key.abandon();
|
next_fn_and_table_and_first_key.abandon();
|
||||||
lua_remove(m_L, abs_source_index);
|
lua_remove(m_L, abs_source_index);
|
||||||
this->operator++();
|
this->operator++();
|
||||||
m_iteration_index = 0;
|
m_iteration_index = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
auto maybe_next = stack::stack_detail::find_lua_next_function(m_L);
|
auto maybe_next = stack::stack_detail::find_lua_next_function(m_L);
|
||||||
if (maybe_next.has_value()) {
|
if (maybe_next.has_value()) {
|
||||||
m_next_function_ref = std::move(*maybe_next);
|
m_next_function_ref = std::move(*maybe_next);
|
||||||
m_table_ref = source_;
|
m_table_ref = source_;
|
||||||
|
|
||||||
stack::push(m_L, lua_nil);
|
stack::push(m_L, lua_nil);
|
||||||
m_key_index = lua_gettop(m_L);
|
m_key_index = lua_gettop(m_L);
|
||||||
this->operator++();
|
this->operator++();
|
||||||
m_iteration_index = 0;
|
m_iteration_index = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// okay, so none of the above worked and now we need to create
|
// okay, so none of the above worked and now we need to create
|
||||||
// a shim / polyfill instead
|
// a shim / polyfill instead
|
||||||
stack::push(m_L, &stack::stack_detail::c_lua_next);
|
stack::push(m_L, &stack::stack_detail::c_lua_next);
|
||||||
m_next_function_ref = stack::pop<protected_function>(m_L);
|
m_next_function_ref = stack::pop<protected_function>(m_L);
|
||||||
m_table_ref = source_;
|
m_table_ref = source_;
|
||||||
stack::push(m_L, lua_nil);
|
stack::push(m_L, lua_nil);
|
||||||
m_key_index = lua_gettop(m_L);
|
m_key_index = lua_gettop(m_L);
|
||||||
this->operator++();
|
this->operator++();
|
||||||
m_iteration_index = 0;
|
m_iteration_index = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
pairs_iterator& operator++() {
|
pairs_iterator& operator++() {
|
||||||
if (m_key_index == empty_key_index) {
|
if (m_key_index == empty_key_index) {
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
sol::protected_function_result next_results = m_next_function_ref(m_table_ref, stack_reference(m_L, m_key_index));
|
sol::protected_function_result next_results = m_next_function_ref(m_table_ref, stack_reference(m_L, m_key_index));
|
||||||
if (!next_results.valid()) {
|
if (!next_results.valid()) {
|
||||||
// TODO: abort, or throw an error?
|
// TODO: abort, or throw an error?
|
||||||
m_clear();
|
m_clear();
|
||||||
m_key_index = empty_key_index;
|
m_key_index = empty_key_index;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
int next_results_count = next_results.return_count();
|
int next_results_count = next_results.return_count();
|
||||||
if (next_results_count < 2) {
|
if (next_results_count < 2) {
|
||||||
// iteration is over!
|
// iteration is over!
|
||||||
next_results.abandon();
|
next_results.abandon();
|
||||||
lua_settop(m_L, m_key_index - 1);
|
lua_settop(m_L, m_key_index - 1);
|
||||||
m_key_index = empty_key_index;
|
m_key_index = empty_key_index;
|
||||||
++m_iteration_index;
|
++m_iteration_index;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
lua_remove(m_L, m_key_index);
|
lua_remove(m_L, m_key_index);
|
||||||
m_key_index = next_results.stack_index() - 1;
|
m_key_index = next_results.stack_index() - 1;
|
||||||
m_cached_key_value_pair.first = stack::get<object>(m_L, m_key_index);
|
m_cached_key_value_pair.first = stack::get<object>(m_L, m_key_index);
|
||||||
m_cached_key_value_pair.second = stack::get<object>(m_L, m_key_index + 1);
|
m_cached_key_value_pair.second = stack::get<object>(m_L, m_key_index + 1);
|
||||||
lua_settop(m_L, m_key_index);
|
lua_settop(m_L, m_key_index);
|
||||||
next_results.abandon();
|
next_results.abandon();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
++m_iteration_index;
|
++m_iteration_index;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::ptrdiff_t index() const {
|
std::ptrdiff_t index() const {
|
||||||
return static_cast<std::ptrdiff_t>(m_iteration_index);
|
return static_cast<std::ptrdiff_t>(m_iteration_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
const_reference operator*() const noexcept {
|
const_reference operator*() const noexcept {
|
||||||
return m_cached_key_value_pair;
|
return m_cached_key_value_pair;
|
||||||
}
|
}
|
||||||
|
|
||||||
reference operator*() noexcept {
|
reference operator*() noexcept {
|
||||||
return m_cached_key_value_pair;
|
return m_cached_key_value_pair;
|
||||||
}
|
}
|
||||||
|
|
||||||
friend bool operator==(const pairs_iterator& left, const pairs_iterator& right) noexcept {
|
friend bool operator==(const pairs_iterator& left, const pairs_iterator& right) noexcept {
|
||||||
return left.m_table_ref == right.m_table_ref && left.m_iteration_index == right.m_iteration_index;
|
return left.m_table_ref == right.m_table_ref && left.m_iteration_index == right.m_iteration_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
friend bool operator!=(const pairs_iterator& left, const pairs_iterator& right) noexcept {
|
friend bool operator!=(const pairs_iterator& left, const pairs_iterator& right) noexcept {
|
||||||
return left.m_table_ref != right.m_table_ref || left.m_iteration_index != right.m_iteration_index;
|
return left.m_table_ref != right.m_table_ref || left.m_iteration_index != right.m_iteration_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
friend bool operator==(const pairs_iterator& left, const pairs_sentinel&) noexcept {
|
friend bool operator==(const pairs_iterator& left, const pairs_sentinel&) noexcept {
|
||||||
return left.m_key_index == empty_key_index;
|
return left.m_key_index == empty_key_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
friend bool operator!=(const pairs_iterator& left, const pairs_sentinel&) noexcept {
|
friend bool operator!=(const pairs_iterator& left, const pairs_sentinel&) noexcept {
|
||||||
return left.m_key_index != empty_key_index;
|
return left.m_key_index != empty_key_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
friend bool operator==(const pairs_sentinel&, const pairs_iterator& left) noexcept {
|
friend bool operator==(const pairs_sentinel&, const pairs_iterator& left) noexcept {
|
||||||
return left.m_key_index == empty_key_index;
|
return left.m_key_index == empty_key_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
friend bool operator!=(const pairs_sentinel&, const pairs_iterator& left) noexcept {
|
friend bool operator!=(const pairs_sentinel&, const pairs_iterator& left) noexcept {
|
||||||
return left.m_key_index != empty_key_index;
|
return left.m_key_index != empty_key_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
~pairs_iterator() {
|
~pairs_iterator() {
|
||||||
if (m_key_index != empty_key_index) {
|
if (m_key_index != empty_key_index) {
|
||||||
m_clear();
|
m_clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void m_clear() noexcept {
|
void m_clear() noexcept {
|
||||||
lua_remove(m_L, m_key_index);
|
lua_remove(m_L, m_key_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
lua_State* m_L;
|
lua_State* m_L;
|
||||||
protected_function m_next_function_ref;
|
protected_function m_next_function_ref;
|
||||||
sol::reference m_table_ref;
|
sol::reference m_table_ref;
|
||||||
std::pair<object, object> m_cached_key_value_pair;
|
std::pair<object, object> m_cached_key_value_pair;
|
||||||
int m_key_index;
|
int m_key_index;
|
||||||
int m_iteration_index;
|
int m_iteration_index;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename Source>
|
template <typename Source>
|
||||||
class basic_pairs_range {
|
class basic_pairs_range {
|
||||||
private:
|
private:
|
||||||
using source_t = std::add_lvalue_reference_t<Source>;
|
using source_t = std::add_lvalue_reference_t<Source>;
|
||||||
source_t m_source;
|
source_t m_source;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
using iterator = pairs_iterator;
|
using iterator = pairs_iterator;
|
||||||
using const_iterator = pairs_iterator;
|
using const_iterator = pairs_iterator;
|
||||||
|
|
||||||
basic_pairs_range(source_t source_) noexcept : m_source(source_) {
|
basic_pairs_range(source_t source_) noexcept : m_source(source_) {
|
||||||
}
|
}
|
||||||
|
|
||||||
iterator begin() noexcept {
|
iterator begin() noexcept {
|
||||||
return iterator(m_source);
|
return iterator(m_source);
|
||||||
}
|
}
|
||||||
|
|
||||||
iterator begin() const noexcept {
|
iterator begin() const noexcept {
|
||||||
return iterator(m_source);
|
return iterator(m_source);
|
||||||
}
|
}
|
||||||
|
|
||||||
const_iterator cbegin() const noexcept {
|
const_iterator cbegin() const noexcept {
|
||||||
return const_iterator(m_source);
|
return const_iterator(m_source);
|
||||||
}
|
}
|
||||||
|
|
||||||
pairs_sentinel end() noexcept {
|
pairs_sentinel end() noexcept {
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
pairs_sentinel end() const noexcept {
|
pairs_sentinel end() const noexcept {
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
pairs_sentinel cend() const noexcept {
|
pairs_sentinel cend() const noexcept {
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_PAIRS_ITERATOR_HPP
|
#endif // SOL_PAIRS_ITERATOR_HPP
|
||||||
|
|
204
extern/sol3/sol/pointer_like.hpp
vendored
204
extern/sol3/sol/pointer_like.hpp
vendored
|
@ -1,102 +1,102 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_POINTER_LIKE_HPP
|
#ifndef SOL_POINTER_LIKE_HPP
|
||||||
#define SOL_POINTER_LIKE_HPP
|
#define SOL_POINTER_LIKE_HPP
|
||||||
|
|
||||||
#include <sol/base_traits.hpp>
|
#include <sol/base_traits.hpp>
|
||||||
|
|
||||||
#include <utility>
|
#include <utility>
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
|
|
||||||
namespace meta {
|
namespace meta {
|
||||||
namespace meta_detail {
|
namespace meta_detail {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using is_dereferenceable_test = decltype(*std::declval<T>());
|
using is_dereferenceable_test = decltype(*std::declval<T>());
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using is_explicitly_dereferenceable_test = decltype(std::declval<T>().operator*());
|
using is_explicitly_dereferenceable_test = decltype(std::declval<T>().operator*());
|
||||||
} // namespace meta_detail
|
} // namespace meta_detail
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using is_pointer_like = std::integral_constant<bool,
|
using is_pointer_like = std::integral_constant<bool,
|
||||||
!std::is_array_v<T> && (std::is_pointer_v<T> || is_detected_v<meta_detail::is_explicitly_dereferenceable_test, T>)>;
|
!std::is_array_v<T> && (std::is_pointer_v<T> || is_detected_v<meta_detail::is_explicitly_dereferenceable_test, T>)>;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
constexpr inline bool is_pointer_like_v = is_pointer_like<T>::value;
|
constexpr inline bool is_pointer_like_v = is_pointer_like<T>::value;
|
||||||
} // namespace meta
|
} // namespace meta
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
auto unwrap(T&& item) -> decltype(std::forward<T>(item)) {
|
auto unwrap(T&& item) -> decltype(std::forward<T>(item)) {
|
||||||
return std::forward<T>(item);
|
return std::forward<T>(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
T& unwrap(std::reference_wrapper<T> arg) {
|
T& unwrap(std::reference_wrapper<T> arg) {
|
||||||
return arg.get();
|
return arg.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline decltype(auto) deref(T&& item) {
|
inline decltype(auto) deref(T&& item) {
|
||||||
using Tu = meta::unqualified_t<T>;
|
using Tu = meta::unqualified_t<T>;
|
||||||
if constexpr (meta::is_pointer_like_v<Tu>) {
|
if constexpr (meta::is_pointer_like_v<Tu>) {
|
||||||
return *std::forward<T>(item);
|
return *std::forward<T>(item);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return std::forward<T>(item);
|
return std::forward<T>(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline decltype(auto) deref_move_only(T&& item) {
|
inline decltype(auto) deref_move_only(T&& item) {
|
||||||
using Tu = meta::unqualified_t<T>;
|
using Tu = meta::unqualified_t<T>;
|
||||||
if constexpr (meta::is_pointer_like_v<Tu> && !std::is_pointer_v<Tu> && !std::is_copy_constructible_v<Tu>) {
|
if constexpr (meta::is_pointer_like_v<Tu> && !std::is_pointer_v<Tu> && !std::is_copy_constructible_v<Tu>) {
|
||||||
return *std::forward<T>(item);
|
return *std::forward<T>(item);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return std::forward<T>(item);
|
return std::forward<T>(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* ptr(T& val) {
|
inline T* ptr(T& val) {
|
||||||
return std::addressof(val);
|
return std::addressof(val);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* ptr(std::reference_wrapper<T> val) {
|
inline T* ptr(std::reference_wrapper<T> val) {
|
||||||
return std::addressof(val.get());
|
return std::addressof(val.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline T* ptr(T* val) {
|
inline T* ptr(T* val) {
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_POINTER_LIKE_HPP
|
#endif // SOL_POINTER_LIKE_HPP
|
||||||
|
|
94
extern/sol3/sol/prologue.hpp
vendored
94
extern/sol3/sol/prologue.hpp
vendored
|
@ -1,47 +1,47 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
// clang-format off
|
// clang-format off
|
||||||
|
|
||||||
#if defined(SOL_PROLOGUE_I_)
|
#if defined(SOL_PROLOGUE_I_)
|
||||||
#error "[sol2] Library Prologue was already included in translation unit and not properly ended with an epilogue."
|
#error "[sol2] Library Prologue was already included in translation unit and not properly ended with an epilogue."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define SOL_PROLOGUE_I_ 1
|
#define SOL_PROLOGUE_I_ 1
|
||||||
|
|
||||||
|
|
||||||
#if SOL_IS_ON(SOL_BUILD_CXX_MODE_I_)
|
#if SOL_IS_ON(SOL_BUILD_CXX_MODE_I_)
|
||||||
#define _FWD(...) static_cast<decltype( __VA_ARGS__ )&&>( __VA_ARGS__ )
|
#define _FWD(...) static_cast<decltype( __VA_ARGS__ )&&>( __VA_ARGS__ )
|
||||||
|
|
||||||
#if SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
#if SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
|
||||||
#define _MOVE(...) static_cast<__typeof( __VA_ARGS__ )&&>( __VA_ARGS__ )
|
#define _MOVE(...) static_cast<__typeof( __VA_ARGS__ )&&>( __VA_ARGS__ )
|
||||||
#else
|
#else
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
|
|
||||||
#define _MOVE(...) static_cast<::std::remove_reference_t<( __VA_ARGS__ )>&&>( __VA_OPT__(,) )
|
#define _MOVE(...) static_cast<::std::remove_reference_t<( __VA_ARGS__ )>&&>( __VA_OPT__(,) )
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
702
extern/sol3/sol/stack.hpp
vendored
702
extern/sol3/sol/stack.hpp
vendored
|
@ -1,351 +1,351 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_STACK_HPP
|
#ifndef SOL_STACK_HPP
|
||||||
#define SOL_STACK_HPP
|
#define SOL_STACK_HPP
|
||||||
|
|
||||||
#include <sol/trampoline.hpp>
|
#include <sol/trampoline.hpp>
|
||||||
#include <sol/stack_core.hpp>
|
#include <sol/stack_core.hpp>
|
||||||
#include <sol/stack_reference.hpp>
|
#include <sol/stack_reference.hpp>
|
||||||
#include <sol/stack_check.hpp>
|
#include <sol/stack_check.hpp>
|
||||||
#include <sol/stack_get.hpp>
|
#include <sol/stack_get.hpp>
|
||||||
#include <sol/stack_check_get.hpp>
|
#include <sol/stack_check_get.hpp>
|
||||||
#include <sol/stack_push.hpp>
|
#include <sol/stack_push.hpp>
|
||||||
#include <sol/stack_pop.hpp>
|
#include <sol/stack_pop.hpp>
|
||||||
#include <sol/stack_field.hpp>
|
#include <sol/stack_field.hpp>
|
||||||
#include <sol/stack_probe.hpp>
|
#include <sol/stack_probe.hpp>
|
||||||
|
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <array>
|
#include <array>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
using typical_chunk_name_t = char[SOL_ID_SIZE_I_];
|
using typical_chunk_name_t = char[SOL_ID_SIZE_I_];
|
||||||
using typical_file_chunk_name_t = char[SOL_FILE_ID_SIZE_I_];
|
using typical_file_chunk_name_t = char[SOL_FILE_ID_SIZE_I_];
|
||||||
|
|
||||||
inline const std::string& default_chunk_name() {
|
inline const std::string& default_chunk_name() {
|
||||||
static const std::string name = "";
|
static const std::string name = "";
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <std::size_t N>
|
template <std::size_t N>
|
||||||
const char* make_chunk_name(const string_view& code, const std::string& chunkname, char (&basechunkname)[N]) {
|
const char* make_chunk_name(const string_view& code, const std::string& chunkname, char (&basechunkname)[N]) {
|
||||||
if (chunkname.empty()) {
|
if (chunkname.empty()) {
|
||||||
auto it = code.cbegin();
|
auto it = code.cbegin();
|
||||||
auto e = code.cend();
|
auto e = code.cend();
|
||||||
std::size_t i = 0;
|
std::size_t i = 0;
|
||||||
static const std::size_t n = N - 4;
|
static const std::size_t n = N - 4;
|
||||||
for (i = 0; i < n && it != e; ++i, ++it) {
|
for (i = 0; i < n && it != e; ++i, ++it) {
|
||||||
basechunkname[i] = *it;
|
basechunkname[i] = *it;
|
||||||
}
|
}
|
||||||
if (it != e) {
|
if (it != e) {
|
||||||
for (std::size_t c = 0; c < 3; ++i, ++c) {
|
for (std::size_t c = 0; c < 3; ++i, ++c) {
|
||||||
basechunkname[i] = '.';
|
basechunkname[i] = '.';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
basechunkname[i] = '\0';
|
basechunkname[i] = '\0';
|
||||||
return &basechunkname[0];
|
return &basechunkname[0];
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return chunkname.c_str();
|
return chunkname.c_str();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void clear_entries(stack_reference r) {
|
inline void clear_entries(stack_reference r) {
|
||||||
stack::push(r.lua_state(), lua_nil);
|
stack::push(r.lua_state(), lua_nil);
|
||||||
while (lua_next(r.lua_state(), -2)) {
|
while (lua_next(r.lua_state(), -2)) {
|
||||||
absolute_index key(r.lua_state(), -2);
|
absolute_index key(r.lua_state(), -2);
|
||||||
auto pn = stack::pop_n(r.lua_state(), 1);
|
auto pn = stack::pop_n(r.lua_state(), 1);
|
||||||
stack::set_field<false, true>(r.lua_state(), key, lua_nil, r.stack_index());
|
stack::set_field<false, true>(r.lua_state(), key, lua_nil, r.stack_index());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void clear_entries(const reference& registry_reference) {
|
inline void clear_entries(const reference& registry_reference) {
|
||||||
auto pp = stack::push_pop(registry_reference);
|
auto pp = stack::push_pop(registry_reference);
|
||||||
stack_reference ref(registry_reference.lua_state(), -1);
|
stack_reference ref(registry_reference.lua_state(), -1);
|
||||||
clear_entries(ref);
|
clear_entries(ref);
|
||||||
}
|
}
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
namespace stack {
|
namespace stack {
|
||||||
namespace stack_detail {
|
namespace stack_detail {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline int push_as_upvalues(lua_State* L, T& item) {
|
inline int push_as_upvalues(lua_State* L, T& item) {
|
||||||
typedef std::decay_t<T> TValue;
|
typedef std::decay_t<T> TValue;
|
||||||
static const std::size_t itemsize = sizeof(TValue);
|
static const std::size_t itemsize = sizeof(TValue);
|
||||||
static const std::size_t voidsize = sizeof(void*);
|
static const std::size_t voidsize = sizeof(void*);
|
||||||
static const std::size_t voidsizem1 = voidsize - 1;
|
static const std::size_t voidsizem1 = voidsize - 1;
|
||||||
static const std::size_t data_t_count = (sizeof(TValue) + voidsizem1) / voidsize;
|
static const std::size_t data_t_count = (sizeof(TValue) + voidsizem1) / voidsize;
|
||||||
typedef std::array<void*, data_t_count> data_t;
|
typedef std::array<void*, data_t_count> data_t;
|
||||||
|
|
||||||
data_t data { {} };
|
data_t data { {} };
|
||||||
std::memcpy(&data[0], std::addressof(item), itemsize);
|
std::memcpy(&data[0], std::addressof(item), itemsize);
|
||||||
int pushcount = 0;
|
int pushcount = 0;
|
||||||
for (const auto& v : data) {
|
for (const auto& v : data) {
|
||||||
lua_pushlightuserdata(L, v);
|
lua_pushlightuserdata(L, v);
|
||||||
pushcount += 1;
|
pushcount += 1;
|
||||||
}
|
}
|
||||||
return pushcount;
|
return pushcount;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline std::pair<T, int> get_as_upvalues(lua_State* L, int index = 2) {
|
inline std::pair<T, int> get_as_upvalues(lua_State* L, int index = 2) {
|
||||||
static const std::size_t data_t_count = (sizeof(T) + (sizeof(void*) - 1)) / sizeof(void*);
|
static const std::size_t data_t_count = (sizeof(T) + (sizeof(void*) - 1)) / sizeof(void*);
|
||||||
typedef std::array<void*, data_t_count> data_t;
|
typedef std::array<void*, data_t_count> data_t;
|
||||||
data_t voiddata { {} };
|
data_t voiddata { {} };
|
||||||
for (std::size_t i = 0, d = 0; d < sizeof(T); ++i, d += sizeof(void*)) {
|
for (std::size_t i = 0, d = 0; d < sizeof(T); ++i, d += sizeof(void*)) {
|
||||||
voiddata[i] = lua_touserdata(L, upvalue_index(index++));
|
voiddata[i] = lua_touserdata(L, upvalue_index(index++));
|
||||||
}
|
}
|
||||||
return std::pair<T, int>(*reinterpret_cast<T*>(static_cast<void*>(voiddata.data())), index);
|
return std::pair<T, int>(*reinterpret_cast<T*>(static_cast<void*>(voiddata.data())), index);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline std::pair<T, int> get_as_upvalues_using_function(lua_State* L, int function_index = -1) {
|
inline std::pair<T, int> get_as_upvalues_using_function(lua_State* L, int function_index = -1) {
|
||||||
static const std::size_t data_t_count = (sizeof(T) + (sizeof(void*) - 1)) / sizeof(void*);
|
static const std::size_t data_t_count = (sizeof(T) + (sizeof(void*) - 1)) / sizeof(void*);
|
||||||
typedef std::array<void*, data_t_count> data_t;
|
typedef std::array<void*, data_t_count> data_t;
|
||||||
function_index = lua_absindex(L, function_index);
|
function_index = lua_absindex(L, function_index);
|
||||||
int index = 0;
|
int index = 0;
|
||||||
data_t voiddata { {} };
|
data_t voiddata { {} };
|
||||||
for (std::size_t d = 0; d < sizeof(T); d += sizeof(void*)) {
|
for (std::size_t d = 0; d < sizeof(T); d += sizeof(void*)) {
|
||||||
// first upvalue is nullptr to respect environment shenanigans
|
// first upvalue is nullptr to respect environment shenanigans
|
||||||
// So +2 instead of +1
|
// So +2 instead of +1
|
||||||
const char* upvalue_name = lua_getupvalue(L, function_index, index + 2);
|
const char* upvalue_name = lua_getupvalue(L, function_index, index + 2);
|
||||||
if (upvalue_name == nullptr) {
|
if (upvalue_name == nullptr) {
|
||||||
// We should freak out here...
|
// We should freak out here...
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
voiddata[index] = lua_touserdata(L, -1);
|
voiddata[index] = lua_touserdata(L, -1);
|
||||||
++index;
|
++index;
|
||||||
}
|
}
|
||||||
lua_pop(L, index);
|
lua_pop(L, index);
|
||||||
return std::pair<T, int>(*reinterpret_cast<T*>(static_cast<void*>(voiddata.data())), index);
|
return std::pair<T, int>(*reinterpret_cast<T*>(static_cast<void*>(voiddata.data())), index);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool checked, typename Handler, typename Fx, typename... Args>
|
template <bool checked, typename Handler, typename Fx, typename... Args>
|
||||||
static decltype(auto) eval(types<>, std::index_sequence<>, lua_State*, int, Handler&&, record&, Fx&& fx, Args&&... args) {
|
static decltype(auto) eval(types<>, std::index_sequence<>, lua_State*, int, Handler&&, record&, Fx&& fx, Args&&... args) {
|
||||||
return std::forward<Fx>(fx)(std::forward<Args>(args)...);
|
return std::forward<Fx>(fx)(std::forward<Args>(args)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool checked, typename Arg, typename... Args, std::size_t I, std::size_t... Is, typename Handler, typename Fx, typename... FxArgs>
|
template <bool checked, typename Arg, typename... Args, std::size_t I, std::size_t... Is, typename Handler, typename Fx, typename... FxArgs>
|
||||||
static decltype(auto) eval(types<Arg, Args...>, std::index_sequence<I, Is...>, lua_State* L_, int start_index_, Handler&& handler_,
|
static decltype(auto) eval(types<Arg, Args...>, std::index_sequence<I, Is...>, lua_State* L_, int start_index_, Handler&& handler_,
|
||||||
record& tracking_, Fx&& fx_, FxArgs&&... fxargs_) {
|
record& tracking_, Fx&& fx_, FxArgs&&... fxargs_) {
|
||||||
#if SOL_IS_ON(SOL_PROPAGATE_EXCEPTIONS_I_)
|
#if SOL_IS_ON(SOL_PROPAGATE_EXCEPTIONS_I_)
|
||||||
// We can save performance/time by letting errors unwind produced arguments
|
// We can save performance/time by letting errors unwind produced arguments
|
||||||
// rather than checking everything once, and then potentially re-doing work
|
// rather than checking everything once, and then potentially re-doing work
|
||||||
if constexpr (checked) {
|
if constexpr (checked) {
|
||||||
return eval<checked>(types<Args...>(),
|
return eval<checked>(types<Args...>(),
|
||||||
std::index_sequence<Is...>(),
|
std::index_sequence<Is...>(),
|
||||||
L_,
|
L_,
|
||||||
start_index_,
|
start_index_,
|
||||||
std::forward<Handler>(handler_),
|
std::forward<Handler>(handler_),
|
||||||
tracking_,
|
tracking_,
|
||||||
std::forward<Fx>(fx_),
|
std::forward<Fx>(fx_),
|
||||||
std::forward<FxArgs>(fxargs_)...,
|
std::forward<FxArgs>(fxargs_)...,
|
||||||
*stack_detail::check_get_arg<Arg>(L_, start_index_ + tracking_.used, handler_, tracking_));
|
*stack_detail::check_get_arg<Arg>(L_, start_index_ + tracking_.used, handler_, tracking_));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
return eval<checked>(types<Args...>(),
|
return eval<checked>(types<Args...>(),
|
||||||
std::index_sequence<Is...>(),
|
std::index_sequence<Is...>(),
|
||||||
L_,
|
L_,
|
||||||
start_index_,
|
start_index_,
|
||||||
std::forward<Handler>(handler_),
|
std::forward<Handler>(handler_),
|
||||||
tracking_,
|
tracking_,
|
||||||
std::forward<Fx>(fx_),
|
std::forward<Fx>(fx_),
|
||||||
std::forward<FxArgs>(fxargs_)...,
|
std::forward<FxArgs>(fxargs_)...,
|
||||||
stack_detail::unchecked_get_arg<Arg>(L_, start_index_ + tracking_.used, tracking_));
|
stack_detail::unchecked_get_arg<Arg>(L_, start_index_ + tracking_.used, tracking_));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool checkargs = detail::default_safe_function_calls, std::size_t... I, typename R, typename... Args, typename Fx, typename... FxArgs>
|
template <bool checkargs = detail::default_safe_function_calls, std::size_t... I, typename R, typename... Args, typename Fx, typename... FxArgs>
|
||||||
inline decltype(auto) call(types<R>, types<Args...> argument_types_, std::index_sequence<I...> argument_indices_, lua_State* L_,
|
inline decltype(auto) call(types<R>, types<Args...> argument_types_, std::index_sequence<I...> argument_indices_, lua_State* L_,
|
||||||
int start_index_, Fx&& fx_, FxArgs&&... args_) {
|
int start_index_, Fx&& fx_, FxArgs&&... args_) {
|
||||||
static_assert(meta::all_v<meta::is_not_move_only<Args>...>,
|
static_assert(meta::all_v<meta::is_not_move_only<Args>...>,
|
||||||
"One of the arguments being bound is a move-only type, and it is not being taken by reference: this will break your code. Please take "
|
"One of the arguments being bound is a move-only type, and it is not being taken by reference: this will break your code. Please take "
|
||||||
"a reference and std::move it manually if this was your intention.");
|
"a reference and std::move it manually if this was your intention.");
|
||||||
argument_handler<types<R, Args...>> handler {};
|
argument_handler<types<R, Args...>> handler {};
|
||||||
record tracking {};
|
record tracking {};
|
||||||
#if SOL_IS_OFF(SOL_PROPAGATE_EXCEPTIONS_I_)
|
#if SOL_IS_OFF(SOL_PROPAGATE_EXCEPTIONS_I_)
|
||||||
if constexpr (checkargs) {
|
if constexpr (checkargs) {
|
||||||
multi_check<Args...>(L_, start_index_, handler);
|
multi_check<Args...>(L_, start_index_, handler);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if constexpr (std::is_void_v<R>) {
|
if constexpr (std::is_void_v<R>) {
|
||||||
eval<checkargs>(
|
eval<checkargs>(
|
||||||
argument_types_, argument_indices_, L_, start_index_, handler, tracking, std::forward<Fx>(fx_), std::forward<FxArgs>(args_)...);
|
argument_types_, argument_indices_, L_, start_index_, handler, tracking, std::forward<Fx>(fx_), std::forward<FxArgs>(args_)...);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return eval<checkargs>(
|
return eval<checkargs>(
|
||||||
argument_types_, argument_indices_, L_, start_index_, handler, tracking, std::forward<Fx>(fx_), std::forward<FxArgs>(args_)...);
|
argument_types_, argument_indices_, L_, start_index_, handler, tracking, std::forward<Fx>(fx_), std::forward<FxArgs>(args_)...);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // namespace stack_detail
|
} // namespace stack_detail
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
int set_ref(lua_State* L, T&& arg, int tableindex = -2) {
|
int set_ref(lua_State* L, T&& arg, int tableindex = -2) {
|
||||||
push(L, std::forward<T>(arg));
|
push(L, std::forward<T>(arg));
|
||||||
return luaL_ref(L, tableindex);
|
return luaL_ref(L, tableindex);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool check_args = detail::default_safe_function_calls, typename R, typename... Args, typename Fx, typename... FxArgs>
|
template <bool check_args = detail::default_safe_function_calls, typename R, typename... Args, typename Fx, typename... FxArgs>
|
||||||
inline decltype(auto) call(types<R> tr, types<Args...> ta, lua_State* L, int start, Fx&& fx, FxArgs&&... args) {
|
inline decltype(auto) call(types<R> tr, types<Args...> ta, lua_State* L, int start, Fx&& fx, FxArgs&&... args) {
|
||||||
using args_indices = std::make_index_sequence<sizeof...(Args)>;
|
using args_indices = std::make_index_sequence<sizeof...(Args)>;
|
||||||
if constexpr (std::is_void_v<R>) {
|
if constexpr (std::is_void_v<R>) {
|
||||||
stack_detail::call<check_args>(tr, ta, args_indices(), L, start, std::forward<Fx>(fx), std::forward<FxArgs>(args)...);
|
stack_detail::call<check_args>(tr, ta, args_indices(), L, start, std::forward<Fx>(fx), std::forward<FxArgs>(args)...);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return stack_detail::call<check_args>(tr, ta, args_indices(), L, start, std::forward<Fx>(fx), std::forward<FxArgs>(args)...);
|
return stack_detail::call<check_args>(tr, ta, args_indices(), L, start, std::forward<Fx>(fx), std::forward<FxArgs>(args)...);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool check_args = detail::default_safe_function_calls, typename R, typename... Args, typename Fx, typename... FxArgs>
|
template <bool check_args = detail::default_safe_function_calls, typename R, typename... Args, typename Fx, typename... FxArgs>
|
||||||
inline decltype(auto) call(types<R> tr, types<Args...> ta, lua_State* L, Fx&& fx, FxArgs&&... args) {
|
inline decltype(auto) call(types<R> tr, types<Args...> ta, lua_State* L, Fx&& fx, FxArgs&&... args) {
|
||||||
if constexpr (std::is_void_v<R>) {
|
if constexpr (std::is_void_v<R>) {
|
||||||
call<check_args>(tr, ta, L, 1, std::forward<Fx>(fx), std::forward<FxArgs>(args)...);
|
call<check_args>(tr, ta, L, 1, std::forward<Fx>(fx), std::forward<FxArgs>(args)...);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return call<check_args>(tr, ta, L, 1, std::forward<Fx>(fx), std::forward<FxArgs>(args)...);
|
return call<check_args>(tr, ta, L, 1, std::forward<Fx>(fx), std::forward<FxArgs>(args)...);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool check_args = detail::default_safe_function_calls, typename R, typename... Args, typename Fx, typename... FxArgs>
|
template <bool check_args = detail::default_safe_function_calls, typename R, typename... Args, typename Fx, typename... FxArgs>
|
||||||
inline decltype(auto) call_from_top(types<R> tr, types<Args...> ta, lua_State* L, Fx&& fx, FxArgs&&... args) {
|
inline decltype(auto) call_from_top(types<R> tr, types<Args...> ta, lua_State* L, Fx&& fx, FxArgs&&... args) {
|
||||||
using expected_count_t = meta::count_for_pack<lua_size, Args...>;
|
using expected_count_t = meta::count_for_pack<lua_size, Args...>;
|
||||||
if constexpr (std::is_void_v<R>) {
|
if constexpr (std::is_void_v<R>) {
|
||||||
call<check_args>(tr,
|
call<check_args>(tr,
|
||||||
ta,
|
ta,
|
||||||
L,
|
L,
|
||||||
(std::max)(static_cast<int>(lua_gettop(L) - expected_count_t::value), static_cast<int>(0)),
|
(std::max)(static_cast<int>(lua_gettop(L) - expected_count_t::value), static_cast<int>(0)),
|
||||||
std::forward<Fx>(fx),
|
std::forward<Fx>(fx),
|
||||||
std::forward<FxArgs>(args)...);
|
std::forward<FxArgs>(args)...);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return call<check_args>(tr,
|
return call<check_args>(tr,
|
||||||
ta,
|
ta,
|
||||||
L,
|
L,
|
||||||
(std::max)(static_cast<int>(lua_gettop(L) - expected_count_t::value), static_cast<int>(0)),
|
(std::max)(static_cast<int>(lua_gettop(L) - expected_count_t::value), static_cast<int>(0)),
|
||||||
std::forward<Fx>(fx),
|
std::forward<Fx>(fx),
|
||||||
std::forward<FxArgs>(args)...);
|
std::forward<FxArgs>(args)...);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool check_args = detail::default_safe_function_calls, bool clean_stack = true, typename Ret0, typename... Ret, typename... Args,
|
template <bool check_args = detail::default_safe_function_calls, bool clean_stack = true, typename Ret0, typename... Ret, typename... Args,
|
||||||
typename Fx, typename... FxArgs>
|
typename Fx, typename... FxArgs>
|
||||||
inline int call_into_lua(types<Ret0, Ret...> tr, types<Args...> ta, lua_State* L, int start, Fx&& fx, FxArgs&&... fxargs) {
|
inline int call_into_lua(types<Ret0, Ret...> tr, types<Args...> ta, lua_State* L, int start, Fx&& fx, FxArgs&&... fxargs) {
|
||||||
if constexpr (std::is_void_v<Ret0>) {
|
if constexpr (std::is_void_v<Ret0>) {
|
||||||
call<check_args>(tr, ta, L, start, std::forward<Fx>(fx), std::forward<FxArgs>(fxargs)...);
|
call<check_args>(tr, ta, L, start, std::forward<Fx>(fx), std::forward<FxArgs>(fxargs)...);
|
||||||
if constexpr (clean_stack) {
|
if constexpr (clean_stack) {
|
||||||
lua_settop(L, 0);
|
lua_settop(L, 0);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
(void)tr;
|
(void)tr;
|
||||||
decltype(auto) r
|
decltype(auto) r
|
||||||
= call<check_args>(types<meta::return_type_t<Ret0, Ret...>>(), ta, L, start, std::forward<Fx>(fx), std::forward<FxArgs>(fxargs)...);
|
= call<check_args>(types<meta::return_type_t<Ret0, Ret...>>(), ta, L, start, std::forward<Fx>(fx), std::forward<FxArgs>(fxargs)...);
|
||||||
using R = meta::unqualified_t<decltype(r)>;
|
using R = meta::unqualified_t<decltype(r)>;
|
||||||
using is_stack = meta::any<is_stack_based<R>, std::is_same<R, absolute_index>, std::is_same<R, ref_index>, std::is_same<R, raw_index>>;
|
using is_stack = meta::any<is_stack_based<R>, std::is_same<R, absolute_index>, std::is_same<R, ref_index>, std::is_same<R, raw_index>>;
|
||||||
if constexpr (clean_stack && !is_stack::value) {
|
if constexpr (clean_stack && !is_stack::value) {
|
||||||
lua_settop(L, 0);
|
lua_settop(L, 0);
|
||||||
}
|
}
|
||||||
return push_reference(L, std::forward<decltype(r)>(r));
|
return push_reference(L, std::forward<decltype(r)>(r));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool check_args = detail::default_safe_function_calls, bool clean_stack = true, typename Fx, typename... FxArgs>
|
template <bool check_args = detail::default_safe_function_calls, bool clean_stack = true, typename Fx, typename... FxArgs>
|
||||||
inline int call_lua(lua_State* L, int start, Fx&& fx, FxArgs&&... fxargs) {
|
inline int call_lua(lua_State* L, int start, Fx&& fx, FxArgs&&... fxargs) {
|
||||||
using traits_type = lua_bind_traits<meta::unqualified_t<Fx>>;
|
using traits_type = lua_bind_traits<meta::unqualified_t<Fx>>;
|
||||||
using args_list = typename traits_type::args_list;
|
using args_list = typename traits_type::args_list;
|
||||||
using returns_list = typename traits_type::returns_list;
|
using returns_list = typename traits_type::returns_list;
|
||||||
return call_into_lua<check_args, clean_stack>(returns_list(), args_list(), L, start, std::forward<Fx>(fx), std::forward<FxArgs>(fxargs)...);
|
return call_into_lua<check_args, clean_stack>(returns_list(), args_list(), L, start, std::forward<Fx>(fx), std::forward<FxArgs>(fxargs)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline call_syntax get_call_syntax(lua_State* L, const string_view& key, int index) {
|
inline call_syntax get_call_syntax(lua_State* L, const string_view& key, int index) {
|
||||||
if (lua_gettop(L) < 1) {
|
if (lua_gettop(L) < 1) {
|
||||||
return call_syntax::dot;
|
return call_syntax::dot;
|
||||||
}
|
}
|
||||||
luaL_getmetatable(L, key.data());
|
luaL_getmetatable(L, key.data());
|
||||||
auto pn = pop_n(L, 1);
|
auto pn = pop_n(L, 1);
|
||||||
if (lua_compare(L, -1, index, LUA_OPEQ) != 1) {
|
if (lua_compare(L, -1, index, LUA_OPEQ) != 1) {
|
||||||
return call_syntax::dot;
|
return call_syntax::dot;
|
||||||
}
|
}
|
||||||
return call_syntax::colon;
|
return call_syntax::colon;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void script(
|
inline void script(
|
||||||
lua_State* L, lua_Reader reader, void* data, const std::string& chunkname = detail::default_chunk_name(), load_mode mode = load_mode::any) {
|
lua_State* L, lua_Reader reader, void* data, const std::string& chunkname = detail::default_chunk_name(), load_mode mode = load_mode::any) {
|
||||||
detail::typical_chunk_name_t basechunkname = {};
|
detail::typical_chunk_name_t basechunkname = {};
|
||||||
const char* chunknametarget = detail::make_chunk_name("lua_Reader", chunkname, basechunkname);
|
const char* chunknametarget = detail::make_chunk_name("lua_Reader", chunkname, basechunkname);
|
||||||
if (lua_load(L, reader, data, chunknametarget, to_string(mode).c_str()) || lua_pcall(L, 0, LUA_MULTRET, 0)) {
|
if (lua_load(L, reader, data, chunknametarget, to_string(mode).c_str()) || lua_pcall(L, 0, LUA_MULTRET, 0)) {
|
||||||
lua_error(L);
|
lua_error(L);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void script(
|
inline void script(
|
||||||
lua_State* L, const string_view& code, const std::string& chunkname = detail::default_chunk_name(), load_mode mode = load_mode::any) {
|
lua_State* L, const string_view& code, const std::string& chunkname = detail::default_chunk_name(), load_mode mode = load_mode::any) {
|
||||||
|
|
||||||
detail::typical_chunk_name_t basechunkname = {};
|
detail::typical_chunk_name_t basechunkname = {};
|
||||||
const char* chunknametarget = detail::make_chunk_name(code, chunkname, basechunkname);
|
const char* chunknametarget = detail::make_chunk_name(code, chunkname, basechunkname);
|
||||||
if (luaL_loadbufferx(L, code.data(), code.size(), chunknametarget, to_string(mode).c_str()) || lua_pcall(L, 0, LUA_MULTRET, 0)) {
|
if (luaL_loadbufferx(L, code.data(), code.size(), chunknametarget, to_string(mode).c_str()) || lua_pcall(L, 0, LUA_MULTRET, 0)) {
|
||||||
lua_error(L);
|
lua_error(L);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void script_file(lua_State* L, const std::string& filename, load_mode mode = load_mode::any) {
|
inline void script_file(lua_State* L, const std::string& filename, load_mode mode = load_mode::any) {
|
||||||
if (luaL_loadfilex(L, filename.c_str(), to_string(mode).c_str()) || lua_pcall(L, 0, LUA_MULTRET, 0)) {
|
if (luaL_loadfilex(L, filename.c_str(), to_string(mode).c_str()) || lua_pcall(L, 0, LUA_MULTRET, 0)) {
|
||||||
lua_error(L);
|
lua_error(L);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void luajit_exception_handler(lua_State* L, int (*handler)(lua_State*, lua_CFunction) = detail::c_trampoline) {
|
inline void luajit_exception_handler(lua_State* L, int (*handler)(lua_State*, lua_CFunction) = detail::c_trampoline) {
|
||||||
#if SOL_IS_ON(SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_)
|
#if SOL_IS_ON(SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_)
|
||||||
if (L == nullptr) {
|
if (L == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_)
|
#if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_)
|
||||||
luaL_checkstack(L, 1, detail::not_enough_stack_space_generic);
|
luaL_checkstack(L, 1, detail::not_enough_stack_space_generic);
|
||||||
#endif // make sure stack doesn't overflow
|
#endif // make sure stack doesn't overflow
|
||||||
lua_pushlightuserdata(L, (void*)handler);
|
lua_pushlightuserdata(L, (void*)handler);
|
||||||
auto pn = pop_n(L, 1);
|
auto pn = pop_n(L, 1);
|
||||||
luaJIT_setmode(L, -1, LUAJIT_MODE_WRAPCFUNC | LUAJIT_MODE_ON);
|
luaJIT_setmode(L, -1, LUAJIT_MODE_WRAPCFUNC | LUAJIT_MODE_ON);
|
||||||
#else
|
#else
|
||||||
(void)L;
|
(void)L;
|
||||||
(void)handler;
|
(void)handler;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void luajit_exception_off(lua_State* L) {
|
inline void luajit_exception_off(lua_State* L) {
|
||||||
#if SOL_IS_ON(SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_)
|
#if SOL_IS_ON(SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_)
|
||||||
if (L == nullptr) {
|
if (L == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
luaJIT_setmode(L, -1, LUAJIT_MODE_WRAPCFUNC | LUAJIT_MODE_OFF);
|
luaJIT_setmode(L, -1, LUAJIT_MODE_WRAPCFUNC | LUAJIT_MODE_OFF);
|
||||||
#else
|
#else
|
||||||
(void)L;
|
(void)L;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
} // namespace stack
|
} // namespace stack
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_STACK_HPP
|
#endif // SOL_STACK_HPP
|
||||||
|
|
196
extern/sol3/sol/stack/detail/pairs.hpp
vendored
196
extern/sol3/sol/stack/detail/pairs.hpp
vendored
|
@ -1,98 +1,98 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this Spermission notice shall be included in all
|
// The above copyright notice and this Spermission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_DETAIL_PAIRS_HPP
|
#ifndef SOL_DETAIL_PAIRS_HPP
|
||||||
#define SOL_DETAIL_PAIRS_HPP
|
#define SOL_DETAIL_PAIRS_HPP
|
||||||
|
|
||||||
#include <sol/version.hpp>
|
#include <sol/version.hpp>
|
||||||
|
|
||||||
#include <sol/stack.hpp>
|
#include <sol/stack.hpp>
|
||||||
#include <sol/stack_reference.hpp>
|
#include <sol/stack_reference.hpp>
|
||||||
#include <sol/protected_function.hpp>
|
#include <sol/protected_function.hpp>
|
||||||
#include <sol/assert.hpp>
|
#include <sol/assert.hpp>
|
||||||
|
|
||||||
#include <optional>
|
#include <optional>
|
||||||
|
|
||||||
namespace sol { namespace stack { namespace stack_detail {
|
namespace sol { namespace stack { namespace stack_detail {
|
||||||
|
|
||||||
inline bool maybe_push_lua_next_function(lua_State* L_) {
|
inline bool maybe_push_lua_next_function(lua_State* L_) {
|
||||||
stack::get_field<true, false>(L_, "next");
|
stack::get_field<true, false>(L_, "next");
|
||||||
bool is_next = stack::check<protected_function>(L_);
|
bool is_next = stack::check<protected_function>(L_);
|
||||||
if (is_next) {
|
if (is_next) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
stack::get_field<true, false>(L_, "table");
|
stack::get_field<true, false>(L_, "table");
|
||||||
stack::record tracking{};
|
stack::record tracking{};
|
||||||
if (!stack::loose_table_check(L_, -1, &no_panic, tracking)) {
|
if (!stack::loose_table_check(L_, -1, &no_panic, tracking)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
lua_getfield(L_, -1, "next");
|
lua_getfield(L_, -1, "next");
|
||||||
bool is_table_next_func = stack::check<protected_function>(L_, -1);
|
bool is_table_next_func = stack::check<protected_function>(L_, -1);
|
||||||
if (is_table_next_func) {
|
if (is_table_next_func) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
lua_pop(L_, 1);
|
lua_pop(L_, 1);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline std::optional<protected_function> find_lua_next_function(lua_State* L_) {
|
inline std::optional<protected_function> find_lua_next_function(lua_State* L_) {
|
||||||
if (maybe_push_lua_next_function(L_)) {
|
if (maybe_push_lua_next_function(L_)) {
|
||||||
return stack::pop<protected_function>(L_);
|
return stack::pop<protected_function>(L_);
|
||||||
}
|
}
|
||||||
return std::nullopt;
|
return std::nullopt;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int c_lua_next(lua_State* L_) noexcept {
|
inline int c_lua_next(lua_State* L_) noexcept {
|
||||||
stack_reference table_stack_ref(L_, raw_index(1));
|
stack_reference table_stack_ref(L_, raw_index(1));
|
||||||
stateless_stack_reference key_stack_ref(L_, raw_index(2));
|
stateless_stack_reference key_stack_ref(L_, raw_index(2));
|
||||||
int result = lua_next(table_stack_ref.lua_state(), table_stack_ref.stack_index());
|
int result = lua_next(table_stack_ref.lua_state(), table_stack_ref.stack_index());
|
||||||
if (result == 0) {
|
if (result == 0) {
|
||||||
stack::push(L_, lua_nil);
|
stack::push(L_, lua_nil);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
return 2;
|
return 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int readonly_pairs(lua_State* L_) noexcept {
|
inline int readonly_pairs(lua_State* L_) noexcept {
|
||||||
int pushed = 0;
|
int pushed = 0;
|
||||||
if (!maybe_push_lua_next_function(L_)) {
|
if (!maybe_push_lua_next_function(L_)) {
|
||||||
// we do not have the "next" function in the global namespace
|
// we do not have the "next" function in the global namespace
|
||||||
// from the "table" global entiry, use our own
|
// from the "table" global entiry, use our own
|
||||||
pushed += stack::push(L_, &c_lua_next);
|
pushed += stack::push(L_, &c_lua_next);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
pushed += 1;
|
pushed += 1;
|
||||||
}
|
}
|
||||||
int metatable_exists = lua_getmetatable(L_, 1);
|
int metatable_exists = lua_getmetatable(L_, 1);
|
||||||
sol_c_assert(metatable_exists == 1);
|
sol_c_assert(metatable_exists == 1);
|
||||||
const auto& index_key = to_string(sol::meta_function::index);
|
const auto& index_key = to_string(sol::meta_function::index);
|
||||||
lua_getfield(L_, lua_gettop(L_), index_key.c_str());
|
lua_getfield(L_, lua_gettop(L_), index_key.c_str());
|
||||||
lua_remove(L_, -2);
|
lua_remove(L_, -2);
|
||||||
pushed += 1;
|
pushed += 1;
|
||||||
pushed += stack::push(L_, lua_nil);
|
pushed += stack::push(L_, lua_nil);
|
||||||
return pushed;
|
return pushed;
|
||||||
}
|
}
|
||||||
|
|
||||||
}}} // sol::stack::stack_detail
|
}}} // sol::stack::stack_detail
|
||||||
|
|
||||||
#endif // SOL_DETAIL_PAIRS_HPP
|
#endif // SOL_DETAIL_PAIRS_HPP
|
||||||
|
|
232
extern/sol3/sol/table.hpp
vendored
232
extern/sol3/sol/table.hpp
vendored
|
@ -1,116 +1,116 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_TABLE_HPP
|
#ifndef SOL_TABLE_HPP
|
||||||
#define SOL_TABLE_HPP
|
#define SOL_TABLE_HPP
|
||||||
|
|
||||||
#include <sol/table_core.hpp>
|
#include <sol/table_core.hpp>
|
||||||
#include <sol/lua_table.hpp>
|
#include <sol/lua_table.hpp>
|
||||||
#include <sol/usertype.hpp>
|
#include <sol/usertype.hpp>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
typedef table_core<false> table;
|
typedef table_core<false> table;
|
||||||
|
|
||||||
template <bool is_global, typename base_type>
|
template <bool is_global, typename base_type>
|
||||||
template <typename Class, typename Key>
|
template <typename Class, typename Key>
|
||||||
usertype<Class> basic_table_core<is_global, base_type>::new_usertype(Key&& key) {
|
usertype<Class> basic_table_core<is_global, base_type>::new_usertype(Key&& key) {
|
||||||
constant_automagic_enrollments<> enrollments {};
|
constant_automagic_enrollments<> enrollments {};
|
||||||
return this->new_usertype<Class>(std::forward<Key>(key), std::move(enrollments));
|
return this->new_usertype<Class>(std::forward<Key>(key), std::move(enrollments));
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool is_global, typename base_type>
|
template <bool is_global, typename base_type>
|
||||||
template <typename Class, typename Key, automagic_flags enrollment_flags>
|
template <typename Class, typename Key, automagic_flags enrollment_flags>
|
||||||
usertype<Class> basic_table_core<is_global, base_type>::new_usertype(Key&& key, constant_automagic_enrollments<enrollment_flags> enrollments) {
|
usertype<Class> basic_table_core<is_global, base_type>::new_usertype(Key&& key, constant_automagic_enrollments<enrollment_flags> enrollments) {
|
||||||
int mt_index = u_detail::register_usertype<Class, enrollment_flags>(this->lua_state(), std::move(enrollments));
|
int mt_index = u_detail::register_usertype<Class, enrollment_flags>(this->lua_state(), std::move(enrollments));
|
||||||
usertype<Class> mt(this->lua_state(), -mt_index);
|
usertype<Class> mt(this->lua_state(), -mt_index);
|
||||||
lua_pop(this->lua_state(), 1);
|
lua_pop(this->lua_state(), 1);
|
||||||
set(std::forward<Key>(key), mt);
|
set(std::forward<Key>(key), mt);
|
||||||
return mt;
|
return mt;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool is_global, typename base_type>
|
template <bool is_global, typename base_type>
|
||||||
template <typename Class, typename Key>
|
template <typename Class, typename Key>
|
||||||
usertype<Class> basic_table_core<is_global, base_type>::new_usertype(Key&& key, automagic_enrollments enrollments) {
|
usertype<Class> basic_table_core<is_global, base_type>::new_usertype(Key&& key, automagic_enrollments enrollments) {
|
||||||
int mt_index = u_detail::register_usertype<Class, automagic_flags::all>(this->lua_state(), std::move(enrollments));
|
int mt_index = u_detail::register_usertype<Class, automagic_flags::all>(this->lua_state(), std::move(enrollments));
|
||||||
usertype<Class> mt(this->lua_state(), -mt_index);
|
usertype<Class> mt(this->lua_state(), -mt_index);
|
||||||
lua_pop(this->lua_state(), 1);
|
lua_pop(this->lua_state(), 1);
|
||||||
set(std::forward<Key>(key), mt);
|
set(std::forward<Key>(key), mt);
|
||||||
return mt;
|
return mt;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <bool is_global, typename base_type>
|
template <bool is_global, typename base_type>
|
||||||
template <typename Class, typename Key, typename Arg, typename... Args, typename>
|
template <typename Class, typename Key, typename Arg, typename... Args, typename>
|
||||||
usertype<Class> basic_table_core<is_global, base_type>::new_usertype(Key&& key, Arg&& arg, Args&&... args) {
|
usertype<Class> basic_table_core<is_global, base_type>::new_usertype(Key&& key, Arg&& arg, Args&&... args) {
|
||||||
constexpr automagic_flags enrollment_flags = meta::any_same_v<no_construction, meta::unqualified_t<Arg>, meta::unqualified_t<Args>...>
|
constexpr automagic_flags enrollment_flags = meta::any_same_v<no_construction, meta::unqualified_t<Arg>, meta::unqualified_t<Args>...>
|
||||||
? clear_flags(automagic_flags::all, automagic_flags::default_constructor)
|
? clear_flags(automagic_flags::all, automagic_flags::default_constructor)
|
||||||
: automagic_flags::all;
|
: automagic_flags::all;
|
||||||
constant_automagic_enrollments<enrollment_flags> enrollments;
|
constant_automagic_enrollments<enrollment_flags> enrollments;
|
||||||
enrollments.default_constructor = !detail::any_is_constructor_v<Arg, Args...>;
|
enrollments.default_constructor = !detail::any_is_constructor_v<Arg, Args...>;
|
||||||
enrollments.destructor = !detail::any_is_destructor_v<Arg, Args...>;
|
enrollments.destructor = !detail::any_is_destructor_v<Arg, Args...>;
|
||||||
usertype<Class> ut = this->new_usertype<Class>(std::forward<Key>(key), std::move(enrollments));
|
usertype<Class> ut = this->new_usertype<Class>(std::forward<Key>(key), std::move(enrollments));
|
||||||
static_assert(sizeof...(Args) % 2 == static_cast<std::size_t>(!detail::any_is_constructor_v<Arg>),
|
static_assert(sizeof...(Args) % 2 == static_cast<std::size_t>(!detail::any_is_constructor_v<Arg>),
|
||||||
"you must pass an even number of arguments to new_usertype after first passing a constructor");
|
"you must pass an even number of arguments to new_usertype after first passing a constructor");
|
||||||
if constexpr (detail::any_is_constructor_v<Arg>) {
|
if constexpr (detail::any_is_constructor_v<Arg>) {
|
||||||
ut.set(meta_function::construct, std::forward<Arg>(arg));
|
ut.set(meta_function::construct, std::forward<Arg>(arg));
|
||||||
ut.tuple_set(std::make_index_sequence<(sizeof...(Args)) / 2>(), std::forward_as_tuple(std::forward<Args>(args)...));
|
ut.tuple_set(std::make_index_sequence<(sizeof...(Args)) / 2>(), std::forward_as_tuple(std::forward<Args>(args)...));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
ut.tuple_set(std::make_index_sequence<(sizeof...(Args) + 1) / 2>(), std::forward_as_tuple(std::forward<Arg>(arg), std::forward<Args>(args)...));
|
ut.tuple_set(std::make_index_sequence<(sizeof...(Args) + 1) / 2>(), std::forward_as_tuple(std::forward<Arg>(arg), std::forward<Args>(args)...));
|
||||||
}
|
}
|
||||||
return ut;
|
return ut;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename base_type>
|
template <typename base_type>
|
||||||
template <typename Key, typename Value>
|
template <typename Key, typename Value>
|
||||||
basic_metatable<base_type>& basic_metatable<base_type>::set(Key&& key, Value&& value) {
|
basic_metatable<base_type>& basic_metatable<base_type>::set(Key&& key, Value&& value) {
|
||||||
this->push();
|
this->push();
|
||||||
lua_State* L = this->lua_state();
|
lua_State* L = this->lua_state();
|
||||||
int target = lua_gettop(L);
|
int target = lua_gettop(L);
|
||||||
optional<u_detail::usertype_storage_base&> maybe_uts = nullopt;
|
optional<u_detail::usertype_storage_base&> maybe_uts = nullopt;
|
||||||
maybe_uts = u_detail::maybe_get_usertype_storage_base(L, target);
|
maybe_uts = u_detail::maybe_get_usertype_storage_base(L, target);
|
||||||
if (maybe_uts) {
|
if (maybe_uts) {
|
||||||
u_detail::usertype_storage_base& uts = *maybe_uts;
|
u_detail::usertype_storage_base& uts = *maybe_uts;
|
||||||
uts.set(L, std::forward<Key>(key), std::forward<Value>(value));
|
uts.set(L, std::forward<Key>(key), std::forward<Value>(value));
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
base_t::set(std::forward<Key>(key), std::forward<Value>(value));
|
base_t::set(std::forward<Key>(key), std::forward<Value>(value));
|
||||||
}
|
}
|
||||||
this->pop();
|
this->pop();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace stack {
|
namespace stack {
|
||||||
template <>
|
template <>
|
||||||
struct unqualified_getter<metatable_key_t> {
|
struct unqualified_getter<metatable_key_t> {
|
||||||
static metatable get(lua_State* L, int index = -1) {
|
static metatable get(lua_State* L, int index = -1) {
|
||||||
if (lua_getmetatable(L, index) == 0) {
|
if (lua_getmetatable(L, index) == 0) {
|
||||||
return metatable(L, ref_index(LUA_REFNIL));
|
return metatable(L, ref_index(LUA_REFNIL));
|
||||||
}
|
}
|
||||||
return metatable(L, -1);
|
return metatable(L, -1);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace stack
|
} // namespace stack
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_TABLE_HPP
|
#endif // SOL_TABLE_HPP
|
||||||
|
|
186
extern/sol3/sol/tuple.hpp
vendored
186
extern/sol3/sol/tuple.hpp
vendored
|
@ -1,93 +1,93 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_TUPLE_HPP
|
#ifndef SOL_TUPLE_HPP
|
||||||
#define SOL_TUPLE_HPP
|
#define SOL_TUPLE_HPP
|
||||||
|
|
||||||
#include <sol/forward.hpp>
|
#include <sol/forward.hpp>
|
||||||
#include <sol/base_traits.hpp>
|
#include <sol/base_traits.hpp>
|
||||||
|
|
||||||
#include <tuple>
|
#include <tuple>
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
using swallow = std::initializer_list<int>;
|
using swallow = std::initializer_list<int>;
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
namespace meta {
|
namespace meta {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using is_tuple = is_specialization_of<T, std::tuple>;
|
using is_tuple = is_specialization_of<T, std::tuple>;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
constexpr inline bool is_tuple_v = is_tuple<T>::value;
|
constexpr inline bool is_tuple_v = is_tuple<T>::value;
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
struct tuple_types_ {
|
struct tuple_types_ {
|
||||||
typedef types<Args...> type;
|
typedef types<Args...> type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
struct tuple_types_<std::tuple<Args...>> {
|
struct tuple_types_<std::tuple<Args...>> {
|
||||||
typedef types<Args...> type;
|
typedef types<Args...> type;
|
||||||
};
|
};
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
using tuple_types = typename detail::tuple_types_<Args...>::type;
|
using tuple_types = typename detail::tuple_types_<Args...>::type;
|
||||||
|
|
||||||
template <typename Arg>
|
template <typename Arg>
|
||||||
struct pop_front_type;
|
struct pop_front_type;
|
||||||
|
|
||||||
template <typename Arg>
|
template <typename Arg>
|
||||||
using pop_front_type_t = typename pop_front_type<Arg>::type;
|
using pop_front_type_t = typename pop_front_type<Arg>::type;
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
struct pop_front_type<types<Args...>> {
|
struct pop_front_type<types<Args...>> {
|
||||||
typedef void front_type;
|
typedef void front_type;
|
||||||
typedef types<Args...> type;
|
typedef types<Args...> type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename Arg, typename... Args>
|
template <typename Arg, typename... Args>
|
||||||
struct pop_front_type<types<Arg, Args...>> {
|
struct pop_front_type<types<Arg, Args...>> {
|
||||||
typedef Arg front_type;
|
typedef Arg front_type;
|
||||||
typedef types<Args...> type;
|
typedef types<Args...> type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <std::size_t N, typename Tuple>
|
template <std::size_t N, typename Tuple>
|
||||||
using tuple_element = std::tuple_element<N, std::remove_reference_t<Tuple>>;
|
using tuple_element = std::tuple_element<N, std::remove_reference_t<Tuple>>;
|
||||||
|
|
||||||
template <std::size_t N, typename Tuple>
|
template <std::size_t N, typename Tuple>
|
||||||
using tuple_element_t = std::tuple_element_t<N, std::remove_reference_t<Tuple>>;
|
using tuple_element_t = std::tuple_element_t<N, std::remove_reference_t<Tuple>>;
|
||||||
|
|
||||||
template <std::size_t N, typename Tuple>
|
template <std::size_t N, typename Tuple>
|
||||||
using unqualified_tuple_element = unqualified<tuple_element_t<N, Tuple>>;
|
using unqualified_tuple_element = unqualified<tuple_element_t<N, Tuple>>;
|
||||||
|
|
||||||
template <std::size_t N, typename Tuple>
|
template <std::size_t N, typename Tuple>
|
||||||
using unqualified_tuple_element_t = unqualified_t<tuple_element_t<N, Tuple>>;
|
using unqualified_tuple_element_t = unqualified_t<tuple_element_t<N, Tuple>>;
|
||||||
|
|
||||||
} // namespace meta
|
} // namespace meta
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_TUPLE_HPP
|
#endif // SOL_TUPLE_HPP
|
||||||
|
|
616
extern/sol3/sol/unicode.hpp
vendored
616
extern/sol3/sol/unicode.hpp
vendored
|
@ -1,308 +1,308 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <sol/string_view.hpp>
|
#include <sol/string_view.hpp>
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
// Everything here was lifted pretty much straight out of
|
// Everything here was lifted pretty much straight out of
|
||||||
// ogonek, because fuck figuring it out=
|
// ogonek, because fuck figuring it out=
|
||||||
namespace unicode {
|
namespace unicode {
|
||||||
enum class error_code {
|
enum class error_code {
|
||||||
ok = 0,
|
ok = 0,
|
||||||
invalid_code_point,
|
invalid_code_point,
|
||||||
invalid_code_unit,
|
invalid_code_unit,
|
||||||
invalid_leading_surrogate,
|
invalid_leading_surrogate,
|
||||||
invalid_trailing_surrogate,
|
invalid_trailing_surrogate,
|
||||||
sequence_too_short,
|
sequence_too_short,
|
||||||
overlong_sequence,
|
overlong_sequence,
|
||||||
};
|
};
|
||||||
|
|
||||||
inline const string_view& to_string(error_code ec) {
|
inline const string_view& to_string(error_code ec) {
|
||||||
static const string_view storage[7] = { "ok",
|
static const string_view storage[7] = { "ok",
|
||||||
"invalid code points",
|
"invalid code points",
|
||||||
"invalid code unit",
|
"invalid code unit",
|
||||||
"invalid leading surrogate",
|
"invalid leading surrogate",
|
||||||
"invalid trailing surrogate",
|
"invalid trailing surrogate",
|
||||||
"sequence too short",
|
"sequence too short",
|
||||||
"overlong sequence" };
|
"overlong sequence" };
|
||||||
return storage[static_cast<std::size_t>(ec)];
|
return storage[static_cast<std::size_t>(ec)];
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename It>
|
template <typename It>
|
||||||
struct decoded_result {
|
struct decoded_result {
|
||||||
error_code error;
|
error_code error;
|
||||||
char32_t codepoint;
|
char32_t codepoint;
|
||||||
It next;
|
It next;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename C>
|
template <typename C>
|
||||||
struct encoded_result {
|
struct encoded_result {
|
||||||
error_code error;
|
error_code error;
|
||||||
std::size_t code_units_size;
|
std::size_t code_units_size;
|
||||||
std::array<C, 4> code_units;
|
std::array<C, 4> code_units;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct unicode_detail {
|
struct unicode_detail {
|
||||||
// codepoint related
|
// codepoint related
|
||||||
static constexpr char32_t last_code_point = 0x10FFFF;
|
static constexpr char32_t last_code_point = 0x10FFFF;
|
||||||
|
|
||||||
static constexpr char32_t first_lead_surrogate = 0xD800;
|
static constexpr char32_t first_lead_surrogate = 0xD800;
|
||||||
static constexpr char32_t last_lead_surrogate = 0xDBFF;
|
static constexpr char32_t last_lead_surrogate = 0xDBFF;
|
||||||
|
|
||||||
static constexpr char32_t first_trail_surrogate = 0xDC00;
|
static constexpr char32_t first_trail_surrogate = 0xDC00;
|
||||||
static constexpr char32_t last_trail_surrogate = 0xDFFF;
|
static constexpr char32_t last_trail_surrogate = 0xDFFF;
|
||||||
|
|
||||||
static constexpr char32_t first_surrogate = first_lead_surrogate;
|
static constexpr char32_t first_surrogate = first_lead_surrogate;
|
||||||
static constexpr char32_t last_surrogate = last_trail_surrogate;
|
static constexpr char32_t last_surrogate = last_trail_surrogate;
|
||||||
|
|
||||||
static constexpr bool is_lead_surrogate(char32_t u) {
|
static constexpr bool is_lead_surrogate(char32_t u) {
|
||||||
return u >= first_lead_surrogate && u <= last_lead_surrogate;
|
return u >= first_lead_surrogate && u <= last_lead_surrogate;
|
||||||
}
|
}
|
||||||
static constexpr bool is_trail_surrogate(char32_t u) {
|
static constexpr bool is_trail_surrogate(char32_t u) {
|
||||||
return u >= first_trail_surrogate && u <= last_trail_surrogate;
|
return u >= first_trail_surrogate && u <= last_trail_surrogate;
|
||||||
}
|
}
|
||||||
static constexpr bool is_surrogate(char32_t u) {
|
static constexpr bool is_surrogate(char32_t u) {
|
||||||
return u >= first_surrogate && u <= last_surrogate;
|
return u >= first_surrogate && u <= last_surrogate;
|
||||||
}
|
}
|
||||||
|
|
||||||
// utf8 related
|
// utf8 related
|
||||||
static constexpr auto last_1byte_value = 0x7Fu;
|
static constexpr auto last_1byte_value = 0x7Fu;
|
||||||
static constexpr auto last_2byte_value = 0x7FFu;
|
static constexpr auto last_2byte_value = 0x7FFu;
|
||||||
static constexpr auto last_3byte_value = 0xFFFFu;
|
static constexpr auto last_3byte_value = 0xFFFFu;
|
||||||
|
|
||||||
static constexpr auto start_2byte_mask = 0x80u;
|
static constexpr auto start_2byte_mask = 0x80u;
|
||||||
static constexpr auto start_3byte_mask = 0xE0u;
|
static constexpr auto start_3byte_mask = 0xE0u;
|
||||||
static constexpr auto start_4byte_mask = 0xF0u;
|
static constexpr auto start_4byte_mask = 0xF0u;
|
||||||
|
|
||||||
static constexpr auto continuation_mask = 0xC0u;
|
static constexpr auto continuation_mask = 0xC0u;
|
||||||
static constexpr auto continuation_signature = 0x80u;
|
static constexpr auto continuation_signature = 0x80u;
|
||||||
|
|
||||||
static constexpr bool is_invalid(unsigned char b) {
|
static constexpr bool is_invalid(unsigned char b) {
|
||||||
return b == 0xC0 || b == 0xC1 || b > 0xF4;
|
return b == 0xC0 || b == 0xC1 || b > 0xF4;
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr bool is_continuation(unsigned char b) {
|
static constexpr bool is_continuation(unsigned char b) {
|
||||||
return (b & unicode_detail::continuation_mask) == unicode_detail::continuation_signature;
|
return (b & unicode_detail::continuation_mask) == unicode_detail::continuation_signature;
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr bool is_overlong(char32_t u, std::size_t bytes) {
|
static constexpr bool is_overlong(char32_t u, std::size_t bytes) {
|
||||||
return u <= unicode_detail::last_1byte_value || (u <= unicode_detail::last_2byte_value && bytes > 2)
|
return u <= unicode_detail::last_1byte_value || (u <= unicode_detail::last_2byte_value && bytes > 2)
|
||||||
|| (u <= unicode_detail::last_3byte_value && bytes > 3);
|
|| (u <= unicode_detail::last_3byte_value && bytes > 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr int sequence_length(unsigned char b) {
|
static constexpr int sequence_length(unsigned char b) {
|
||||||
return (b & start_2byte_mask) == 0 ? 1
|
return (b & start_2byte_mask) == 0 ? 1
|
||||||
: (b & start_3byte_mask) != start_3byte_mask ? 2
|
: (b & start_3byte_mask) != start_3byte_mask ? 2
|
||||||
: (b & start_4byte_mask) != start_4byte_mask ? 3
|
: (b & start_4byte_mask) != start_4byte_mask ? 3
|
||||||
: 4;
|
: 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr char32_t decode(unsigned char b0, unsigned char b1) {
|
static constexpr char32_t decode(unsigned char b0, unsigned char b1) {
|
||||||
return (static_cast<char32_t>((b0 & 0x1Fu) << 6u) | static_cast<char32_t>(b1 & 0x3Fu));
|
return (static_cast<char32_t>((b0 & 0x1Fu) << 6u) | static_cast<char32_t>(b1 & 0x3Fu));
|
||||||
}
|
}
|
||||||
static constexpr char32_t decode(unsigned char b0, unsigned char b1, unsigned char b2) {
|
static constexpr char32_t decode(unsigned char b0, unsigned char b1, unsigned char b2) {
|
||||||
return static_cast<char32_t>((b0 & 0x0Fu) << 12u) | static_cast<char32_t>((b1 & 0x3Fu) << 6u) | static_cast<char32_t>(b2 & 0x3Fu);
|
return static_cast<char32_t>((b0 & 0x0Fu) << 12u) | static_cast<char32_t>((b1 & 0x3Fu) << 6u) | static_cast<char32_t>(b2 & 0x3Fu);
|
||||||
}
|
}
|
||||||
static constexpr char32_t decode(unsigned char b0, unsigned char b1, unsigned char b2, unsigned char b3) {
|
static constexpr char32_t decode(unsigned char b0, unsigned char b1, unsigned char b2, unsigned char b3) {
|
||||||
return static_cast<char32_t>(static_cast<char32_t>((b0 & 0x07u) << 18u) | static_cast<char32_t>((b1 & 0x3F) << 12)
|
return static_cast<char32_t>(static_cast<char32_t>((b0 & 0x07u) << 18u) | static_cast<char32_t>((b1 & 0x3F) << 12)
|
||||||
| static_cast<char32_t>((b2 & 0x3Fu) << 6u) | static_cast<char32_t>(b3 & 0x3Fu));
|
| static_cast<char32_t>((b2 & 0x3Fu) << 6u) | static_cast<char32_t>(b3 & 0x3Fu));
|
||||||
}
|
}
|
||||||
|
|
||||||
// utf16 related
|
// utf16 related
|
||||||
static constexpr char32_t last_bmp_value = 0xFFFF;
|
static constexpr char32_t last_bmp_value = 0xFFFF;
|
||||||
static constexpr char32_t normalizing_value = 0x10000;
|
static constexpr char32_t normalizing_value = 0x10000;
|
||||||
static constexpr int lead_surrogate_bitmask = 0xFFC00;
|
static constexpr int lead_surrogate_bitmask = 0xFFC00;
|
||||||
static constexpr int trail_surrogate_bitmask = 0x3FF;
|
static constexpr int trail_surrogate_bitmask = 0x3FF;
|
||||||
static constexpr int lead_shifted_bits = 10;
|
static constexpr int lead_shifted_bits = 10;
|
||||||
static constexpr char32_t replacement = 0xFFFD;
|
static constexpr char32_t replacement = 0xFFFD;
|
||||||
|
|
||||||
static char32_t combine_surrogates(char16_t lead, char16_t trail) {
|
static char32_t combine_surrogates(char16_t lead, char16_t trail) {
|
||||||
auto hi = lead - first_lead_surrogate;
|
auto hi = lead - first_lead_surrogate;
|
||||||
auto lo = trail - first_trail_surrogate;
|
auto lo = trail - first_trail_surrogate;
|
||||||
return normalizing_value + ((hi << lead_shifted_bits) | lo);
|
return normalizing_value + ((hi << lead_shifted_bits) | lo);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
inline encoded_result<char> code_point_to_utf8(char32_t codepoint) {
|
inline encoded_result<char> code_point_to_utf8(char32_t codepoint) {
|
||||||
encoded_result<char> er;
|
encoded_result<char> er;
|
||||||
er.error = error_code::ok;
|
er.error = error_code::ok;
|
||||||
if (codepoint <= unicode_detail::last_1byte_value) {
|
if (codepoint <= unicode_detail::last_1byte_value) {
|
||||||
er.code_units_size = 1;
|
er.code_units_size = 1;
|
||||||
er.code_units = std::array<char, 4> { { static_cast<char>(codepoint) } };
|
er.code_units = std::array<char, 4> { { static_cast<char>(codepoint) } };
|
||||||
}
|
}
|
||||||
else if (codepoint <= unicode_detail::last_2byte_value) {
|
else if (codepoint <= unicode_detail::last_2byte_value) {
|
||||||
er.code_units_size = 2;
|
er.code_units_size = 2;
|
||||||
er.code_units = std::array<char, 4> { {
|
er.code_units = std::array<char, 4> { {
|
||||||
static_cast<char>(0xC0 | ((codepoint & 0x7C0) >> 6)),
|
static_cast<char>(0xC0 | ((codepoint & 0x7C0) >> 6)),
|
||||||
static_cast<char>(0x80 | (codepoint & 0x3F)),
|
static_cast<char>(0x80 | (codepoint & 0x3F)),
|
||||||
} };
|
} };
|
||||||
}
|
}
|
||||||
else if (codepoint <= unicode_detail::last_3byte_value) {
|
else if (codepoint <= unicode_detail::last_3byte_value) {
|
||||||
er.code_units_size = 3;
|
er.code_units_size = 3;
|
||||||
er.code_units = std::array<char, 4> { {
|
er.code_units = std::array<char, 4> { {
|
||||||
static_cast<char>(0xE0 | ((codepoint & 0xF000) >> 12)),
|
static_cast<char>(0xE0 | ((codepoint & 0xF000) >> 12)),
|
||||||
static_cast<char>(0x80 | ((codepoint & 0xFC0) >> 6)),
|
static_cast<char>(0x80 | ((codepoint & 0xFC0) >> 6)),
|
||||||
static_cast<char>(0x80 | (codepoint & 0x3F)),
|
static_cast<char>(0x80 | (codepoint & 0x3F)),
|
||||||
} };
|
} };
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
er.code_units_size = 4;
|
er.code_units_size = 4;
|
||||||
er.code_units = std::array<char, 4> { {
|
er.code_units = std::array<char, 4> { {
|
||||||
static_cast<char>(0xF0 | ((codepoint & 0x1C0000) >> 18)),
|
static_cast<char>(0xF0 | ((codepoint & 0x1C0000) >> 18)),
|
||||||
static_cast<char>(0x80 | ((codepoint & 0x3F000) >> 12)),
|
static_cast<char>(0x80 | ((codepoint & 0x3F000) >> 12)),
|
||||||
static_cast<char>(0x80 | ((codepoint & 0xFC0) >> 6)),
|
static_cast<char>(0x80 | ((codepoint & 0xFC0) >> 6)),
|
||||||
static_cast<char>(0x80 | (codepoint & 0x3F)),
|
static_cast<char>(0x80 | (codepoint & 0x3F)),
|
||||||
} };
|
} };
|
||||||
}
|
}
|
||||||
return er;
|
return er;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline encoded_result<char16_t> code_point_to_utf16(char32_t codepoint) {
|
inline encoded_result<char16_t> code_point_to_utf16(char32_t codepoint) {
|
||||||
encoded_result<char16_t> er;
|
encoded_result<char16_t> er;
|
||||||
|
|
||||||
if (codepoint <= unicode_detail::last_bmp_value) {
|
if (codepoint <= unicode_detail::last_bmp_value) {
|
||||||
er.code_units_size = 1;
|
er.code_units_size = 1;
|
||||||
er.code_units = std::array<char16_t, 4> { { static_cast<char16_t>(codepoint) } };
|
er.code_units = std::array<char16_t, 4> { { static_cast<char16_t>(codepoint) } };
|
||||||
er.error = error_code::ok;
|
er.error = error_code::ok;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
auto normal = codepoint - unicode_detail::normalizing_value;
|
auto normal = codepoint - unicode_detail::normalizing_value;
|
||||||
auto lead = unicode_detail::first_lead_surrogate + ((normal & unicode_detail::lead_surrogate_bitmask) >> unicode_detail::lead_shifted_bits);
|
auto lead = unicode_detail::first_lead_surrogate + ((normal & unicode_detail::lead_surrogate_bitmask) >> unicode_detail::lead_shifted_bits);
|
||||||
auto trail = unicode_detail::first_trail_surrogate + (normal & unicode_detail::trail_surrogate_bitmask);
|
auto trail = unicode_detail::first_trail_surrogate + (normal & unicode_detail::trail_surrogate_bitmask);
|
||||||
er.code_units = std::array<char16_t, 4> { { static_cast<char16_t>(lead), static_cast<char16_t>(trail) } };
|
er.code_units = std::array<char16_t, 4> { { static_cast<char16_t>(lead), static_cast<char16_t>(trail) } };
|
||||||
er.code_units_size = 2;
|
er.code_units_size = 2;
|
||||||
er.error = error_code::ok;
|
er.error = error_code::ok;
|
||||||
}
|
}
|
||||||
return er;
|
return er;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline encoded_result<char32_t> code_point_to_utf32(char32_t codepoint) {
|
inline encoded_result<char32_t> code_point_to_utf32(char32_t codepoint) {
|
||||||
encoded_result<char32_t> er;
|
encoded_result<char32_t> er;
|
||||||
er.code_units_size = 1;
|
er.code_units_size = 1;
|
||||||
er.code_units[0] = codepoint;
|
er.code_units[0] = codepoint;
|
||||||
er.error = error_code::ok;
|
er.error = error_code::ok;
|
||||||
return er;
|
return er;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename It>
|
template <typename It>
|
||||||
inline decoded_result<It> utf8_to_code_point(It it, It last) {
|
inline decoded_result<It> utf8_to_code_point(It it, It last) {
|
||||||
decoded_result<It> dr;
|
decoded_result<It> dr;
|
||||||
if (it == last) {
|
if (it == last) {
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
dr.error = error_code::sequence_too_short;
|
dr.error = error_code::sequence_too_short;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned char b0 = static_cast<unsigned char>(*it);
|
unsigned char b0 = static_cast<unsigned char>(*it);
|
||||||
std::size_t length = static_cast<std::size_t>(unicode_detail::sequence_length(b0));
|
std::size_t length = static_cast<std::size_t>(unicode_detail::sequence_length(b0));
|
||||||
|
|
||||||
if (length == 1) {
|
if (length == 1) {
|
||||||
dr.codepoint = static_cast<char32_t>(b0);
|
dr.codepoint = static_cast<char32_t>(b0);
|
||||||
dr.error = error_code::ok;
|
dr.error = error_code::ok;
|
||||||
++it;
|
++it;
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unicode_detail::is_invalid(b0) || unicode_detail::is_continuation(b0)) {
|
if (unicode_detail::is_invalid(b0) || unicode_detail::is_continuation(b0)) {
|
||||||
dr.error = error_code::invalid_code_unit;
|
dr.error = error_code::invalid_code_unit;
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
|
|
||||||
++it;
|
++it;
|
||||||
std::array<unsigned char, 4> b;
|
std::array<unsigned char, 4> b;
|
||||||
b[0] = b0;
|
b[0] = b0;
|
||||||
for (std::size_t i = 1; i < length; ++i) {
|
for (std::size_t i = 1; i < length; ++i) {
|
||||||
b[i] = static_cast<unsigned char>(*it);
|
b[i] = static_cast<unsigned char>(*it);
|
||||||
if (!unicode_detail::is_continuation(b[i])) {
|
if (!unicode_detail::is_continuation(b[i])) {
|
||||||
dr.error = error_code::invalid_code_unit;
|
dr.error = error_code::invalid_code_unit;
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
++it;
|
++it;
|
||||||
}
|
}
|
||||||
|
|
||||||
char32_t decoded;
|
char32_t decoded;
|
||||||
switch (length) {
|
switch (length) {
|
||||||
case 2:
|
case 2:
|
||||||
decoded = unicode_detail::decode(b[0], b[1]);
|
decoded = unicode_detail::decode(b[0], b[1]);
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
decoded = unicode_detail::decode(b[0], b[1], b[2]);
|
decoded = unicode_detail::decode(b[0], b[1], b[2]);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
decoded = unicode_detail::decode(b[0], b[1], b[2], b[3]);
|
decoded = unicode_detail::decode(b[0], b[1], b[2], b[3]);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unicode_detail::is_overlong(decoded, length)) {
|
if (unicode_detail::is_overlong(decoded, length)) {
|
||||||
dr.error = error_code::overlong_sequence;
|
dr.error = error_code::overlong_sequence;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
if (unicode_detail::is_surrogate(decoded) || decoded > unicode_detail::last_code_point) {
|
if (unicode_detail::is_surrogate(decoded) || decoded > unicode_detail::last_code_point) {
|
||||||
dr.error = error_code::invalid_code_point;
|
dr.error = error_code::invalid_code_point;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// then everything is fine
|
// then everything is fine
|
||||||
dr.codepoint = decoded;
|
dr.codepoint = decoded;
|
||||||
dr.error = error_code::ok;
|
dr.error = error_code::ok;
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename It>
|
template <typename It>
|
||||||
inline decoded_result<It> utf16_to_code_point(It it, It last) {
|
inline decoded_result<It> utf16_to_code_point(It it, It last) {
|
||||||
decoded_result<It> dr;
|
decoded_result<It> dr;
|
||||||
if (it == last) {
|
if (it == last) {
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
dr.error = error_code::sequence_too_short;
|
dr.error = error_code::sequence_too_short;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
|
|
||||||
char16_t lead = static_cast<char16_t>(*it);
|
char16_t lead = static_cast<char16_t>(*it);
|
||||||
|
|
||||||
if (!unicode_detail::is_surrogate(lead)) {
|
if (!unicode_detail::is_surrogate(lead)) {
|
||||||
++it;
|
++it;
|
||||||
dr.codepoint = static_cast<char32_t>(lead);
|
dr.codepoint = static_cast<char32_t>(lead);
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
dr.error = error_code::ok;
|
dr.error = error_code::ok;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
if (!unicode_detail::is_lead_surrogate(lead)) {
|
if (!unicode_detail::is_lead_surrogate(lead)) {
|
||||||
dr.error = error_code::invalid_leading_surrogate;
|
dr.error = error_code::invalid_leading_surrogate;
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
|
|
||||||
++it;
|
++it;
|
||||||
auto trail = *it;
|
auto trail = *it;
|
||||||
if (!unicode_detail::is_trail_surrogate(trail)) {
|
if (!unicode_detail::is_trail_surrogate(trail)) {
|
||||||
dr.error = error_code::invalid_trailing_surrogate;
|
dr.error = error_code::invalid_trailing_surrogate;
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
|
|
||||||
dr.codepoint = unicode_detail::combine_surrogates(lead, trail);
|
dr.codepoint = unicode_detail::combine_surrogates(lead, trail);
|
||||||
dr.next = ++it;
|
dr.next = ++it;
|
||||||
dr.error = error_code::ok;
|
dr.error = error_code::ok;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename It>
|
template <typename It>
|
||||||
inline decoded_result<It> utf32_to_code_point(It it, It last) {
|
inline decoded_result<It> utf32_to_code_point(It it, It last) {
|
||||||
decoded_result<It> dr;
|
decoded_result<It> dr;
|
||||||
if (it == last) {
|
if (it == last) {
|
||||||
dr.next = it;
|
dr.next = it;
|
||||||
dr.error = error_code::sequence_too_short;
|
dr.error = error_code::sequence_too_short;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
dr.codepoint = static_cast<char32_t>(*it);
|
dr.codepoint = static_cast<char32_t>(*it);
|
||||||
dr.next = ++it;
|
dr.next = ++it;
|
||||||
dr.error = error_code::ok;
|
dr.error = error_code::ok;
|
||||||
return dr;
|
return dr;
|
||||||
}
|
}
|
||||||
} // namespace unicode
|
} // namespace unicode
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
480
extern/sol3/sol/unique_usertype_traits.hpp
vendored
480
extern/sol3/sol/unique_usertype_traits.hpp
vendored
|
@ -1,240 +1,240 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_UNIQUE_USERTYPE_TRAITS_HPP
|
#ifndef SOL_UNIQUE_USERTYPE_TRAITS_HPP
|
||||||
#define SOL_UNIQUE_USERTYPE_TRAITS_HPP
|
#define SOL_UNIQUE_USERTYPE_TRAITS_HPP
|
||||||
|
|
||||||
#include <sol/base_traits.hpp>
|
#include <sol/base_traits.hpp>
|
||||||
#include <sol/pointer_like.hpp>
|
#include <sol/pointer_like.hpp>
|
||||||
|
|
||||||
#include <sol/forward.hpp>
|
#include <sol/forward.hpp>
|
||||||
|
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unique_fallback {
|
struct unique_fallback {
|
||||||
using SOL_INTERNAL_UNSPECIALIZED_MARKER_ = int;
|
using SOL_INTERNAL_UNSPECIALIZED_MARKER_ = int;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unique_fallback<std::shared_ptr<T>> {
|
struct unique_fallback<std::shared_ptr<T>> {
|
||||||
private:
|
private:
|
||||||
using pointer = typename std::pointer_traits<std::shared_ptr<T>>::element_type*;
|
using pointer = typename std::pointer_traits<std::shared_ptr<T>>::element_type*;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// rebind is non-void
|
// rebind is non-void
|
||||||
// if and only if unique usertype
|
// if and only if unique usertype
|
||||||
// is cast-capable
|
// is cast-capable
|
||||||
template <typename X>
|
template <typename X>
|
||||||
using rebind_actual_type = std::shared_ptr<X>;
|
using rebind_actual_type = std::shared_ptr<X>;
|
||||||
|
|
||||||
static bool is_null(lua_State*, const std::shared_ptr<T>& p) noexcept {
|
static bool is_null(lua_State*, const std::shared_ptr<T>& p) noexcept {
|
||||||
return p == nullptr;
|
return p == nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static pointer get(lua_State*, const std::shared_ptr<T>& p) noexcept {
|
static pointer get(lua_State*, const std::shared_ptr<T>& p) noexcept {
|
||||||
return p.get();
|
return p.get();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T, typename D>
|
template <typename T, typename D>
|
||||||
struct unique_fallback<std::unique_ptr<T, D>> {
|
struct unique_fallback<std::unique_ptr<T, D>> {
|
||||||
private:
|
private:
|
||||||
using pointer = typename std::unique_ptr<T, D>::pointer;
|
using pointer = typename std::unique_ptr<T, D>::pointer;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static bool is_null(lua_State*, const std::unique_ptr<T, D>& p) noexcept {
|
static bool is_null(lua_State*, const std::unique_ptr<T, D>& p) noexcept {
|
||||||
return p == nullptr;
|
return p == nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static pointer get(lua_State*, const std::unique_ptr<T, D>& p) noexcept {
|
static pointer get(lua_State*, const std::unique_ptr<T, D>& p) noexcept {
|
||||||
return p.get();
|
return p.get();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
namespace meta { namespace meta_detail {
|
namespace meta { namespace meta_detail {
|
||||||
template <typename T, typename = void>
|
template <typename T, typename = void>
|
||||||
struct unique_actual_type;
|
struct unique_actual_type;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unique_actual_type<T, meta::void_t<typename T::actual_type>> {
|
struct unique_actual_type<T, meta::void_t<typename T::actual_type>> {
|
||||||
using type = typename T::actual_type;
|
using type = typename T::actual_type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T, typename... Rest, template <typename...> class Templ>
|
template <typename T, typename... Rest, template <typename...> class Templ>
|
||||||
struct unique_actual_type<Templ<T, Rest...>> {
|
struct unique_actual_type<Templ<T, Rest...>> {
|
||||||
using type = T;
|
using type = T;
|
||||||
};
|
};
|
||||||
|
|
||||||
}} // namespace meta::meta_detail
|
}} // namespace meta::meta_detail
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using unique_usertype_actual_t = typename meta::meta_detail::unique_actual_type<unique_usertype_traits<T>>::type;
|
using unique_usertype_actual_t = typename meta::meta_detail::unique_actual_type<unique_usertype_traits<T>>::type;
|
||||||
|
|
||||||
namespace meta { namespace meta_detail {
|
namespace meta { namespace meta_detail {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using value_test_t = decltype(T::value);
|
using value_test_t = decltype(T::value);
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using type_test_t = typename T::type;
|
using type_test_t = typename T::type;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using type_element_type_t = typename T::element_type;
|
using type_element_type_t = typename T::element_type;
|
||||||
|
|
||||||
template <typename T, typename = void>
|
template <typename T, typename = void>
|
||||||
struct unique_element_type {
|
struct unique_element_type {
|
||||||
using type = typename std::pointer_traits<typename unique_actual_type<T>::type>::element_type;
|
using type = typename std::pointer_traits<typename unique_actual_type<T>::type>::element_type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unique_element_type<T, std::enable_if_t<meta::is_detected_v<type_element_type_t, T>>> {
|
struct unique_element_type<T, std::enable_if_t<meta::is_detected_v<type_element_type_t, T>>> {
|
||||||
using type = typename T::element_type;
|
using type = typename T::element_type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unique_element_type<T, std::enable_if_t<meta::is_detected_v<type_test_t, T>>> {
|
struct unique_element_type<T, std::enable_if_t<meta::is_detected_v<type_test_t, T>>> {
|
||||||
using type = typename T::type;
|
using type = typename T::type;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T, typename = void>
|
template <typename T, typename = void>
|
||||||
struct unique_valid : std::integral_constant<bool, !has_internal_marker_v<T>> { };
|
struct unique_valid : std::integral_constant<bool, !has_internal_marker_v<T>> { };
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unique_valid<T, meta::void_t<decltype(T::value)>> : std::integral_constant<bool, T::value> { };
|
struct unique_valid<T, meta::void_t<decltype(T::value)>> : std::integral_constant<bool, T::value> { };
|
||||||
}} // namespace meta::meta_detail
|
}} // namespace meta::meta_detail
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using unique_usertype_element_t = typename meta::meta_detail::unique_element_type<unique_usertype_traits<T>>::type;
|
using unique_usertype_element_t = typename meta::meta_detail::unique_element_type<unique_usertype_traits<T>>::type;
|
||||||
|
|
||||||
template <typename T, typename Element = void>
|
template <typename T, typename Element = void>
|
||||||
using unique_usertype_rebind_actual_t = typename unique_usertype_traits<T>::template rebind_actual_type<Element>;
|
using unique_usertype_rebind_actual_t = typename unique_usertype_traits<T>::template rebind_actual_type<Element>;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unique_usertype_traits : public detail::unique_fallback<T> { };
|
struct unique_usertype_traits : public detail::unique_fallback<T> { };
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct is_unique_usertype : std::integral_constant<bool, meta::meta_detail::unique_valid<unique_usertype_traits<T>>::value> { };
|
struct is_unique_usertype : std::integral_constant<bool, meta::meta_detail::unique_valid<unique_usertype_traits<T>>::value> { };
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline constexpr bool is_unique_usertype_v = is_unique_usertype<T>::value;
|
inline constexpr bool is_unique_usertype_v = is_unique_usertype<T>::value;
|
||||||
|
|
||||||
namespace meta { namespace meta_detail {
|
namespace meta { namespace meta_detail {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using adl_sol_lua_check_access_test_t
|
using adl_sol_lua_check_access_test_t
|
||||||
= decltype(sol_lua_check_access(types<T>(), static_cast<lua_State*>(nullptr), -1, std::declval<stack::record&>()));
|
= decltype(sol_lua_check_access(types<T>(), static_cast<lua_State*>(nullptr), -1, std::declval<stack::record&>()));
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline constexpr bool is_adl_sol_lua_check_access_v = meta::is_detected_v<adl_sol_lua_check_access_test_t, T>;
|
inline constexpr bool is_adl_sol_lua_check_access_v = meta::is_detected_v<adl_sol_lua_check_access_test_t, T>;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using unique_usertype_get_with_state_test_t
|
using unique_usertype_get_with_state_test_t
|
||||||
= decltype(unique_usertype_traits<T>::get(static_cast<lua_State*>(nullptr), std::declval<unique_usertype_actual_t<T>>()));
|
= decltype(unique_usertype_traits<T>::get(static_cast<lua_State*>(nullptr), std::declval<unique_usertype_actual_t<T>>()));
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline constexpr bool unique_usertype_get_with_state_v = meta::is_detected_v<unique_usertype_get_with_state_test_t, T>;
|
inline constexpr bool unique_usertype_get_with_state_v = meta::is_detected_v<unique_usertype_get_with_state_test_t, T>;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using unique_usertype_is_null_with_state_test_t
|
using unique_usertype_is_null_with_state_test_t
|
||||||
= decltype(unique_usertype_traits<T>::is_null(static_cast<lua_State*>(nullptr), std::declval<unique_usertype_actual_t<T>>()));
|
= decltype(unique_usertype_traits<T>::is_null(static_cast<lua_State*>(nullptr), std::declval<unique_usertype_actual_t<T>>()));
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline constexpr bool unique_usertype_is_null_with_state_v = meta::is_detected_v<unique_usertype_is_null_with_state_test_t, T>;
|
inline constexpr bool unique_usertype_is_null_with_state_v = meta::is_detected_v<unique_usertype_is_null_with_state_test_t, T>;
|
||||||
}} // namespace meta::meta_detail
|
}} // namespace meta::meta_detail
|
||||||
|
|
||||||
namespace detail {
|
namespace detail {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
constexpr bool unique_is_null_noexcept() noexcept {
|
constexpr bool unique_is_null_noexcept() noexcept {
|
||||||
if constexpr (meta::meta_detail::unique_usertype_is_null_with_state_v<std::remove_cv_t<T>>) {
|
if constexpr (meta::meta_detail::unique_usertype_is_null_with_state_v<std::remove_cv_t<T>>) {
|
||||||
return noexcept(
|
return noexcept(
|
||||||
unique_usertype_traits<T>::is_null(static_cast<lua_State*>(nullptr), std::declval<unique_usertype_actual_t<std::remove_cv_t<T>>>()));
|
unique_usertype_traits<T>::is_null(static_cast<lua_State*>(nullptr), std::declval<unique_usertype_actual_t<std::remove_cv_t<T>>>()));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return noexcept(unique_usertype_traits<T>::is_null(std::declval<unique_usertype_actual_t<std::remove_cv_t<T>>>()));
|
return noexcept(unique_usertype_traits<T>::is_null(std::declval<unique_usertype_actual_t<std::remove_cv_t<T>>>()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
bool unique_is_null(lua_State* L_, T& value_) noexcept(unique_is_null_noexcept<std::remove_cv_t<T>>()) {
|
bool unique_is_null(lua_State* L_, T& value_) noexcept(unique_is_null_noexcept<std::remove_cv_t<T>>()) {
|
||||||
using Tu = std::remove_cv_t<T>;
|
using Tu = std::remove_cv_t<T>;
|
||||||
if constexpr (meta::meta_detail::unique_usertype_is_null_with_state_v<Tu>) {
|
if constexpr (meta::meta_detail::unique_usertype_is_null_with_state_v<Tu>) {
|
||||||
return unique_usertype_traits<Tu>::is_null(L_, value_);
|
return unique_usertype_traits<Tu>::is_null(L_, value_);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return unique_usertype_traits<Tu>::is_null(value_);
|
return unique_usertype_traits<Tu>::is_null(value_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
constexpr bool unique_get_noexcept() noexcept {
|
constexpr bool unique_get_noexcept() noexcept {
|
||||||
if constexpr (meta::meta_detail::unique_usertype_get_with_state_v<std::remove_cv_t<T>>) {
|
if constexpr (meta::meta_detail::unique_usertype_get_with_state_v<std::remove_cv_t<T>>) {
|
||||||
return noexcept(
|
return noexcept(
|
||||||
unique_usertype_traits<T>::get(static_cast<lua_State*>(nullptr), std::declval<unique_usertype_actual_t<std::remove_cv_t<T>>>()));
|
unique_usertype_traits<T>::get(static_cast<lua_State*>(nullptr), std::declval<unique_usertype_actual_t<std::remove_cv_t<T>>>()));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return noexcept(unique_usertype_traits<T>::get(std::declval<unique_usertype_actual_t<std::remove_cv_t<T>>>()));
|
return noexcept(unique_usertype_traits<T>::get(std::declval<unique_usertype_actual_t<std::remove_cv_t<T>>>()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
auto unique_get(lua_State* L_, T& value_) noexcept(unique_get_noexcept<std::remove_cv_t<T>>()) {
|
auto unique_get(lua_State* L_, T& value_) noexcept(unique_get_noexcept<std::remove_cv_t<T>>()) {
|
||||||
using Tu = std::remove_cv_t<T>;
|
using Tu = std::remove_cv_t<T>;
|
||||||
if constexpr (meta::meta_detail::unique_usertype_get_with_state_v<Tu>) {
|
if constexpr (meta::meta_detail::unique_usertype_get_with_state_v<Tu>) {
|
||||||
return unique_usertype_traits<Tu>::get(L_, value_);
|
return unique_usertype_traits<Tu>::get(L_, value_);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return unique_usertype_traits<Tu>::get(value_);
|
return unique_usertype_traits<Tu>::get(value_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
|
|
||||||
namespace meta { namespace meta_detail {
|
namespace meta { namespace meta_detail {
|
||||||
template <typename T, typename Element = void>
|
template <typename T, typename Element = void>
|
||||||
using is_rebind_actual_type_test_t = typename T::template rebind_actual_type<Element>;
|
using is_rebind_actual_type_test_t = typename T::template rebind_actual_type<Element>;
|
||||||
|
|
||||||
template <typename T, typename Element = void>
|
template <typename T, typename Element = void>
|
||||||
using is_rebind_actual_type = meta::is_detected<is_rebind_actual_type_test_t, T, Element>;
|
using is_rebind_actual_type = meta::is_detected<is_rebind_actual_type_test_t, T, Element>;
|
||||||
|
|
||||||
template <typename T, typename Element = void>
|
template <typename T, typename Element = void>
|
||||||
inline constexpr bool is_rebind_actual_type_v = is_rebind_actual_type<T, Element>::value;
|
inline constexpr bool is_rebind_actual_type_v = is_rebind_actual_type<T, Element>::value;
|
||||||
|
|
||||||
template <typename T, typename Element, bool = is_rebind_actual_type_v<T, Element>>
|
template <typename T, typename Element, bool = is_rebind_actual_type_v<T, Element>>
|
||||||
struct is_actual_type_rebindable_for_test : std::false_type { };
|
struct is_actual_type_rebindable_for_test : std::false_type { };
|
||||||
|
|
||||||
template <typename T, typename Element>
|
template <typename T, typename Element>
|
||||||
struct is_actual_type_rebindable_for_test<T, Element, true>
|
struct is_actual_type_rebindable_for_test<T, Element, true>
|
||||||
: std::integral_constant<bool, !std::is_void_v<typename T::template rebind_actual_type<Element>>> { };
|
: std::integral_constant<bool, !std::is_void_v<typename T::template rebind_actual_type<Element>>> { };
|
||||||
}} // namespace meta::meta_detail
|
}} // namespace meta::meta_detail
|
||||||
|
|
||||||
template <typename T, typename Element = void>
|
template <typename T, typename Element = void>
|
||||||
using is_actual_type_rebindable_for = typename meta::meta_detail::is_actual_type_rebindable_for_test<unique_usertype_traits<T>, Element>::type;
|
using is_actual_type_rebindable_for = typename meta::meta_detail::is_actual_type_rebindable_for_test<unique_usertype_traits<T>, Element>::type;
|
||||||
|
|
||||||
template <typename T, typename Element = void>
|
template <typename T, typename Element = void>
|
||||||
inline constexpr bool is_actual_type_rebindable_for_v = is_actual_type_rebindable_for<T, Element>::value;
|
inline constexpr bool is_actual_type_rebindable_for_v = is_actual_type_rebindable_for<T, Element>::value;
|
||||||
|
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_UNIQUE_USERTYPE_TRAITS_HPP
|
#endif // SOL_UNIQUE_USERTYPE_TRAITS_HPP
|
||||||
|
|
122
extern/sol3/sol/usertype_traits.hpp
vendored
122
extern/sol3/sol/usertype_traits.hpp
vendored
|
@ -1,61 +1,61 @@
|
||||||
// sol2
|
// sol2
|
||||||
|
|
||||||
// The MIT License (MIT)
|
// The MIT License (MIT)
|
||||||
|
|
||||||
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
// Copyright (c) 2013-2021 Rapptz, ThePhD and contributors
|
||||||
|
|
||||||
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
// this software and associated documentation files (the "Software"), to deal in
|
// this software and associated documentation files (the "Software"), to deal in
|
||||||
// the Software without restriction, including without limitation the rights to
|
// the Software without restriction, including without limitation the rights to
|
||||||
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
// the Software, and to permit persons to whom the Software is furnished to do so,
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
// subject to the following conditions:
|
// subject to the following conditions:
|
||||||
|
|
||||||
// The above copyright notice and this permission notice shall be included in all
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
// copies or substantial portions of the Software.
|
// copies or substantial portions of the Software.
|
||||||
|
|
||||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
#ifndef SOL_USERTYPE_TRAITS_HPP
|
#ifndef SOL_USERTYPE_TRAITS_HPP
|
||||||
#define SOL_USERTYPE_TRAITS_HPP
|
#define SOL_USERTYPE_TRAITS_HPP
|
||||||
|
|
||||||
#include <sol/demangle.hpp>
|
#include <sol/demangle.hpp>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol {
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct usertype_traits {
|
struct usertype_traits {
|
||||||
static const std::string& name() {
|
static const std::string& name() {
|
||||||
static const std::string& n = detail::short_demangle<T>();
|
static const std::string& n = detail::short_demangle<T>();
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
static const std::string& qualified_name() {
|
static const std::string& qualified_name() {
|
||||||
static const std::string& q_n = detail::demangle<T>();
|
static const std::string& q_n = detail::demangle<T>();
|
||||||
return q_n;
|
return q_n;
|
||||||
}
|
}
|
||||||
static const std::string& metatable() {
|
static const std::string& metatable() {
|
||||||
static const std::string m = std::string("sol.").append(detail::demangle<T>());
|
static const std::string m = std::string("sol.").append(detail::demangle<T>());
|
||||||
return m;
|
return m;
|
||||||
}
|
}
|
||||||
static const std::string& user_metatable() {
|
static const std::string& user_metatable() {
|
||||||
static const std::string u_m = std::string("sol.").append(detail::demangle<T>()).append(".user");
|
static const std::string u_m = std::string("sol.").append(detail::demangle<T>()).append(".user");
|
||||||
return u_m;
|
return u_m;
|
||||||
}
|
}
|
||||||
static const std::string& user_gc_metatable() {
|
static const std::string& user_gc_metatable() {
|
||||||
static const std::string u_g_m = std::string("sol.").append(detail::demangle<T>()).append(".user\xE2\x99\xBB");
|
static const std::string u_g_m = std::string("sol.").append(detail::demangle<T>()).append(".user\xE2\x99\xBB");
|
||||||
return u_g_m;
|
return u_g_m;
|
||||||
}
|
}
|
||||||
static const std::string& gc_table() {
|
static const std::string& gc_table() {
|
||||||
static const std::string g_t = std::string("sol.").append(detail::demangle<T>()).append(".\xE2\x99\xBB");
|
static const std::string g_t = std::string("sol.").append(detail::demangle<T>()).append(".\xE2\x99\xBB");
|
||||||
return g_t;
|
return g_t;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace sol
|
} // namespace sol
|
||||||
|
|
||||||
#endif // SOL_USERTYPE_TRAITS_HPP
|
#endif // SOL_USERTYPE_TRAITS_HPP
|
||||||
|
|
|
@ -1,71 +1,71 @@
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Coroutine Manipulation.
|
-- Coroutine Manipulation.
|
||||||
-- The operations related to coroutines comprise a sub-library of the basic library
|
-- The operations related to coroutines comprise a sub-library of the basic library
|
||||||
-- and come inside the table coroutine.
|
-- and come inside the table coroutine.
|
||||||
-- See http://www.lua.org/manual/5.1/manual.html#2.11 for a general description of coroutines.
|
-- See http://www.lua.org/manual/5.1/manual.html#2.11 for a general description of coroutines.
|
||||||
-- @module coroutine
|
-- @module coroutine
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Creates a new coroutine, with body `f`. `f` must be a Lua
|
-- Creates a new coroutine, with body `f`. `f` must be a Lua
|
||||||
-- function. Returns this new coroutine, an object with type `"thread"`.
|
-- function. Returns this new coroutine, an object with type `"thread"`.
|
||||||
-- @function [parent=#coroutine] create
|
-- @function [parent=#coroutine] create
|
||||||
-- @param f a function used as coroutine body.
|
-- @param f a function used as coroutine body.
|
||||||
-- @return #thread a new coroutine.
|
-- @return #thread a new coroutine.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Starts or continues the execution of coroutine `co`. The first time
|
-- Starts or continues the execution of coroutine `co`. The first time
|
||||||
-- you resume a coroutine, it starts running its body. The values `val1`,
|
-- you resume a coroutine, it starts running its body. The values `val1`,
|
||||||
-- ... are passed as the arguments to the body function. If the coroutine
|
-- ... are passed as the arguments to the body function. If the coroutine
|
||||||
-- has yielded, `resume` restarts it; the values `val1`, ... are passed
|
-- has yielded, `resume` restarts it; the values `val1`, ... are passed
|
||||||
-- as the results from the yield.
|
-- as the results from the yield.
|
||||||
--
|
--
|
||||||
-- If the coroutine runs without any errors, `resume` returns true plus any
|
-- If the coroutine runs without any errors, `resume` returns true plus any
|
||||||
-- values passed to `yield` (if the coroutine yields) or any values returned
|
-- values passed to `yield` (if the coroutine yields) or any values returned
|
||||||
-- by the body function (if the coroutine terminates). If there is any error,
|
-- by the body function (if the coroutine terminates). If there is any error,
|
||||||
-- `resume` returns false plus the error message.
|
-- `resume` returns false plus the error message.
|
||||||
-- @function [parent=#coroutine] resume
|
-- @function [parent=#coroutine] resume
|
||||||
-- @param #thread co coroutine to start or resume.
|
-- @param #thread co coroutine to start or resume.
|
||||||
-- @param ... arguments passed to the body function or as result of yield call.
|
-- @param ... arguments passed to the body function or as result of yield call.
|
||||||
-- @return #boolean true plus any values passed to `yield` (if the coroutine yields) or any values returned
|
-- @return #boolean true plus any values passed to `yield` (if the coroutine yields) or any values returned
|
||||||
-- by the body function (if the coroutine terminates)
|
-- by the body function (if the coroutine terminates)
|
||||||
-- @return #boolean false plus an error message.
|
-- @return #boolean false plus an error message.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the running coroutine, or nil when called by the main thread.
|
-- Returns the running coroutine, or nil when called by the main thread.
|
||||||
-- @function [parent=#coroutine] running
|
-- @function [parent=#coroutine] running
|
||||||
-- @return #thread the running coroutine, or nil when called by the main thread.
|
-- @return #thread the running coroutine, or nil when called by the main thread.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the status of coroutine `co`, as a string: `"running"`, if
|
-- Returns the status of coroutine `co`, as a string: `"running"`, if
|
||||||
-- the coroutine is running (that is, it called `status`); `"suspended"`, if
|
-- the coroutine is running (that is, it called `status`); `"suspended"`, if
|
||||||
-- the coroutine is suspended in a call to `yield`, or if it has not started
|
-- the coroutine is suspended in a call to `yield`, or if it has not started
|
||||||
-- running yet; `"normal"` if the coroutine is active but not running (that
|
-- running yet; `"normal"` if the coroutine is active but not running (that
|
||||||
-- is, it has resumed another coroutine); and `"dead"` if the coroutine has
|
-- is, it has resumed another coroutine); and `"dead"` if the coroutine has
|
||||||
-- finished its body function, or if it has stopped with an error.
|
-- finished its body function, or if it has stopped with an error.
|
||||||
-- @function [parent=#coroutine] status
|
-- @function [parent=#coroutine] status
|
||||||
-- @param #thread co a coroutine
|
-- @param #thread co a coroutine
|
||||||
-- @return #string the status : `"running"`, `"suspended"`, `"normal"` or `"dead"`.
|
-- @return #string the status : `"running"`, `"suspended"`, `"normal"` or `"dead"`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Creates a new coroutine, with body `f`. `f` must be a Lua
|
-- Creates a new coroutine, with body `f`. `f` must be a Lua
|
||||||
-- function. Returns a function that resumes the coroutine each time it is
|
-- function. Returns a function that resumes the coroutine each time it is
|
||||||
-- called. Any arguments passed to the function behave as the extra arguments to
|
-- called. Any arguments passed to the function behave as the extra arguments to
|
||||||
-- `resume`. Returns the same values returned by `resume`, except the first
|
-- `resume`. Returns the same values returned by `resume`, except the first
|
||||||
-- boolean. In case of error, propagates the error.
|
-- boolean. In case of error, propagates the error.
|
||||||
-- @function [parent=#coroutine] wrap
|
-- @function [parent=#coroutine] wrap
|
||||||
-- @param f a function used as coroutine body.
|
-- @param f a function used as coroutine body.
|
||||||
-- @param ... arguments passed to the body function or as result of yield call.
|
-- @param ... arguments passed to the body function or as result of yield call.
|
||||||
-- @return Any values passed to `yield` (if the coroutine yields) or any values returned
|
-- @return Any values passed to `yield` (if the coroutine yields) or any values returned
|
||||||
-- by the body function (if the coroutine terminates).
|
-- by the body function (if the coroutine terminates).
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Suspends the execution of the calling coroutine. The coroutine cannot
|
-- Suspends the execution of the calling coroutine. The coroutine cannot
|
||||||
-- be running a C function, a metamethod, or an iterator. Any arguments to
|
-- be running a C function, a metamethod, or an iterator. Any arguments to
|
||||||
-- `yield` are passed as extra results to `resume`.
|
-- `yield` are passed as extra results to `resume`.
|
||||||
-- @function [parent=#coroutine] yield
|
-- @function [parent=#coroutine] yield
|
||||||
-- @param ... arguments passed as extra results to `resume` function.
|
-- @param ... arguments passed as extra results to `resume` function.
|
||||||
-- @return Any values passed to the `resume` function.
|
-- @return Any values passed to the `resume` function.
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -1,269 +1,269 @@
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Lua global variables.
|
-- Lua global variables.
|
||||||
-- The basic library provides some core functions to Lua.
|
-- The basic library provides some core functions to Lua.
|
||||||
-- All the preloaded module of Lua are declared here.
|
-- All the preloaded module of Lua are declared here.
|
||||||
-- @module global
|
-- @module global
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
------------------------------------------------------------------------------
|
||||||
-- This library provides generic functions for coroutine manipulation.
|
-- This library provides generic functions for coroutine manipulation.
|
||||||
-- This is a global variable which hold the preloaded @{coroutine} module.
|
-- This is a global variable which hold the preloaded @{coroutine} module.
|
||||||
-- @field[parent = #global] coroutine#coroutine coroutine preloaded module
|
-- @field[parent = #global] coroutine#coroutine coroutine preloaded module
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
------------------------------------------------------------------------------
|
||||||
-- This library provides generic functions for string manipulation.
|
-- This library provides generic functions for string manipulation.
|
||||||
-- This is a global variable which hold the preloaded @{string} module.
|
-- This is a global variable which hold the preloaded @{string} module.
|
||||||
-- @field[parent = #global] string#string string preloaded module
|
-- @field[parent = #global] string#string string preloaded module
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
------------------------------------------------------------------------------
|
||||||
-- This library provides generic functions for table manipulation.
|
-- This library provides generic functions for table manipulation.
|
||||||
-- This is a global variable which hold the preloaded @{table} module.
|
-- This is a global variable which hold the preloaded @{table} module.
|
||||||
-- @field[parent = #global] table#table table preloaded module
|
-- @field[parent = #global] table#table table preloaded module
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
------------------------------------------------------------------------------
|
||||||
-- This library is an interface to the standard C math library.
|
-- This library is an interface to the standard C math library.
|
||||||
-- This is a global variable which hold the preloaded @{math} module.
|
-- This is a global variable which hold the preloaded @{math} module.
|
||||||
-- @field[parent = #global] math#math math preloaded module
|
-- @field[parent = #global] math#math math preloaded module
|
||||||
|
|
||||||
------------------------------------------------------------------------------
|
------------------------------------------------------------------------------
|
||||||
-- This library is an interface to the standard C math library.
|
-- This library is an interface to the standard C math library.
|
||||||
-- This is a global variable which hold the preloaded @{omwutil} module.
|
-- This is a global variable which hold the preloaded @{omwutil} module.
|
||||||
-- @field[parent = #global] omwutil#omwutil ou preloaded module
|
-- @field[parent = #global] omwutil#omwutil ou preloaded module
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Issues an error when the value of its argument `v` is false (i.e.,
|
-- Issues an error when the value of its argument `v` is false (i.e.,
|
||||||
-- **nil** or **false**); otherwise, returns all its arguments. `message` is an error
|
-- **nil** or **false**); otherwise, returns all its arguments. `message` is an error
|
||||||
-- message; when absent, it defaults to *"assertion failed!"*.
|
-- message; when absent, it defaults to *"assertion failed!"*.
|
||||||
-- @function [parent=#global] assert
|
-- @function [parent=#global] assert
|
||||||
-- @param v if this argument is false an error is issued.
|
-- @param v if this argument is false an error is issued.
|
||||||
-- @param #string message an error message. defaults value is *"assertion failed"*.
|
-- @param #string message an error message. defaults value is *"assertion failed"*.
|
||||||
-- @return All its arguments.
|
-- @return All its arguments.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Terminates the last protected function called and returns `message`
|
-- Terminates the last protected function called and returns `message`
|
||||||
-- as the error message. Function `error` never returns.
|
-- as the error message. Function `error` never returns.
|
||||||
--
|
--
|
||||||
-- Usually, `error` adds some information about the error position at the
|
-- Usually, `error` adds some information about the error position at the
|
||||||
-- beginning of the message. The `level` argument specifies how to get the
|
-- beginning of the message. The `level` argument specifies how to get the
|
||||||
-- error position.
|
-- error position.
|
||||||
-- With level 1 (the default), the error position is where the
|
-- With level 1 (the default), the error position is where the
|
||||||
-- `error` function was called.
|
-- `error` function was called.
|
||||||
-- Level 2 points the error to where the function
|
-- Level 2 points the error to where the function
|
||||||
-- that called `error` was called; and so on.
|
-- that called `error` was called; and so on.
|
||||||
-- Passing a level 0 avoids the addition of error position information to the message.
|
-- Passing a level 0 avoids the addition of error position information to the message.
|
||||||
-- @function [parent=#global] error
|
-- @function [parent=#global] error
|
||||||
-- @param #string message an error message.
|
-- @param #string message an error message.
|
||||||
-- @param #number level specifies how to get the error position, default value is `1`.
|
-- @param #number level specifies how to get the error position, default value is `1`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- If `object` does not have a metatable, returns nil. Otherwise, if the
|
-- If `object` does not have a metatable, returns nil. Otherwise, if the
|
||||||
-- object's metatable has a `"__metatable"` field, returns the associated
|
-- object's metatable has a `"__metatable"` field, returns the associated
|
||||||
-- value. Otherwise, returns the metatable of the given object.
|
-- value. Otherwise, returns the metatable of the given object.
|
||||||
-- @function [parent=#global] getmetatable
|
-- @function [parent=#global] getmetatable
|
||||||
-- @param object
|
-- @param object
|
||||||
-- @return #table the metatable of object.
|
-- @return #table the metatable of object.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Use to iterate over a table by index.
|
-- Use to iterate over a table by index.
|
||||||
-- Returns three values: an iterator function, the table `t`, and 0,
|
-- Returns three values: an iterator function, the table `t`, and 0,
|
||||||
-- so that the construction :
|
-- so that the construction :
|
||||||
--
|
--
|
||||||
-- for i,v in ipairs(t) do *body* end
|
-- for i,v in ipairs(t) do *body* end
|
||||||
-- will iterate over the pairs (`1,t[1]`), (`2,t[2]`), ..., up to the
|
-- will iterate over the pairs (`1,t[1]`), (`2,t[2]`), ..., up to the
|
||||||
-- first integer key absent from the table.
|
-- first integer key absent from the table.
|
||||||
-- @function [parent=#global] ipairs
|
-- @function [parent=#global] ipairs
|
||||||
-- @param #table t a table by index.
|
-- @param #table t a table by index.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Allows a program to traverse all fields of a table. Its first argument is
|
-- Allows a program to traverse all fields of a table. Its first argument is
|
||||||
-- a table and its second argument is an index in this table. `next` returns
|
-- a table and its second argument is an index in this table. `next` returns
|
||||||
-- the next index of the table and its associated value.
|
-- the next index of the table and its associated value.
|
||||||
--
|
--
|
||||||
-- When called with nil
|
-- When called with nil
|
||||||
-- as its second argument, `next` returns an initial index and its associated
|
-- as its second argument, `next` returns an initial index and its associated
|
||||||
-- value. When called with the last index, or with nil in an empty table, `next`
|
-- value. When called with the last index, or with nil in an empty table, `next`
|
||||||
-- returns nil.
|
-- returns nil.
|
||||||
--
|
--
|
||||||
-- If the second argument is absent, then it is interpreted as
|
-- If the second argument is absent, then it is interpreted as
|
||||||
-- nil. In particular, you can use `next(t)` to check whether a table is empty.
|
-- nil. In particular, you can use `next(t)` to check whether a table is empty.
|
||||||
-- The order in which the indices are enumerated is not specified, *even for
|
-- The order in which the indices are enumerated is not specified, *even for
|
||||||
-- numeric indices*. (To traverse a table in numeric order, use a numerical
|
-- numeric indices*. (To traverse a table in numeric order, use a numerical
|
||||||
-- for or the `ipairs` function.)
|
-- for or the `ipairs` function.)
|
||||||
--
|
--
|
||||||
-- The behavior of `next` is *undefined* if, during the traversal, you assign
|
-- The behavior of `next` is *undefined* if, during the traversal, you assign
|
||||||
-- any value to a non-existent field in the table. You may however modify
|
-- any value to a non-existent field in the table. You may however modify
|
||||||
-- existing fields. In particular, you may clear existing fields.
|
-- existing fields. In particular, you may clear existing fields.
|
||||||
-- @function [parent=#global] next
|
-- @function [parent=#global] next
|
||||||
-- @param #table table table to traverse.
|
-- @param #table table table to traverse.
|
||||||
-- @param index initial index.
|
-- @param index initial index.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Use to iterate over a table.
|
-- Use to iterate over a table.
|
||||||
-- Returns three values: the `next` function, the table `t`, and nil,
|
-- Returns three values: the `next` function, the table `t`, and nil,
|
||||||
-- so that the construction :
|
-- so that the construction :
|
||||||
--
|
--
|
||||||
-- for k,v in pairs(t) do *body* end
|
-- for k,v in pairs(t) do *body* end
|
||||||
-- will iterate over all key-value pairs of table `t`.
|
-- will iterate over all key-value pairs of table `t`.
|
||||||
--
|
--
|
||||||
-- See function `next` for the caveats of modifying the table during its
|
-- See function `next` for the caveats of modifying the table during its
|
||||||
-- traversal.
|
-- traversal.
|
||||||
-- @function [parent=#global] pairs
|
-- @function [parent=#global] pairs
|
||||||
-- @param #table t table to traverse.
|
-- @param #table t table to traverse.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Calls function `f` with the given arguments in *protected mode*. This
|
-- Calls function `f` with the given arguments in *protected mode*. This
|
||||||
-- means that any error inside `f` is not propagated; instead, `pcall` catches
|
-- means that any error inside `f` is not propagated; instead, `pcall` catches
|
||||||
-- the error and returns a status code. Its first result is the status code (a
|
-- the error and returns a status code. Its first result is the status code (a
|
||||||
-- boolean), which is true if the call succeeds without errors. In such case,
|
-- boolean), which is true if the call succeeds without errors. In such case,
|
||||||
-- `pcall` also returns all results from the call, after this first result. In
|
-- `pcall` also returns all results from the call, after this first result. In
|
||||||
-- case of any error, `pcall` returns false plus the error message.
|
-- case of any error, `pcall` returns false plus the error message.
|
||||||
-- @function [parent=#global] pcall
|
-- @function [parent=#global] pcall
|
||||||
-- @param f function to be call in *protected mode*.
|
-- @param f function to be call in *protected mode*.
|
||||||
-- @param ... function arguments.
|
-- @param ... function arguments.
|
||||||
-- @return #boolean true plus the result of `f` function if its call succeeds without errors.
|
-- @return #boolean true plus the result of `f` function if its call succeeds without errors.
|
||||||
-- @return #boolean,#string false plus the error message in case of any error.
|
-- @return #boolean,#string false plus the error message in case of any error.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Receives any number of arguments, and prints their values to OpenMW log,
|
-- Receives any number of arguments, and prints their values to OpenMW log,
|
||||||
-- using the `tostring` function to convert them to strings. `print` is not
|
-- using the `tostring` function to convert them to strings. `print` is not
|
||||||
-- intended for formatted output, but only as a quick way to show a value,
|
-- intended for formatted output, but only as a quick way to show a value,
|
||||||
-- typically for debugging. For formatted output, use `string.format`.
|
-- typically for debugging. For formatted output, use `string.format`.
|
||||||
--
|
--
|
||||||
-- @function [parent=#global] print
|
-- @function [parent=#global] print
|
||||||
-- @param ... values to print to `stdout`.
|
-- @param ... values to print to `stdout`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Checks whether `v1` is equal to `v2`, without invoking any
|
-- Checks whether `v1` is equal to `v2`, without invoking any
|
||||||
-- metamethod. Returns a boolean.
|
-- metamethod. Returns a boolean.
|
||||||
-- @function [parent=#global] rawequal
|
-- @function [parent=#global] rawequal
|
||||||
-- @param v1
|
-- @param v1
|
||||||
-- @param v2
|
-- @param v2
|
||||||
-- @return #boolean true if `v1` is equal to `v2`.
|
-- @return #boolean true if `v1` is equal to `v2`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Gets the real value of `table[index]`, without invoking any
|
-- Gets the real value of `table[index]`, without invoking any
|
||||||
-- metamethod. `table` must be a table; `index` may be any value.
|
-- metamethod. `table` must be a table; `index` may be any value.
|
||||||
-- @function [parent=#global] rawget
|
-- @function [parent=#global] rawget
|
||||||
-- @param #table table
|
-- @param #table table
|
||||||
-- @param index may be any value.
|
-- @param index may be any value.
|
||||||
-- @return The real value of `table[index]`, without invoking any
|
-- @return The real value of `table[index]`, without invoking any
|
||||||
-- metamethod.
|
-- metamethod.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Sets the real value of `table[index]` to `value`, without invoking any
|
-- Sets the real value of `table[index]` to `value`, without invoking any
|
||||||
-- metamethod. `table` must be a table, `index` any value different from nil,
|
-- metamethod. `table` must be a table, `index` any value different from nil,
|
||||||
-- and `value` any Lua value.
|
-- and `value` any Lua value.
|
||||||
-- This function returns `table`.
|
-- This function returns `table`.
|
||||||
-- @function [parent=#global] rawset
|
-- @function [parent=#global] rawset
|
||||||
-- @param #table table
|
-- @param #table table
|
||||||
-- @param index any value different from nil.
|
-- @param index any value different from nil.
|
||||||
-- @param value any Lua value.
|
-- @param value any Lua value.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- If `index` is a number, returns all arguments after argument number
|
-- If `index` is a number, returns all arguments after argument number
|
||||||
-- `index`. Otherwise, `index` must be the string `"#"`, and `select` returns
|
-- `index`. Otherwise, `index` must be the string `"#"`, and `select` returns
|
||||||
-- the total number of extra arguments it received.
|
-- the total number of extra arguments it received.
|
||||||
-- @function [parent=#global] select
|
-- @function [parent=#global] select
|
||||||
-- @param index a number or the string `"#"`
|
-- @param index a number or the string `"#"`
|
||||||
-- @param ...
|
-- @param ...
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Sets the metatable for the given table. (You cannot change the metatable
|
-- Sets the metatable for the given table. (You cannot change the metatable
|
||||||
-- of other types from Lua, only from C.) If `metatable` is nil, removes the
|
-- of other types from Lua, only from C.) If `metatable` is nil, removes the
|
||||||
-- metatable of the given table. If the original metatable has a `"__metatable"`
|
-- metatable of the given table. If the original metatable has a `"__metatable"`
|
||||||
-- field, raises an error.
|
-- field, raises an error.
|
||||||
-- This function returns `table`.
|
-- This function returns `table`.
|
||||||
-- @function [parent=#global] setmetatable
|
-- @function [parent=#global] setmetatable
|
||||||
-- @param #table table
|
-- @param #table table
|
||||||
-- @param #table metatable
|
-- @param #table metatable
|
||||||
-- @return The first argument `table`.
|
-- @return The first argument `table`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Tries to convert its argument to a number. If the argument is already
|
-- Tries to convert its argument to a number. If the argument is already
|
||||||
-- a number or a string convertible to a number, then `tonumber` returns this
|
-- a number or a string convertible to a number, then `tonumber` returns this
|
||||||
-- number; otherwise, it returns **nil.**
|
-- number; otherwise, it returns **nil.**
|
||||||
--
|
--
|
||||||
-- An optional argument specifies the base to interpret the numeral. The base
|
-- An optional argument specifies the base to interpret the numeral. The base
|
||||||
-- may be any integer between 2 and 36, inclusive. In bases above 10, the
|
-- may be any integer between 2 and 36, inclusive. In bases above 10, the
|
||||||
-- letter '`A`' (in either upper or lower case) represents 10, '`B`' represents
|
-- letter '`A`' (in either upper or lower case) represents 10, '`B`' represents
|
||||||
-- 11, and so forth, with '`Z`' representing 35. In base 10 (the default),
|
-- 11, and so forth, with '`Z`' representing 35. In base 10 (the default),
|
||||||
-- the number can have a decimal part, as well as an optional exponent part.
|
-- the number can have a decimal part, as well as an optional exponent part.
|
||||||
-- In other bases, only unsigned integers are accepted.
|
-- In other bases, only unsigned integers are accepted.
|
||||||
-- @function [parent=#global] tonumber
|
-- @function [parent=#global] tonumber
|
||||||
-- @param e a number or string to convert to a number.
|
-- @param e a number or string to convert to a number.
|
||||||
-- @param #number base the base to interpret the numeral, any integer between 2 and 36.(default is 10).
|
-- @param #number base the base to interpret the numeral, any integer between 2 and 36.(default is 10).
|
||||||
-- @return #number a number if conversion succeeds else **nil**.
|
-- @return #number a number if conversion succeeds else **nil**.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Receives an argument of any type and converts it to a string in a
|
-- Receives an argument of any type and converts it to a string in a
|
||||||
-- reasonable format. For complete control of how numbers are converted, use
|
-- reasonable format. For complete control of how numbers are converted, use
|
||||||
-- `string.format`.
|
-- `string.format`.
|
||||||
--
|
--
|
||||||
-- If the metatable of `e` has a `"__tostring"` field, then `tostring` calls
|
-- If the metatable of `e` has a `"__tostring"` field, then `tostring` calls
|
||||||
-- the corresponding value with `e` as argument, and uses the result of the
|
-- the corresponding value with `e` as argument, and uses the result of the
|
||||||
-- call as its result.
|
-- call as its result.
|
||||||
-- @function [parent=#global] tostring
|
-- @function [parent=#global] tostring
|
||||||
-- @param e an argument of any type.
|
-- @param e an argument of any type.
|
||||||
-- @return #string a string in a reasonable format.
|
-- @return #string a string in a reasonable format.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the type of its only argument, coded as a string. The possible
|
-- Returns the type of its only argument, coded as a string. The possible
|
||||||
-- results of this function are "
|
-- results of this function are "
|
||||||
-- `nil`" (a string, not the value nil), "`number`", "`string`", "`boolean`",
|
-- `nil`" (a string, not the value nil), "`number`", "`string`", "`boolean`",
|
||||||
-- "`table`", "`function`", "`thread`", and "`userdata`".
|
-- "`table`", "`function`", "`thread`", and "`userdata`".
|
||||||
-- @function [parent=#global] type
|
-- @function [parent=#global] type
|
||||||
-- @param v any value.
|
-- @param v any value.
|
||||||
-- @return #string the type of `v`.
|
-- @return #string the type of `v`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the elements from the given table. This function is equivalent to
|
-- Returns the elements from the given table. This function is equivalent to
|
||||||
--
|
--
|
||||||
-- return list[i], list[i+1], ..., list[j]
|
-- return list[i], list[i+1], ..., list[j]
|
||||||
-- except that the above code can be written only for a fixed number of
|
-- except that the above code can be written only for a fixed number of
|
||||||
-- elements. By default, `i` is 1 and `j` is the length of the list, as
|
-- elements. By default, `i` is 1 and `j` is the length of the list, as
|
||||||
-- defined by the length operator.
|
-- defined by the length operator.
|
||||||
-- @function [parent=#global] unpack
|
-- @function [parent=#global] unpack
|
||||||
-- @param #table list a table by index
|
-- @param #table list a table by index
|
||||||
-- @param i index of first value.
|
-- @param i index of first value.
|
||||||
-- @param j index of last value.
|
-- @param j index of last value.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- A global variable (not a function) that holds a string containing the
|
-- A global variable (not a function) that holds a string containing the
|
||||||
-- current interpreter version. The current contents of this variable is
|
-- current interpreter version. The current contents of this variable is
|
||||||
-- "`Lua 5.1`".
|
-- "`Lua 5.1`".
|
||||||
-- @field [parent = #global] #string _VERSION
|
-- @field [parent = #global] #string _VERSION
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- This function is similar to `pcall`, except that you can set a new
|
-- This function is similar to `pcall`, except that you can set a new
|
||||||
-- error handler.
|
-- error handler.
|
||||||
--
|
--
|
||||||
-- `xpcall` calls function `f` in protected mode, using `err` as the error
|
-- `xpcall` calls function `f` in protected mode, using `err` as the error
|
||||||
-- handler. Any error inside `f` is not propagated; instead, `xpcall` catches
|
-- handler. Any error inside `f` is not propagated; instead, `xpcall` catches
|
||||||
-- the error, calls the `err` function with the original error object, and
|
-- the error, calls the `err` function with the original error object, and
|
||||||
-- returns a status code. Its first result is the status code (a boolean),
|
-- returns a status code. Its first result is the status code (a boolean),
|
||||||
-- which is true if the call succeeds without errors. In this case, `xpcall`
|
-- which is true if the call succeeds without errors. In this case, `xpcall`
|
||||||
-- also returns all results from the call, after this first result. In case
|
-- also returns all results from the call, after this first result. In case
|
||||||
-- of any error, `xpcall` returns false plus the result from `err`.
|
-- of any error, `xpcall` returns false plus the result from `err`.
|
||||||
-- @function [parent=#global] xpcall
|
-- @function [parent=#global] xpcall
|
||||||
-- @param f function to be call in *protected mode*.
|
-- @param f function to be call in *protected mode*.
|
||||||
-- @param err function used as error handler.
|
-- @param err function used as error handler.
|
||||||
-- @return #boolean true plus the result of `f` function if its call succeeds without errors.
|
-- @return #boolean true plus the result of `f` function if its call succeeds without errors.
|
||||||
-- @return #boolean,#string false plus the result of `err` function.
|
-- @return #boolean,#string false plus the result of `err` function.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Loads the given module.
|
-- Loads the given module.
|
||||||
-- If the requested module is one of the allowed standard libraries
|
-- If the requested module is one of the allowed standard libraries
|
||||||
-- (`coroutine`, `math`, `string`, `table`), then returns the library.
|
-- (`coroutine`, `math`, `string`, `table`), then returns the library.
|
||||||
-- If it is one of the built-in OpenMW API packages, then returns the package.
|
-- If it is one of the built-in OpenMW API packages, then returns the package.
|
||||||
-- Otherwise it searches for a Lua source file with such name in OpenMW data folders.
|
-- Otherwise it searches for a Lua source file with such name in OpenMW data folders.
|
||||||
-- For example `require('my_lua_library.something')` will try to open the file
|
-- For example `require('my_lua_library.something')` will try to open the file
|
||||||
-- `my_lua_library/something.lua`.
|
-- `my_lua_library/something.lua`.
|
||||||
--
|
--
|
||||||
-- Loading DLLs and precompiled Lua files is intentionally prohibited for reasons
|
-- Loading DLLs and precompiled Lua files is intentionally prohibited for reasons
|
||||||
-- of safety and compatibility between different platforms.
|
-- of safety and compatibility between different platforms.
|
||||||
--
|
--
|
||||||
-- If there is any error loading or running the module, or if it cannot find
|
-- If there is any error loading or running the module, or if it cannot find
|
||||||
-- any loader for the module, then `require` signals an error.
|
-- any loader for the module, then `require` signals an error.
|
||||||
-- @function [parent=#global] require
|
-- @function [parent=#global] require
|
||||||
-- @param #string modname name of module to load.
|
-- @param #string modname name of module to load.
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -1,200 +1,200 @@
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Mathematical Functions.
|
-- Mathematical Functions.
|
||||||
-- This library is an interface to the standard C math library.
|
-- This library is an interface to the standard C math library.
|
||||||
-- It provides all its functions inside the table math.
|
-- It provides all its functions inside the table math.
|
||||||
-- @module math
|
-- @module math
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the absolute value of `x`.
|
-- Returns the absolute value of `x`.
|
||||||
-- @function [parent=#math] abs
|
-- @function [parent=#math] abs
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the arc cosine of `x` (in radians).
|
-- Returns the arc cosine of `x` (in radians).
|
||||||
-- @function [parent=#math] acos
|
-- @function [parent=#math] acos
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the arc sine of `x` (in radians).
|
-- Returns the arc sine of `x` (in radians).
|
||||||
-- @function [parent=#math] asin
|
-- @function [parent=#math] asin
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the arc tangent of `x` (in radians).
|
-- Returns the arc tangent of `x` (in radians).
|
||||||
-- @function [parent=#math] atan
|
-- @function [parent=#math] atan
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the arc tangent of `y/x` (in radians), but uses the signs
|
-- Returns the arc tangent of `y/x` (in radians), but uses the signs
|
||||||
-- of both parameters to find the quadrant of the result. (It also handles
|
-- of both parameters to find the quadrant of the result. (It also handles
|
||||||
-- correctly the case of `x` being zero.)
|
-- correctly the case of `x` being zero.)
|
||||||
-- @function [parent=#math] atan2
|
-- @function [parent=#math] atan2
|
||||||
-- @param #number y
|
-- @param #number y
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the smallest integer larger than or equal to `x`.
|
-- Returns the smallest integer larger than or equal to `x`.
|
||||||
-- @function [parent=#math] ceil
|
-- @function [parent=#math] ceil
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the cosine of `x` (assumed to be in radians).
|
-- Returns the cosine of `x` (assumed to be in radians).
|
||||||
-- @function [parent=#math] cos
|
-- @function [parent=#math] cos
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the hyperbolic cosine of `x`.
|
-- Returns the hyperbolic cosine of `x`.
|
||||||
-- @function [parent=#math] cosh
|
-- @function [parent=#math] cosh
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the angle `x` (given in radians) in degrees.
|
-- Returns the angle `x` (given in radians) in degrees.
|
||||||
-- @function [parent=#math] deg
|
-- @function [parent=#math] deg
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the value *e^x*.
|
-- Returns the value *e^x*.
|
||||||
-- @function [parent=#math] exp
|
-- @function [parent=#math] exp
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the largest integer smaller than or equal to `x`.
|
-- Returns the largest integer smaller than or equal to `x`.
|
||||||
-- @function [parent=#math] floor
|
-- @function [parent=#math] floor
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the remainder of the division of `x` by `y` that rounds the
|
-- Returns the remainder of the division of `x` by `y` that rounds the
|
||||||
-- quotient towards zero.
|
-- quotient towards zero.
|
||||||
-- @function [parent=#math] fmod
|
-- @function [parent=#math] fmod
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @param #number y
|
-- @param #number y
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns `m` and `e` such that *x = m2^e*, `e` is an integer and the
|
-- Returns `m` and `e` such that *x = m2^e*, `e` is an integer and the
|
||||||
-- absolute value of `m` is in the range *[0.5, 1)* (or zero when `x` is zero).
|
-- absolute value of `m` is in the range *[0.5, 1)* (or zero when `x` is zero).
|
||||||
-- @function [parent=#math] frexp
|
-- @function [parent=#math] frexp
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- The value `HUGE_VAL`, a value larger than or equal to any other
|
-- The value `HUGE_VAL`, a value larger than or equal to any other
|
||||||
-- numerical value.
|
-- numerical value.
|
||||||
-- @field [parent=#math] #number huge
|
-- @field [parent=#math] #number huge
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns *m2^e* (`e` should be an integer).
|
-- Returns *m2^e* (`e` should be an integer).
|
||||||
-- @function [parent=#math] ldexp
|
-- @function [parent=#math] ldexp
|
||||||
-- @param #number m
|
-- @param #number m
|
||||||
-- @param #number e
|
-- @param #number e
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the natural logarithm of `x`.
|
-- Returns the natural logarithm of `x`.
|
||||||
-- @function [parent=#math] log
|
-- @function [parent=#math] log
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the base-10 logarithm of `x`.
|
-- Returns the base-10 logarithm of `x`.
|
||||||
-- @function [parent=#math] log10
|
-- @function [parent=#math] log10
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the maximum value among its arguments.
|
-- Returns the maximum value among its arguments.
|
||||||
-- @function [parent=#math] max
|
-- @function [parent=#math] max
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the minimum value among its arguments.
|
-- Returns the minimum value among its arguments.
|
||||||
-- @function [parent=#math] min
|
-- @function [parent=#math] min
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns two numbers, the integral part of `x` and the fractional part of
|
-- Returns two numbers, the integral part of `x` and the fractional part of
|
||||||
-- `x`.
|
-- `x`.
|
||||||
-- @function [parent=#math] modf
|
-- @function [parent=#math] modf
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- The value of *pi*.
|
-- The value of *pi*.
|
||||||
-- @field [parent=#math] #number pi
|
-- @field [parent=#math] #number pi
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns *x^y*. (You can also use the expression `x^y` to compute this
|
-- Returns *x^y*. (You can also use the expression `x^y` to compute this
|
||||||
-- value.)
|
-- value.)
|
||||||
-- @function [parent=#math] pow
|
-- @function [parent=#math] pow
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @param #number y
|
-- @param #number y
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the angle `x` (given in degrees) in radians.
|
-- Returns the angle `x` (given in degrees) in radians.
|
||||||
-- @function [parent=#math] rad
|
-- @function [parent=#math] rad
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- This function is an interface to the simple pseudo-random generator
|
-- This function is an interface to the simple pseudo-random generator
|
||||||
-- function `rand` provided by ANSI C. (No guarantees can be given for its
|
-- function `rand` provided by ANSI C. (No guarantees can be given for its
|
||||||
-- statistical properties.)
|
-- statistical properties.)
|
||||||
--
|
--
|
||||||
-- When called without arguments, returns a uniform pseudo-random real
|
-- When called without arguments, returns a uniform pseudo-random real
|
||||||
-- number in the range *[0,1)*. When called with an integer number `m`,
|
-- number in the range *[0,1)*. When called with an integer number `m`,
|
||||||
-- `math.random` returns a uniform pseudo-random integer in the range *[1,
|
-- `math.random` returns a uniform pseudo-random integer in the range *[1,
|
||||||
-- m]*. When called with two integer numbers `m` and `n`, `math.random`
|
-- m]*. When called with two integer numbers `m` and `n`, `math.random`
|
||||||
-- returns a uniform pseudo-random integer in the range *[m, n]*.
|
-- returns a uniform pseudo-random integer in the range *[m, n]*.
|
||||||
-- @function [parent=#math] random
|
-- @function [parent=#math] random
|
||||||
-- @param #number m
|
-- @param #number m
|
||||||
-- @param #number n
|
-- @param #number n
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the sine of `x` (assumed to be in radians).
|
-- Returns the sine of `x` (assumed to be in radians).
|
||||||
-- @function [parent=#math] sin
|
-- @function [parent=#math] sin
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the hyperbolic sine of `x`.
|
-- Returns the hyperbolic sine of `x`.
|
||||||
-- @function [parent=#math] sinh
|
-- @function [parent=#math] sinh
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the square root of `x`. (You can also use the expression `x^0.5`
|
-- Returns the square root of `x`. (You can also use the expression `x^0.5`
|
||||||
-- to compute this value.)
|
-- to compute this value.)
|
||||||
-- @function [parent=#math] sqrt
|
-- @function [parent=#math] sqrt
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the tangent of `x` (assumed to be in radians).
|
-- Returns the tangent of `x` (assumed to be in radians).
|
||||||
-- @function [parent=#math] tan
|
-- @function [parent=#math] tan
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the hyperbolic tangent of `x`.
|
-- Returns the hyperbolic tangent of `x`.
|
||||||
-- @function [parent=#math] tanh
|
-- @function [parent=#math] tanh
|
||||||
-- @param #number x
|
-- @param #number x
|
||||||
-- @return #number
|
-- @return #number
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -1,231 +1,231 @@
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- String Manipulation.
|
-- String Manipulation.
|
||||||
-- This library provides generic functions for string manipulation,
|
-- This library provides generic functions for string manipulation,
|
||||||
-- such as finding and extracting substrings, and pattern matching.
|
-- such as finding and extracting substrings, and pattern matching.
|
||||||
-- When indexing a string in Lua, the first character is at position 1 (not at 0, as in C).
|
-- When indexing a string in Lua, the first character is at position 1 (not at 0, as in C).
|
||||||
-- Indices are allowed to be negative and are interpreted as indexing backwards, from the end of the string.
|
-- Indices are allowed to be negative and are interpreted as indexing backwards, from the end of the string.
|
||||||
-- Thus, the last character is at position -1, and so on.
|
-- Thus, the last character is at position -1, and so on.
|
||||||
--
|
--
|
||||||
-- The string library provides all its functions inside the table string. It also sets a metatable for strings where the __index field points to the string table. Therefore, you can use the string functions in object-oriented style.
|
-- The string library provides all its functions inside the table string. It also sets a metatable for strings where the __index field points to the string table. Therefore, you can use the string functions in object-oriented style.
|
||||||
-- For instance, string.byte(s, i) can be written as s:byte(i).
|
-- For instance, string.byte(s, i) can be written as s:byte(i).
|
||||||
--
|
--
|
||||||
-- The string library assumes one-byte character encodings.
|
-- The string library assumes one-byte character encodings.
|
||||||
-- @module string
|
-- @module string
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the internal numerical codes of the characters `s[i]`, `s[i+1]`,
|
-- Returns the internal numerical codes of the characters `s[i]`, `s[i+1]`,
|
||||||
-- ..., `s[j]`. The default value for `i` is 1; the default value for `j`
|
-- ..., `s[j]`. The default value for `i` is 1; the default value for `j`
|
||||||
-- is `i`.
|
-- is `i`.
|
||||||
-- Note that numerical codes are not necessarily portable across platforms.
|
-- Note that numerical codes are not necessarily portable across platforms.
|
||||||
-- @function [parent=#string] byte
|
-- @function [parent=#string] byte
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @param #number i start index, default value is 1.
|
-- @param #number i start index, default value is 1.
|
||||||
-- @param #number j end index, default value is `i`.
|
-- @param #number j end index, default value is `i`.
|
||||||
-- @return the internal numerical codes of the characters `s[i]`, `s[i+1]`,..., `s[j]`
|
-- @return the internal numerical codes of the characters `s[i]`, `s[i+1]`,..., `s[j]`
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Receives zero or more integers. Returns a string with length equal to
|
-- Receives zero or more integers. Returns a string with length equal to
|
||||||
-- the number of arguments, in which each character has the internal numerical
|
-- the number of arguments, in which each character has the internal numerical
|
||||||
-- code equal to its corresponding argument.
|
-- code equal to its corresponding argument.
|
||||||
--
|
--
|
||||||
-- Note that numerical codes are not necessarily portable across platforms.
|
-- Note that numerical codes are not necessarily portable across platforms.
|
||||||
-- @function [parent=#string] char
|
-- @function [parent=#string] char
|
||||||
-- @param ... zero or more integers.
|
-- @param ... zero or more integers.
|
||||||
-- @return #string a string with length equal to
|
-- @return #string a string with length equal to
|
||||||
-- the number of arguments, in which each character has the internal numerical
|
-- the number of arguments, in which each character has the internal numerical
|
||||||
-- code equal to its corresponding argument.
|
-- code equal to its corresponding argument.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns a string containing a binary representation of the given
|
-- Returns a string containing a binary representation of the given
|
||||||
-- function, so that a later `loadstring` on this string returns a copy of
|
-- function, so that a later `loadstring` on this string returns a copy of
|
||||||
-- the function. `function` must be a Lua function without upvalues.
|
-- the function. `function` must be a Lua function without upvalues.
|
||||||
-- @function [parent=#string] dump
|
-- @function [parent=#string] dump
|
||||||
-- @param f the function to dump.
|
-- @param f the function to dump.
|
||||||
-- @return #string a string representation of the given function.
|
-- @return #string a string representation of the given function.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Looks for the first match of `pattern` in the string `s`. If it finds a
|
-- Looks for the first match of `pattern` in the string `s`. If it finds a
|
||||||
-- match, then `find` returns the indices of `s` where this occurrence starts
|
-- match, then `find` returns the indices of `s` where this occurrence starts
|
||||||
-- and ends; otherwise, it returns nil.A third, optional numerical argument
|
-- and ends; otherwise, it returns nil.A third, optional numerical argument
|
||||||
-- `init` specifies where to start the search; its default value is 1 and
|
-- `init` specifies where to start the search; its default value is 1 and
|
||||||
-- can be negative. A value of true as a fourth, optional argument `plain`
|
-- can be negative. A value of true as a fourth, optional argument `plain`
|
||||||
-- turns off the pattern matching facilities, so the function does a plain
|
-- turns off the pattern matching facilities, so the function does a plain
|
||||||
-- "find substring" operation, with no characters in `pattern` being considered
|
-- "find substring" operation, with no characters in `pattern` being considered
|
||||||
-- "magic".
|
-- "magic".
|
||||||
--
|
--
|
||||||
-- Note that if `plain` is given, then `init` must be given as well.
|
-- Note that if `plain` is given, then `init` must be given as well.
|
||||||
-- If the pattern has captures, then in a successful match the captured values
|
-- If the pattern has captures, then in a successful match the captured values
|
||||||
-- are also returned, after the two indices.
|
-- are also returned, after the two indices.
|
||||||
-- @function [parent=#string] find
|
-- @function [parent=#string] find
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @param #string pattern pattern to search.
|
-- @param #string pattern pattern to search.
|
||||||
-- @param #number init index where to start the search. (default value is 1)
|
-- @param #number init index where to start the search. (default value is 1)
|
||||||
-- @param #boolean plain set to true to search without pattern matching. (default value is false)
|
-- @param #boolean plain set to true to search without pattern matching. (default value is false)
|
||||||
-- @return #number, #number start and end indices of first occurence.
|
-- @return #number, #number start and end indices of first occurence.
|
||||||
-- @return #nil if pattern not found.
|
-- @return #nil if pattern not found.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns a formatted version of its variable number of arguments following
|
-- Returns a formatted version of its variable number of arguments following
|
||||||
-- the description given in its first argument (which must be a string). The
|
-- the description given in its first argument (which must be a string). The
|
||||||
-- format string follows the same rules as the `printf` family of standard C
|
-- format string follows the same rules as the `printf` family of standard C
|
||||||
-- functions. The only differences are that the options/modifiers `*`, `l`,
|
-- functions. The only differences are that the options/modifiers `*`, `l`,
|
||||||
-- `L`, `n`, `p`, and `h` are not supported and that there is an extra option,
|
-- `L`, `n`, `p`, and `h` are not supported and that there is an extra option,
|
||||||
-- `q`. The `q` option formats a string in a form suitable to be safely read
|
-- `q`. The `q` option formats a string in a form suitable to be safely read
|
||||||
-- back by the Lua interpreter: the string is written between double quotes,
|
-- back by the Lua interpreter: the string is written between double quotes,
|
||||||
-- and all double quotes, newlines, embedded zeros, and backslashes in the
|
-- and all double quotes, newlines, embedded zeros, and backslashes in the
|
||||||
-- string are correctly escaped when written. For instance, the call
|
-- string are correctly escaped when written. For instance, the call
|
||||||
--
|
--
|
||||||
-- string.format('%q', 'a string with "quotes" and \n new line')
|
-- string.format('%q', 'a string with "quotes" and \n new line')
|
||||||
--
|
--
|
||||||
-- will produce the string:
|
-- will produce the string:
|
||||||
--
|
--
|
||||||
-- "a string with \"quotes\" and \
|
-- "a string with \"quotes\" and \
|
||||||
-- new line"
|
-- new line"
|
||||||
--
|
--
|
||||||
-- The options `c`, `d`, `E`, `e`, `f`, `g`, `G`, `i`, `o`, `u`, `X`, and
|
-- The options `c`, `d`, `E`, `e`, `f`, `g`, `G`, `i`, `o`, `u`, `X`, and
|
||||||
-- `x` all expect a number as argument, whereas `q` and `s` expect a string.
|
-- `x` all expect a number as argument, whereas `q` and `s` expect a string.
|
||||||
-- This function does not accept string values containing embedded zeros,
|
-- This function does not accept string values containing embedded zeros,
|
||||||
-- except as arguments to the `q` option.
|
-- except as arguments to the `q` option.
|
||||||
-- @function [parent=#string] format
|
-- @function [parent=#string] format
|
||||||
-- @param #string formatstring the string template.
|
-- @param #string formatstring the string template.
|
||||||
-- @param ... arguments could be strings or numbers.
|
-- @param ... arguments could be strings or numbers.
|
||||||
-- @return #string the formatted string.
|
-- @return #string the formatted string.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns an iterator function that, each time it is called, returns the
|
-- Returns an iterator function that, each time it is called, returns the
|
||||||
-- next captures from `pattern` over string `s`. If `pattern` specifies no
|
-- next captures from `pattern` over string `s`. If `pattern` specifies no
|
||||||
-- captures, then the whole match is produced in each call.
|
-- captures, then the whole match is produced in each call.
|
||||||
-- As an example, the following loop
|
-- As an example, the following loop
|
||||||
--
|
--
|
||||||
-- s = "hello world from Lua"
|
-- s = "hello world from Lua"
|
||||||
-- for w in string.gmatch(s, "%a+") do
|
-- for w in string.gmatch(s, "%a+") do
|
||||||
-- print(w)
|
-- print(w)
|
||||||
-- end
|
-- end
|
||||||
--
|
--
|
||||||
-- will iterate over all the words from string `s`, printing one per line. The
|
-- will iterate over all the words from string `s`, printing one per line. The
|
||||||
-- next example collects all pairs `key=value` from the given string into
|
-- next example collects all pairs `key=value` from the given string into
|
||||||
-- a table:
|
-- a table:
|
||||||
--
|
--
|
||||||
-- t = {}
|
-- t = {}
|
||||||
-- s = "from=world, to=Lua"
|
-- s = "from=world, to=Lua"
|
||||||
-- for k, v in string.gmatch(s, "(%w+)=(%w+)") do
|
-- for k, v in string.gmatch(s, "(%w+)=(%w+)") do
|
||||||
-- t[k] = v
|
-- t[k] = v
|
||||||
-- end
|
-- end
|
||||||
--
|
--
|
||||||
-- For this function, a '`^`' at the start of a pattern does not work as an
|
-- For this function, a '`^`' at the start of a pattern does not work as an
|
||||||
-- anchor, as this would prevent the iteration.
|
-- anchor, as this would prevent the iteration.
|
||||||
-- @function [parent=#string] gmatch
|
-- @function [parent=#string] gmatch
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @param #string pattern pattern to search.
|
-- @param #string pattern pattern to search.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns a copy of `s` in which all (or the first `n`, if given)
|
-- Returns a copy of `s` in which all (or the first `n`, if given)
|
||||||
-- occurrences of the `pattern` have been replaced by a replacement string
|
-- occurrences of the `pattern` have been replaced by a replacement string
|
||||||
-- specified by `repl`, which can be a string, a table, or a function. `gsub`
|
-- specified by `repl`, which can be a string, a table, or a function. `gsub`
|
||||||
-- also returns, as its second value, the total number of matches that occurred.
|
-- also returns, as its second value, the total number of matches that occurred.
|
||||||
--
|
--
|
||||||
-- If `repl` is a string, then its value is used for replacement. The character
|
-- If `repl` is a string, then its value is used for replacement. The character
|
||||||
-- `%` works as an escape character: any sequence in `repl` of the form `%n`,
|
-- `%` works as an escape character: any sequence in `repl` of the form `%n`,
|
||||||
-- with *n* between 1 and 9, stands for the value of the *n*-th captured
|
-- with *n* between 1 and 9, stands for the value of the *n*-th captured
|
||||||
-- substring (see below). The sequence `%0` stands for the whole match. The
|
-- substring (see below). The sequence `%0` stands for the whole match. The
|
||||||
-- sequence `%%` stands for a single `%`.
|
-- sequence `%%` stands for a single `%`.
|
||||||
--
|
--
|
||||||
-- If `repl` is a table, then the table is queried for every match, using
|
-- If `repl` is a table, then the table is queried for every match, using
|
||||||
-- the first capture as the key; if the pattern specifies no captures, then
|
-- the first capture as the key; if the pattern specifies no captures, then
|
||||||
-- the whole match is used as the key.
|
-- the whole match is used as the key.
|
||||||
--
|
--
|
||||||
-- If `repl` is a function, then this function is called every time a match
|
-- If `repl` is a function, then this function is called every time a match
|
||||||
-- occurs, with all captured substrings passed as arguments, in order; if
|
-- occurs, with all captured substrings passed as arguments, in order; if
|
||||||
-- the pattern specifies no captures, then the whole match is passed as a
|
-- the pattern specifies no captures, then the whole match is passed as a
|
||||||
-- sole argument.
|
-- sole argument.
|
||||||
--
|
--
|
||||||
-- If the value returned by the table query or by the function call is a
|
-- If the value returned by the table query or by the function call is a
|
||||||
-- string or a number, then it is used as the replacement string; otherwise,
|
-- string or a number, then it is used as the replacement string; otherwise,
|
||||||
-- if it is false or nil, then there is no replacement (that is, the original
|
-- if it is false or nil, then there is no replacement (that is, the original
|
||||||
-- match is kept in the string).
|
-- match is kept in the string).
|
||||||
--
|
--
|
||||||
-- Here are some examples:
|
-- Here are some examples:
|
||||||
--
|
--
|
||||||
-- x = string.gsub("hello world", "(%w+)", "%1 %1")
|
-- x = string.gsub("hello world", "(%w+)", "%1 %1")
|
||||||
-- --> x="hello hello world world"
|
-- --> x="hello hello world world"
|
||||||
-- x = string.gsub("hello world", "%w+", "%0 %0", 1)
|
-- x = string.gsub("hello world", "%w+", "%0 %0", 1)
|
||||||
-- --> x="hello hello world"
|
-- --> x="hello hello world"
|
||||||
-- x = string.gsub("hello world from Lua", "(%w+)%s*(%w+)", "%2 %1")
|
-- x = string.gsub("hello world from Lua", "(%w+)%s*(%w+)", "%2 %1")
|
||||||
-- --> x="world hello Lua from"
|
-- --> x="world hello Lua from"
|
||||||
-- x = string.gsub("home = $HOME, user = $USER", "%$(%w+)", os.getenv)
|
-- x = string.gsub("home = $HOME, user = $USER", "%$(%w+)", os.getenv)
|
||||||
-- --> x="home = /home/roberto, user = roberto"
|
-- --> x="home = /home/roberto, user = roberto"
|
||||||
-- x = string.gsub("4+5 = $return 4+5$", "%$(.-)%$", function (s)
|
-- x = string.gsub("4+5 = $return 4+5$", "%$(.-)%$", function (s)
|
||||||
-- return loadstring(s)()
|
-- return loadstring(s)()
|
||||||
-- end)
|
-- end)
|
||||||
-- --> x="4+5 = 9"
|
-- --> x="4+5 = 9"
|
||||||
-- local t = {name="lua", version="5.1"}
|
-- local t = {name="lua", version="5.1"}
|
||||||
-- x = string.gsub("$name-$version.tar.gz", "%$(%w+)", t)
|
-- x = string.gsub("$name-$version.tar.gz", "%$(%w+)", t)
|
||||||
-- --> x="lua-5.1.tar.gz"
|
-- --> x="lua-5.1.tar.gz"
|
||||||
-- @function [parent=#string] gsub
|
-- @function [parent=#string] gsub
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @param #string pattern pattern to search.
|
-- @param #string pattern pattern to search.
|
||||||
-- @param repl replacement could be a string, a table or a function.
|
-- @param repl replacement could be a string, a table or a function.
|
||||||
-- @param #number n number of occurences to replace, default is nil which means all occurences.
|
-- @param #number n number of occurences to replace, default is nil which means all occurences.
|
||||||
-- @return #string a modified copy of `s`.
|
-- @return #string a modified copy of `s`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Receives a string and returns its length. The empty string `""` has
|
-- Receives a string and returns its length. The empty string `""` has
|
||||||
-- length 0. Embedded zeros are counted, so `"a\000bc\000"` has length 5.
|
-- length 0. Embedded zeros are counted, so `"a\000bc\000"` has length 5.
|
||||||
-- @function [parent=#string] len
|
-- @function [parent=#string] len
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @return #number the lenght of `s`.
|
-- @return #number the lenght of `s`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Receives a string and returns a copy of this string with all uppercase
|
-- Receives a string and returns a copy of this string with all uppercase
|
||||||
-- letters changed to lowercase. All other characters are left unchanged. The
|
-- letters changed to lowercase. All other characters are left unchanged. The
|
||||||
-- definition of what an uppercase letter is depends on the current locale.
|
-- definition of what an uppercase letter is depends on the current locale.
|
||||||
-- @function [parent=#string] lower
|
-- @function [parent=#string] lower
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @return #string a lower case version of `s`.
|
-- @return #string a lower case version of `s`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Looks for the first *match* of `pattern` in the string `s`. If it
|
-- Looks for the first *match* of `pattern` in the string `s`. If it
|
||||||
-- finds one, then `match` returns the captures from the pattern; otherwise
|
-- finds one, then `match` returns the captures from the pattern; otherwise
|
||||||
-- it returns nil. If `pattern` specifies no captures, then the whole match
|
-- it returns nil. If `pattern` specifies no captures, then the whole match
|
||||||
-- is returned. A third, optional numerical argument `init` specifies where
|
-- is returned. A third, optional numerical argument `init` specifies where
|
||||||
-- to start the search; its default value is 1 and can be negative.
|
-- to start the search; its default value is 1 and can be negative.
|
||||||
-- @function [parent=#string] match
|
-- @function [parent=#string] match
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @param #string pattern pattern to search.
|
-- @param #string pattern pattern to search.
|
||||||
-- @param #number init index where to start the search. (default value is 1)
|
-- @param #number init index where to start the search. (default value is 1)
|
||||||
-- @return #string the captures from the pattern; otherwise it returns nil. If pattern specifies no captures, then the whole match is returned.
|
-- @return #string the captures from the pattern; otherwise it returns nil. If pattern specifies no captures, then the whole match is returned.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns a string that is the concatenation of `n` copies of the string `s`.
|
-- Returns a string that is the concatenation of `n` copies of the string `s`.
|
||||||
-- @function [parent=#string] rep
|
-- @function [parent=#string] rep
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @param #number n number of repetition.
|
-- @param #number n number of repetition.
|
||||||
-- @return #string the concatenation of `n` copies of the string `s`.
|
-- @return #string the concatenation of `n` copies of the string `s`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns a string that is the string `s` reversed.
|
-- Returns a string that is the string `s` reversed.
|
||||||
-- @function [parent=#string] reverse
|
-- @function [parent=#string] reverse
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @return #string the string `s` reversed.
|
-- @return #string the string `s` reversed.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the substring of `s` that starts at `i` and continues until
|
-- Returns the substring of `s` that starts at `i` and continues until
|
||||||
-- `j`; `i` and `j` can be negative. If `j` is absent, then it is assumed to
|
-- `j`; `i` and `j` can be negative. If `j` is absent, then it is assumed to
|
||||||
-- be equal to -1 (which is the same as the string length). In particular,
|
-- be equal to -1 (which is the same as the string length). In particular,
|
||||||
-- the call `string.sub(s,1,j)` returns a prefix of `s` with length `j`, and
|
-- the call `string.sub(s,1,j)` returns a prefix of `s` with length `j`, and
|
||||||
-- `string.sub(s, -i)` returns a suffix of `s` with length `i`.
|
-- `string.sub(s, -i)` returns a suffix of `s` with length `i`.
|
||||||
-- @function [parent=#string] sub
|
-- @function [parent=#string] sub
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @param #number i start index.
|
-- @param #number i start index.
|
||||||
-- @param #number j end index. (default value is -1, which is the same as the string lenght)
|
-- @param #number j end index. (default value is -1, which is the same as the string lenght)
|
||||||
-- @return #string the substring of `s` that starts at `i` and continues until `j`.
|
-- @return #string the substring of `s` that starts at `i` and continues until `j`.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Receives a string and returns a copy of this string with all lowercase
|
-- Receives a string and returns a copy of this string with all lowercase
|
||||||
-- letters changed to uppercase. All other characters are left unchanged. The
|
-- letters changed to uppercase. All other characters are left unchanged. The
|
||||||
-- definition of what a lowercase letter is depends on the current locale.
|
-- definition of what a lowercase letter is depends on the current locale.
|
||||||
-- @function [parent=#string] upper
|
-- @function [parent=#string] upper
|
||||||
-- @param #string s string to handle.
|
-- @param #string s string to handle.
|
||||||
-- @return #string a upper case version of `s`.
|
-- @return #string a upper case version of `s`.
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -1,66 +1,66 @@
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Table Manipulation
|
-- Table Manipulation
|
||||||
-- This library provides generic functions for table manipulation.
|
-- This library provides generic functions for table manipulation.
|
||||||
-- It provides all its functions inside the table table.
|
-- It provides all its functions inside the table table.
|
||||||
--
|
--
|
||||||
-- Most functions in the table library assume that the table represents an array or a list.
|
-- Most functions in the table library assume that the table represents an array or a list.
|
||||||
-- For these functions, when we talk about the "length" of a table we mean the result of the length operator.
|
-- For these functions, when we talk about the "length" of a table we mean the result of the length operator.
|
||||||
-- @module table
|
-- @module table
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Given an array where all elements are strings or numbers, returns
|
-- Given an array where all elements are strings or numbers, returns
|
||||||
-- `table[i]..sep..table[i+1]...sep..table[j]`. The default value for
|
-- `table[i]..sep..table[i+1]...sep..table[j]`. The default value for
|
||||||
-- `sep` is the empty string, the default for `i` is 1, and the default for
|
-- `sep` is the empty string, the default for `i` is 1, and the default for
|
||||||
-- `j` is the length of the table. If `i` is greater than `j`, returns the
|
-- `j` is the length of the table. If `i` is greater than `j`, returns the
|
||||||
-- empty string.
|
-- empty string.
|
||||||
-- @function [parent=#table] concat
|
-- @function [parent=#table] concat
|
||||||
-- @param #table table table to handle.
|
-- @param #table table table to handle.
|
||||||
-- @param #string sep the separator, default value is an empty string.
|
-- @param #string sep the separator, default value is an empty string.
|
||||||
-- @param #number i start index, default value is 1.
|
-- @param #number i start index, default value is 1.
|
||||||
-- @param #number j end index, default value is lenght of the table.
|
-- @param #number j end index, default value is lenght of the table.
|
||||||
-- @return #string the concatenated table.
|
-- @return #string the concatenated table.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Inserts element `value` at position `pos` in `table`, shifting up
|
-- Inserts element `value` at position `pos` in `table`, shifting up
|
||||||
-- other elements to open space, if necessary. The default value for `pos` is
|
-- other elements to open space, if necessary. The default value for `pos` is
|
||||||
-- `n+1`, where `n` is the length of the table, so that a call
|
-- `n+1`, where `n` is the length of the table, so that a call
|
||||||
-- `table.insert(t,x)` inserts `x` at the end of table `t`.
|
-- `table.insert(t,x)` inserts `x` at the end of table `t`.
|
||||||
-- @function [parent=#table] insert
|
-- @function [parent=#table] insert
|
||||||
-- @param #table table table to modify.
|
-- @param #table table table to modify.
|
||||||
-- @param #number pos index of insertion.
|
-- @param #number pos index of insertion.
|
||||||
-- @param value value to insert.
|
-- @param value value to insert.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Returns the largest positive numerical index of the given table, or
|
-- Returns the largest positive numerical index of the given table, or
|
||||||
-- zero if the table has no positive numerical indices. (To do its job this
|
-- zero if the table has no positive numerical indices. (To do its job this
|
||||||
-- function does a linear traversal of the whole table.)
|
-- function does a linear traversal of the whole table.)
|
||||||
-- @function [parent=#table] maxn
|
-- @function [parent=#table] maxn
|
||||||
-- @param #table table table to traverse.
|
-- @param #table table table to traverse.
|
||||||
-- @return #number the largest positive numerical index of the given table, or
|
-- @return #number the largest positive numerical index of the given table, or
|
||||||
-- zero if the table has no positive numerical indices.
|
-- zero if the table has no positive numerical indices.
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Removes from `table` the element at position `pos`, shifting down other
|
-- Removes from `table` the element at position `pos`, shifting down other
|
||||||
-- elements to close the space, if necessary. Returns the value of the removed
|
-- elements to close the space, if necessary. Returns the value of the removed
|
||||||
-- element. The default value for `pos` is `n`, where `n` is the length of the
|
-- element. The default value for `pos` is `n`, where `n` is the length of the
|
||||||
-- table, so that a call `table.remove(t)` removes the last element of table
|
-- table, so that a call `table.remove(t)` removes the last element of table
|
||||||
-- `t`.
|
-- `t`.
|
||||||
-- @function [parent=#table] remove
|
-- @function [parent=#table] remove
|
||||||
-- @param #table table table to modify.
|
-- @param #table table table to modify.
|
||||||
-- @param #number pos index of deletion. (default value is the lenght of the table)
|
-- @param #number pos index of deletion. (default value is the lenght of the table)
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------
|
||||||
-- Sorts table elements in a given order,
|
-- Sorts table elements in a given order,
|
||||||
-- *in-place*, from `table[1]` to `table[n]`, where `n` is the length of the
|
-- *in-place*, from `table[1]` to `table[n]`, where `n` is the length of the
|
||||||
-- table. If `comp` is given, then it must be a function that receives two
|
-- table. If `comp` is given, then it must be a function that receives two
|
||||||
-- table elements, and returns true when the first is less than the second
|
-- table elements, and returns true when the first is less than the second
|
||||||
-- (so that `not comp(a[i+1],a[i])` will be true after the sort). Lua operator < is used instead.
|
-- (so that `not comp(a[i+1],a[i])` will be true after the sort). Lua operator < is used instead.
|
||||||
--
|
--
|
||||||
-- The sort algorithm is not stable; that is, elements considered equal by the given order may have their relative positions changed by the sort.
|
-- The sort algorithm is not stable; that is, elements considered equal by the given order may have their relative positions changed by the sort.
|
||||||
-- @function [parent=#table] sort
|
-- @function [parent=#table] sort
|
||||||
-- @param #table table table to sort.
|
-- @param #table table table to sort.
|
||||||
-- @param comp a function which take to table and returns true when the first is less than the second.
|
-- @param comp a function which take to table and returns true when the first is less than the second.
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -1,25 +1,25 @@
|
||||||
\section{OpenCS starting dialog}
|
\section{OpenCS starting dialog}
|
||||||
\subsection{Introduction}
|
\subsection{Introduction}
|
||||||
The great day has come. Today, you shall open \OCS{} application. And when you do this, you shall see our starting dialog window that holds three buttons
|
The great day has come. Today, you shall open \OCS{} application. And when you do this, you shall see our starting dialog window that holds three buttons
|
||||||
that can bring both pain and happiness. So just do this, please.
|
that can bring both pain and happiness. So just do this, please.
|
||||||
|
|
||||||
\subsection{Basics}
|
\subsection{Basics}
|
||||||
Back to the manual? Great! As you can see, the starting window holds just three buttons. Since you are already familiar with our files system, they come
|
Back to the manual? Great! As you can see, the starting window holds just three buttons. Since you are already familiar with our files system, they come
|
||||||
to you with no surprise.\\
|
to you with no surprise.\\
|
||||||
|
|
||||||
First, there is a \textbf{Create A New Game} button. Clearly, you should press it when you want to create a game file. Than, what \textbf{Create A New Addon} button do?
|
First, there is a \textbf{Create A New Game} button. Clearly, you should press it when you want to create a game file. Than, what \textbf{Create A New Addon} button do?
|
||||||
Yes! You are right! This button will create any addon content file (and new project file associated with it)! Wonderful! And what the last remaining button do? \textbf{Edit A Content File}? Well, it comes with no surprise that this should be used when you need to alter existing content file, either a game or addon.\\
|
Yes! You are right! This button will create any addon content file (and new project file associated with it)! Wonderful! And what the last remaining button do? \textbf{Edit A Content File}? Well, it comes with no surprise that this should be used when you need to alter existing content file, either a game or addon.\\
|
||||||
|
|
||||||
\paragraph{Selecting Files For New Addon}
|
\paragraph{Selecting Files For New Addon}
|
||||||
As We wrote earlier, both \OMW{} and \OCS{} are operating with dependency idea in mind. As You remember you should only depend on files you are actually using. But how?\\
|
As We wrote earlier, both \OMW{} and \OCS{} are operating with dependency idea in mind. As You remember you should only depend on files you are actually using. But how?\\
|
||||||
It is simple. When you click either \textbf{Create new Addon} you will be asked to choose those with a new dialog window. The window is using vertical layout, first you should consider the the top element, the one that allows you to select a game file with drop down menu. Since we are operating on the assumption that there is only one game file loaded at the time, you can depend only on one game file. Next, choose addons that you want to use in your addon with checkboxes.\\
|
It is simple. When you click either \textbf{Create new Addon} you will be asked to choose those with a new dialog window. The window is using vertical layout, first you should consider the the top element, the one that allows you to select a game file with drop down menu. Since we are operating on the assumption that there is only one game file loaded at the time, you can depend only on one game file. Next, choose addons that you want to use in your addon with checkboxes.\\
|
||||||
|
|
||||||
The last thing to do is to name your your addon and click create.
|
The last thing to do is to name your your addon and click create.
|
||||||
|
|
||||||
\paragraph{Selecting File for Editing}
|
\paragraph{Selecting File for Editing}
|
||||||
Clicking \textbf{Edit A Content File} will show somewhat similar window. Here you should select your Game file with drop down menu. If you want to edit this game file, simply click \textbf{OK} button. If you want to alter addon depending on that file, mark it with check-box and than click \textbf{Ok} button.
|
Clicking \textbf{Edit A Content File} will show somewhat similar window. Here you should select your Game file with drop down menu. If you want to edit this game file, simply click \textbf{OK} button. If you want to alter addon depending on that file, mark it with check-box and than click \textbf{Ok} button.
|
||||||
|
|
||||||
\subsection{Advanced}
|
\subsection{Advanced}
|
||||||
If you are paying attention, you noticed any extra icon with wrench. This one will open small settings window. Those are general OpenCS settings. We will cover this is separate section.\\
|
If you are paying attention, you noticed any extra icon with wrench. This one will open small settings window. Those are general OpenCS settings. We will cover this is separate section.\\
|
||||||
|
|
||||||
And that would be it. There is no point spending more time here. We should go forward now.
|
And that would be it. There is no point spending more time here. We should go forward now.
|
|
@ -1,118 +1,118 @@
|
||||||
\section{Files and Directories}
|
\section{Files and Directories}
|
||||||
\subsection{Introduction}
|
\subsection{Introduction}
|
||||||
This section of the manual describes the directories and file types used by OpenCS. A file is a resource for storing data (e.g. .exe, .jpg, .txt),
|
This section of the manual describes the directories and file types used by OpenCS. A file is a resource for storing data (e.g. .exe, .jpg, .txt),
|
||||||
whereas a directory is a folder or file system structure which points to these files (or other directories). You are most likely already familiar
|
whereas a directory is a folder or file system structure which points to these files (or other directories). You are most likely already familiar
|
||||||
with these concepts.
|
with these concepts.
|
||||||
|
|
||||||
\subsection{Used terms} %TODO
|
\subsection{Used terms} %TODO
|
||||||
|
|
||||||
\subsection{Basics}
|
\subsection{Basics}
|
||||||
|
|
||||||
\paragraph{Directories}
|
\paragraph{Directories}
|
||||||
OpenMW and \OCS{} store their files in multiple directories. Firstly, there is the \textbf{user directory} that holds configuration
|
OpenMW and \OCS{} store their files in multiple directories. Firstly, there is the \textbf{user directory} that holds configuration
|
||||||
files and several other folders. The location of the user directory is hard coded for each supported operating system.
|
files and several other folders. The location of the user directory is hard coded for each supported operating system.
|
||||||
|
|
||||||
%TODO list paths.
|
%TODO list paths.
|
||||||
In addition to the user directory, both \OMW{} and \OCS{} need a place to store the game’s actual data files: for example, the
|
In addition to the user directory, both \OMW{} and \OCS{} need a place to store the game’s actual data files: for example, the
|
||||||
textures, models, sounds and records of in-game objects. We support multiple paths to these files (termed \textbf{data paths}),
|
textures, models, sounds and records of in-game objects. We support multiple paths to these files (termed \textbf{data paths}),
|
||||||
as specified in the configuration. Usually, one data path points to the directory where \MW{} is installed; however, you are
|
as specified in the configuration. Usually, one data path points to the directory where \MW{} is installed; however, you are
|
||||||
free to specify as many data paths as you would like. In addition, one particular data path, as described below, is used to store
|
free to specify as many data paths as you would like. In addition, one particular data path, as described below, is used to store
|
||||||
newly created content files.
|
newly created content files.
|
||||||
|
|
||||||
\paragraph{Content files}
|
\paragraph{Content files}
|
||||||
\BS{} \MW{} engine uses two file types: ESM (master) and ESP (plugin). The distinction between the two is often confusing.
|
\BS{} \MW{} engine uses two file types: ESM (master) and ESP (plugin). The distinction between the two is often confusing.
|
||||||
You would expect that the ESM (master) file is used to specify a single master which is modified by the ESP files (plugins), and indeed:
|
You would expect that the ESM (master) file is used to specify a single master which is modified by the ESP files (plugins), and indeed:
|
||||||
this is the basic idea. However, the original expansions are also ESM files, even though they can be described as very large plugins.
|
this is the basic idea. However, the original expansions are also ESM files, even though they can be described as very large plugins.
|
||||||
There were technical reasons behind this decision -- somewhat valid in the case of the original engine -- but a more logical file system is
|
There were technical reasons behind this decision -- somewhat valid in the case of the original engine -- but a more logical file system is
|
||||||
much preferable. \OMW{} achieves this through the creation of our own types of content file.
|
much preferable. \OMW{} achieves this through the creation of our own types of content file.
|
||||||
|
|
||||||
We support both ESM and ESP files, but, in order to make use of \OMW{}'s new features, one should consider using new file types designed
|
We support both ESM and ESP files, but, in order to make use of \OMW{}'s new features, one should consider using new file types designed
|
||||||
with our engine in mind: game files and addon files, collectively termed \textbf{content files}.
|
with our engine in mind: game files and addon files, collectively termed \textbf{content files}.
|
||||||
|
|
||||||
\subparagraph{OpenMW content files}
|
\subparagraph{OpenMW content files}
|
||||||
The distinction between game and addon files is similar to that between ESM and ESP, however their relationship to each other is
|
The distinction between game and addon files is similar to that between ESM and ESP, however their relationship to each other is
|
||||||
strictly defined -– the former are always master files, and the latter are always plugins. If you want to make a new game using the \OMW{}
|
strictly defined -– the former are always master files, and the latter are always plugins. If you want to make a new game using the \OMW{}
|
||||||
engine (i.e. a ``total conversion''), you should create a game file. If you want to create an addon for an existing game file, simply
|
engine (i.e. a ``total conversion''), you should create a game file. If you want to create an addon for an existing game file, simply
|
||||||
create an addon file. Nothing else matters: the only distinction you should consider is whether your project involves changing another game,
|
create an addon file. Nothing else matters: the only distinction you should consider is whether your project involves changing another game,
|
||||||
or creating a new one. Simple as that.
|
or creating a new one. Simple as that.
|
||||||
|
|
||||||
Furthermore, our content files’ extensions are .omwaddon for addon files and .omwgame for game files.
|
Furthermore, our content files’ extensions are .omwaddon for addon files and .omwgame for game files.
|
||||||
|
|
||||||
%TODO describe what content files contains. and what not.
|
%TODO describe what content files contains. and what not.
|
||||||
\subparagraph{\MW{} content files}
|
\subparagraph{\MW{} content files}
|
||||||
Using our content files is the recommended solution for projects that employ the \OMW{} engine. However, some players will wish to use
|
Using our content files is the recommended solution for projects that employ the \OMW{} engine. However, some players will wish to use
|
||||||
the original \MW{} engine, despite its large flaws and lacking features\footnote{If this is wrong, we are a very successful project. Yay!}.
|
the original \MW{} engine, despite its large flaws and lacking features\footnote{If this is wrong, we are a very successful project. Yay!}.
|
||||||
In addition, since 2002, thousands of ESP/ESM files have been created, some with truly outstanding content. Because of this, \OCS{}
|
In addition, since 2002, thousands of ESP/ESM files have been created, some with truly outstanding content. Because of this, \OCS{}
|
||||||
will support ESP/ESM files, although this will impose limitations on the user. If you do decide to use ESP/ESM files rather than our own content
|
will support ESP/ESM files, although this will impose limitations on the user. If you do decide to use ESP/ESM files rather than our own content
|
||||||
files, you are most likely aiming for original engine compatibility. This subject is covered in the very last section of the manual.
|
files, you are most likely aiming for original engine compatibility. This subject is covered in the very last section of the manual.
|
||||||
%not finished TODO add the said section. Most likely when more features are present.
|
%not finished TODO add the said section. Most likely when more features are present.
|
||||||
|
|
||||||
The actual creation of new files is described in the next chapter. Here we are going to focus only on the essential information needed
|
The actual creation of new files is described in the next chapter. Here we are going to focus only on the essential information needed
|
||||||
to create your first \OCS{} file. For now, let's jut remember that content files are stored in the user directory, in the \textbf{data}
|
to create your first \OCS{} file. For now, let's jut remember that content files are stored in the user directory, in the \textbf{data}
|
||||||
subfolder (the particular data directory mentioned above).
|
subfolder (the particular data directory mentioned above).
|
||||||
|
|
||||||
\subparagraph{Dependencies}
|
\subparagraph{Dependencies}
|
||||||
Since addons aim to modify an existing game, it is logical that they also depend on the said game: otherwise they will not function.
|
Since addons aim to modify an existing game, it is logical that they also depend on the said game: otherwise they will not function.
|
||||||
For example, your modification changes the price of iron swords. But what if there are no iron swords in the game? That is right:
|
For example, your modification changes the price of iron swords. But what if there are no iron swords in the game? That is right:
|
||||||
it is nonsense. Therefore, it is necessary to make your addon a dependency of other content files. These can be either game files
|
it is nonsense. Therefore, it is necessary to make your addon a dependency of other content files. These can be either game files
|
||||||
(e.g. an entirely new island), or other addon files (e.g. a house on the island). It is a good idea for addons to depend only on the
|
(e.g. an entirely new island), or other addon files (e.g. a house on the island). It is a good idea for addons to depend only on the
|
||||||
content files they modify, but this is up to the end user to determine.
|
content files they modify, but this is up to the end user to determine.
|
||||||
|
|
||||||
Game files do not depend on any other content files, as they act as master files. A player can only use one game file at a time
|
Game files do not depend on any other content files, as they act as master files. A player can only use one game file at a time
|
||||||
(although this does not apply to the original and dirty ESP/ESM system).
|
(although this does not apply to the original and dirty ESP/ESM system).
|
||||||
|
|
||||||
%\subparagraph{Loading order} %TODO
|
%\subparagraph{Loading order} %TODO
|
||||||
\paragraph{Project files}
|
\paragraph{Project files}
|
||||||
Project files contain data not used by the \OMW{} game engine but which are still needed by OpenCS. Good examples of this data type
|
Project files contain data not used by the \OMW{} game engine but which are still needed by OpenCS. Good examples of this data type
|
||||||
are the record filters (described below). As a mod author, you probably do not need and/or want to distribute project files at all,
|
are the record filters (described below). As a mod author, you probably do not need and/or want to distribute project files at all,
|
||||||
as they are meant to be used only by you.
|
as they are meant to be used only by you.
|
||||||
|
|
||||||
Since project files govern how content files are used in OpenCS, they are always used in conjunction with your specific project.
|
Since project files govern how content files are used in OpenCS, they are always used in conjunction with your specific project.
|
||||||
In fact, each time work commences on a content file that does not have a corresponding project file, a new project file will be created.
|
In fact, each time work commences on a content file that does not have a corresponding project file, a new project file will be created.
|
||||||
|
|
||||||
The project file extension is ``.project''. The name of the project file is the whole name of the content file with appended extensions.
|
The project file extension is ``.project''. The name of the project file is the whole name of the content file with appended extensions.
|
||||||
For instance, a content file named swords.omwaddon is associated with the project file swords.omwaddon.project.
|
For instance, a content file named swords.omwaddon is associated with the project file swords.omwaddon.project.
|
||||||
|
|
||||||
%TODO where are they stored.
|
%TODO where are they stored.
|
||||||
Project files are stored inside the user directory, in the \textbf{projects} subfolder. This is both the location of newly created
|
Project files are stored inside the user directory, in the \textbf{projects} subfolder. This is both the location of newly created
|
||||||
project files, and the place where \OCS{} looks for already existing files.
|
project files, and the place where \OCS{} looks for already existing files.
|
||||||
|
|
||||||
\paragraph{Resource files}
|
\paragraph{Resource files}
|
||||||
%textures, sounds, whatever
|
%textures, sounds, whatever
|
||||||
The vast majority of modern video games use what we shall term \textbf{resource files}: models, textures, icons, sounds and so on.
|
The vast majority of modern video games use what we shall term \textbf{resource files}: models, textures, icons, sounds and so on.
|
||||||
ESPs, ESMs and \OMW{} content files do not contain these files, merely instructions on how they are used. It follows that the \OMW{}
|
ESPs, ESMs and \OMW{} content files do not contain these files, merely instructions on how they are used. It follows that the \OMW{}
|
||||||
engine must be capable of supporting these resource files in order for them to function. Therefore this section covers ways to add
|
engine must be capable of supporting these resource files in order for them to function. Therefore this section covers ways to add
|
||||||
resource files to your content file, and outlines which formats are supported. Later, you will learn how to make use of these files
|
resource files to your content file, and outlines which formats are supported. Later, you will learn how to make use of these files
|
||||||
in your content.
|
in your content.
|
||||||
|
|
||||||
\subparagraph{Audio}
|
\subparagraph{Audio}
|
||||||
OpenMW utilises {FFmpeg} for audio playback, so we support every audio type supported by this library. This is a huge list.
|
OpenMW utilises {FFmpeg} for audio playback, so we support every audio type supported by this library. This is a huge list.
|
||||||
Below is only a small sample of supported file types.
|
Below is only a small sample of supported file types.
|
||||||
|
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item mp3 ({MPEG}-1 {Part 3 Layer 3}) A popular audio file format and the \textit{de facto} standard for storing audio. Used by
|
\item mp3 ({MPEG}-1 {Part 3 Layer 3}) A popular audio file format and the \textit{de facto} standard for storing audio. Used by
|
||||||
the \MW{} game.
|
the \MW{} game.
|
||||||
\item ogg Open source, multimedia container file which uses the high quality vorbis audio codec. Recommended.
|
\item ogg Open source, multimedia container file which uses the high quality vorbis audio codec. Recommended.
|
||||||
\end{description}
|
\end{description}
|
||||||
|
|
||||||
\subparagraph{Video}
|
\subparagraph{Video}
|
||||||
As in the case of audio files, we use {FFmpeg} to decode video files. The list of supported files is long -– only the most
|
As in the case of audio files, we use {FFmpeg} to decode video files. The list of supported files is long -– only the most
|
||||||
significant will be covered.
|
significant will be covered.
|
||||||
|
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item bik Format used by the original \MW{} game.
|
\item bik Format used by the original \MW{} game.
|
||||||
\item mp4 Multimedia container which use more advanced codecs ({MPEG-4 Parts 2,3,10}) with a better audio and video compression rate,
|
\item mp4 Multimedia container which use more advanced codecs ({MPEG-4 Parts 2,3,10}) with a better audio and video compression rate,
|
||||||
but which require more {CPU} intensive decoding -- this probably makes it less suited for storing sounds in computer games, but
|
but which require more {CPU} intensive decoding -- this probably makes it less suited for storing sounds in computer games, but
|
||||||
good for videos.
|
good for videos.
|
||||||
\item webm A new, shiny and open source video format with excellent compression. It needs quite a lot of processing power to be decoded,
|
\item webm A new, shiny and open source video format with excellent compression. It needs quite a lot of processing power to be decoded,
|
||||||
but since game logic is not running during cut scenes we can recommend it for use with \OMW.
|
but since game logic is not running during cut scenes we can recommend it for use with \OMW.
|
||||||
\item ogv An alternative, open source container using theora codec for video and vorbis for audio.
|
\item ogv An alternative, open source container using theora codec for video and vorbis for audio.
|
||||||
\end{description}
|
\end{description}
|
||||||
|
|
||||||
\subparagraph{Textures and images}
|
\subparagraph{Textures and images}
|
||||||
\MW{} uses {DDS} and {TGA} files for all kinds of two dimensional images and textures. In addition, the original engine supported BMP
|
\MW{} uses {DDS} and {TGA} files for all kinds of two dimensional images and textures. In addition, the original engine supported BMP
|
||||||
files (although {BMP} is a terrible format for a video game). We also support an extended set of image files -- including {JPEG} and {PNG}.
|
files (although {BMP} is a terrible format for a video game). We also support an extended set of image files -- including {JPEG} and {PNG}.
|
||||||
JPEG and PNG files can be useful in some cases. For instance, a JPEG file is a valid option for a skybox texture and PNG can useful for masks.
|
JPEG and PNG files can be useful in some cases. For instance, a JPEG file is a valid option for a skybox texture and PNG can useful for masks.
|
||||||
However, keep in mind that a JPEG can grow large quickly and so are not the best option with a {DirectX} rendering backend. DDS files
|
However, keep in mind that a JPEG can grow large quickly and so are not the best option with a {DirectX} rendering backend. DDS files
|
||||||
are therefore recommended for textures.
|
are therefore recommended for textures.
|
||||||
%\subparagraph{Meshes} %TODO once we will support something more than just nifs
|
%\subparagraph{Meshes} %TODO once we will support something more than just nifs
|
|
@ -1,202 +1,202 @@
|
||||||
\section{Record filters}
|
\section{Record filters}
|
||||||
\subsection{Introduction}
|
\subsection{Introduction}
|
||||||
Filters are the key element of \OCS{} use cases by allowing rapid and easy access to the searched records presented in all tables.
|
Filters are the key element of \OCS{} use cases by allowing rapid and easy access to the searched records presented in all tables.
|
||||||
Therefore: in order to use this application fully effective you should make sure that all concepts and instructions written in
|
Therefore: in order to use this application fully effective you should make sure that all concepts and instructions written in
|
||||||
the this section of the manual are perfectly clear to you.
|
the this section of the manual are perfectly clear to you.
|
||||||
|
|
||||||
Do not be afraid though, filters are fairly intuitive and easy to use.
|
Do not be afraid though, filters are fairly intuitive and easy to use.
|
||||||
|
|
||||||
\subsubsection{Used Terms}
|
\subsubsection{Used Terms}
|
||||||
|
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item[Filter] is generally speaking a tool able to ``Filter'' (that is: select some elements, while discarding others) according
|
\item[Filter] is generally speaking a tool able to ``Filter'' (that is: select some elements, while discarding others) according
|
||||||
to the some criteria. In case of \OCS: records are being filtered according to the criteria of user choice. Criteria are written
|
to the some criteria. In case of \OCS: records are being filtered according to the criteria of user choice. Criteria are written
|
||||||
down in language with simple syntax.
|
down in language with simple syntax.
|
||||||
\item[Criteria] describes condition under with any any record is being select by the filter.
|
\item[Criteria] describes condition under with any any record is being select by the filter.
|
||||||
\item[Syntax] as you may noticed computers (in general) are rather strict, and expect only strictly formulated orders -- that is:
|
\item[Syntax] as you may noticed computers (in general) are rather strict, and expect only strictly formulated orders -- that is:
|
||||||
written with correct syntax.
|
written with correct syntax.
|
||||||
\item[Expression] is way we are actually performing filtering. Filter can be treated as ``functions'': accepts arguments, and evaluates
|
\item[Expression] is way we are actually performing filtering. Filter can be treated as ``functions'': accepts arguments, and evaluates
|
||||||
either to the true or false for every column record at the time.
|
either to the true or false for every column record at the time.
|
||||||
\item[N-ary] is any expression that expects one or more expressions as arguments. It is useful for grouping two (or more) other expressions
|
\item[N-ary] is any expression that expects one or more expressions as arguments. It is useful for grouping two (or more) other expressions
|
||||||
together in order to create filter that will check for criteria placed in two (again: or more) columns (logical \textit{or}, \textit{and}).
|
together in order to create filter that will check for criteria placed in two (again: or more) columns (logical \textit{or}, \textit{and}).
|
||||||
\item[unary] is any expression that expects one other expression. The example is \textit{not} expression. In fact \textit{not} is the only useful
|
\item[unary] is any expression that expects one other expression. The example is \textit{not} expression. In fact \textit{not} is the only useful
|
||||||
unary expression in \OCS{} record filters.
|
unary expression in \OCS{} record filters.
|
||||||
\item[nullary] is expression that does not accepts other expressions. It accepts arguments specified later.
|
\item[nullary] is expression that does not accepts other expressions. It accepts arguments specified later.
|
||||||
\end{description}
|
\end{description}
|
||||||
|
|
||||||
\subsubsection{Basics}
|
\subsubsection{Basics}
|
||||||
In fact you do not need to learn everything about filters in order to use them. In fact all you need to know to achieve decent productivity
|
In fact you do not need to learn everything about filters in order to use them. In fact all you need to know to achieve decent productivity
|
||||||
with \OCS{} is inside basics section.
|
with \OCS{} is inside basics section.
|
||||||
|
|
||||||
\subsubsection{Interface}
|
\subsubsection{Interface}
|
||||||
Above each table there is a field that is used to enter filter: either predefined by the \OMW{} developers or made by you, the user.
|
Above each table there is a field that is used to enter filter: either predefined by the \OMW{} developers or made by you, the user.
|
||||||
You probably noticed it before. However there is also completely new element, although using familiar table layout. Go to the application
|
You probably noticed it before. However there is also completely new element, although using familiar table layout. Go to the application
|
||||||
menu view, and click filters. You should see set of default filters, made by the \OMW{} team in the table with the following columns: filter,
|
menu view, and click filters. You should see set of default filters, made by the \OMW{} team in the table with the following columns: filter,
|
||||||
description and modified.
|
description and modified.
|
||||||
|
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item[ID] contains the name of the filter.
|
\item[ID] contains the name of the filter.
|
||||||
\item[Modified] just like in all other tables you have seen so far modified indicates if a filter was added, modified or removed.
|
\item[Modified] just like in all other tables you have seen so far modified indicates if a filter was added, modified or removed.
|
||||||
\item[Filter] column containing expression of the filter.
|
\item[Filter] column containing expression of the filter.
|
||||||
\item[Description] contains the short description of the filter function. Do not expect any surprises there.
|
\item[Description] contains the short description of the filter function. Do not expect any surprises there.
|
||||||
\end{description}
|
\end{description}
|
||||||
|
|
||||||
So let's learn how to actually use those to speed up your work.
|
So let's learn how to actually use those to speed up your work.
|
||||||
\subsubsection{Using predefined filters}
|
\subsubsection{Using predefined filters}
|
||||||
Using those filters is quite easy and involves typing inside the filter field above the table. For instance, try to open referencables
|
Using those filters is quite easy and involves typing inside the filter field above the table. For instance, try to open referencables
|
||||||
table and type in the filters field the following: \mono{project::weapons}. As soon as you complete the text, table will magicly alter
|
table and type in the filters field the following: \mono{project::weapons}. As soon as you complete the text, table will magicly alter
|
||||||
and will show only the weapons. As you could noticed \mono{project::weapons} is nothing else than a~ID of one of the predefined filters. That is it:
|
and will show only the weapons. As you could noticed \mono{project::weapons} is nothing else than a~ID of one of the predefined filters. That is it:
|
||||||
in order to use the filter inside the table you simply type it is name inside the filter field.
|
in order to use the filter inside the table you simply type it is name inside the filter field.
|
||||||
|
|
||||||
To make life easier filter IDs follow simple convention.
|
To make life easier filter IDs follow simple convention.
|
||||||
|
|
||||||
\begin{itemize}
|
\begin{itemize}
|
||||||
\item Filter ID filtering a specific record type contains usually the name of a specific group. For instance \mono{project::weapons} filter
|
\item Filter ID filtering a specific record type contains usually the name of a specific group. For instance \mono{project::weapons} filter
|
||||||
contains the word weapons (did you noticed?). Plural form is always used.
|
contains the word weapons (did you noticed?). Plural form is always used.
|
||||||
\item When filtering specific subgroup the ID starts just like in the case of general filter. For instance \mono{project::weaponssilver} will
|
\item When filtering specific subgroup the ID starts just like in the case of general filter. For instance \mono{project::weaponssilver} will
|
||||||
filter only silver weapons (new mechanic introduced by the \BM{}, silver weapons deal double damage against werewolfs) and
|
filter only silver weapons (new mechanic introduced by the \BM{}, silver weapons deal double damage against werewolfs) and
|
||||||
\mono{project::weaponsmagical} will filter only magical weapons (able to hurt ghosts and other supernatural creatures).
|
\mono{project::weaponsmagical} will filter only magical weapons (able to hurt ghosts and other supernatural creatures).
|
||||||
\item There are few exceptions from the above rule. For instance there is a \mono{project::added}, \mono{project::removed},
|
\item There are few exceptions from the above rule. For instance there is a \mono{project::added}, \mono{project::removed},
|
||||||
\mono{project::modyfied}, \mono{project::base}.
|
\mono{project::modyfied}, \mono{project::base}.
|
||||||
You would probably except something more like \mono{project::statusadded} but in this case typing this few extra characters would only
|
You would probably except something more like \mono{project::statusadded} but in this case typing this few extra characters would only
|
||||||
help to break your keyboard faster.
|
help to break your keyboard faster.
|
||||||
\end{itemize}
|
\end{itemize}
|
||||||
|
|
||||||
We strongly recommend to take a look at the filters table right now to see what you can filter with that. And try using it! It is very simple.
|
We strongly recommend to take a look at the filters table right now to see what you can filter with that. And try using it! It is very simple.
|
||||||
|
|
||||||
\subsection{Advanced}
|
\subsection{Advanced}
|
||||||
Back to the manual? Great.
|
Back to the manual? Great.
|
||||||
|
|
||||||
If you want to create your own filter you have to know exactly what do you want to get in order to translate this into the expressions.
|
If you want to create your own filter you have to know exactly what do you want to get in order to translate this into the expressions.
|
||||||
Finally, you will have to write this with correct syntax. As a result table will show only desired rows.
|
Finally, you will have to write this with correct syntax. As a result table will show only desired rows.
|
||||||
|
|
||||||
Advance subsection covers everything that you need to know in order to create any filter you may want to %TODO the filter part is actually wrong
|
Advance subsection covers everything that you need to know in order to create any filter you may want to %TODO the filter part is actually wrong
|
||||||
\subsubsection{Namespaces}
|
\subsubsection{Namespaces}
|
||||||
Did you noticed that every default filter has \mono{project::} prefix? It is a \textit{namespace}, a~term borrowed from the \CPP{} language.
|
Did you noticed that every default filter has \mono{project::} prefix? It is a \textit{namespace}, a~term borrowed from the \CPP{} language.
|
||||||
In case of \OCS{} namespace always means scope of the said object\footnote{You are not supposed to understand this at the moment.}.
|
In case of \OCS{} namespace always means scope of the said object\footnote{You are not supposed to understand this at the moment.}.
|
||||||
But what does it mean in case of filters? Well, short explanation is actually simple.
|
But what does it mean in case of filters? Well, short explanation is actually simple.
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item[project::] namespace indicates that filter is used with the project, in multiple sessions. You can restart \OCS{} and filter
|
\item[project::] namespace indicates that filter is used with the project, in multiple sessions. You can restart \OCS{} and filter
|
||||||
is still there.
|
is still there.
|
||||||
\item[session::] namespace indicates that filter is not stored trough multiple sessions and once you will quit \OCS{} (close session)
|
\item[session::] namespace indicates that filter is not stored trough multiple sessions and once you will quit \OCS{} (close session)
|
||||||
the filter will be gone. Forever! Until then it can be found inside the filters table.
|
the filter will be gone. Forever! Until then it can be found inside the filters table.
|
||||||
\end{description}
|
\end{description}
|
||||||
In addition to this two scopes, there is a third one; called one-shot. One-shot filters are not stored (even during single session)
|
In addition to this two scopes, there is a third one; called one-shot. One-shot filters are not stored (even during single session)
|
||||||
anywhere and as the name implies they are supposed to be created when needed only once. Good thing about the one-shot filters is that
|
anywhere and as the name implies they are supposed to be created when needed only once. Good thing about the one-shot filters is that
|
||||||
you do not need to open filters table in order to create it. Instead you just type it directly inside the filter field, starting with
|
you do not need to open filters table in order to create it. Instead you just type it directly inside the filter field, starting with
|
||||||
exclamation mark: ``!''.
|
exclamation mark: ``!''.
|
||||||
|
|
||||||
Still, you may wonder how you are supposed to write expressions, what expressions you should use, and what syntax looks like. Let's start
|
Still, you may wonder how you are supposed to write expressions, what expressions you should use, and what syntax looks like. Let's start
|
||||||
with nullary expressions that will allow you to create a basic filter.
|
with nullary expressions that will allow you to create a basic filter.
|
||||||
|
|
||||||
\subsubsection{Nullary expressions}
|
\subsubsection{Nullary expressions}
|
||||||
All nullary expressions are used in similar manner. First off: you have to write it is name (for instance: \mono{string}) and secondly:
|
All nullary expressions are used in similar manner. First off: you have to write it is name (for instance: \mono{string}) and secondly:
|
||||||
condition that will be checked inside brackets (for instance \mono{string(something, something)}). If conditions of your expression will be meet
|
condition that will be checked inside brackets (for instance \mono{string(something, something)}). If conditions of your expression will be meet
|
||||||
by a record (technical speaking: expression will evaluate to true) the record will show up in the table.
|
by a record (technical speaking: expression will evaluate to true) the record will show up in the table.
|
||||||
|
|
||||||
It is clear that you need to know what are you checking, that is: what column of the table contains information that you are interested
|
It is clear that you need to know what are you checking, that is: what column of the table contains information that you are interested
|
||||||
in and what should be inside specific cell inside this column to meet your requirements. In most cases first word inside brackets sets column
|
in and what should be inside specific cell inside this column to meet your requirements. In most cases first word inside brackets sets column
|
||||||
you want to see, while the second one sets desired value inside of the cell. To separate column argument from the value argument use comma.
|
you want to see, while the second one sets desired value inside of the cell. To separate column argument from the value argument use comma.
|
||||||
|
|
||||||
\paragraph{String -- string(``column'', ``value'')}
|
\paragraph{String -- string(``column'', ``value'')}
|
||||||
String in programmers language is often\footnote{Often, not always. There are different programming languages using slightly different terms.}
|
String in programmers language is often\footnote{Often, not always. There are different programming languages using slightly different terms.}
|
||||||
just a word for anything composed of characters. In case of \OCS{} this is in fact true for every value inside the column that is not composed
|
just a word for anything composed of characters. In case of \OCS{} this is in fact true for every value inside the column that is not composed
|
||||||
of the pure numbers. Even columns containing only ``true`` and ``false`` values can be targeted by the string expression\footnote{There is no
|
of the pure numbers. Even columns containing only ``true`` and ``false`` values can be targeted by the string expression\footnote{There is no
|
||||||
Boolean (``true'' or ``false'') value in the \OCS. You should use string for those.}. String evaluates to true,
|
Boolean (``true'' or ``false'') value in the \OCS. You should use string for those.}. String evaluates to true,
|
||||||
when record contains in the specified column exactly the same value as specified.
|
when record contains in the specified column exactly the same value as specified.
|
||||||
|
|
||||||
Since majority of the columns contain string values, string is among the most often used expressions. Examples:
|
Since majority of the columns contain string values, string is among the most often used expressions. Examples:
|
||||||
\begin{itemize}
|
\begin{itemize}
|
||||||
\item \mono{string(``Record Type'', ``Weapon'')} -- will evaluate to true for all records containing \mono{Weapon} in the \mono{Record Type} column cell.
|
\item \mono{string(``Record Type'', ``Weapon'')} -- will evaluate to true for all records containing \mono{Weapon} in the \mono{Record Type} column cell.
|
||||||
This group contains every weapon (including arrows and bolts) found in the game.
|
This group contains every weapon (including arrows and bolts) found in the game.
|
||||||
\item \mono{string(``Portable'', ``true'')} -- will evaluate to true for all records containing word true inside \mono{Portable} column cell.
|
\item \mono{string(``Portable'', ``true'')} -- will evaluate to true for all records containing word true inside \mono{Portable} column cell.
|
||||||
This group contains every portable light sources (lanterns, torches etc.).
|
This group contains every portable light sources (lanterns, torches etc.).
|
||||||
\end{itemize}
|
\end{itemize}
|
||||||
This is probably enough to create around 90 string filters you will eventually need. However, this expression is even more powerful
|
This is probably enough to create around 90 string filters you will eventually need. However, this expression is even more powerful
|
||||||
-- it accepts regular expressions (also called regexps). Regular expressions is a way to create string criteria that will be matched
|
-- it accepts regular expressions (also called regexps). Regular expressions is a way to create string criteria that will be matched
|
||||||
by one than just one specific value in the column. For instance, you can display both left and right gauntlets with the following expression:
|
by one than just one specific value in the column. For instance, you can display both left and right gauntlets with the following expression:
|
||||||
\mono{string("armor type", ".* gauntlet"))} because \mono{.*} in regexps means just: ``anything''. This filter says: please, show me ``any'' gauntlet.
|
\mono{string("armor type", ".* gauntlet"))} because \mono{.*} in regexps means just: ``anything''. This filter says: please, show me ``any'' gauntlet.
|
||||||
There are left and right gauntlets in the \MW{} so this will evaluate to true for both. Simple, isn't it?
|
There are left and right gauntlets in the \MW{} so this will evaluate to true for both. Simple, isn't it?
|
||||||
|
|
||||||
Creating regexps can be a difficult and annoying -- especially when you need complex criteria. On the other hand, we are under impression that in reality complex expressions are needed only in sporadic cases. In fact, the truth is: that most of the time only already mentioned
|
Creating regexps can be a difficult and annoying -- especially when you need complex criteria. On the other hand, we are under impression that in reality complex expressions are needed only in sporadic cases. In fact, the truth is: that most of the time only already mentioned
|
||||||
\mono{.*} is needed and therefore the following description of regexps can be skipped by vast majority of readers.
|
\mono{.*} is needed and therefore the following description of regexps can be skipped by vast majority of readers.
|
||||||
|
|
||||||
Before working with Regular Expressions, you should understand what actually are regular expressions. Essentially, the idea is simple:
|
Before working with Regular Expressions, you should understand what actually are regular expressions. Essentially, the idea is simple:
|
||||||
when you are writing any word, you are using strictly defined letters -- that is: letters create a word. What you want to do with regular
|
when you are writing any word, you are using strictly defined letters -- that is: letters create a word. What you want to do with regular
|
||||||
expression is to use set of rules that will match to many words. It is not that difficult to see what it's needed to do so: first,
|
expression is to use set of rules that will match to many words. It is not that difficult to see what it's needed to do so: first,
|
||||||
you will clearly need way to determinate what letters you want to match (word is composed by letters).
|
you will clearly need way to determinate what letters you want to match (word is composed by letters).
|
||||||
|
|
||||||
Before introducing other ways to choose between characters, I want explain anchors. Anchors allows you to decide where to ``look'' in the string.
|
Before introducing other ways to choose between characters, I want explain anchors. Anchors allows you to decide where to ``look'' in the string.
|
||||||
You surely should know about \mono{\textasciicircum} anchor and \mono{\textdollar}. Putting \mono{\textasciicircum} will tell to \OCS{}
|
You surely should know about \mono{\textasciicircum} anchor and \mono{\textdollar}. Putting \mono{\textasciicircum} will tell to \OCS{}
|
||||||
to look on the beginning of string, while \mono{\textdollar} is used to mark the end of it. For instance, pattern
|
to look on the beginning of string, while \mono{\textdollar} is used to mark the end of it. For instance, pattern
|
||||||
\mono{\textasciicircum{}Pink.* elephant.\textdollar} will match any sentence beginning with the word \mono{Pink} and ending with
|
\mono{\textasciicircum{}Pink.* elephant.\textdollar} will match any sentence beginning with the word \mono{Pink} and ending with
|
||||||
\mono{ elephant.}. Pink fat elephant. Pink cute elephant. It does not matter what is in between because \mono{.*} is used.
|
\mono{ elephant.}. Pink fat elephant. Pink cute elephant. It does not matter what is in between because \mono{.*} is used.
|
||||||
|
|
||||||
You have already seen the power of the simple \mono{.*}. But what if you want to chose between only two (or more) letters? Well, this is when
|
You have already seen the power of the simple \mono{.*}. But what if you want to chose between only two (or more) letters? Well, this is when
|
||||||
\mono{[|]} comes in handy. If you write something like: \mono{\textasciicircum[a|k].*} you are simply telling \OCS{} to filter anything that
|
\mono{[|]} comes in handy. If you write something like: \mono{\textasciicircum[a|k].*} you are simply telling \OCS{} to filter anything that
|
||||||
starts with either \mono{a} or \mono{k}. Using \mono{\textasciicircum[a|k|l].*} will work in the same manner, that is; it will also cover strings starting with \mono{l} as well.
|
starts with either \mono{a} or \mono{k}. Using \mono{\textasciicircum[a|k|l].*} will work in the same manner, that is; it will also cover strings starting with \mono{l} as well.
|
||||||
|
|
||||||
What if you want to match more than just one latter? Just use \mono{(|)}. It is pretty similar to the above one letter as you see, but it is
|
What if you want to match more than just one latter? Just use \mono{(|)}. It is pretty similar to the above one letter as you see, but it is
|
||||||
used to fit more than just one character. For instance: \mono{\textasciicircum(Pink|Green).* (elephant|crocodile).\textdollar} will be
|
used to fit more than just one character. For instance: \mono{\textasciicircum(Pink|Green).* (elephant|crocodile).\textdollar} will be
|
||||||
true for all sentences starting with \mono{Pink} or \mono{Green} and ending with either \mono{elephant.} or \mono{crocodile.}.
|
true for all sentences starting with \mono{Pink} or \mono{Green} and ending with either \mono{elephant.} or \mono{crocodile.}.
|
||||||
|
|
||||||
Regular expressions are not the main topic of this manual. If you wish to learn more on this subject please, read the documentation on
|
Regular expressions are not the main topic of this manual. If you wish to learn more on this subject please, read the documentation on
|
||||||
Qt regular expressions syntax, or TRE regexp syntax (it is almost like in Qt). Above is just enough to use \OCS{} effectively.
|
Qt regular expressions syntax, or TRE regexp syntax (it is almost like in Qt). Above is just enough to use \OCS{} effectively.
|
||||||
|
|
||||||
\paragraph{Value -- value(``value'', (``open'', ``close''))}
|
\paragraph{Value -- value(``value'', (``open'', ``close''))}
|
||||||
While string expression covers vast group of columns containing string values, there are in fact columns with just numerical values like
|
While string expression covers vast group of columns containing string values, there are in fact columns with just numerical values like
|
||||||
``weight``. To filter those we need a value expression. This one works in similar manner to the string filter: first token name and criteria
|
``weight``. To filter those we need a value expression. This one works in similar manner to the string filter: first token name and criteria
|
||||||
inside brackets. Clearly, conditions should hold column to test in. However in this case wanted value is specified as a range.
|
inside brackets. Clearly, conditions should hold column to test in. However in this case wanted value is specified as a range.
|
||||||
As you would imagine the range can be specified as including a border value, or excluding. We are using two types of brackets for this:
|
As you would imagine the range can be specified as including a border value, or excluding. We are using two types of brackets for this:
|
||||||
\begin{itemize}
|
\begin{itemize}
|
||||||
\item To include value use [] brackets. For value equal 5, expression \mono{value(something, [5, 10])} will evaluate to true.
|
\item To include value use [] brackets. For value equal 5, expression \mono{value(something, [5, 10])} will evaluate to true.
|
||||||
\item To exclude value use () brackets. For value equal 5, expression \mono{value(something, (5, 10))} will evaluate to false.
|
\item To exclude value use () brackets. For value equal 5, expression \mono{value(something, (5, 10))} will evaluate to false.
|
||||||
\item Mixing brackets is completely legal. For value equal 10, expression \mono{value(something, [5, 10)} will evaluate to true.
|
\item Mixing brackets is completely legal. For value equal 10, expression \mono{value(something, [5, 10)} will evaluate to true.
|
||||||
The same expression will evaluate to false for value equal 10.
|
The same expression will evaluate to false for value equal 10.
|
||||||
\end{itemize}
|
\end{itemize}
|
||||||
|
|
||||||
\paragraph{``true'' and ``false''}
|
\paragraph{``true'' and ``false''}
|
||||||
Nullary \textit{true} and \textit{false} do not accept any arguments, and always evaluates to true (in case of \textit{true})
|
Nullary \textit{true} and \textit{false} do not accept any arguments, and always evaluates to true (in case of \textit{true})
|
||||||
and false (in case of \textit{false}) no matter what. The main usage of this expressions is the give users ability to quickly
|
and false (in case of \textit{false}) no matter what. The main usage of this expressions is the give users ability to quickly
|
||||||
disable some part of the filter that makes heavy use of the logical expressions.
|
disable some part of the filter that makes heavy use of the logical expressions.
|
||||||
|
|
||||||
\subsubsection{Logical expressions}
|
\subsubsection{Logical expressions}
|
||||||
This subsection takes care of two remaining groups of expressions: binary and unary. The only unary expression present in the \OCS{} is logical
|
This subsection takes care of two remaining groups of expressions: binary and unary. The only unary expression present in the \OCS{} is logical
|
||||||
\textit{not}, while the remaining binary expressions are: \textit{or}, \textit{and}. This clearly makes them (from the user point of view)
|
\textit{not}, while the remaining binary expressions are: \textit{or}, \textit{and}. This clearly makes them (from the user point of view)
|
||||||
belonging to the same group of logical expressions.
|
belonging to the same group of logical expressions.
|
||||||
|
|
||||||
\paragraph{not -- not expression()}
|
\paragraph{not -- not expression()}
|
||||||
Sometimes you may be in need of reversing the output of the expression. This is where \textit{not} comes in handy. Adding \textit{not} before
|
Sometimes you may be in need of reversing the output of the expression. This is where \textit{not} comes in handy. Adding \textit{not} before
|
||||||
expression will revert it: if expression was returning true, it will return false; if it was returning false, it will return true. Parenthesis are not needed: \textit{not} will revert only the first expression following it.
|
expression will revert it: if expression was returning true, it will return false; if it was returning false, it will return true. Parenthesis are not needed: \textit{not} will revert only the first expression following it.
|
||||||
|
|
||||||
To show this on know example, let's consider the \mono{string("armor type", ".* gauntlet"))} filter. As we mentioned earlier this will return true
|
To show this on know example, let's consider the \mono{string("armor type", ".* gauntlet"))} filter. As we mentioned earlier this will return true
|
||||||
for every gauntlet found in game. In order to show everything, but gauntlets we simply do \mono{not string("armor type", ".* gauntlet"))}.
|
for every gauntlet found in game. In order to show everything, but gauntlets we simply do \mono{not string("armor type", ".* gauntlet"))}.
|
||||||
This is probably not the most useful filter on earth. The real value of \textit{not} expression shines when combined with
|
This is probably not the most useful filter on earth. The real value of \textit{not} expression shines when combined with
|
||||||
\textit{or}, \textit{and} filters.
|
\textit{or}, \textit{and} filters.
|
||||||
|
|
||||||
\paragraph{or -- or(expression1(), expression2())}
|
\paragraph{or -- or(expression1(), expression2())}
|
||||||
\textit{Or} is a expression that will return true if one of the arguments evaluates to true. You can use two or more arguments, separated by the comma.
|
\textit{Or} is a expression that will return true if one of the arguments evaluates to true. You can use two or more arguments, separated by the comma.
|
||||||
|
|
||||||
\textit{Or} expression is useful when showing two different group of records is needed. For instance the standard actor filter is using the following
|
\textit{Or} expression is useful when showing two different group of records is needed. For instance the standard actor filter is using the following
|
||||||
\mono{or(string(``record type'', npc), string(``record type'', creature))} and will show both npcs and creatures.
|
\mono{or(string(``record type'', npc), string(``record type'', creature))} and will show both npcs and creatures.
|
||||||
|
|
||||||
\paragraph{and -- and(expression1(), expression2())}
|
\paragraph{and -- and(expression1(), expression2())}
|
||||||
\textit{And} is a expression that will return true if all arguments evaluates to true. As in the case of ``or'' you can use two or more arguments,
|
\textit{And} is a expression that will return true if all arguments evaluates to true. As in the case of ``or'' you can use two or more arguments,
|
||||||
separated by a comma.
|
separated by a comma.
|
||||||
As we mentioned earlier in the \textit{not} filter, combining \textit{not} with \textit{and} can be very useful. For instance to show all armor types,
|
As we mentioned earlier in the \textit{not} filter, combining \textit{not} with \textit{and} can be very useful. For instance to show all armor types,
|
||||||
excluding gauntlets you can write the following: \mono{and (not string(``armor type'', ``.* gauntlet''), string(``Record Type'', ``Armor''))}.
|
excluding gauntlets you can write the following: \mono{and (not string(``armor type'', ``.* gauntlet''), string(``Record Type'', ``Armor''))}.
|
||||||
|
|
||||||
\subsubsection{Creating and saving filter}
|
\subsubsection{Creating and saving filter}
|
||||||
In order to create and save new filter, you should go to the filters table, right click and select option ``add record'' from the context menu.
|
In order to create and save new filter, you should go to the filters table, right click and select option ``add record'' from the context menu.
|
||||||
A horizontal widget group at the bottom of the table should show up. From there you should select a namespace responsible for scope of
|
A horizontal widget group at the bottom of the table should show up. From there you should select a namespace responsible for scope of
|
||||||
the filter (described earlier) and desired ID of the filter. After pressing OK button new entry will show up in the filters table. This filter
|
the filter (described earlier) and desired ID of the filter. After pressing OK button new entry will show up in the filters table. This filter
|
||||||
does nothing at the moment, since it still lacks expressions. In order to add your formula simply double click the filter cell of the new entry
|
does nothing at the moment, since it still lacks expressions. In order to add your formula simply double click the filter cell of the new entry
|
||||||
and write it down there.
|
and write it down there.
|
||||||
Done! You are free to use your filter.
|
Done! You are free to use your filter.
|
||||||
|
|
||||||
\subsubsection{Replacing the default filters set}
|
\subsubsection{Replacing the default filters set}
|
||||||
OpenCS allows you to substitute default filters set provided by us, with your own filters. In order to do so you should create a new project,
|
OpenCS allows you to substitute default filters set provided by us, with your own filters. In order to do so you should create a new project,
|
||||||
add desired filters, remove undesired and save. Rename the file to the ``defaultfilters'' (do not forget to remove .omwaddon.project extension)
|
add desired filters, remove undesired and save. Rename the file to the ``defaultfilters'' (do not forget to remove .omwaddon.project extension)
|
||||||
and place it inside your configuration directory.
|
and place it inside your configuration directory.
|
||||||
|
|
||||||
The file acts as template for all new project files from now. If you wish to go back to the old default set, simply rename or remove the custom file.
|
The file acts as template for all new project files from now. If you wish to go back to the old default set, simply rename or remove the custom file.
|
||||||
|
|
|
@ -1,37 +1,37 @@
|
||||||
\documentclass[american]{article}
|
\documentclass[american]{article}
|
||||||
\usepackage[T1]{fontenc}
|
\usepackage[T1]{fontenc}
|
||||||
\usepackage{babel}
|
\usepackage{babel}
|
||||||
\usepackage{txfonts} % Public Times New Roman text & math font
|
\usepackage{txfonts} % Public Times New Roman text & math font
|
||||||
\usepackage[pdftex]{graphicx}
|
\usepackage[pdftex]{graphicx}
|
||||||
\usepackage[final,colorlinks,pdftex,pdfpagelabels=true]{hyperref}
|
\usepackage[final,colorlinks,pdftex,pdfpagelabels=true]{hyperref}
|
||||||
\author{OpenMW Team}
|
\author{OpenMW Team}
|
||||||
|
|
||||||
\def\pdfBorderAttrs{/Border [0 0 0] } % No border arround Links
|
\def\pdfBorderAttrs{/Border [0 0 0] } % No border arround Links
|
||||||
|
|
||||||
\def\CPP{{C\kern-.05em\raise.23ex\hbox{+\kern-.05em+}}}
|
\def\CPP{{C\kern-.05em\raise.23ex\hbox{+\kern-.05em+}}}
|
||||||
\hypersetup{%
|
\hypersetup{%
|
||||||
pdfauthor={Copyright \textcopyright{} OpenMW Team },
|
pdfauthor={Copyright \textcopyright{} OpenMW Team },
|
||||||
pdftitle={OpenCS user manual}
|
pdftitle={OpenCS user manual}
|
||||||
}
|
}
|
||||||
\def\mono{\texttt}
|
\def\mono{\texttt}
|
||||||
\def\MW{\textit{Morrowind\texttrademark{}}}
|
\def\MW{\textit{Morrowind\texttrademark{}}}
|
||||||
\def\TB{\textit{Tribunal}}
|
\def\TB{\textit{Tribunal}}
|
||||||
\def\BM{\textit{Bloodmon}}
|
\def\BM{\textit{Bloodmon}}
|
||||||
\def\BS{Bethesda Softworks}
|
\def\BS{Bethesda Softworks}
|
||||||
\def\OMW{\hbox{OpenMW}}
|
\def\OMW{\hbox{OpenMW}}
|
||||||
\def\OCS{\hbox{OpenCS}}
|
\def\OCS{\hbox{OpenCS}}
|
||||||
|
|
||||||
\begin{document}
|
\begin{document}
|
||||||
|
|
||||||
\title{OpenCS User Manual}
|
\title{OpenCS User Manual}
|
||||||
\maketitle
|
\maketitle
|
||||||
\newpage
|
\newpage
|
||||||
\tableofcontents{}
|
\tableofcontents{}
|
||||||
\newpage
|
\newpage
|
||||||
\input{files_and_directories}
|
\input{files_and_directories}
|
||||||
\input{creating_file}
|
\input{creating_file}
|
||||||
\input{windows}
|
\input{windows}
|
||||||
\input{tables}
|
\input{tables}
|
||||||
\input{recordtypes}
|
\input{recordtypes}
|
||||||
\input{filters}
|
\input{filters}
|
||||||
\end{document}
|
\end{document}
|
||||||
|
|
|
@ -1,18 +1,18 @@
|
||||||
\section{Record Types}
|
\section{Record Types}
|
||||||
|
|
||||||
\subsection{Introduction}
|
\subsection{Introduction}
|
||||||
A gameworld contains many items, such as chests, weapons and monsters. All these items are merely instances of templates that we call \textbf{Objects}. The OpenCS \textbf{Objects} table contains information about each of these template objects, eg. its value and weight in the case of items and an aggression level in the case of NPCs.
|
A gameworld contains many items, such as chests, weapons and monsters. All these items are merely instances of templates that we call \textbf{Objects}. The OpenCS \textbf{Objects} table contains information about each of these template objects, eg. its value and weight in the case of items and an aggression level in the case of NPCs.
|
||||||
|
|
||||||
Let's go through all Record Types and discuss what you can tell OpenCS about them.
|
Let's go through all Record Types and discuss what you can tell OpenCS about them.
|
||||||
|
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item[Activator:] When the player enters the same cell as this object, a script is started. Often it also has a \textbf{Script} attached to it, though it not mandatory. These scripts are small bits of code written in a special scripting language that OpenCS can read and interpret.
|
\item[Activator:] When the player enters the same cell as this object, a script is started. Often it also has a \textbf{Script} attached to it, though it not mandatory. These scripts are small bits of code written in a special scripting language that OpenCS can read and interpret.
|
||||||
\item[Potion:] This is a potion that is not self-made. It has an \textbf{Icon} for your inventory, Aside from the self-explanatory \textbf{Weight} and \textbf{Coin Value}, it has an attribute called \textbf{Auto Calc} set to ``False''. This means that the effects of this potion are pre-configured. This does not happen when the player makes their own potion.
|
\item[Potion:] This is a potion that is not self-made. It has an \textbf{Icon} for your inventory, Aside from the self-explanatory \textbf{Weight} and \textbf{Coin Value}, it has an attribute called \textbf{Auto Calc} set to ``False''. This means that the effects of this potion are pre-configured. This does not happen when the player makes their own potion.
|
||||||
\item[Apparatus:] This is a tool to make potions. Again there's an icon for your inventory as well as a weight and a coin value. It also has a \textbf{Quality} value attached to it: higher the number, the better the effect on your potions will be. The \textbf{Apparatus Type} describes if the item is a Calcinator, Retort, Alembic or Mortar \& Pestle. Each has a different effect on the potion the player makes. For more information on this subject, please refer to the \href{http://www.uesp.net/wiki/Morrowind:Alchemy#Tools}{UESP page on Alchemy Tools}.
|
\item[Apparatus:] This is a tool to make potions. Again there's an icon for your inventory as well as a weight and a coin value. It also has a \textbf{Quality} value attached to it: higher the number, the better the effect on your potions will be. The \textbf{Apparatus Type} describes if the item is a Calcinator, Retort, Alembic or Mortar \& Pestle. Each has a different effect on the potion the player makes. For more information on this subject, please refer to the \href{http://www.uesp.net/wiki/Morrowind:Alchemy#Tools}{UESP page on Alchemy Tools}.
|
||||||
\item[Armor:] This type of item adds \textbf{Enchantment Points} to the mix. Every piece of clothing or armor has a ''pool'' of potential Magicka that gets unlocked when you enchant it. Strong enchantments consume more Magicka from this pool: the stronger the enchantment, the more Enchantment Points each cast will take up. For more information on this subject, please refer to the \href{http://www.uesp.net/wiki/Morrowind:Enchant}{Enchant page on UESP}. \textbf{Health} means the amount of hit points this piece of armor has. If it sustains enough damage, the armor will be destroyed. Finally, \textbf{Armor Value} tells the game how much points to add to the player character's Armor Rating.
|
\item[Armor:] This type of item adds \textbf{Enchantment Points} to the mix. Every piece of clothing or armor has a ''pool'' of potential Magicka that gets unlocked when you enchant it. Strong enchantments consume more Magicka from this pool: the stronger the enchantment, the more Enchantment Points each cast will take up. For more information on this subject, please refer to the \href{http://www.uesp.net/wiki/Morrowind:Enchant}{Enchant page on UESP}. \textbf{Health} means the amount of hit points this piece of armor has. If it sustains enough damage, the armor will be destroyed. Finally, \textbf{Armor Value} tells the game how much points to add to the player character's Armor Rating.
|
||||||
\item[Book:] This includes scrolls and notes. For the game to make the distinction between books and scrolls, an extra property, \textbf{Scroll}, has been added. Under the \textbf{Skill} column a scroll or book can have an in-game skill listed. Reading this item will raise the player's level in that specific skill. For more information on this, please refer to the \href{http://www.uesp.net/wiki/Morrowind:Skill_Books}{Skill Books page on UESP}.
|
\item[Book:] This includes scrolls and notes. For the game to make the distinction between books and scrolls, an extra property, \textbf{Scroll}, has been added. Under the \textbf{Skill} column a scroll or book can have an in-game skill listed. Reading this item will raise the player's level in that specific skill. For more information on this, please refer to the \href{http://www.uesp.net/wiki/Morrowind:Skill_Books}{Skill Books page on UESP}.
|
||||||
\item[Clothing:] These items work just like Armors, but confer no protective properties. Rather than ``Armor Type'', these items have a ``Clothing Type''.
|
\item[Clothing:] These items work just like Armors, but confer no protective properties. Rather than ``Armor Type'', these items have a ``Clothing Type''.
|
||||||
\item[Container:] This is all the stuff that stores items, from chests to sacks to plants. Its \textbf{Capacity} shows how much stuff you can put in the container. You can compare it to the maximum allowed load a player character can carry (who will get over-encumbered and unable to move if he crosses this threshold). A container, however, will just refuse to take the item in question when it gets ''over-encumbered''. \textbf{Organic Container}s are containers such as plants. Containers that \textbf{Respawn} are not safe to store stuff in. After a certain amount of time they will reset to their default contents, meaning that everything in it is gone forever.
|
\item[Container:] This is all the stuff that stores items, from chests to sacks to plants. Its \textbf{Capacity} shows how much stuff you can put in the container. You can compare it to the maximum allowed load a player character can carry (who will get over-encumbered and unable to move if he crosses this threshold). A container, however, will just refuse to take the item in question when it gets ''over-encumbered''. \textbf{Organic Container}s are containers such as plants. Containers that \textbf{Respawn} are not safe to store stuff in. After a certain amount of time they will reset to their default contents, meaning that everything in it is gone forever.
|
||||||
\item[Creature:] These can be monsters, animals and the like.
|
\item[Creature:] These can be monsters, animals and the like.
|
||||||
|
|
||||||
\end{description}
|
\end{description}
|
||||||
|
|
|
@ -1,94 +1,94 @@
|
||||||
\section{Tables}
|
\section{Tables}
|
||||||
|
|
||||||
\subsection{Introduction}
|
\subsection{Introduction}
|
||||||
If you have launched \OCS{} already and played around with it for a bit, you have probably gotten the impression that it contains lots of tables.
|
If you have launched \OCS{} already and played around with it for a bit, you have probably gotten the impression that it contains lots of tables.
|
||||||
You'd be spot on: \OCS{} is built around using tables. This does not mean it works just like Microsoft Excel or Libre Office Calc, though.
|
You'd be spot on: \OCS{} is built around using tables. This does not mean it works just like Microsoft Excel or Libre Office Calc, though.
|
||||||
Due to the vast amounts of information involved with \MW, tables just made the most sense. You have to be able to spot information quickly
|
Due to the vast amounts of information involved with \MW, tables just made the most sense. You have to be able to spot information quickly
|
||||||
and be able to change them on the fly.
|
and be able to change them on the fly.
|
||||||
Let's browse through the various screens and see what all these tables show.
|
Let's browse through the various screens and see what all these tables show.
|
||||||
|
|
||||||
\subsection{Used Terms}
|
\subsection{Used Terms}
|
||||||
|
|
||||||
\subsubsection{Glossary}
|
\subsubsection{Glossary}
|
||||||
|
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item[Record:] An entry in \OCS{} representing an item, location, sound, NPC or anything else.
|
\item[Record:] An entry in \OCS{} representing an item, location, sound, NPC or anything else.
|
||||||
|
|
||||||
\item[Instance, Object:] When an item is placed in the world, it isn't an isolated and unique object. For example, the game world might contain a lot of exquisite belts on different NPCs and in many crates, but they all refer to one specific record in the game's library: the Exquisite Belt record. In this case, all those belts in crates and on NPCs are \textbf{instances}. The central Exquisite Belt record is called a \textbf{object}. This allows modders to make changes to all items of the same type. For example, if you want all exquisite belts to have 4000 enchantment points rather than 400, you will only need to change the \textbf{object} Exquisite Belt rather than all exquisite belts \textbf{instances} individually.
|
\item[Instance, Object:] When an item is placed in the world, it isn't an isolated and unique object. For example, the game world might contain a lot of exquisite belts on different NPCs and in many crates, but they all refer to one specific record in the game's library: the Exquisite Belt record. In this case, all those belts in crates and on NPCs are \textbf{instances}. The central Exquisite Belt record is called a \textbf{object}. This allows modders to make changes to all items of the same type. For example, if you want all exquisite belts to have 4000 enchantment points rather than 400, you will only need to change the \textbf{object} Exquisite Belt rather than all exquisite belts \textbf{instances} individually.
|
||||||
\end{description}
|
\end{description}
|
||||||
|
|
||||||
\subsubsection{Recurring Terms}
|
\subsubsection{Recurring Terms}
|
||||||
Some columns are recurring throughout \OCS. They show up in (nearly) every table in \OCS.
|
Some columns are recurring throughout \OCS. They show up in (nearly) every table in \OCS.
|
||||||
|
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item[ID] Many items in the OpenCS database have a unique identifier in both OpenCS and Morrowind. This is usually a very self-explanatory name. For example, the ID for the (unique) black pants of Caius Cosades is ``Caius\_pants''. This allows you to manipulate the game in many ways. For example, you could add these pants to your inventory by simply opening the console and write: ``player->addItem Caius\_pants''. Either way, in both Morrowind and OpenCS, the ID is the primary way to identify all these different parts of the game.
|
\item[ID] Many items in the OpenCS database have a unique identifier in both OpenCS and Morrowind. This is usually a very self-explanatory name. For example, the ID for the (unique) black pants of Caius Cosades is ``Caius\_pants''. This allows you to manipulate the game in many ways. For example, you could add these pants to your inventory by simply opening the console and write: ``player->addItem Caius\_pants''. Either way, in both Morrowind and OpenCS, the ID is the primary way to identify all these different parts of the game.
|
||||||
\item[Modified] This column shows what has happened (if something has happened) to this record. There are four possible states in which it can exist.
|
\item[Modified] This column shows what has happened (if something has happened) to this record. There are four possible states in which it can exist.
|
||||||
\item[Base] means that this record is part of the base game and is in its original state. Usually, if you create a mod, the base game is Morrowind with
|
\item[Base] means that this record is part of the base game and is in its original state. Usually, if you create a mod, the base game is Morrowind with
|
||||||
optionally the Bloodmoon and Tribunal expansions.
|
optionally the Bloodmoon and Tribunal expansions.
|
||||||
\item[Added] means that this record was not in the base game and has been added by a~modder.
|
\item[Added] means that this record was not in the base game and has been added by a~modder.
|
||||||
\item[Modified] means that the record is part of the base game, but has been changed in some way.
|
\item[Modified] means that the record is part of the base game, but has been changed in some way.
|
||||||
\item[Deleted] means that this record used to be part of the base game, but has been removed as an entry. This does not mean, however, that the occurrences
|
\item[Deleted] means that this record used to be part of the base game, but has been removed as an entry. This does not mean, however, that the occurrences
|
||||||
in the game itself have been removed! For example, if you remove the CharGen\_Bed entry from morrowind.esm, it does not mean the bedroll in the basement
|
in the game itself have been removed! For example, if you remove the CharGen\_Bed entry from morrowind.esm, it does not mean the bedroll in the basement
|
||||||
of the Census and Excise Office in Seyda Neen is gone. You're going to have to delete that instance yourself or make sure that that object is replaced
|
of the Census and Excise Office in Seyda Neen is gone. You're going to have to delete that instance yourself or make sure that that object is replaced
|
||||||
by something that still exists otherwise you will get crashes in the worst case scenario.
|
by something that still exists otherwise you will get crashes in the worst case scenario.
|
||||||
\end{description}
|
\end{description}
|
||||||
|
|
||||||
\subsection{World Screens}
|
\subsection{World Screens}
|
||||||
The contents of the game world can be changed by choosing one of the options in the appropriate menu at the top of the screen.
|
The contents of the game world can be changed by choosing one of the options in the appropriate menu at the top of the screen.
|
||||||
|
|
||||||
\subsubsection{Regions}
|
\subsubsection{Regions}
|
||||||
This describes the general areas of the gameworld. Each of these areas has different rules about things such as encounters and weather.
|
This describes the general areas of the gameworld. Each of these areas has different rules about things such as encounters and weather.
|
||||||
|
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item[Name:] This is how the game will show your location in-game.
|
\item[Name:] This is how the game will show your location in-game.
|
||||||
\item[Map Colour:] This is a six-digit hexadecimal representation of the color used to identify the region on the map available in
|
\item[Map Colour:] This is a six-digit hexadecimal representation of the color used to identify the region on the map available in
|
||||||
World > Region Map. If you do not have an application with a color picker, you can use your favorite search engine to find a color picker on-line.
|
World > Region Map. If you do not have an application with a color picker, you can use your favorite search engine to find a color picker on-line.
|
||||||
\item[Sleep Encounter:] These are the rules for what kind of enemies you might encounter when you sleep outside in the wild.
|
\item[Sleep Encounter:] These are the rules for what kind of enemies you might encounter when you sleep outside in the wild.
|
||||||
\end{description}
|
\end{description}
|
||||||
|
|
||||||
\subsubsection{Cells}
|
\subsubsection{Cells}
|
||||||
Expansive worlds such as Vvardenfell, with all its items, NPCs, etc. have a lot going on simultaneously. But if you are in Balmora,
|
Expansive worlds such as Vvardenfell, with all its items, NPCs, etc. have a lot going on simultaneously. But if you are in Balmora,
|
||||||
why would the computer need to keep track the exact locations of NPCs walking through the corridors in a Vivec canton? All that work would
|
why would the computer need to keep track the exact locations of NPCs walking through the corridors in a Vivec canton? All that work would
|
||||||
be quite useless and bring your system to its knees! So the world has been divided up into squares we call "cells". Once your character enters a cell,
|
be quite useless and bring your system to its knees! So the world has been divided up into squares we call "cells". Once your character enters a cell,
|
||||||
the game will load everything that is going on in that cell so you can interact with it.
|
the game will load everything that is going on in that cell so you can interact with it.
|
||||||
|
|
||||||
In the original \MW{} this could be seen when you were traveling and you would see a small loading bar at the bottom of the screen;
|
In the original \MW{} this could be seen when you were traveling and you would see a small loading bar at the bottom of the screen;
|
||||||
you had just entered a new cell and the game would have to load all the items and NPCs. The Cells screen in \OCS{} provides you with a list of cells
|
you had just entered a new cell and the game would have to load all the items and NPCs. The Cells screen in \OCS{} provides you with a list of cells
|
||||||
in the game, both the interior cells (houses, dungeons, mines, etc.) and the exterior cells (the outside world).
|
in the game, both the interior cells (houses, dungeons, mines, etc.) and the exterior cells (the outside world).
|
||||||
|
|
||||||
\begin{description}
|
\begin{description}
|
||||||
\item[Sleep Forbidden:] Can the player sleep on the floor? In most cities it is forbidden to sleep outside. Sleeping in the wild carries its
|
\item[Sleep Forbidden:] Can the player sleep on the floor? In most cities it is forbidden to sleep outside. Sleeping in the wild carries its
|
||||||
own risks of attack, though, and this entry lets you decide if a player should be allowed to sleep on the floor in this cell or not.
|
own risks of attack, though, and this entry lets you decide if a player should be allowed to sleep on the floor in this cell or not.
|
||||||
|
|
||||||
\item[Interior Water:] Should water be rendered in this interior cell? The game world consists of an endless ocean at height 0. Then the landscape
|
\item[Interior Water:] Should water be rendered in this interior cell? The game world consists of an endless ocean at height 0. Then the landscape
|
||||||
is added. If part of the landscape goes below height 0, the player will see water. (See illustration.)
|
is added. If part of the landscape goes below height 0, the player will see water. (See illustration.)
|
||||||
|
|
||||||
Setting the cell's Interior Water to true tells the game that this cell is both an interior cell (inside a building, for example, rather than
|
Setting the cell's Interior Water to true tells the game that this cell is both an interior cell (inside a building, for example, rather than
|
||||||
in the open air) but that there still needs to be water at height 0. This is useful for dungeons or mines that have water in them.
|
in the open air) but that there still needs to be water at height 0. This is useful for dungeons or mines that have water in them.
|
||||||
|
|
||||||
Setting the cell's Interior Water to false tells the game that the water at height 0 should not be used. Remember that cells that are in
|
Setting the cell's Interior Water to false tells the game that the water at height 0 should not be used. Remember that cells that are in
|
||||||
the outside world are exterior cells and should thus \textit{always} be set to false!
|
the outside world are exterior cells and should thus \textit{always} be set to false!
|
||||||
|
|
||||||
\item[Interior Sky:] Should this interior cell have a sky? This is a rather unique case. The \TB{} expansion took place in a city on
|
\item[Interior Sky:] Should this interior cell have a sky? This is a rather unique case. The \TB{} expansion took place in a city on
|
||||||
the mainland. Normally this would require the city to be composed of exterior cells so it has a sky, weather and the like. But if the player is
|
the mainland. Normally this would require the city to be composed of exterior cells so it has a sky, weather and the like. But if the player is
|
||||||
in an exterior cell and looks at his in-game map, he sees the map of the gameworld with an overview of all exterior cells. The player would have to see
|
in an exterior cell and looks at his in-game map, he sees the map of the gameworld with an overview of all exterior cells. The player would have to see
|
||||||
the city's very own map, as if he was walking around in an interior cell.
|
the city's very own map, as if he was walking around in an interior cell.
|
||||||
|
|
||||||
So the developers decided to create a workaround and take a bit of both: The whole city would technically work exactly like an interior cell,
|
So the developers decided to create a workaround and take a bit of both: The whole city would technically work exactly like an interior cell,
|
||||||
but it would need a sky as if it was an exterior cell. That is what this is. This is why the vast majority of the cells you will find in this screen
|
but it would need a sky as if it was an exterior cell. That is what this is. This is why the vast majority of the cells you will find in this screen
|
||||||
will have this option set to false: It is only meant for these "fake exteriors".
|
will have this option set to false: It is only meant for these "fake exteriors".
|
||||||
|
|
||||||
\item[Region:] To which Region does this cell belong? This has an impact on the way the game handles weather and encounters in this area.
|
\item[Region:] To which Region does this cell belong? This has an impact on the way the game handles weather and encounters in this area.
|
||||||
It is also possible for a cell not to belong to any region.
|
It is also possible for a cell not to belong to any region.
|
||||||
|
|
||||||
\end{description}
|
\end{description}
|
||||||
|
|
||||||
\subsubsection{Objects}
|
\subsubsection{Objects}
|
||||||
This is a library of all the items, triggers, containers, NPCs, etc. in the game. There are several kinds of Record Types. Depending on which type
|
This is a library of all the items, triggers, containers, NPCs, etc. in the game. There are several kinds of Record Types. Depending on which type
|
||||||
a record is, it will need specific information to function. For example, an NPC needs a value attached to its aggression level. A chest, of course,
|
a record is, it will need specific information to function. For example, an NPC needs a value attached to its aggression level. A chest, of course,
|
||||||
does not. All Record Types contain at least a~model. How else would the player see them? Usually they also have a Name, which is what you see
|
does not. All Record Types contain at least a~model. How else would the player see them? Usually they also have a Name, which is what you see
|
||||||
when you hover your reticle over the object.
|
when you hover your reticle over the object.
|
||||||
|
|
||||||
This is a library of all the items, triggers, containers, NPCs, etc. in the game. There are several kinds of Record Types. Depending on which type a record is, it will need specific information to function. For example, an NPC needs a value attached to its aggression level. A chest, of course, does not. All Record Types contain at least a model. How else would the player see them? Usually they also have a Name, which is what you see when you hover your reticle over the object.
|
This is a library of all the items, triggers, containers, NPCs, etc. in the game. There are several kinds of Record Types. Depending on which type a record is, it will need specific information to function. For example, an NPC needs a value attached to its aggression level. A chest, of course, does not. All Record Types contain at least a model. How else would the player see them? Usually they also have a Name, which is what you see when you hover your reticle over the object.
|
||||||
|
|
||||||
Please refer to the Record Types section for an overview of what each type of object does and what you can tell OpenCS about these objects.
|
Please refer to the Record Types section for an overview of what each type of object does and what you can tell OpenCS about these objects.
|
||||||
|
|
|
@ -1,54 +1,54 @@
|
||||||
\section{Windows}
|
\section{Windows}
|
||||||
\subsection{Introduction}
|
\subsection{Introduction}
|
||||||
This section describes the multiple windows interface of the \OCS{} editor. This design principle was chosen in order
|
This section describes the multiple windows interface of the \OCS{} editor. This design principle was chosen in order
|
||||||
to extend the flexibility of the editor, especially on the multiple screens setups and on environments providing advanced
|
to extend the flexibility of the editor, especially on the multiple screens setups and on environments providing advanced
|
||||||
windows management features, like for instance: multiple desktops found commonly on many open source desktop environments.
|
windows management features, like for instance: multiple desktops found commonly on many open source desktop environments.
|
||||||
However, it is enough to have a single large screen to see the advantages of this concept.
|
However, it is enough to have a single large screen to see the advantages of this concept.
|
||||||
|
|
||||||
OpenCS windows interface is easy to describe and understand. In fact we decided to minimize use of many windows concepts
|
OpenCS windows interface is easy to describe and understand. In fact we decided to minimize use of many windows concepts
|
||||||
applied commonly in various applications. For instance dialog windows are really hard to find in the \OCS. You are free to try,
|
applied commonly in various applications. For instance dialog windows are really hard to find in the \OCS. You are free to try,
|
||||||
though.
|
though.
|
||||||
|
|
||||||
Because of this, and the fact that we expect that user is familiar with other applications using windows this section is mostly
|
Because of this, and the fact that we expect that user is familiar with other applications using windows this section is mostly
|
||||||
focused on practical ways of organizing work with the \OCS.
|
focused on practical ways of organizing work with the \OCS.
|
||||||
|
|
||||||
\subsection{Basics}
|
\subsection{Basics}
|
||||||
After starting \OCS{} and choosing content files to use a editor window should show up. It probably does not look surprising:
|
After starting \OCS{} and choosing content files to use a editor window should show up. It probably does not look surprising:
|
||||||
there is a menubar at the top, and there is a~large empty area. That is it: a brand new \OCS{} window contains only menubar
|
there is a menubar at the top, and there is a~large empty area. That is it: a brand new \OCS{} window contains only menubar
|
||||||
and statusbar. In order to make it a little bit more useful you probably want to enable some panels\footnote{Also known as widgets.}.
|
and statusbar. In order to make it a little bit more useful you probably want to enable some panels\footnote{Also known as widgets.}.
|
||||||
You are free to do so, just try to explore the menubar.
|
You are free to do so, just try to explore the menubar.
|
||||||
|
|
||||||
You probably founded out the way to enable and disable some interesting tables, but those will be described later. For now, let's
|
You probably founded out the way to enable and disable some interesting tables, but those will be described later. For now, let's
|
||||||
just focus on the windows itself.
|
just focus on the windows itself.
|
||||||
|
|
||||||
\paragraph{Creating new windows}
|
\paragraph{Creating new windows}
|
||||||
is easy! Just visit view menu, and use the ``New View'' item. Suddenly, out of the blue a new window will show up. As you would expect,
|
is easy! Just visit view menu, and use the ``New View'' item. Suddenly, out of the blue a new window will show up. As you would expect,
|
||||||
it is also blank, and you are free to add any of the \OCS{} panels.
|
it is also blank, and you are free to add any of the \OCS{} panels.
|
||||||
|
|
||||||
\paragraph{Closing opened window}
|
\paragraph{Closing opened window}
|
||||||
is also easy! Simply close that window decoration button. We suspect that you knew that already, but better to be sure.
|
is also easy! Simply close that window decoration button. We suspect that you knew that already, but better to be sure.
|
||||||
Closing last \OCS{} window will also terminate application session.
|
Closing last \OCS{} window will also terminate application session.
|
||||||
|
|
||||||
\paragraph{Multi-everything}
|
\paragraph{Multi-everything}
|
||||||
is the main foundation of \OCS{} interface. You are free to create as many windows as you want to, free to populate it with
|
is the main foundation of \OCS{} interface. You are free to create as many windows as you want to, free to populate it with
|
||||||
any panels you may want to, and move everything as you wish to -- even if it makes no sense at all. If you just got crazy idea and
|
any panels you may want to, and move everything as you wish to -- even if it makes no sense at all. If you just got crazy idea and
|
||||||
you are wonder if you are able to have one hundred \OCS{} windows showing panels of the same type, well most likely you are
|
you are wonder if you are able to have one hundred \OCS{} windows showing panels of the same type, well most likely you are
|
||||||
able to do so.
|
able to do so.
|
||||||
|
|
||||||
The principle behind this design decision is easy to see for \BS{} made editor, but maybe not so clear for users who are
|
The principle behind this design decision is easy to see for \BS{} made editor, but maybe not so clear for users who are
|
||||||
just about to begin their wonderful journey of modding.
|
just about to begin their wonderful journey of modding.
|
||||||
|
|
||||||
\subsection{Advanced}
|
\subsection{Advanced}
|
||||||
So why? Why this is created in such manner. The answer is frankly simple: because it is effective. When creating a mod, you often
|
So why? Why this is created in such manner. The answer is frankly simple: because it is effective. When creating a mod, you often
|
||||||
have to work only with just one table. For instance you are just balancing weapons damage and other statistics. It makes sense
|
have to work only with just one table. For instance you are just balancing weapons damage and other statistics. It makes sense
|
||||||
to have all the space for just that one table. More often, you are required to work with two and switch them from time to time.
|
to have all the space for just that one table. More often, you are required to work with two and switch them from time to time.
|
||||||
All major graphical environments commonly present in operating systems comes with switcher feature, that is a key shortcut to change
|
All major graphical environments commonly present in operating systems comes with switcher feature, that is a key shortcut to change
|
||||||
active window. It is very effective and fast when you have only two windows, each holding only one table. Sometimes you have to work
|
active window. It is very effective and fast when you have only two windows, each holding only one table. Sometimes you have to work
|
||||||
with two at the time, and with one from time to time. Here, you can have one window holding two tables, and second holding just one.
|
with two at the time, and with one from time to time. Here, you can have one window holding two tables, and second holding just one.
|
||||||
|
|
||||||
OpenCS is designed to simply make sense and do not slowdown users. It is as simple as possible (but not simpler), and uses one
|
OpenCS is designed to simply make sense and do not slowdown users. It is as simple as possible (but not simpler), and uses one
|
||||||
flexible approach in all cases.
|
flexible approach in all cases.
|
||||||
|
|
||||||
There is no point in digging deeper in the windows of \OCS. Let's explore panels, starting with tables.
|
There is no point in digging deeper in the windows of \OCS. Let's explore panels, starting with tables.
|
||||||
|
|
||||||
%We should write some tips and tricks here.
|
%We should write some tips and tricks here.
|
Loading…
Reference in a new issue