mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-01-19 03:57:14 +01:00
Adjust the Player entity methods to use the new method of receiving formatted strings.
This commit is contained in:
parent
9a52981f19
commit
6373c24bae
@ -86,9 +86,23 @@ const String & CPlayer::GetTag() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
void CPlayer::SetTag(CSStr tag)
|
void CPlayer::SetTag(const StackStrF & tag)
|
||||||
{
|
{
|
||||||
m_Tag.assign(tag);
|
if (tag.mLen > 0)
|
||||||
|
{
|
||||||
|
m_Tag.assign(tag.mPtr, tag.mLen);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_Tag.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ------------------------------------------------------------------------------------------------
|
||||||
|
CPlayer & CPlayer::ApplyTag(StackStrF & tag)
|
||||||
|
{
|
||||||
|
SetTag(tag);
|
||||||
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
@ -317,12 +331,12 @@ CSStr CPlayer::GetName() const
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
void CPlayer::SetName(CSStr name) const
|
void CPlayer::SetName(StackStrF & name) const
|
||||||
{
|
{
|
||||||
// Validate the managed identifier
|
// Validate the managed identifier
|
||||||
Validate();
|
Validate();
|
||||||
// Perform the requested operation
|
// Perform the requested operation
|
||||||
const vcmpError ret = _Func->SetPlayerName(m_ID, name);
|
const vcmpError ret = _Func->SetPlayerName(m_ID, name.mPtr);
|
||||||
// Validate the resulted status
|
// Validate the resulted status
|
||||||
if (ret == vcmpErrorNullArgument)
|
if (ret == vcmpErrorNullArgument)
|
||||||
{
|
{
|
||||||
@ -1354,13 +1368,14 @@ void CPlayer::SetSpectator(CPlayer & target) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
void CPlayer::Redirect(CSStr ip, Uint32 port, CSStr nick, CSStr server_pass, CSStr user_pass)
|
void CPlayer::Redirect(const StackStrF & ip, Uint32 port, const StackStrF & nick,
|
||||||
|
const StackStrF & server_pass, const StackStrF & user_pass)
|
||||||
{
|
{
|
||||||
// Validate the managed identifier
|
// Validate the managed identifier
|
||||||
Validate();
|
Validate();
|
||||||
// Return the requested information
|
// Return the requested information
|
||||||
if (_Func->RedirectPlayerToServer(m_ID, ip, port,
|
if (_Func->RedirectPlayerToServer(m_ID, ip.mPtr, port,
|
||||||
nick, server_pass, user_pass) == vcmpErrorNullArgument)
|
nick.mPtr, server_pass.mPtr, user_pass.mPtr) == vcmpErrorNullArgument)
|
||||||
{
|
{
|
||||||
STHROWF("Invalid arguments encountered");
|
STHROWF("Invalid arguments encountered");
|
||||||
}
|
}
|
||||||
@ -1454,7 +1469,7 @@ const String & CPlayer::GetMessagePrefix(Uint32 index) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
void CPlayer::SetMessagePrefix(Uint32 index, CSStr prefix)
|
void CPlayer::SetMessagePrefix(Uint32 index, StackStrF & prefix)
|
||||||
{
|
{
|
||||||
// Perform a range check on the specified prefix index
|
// Perform a range check on the specified prefix index
|
||||||
if (index >= SQMOD_PLAYER_MSG_PREFIXES)
|
if (index >= SQMOD_PLAYER_MSG_PREFIXES)
|
||||||
@ -1464,7 +1479,7 @@ void CPlayer::SetMessagePrefix(Uint32 index, CSStr prefix)
|
|||||||
// Validate the managed identifier
|
// Validate the managed identifier
|
||||||
Validate();
|
Validate();
|
||||||
// Perform the requested operation
|
// Perform the requested operation
|
||||||
mMessagePrefixes[index].assign(prefix);
|
mMessagePrefixes[index].assign(prefix.mPtr, ClampMin(prefix.mLen, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
@ -1631,38 +1646,26 @@ void CPlayer::StreamFloat(SQFloat val)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
void CPlayer::StreamString(CSStr val)
|
void CPlayer::StreamString(StackStrF & val)
|
||||||
{
|
{
|
||||||
// Validate the managed identifier
|
// Validate the managed identifier
|
||||||
Validate();
|
Validate();
|
||||||
// Is the given string value even valid?
|
|
||||||
if (!val)
|
|
||||||
{
|
|
||||||
STHROWF("Invalid string argument: null");
|
|
||||||
}
|
|
||||||
// Calculate the string length
|
// Calculate the string length
|
||||||
Uint16 length = ConvTo< Uint16 >::From(std::strlen(val));
|
Uint16 length = ConvTo< Uint16 >::From(val.mLen);
|
||||||
// Change the size endianness to big endian
|
// Change the size endianness to big endian
|
||||||
Uint16 size = ((length >> 8) & 0xFF) | ((length & 0xFF) << 8);
|
Uint16 size = ((length >> 8) & 0xFF) | ((length & 0xFF) << 8);
|
||||||
// Write the size and then the string contents
|
// Write the size and then the string contents
|
||||||
m_Buffer.Push< Uint16 >(size);
|
m_Buffer.Push< Uint16 >(size);
|
||||||
m_Buffer.AppendS(val, length);
|
m_Buffer.AppendS(val.mPtr, length);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
void CPlayer::StreamRawString(CSStr val)
|
void CPlayer::StreamRawString(StackStrF & val)
|
||||||
{
|
{
|
||||||
// Validate the managed identifier
|
// Validate the managed identifier
|
||||||
Validate();
|
Validate();
|
||||||
// Is the given string value even valid?
|
|
||||||
if (!val)
|
|
||||||
{
|
|
||||||
STHROWF("Invalid string argument: null");
|
|
||||||
}
|
|
||||||
// Calculate the string length
|
|
||||||
Uint16 length = ConvTo< Uint16 >::From(std::strlen(val));
|
|
||||||
// Write the the string contents
|
// Write the the string contents
|
||||||
m_Buffer.AppendS(val, length);
|
m_Buffer.AppendS(val.mPtr, ClampMin(val.mLen, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
@ -2368,6 +2371,7 @@ void Register_CPlayer(HSQUIRRELVM vm)
|
|||||||
.Prop(_SC("Active"), &CPlayer::IsActive)
|
.Prop(_SC("Active"), &CPlayer::IsActive)
|
||||||
// Core Methods
|
// Core Methods
|
||||||
.Func(_SC("Bind"), &CPlayer::BindEvent)
|
.Func(_SC("Bind"), &CPlayer::BindEvent)
|
||||||
|
.FmtFunc(_SC("SetTag"), &CPlayer::ApplyTag)
|
||||||
.Func(_SC("CustomEvent"), &CPlayer::CustomEvent)
|
.Func(_SC("CustomEvent"), &CPlayer::CustomEvent)
|
||||||
// Properties
|
// Properties
|
||||||
.Prop(_SC("Connected"), &CPlayer::IsConnected)
|
.Prop(_SC("Connected"), &CPlayer::IsConnected)
|
||||||
@ -2447,6 +2451,7 @@ void Register_CPlayer(HSQUIRRELVM vm)
|
|||||||
.Func(_SC("Ban"), &CPlayer::Ban)
|
.Func(_SC("Ban"), &CPlayer::Ban)
|
||||||
.Func(_SC("KickBecause"), &CPlayer::KickBecause)
|
.Func(_SC("KickBecause"), &CPlayer::KickBecause)
|
||||||
.Func(_SC("BanBecause"), &CPlayer::BanBecause)
|
.Func(_SC("BanBecause"), &CPlayer::BanBecause)
|
||||||
|
.FmtFunc(_SC("SetName"), &CPlayer::SetName)
|
||||||
.Func(_SC("GetOption"), &CPlayer::GetOption)
|
.Func(_SC("GetOption"), &CPlayer::GetOption)
|
||||||
.Func(_SC("SetOption"), &CPlayer::SetOption)
|
.Func(_SC("SetOption"), &CPlayer::SetOption)
|
||||||
.Func(_SC("SetOptionEx"), &CPlayer::SetOptionEx)
|
.Func(_SC("SetOptionEx"), &CPlayer::SetOptionEx)
|
||||||
@ -2473,14 +2478,14 @@ void Register_CPlayer(HSQUIRRELVM vm)
|
|||||||
.Func(_SC("Redirect"), &CPlayer::Redirect)
|
.Func(_SC("Redirect"), &CPlayer::Redirect)
|
||||||
.Func(_SC("PlaySound"), &CPlayer::PlaySound)
|
.Func(_SC("PlaySound"), &CPlayer::PlaySound)
|
||||||
.Func(_SC("GetMsgPrefix"), &CPlayer::GetMessagePrefix)
|
.Func(_SC("GetMsgPrefix"), &CPlayer::GetMessagePrefix)
|
||||||
.Func(_SC("SetMsgPrefix"), &CPlayer::SetMessagePrefix)
|
.FmtFunc(_SC("SetMsgPrefix"), &CPlayer::SetMessagePrefix)
|
||||||
.Func(_SC("SetTrackPosition"), &CPlayer::SetTrackPositionEx)
|
.Func(_SC("SetTrackPosition"), &CPlayer::SetTrackPositionEx)
|
||||||
.Func(_SC("StreamByte"), &CPlayer::StreamByte)
|
.Func(_SC("StreamByte"), &CPlayer::StreamByte)
|
||||||
.Func(_SC("StreamShort"), &CPlayer::StreamShort)
|
.Func(_SC("StreamShort"), &CPlayer::StreamShort)
|
||||||
.Func(_SC("StreamInt"), &CPlayer::StreamInt)
|
.Func(_SC("StreamInt"), &CPlayer::StreamInt)
|
||||||
.Func(_SC("StreamFloat"), &CPlayer::StreamFloat)
|
.Func(_SC("StreamFloat"), &CPlayer::StreamFloat)
|
||||||
.Func(_SC("StreamString"), &CPlayer::StreamString)
|
.FmtFunc(_SC("StreamString"), &CPlayer::StreamString)
|
||||||
.Func(_SC("StreamRawString"), &CPlayer::StreamRawString)
|
.FmtFunc(_SC("StreamRawString"), &CPlayer::StreamRawString)
|
||||||
.Func(_SC("FlushStream"), &CPlayer::FlushStream)
|
.Func(_SC("FlushStream"), &CPlayer::FlushStream)
|
||||||
.Func(_SC("SendBuffer"), &CPlayer::SendBuffer)
|
.Func(_SC("SendBuffer"), &CPlayer::SendBuffer)
|
||||||
// Member Overloads
|
// Member Overloads
|
||||||
|
@ -207,7 +207,12 @@ public:
|
|||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Modify the associated user tag.
|
* Modify the associated user tag.
|
||||||
*/
|
*/
|
||||||
void SetTag(CSStr tag);
|
void SetTag(const StackStrF & tag);
|
||||||
|
|
||||||
|
/* --------------------------------------------------------------------------------------------
|
||||||
|
* Modify the associated user tag.
|
||||||
|
*/
|
||||||
|
CPlayer & ApplyTag(StackStrF & tag);
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Retrieve the associated user data.
|
* Retrieve the associated user data.
|
||||||
@ -297,7 +302,7 @@ public:
|
|||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Modify the nick name of the managed player entity.
|
* Modify the nick name of the managed player entity.
|
||||||
*/
|
*/
|
||||||
void SetName(CSStr name) const;
|
void SetName(StackStrF & name) const;
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Retrieve the current state of the managed player entity.
|
* Retrieve the current state of the managed player entity.
|
||||||
@ -727,7 +732,8 @@ public:
|
|||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Redirect the managed player entity to the specified server.
|
* Redirect the managed player entity to the specified server.
|
||||||
*/
|
*/
|
||||||
void Redirect(CSStr ip, Uint32 port, CSStr nick, CSStr server_pass, CSStr user_pass);
|
void Redirect(const StackStrF & ip, Uint32 port, const StackStrF & nick,
|
||||||
|
const StackStrF & server_pass, const StackStrF & user_pass);
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Retrieve the authority level of the managed player entity.
|
* Retrieve the authority level of the managed player entity.
|
||||||
@ -777,7 +783,7 @@ public:
|
|||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Modify the message prefix at the specified index for the managed player entity.
|
* Modify the message prefix at the specified index for the managed player entity.
|
||||||
*/
|
*/
|
||||||
void SetMessagePrefix(Uint32 index, CSStr prefix);
|
void SetMessagePrefix(Uint32 index, StackStrF & prefix);
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Retrieve the amount of tracked position changes for the managed player entity.
|
* Retrieve the amount of tracked position changes for the managed player entity.
|
||||||
@ -872,12 +878,12 @@ public:
|
|||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Write a string to the stream buffer.
|
* Write a string to the stream buffer.
|
||||||
*/
|
*/
|
||||||
void StreamString(CSStr val);
|
void StreamString(StackStrF & val);
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Write a raw string to the stream buffer.
|
* Write a raw string to the stream buffer.
|
||||||
*/
|
*/
|
||||||
void StreamRawString(CSStr val);
|
void StreamRawString(StackStrF & val);
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------
|
/* --------------------------------------------------------------------------------------------
|
||||||
* Send the data in the stream buffer to the client.
|
* Send the data in the stream buffer to the client.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user