mirror of
https://github.com/DarkflameUniverse/DarkflameServer.git
synced 2025-01-24 21:57:02 +00:00
5942182486
* Logger: Rename logger to Logger from dLogger * Logger: Add compile time filename Fix include issues Add writers Add macros Add macro to force compilation * Logger: Replace calls with macros Allows for filename and line number to be logged * Logger: Add comments and remove extra define Logger: Replace with unique_ptr also flush console at exit. regular file writer should be flushed on file close. Logger: Remove constexpr on variable * Logger: Simplify code * Update Logger.cpp
75 lines
2.0 KiB
C++
75 lines
2.0 KiB
C++
#include "PacketUtils.h"
|
|
#include <vector>
|
|
#include <fstream>
|
|
#include "Logger.h"
|
|
#include "Game.h"
|
|
|
|
uint16_t PacketUtils::ReadU16(uint32_t startLoc, Packet* packet) {
|
|
if (startLoc + 2 > packet->length) return 0;
|
|
|
|
std::vector<unsigned char> t;
|
|
for (uint32_t i = startLoc; i < startLoc + 2; i++) t.push_back(packet->data[i]);
|
|
return *(uint16_t*)t.data();
|
|
}
|
|
|
|
uint32_t PacketUtils::ReadU32(uint32_t startLoc, Packet* packet) {
|
|
if (startLoc + 4 > packet->length) return 0;
|
|
|
|
std::vector<unsigned char> t;
|
|
for (uint32_t i = startLoc; i < startLoc + 4; i++) {
|
|
t.push_back(packet->data[i]);
|
|
}
|
|
return *(uint32_t*)t.data();
|
|
}
|
|
|
|
uint64_t PacketUtils::ReadU64(uint32_t startLoc, Packet* packet) {
|
|
if (startLoc + 8 > packet->length) return 0;
|
|
|
|
std::vector<unsigned char> t;
|
|
for (uint32_t i = startLoc; i < startLoc + 8; i++) t.push_back(packet->data[i]);
|
|
return *(uint64_t*)t.data();
|
|
}
|
|
|
|
int64_t PacketUtils::ReadS64(uint32_t startLoc, Packet* packet) {
|
|
if (startLoc + 8 > packet->length) return 0;
|
|
|
|
std::vector<unsigned char> t;
|
|
for (size_t i = startLoc; i < startLoc + 8; i++) t.push_back(packet->data[i]);
|
|
return *(int64_t*)t.data();
|
|
}
|
|
|
|
std::string PacketUtils::ReadString(uint32_t startLoc, Packet* packet, bool wide, uint32_t maxLen) {
|
|
std::string readString = "";
|
|
|
|
if (wide) maxLen *= 2;
|
|
|
|
if (packet->length > startLoc) {
|
|
uint32_t i = 0;
|
|
while (packet->data[startLoc + i] != '\0' && packet->length > (uint32_t)(startLoc + i) && maxLen > i) {
|
|
readString.push_back(packet->data[startLoc + i]);
|
|
|
|
if (wide) {
|
|
i += 2; // Wide-char string
|
|
} else {
|
|
i++; // Regular string
|
|
}
|
|
}
|
|
}
|
|
|
|
return readString;
|
|
}
|
|
|
|
//! Saves a packet to the filesystem
|
|
void PacketUtils::SavePacket(const std::string& filename, const char* data, size_t length) {
|
|
//If we don't log to the console, don't save the bin files either. This takes up a lot of time.
|
|
if (!Game::logger->GetLogToConsole()) return;
|
|
|
|
std::string path = "packets/" + filename;
|
|
|
|
std::ofstream file(path, std::ios::binary);
|
|
if (!file.is_open()) return;
|
|
|
|
file.write(data, length);
|
|
file.close();
|
|
}
|