mirror of
https://github.com/ciphervance/supercell-wx.git
synced 2025-10-30 17:20:04 +00:00
Linked and unlinked vector packets
This commit is contained in:
parent
ab702e9927
commit
96cd27adcb
6 changed files with 237 additions and 151 deletions
|
|
@ -26,9 +26,9 @@ public:
|
||||||
LinkedVectorPacket(LinkedVectorPacket&&) noexcept;
|
LinkedVectorPacket(LinkedVectorPacket&&) noexcept;
|
||||||
LinkedVectorPacket& operator=(LinkedVectorPacket&&) noexcept;
|
LinkedVectorPacket& operator=(LinkedVectorPacket&&) noexcept;
|
||||||
|
|
||||||
uint16_t packet_code() const;
|
uint16_t packet_code() const;
|
||||||
uint16_t length_of_block() const;
|
uint16_t length_of_block() const;
|
||||||
uint16_t value_of_vector() const;
|
std::optional<uint16_t> value_of_vector() const;
|
||||||
|
|
||||||
size_t data_size() const override;
|
size_t data_size() const override;
|
||||||
|
|
||||||
|
|
|
||||||
43
wxdata/include/scwx/wsr88d/rpg/unlinked_vector_packet.hpp
Normal file
43
wxdata/include/scwx/wsr88d/rpg/unlinked_vector_packet.hpp
Normal file
|
|
@ -0,0 +1,43 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <scwx/wsr88d/rpg/packet.hpp>
|
||||||
|
|
||||||
|
#include <cstdint>
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
namespace scwx
|
||||||
|
{
|
||||||
|
namespace wsr88d
|
||||||
|
{
|
||||||
|
namespace rpg
|
||||||
|
{
|
||||||
|
|
||||||
|
class UnlinkedVectorPacketImpl;
|
||||||
|
|
||||||
|
class UnlinkedVectorPacket : public Packet
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit UnlinkedVectorPacket();
|
||||||
|
~UnlinkedVectorPacket();
|
||||||
|
|
||||||
|
UnlinkedVectorPacket(const UnlinkedVectorPacket&) = delete;
|
||||||
|
UnlinkedVectorPacket& operator=(const UnlinkedVectorPacket&) = delete;
|
||||||
|
|
||||||
|
UnlinkedVectorPacket(UnlinkedVectorPacket&&) noexcept;
|
||||||
|
UnlinkedVectorPacket& operator=(UnlinkedVectorPacket&&) noexcept;
|
||||||
|
|
||||||
|
uint16_t packet_code() const;
|
||||||
|
uint16_t length_of_block() const;
|
||||||
|
std::optional<uint16_t> value_of_vector() const;
|
||||||
|
|
||||||
|
size_t data_size() const override;
|
||||||
|
|
||||||
|
bool Parse(std::istream& is) override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::unique_ptr<UnlinkedVectorPacketImpl> p;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace rpg
|
||||||
|
} // namespace wsr88d
|
||||||
|
} // namespace scwx
|
||||||
|
|
@ -1,46 +0,0 @@
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include <scwx/wsr88d/message.hpp>
|
|
||||||
|
|
||||||
#include <cstdint>
|
|
||||||
#include <memory>
|
|
||||||
|
|
||||||
namespace scwx
|
|
||||||
{
|
|
||||||
namespace wsr88d
|
|
||||||
{
|
|
||||||
namespace rpg
|
|
||||||
{
|
|
||||||
|
|
||||||
class Vector2DImpl;
|
|
||||||
|
|
||||||
class Vector2D : public Message
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
explicit Vector2D();
|
|
||||||
~Vector2D();
|
|
||||||
|
|
||||||
Vector2D(const Vector2D&) = delete;
|
|
||||||
Vector2D& operator=(const Vector2D&) = delete;
|
|
||||||
|
|
||||||
Vector2D(Vector2D&&) noexcept;
|
|
||||||
Vector2D& operator=(Vector2D&&) noexcept;
|
|
||||||
|
|
||||||
int16_t start_i() const;
|
|
||||||
int16_t start_j() const;
|
|
||||||
int16_t end_i() const;
|
|
||||||
int16_t end_j() const;
|
|
||||||
|
|
||||||
size_t data_size() const override;
|
|
||||||
|
|
||||||
bool Parse(std::istream& is) override;
|
|
||||||
|
|
||||||
static constexpr size_t SIZE = 8u;
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::unique_ptr<Vector2DImpl> p;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace rpg
|
|
||||||
} // namespace wsr88d
|
|
||||||
} // namespace scwx
|
|
||||||
|
|
@ -1,9 +1,6 @@
|
||||||
#include <scwx/wsr88d/rpg/linked_vector_packet.hpp>
|
#include <scwx/wsr88d/rpg/linked_vector_packet.hpp>
|
||||||
#include <scwx/wsr88d/rpg/vector2d.hpp>
|
|
||||||
|
|
||||||
#include <array>
|
|
||||||
#include <istream>
|
#include <istream>
|
||||||
#include <set>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include <boost/log/trivial.hpp>
|
#include <boost/log/trivial.hpp>
|
||||||
|
|
@ -22,14 +19,23 @@ class LinkedVectorPacketImpl
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
explicit LinkedVectorPacketImpl() :
|
explicit LinkedVectorPacketImpl() :
|
||||||
packetCode_ {}, lengthOfBlock_ {}, valueOfVector_ {}, vectorList_ {} {};
|
packetCode_ {},
|
||||||
|
lengthOfBlock_ {},
|
||||||
|
valueOfVector_ {},
|
||||||
|
startI_ {},
|
||||||
|
startJ_ {},
|
||||||
|
endI_ {},
|
||||||
|
endJ_ {} {};
|
||||||
~LinkedVectorPacketImpl() = default;
|
~LinkedVectorPacketImpl() = default;
|
||||||
|
|
||||||
uint16_t packetCode_;
|
uint16_t packetCode_;
|
||||||
uint16_t lengthOfBlock_;
|
uint16_t lengthOfBlock_;
|
||||||
uint16_t valueOfVector_;
|
uint16_t valueOfVector_;
|
||||||
|
|
||||||
std::vector<Vector2D> vectorList_;
|
uint16_t startI_;
|
||||||
|
uint16_t startJ_;
|
||||||
|
std::vector<uint16_t> endI_;
|
||||||
|
std::vector<uint16_t> endJ_;
|
||||||
};
|
};
|
||||||
|
|
||||||
LinkedVectorPacket::LinkedVectorPacket() :
|
LinkedVectorPacket::LinkedVectorPacket() :
|
||||||
|
|
@ -52,9 +58,16 @@ uint16_t LinkedVectorPacket::length_of_block() const
|
||||||
return p->lengthOfBlock_;
|
return p->lengthOfBlock_;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint16_t LinkedVectorPacket::value_of_vector() const
|
std::optional<uint16_t> LinkedVectorPacket::value_of_vector() const
|
||||||
{
|
{
|
||||||
return p->valueOfVector_;
|
std::optional<uint16_t> value;
|
||||||
|
|
||||||
|
if (p->packetCode_ == 9)
|
||||||
|
{
|
||||||
|
value = p->valueOfVector_;
|
||||||
|
}
|
||||||
|
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t LinkedVectorPacket::data_size() const
|
size_t LinkedVectorPacket::data_size() const
|
||||||
|
|
@ -72,7 +85,7 @@ bool LinkedVectorPacket::Parse(std::istream& is)
|
||||||
p->packetCode_ = ntohs(p->packetCode_);
|
p->packetCode_ = ntohs(p->packetCode_);
|
||||||
p->lengthOfBlock_ = ntohs(p->lengthOfBlock_);
|
p->lengthOfBlock_ = ntohs(p->lengthOfBlock_);
|
||||||
|
|
||||||
size_t vectorSize = p->lengthOfBlock_;
|
int vectorSize = static_cast<int>(p->lengthOfBlock_) - 2;
|
||||||
|
|
||||||
if (is.eof())
|
if (is.eof())
|
||||||
{
|
{
|
||||||
|
|
@ -87,15 +100,28 @@ bool LinkedVectorPacket::Parse(std::istream& is)
|
||||||
vectorSize -= 2;
|
vectorSize -= 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
// The number of vectors is equal to the size divided by the number of bytes
|
is.read(reinterpret_cast<char*>(&p->startI_), 2);
|
||||||
// in a vector
|
is.read(reinterpret_cast<char*>(&p->startJ_), 2);
|
||||||
size_t vectorCount = Vector2D::SIZE / 8;
|
|
||||||
|
|
||||||
for (size_t v = 0; v < vectorCount && !is.eof(); v++)
|
p->startI_ = ntohs(p->startI_);
|
||||||
|
p->startJ_ = ntohs(p->startJ_);
|
||||||
|
|
||||||
|
// The number of vectors is equal to the size divided by the number of bytes
|
||||||
|
// in a vector coordinate
|
||||||
|
int vectorCount = vectorSize / 4;
|
||||||
|
uint16_t endI;
|
||||||
|
uint16_t endJ;
|
||||||
|
|
||||||
|
for (int v = 0; v < vectorCount && !is.eof(); v++)
|
||||||
{
|
{
|
||||||
Vector2D vector;
|
is.read(reinterpret_cast<char*>(&endI), 2);
|
||||||
vector.Parse(is);
|
is.read(reinterpret_cast<char*>(&endJ), 2);
|
||||||
p->vectorList_.push_back(std::move(vector));
|
|
||||||
|
endI = ntohs(endI);
|
||||||
|
endJ = ntohs(endJ);
|
||||||
|
|
||||||
|
p->endI_.push_back(endI);
|
||||||
|
p->endJ_.push_back(endJ);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is.eof())
|
if (is.eof())
|
||||||
|
|
|
||||||
150
wxdata/source/scwx/wsr88d/rpg/unlinked_vector_packet.cpp
Normal file
150
wxdata/source/scwx/wsr88d/rpg/unlinked_vector_packet.cpp
Normal file
|
|
@ -0,0 +1,150 @@
|
||||||
|
#include <scwx/wsr88d/rpg/unlinked_vector_packet.hpp>
|
||||||
|
|
||||||
|
#include <istream>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include <boost/log/trivial.hpp>
|
||||||
|
|
||||||
|
namespace scwx
|
||||||
|
{
|
||||||
|
namespace wsr88d
|
||||||
|
{
|
||||||
|
namespace rpg
|
||||||
|
{
|
||||||
|
|
||||||
|
static const std::string logPrefix_ =
|
||||||
|
"[scwx::wsr88d::rpg::unlinked_vector_packet] ";
|
||||||
|
|
||||||
|
class UnlinkedVectorPacketImpl
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit UnlinkedVectorPacketImpl() :
|
||||||
|
packetCode_ {},
|
||||||
|
lengthOfBlock_ {},
|
||||||
|
valueOfVector_ {},
|
||||||
|
beginI_ {},
|
||||||
|
beginJ_ {},
|
||||||
|
endI_ {},
|
||||||
|
endJ_ {} {};
|
||||||
|
~UnlinkedVectorPacketImpl() = default;
|
||||||
|
|
||||||
|
uint16_t packetCode_;
|
||||||
|
uint16_t lengthOfBlock_;
|
||||||
|
uint16_t valueOfVector_;
|
||||||
|
|
||||||
|
std::vector<uint16_t> beginI_;
|
||||||
|
std::vector<uint16_t> beginJ_;
|
||||||
|
std::vector<uint16_t> endI_;
|
||||||
|
std::vector<uint16_t> endJ_;
|
||||||
|
};
|
||||||
|
|
||||||
|
UnlinkedVectorPacket::UnlinkedVectorPacket() :
|
||||||
|
p(std::make_unique<UnlinkedVectorPacketImpl>())
|
||||||
|
{
|
||||||
|
}
|
||||||
|
UnlinkedVectorPacket::~UnlinkedVectorPacket() = default;
|
||||||
|
|
||||||
|
UnlinkedVectorPacket::UnlinkedVectorPacket(UnlinkedVectorPacket&&) noexcept =
|
||||||
|
default;
|
||||||
|
UnlinkedVectorPacket&
|
||||||
|
UnlinkedVectorPacket::operator=(UnlinkedVectorPacket&&) noexcept = default;
|
||||||
|
|
||||||
|
uint16_t UnlinkedVectorPacket::packet_code() const
|
||||||
|
{
|
||||||
|
return p->packetCode_;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16_t UnlinkedVectorPacket::length_of_block() const
|
||||||
|
{
|
||||||
|
return p->lengthOfBlock_;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::optional<uint16_t> UnlinkedVectorPacket::value_of_vector() const
|
||||||
|
{
|
||||||
|
std::optional<uint16_t> value;
|
||||||
|
|
||||||
|
if (p->packetCode_ == 10)
|
||||||
|
{
|
||||||
|
value = p->valueOfVector_;
|
||||||
|
}
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t UnlinkedVectorPacket::data_size() const
|
||||||
|
{
|
||||||
|
return p->lengthOfBlock_ + 4u;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool UnlinkedVectorPacket::Parse(std::istream& is)
|
||||||
|
{
|
||||||
|
bool blockValid = true;
|
||||||
|
|
||||||
|
is.read(reinterpret_cast<char*>(&p->packetCode_), 2);
|
||||||
|
is.read(reinterpret_cast<char*>(&p->lengthOfBlock_), 2);
|
||||||
|
|
||||||
|
p->packetCode_ = ntohs(p->packetCode_);
|
||||||
|
p->lengthOfBlock_ = ntohs(p->lengthOfBlock_);
|
||||||
|
|
||||||
|
int vectorSize = static_cast<int>(p->lengthOfBlock_);
|
||||||
|
|
||||||
|
if (is.eof())
|
||||||
|
{
|
||||||
|
BOOST_LOG_TRIVIAL(debug) << logPrefix_ << "Reached end of file";
|
||||||
|
blockValid = false;
|
||||||
|
}
|
||||||
|
else if (p->packetCode_ == 10)
|
||||||
|
{
|
||||||
|
is.read(reinterpret_cast<char*>(&p->valueOfVector_), 2);
|
||||||
|
p->valueOfVector_ = ntohs(p->valueOfVector_);
|
||||||
|
|
||||||
|
vectorSize -= 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
// The number of vectors is equal to the size divided by the number of bytes
|
||||||
|
// in a vector
|
||||||
|
int vectorCount = vectorSize / 8;
|
||||||
|
uint16_t beginI;
|
||||||
|
uint16_t beginJ;
|
||||||
|
uint16_t endI;
|
||||||
|
uint16_t endJ;
|
||||||
|
|
||||||
|
for (int v = 0; v < vectorCount && !is.eof(); v++)
|
||||||
|
{
|
||||||
|
is.read(reinterpret_cast<char*>(&beginI), 2);
|
||||||
|
is.read(reinterpret_cast<char*>(&beginJ), 2);
|
||||||
|
is.read(reinterpret_cast<char*>(&endI), 2);
|
||||||
|
is.read(reinterpret_cast<char*>(&endJ), 2);
|
||||||
|
|
||||||
|
beginI = ntohs(beginI);
|
||||||
|
beginJ = ntohs(beginJ);
|
||||||
|
endI = ntohs(endI);
|
||||||
|
endJ = ntohs(endJ);
|
||||||
|
|
||||||
|
p->beginI_.push_back(beginI);
|
||||||
|
p->beginJ_.push_back(beginJ);
|
||||||
|
p->endI_.push_back(endI);
|
||||||
|
p->endJ_.push_back(endJ);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is.eof())
|
||||||
|
{
|
||||||
|
BOOST_LOG_TRIVIAL(debug) << logPrefix_ << "Reached end of file";
|
||||||
|
blockValid = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (p->packetCode_ != 7 && p->packetCode_ != 10)
|
||||||
|
{
|
||||||
|
BOOST_LOG_TRIVIAL(warning)
|
||||||
|
<< logPrefix_ << "Invalid packet code: " << p->packetCode_;
|
||||||
|
blockValid = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return blockValid;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace rpg
|
||||||
|
} // namespace wsr88d
|
||||||
|
} // namespace scwx
|
||||||
|
|
@ -1,87 +0,0 @@
|
||||||
#include <scwx/wsr88d/rpg/vector2d.hpp>
|
|
||||||
|
|
||||||
#include <array>
|
|
||||||
#include <istream>
|
|
||||||
#include <set>
|
|
||||||
#include <string>
|
|
||||||
|
|
||||||
#include <boost/log/trivial.hpp>
|
|
||||||
|
|
||||||
namespace scwx
|
|
||||||
{
|
|
||||||
namespace wsr88d
|
|
||||||
{
|
|
||||||
namespace rpg
|
|
||||||
{
|
|
||||||
|
|
||||||
static const std::string logPrefix_ = "[scwx::wsr88d::rpg::vector2d] ";
|
|
||||||
|
|
||||||
class Vector2DImpl
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
explicit Vector2DImpl() : startI_ {}, startJ_ {}, endI_ {}, endJ_ {} {};
|
|
||||||
~Vector2DImpl() = default;
|
|
||||||
|
|
||||||
int16_t startI_;
|
|
||||||
int16_t startJ_;
|
|
||||||
int16_t endI_;
|
|
||||||
int16_t endJ_;
|
|
||||||
};
|
|
||||||
|
|
||||||
Vector2D::Vector2D() : p(std::make_unique<Vector2DImpl>()) {}
|
|
||||||
Vector2D::~Vector2D() = default;
|
|
||||||
|
|
||||||
Vector2D::Vector2D(Vector2D&&) noexcept = default;
|
|
||||||
Vector2D& Vector2D::operator=(Vector2D&&) noexcept = default;
|
|
||||||
|
|
||||||
int16_t Vector2D::start_i() const
|
|
||||||
{
|
|
||||||
return p->startI_;
|
|
||||||
}
|
|
||||||
|
|
||||||
int16_t Vector2D::start_j() const
|
|
||||||
{
|
|
||||||
return p->startJ_;
|
|
||||||
}
|
|
||||||
|
|
||||||
int16_t Vector2D::end_i() const
|
|
||||||
{
|
|
||||||
return p->endI_;
|
|
||||||
}
|
|
||||||
|
|
||||||
int16_t Vector2D::end_j() const
|
|
||||||
{
|
|
||||||
return p->endJ_;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t Vector2D::data_size() const
|
|
||||||
{
|
|
||||||
return SIZE;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Vector2D::Parse(std::istream& is)
|
|
||||||
{
|
|
||||||
bool blockValid = true;
|
|
||||||
|
|
||||||
is.read(reinterpret_cast<char*>(&p->startI_), 2);
|
|
||||||
is.read(reinterpret_cast<char*>(&p->startJ_), 2);
|
|
||||||
is.read(reinterpret_cast<char*>(&p->endI_), 2);
|
|
||||||
is.read(reinterpret_cast<char*>(&p->endJ_), 2);
|
|
||||||
|
|
||||||
p->startI_ = ntohs(p->startI_);
|
|
||||||
p->startJ_ = ntohs(p->startJ_);
|
|
||||||
p->endI_ = ntohs(p->endI_);
|
|
||||||
p->endJ_ = ntohs(p->endJ_);
|
|
||||||
|
|
||||||
if (is.eof())
|
|
||||||
{
|
|
||||||
BOOST_LOG_TRIVIAL(debug) << logPrefix_ << "Reached end of file";
|
|
||||||
blockValid = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return blockValid;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace rpg
|
|
||||||
} // namespace wsr88d
|
|
||||||
} // namespace scwx
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue