6#include <initializer_list>
21template <
typename List>
24 friend class NBT_Reader;
25 friend class NBT_Writer;
26 friend class NBT_Helper;
55 template<
typename... Args>
61 NBT_List(std::initializer_list<typename List::value_type> init) : List(init)
84 List::operator=(std::move(_Move));
93 List::operator=(_Copy);
109 return (
const List &)*
this == (
const List &)_Right;
117 return (
const List &)*
this != (
const List &)_Right;
125 return (
const List &)*this <=> (
const List &)_Right;
140 using List::operator[];
152 typename List::value_type &
Get(
const typename List::size_type &szPos)
154 return List::at(szPos);
161 const typename List::value_type &
Get(
const typename List::size_type &szPos)
const
163 return List::at(szPos);
169 typename List::value_type *
Has(
const typename List::size_type &szPos)
noexcept
171 return szPos < List::size()
172 ? &List::operator[](szPos)
179 const typename List::value_type *
Has(
const typename List::size_type &szPos)
const noexcept
181 return szPos < List::size()
182 ? &List::operator[](szPos)
189 typename List::value_type &
Front(
void)
noexcept
191 return List::front();
197 const typename List::value_type &
Front(
void)
const noexcept
199 return List::front();
205 typename List::value_type &
Back(
void)
noexcept
213 const typename List::value_type &
Back(
void)
const noexcept
230 template <
typename V>
231 typename List::value_type &
Add(
typename List::size_type szPos, V &&vTagVal)
233 return *List::emplace(List::begin() + szPos, std::forward<V>(vTagVal));
240 template <
typename V>
243 return *List::emplace(List::begin(), std::forward<V>(vTagVal));
250 template <
typename V>
251 typename List::value_type &
AddBack(V &&vTagVal)
253 return List::emplace_back(std::forward<V>(vTagVal));
262 template <
typename V>
263 typename List::value_type &
Set(
typename List::size_type szPos, V &&vTagVal)
265 return List::operator[](szPos) = std::forward<V>(vTagVal);
270 void Remove(
typename List::size_type szPos)
272 List::erase(List::begin() + szPos);
284 void Resize(
typename List::size_type szNewSize)
286 return List::resize(szNewSize);
292 void Resize(
typename List::size_type szNewSize,
const typename List::value_type &value)
294 return List::resize(szNewSize, value);
301 List::insert(List::end(), _Copy.begin(), _Copy.end());
308 List::insert(List::end(), std::make_move_iterator(_Move.begin()), std::make_move_iterator(_Move.end()));
315 typename List::iterator
Insert(
typename List::const_iterator itPos,
const typename List::value_type &value)
317 return List::insert(itPos, value);
324 typename List::iterator
Insert(
typename List::const_iterator itPos,
typename List::value_type &&value)
326 return List::insert(itPos, std::move(value));
334 typename List::iterator
Insert(
typename List::const_iterator itPos,
typename List::size_type szCount,
const typename List::value_type &value)
336 return List::insert(itPos, szCount, value);
344 template<
typename InputIt>
345 typename List::iterator
Insert(
typename List::const_iterator itPos, InputIt itFirst, InputIt itLast)
347 return List::insert(itPos, itFirst, itLast);
354 typename List::iterator
Insert(
typename List::const_iterator itPos, std::initializer_list<typename List::value_type> ilistValue)
356 return List::insert(itPos, ilistValue);
365 return List::empty();
370 typename List::size_type
Size(
void)
const noexcept
377 void Reserve(
typename List::size_type szNewCap)
379 return List::reserve(szNewCap);
385 return List::shrink_to_fit();
392 bool Contains(
const typename List::value_type &tValue)
const noexcept
394 return std::find(List::begin(), List::end(), tValue) != List::end();
402 template<
typename Predicate>
405 return std::find_if(List::begin(), List::end(), pred) != List::end();
411#define TYPE_GET_FUNC(type)\
419const typename NBT_Type::type &Get##type(const typename List::size_type &szPos) const\
421 return List::at(szPos).Get##type();\
431typename NBT_Type::type &Get##type(const typename List::size_type &szPos)\
433 return List::at(szPos).Get##type();\
441const typename NBT_Type::type *Has##type(const typename List::size_type &szPos) const noexcept\
443 auto *p = Has(szPos);\
444 return p != NULL && p->Is##type()\
454typename NBT_Type::type *Has##type(const typename List::size_type &szPos) noexcept\
456 auto *p = Has(szPos);\
457 return p != NULL && p->Is##type()\
468const typename NBT_Type::type &Front##type(void) const\
470 return List::front().Get##type(); \
479typename NBT_Type::type &Front##type(void)\
481 return List::front().Get##type(); \
489const typename NBT_Type::type &Back##type(void) const\
491 return List::back().Get##type();\
500typename NBT_Type::type &Back##type(void)\
502 return List::back().Get##type();\
535#define TYPE_PUT_FUNC(type)\
542typename List::value_type &Add##type(typename List::size_type szPos, const typename NBT_Type::type &vTagVal)\
544 return Add(szPos, vTagVal);\
554typename List::value_type & Add##type(typename List::size_type szPos, typename NBT_Type::type &&vTagVal)\
556 return Add(szPos, std::move(vTagVal));\
565typename List::value_type &AddFront##type(const typename NBT_Type::type &vTagVal)\
567 return AddFront(vTagVal); \
576typename List::value_type & AddFront##type(typename NBT_Type::type &&vTagVal)\
578 return AddFront(std::move(vTagVal));\
587typename List::value_type &AddBack##type(const typename NBT_Type::type &vTagVal)\
589 return AddBack(vTagVal);\
598typename List::value_type &AddBack##type(typename NBT_Type::type &&vTagVal)\
600 return AddBack(std::move(vTagVal));\
610typename List::value_type &Set##type(typename List::size_type szPos, const typename NBT_Type::type &vTagVal)\
612 return Set(szPos, vTagVal);\
622typename List::value_type &Set##type(typename List::size_type szPos, typename NBT_Type::type &&vTagVal)\
624 return Set(szPos, std::move(vTagVal));\
#define TYPE_PUT_FUNC(type)
不同类型名接口生成宏
定义 NBT_List.hpp:495
#define TYPE_GET_FUNC(type)
不同类型名接口生成宏
定义 NBT_List.hpp:411
@ Int
对应NBT_Type::Int
定义 NBT_TAG.hpp:21
@ Float
对应NBT_Type::Float
定义 NBT_TAG.hpp:23
@ ByteArray
对应NBT_Type::ByteArray
定义 NBT_TAG.hpp:25
@ Short
对应NBT_Type::Short
定义 NBT_TAG.hpp:20
@ List
对应NBT_Type::List
定义 NBT_TAG.hpp:27
@ Long
对应NBT_Type::Long
定义 NBT_TAG.hpp:22
@ End
对应NBT_Type::End
定义 NBT_TAG.hpp:18
@ LongArray
对应NBT_Type::LongArray
定义 NBT_TAG.hpp:30
@ Byte
对应NBT_Type::Byte
定义 NBT_TAG.hpp:19
@ IntArray
对应NBT_Type::IntArray
定义 NBT_TAG.hpp:29
@ Double
对应NBT_Type::Double
定义 NBT_TAG.hpp:24
用于格式化打印、序列化、计算哈希等功能
定义 NBT_Helper.hpp:25
typename List::allocator_type Allocator_Type
标准库容器公开类型映射
定义 NBT_List.hpp:35
typename List::const_pointer Const_Pointer
标准库容器公开类型映射
定义 NBT_List.hpp:41
typename List::size_type Size_Type
标准库容器公开类型映射
定义 NBT_List.hpp:36
List::iterator Insert(typename List::const_iterator itPos, typename List::value_type &&value)
在指定位置插入一个元素(移动构造)
定义 NBT_List.hpp:324
bool Empty(void) const noexcept
检查容器是否为空
定义 NBT_List.hpp:363
List::value_type & Add(typename List::size_type szPos, V &&vTagVal)
在指定位置的前面插入元素
定义 NBT_List.hpp:231
void Reserve(typename List::size_type szNewCap)
预留存储空间
定义 NBT_List.hpp:377
typename List::reference Reference
标准库容器公开类型映射
定义 NBT_List.hpp:38
NBT_List(NBT_List &&_Move) noexcept
移动构造函数
定义 NBT_List.hpp:71
typename List::reverse_iterator Reverse_Iterator
标准库容器公开类型映射
定义 NBT_List.hpp:44
const List & GetData(void) const noexcept
获取底层容器数据的常量引用
定义 NBT_List.hpp:99
List::iterator Insert(typename List::const_iterator itPos, const typename List::value_type &value)
在指定位置插入一个元素(拷贝构造)
定义 NBT_List.hpp:315
List::value_type & Get(const typename List::size_type &szPos)
根据位置获取值
定义 NBT_List.hpp:152
const List::value_type & Back(void) const noexcept
获取列表最后的元素(常量版本)
定义 NBT_List.hpp:213
bool Contains(const typename List::value_type &tValue) const noexcept
检查是否包含指定元素
定义 NBT_List.hpp:392
void ShrinkToFit(void)
缩减容器容量以匹配大小
定义 NBT_List.hpp:383
List::size_type Size(void) const noexcept
获取容器中元素的数量
定义 NBT_List.hpp:370
bool operator==(const NBT_List &_Right) const noexcept
相等比较运算符
定义 NBT_List.hpp:107
typename List::const_reverse_iterator Const_Reverse_Iterator
标准库容器公开类型映射
定义 NBT_List.hpp:45
typename List::difference_type Difference_Type
标准库容器公开类型映射
定义 NBT_List.hpp:37
typename List::iterator Iterator
标准库容器公开类型映射
定义 NBT_List.hpp:42
void Merge(NBT_List &&_Move)
移动合并另一个NBT_List的内容
定义 NBT_List.hpp:306
void Resize(typename List::size_type szNewSize, const typename List::value_type &value)
调整容器大小,如果大小大于当前大小,那么使用val填充新增空间,否则删除多余元素
定义 NBT_List.hpp:292
List::iterator Insert(typename List::const_iterator itPos, InputIt itFirst, InputIt itLast)
在指定位置插入一个范围内的元素
定义 NBT_List.hpp:345
std::partial_ordering operator<=>(const NBT_List &_Right) const noexcept
三路比较运算符
定义 NBT_List.hpp:123
const List::value_type & Front(void) const noexcept
获取列表开头的元素(常量版本)
定义 NBT_List.hpp:197
typename List::value_type Value_Type
标准库容器公开类型映射
定义 NBT_List.hpp:34
void Clear(void)
清空所有元素
定义 NBT_List.hpp:277
void Merge(const NBT_List &_Copy)
拷贝合并另一个NBT_List的内容
定义 NBT_List.hpp:299
NBT_List(Args &&... args)
构造函数
定义 NBT_List.hpp:56
void Resize(typename List::size_type szNewSize)
调整容器大小,如果大小大于当前大小,那么使用默认值填充新增空间,否则删除多余元素
定义 NBT_List.hpp:284
NBT_List(const NBT_List &_Copy)
拷贝构造函数
定义 NBT_List.hpp:76
List::value_type & Back(void) noexcept
获取列表最后的元素
定义 NBT_List.hpp:205
NBT_List(void)=default
默认构造函数
List::value_type & Set(typename List::size_type szPos, V &&vTagVal)
设置(替换)指定位置的元素
定义 NBT_List.hpp:263
NBT_List(std::initializer_list< typename List::value_type > init)
初始化列表构造函数
定义 NBT_List.hpp:61
~NBT_List(void)=default
析构函数
List::value_type & Front(void) noexcept
获取列表开头的元素
定义 NBT_List.hpp:189
List::value_type & AddFront(V &&vTagVal)
在列表头部插入元素
定义 NBT_List.hpp:241
typename List::pointer Pointer
标准库容器公开类型映射
定义 NBT_List.hpp:40
typename List::const_iterator Const_Iterator
标准库容器公开类型映射
定义 NBT_List.hpp:43
List::iterator Insert(typename List::const_iterator itPos, typename List::size_type szCount, const typename List::value_type &value)
在指定位置插入count个相同的元素
定义 NBT_List.hpp:334
bool operator!=(const NBT_List &_Right) const noexcept
不等比较运算符
定义 NBT_List.hpp:115
List::value_type * Has(const typename List::size_type &szPos) noexcept
根据位置查找值
定义 NBT_List.hpp:169
NBT_List & operator=(const NBT_List &_Copy)
拷贝赋值运算符
定义 NBT_List.hpp:91
void Remove(typename List::size_type szPos)
删除指定位置的元素
定义 NBT_List.hpp:270
bool ContainsIf(Predicate pred) const noexcept
使用谓词检查是否存在满足条件的元素
定义 NBT_List.hpp:403
List::value_type & AddBack(V &&vTagVal)
在列表末尾插入元素
定义 NBT_List.hpp:251
const List::value_type * Has(const typename List::size_type &szPos) const noexcept
根据位置查找值(常量版本)
定义 NBT_List.hpp:179
const List::value_type & Get(const typename List::size_type &szPos) const
根据位置获取值(常量版本)
定义 NBT_List.hpp:161
NBT_List & operator=(NBT_List &&_Move) noexcept
移动赋值运算符
定义 NBT_List.hpp:82
List::iterator Insert(typename List::const_iterator itPos, std::initializer_list< typename List::value_type > ilistValue)
在指定位置插入初始化列表中的元素
定义 NBT_List.hpp:354
typename List::const_reference Const_Reference
标准库容器公开类型映射
定义 NBT_List.hpp:39
这个类用于提供从NBT二进制流读取到NBT_Type::Compound对象的反序列化功能
定义 NBT_Reader.hpp:23
这个类用于提供从NBT_Type::Compound对象写出到NBT二进制流的序列化功能
定义 NBT_Writer.hpp:23
在std命名空间中添加类的默认hash特化以便unordered_map等容器自动获取
定义 NBT_String.hpp:422