add sky setting overrides to celestial.flyShip, pass net rules to packet read/write
This commit is contained in:
parent
3fc12923ce
commit
dd52188e53
@ -6,6 +6,8 @@
|
|||||||
|
|
||||||
namespace Star {
|
namespace Star {
|
||||||
|
|
||||||
|
unsigned const CurrentStreamVersion = 3;
|
||||||
|
|
||||||
DataStream::DataStream()
|
DataStream::DataStream()
|
||||||
: m_byteOrder(ByteOrder::BigEndian),
|
: m_byteOrder(ByteOrder::BigEndian),
|
||||||
m_nullTerminatedStrings(false),
|
m_nullTerminatedStrings(false),
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
namespace Star {
|
namespace Star {
|
||||||
|
|
||||||
STAR_EXCEPTION(DataStreamException, IOException);
|
STAR_EXCEPTION(DataStreamException, IOException);
|
||||||
|
extern unsigned const CurrentStreamVersion;
|
||||||
|
|
||||||
// Writes complex types to bytes in a portable big-endian fashion.
|
// Writes complex types to bytes in a portable big-endian fashion.
|
||||||
class DataStream {
|
class DataStream {
|
||||||
@ -13,8 +14,6 @@ public:
|
|||||||
DataStream();
|
DataStream();
|
||||||
virtual ~DataStream() = default;
|
virtual ~DataStream() = default;
|
||||||
|
|
||||||
static unsigned const CurrentStreamVersion = 2;
|
|
||||||
|
|
||||||
// DataStream defaults to big-endian order for all primitive types
|
// DataStream defaults to big-endian order for all primitive types
|
||||||
ByteOrder byteOrder() const;
|
ByteOrder byteOrder() const;
|
||||||
void setByteOrder(ByteOrder byteOrder);
|
void setByteOrder(ByteOrder byteOrder);
|
||||||
|
@ -2,6 +2,6 @@
|
|||||||
|
|
||||||
namespace Star {
|
namespace Star {
|
||||||
|
|
||||||
VersionNumber const OpenProtocolVersion = 2;
|
VersionNumber const OpenProtocolVersion = 3;
|
||||||
|
|
||||||
}
|
}
|
@ -62,9 +62,8 @@ Maybe<PacketStats> PacketSocket::incomingStats() const {
|
|||||||
Maybe<PacketStats> PacketSocket::outgoingStats() const {
|
Maybe<PacketStats> PacketSocket::outgoingStats() const {
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
void PacketSocket::setNetRules(NetCompatibilityRules netRules) { m_netRules = netRules; }
|
||||||
void PacketSocket::setLegacy(bool legacy) { m_legacy = legacy; }
|
NetCompatibilityRules PacketSocket::netRules() const { return m_netRules; }
|
||||||
bool PacketSocket::legacy() const { return m_legacy; }
|
|
||||||
|
|
||||||
void CompressedPacketSocket::setCompressionStreamEnabled(bool enabled) { m_useCompressionStream = enabled; }
|
void CompressedPacketSocket::setCompressionStreamEnabled(bool enabled) { m_useCompressionStream = enabled; }
|
||||||
bool CompressedPacketSocket::compressionStreamEnabled() const { return m_useCompressionStream; }
|
bool CompressedPacketSocket::compressionStreamEnabled() const { return m_useCompressionStream; }
|
||||||
@ -155,7 +154,8 @@ void TcpPacketSocket::sendPackets(List<PacketPtr> packets) {
|
|||||||
PacketPtr& packet = it.next();
|
PacketPtr& packet = it.next();
|
||||||
auto packetType = packet->type();
|
auto packetType = packet->type();
|
||||||
DataStreamBuffer packetBuffer;
|
DataStreamBuffer packetBuffer;
|
||||||
packet->write(packetBuffer);
|
packetBuffer.setStreamCompatibilityVersion(netRules());
|
||||||
|
packet->write(packetBuffer, netRules());
|
||||||
outBuffer.write(packetType);
|
outBuffer.write(packetType);
|
||||||
outBuffer.writeVlqI((int)packetBuffer.size());
|
outBuffer.writeVlqI((int)packetBuffer.size());
|
||||||
outBuffer.writeData(packetBuffer.ptr(), packetBuffer.size());
|
outBuffer.writeData(packetBuffer.ptr(), packetBuffer.size());
|
||||||
@ -168,13 +168,11 @@ void TcpPacketSocket::sendPackets(List<PacketPtr> packets) {
|
|||||||
PacketCompressionMode currentCompressionMode = it.peekNext()->compressionMode();
|
PacketCompressionMode currentCompressionMode = it.peekNext()->compressionMode();
|
||||||
|
|
||||||
DataStreamBuffer packetBuffer;
|
DataStreamBuffer packetBuffer;
|
||||||
|
packetBuffer.setStreamCompatibilityVersion(netRules());
|
||||||
while (it.hasNext()
|
while (it.hasNext()
|
||||||
&& it.peekNext()->type() == currentType
|
&& it.peekNext()->type() == currentType
|
||||||
&& it.peekNext()->compressionMode() == currentCompressionMode) {
|
&& it.peekNext()->compressionMode() == currentCompressionMode) {
|
||||||
if (legacy())
|
it.next()->write(packetBuffer, netRules());
|
||||||
it.next()->writeLegacy(packetBuffer);
|
|
||||||
else
|
|
||||||
it.next()->write(packetBuffer);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Packets must read and write actual data, because this is used to
|
// Packets must read and write actual data, because this is used to
|
||||||
@ -239,6 +237,7 @@ List<PacketPtr> TcpPacketSocket::receivePackets() {
|
|||||||
m_incomingStats.mix(packetType, packetSize, !compressionStreamEnabled());
|
m_incomingStats.mix(packetType, packetSize, !compressionStreamEnabled());
|
||||||
|
|
||||||
DataStreamExternalBuffer packetStream(ds.ptr() + ds.pos(), packetSize);
|
DataStreamExternalBuffer packetStream(ds.ptr() + ds.pos(), packetSize);
|
||||||
|
packetStream.setStreamCompatibilityVersion(netRules());
|
||||||
ByteArray uncompressed;
|
ByteArray uncompressed;
|
||||||
if (packetCompressed) {
|
if (packetCompressed) {
|
||||||
uncompressed = uncompressData(packetStream.ptr(), packetSize, PacketSizeLimit);
|
uncompressed = uncompressData(packetStream.ptr(), packetSize, PacketSizeLimit);
|
||||||
@ -255,10 +254,7 @@ List<PacketPtr> TcpPacketSocket::receivePackets() {
|
|||||||
}
|
}
|
||||||
PacketPtr packet = createPacket(packetType);
|
PacketPtr packet = createPacket(packetType);
|
||||||
packet->setCompressionMode(packetCompressed ? PacketCompressionMode::Enabled : PacketCompressionMode::Disabled);
|
packet->setCompressionMode(packetCompressed ? PacketCompressionMode::Enabled : PacketCompressionMode::Disabled);
|
||||||
if (legacy())
|
packet->read(packetStream, netRules());
|
||||||
packet->readLegacy(packetStream);
|
|
||||||
else
|
|
||||||
packet->read(packetStream);
|
|
||||||
packets.append(std::move(packet));
|
packets.append(std::move(packet));
|
||||||
} while (!packetStream.atEnd());
|
} while (!packetStream.atEnd());
|
||||||
}
|
}
|
||||||
@ -347,10 +343,6 @@ Maybe<PacketStats> TcpPacketSocket::outgoingStats() const {
|
|||||||
return m_outgoingStats.stats();
|
return m_outgoingStats.stats();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TcpPacketSocket::setLegacy(bool legacy) {
|
|
||||||
PacketSocket::setLegacy(legacy);
|
|
||||||
}
|
|
||||||
|
|
||||||
TcpPacketSocket::TcpPacketSocket(TcpSocketPtr socket) : m_socket(std::move(socket)) {}
|
TcpPacketSocket::TcpPacketSocket(TcpSocketPtr socket) : m_socket(std::move(socket)) {}
|
||||||
|
|
||||||
P2PPacketSocketUPtr P2PPacketSocket::open(P2PSocketUPtr socket) {
|
P2PPacketSocketUPtr P2PPacketSocket::open(P2PSocketUPtr socket) {
|
||||||
@ -373,8 +365,9 @@ void P2PPacketSocket::sendPackets(List<PacketPtr> packets) {
|
|||||||
while (it.hasNext()) {
|
while (it.hasNext()) {
|
||||||
PacketType currentType = it.peekNext()->type();
|
PacketType currentType = it.peekNext()->type();
|
||||||
DataStreamBuffer packetBuffer;
|
DataStreamBuffer packetBuffer;
|
||||||
|
packetBuffer.setStreamCompatibilityVersion(netRules());
|
||||||
while (it.hasNext() && it.peekNext()->type() == currentType)
|
while (it.hasNext() && it.peekNext()->type() == currentType)
|
||||||
it.next()->write(packetBuffer);
|
it.next()->write(packetBuffer, netRules());
|
||||||
outBuffer.write(currentType);
|
outBuffer.write(currentType);
|
||||||
outBuffer.write<bool>(false);
|
outBuffer.write<bool>(false);
|
||||||
outBuffer.writeData(packetBuffer.ptr(), packetBuffer.size());
|
outBuffer.writeData(packetBuffer.ptr(), packetBuffer.size());
|
||||||
@ -387,13 +380,11 @@ void P2PPacketSocket::sendPackets(List<PacketPtr> packets) {
|
|||||||
PacketCompressionMode currentCompressionMode = it.peekNext()->compressionMode();
|
PacketCompressionMode currentCompressionMode = it.peekNext()->compressionMode();
|
||||||
|
|
||||||
DataStreamBuffer packetBuffer;
|
DataStreamBuffer packetBuffer;
|
||||||
|
packetBuffer.setStreamCompatibilityVersion(netRules());
|
||||||
while (it.hasNext()
|
while (it.hasNext()
|
||||||
&& it.peekNext()->type() == currentType
|
&& it.peekNext()->type() == currentType
|
||||||
&& it.peekNext()->compressionMode() == currentCompressionMode) {
|
&& it.peekNext()->compressionMode() == currentCompressionMode) {
|
||||||
if (legacy())
|
it.next()->write(packetBuffer, netRules());
|
||||||
it.next()->writeLegacy(packetBuffer);
|
|
||||||
else
|
|
||||||
it.next()->write(packetBuffer);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Packets must read and write actual data, because this is used to
|
// Packets must read and write actual data, because this is used to
|
||||||
@ -440,13 +431,11 @@ List<PacketPtr> P2PPacketSocket::receivePackets() {
|
|||||||
m_incomingStats.mix(packetType, packetSize, !compressionStreamEnabled());
|
m_incomingStats.mix(packetType, packetSize, !compressionStreamEnabled());
|
||||||
|
|
||||||
DataStreamExternalBuffer packetStream(packetBytes);
|
DataStreamExternalBuffer packetStream(packetBytes);
|
||||||
|
packetStream.setStreamCompatibilityVersion(netRules());
|
||||||
do {
|
do {
|
||||||
PacketPtr packet = createPacket(packetType);
|
PacketPtr packet = createPacket(packetType);
|
||||||
packet->setCompressionMode(packetCompressed ? PacketCompressionMode::Enabled : PacketCompressionMode::Disabled);
|
packet->setCompressionMode(packetCompressed ? PacketCompressionMode::Enabled : PacketCompressionMode::Disabled);
|
||||||
if (legacy())
|
packet->read(packetStream, netRules());
|
||||||
packet->readLegacy(packetStream);
|
|
||||||
else
|
|
||||||
packet->read(packetStream);
|
|
||||||
packets.append(std::move(packet));
|
packets.append(std::move(packet));
|
||||||
} while (!packetStream.atEnd());
|
} while (!packetStream.atEnd());
|
||||||
}
|
}
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
#include "StarP2PNetworkingService.hpp"
|
#include "StarP2PNetworkingService.hpp"
|
||||||
#include "StarNetPackets.hpp"
|
#include "StarNetPackets.hpp"
|
||||||
#include "StarZSTDCompression.hpp"
|
#include "StarZSTDCompression.hpp"
|
||||||
|
#include "StarNetCompatibility.hpp"
|
||||||
|
|
||||||
namespace Star {
|
namespace Star {
|
||||||
|
|
||||||
@ -75,10 +76,11 @@ public:
|
|||||||
virtual Maybe<PacketStats> incomingStats() const;
|
virtual Maybe<PacketStats> incomingStats() const;
|
||||||
virtual Maybe<PacketStats> outgoingStats() const;
|
virtual Maybe<PacketStats> outgoingStats() const;
|
||||||
|
|
||||||
virtual void setLegacy(bool legacy);
|
virtual void setNetRules(NetCompatibilityRules netRules);
|
||||||
virtual bool legacy() const;
|
virtual NetCompatibilityRules netRules() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool m_legacy = false;
|
NetCompatibilityRules m_netRules;
|
||||||
};
|
};
|
||||||
|
|
||||||
class CompressedPacketSocket : public PacketSocket {
|
class CompressedPacketSocket : public PacketSocket {
|
||||||
@ -142,8 +144,6 @@ public:
|
|||||||
|
|
||||||
Maybe<PacketStats> incomingStats() const override;
|
Maybe<PacketStats> incomingStats() const override;
|
||||||
Maybe<PacketStats> outgoingStats() const override;
|
Maybe<PacketStats> outgoingStats() const override;
|
||||||
|
|
||||||
void setLegacy(bool legacy) override;
|
|
||||||
private:
|
private:
|
||||||
TcpPacketSocket(TcpSocketPtr socket);
|
TcpPacketSocket(TcpSocketPtr socket);
|
||||||
|
|
||||||
|
@ -85,8 +85,10 @@ EnumMap<NetCompressionMode> const NetCompressionModeNames {
|
|||||||
|
|
||||||
Packet::~Packet() {}
|
Packet::~Packet() {}
|
||||||
|
|
||||||
void Packet::readLegacy(DataStream& ds) { read(ds); }
|
void Packet::read(DataStream& ds, NetCompatibilityRules netRules) { read(ds); }
|
||||||
void Packet::writeLegacy(DataStream& ds) const { write(ds); }
|
void Packet::read(DataStream& ds) {}
|
||||||
|
void Packet::write(DataStream& ds, NetCompatibilityRules netRules) const { write(ds); }
|
||||||
|
void Packet::write(DataStream& ds) const {}
|
||||||
void Packet::readJson(Json const& json) {}
|
void Packet::readJson(Json const& json) {}
|
||||||
Json Packet::writeJson() const { return JsonObject{}; }
|
Json Packet::writeJson() const { return JsonObject{}; }
|
||||||
|
|
||||||
@ -206,12 +208,9 @@ void ProtocolResponsePacket::read(DataStream& ds) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProtocolResponsePacket::writeLegacy(DataStream& ds) const {
|
void ProtocolResponsePacket::write(DataStream& ds, NetCompatibilityRules netRules) const {
|
||||||
ds.write(allowed);
|
ds.write(allowed);
|
||||||
}
|
if (!netRules.isLegacy())
|
||||||
|
|
||||||
void ProtocolResponsePacket::write(DataStream& ds) const {
|
|
||||||
writeLegacy(ds);
|
|
||||||
ds.write(info);
|
ds.write(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -339,22 +338,17 @@ PausePacket::PausePacket() {}
|
|||||||
|
|
||||||
PausePacket::PausePacket(bool pause, float timescale) : pause(pause), timescale(timescale) {}
|
PausePacket::PausePacket(bool pause, float timescale) : pause(pause), timescale(timescale) {}
|
||||||
|
|
||||||
void PausePacket::readLegacy(DataStream& ds) {
|
void PausePacket::read(DataStream& ds, NetCompatibilityRules netRules) {
|
||||||
ds.read(pause);
|
ds.read(pause);
|
||||||
|
if (!netRules.isLegacy())
|
||||||
|
ds.read(timescale);
|
||||||
|
else
|
||||||
timescale = 1.0f;
|
timescale = 1.0f;
|
||||||
}
|
}
|
||||||
|
|
||||||
void PausePacket::read(DataStream& ds) {
|
void PausePacket::write(DataStream& ds, NetCompatibilityRules netRules) const {
|
||||||
readLegacy(ds);
|
|
||||||
ds.read(timescale);
|
|
||||||
}
|
|
||||||
|
|
||||||
void PausePacket::writeLegacy(DataStream& ds) const {
|
|
||||||
ds.write(pause);
|
ds.write(pause);
|
||||||
}
|
if (!netRules.isLegacy())
|
||||||
|
|
||||||
void PausePacket::write(DataStream& ds) const {
|
|
||||||
writeLegacy(ds);
|
|
||||||
ds.write(timescale);
|
ds.write(timescale);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -409,7 +403,8 @@ ClientConnectPacket::ClientConnectPacket(ByteArray assetsDigest, bool allowAsset
|
|||||||
playerName(std::move(playerName)), playerSpecies(std::move(playerSpecies)), shipChunks(std::move(shipChunks)),
|
playerName(std::move(playerName)), playerSpecies(std::move(playerSpecies)), shipChunks(std::move(shipChunks)),
|
||||||
shipUpgrades(std::move(shipUpgrades)), introComplete(std::move(introComplete)), account(std::move(account)), info(std::move(info)) {}
|
shipUpgrades(std::move(shipUpgrades)), introComplete(std::move(introComplete)), account(std::move(account)), info(std::move(info)) {}
|
||||||
|
|
||||||
void ClientConnectPacket::readLegacy(DataStream& ds) {
|
|
||||||
|
void ClientConnectPacket::read(DataStream& ds, NetCompatibilityRules netRules) {
|
||||||
ds.read(assetsDigest);
|
ds.read(assetsDigest);
|
||||||
ds.read(allowAssetsMismatch);
|
ds.read(allowAssetsMismatch);
|
||||||
ds.read(playerUuid);
|
ds.read(playerUuid);
|
||||||
@ -419,15 +414,11 @@ void ClientConnectPacket::readLegacy(DataStream& ds) {
|
|||||||
ds.read(shipUpgrades);
|
ds.read(shipUpgrades);
|
||||||
ds.read(introComplete);
|
ds.read(introComplete);
|
||||||
ds.read(account);
|
ds.read(account);
|
||||||
info = Json();
|
if (!netRules.isLegacy())
|
||||||
}
|
|
||||||
|
|
||||||
void ClientConnectPacket::read(DataStream& ds) {
|
|
||||||
readLegacy(ds);
|
|
||||||
ds.read(info);
|
ds.read(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ClientConnectPacket::writeLegacy(DataStream& ds) const {
|
void ClientConnectPacket::write(DataStream& ds, NetCompatibilityRules netRules) const {
|
||||||
ds.write(assetsDigest);
|
ds.write(assetsDigest);
|
||||||
ds.write(allowAssetsMismatch);
|
ds.write(allowAssetsMismatch);
|
||||||
ds.write(playerUuid);
|
ds.write(playerUuid);
|
||||||
@ -437,10 +428,7 @@ void ClientConnectPacket::writeLegacy(DataStream& ds) const {
|
|||||||
ds.write(shipUpgrades);
|
ds.write(shipUpgrades);
|
||||||
ds.write(introComplete);
|
ds.write(introComplete);
|
||||||
ds.write(account);
|
ds.write(account);
|
||||||
}
|
if (!netRules.isLegacy())
|
||||||
|
|
||||||
void ClientConnectPacket::write(DataStream& ds) const {
|
|
||||||
writeLegacy(ds);
|
|
||||||
ds.write(info);
|
ds.write(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -484,16 +472,20 @@ void PlayerWarpPacket::write(DataStream& ds) const {
|
|||||||
|
|
||||||
FlyShipPacket::FlyShipPacket() {}
|
FlyShipPacket::FlyShipPacket() {}
|
||||||
|
|
||||||
FlyShipPacket::FlyShipPacket(Vec3I system, SystemLocation location) : system(std::move(system)), location(std::move(location)) {}
|
FlyShipPacket::FlyShipPacket(Vec3I system, SystemLocation location, Json settings) : system(std::move(system)), location(std::move(location)), settings(std::move(settings)) {}
|
||||||
|
|
||||||
void FlyShipPacket::read(DataStream& ds) {
|
void FlyShipPacket::read(DataStream& ds, NetCompatibilityRules netRules) {
|
||||||
ds.read(system);
|
ds.read(system);
|
||||||
ds.read(location);
|
ds.read(location);
|
||||||
|
if (netRules.version() >= 3)
|
||||||
|
ds.read(settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FlyShipPacket::write(DataStream& ds) const {
|
void FlyShipPacket::write(DataStream& ds, NetCompatibilityRules netRules) const {
|
||||||
ds.write(system);
|
ds.write(system);
|
||||||
ds.write(location);
|
ds.write(location);
|
||||||
|
if (netRules.version() >= 3)
|
||||||
|
ds.write(settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
ChatSendPacket::ChatSendPacket() : sendMode(ChatSendMode::Broadcast) {}
|
ChatSendPacket::ChatSendPacket() : sendMode(ChatSendMode::Broadcast) {}
|
||||||
@ -944,24 +936,23 @@ void WorldStartAcknowledgePacket::write(DataStream& ds) const {
|
|||||||
PingPacket::PingPacket() {}
|
PingPacket::PingPacket() {}
|
||||||
PingPacket::PingPacket(int64_t time) : time(time) {}
|
PingPacket::PingPacket(int64_t time) : time(time) {}
|
||||||
|
|
||||||
void PingPacket::readLegacy(DataStream& ds) {
|
void PingPacket::read(DataStream& ds, NetCompatibilityRules netRules) {
|
||||||
|
if (netRules.isLegacy()) {
|
||||||
// Packets can't be empty, read the trash data
|
// Packets can't be empty, read the trash data
|
||||||
ds.read<bool>();
|
ds.read<bool>();
|
||||||
time = 0;
|
time = 0;
|
||||||
}
|
} else {
|
||||||
|
|
||||||
void PingPacket::read(DataStream& ds) {
|
|
||||||
ds.readVlqI(time);
|
ds.readVlqI(time);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PingPacket::write(DataStream& ds, NetCompatibilityRules netRules) const {
|
||||||
void PingPacket::writeLegacy(DataStream& ds) const {
|
if (netRules.isLegacy()) {
|
||||||
// Packets can't be empty, write some trash data
|
// Packets can't be empty, write some trash data
|
||||||
ds.write<bool>(false);
|
ds.write<bool>(false);
|
||||||
}
|
} else {
|
||||||
|
|
||||||
void PingPacket::write(DataStream& ds) const {
|
|
||||||
ds.writeVlqI(time);
|
ds.writeVlqI(time);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EntityCreatePacket::EntityCreatePacket(EntityType entityType, ByteArray storeData, ByteArray firstNetState, EntityId entityId)
|
EntityCreatePacket::EntityCreatePacket(EntityType entityType, ByteArray storeData, ByteArray firstNetState, EntityId entityId)
|
||||||
@ -1265,44 +1256,47 @@ void FindUniqueEntityResponsePacket::write(DataStream& ds) const {
|
|||||||
PongPacket::PongPacket() {}
|
PongPacket::PongPacket() {}
|
||||||
PongPacket::PongPacket(int64_t time) : time(time) {}
|
PongPacket::PongPacket(int64_t time) : time(time) {}
|
||||||
|
|
||||||
void PongPacket::readLegacy(DataStream& ds) {
|
|
||||||
|
void PongPacket::read(DataStream& ds, NetCompatibilityRules netRules) {
|
||||||
|
if (netRules.isLegacy()) {
|
||||||
// Packets can't be empty, read the trash data
|
// Packets can't be empty, read the trash data
|
||||||
ds.read<bool>();
|
ds.read<bool>();
|
||||||
time = 0;
|
time = 0;
|
||||||
}
|
} else {
|
||||||
|
|
||||||
void PongPacket::read(DataStream& ds) {
|
|
||||||
ds.readVlqI(time);
|
ds.readVlqI(time);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void PongPacket::writeLegacy(DataStream& ds) const {
|
void PongPacket::write(DataStream& ds, NetCompatibilityRules netRules) const {
|
||||||
|
if (netRules.isLegacy()) {
|
||||||
// Packets can't be empty, write some trash data
|
// Packets can't be empty, write some trash data
|
||||||
ds.write<bool>(false);
|
ds.write<bool>(false);
|
||||||
}
|
} else {
|
||||||
|
|
||||||
void PongPacket::write(DataStream& ds) const {
|
|
||||||
ds.writeVlqI(time);
|
ds.writeVlqI(time);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
StepUpdatePacket::StepUpdatePacket() : remoteTime(0.0) {}
|
StepUpdatePacket::StepUpdatePacket() : remoteTime(0.0) {}
|
||||||
|
|
||||||
StepUpdatePacket::StepUpdatePacket(double remoteTime) : remoteTime(remoteTime) {}
|
StepUpdatePacket::StepUpdatePacket(double remoteTime) : remoteTime(remoteTime) {}
|
||||||
|
|
||||||
void StepUpdatePacket::readLegacy(DataStream& ds) {
|
|
||||||
|
void StepUpdatePacket::read(DataStream& ds, NetCompatibilityRules netRules) {
|
||||||
|
if (netRules.isLegacy()) {
|
||||||
auto steps = ds.readVlqU();
|
auto steps = ds.readVlqU();
|
||||||
remoteTime = double(steps) / 60.0;
|
remoteTime = double(steps) / 60.0;
|
||||||
}
|
} else {
|
||||||
|
|
||||||
void StepUpdatePacket::read(DataStream& ds) {
|
|
||||||
ds.read(remoteTime);
|
ds.read(remoteTime);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void StepUpdatePacket::writeLegacy(DataStream& ds) const {
|
void StepUpdatePacket::write(DataStream& ds, NetCompatibilityRules netRules) const {
|
||||||
|
if (netRules.isLegacy()) {
|
||||||
ds.writeVlqU((uint64_t)round(remoteTime * 60.0));
|
ds.writeVlqU((uint64_t)round(remoteTime * 60.0));
|
||||||
}
|
} else {
|
||||||
|
|
||||||
void StepUpdatePacket::write(DataStream& ds) const {
|
|
||||||
ds.write(remoteTime);
|
ds.write(remoteTime);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SystemWorldStartPacket::SystemWorldStartPacket() {}
|
SystemWorldStartPacket::SystemWorldStartPacket() {}
|
||||||
|
@ -134,10 +134,10 @@ struct Packet {
|
|||||||
|
|
||||||
virtual PacketType type() const = 0;
|
virtual PacketType type() const = 0;
|
||||||
|
|
||||||
virtual void readLegacy(DataStream& ds);
|
virtual void read(DataStream& ds, NetCompatibilityRules netRules);
|
||||||
virtual void read(DataStream& ds) = 0;
|
virtual void read(DataStream& ds);
|
||||||
virtual void writeLegacy(DataStream& ds) const;
|
virtual void write(DataStream& ds, NetCompatibilityRules netRules) const;
|
||||||
virtual void write(DataStream& ds) const = 0;
|
virtual void write(DataStream& ds) const;
|
||||||
|
|
||||||
virtual void readJson(Json const& json);
|
virtual void readJson(Json const& json);
|
||||||
virtual Json writeJson() const;
|
virtual Json writeJson() const;
|
||||||
@ -172,8 +172,7 @@ struct ProtocolResponsePacket : PacketBase<PacketType::ProtocolResponse> {
|
|||||||
ProtocolResponsePacket(bool allowed = false, Json info = {});
|
ProtocolResponsePacket(bool allowed = false, Json info = {});
|
||||||
|
|
||||||
void read(DataStream& ds) override;
|
void read(DataStream& ds) override;
|
||||||
void writeLegacy(DataStream& ds) const override;
|
void write(DataStream& ds, NetCompatibilityRules netRules) const override;
|
||||||
void write(DataStream& ds) const override;
|
|
||||||
|
|
||||||
bool allowed;
|
bool allowed;
|
||||||
Json info;
|
Json info;
|
||||||
@ -281,10 +280,8 @@ struct PausePacket : PacketBase<PacketType::Pause> {
|
|||||||
PausePacket();
|
PausePacket();
|
||||||
PausePacket(bool pause, float timescale = 1.0f);
|
PausePacket(bool pause, float timescale = 1.0f);
|
||||||
|
|
||||||
void readLegacy(DataStream& ds) override;
|
void read(DataStream& ds, NetCompatibilityRules netRules) override;
|
||||||
void read(DataStream& ds) override;
|
void write(DataStream& ds, NetCompatibilityRules netRules) const override;
|
||||||
void writeLegacy(DataStream& ds) const override;
|
|
||||||
void write(DataStream& ds) const override;
|
|
||||||
|
|
||||||
void readJson(Json const& json) override;
|
void readJson(Json const& json) override;
|
||||||
Json writeJson() const override;
|
Json writeJson() const override;
|
||||||
@ -313,10 +310,8 @@ struct ClientConnectPacket : PacketBase<PacketType::ClientConnect> {
|
|||||||
String playerSpecies, WorldChunks shipChunks, ShipUpgrades shipUpgrades, bool introComplete,
|
String playerSpecies, WorldChunks shipChunks, ShipUpgrades shipUpgrades, bool introComplete,
|
||||||
String account, Json info = {});
|
String account, Json info = {});
|
||||||
|
|
||||||
void readLegacy(DataStream& ds) override;
|
void read(DataStream& ds, NetCompatibilityRules netRules) override;
|
||||||
void read(DataStream& ds) override;
|
void write(DataStream& ds, NetCompatibilityRules netRules) const override;
|
||||||
void writeLegacy(DataStream& ds) const override;
|
|
||||||
void write(DataStream& ds) const override;
|
|
||||||
|
|
||||||
ByteArray assetsDigest;
|
ByteArray assetsDigest;
|
||||||
bool allowAssetsMismatch;
|
bool allowAssetsMismatch;
|
||||||
@ -360,13 +355,14 @@ struct PlayerWarpPacket : PacketBase<PacketType::PlayerWarp> {
|
|||||||
|
|
||||||
struct FlyShipPacket : PacketBase<PacketType::FlyShip> {
|
struct FlyShipPacket : PacketBase<PacketType::FlyShip> {
|
||||||
FlyShipPacket();
|
FlyShipPacket();
|
||||||
FlyShipPacket(Vec3I system, SystemLocation location);
|
FlyShipPacket(Vec3I system, SystemLocation location, Json settings = {});
|
||||||
|
|
||||||
void read(DataStream& ds) override;
|
void read(DataStream& ds, NetCompatibilityRules netRules) override;
|
||||||
void write(DataStream& ds) const override;
|
void write(DataStream& ds, NetCompatibilityRules netRules) const override;
|
||||||
|
|
||||||
Vec3I system;
|
Vec3I system;
|
||||||
SystemLocation location;
|
SystemLocation location;
|
||||||
|
Json settings;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ChatSendPacket : PacketBase<PacketType::ChatSend> {
|
struct ChatSendPacket : PacketBase<PacketType::ChatSend> {
|
||||||
@ -614,10 +610,8 @@ struct PongPacket : PacketBase<PacketType::Pong> {
|
|||||||
PongPacket();
|
PongPacket();
|
||||||
PongPacket(int64_t time);
|
PongPacket(int64_t time);
|
||||||
|
|
||||||
void readLegacy(DataStream& ds) override;
|
void read(DataStream& ds, NetCompatibilityRules netRules) override;
|
||||||
void read(DataStream& ds) override;
|
void write(DataStream& ds, NetCompatibilityRules netRules) const override;
|
||||||
void writeLegacy(DataStream& ds) const override;
|
|
||||||
void write(DataStream& ds) const override;
|
|
||||||
|
|
||||||
int64_t time = 0;
|
int64_t time = 0;
|
||||||
};
|
};
|
||||||
@ -733,10 +727,8 @@ struct PingPacket : PacketBase<PacketType::Ping> {
|
|||||||
PingPacket();
|
PingPacket();
|
||||||
PingPacket(int64_t time);
|
PingPacket(int64_t time);
|
||||||
|
|
||||||
void readLegacy(DataStream& ds) override;
|
void read(DataStream& ds, NetCompatibilityRules netRules) override;
|
||||||
void read(DataStream& ds) override;
|
void write(DataStream& ds, NetCompatibilityRules netRules) const override;
|
||||||
void writeLegacy(DataStream& ds) const override;
|
|
||||||
void write(DataStream& ds) const override;
|
|
||||||
|
|
||||||
int64_t time = 0;
|
int64_t time = 0;
|
||||||
};
|
};
|
||||||
@ -879,10 +871,8 @@ struct StepUpdatePacket : PacketBase<PacketType::StepUpdate> {
|
|||||||
StepUpdatePacket();
|
StepUpdatePacket();
|
||||||
StepUpdatePacket(double remoteTime);
|
StepUpdatePacket(double remoteTime);
|
||||||
|
|
||||||
void readLegacy(DataStream& ds) override;
|
void read(DataStream& ds, NetCompatibilityRules netRules) override;
|
||||||
void read(DataStream& ds) override;
|
void write(DataStream& ds, NetCompatibilityRules netRules) const override;
|
||||||
void writeLegacy(DataStream& ds) const override;
|
|
||||||
void write(DataStream& ds) const override;
|
|
||||||
|
|
||||||
double remoteTime;
|
double remoteTime;
|
||||||
};
|
};
|
||||||
|
@ -13,11 +13,7 @@
|
|||||||
namespace Star {
|
namespace Star {
|
||||||
|
|
||||||
Sky::Sky() {
|
Sky::Sky() {
|
||||||
m_settings = Root::singleton().assets()->json("/sky.config");
|
skyParametersUpdated();
|
||||||
|
|
||||||
m_starFrames = m_settings.queryInt("stars.frames");
|
|
||||||
m_starList = jsonToStringList(m_settings.query("stars.list"));
|
|
||||||
m_hyperStarList = jsonToStringList(m_settings.query("stars.hyperlist"));
|
|
||||||
|
|
||||||
m_netInit = false;
|
m_netInit = false;
|
||||||
|
|
||||||
@ -38,7 +34,7 @@ Sky::Sky() {
|
|||||||
|
|
||||||
Sky::Sky(SkyParameters const& skyParameters, bool inOrbit) : Sky() {
|
Sky::Sky(SkyParameters const& skyParameters, bool inOrbit) : Sky() {
|
||||||
m_skyParameters = skyParameters;
|
m_skyParameters = skyParameters;
|
||||||
m_skyParametersUpdated = true;
|
skyParametersUpdated();
|
||||||
|
|
||||||
if (inOrbit)
|
if (inOrbit)
|
||||||
m_skyType = SkyType::Orbital;
|
m_skyType = SkyType::Orbital;
|
||||||
@ -46,7 +42,7 @@ Sky::Sky(SkyParameters const& skyParameters, bool inOrbit) : Sky() {
|
|||||||
m_skyType = m_skyParameters.skyType;
|
m_skyType = m_skyParameters.skyType;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sky::startFlying(bool enterHyperspace, bool startInWarp) {
|
void Sky::startFlying(bool enterHyperspace, bool startInWarp, Json settings) {
|
||||||
if (startInWarp)
|
if (startInWarp)
|
||||||
m_flyingType = FlyingType::Warp;
|
m_flyingType = FlyingType::Warp;
|
||||||
else
|
else
|
||||||
@ -55,6 +51,10 @@ void Sky::startFlying(bool enterHyperspace, bool startInWarp) {
|
|||||||
m_flyingTimer = 0;
|
m_flyingTimer = 0;
|
||||||
m_enterHyperspace = enterHyperspace;
|
m_enterHyperspace = enterHyperspace;
|
||||||
m_startInWarp = startInWarp;
|
m_startInWarp = startInWarp;
|
||||||
|
if (settings.isType(Json::Type::Object)) {
|
||||||
|
m_skyParameters.settings = settings;
|
||||||
|
skyParametersUpdated();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sky::stopFlyingAt(Maybe<SkyParameters> dest) {
|
void Sky::stopFlyingAt(Maybe<SkyParameters> dest) {
|
||||||
@ -63,7 +63,7 @@ void Sky::stopFlyingAt(Maybe<SkyParameters> dest) {
|
|||||||
|
|
||||||
void Sky::jumpTo(SkyParameters skyParameters) {
|
void Sky::jumpTo(SkyParameters skyParameters) {
|
||||||
m_skyParameters = skyParameters;
|
m_skyParameters = skyParameters;
|
||||||
m_skyParametersUpdated = true;
|
skyParametersUpdated();
|
||||||
}
|
}
|
||||||
|
|
||||||
pair<ByteArray, uint64_t> Sky::writeUpdate(uint64_t fromVersion, NetCompatibilityRules rules) {
|
pair<ByteArray, uint64_t> Sky::writeUpdate(uint64_t fromVersion, NetCompatibilityRules rules) {
|
||||||
@ -531,8 +531,10 @@ void Sky::writeNetStates() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Sky::readNetStates() {
|
void Sky::readNetStates() {
|
||||||
if (m_skyParametersNetState.pullUpdated())
|
if (m_skyParametersNetState.pullUpdated()) {
|
||||||
m_skyParameters = SkyParameters(DataStreamBuffer::deserialize<Json>(m_skyParametersNetState.get()));
|
m_skyParameters = SkyParameters(DataStreamBuffer::deserialize<Json>(m_skyParametersNetState.get()));
|
||||||
|
skyParametersUpdated();
|
||||||
|
}
|
||||||
|
|
||||||
m_skyType = (SkyType)m_skyTypeNetState.get();
|
m_skyType = (SkyType)m_skyTypeNetState.get();
|
||||||
m_time = m_timeNetState.get();
|
m_time = m_timeNetState.get();
|
||||||
@ -651,4 +653,12 @@ float Sky::slowdownTime() const {
|
|||||||
return m_settings.queryFloat("slowdownTime");
|
return m_settings.queryFloat("slowdownTime");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Sky::skyParametersUpdated() {
|
||||||
|
m_skyParametersUpdated = true;
|
||||||
|
m_settings = jsonMerge(Root::singleton().assets()->json("/sky.config"), m_skyParameters.settings);
|
||||||
|
m_starFrames = m_settings.queryInt("stars.frames");
|
||||||
|
m_starList = jsonToStringList(m_settings.query("stars.list"));
|
||||||
|
m_hyperStarList = jsonToStringList(m_settings.query("stars.hyperlist"));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -23,7 +23,7 @@ public:
|
|||||||
Sky(SkyParameters const& skyParameters, bool inOrbit);
|
Sky(SkyParameters const& skyParameters, bool inOrbit);
|
||||||
|
|
||||||
// Controls the space sky "flight" system
|
// Controls the space sky "flight" system
|
||||||
void startFlying(bool enterHyperspace, bool startInWarp);
|
void startFlying(bool enterHyperspace, bool startInWarp, Json settings = {});
|
||||||
// Stops flying animation copying the new pertinant sky data from the given
|
// Stops flying animation copying the new pertinant sky data from the given
|
||||||
// sky, as though the sky as moved to a new world.
|
// sky, as though the sky as moved to a new world.
|
||||||
void stopFlyingAt(Maybe<SkyParameters> SkyParameters);
|
void stopFlyingAt(Maybe<SkyParameters> SkyParameters);
|
||||||
@ -117,6 +117,8 @@ private:
|
|||||||
float speedupTime() const;
|
float speedupTime() const;
|
||||||
float slowdownTime() const;
|
float slowdownTime() const;
|
||||||
|
|
||||||
|
void skyParametersUpdated();
|
||||||
|
|
||||||
Json m_settings;
|
Json m_settings;
|
||||||
SkyParameters m_skyParameters;
|
SkyParameters m_skyParameters;
|
||||||
bool m_skyParametersUpdated;
|
bool m_skyParametersUpdated;
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
|
|
||||||
namespace Star {
|
namespace Star {
|
||||||
|
|
||||||
SkyParameters::SkyParameters() : seed(), skyType(SkyType::Barren), skyColoring(makeRight(Color::Black)) {}
|
SkyParameters::SkyParameters() : seed(), skyType(SkyType::Barren), skyColoring(makeRight(Color::Black)), settings(JsonObject()) {}
|
||||||
|
|
||||||
SkyParameters::SkyParameters(CelestialCoordinate const& coordinate, CelestialDatabasePtr const& celestialDatabase)
|
SkyParameters::SkyParameters(CelestialCoordinate const& coordinate, CelestialDatabasePtr const& celestialDatabase)
|
||||||
: SkyParameters() {
|
: SkyParameters() {
|
||||||
@ -113,6 +113,8 @@ SkyParameters::SkyParameters(Json const& config) : SkyParameters() {
|
|||||||
surfaceLevel = config.optFloat("surfaceLevel");
|
surfaceLevel = config.optFloat("surfaceLevel");
|
||||||
|
|
||||||
sunType = config.getString("sunType", "");
|
sunType = config.getString("sunType", "");
|
||||||
|
|
||||||
|
settings = config.get("settings", JsonObject());
|
||||||
}
|
}
|
||||||
|
|
||||||
Json SkyParameters::toJson() const {
|
Json SkyParameters::toJson() const {
|
||||||
@ -155,6 +157,7 @@ Json SkyParameters::toJson() const {
|
|||||||
{"spaceLevel", jsonFromMaybe<float>(spaceLevel)},
|
{"spaceLevel", jsonFromMaybe<float>(spaceLevel)},
|
||||||
{"surfaceLevel", jsonFromMaybe<float>(surfaceLevel)},
|
{"surfaceLevel", jsonFromMaybe<float>(surfaceLevel)},
|
||||||
{"sunType", sunType},
|
{"sunType", sunType},
|
||||||
|
{"settings", settings}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -170,6 +173,8 @@ void SkyParameters::read(DataStream& ds) {
|
|||||||
ds >> spaceLevel;
|
ds >> spaceLevel;
|
||||||
ds >> surfaceLevel;
|
ds >> surfaceLevel;
|
||||||
ds >> sunType;
|
ds >> sunType;
|
||||||
|
if (ds.streamCompatibilityVersion() >= 3)
|
||||||
|
ds >> settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SkyParameters::write(DataStream& ds) const {
|
void SkyParameters::write(DataStream& ds) const {
|
||||||
@ -184,6 +189,8 @@ void SkyParameters::write(DataStream& ds) const {
|
|||||||
ds << spaceLevel;
|
ds << spaceLevel;
|
||||||
ds << surfaceLevel;
|
ds << surfaceLevel;
|
||||||
ds << sunType;
|
ds << sunType;
|
||||||
|
if (ds.streamCompatibilityVersion() >= 3)
|
||||||
|
ds << settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SkyParameters::readVisitableParameters(VisitableWorldParametersConstPtr visitableParameters) {
|
void SkyParameters::readVisitableParameters(VisitableWorldParametersConstPtr visitableParameters) {
|
||||||
|
@ -45,6 +45,7 @@ struct SkyParameters {
|
|||||||
Maybe<float> spaceLevel;
|
Maybe<float> spaceLevel;
|
||||||
Maybe<float> surfaceLevel;
|
Maybe<float> surfaceLevel;
|
||||||
String sunType;
|
String sunType;
|
||||||
|
Json settings;
|
||||||
};
|
};
|
||||||
|
|
||||||
DataStream& operator>>(DataStream& ds, SkyParameters& sky);
|
DataStream& operator>>(DataStream& ds, SkyParameters& sky);
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
namespace Star {
|
namespace Star {
|
||||||
|
|
||||||
StringList SkyRenderData::starTypes() const {
|
StringList const& SkyRenderData::starTypes() const {
|
||||||
if (type == SkyType::Warp)
|
if (type == SkyType::Warp)
|
||||||
return hyperStarList;
|
return hyperStarList;
|
||||||
else
|
else
|
||||||
|
@ -32,7 +32,7 @@ struct SkyRenderData {
|
|||||||
Color bottomRectColor;
|
Color bottomRectColor;
|
||||||
Color flashColor;
|
Color flashColor;
|
||||||
|
|
||||||
StringList starTypes() const;
|
StringList const& starTypes() const;
|
||||||
|
|
||||||
// Star and orbiter positions here are in view space, from (0, 0) to viewSize
|
// Star and orbiter positions here are in view space, from (0, 0) to viewSize
|
||||||
|
|
||||||
|
@ -124,7 +124,7 @@ Maybe<String> UniverseClient::connect(UniverseConnection connection, bool allowA
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
connection.packetSocket().setLegacy(legacyServer);
|
connection.packetSocket().setNetRules(compatibilityRules);
|
||||||
auto clientConnect = make_shared<ClientConnectPacket>(Root::singleton().assets()->digest(), allowAssetsMismatch, m_mainPlayer->uuid(), m_mainPlayer->name(),
|
auto clientConnect = make_shared<ClientConnectPacket>(Root::singleton().assets()->digest(), allowAssetsMismatch, m_mainPlayer->uuid(), m_mainPlayer->name(),
|
||||||
m_mainPlayer->species(), m_playerStorage->loadShipData(m_mainPlayer->uuid()), m_mainPlayer->shipUpgrades(),
|
m_mainPlayer->species(), m_playerStorage->loadShipData(m_mainPlayer->uuid()), m_mainPlayer->shipUpgrades(),
|
||||||
m_mainPlayer->log()->introComplete(), account);
|
m_mainPlayer->log()->introComplete(), account);
|
||||||
@ -426,8 +426,8 @@ void UniverseClient::warpPlayer(WarpAction const& warpAction, bool animate, Stri
|
|||||||
m_pendingWarp = warpAction;
|
m_pendingWarp = warpAction;
|
||||||
}
|
}
|
||||||
|
|
||||||
void UniverseClient::flyShip(Vec3I const& system, SystemLocation const& destination) {
|
void UniverseClient::flyShip(Vec3I const& system, SystemLocation const& destination, Json const& settings) {
|
||||||
m_connection->pushSingle(make_shared<FlyShipPacket>(system, destination));
|
m_connection->pushSingle(make_shared<FlyShipPacket>(system, destination, settings));
|
||||||
}
|
}
|
||||||
|
|
||||||
CelestialDatabasePtr UniverseClient::celestialDatabase() const {
|
CelestialDatabasePtr UniverseClient::celestialDatabase() const {
|
||||||
|
@ -61,7 +61,7 @@ public:
|
|||||||
bool canTeleport() const;
|
bool canTeleport() const;
|
||||||
|
|
||||||
void warpPlayer(WarpAction const& warpAction, bool animate = true, String const& animationType = "default", bool deploy = false);
|
void warpPlayer(WarpAction const& warpAction, bool animate = true, String const& animationType = "default", bool deploy = false);
|
||||||
void flyShip(Vec3I const& system, SystemLocation const& destination);
|
void flyShip(Vec3I const& system, SystemLocation const& destination, Json const& settings = {});
|
||||||
|
|
||||||
CelestialDatabasePtr celestialDatabase() const;
|
CelestialDatabasePtr celestialDatabase() const;
|
||||||
|
|
||||||
|
@ -288,7 +288,7 @@ void UniverseServer::clientWarpPlayer(ConnectionId clientId, WarpAction action,
|
|||||||
m_pendingPlayerWarps[clientId] = pair<WarpAction, bool>(std::move(action), std::move(deploy));
|
m_pendingPlayerWarps[clientId] = pair<WarpAction, bool>(std::move(action), std::move(deploy));
|
||||||
}
|
}
|
||||||
|
|
||||||
void UniverseServer::clientFlyShip(ConnectionId clientId, Vec3I const& system, SystemLocation const& location) {
|
void UniverseServer::clientFlyShip(ConnectionId clientId, Vec3I const& system, SystemLocation const& location, Json const& settings) {
|
||||||
RecursiveMutexLocker locker(m_mainLock);
|
RecursiveMutexLocker locker(m_mainLock);
|
||||||
ReadLocker clientsLocker(m_clientsLock);
|
ReadLocker clientsLocker(m_clientsLock);
|
||||||
|
|
||||||
@ -300,7 +300,7 @@ void UniverseServer::clientFlyShip(ConnectionId clientId, Vec3I const& system, S
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (system == Vec3I()) {
|
if (system == Vec3I()) {
|
||||||
m_pendingFlights.set(clientId, {Vec3I(), {}}); // find starter world
|
m_pendingFlights.set(clientId, make_tuple(Vec3I(), SystemLocation(), settings)); // find starter world
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -315,7 +315,7 @@ void UniverseServer::clientFlyShip(ConnectionId clientId, Vec3I const& system, S
|
|||||||
|
|
||||||
// don't switch systems while already flying
|
// don't switch systems while already flying
|
||||||
if (!m_pendingArrivals.contains(clientId) || sameSystem)
|
if (!m_pendingArrivals.contains(clientId) || sameSystem)
|
||||||
m_pendingFlights.set(clientId, {system, location});
|
m_pendingFlights.set(clientId, make_tuple(system, location, settings));
|
||||||
}
|
}
|
||||||
|
|
||||||
WorldId UniverseServer::clientWorld(ConnectionId clientId) const {
|
WorldId UniverseServer::clientWorld(ConnectionId clientId) const {
|
||||||
@ -892,10 +892,11 @@ void UniverseServer::flyShips() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
eraseWhere(m_pendingFlights, [this](pair<ConnectionId const, pair<Vec3I, SystemLocation>> const& p) {
|
eraseWhere(m_pendingFlights, [this](pair<ConnectionId const, tuple<Vec3I, SystemLocation, Json>> const& p) {
|
||||||
ConnectionId clientId = p.first;
|
ConnectionId clientId = p.first;
|
||||||
Vec3I system = p.second.first;
|
Vec3I system = get<0>(p.second);
|
||||||
SystemLocation location = p.second.second;
|
SystemLocation location = get<1>(p.second);
|
||||||
|
Json settings = get<2>(p.second);
|
||||||
|
|
||||||
auto clientContext = m_clients.value(clientId);
|
auto clientContext = m_clients.value(clientId);
|
||||||
if (!clientContext)
|
if (!clientContext)
|
||||||
@ -935,7 +936,7 @@ void UniverseServer::flyShips() {
|
|||||||
clientContext->setSystemWorld({});
|
clientContext->setSystemWorld({});
|
||||||
|
|
||||||
if (location)
|
if (location)
|
||||||
m_queuedFlights.set(clientId, {{system, location}, {}});
|
m_queuedFlights.set(clientId, {make_tuple(system, location, settings), {}});
|
||||||
|
|
||||||
destination = CelestialCoordinate(system);
|
destination = CelestialCoordinate(system);
|
||||||
}
|
}
|
||||||
@ -946,8 +947,8 @@ void UniverseServer::flyShips() {
|
|||||||
Logger::info("Flying ship for player {} to {}", clientId, destination);
|
Logger::info("Flying ship for player {} to {}", clientId, destination);
|
||||||
|
|
||||||
bool startInWarp = system == Vec3I();
|
bool startInWarp = system == Vec3I();
|
||||||
clientShip->executeAction([interstellar, startInWarp](WorldServerThread*, WorldServer* worldServer) {
|
clientShip->executeAction([interstellar, startInWarp, settings](WorldServerThread*, WorldServer* worldServer) {
|
||||||
worldServer->startFlyingSky(interstellar, startInWarp);
|
worldServer->startFlyingSky(interstellar, startInWarp, settings);
|
||||||
});
|
});
|
||||||
|
|
||||||
clientContext->setShipCoordinate(CelestialCoordinate(system));
|
clientContext->setShipCoordinate(CelestialCoordinate(system));
|
||||||
@ -1507,7 +1508,7 @@ void UniverseServer::packetsReceived(UniverseConnectionServer*, ConnectionId cli
|
|||||||
clientWarpPlayer(clientId, warpAction->action, warpAction->deploy);
|
clientWarpPlayer(clientId, warpAction->action, warpAction->deploy);
|
||||||
|
|
||||||
} else if (auto flyShip = as<FlyShipPacket>(packet)) {
|
} else if (auto flyShip = as<FlyShipPacket>(packet)) {
|
||||||
clientFlyShip(clientId, flyShip->system, flyShip->location);
|
clientFlyShip(clientId, flyShip->system, flyShip->location, flyShip->settings);
|
||||||
|
|
||||||
} else if (auto chatSend = as<ChatSendPacket>(packet)) {
|
} else if (auto chatSend = as<ChatSendPacket>(packet)) {
|
||||||
RecursiveMutexLocker locker(m_mainLock);
|
RecursiveMutexLocker locker(m_mainLock);
|
||||||
@ -1554,7 +1555,8 @@ void UniverseServer::acceptConnection(UniverseConnection connection, Maybe<HostA
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool legacyClient = protocolRequest->compressionMode() != PacketCompressionMode::Enabled;
|
bool legacyClient = protocolRequest->compressionMode() != PacketCompressionMode::Enabled;
|
||||||
connection.packetSocket().setLegacy(legacyClient);
|
if (legacyClient)
|
||||||
|
connection.packetSocket().setNetRules(LegacyVersion);
|
||||||
|
|
||||||
auto protocolResponse = make_shared<ProtocolResponsePacket>();
|
auto protocolResponse = make_shared<ProtocolResponsePacket>();
|
||||||
protocolResponse->setCompressionMode(PacketCompressionMode::Enabled); // Signal that we're OpenStarbound
|
protocolResponse->setCompressionMode(PacketCompressionMode::Enabled); // Signal that we're OpenStarbound
|
||||||
@ -1681,8 +1683,9 @@ void UniverseServer::acceptConnection(UniverseConnection connection, Maybe<HostA
|
|||||||
if (Json brand = info.get("brand", "custom"))
|
if (Json brand = info.get("brand", "custom"))
|
||||||
connectionLog += strf(" ({} client)", brand.toString());
|
connectionLog += strf(" ({} client)", brand.toString());
|
||||||
if (info.getBool("legacy", false))
|
if (info.getBool("legacy", false))
|
||||||
connection.packetSocket().setLegacy(legacyClient = true);
|
netRules.setVersion(LegacyVersion);
|
||||||
}
|
}
|
||||||
|
connection.packetSocket().setNetRules(netRules);
|
||||||
Logger::log(LogLevel::Info, connectionLog.utf8Ptr());
|
Logger::log(LogLevel::Info, connectionLog.utf8Ptr());
|
||||||
|
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ public:
|
|||||||
RpcThreadPromise<Json> sendWorldMessage(WorldId const& worldId, String const& message, JsonArray const& args = {});
|
RpcThreadPromise<Json> sendWorldMessage(WorldId const& worldId, String const& message, JsonArray const& args = {});
|
||||||
|
|
||||||
void clientWarpPlayer(ConnectionId clientId, WarpAction action, bool deploy = false);
|
void clientWarpPlayer(ConnectionId clientId, WarpAction action, bool deploy = false);
|
||||||
void clientFlyShip(ConnectionId clientId, Vec3I const& system, SystemLocation const& location);
|
void clientFlyShip(ConnectionId clientId, Vec3I const& system, SystemLocation const& location, Json const& settings = {});
|
||||||
WorldId clientWorld(ConnectionId clientId) const;
|
WorldId clientWorld(ConnectionId clientId) const;
|
||||||
CelestialCoordinate clientShipCoordinate(ConnectionId clientId) const;
|
CelestialCoordinate clientShipCoordinate(ConnectionId clientId) const;
|
||||||
|
|
||||||
@ -243,8 +243,8 @@ private:
|
|||||||
TeamManagerPtr m_teamManager;
|
TeamManagerPtr m_teamManager;
|
||||||
|
|
||||||
HashMap<ConnectionId, pair<WarpAction, bool>> m_pendingPlayerWarps;
|
HashMap<ConnectionId, pair<WarpAction, bool>> m_pendingPlayerWarps;
|
||||||
HashMap<ConnectionId, pair<pair<Vec3I, SystemLocation>, Maybe<double>>> m_queuedFlights;
|
HashMap<ConnectionId, pair<tuple<Vec3I, SystemLocation, Json>, Maybe<double>>> m_queuedFlights;
|
||||||
HashMap<ConnectionId, pair<Vec3I, SystemLocation>> m_pendingFlights;
|
HashMap<ConnectionId, tuple<Vec3I, SystemLocation, Json>> m_pendingFlights;
|
||||||
HashMap<ConnectionId, CelestialCoordinate> m_pendingArrivals;
|
HashMap<ConnectionId, CelestialCoordinate> m_pendingArrivals;
|
||||||
HashMap<ConnectionId, String> m_pendingDisconnections;
|
HashMap<ConnectionId, String> m_pendingDisconnections;
|
||||||
HashMap<ConnectionId, List<WorkerPoolPromise<CelestialResponse>>> m_pendingCelestialRequests;
|
HashMap<ConnectionId, List<WorkerPoolPromise<CelestialResponse>>> m_pendingCelestialRequests;
|
||||||
|
@ -853,6 +853,10 @@ void WorldServer::setSpawningEnabled(bool spawningEnabled) {
|
|||||||
m_spawner.setActive(spawningEnabled);
|
m_spawner.setActive(spawningEnabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void WorldServer::setPropertyListener(String const& propertyName, WorldPropertyListener listener) {
|
||||||
|
m_worldPropertyListeners[propertyName] = listener;
|
||||||
|
}
|
||||||
|
|
||||||
TileModificationList WorldServer::validTileModifications(TileModificationList const& modificationList, bool allowEntityOverlap) const {
|
TileModificationList WorldServer::validTileModifications(TileModificationList const& modificationList, bool allowEntityOverlap) const {
|
||||||
return WorldImpl::splitTileModifications(m_entityMap, modificationList, allowEntityOverlap, m_tileGetterFunction, [this](Vec2I pos, TileModification) {
|
return WorldImpl::splitTileModifications(m_entityMap, modificationList, allowEntityOverlap, m_tileGetterFunction, [this](Vec2I pos, TileModification) {
|
||||||
return !isTileProtected(pos);
|
return !isTileProtected(pos);
|
||||||
@ -2202,14 +2206,17 @@ void WorldServer::setProperty(String const& propertyName, Json const& property)
|
|||||||
for (auto const& pair : m_clientInfo)
|
for (auto const& pair : m_clientInfo)
|
||||||
pair.second->outgoingPackets.append(make_shared<UpdateWorldPropertiesPacket>(JsonObject{ {propertyName, property} }));
|
pair.second->outgoingPackets.append(make_shared<UpdateWorldPropertiesPacket>(JsonObject{ {propertyName, property} }));
|
||||||
}
|
}
|
||||||
|
auto listener = m_worldPropertyListeners.find(propertyName);
|
||||||
|
if (listener != m_worldPropertyListeners.end())
|
||||||
|
listener->second(property);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WorldServer::timer(float delay, WorldAction worldAction) {
|
void WorldServer::timer(float delay, WorldAction worldAction) {
|
||||||
m_timers.append({delay, worldAction});
|
m_timers.append({delay, worldAction});
|
||||||
}
|
}
|
||||||
|
|
||||||
void WorldServer::startFlyingSky(bool enterHyperspace, bool startInWarp) {
|
void WorldServer::startFlyingSky(bool enterHyperspace, bool startInWarp, Json settings) {
|
||||||
m_sky->startFlying(enterHyperspace, startInWarp);
|
m_sky->startFlying(enterHyperspace, startInWarp, settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WorldServer::stopFlyingSkyAt(SkyParameters const& destination) {
|
void WorldServer::stopFlyingSkyAt(SkyParameters const& destination) {
|
||||||
|
@ -50,6 +50,7 @@ class WorldServer : public World {
|
|||||||
public:
|
public:
|
||||||
typedef LuaMessageHandlingComponent<LuaUpdatableComponent<LuaWorldComponent<LuaBaseComponent>>> ScriptComponent;
|
typedef LuaMessageHandlingComponent<LuaUpdatableComponent<LuaWorldComponent<LuaBaseComponent>>> ScriptComponent;
|
||||||
typedef shared_ptr<ScriptComponent> ScriptComponentPtr;
|
typedef shared_ptr<ScriptComponent> ScriptComponentPtr;
|
||||||
|
typedef function<void(Json const&)> WorldPropertyListener;
|
||||||
|
|
||||||
// Create a new world with the given template, writing new storage file.
|
// Create a new world with the given template, writing new storage file.
|
||||||
WorldServer(WorldTemplatePtr const& worldTemplate, IODevicePtr storage);
|
WorldServer(WorldTemplatePtr const& worldTemplate, IODevicePtr storage);
|
||||||
@ -108,7 +109,7 @@ public:
|
|||||||
|
|
||||||
Maybe<Json> receiveMessage(ConnectionId fromConnection, String const& message, JsonArray const& args);
|
Maybe<Json> receiveMessage(ConnectionId fromConnection, String const& message, JsonArray const& args);
|
||||||
|
|
||||||
void startFlyingSky(bool enterHyperspace, bool startInWarp);
|
void startFlyingSky(bool enterHyperspace, bool startInWarp, Json settings = {});
|
||||||
void stopFlyingSkyAt(SkyParameters const& destination);
|
void stopFlyingSkyAt(SkyParameters const& destination);
|
||||||
void setOrbitalSky(SkyParameters const& destination);
|
void setOrbitalSky(SkyParameters const& destination);
|
||||||
|
|
||||||
@ -231,6 +232,8 @@ public:
|
|||||||
|
|
||||||
void setSpawningEnabled(bool spawningEnabled);
|
void setSpawningEnabled(bool spawningEnabled);
|
||||||
|
|
||||||
|
void setPropertyListener(String const& propertyName, WorldPropertyListener listener);
|
||||||
|
|
||||||
// Write all active sectors to disk without unloading them
|
// Write all active sectors to disk without unloading them
|
||||||
void sync();
|
void sync();
|
||||||
// Copy full world to in memory representation
|
// Copy full world to in memory representation
|
||||||
@ -347,6 +350,7 @@ private:
|
|||||||
bool m_adjustPlayerStart;
|
bool m_adjustPlayerStart;
|
||||||
bool m_respawnInWorld;
|
bool m_respawnInWorld;
|
||||||
JsonObject m_worldProperties;
|
JsonObject m_worldProperties;
|
||||||
|
StringMap<WorldPropertyListener> m_worldPropertyListeners;
|
||||||
|
|
||||||
Maybe<pair<String, String>> m_newPlanetType;
|
Maybe<pair<String, String>> m_newPlanetType;
|
||||||
|
|
||||||
|
@ -30,9 +30,9 @@ LuaCallbacks LuaBindings::makeCelestialCallbacks(UniverseClient* client) {
|
|||||||
return client->currentSky()->inHyperspace();
|
return client->currentSky()->inHyperspace();
|
||||||
});
|
});
|
||||||
|
|
||||||
callbacks.registerCallback("flyShip", [client,systemWorld](Vec3I const& system, Json const& destination) {
|
callbacks.registerCallback("flyShip", [client,systemWorld](Vec3I const& system, Json const& destination, Json const& settings) {
|
||||||
auto location = jsonToSystemLocation(destination);
|
auto location = jsonToSystemLocation(destination);
|
||||||
client->flyShip(system, location);
|
client->flyShip(system, location, settings);
|
||||||
});
|
});
|
||||||
callbacks.registerCallback("flying", [systemWorld]() {
|
callbacks.registerCallback("flying", [systemWorld]() {
|
||||||
return systemWorld->flying();
|
return systemWorld->flying();
|
||||||
|
@ -39,9 +39,6 @@ void EnvironmentPainter::update(float dt) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void EnvironmentPainter::renderStars(float pixelRatio, Vec2F const& screenSize, SkyRenderData const& sky) {
|
void EnvironmentPainter::renderStars(float pixelRatio, Vec2F const& screenSize, SkyRenderData const& sky) {
|
||||||
if (!sky.settings)
|
|
||||||
return;
|
|
||||||
|
|
||||||
float nightSkyAlpha = 1.0f - min(sky.dayLevel, sky.skyAlpha);
|
float nightSkyAlpha = 1.0f - min(sky.dayLevel, sky.skyAlpha);
|
||||||
if (nightSkyAlpha <= 0.0f)
|
if (nightSkyAlpha <= 0.0f)
|
||||||
return;
|
return;
|
||||||
@ -58,6 +55,9 @@ void EnvironmentPainter::renderStars(float pixelRatio, Vec2F const& screenSize,
|
|||||||
setupStars(sky);
|
setupStars(sky);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!sky.settings || sky.starFrames == 0 || sky.starTypes().empty())
|
||||||
|
return;
|
||||||
|
|
||||||
float screenBuffer = sky.settings.queryFloat("stars.screenBuffer");
|
float screenBuffer = sky.settings.queryFloat("stars.screenBuffer");
|
||||||
|
|
||||||
PolyF field = PolyF(RectF::withSize(viewMin, Vec2F(viewSize)).padded(screenBuffer));
|
PolyF field = PolyF(RectF::withSize(viewMin, Vec2F(viewSize)).padded(screenBuffer));
|
||||||
@ -85,7 +85,7 @@ void EnvironmentPainter::renderStars(float pixelRatio, Vec2F const& screenSize,
|
|||||||
Vec2F screenPos = transform.transformVec2(star.first);
|
Vec2F screenPos = transform.transformVec2(star.first);
|
||||||
if (viewRect.contains(screenPos)) {
|
if (viewRect.contains(screenPos)) {
|
||||||
size_t starFrame = (size_t)(sky.epochTime + star.second.second) % sky.starFrames;
|
size_t starFrame = (size_t)(sky.epochTime + star.second.second) % sky.starFrames;
|
||||||
auto const& texture = m_starTextures[star.second.first * sky.starFrames + starFrame];
|
if (auto const& texture = m_starTextures[star.second.first * sky.starFrames + starFrame])
|
||||||
primitives.emplace_back(std::in_place_type_t<RenderQuad>(), texture, screenPos * pixelRatio - Vec2F(texture->size()) / 2, 1.0, color, 0.0f);
|
primitives.emplace_back(std::in_place_type_t<RenderQuad>(), texture, screenPos * pixelRatio - Vec2F(texture->size()) / 2, 1.0, color, 0.0f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -455,7 +455,7 @@ void EnvironmentPainter::setupStars(SkyRenderData const& sky) {
|
|||||||
if (!sky.settings)
|
if (!sky.settings)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
StringList starTypes = sky.starTypes();
|
StringList const& starTypes = sky.starTypes();
|
||||||
size_t starTypesSize = starTypes.size();
|
size_t starTypesSize = starTypes.size();
|
||||||
|
|
||||||
m_starTextures.resize(starTypesSize * sky.starFrames);
|
m_starTextures.resize(starTypesSize * sky.starFrames);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user