mirror of
https://github.com/EQEmu/Server.git
synced 2026-04-02 16:32:26 +00:00
- License was intended to be GPLv3 per earlier commit of GPLv3 LICENSE FILE - This is confirmed by the inclusion of libraries that are incompatible with GPLv2 - This is also confirmed by KLS and the agreement of KLS's predecessors - Added GPLv3 license headers to the compilable source files - Removed Folly licensing in strings.h since the string functions do not match the Folly functions and are standard functions - this must have been left over from previous implementations - Removed individual contributor license headers since the project has been under the "developer" mantle for many years - Removed comments on files that were previously automatically generated since they've been manually modified multiple times and there are no automatic scripts referencing them (removed in 2023)
130 lines
3.4 KiB
C++
130 lines
3.4 KiB
C++
/* EQEmu: EQEmulator
|
|
|
|
Copyright (C) 2001-2026 EQEmu Development Team
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#pragma once
|
|
|
|
#include "common/types.h"
|
|
|
|
#include <cstring>
|
|
#include <sstream>
|
|
#include <string>
|
|
#include <type_traits>
|
|
|
|
|
|
namespace EQ
|
|
{
|
|
class MemoryBuffer {
|
|
public:
|
|
MemoryBuffer();
|
|
MemoryBuffer(size_t sz);
|
|
MemoryBuffer(const MemoryBuffer &other);
|
|
MemoryBuffer(MemoryBuffer &&other);
|
|
MemoryBuffer& operator=(const MemoryBuffer &other);
|
|
MemoryBuffer& operator=(MemoryBuffer &&other);
|
|
MemoryBuffer& operator+=(const MemoryBuffer &rhs);
|
|
friend MemoryBuffer operator+(MemoryBuffer lhs, const MemoryBuffer& rhs) { return lhs += rhs; }
|
|
~MemoryBuffer();
|
|
|
|
uchar& operator[](size_t pos);
|
|
const uchar& operator[](size_t pos) const;
|
|
|
|
template<typename T>
|
|
operator T*() {
|
|
return reinterpret_cast<T*>(buffer_);
|
|
}
|
|
|
|
template<typename T>
|
|
operator T*() const {
|
|
return reinterpret_cast<T*>(buffer_);
|
|
}
|
|
|
|
operator bool() { return buffer_ != nullptr; }
|
|
operator bool() const { return buffer_ != nullptr; }
|
|
|
|
bool Empty();
|
|
bool Empty() const;
|
|
size_t Size();
|
|
size_t Size() const;
|
|
size_t Capacity();
|
|
size_t Capacity() const;
|
|
|
|
void Resize(size_t sz);
|
|
void Clear();
|
|
void Zero();
|
|
|
|
template<typename T>
|
|
void Write(T val) {
|
|
static_assert(std::is_standard_layout<T>::value, "MemoryBuffer::Write<T>(T val) only works on pod and string types.");
|
|
Write((const char*)&val, sizeof(T));
|
|
}
|
|
|
|
template<typename T>
|
|
T Read() {
|
|
static_assert(std::is_standard_layout<T>::value, "MemoryBuffer::Read<T>() only works on pod and string types.");
|
|
T temp;
|
|
Read((uchar*)&temp, sizeof(T));
|
|
return temp;
|
|
}
|
|
|
|
void Write(const std::string &val) {
|
|
Write(val.c_str(), val.length());
|
|
Write((uint8)0);
|
|
}
|
|
|
|
void Write(const char *val) {
|
|
size_t len = strlen(val);
|
|
Write(val, len);
|
|
Write((uint8)0);
|
|
}
|
|
|
|
std::string ReadString() {
|
|
std::string ret;
|
|
size_t len = strlen((const char*)&buffer_[read_pos_]);
|
|
ret.resize(len);
|
|
memcpy(&ret[0], &buffer_[read_pos_], len);
|
|
read_pos_ += len + 1;
|
|
return ret;
|
|
}
|
|
|
|
void Write(const char *val, size_t len);
|
|
void Read(uchar *buf, size_t len);
|
|
void Read(char *str);
|
|
|
|
inline size_t GetWritePosition() { return write_pos_; }
|
|
inline void SetWritePosition(size_t wp) { write_pos_ = wp; }
|
|
inline void WriteSkipBytes(size_t skip) { write_pos_ += skip; }
|
|
inline size_t GetReadPosition() { return read_pos_; }
|
|
inline void SetReadPosition(size_t rp) { read_pos_ = rp; }
|
|
inline void ReadSkipBytes(size_t skip) { read_pos_ += skip; }
|
|
|
|
private:
|
|
uchar *buffer_;
|
|
size_t size_;
|
|
size_t capacity_;
|
|
size_t write_pos_;
|
|
size_t read_pos_;
|
|
};
|
|
|
|
class OutBuffer : public std::stringstream {
|
|
public:
|
|
inline size_t size() { return static_cast<size_t>(tellp()); }
|
|
void overwrite(OutBuffer::pos_type position, const char *_Str, std::streamsize _Count);
|
|
uchar* detach();
|
|
};
|
|
|
|
} /*EQEmu*/
|