diff options
| author | ljfa-ag <ljfa-ag@web.de> | 2015-07-15 19:35:51 +0200 |
|---|---|---|
| committer | ljfa-ag <ljfa-ag@web.de> | 2015-07-15 19:35:51 +0200 |
| commit | ea404fc070d15cf53fb6e0099f8e68771da529fd (patch) | |
| tree | f462206f980ec8c8d8b8ff5f4df8f9f94728a5c3 | |
| parent | dea5b824c5c2a36e2b7bbbcb24f7863630315986 (diff) | |
| download | Project-Tick-ea404fc070d15cf53fb6e0099f8e68771da529fd.tar.gz Project-Tick-ea404fc070d15cf53fb6e0099f8e68771da529fd.zip | |
Implement tag_array
| -rw-r--r-- | include/primitive_detail.h | 4 | ||||
| -rw-r--r-- | include/tag_array.h | 95 |
2 files changed, 92 insertions, 7 deletions
diff --git a/include/primitive_detail.h b/include/primitive_detail.h index aaf33ff563..d124e738da 100644 --- a/include/primitive_detail.h +++ b/include/primitive_detail.h @@ -34,9 +34,7 @@ namespace detail { ///Meta-struct that holds the tag_type value for a specific primitive type template<class T> struct get_primitive_type - { - static_assert(sizeof(T) != sizeof(T), "Can only use primitive types used by NBT as parameter for tag_primitive"); - }; + { static_assert(sizeof(T) != sizeof(T), "Can only use primitive types used by NBT as parameter for tag_primitive"); }; template<> struct get_primitive_type<int8_t> : public std::integral_constant<tag_type, tag_type::Byte> {}; template<> struct get_primitive_type<int16_t> : public std::integral_constant<tag_type, tag_type::Short> {}; diff --git a/include/tag_array.h b/include/tag_array.h index 4283ea4fac..159e432626 100644 --- a/include/tag_array.h +++ b/include/tag_array.h @@ -21,11 +21,23 @@ #define TAG_ARRAY_H_INCLUDED #include "crtp_tag.h" +#include <type_traits> #include <vector> namespace nbt { +namespace detail +{ + + template<class T> struct get_array_type + { static_assert(sizeof(T) != sizeof(T), "Can only use byte or int as parameter for tag_array"); }; + + template<> struct get_array_type<int8_t> : public std::integral_constant<tag_type, tag_type::Byte_Array> {}; + template<> struct get_array_type<int32_t> : public std::integral_constant<tag_type, tag_type::Int_Array> {}; + +} + /** * @brief Tag that contains an array of byte or int values * @@ -43,10 +55,10 @@ public: typedef T value_type; ///The type of the tag - static constexpr tag_type type = tag_type::Byte_Array; + static constexpr tag_type type = detail::get_array_type<T>::value; ///Constructs an empty array - tag_array(); + tag_array() {} ///Constructs an array with the given values tag_array(std::initializer_list<T> init); @@ -86,14 +98,89 @@ public: const_iterator cbegin() const; const_iterator cend() const; -private: - std::vector<T> values; + ///The vector that holds the values + std::vector<T> data; }; +template<class T> bool operator==(const tag_array<T>& lhs, const tag_array<T>& rhs); +template<class T> bool operator!=(const tag_array<T>& lhs, const tag_array<T>& rhs); + //Typedefs that should be used instead of the template tag_array. typedef tag_array<int8_t> tag_byte_array; typedef tag_array<int32_t> tag_int_array; +template<class T> +tag_array<T>::tag_array(std::initializer_list<T> init): + data(init) +{} + +template<class T> +T& tag_array<T>::at(size_t i) +{ + return data.at(i); +} + +template<class T> +T tag_array<T>::at(size_t i) const +{ + return data.at(i); +} + +template<class T> +T& tag_array<T>::operator[](size_t i) +{ + return data[i]; +} + +template<class T> +T tag_array<T>::operator[](size_t i) const +{ + return data[i]; +} + +template<class T> +void tag_array<T>::push_back(T val) +{ + data.push_back(val); +} + +template<class T> +void tag_array<T>::pop_back() +{ + data.pop_back(); +} + +template<class T> +size_t tag_array<T>::size() const +{ + return data.size(); +} + +template<class T> +void tag_array<T>::clear() +{ + data.clear(); +} + +template<class T> auto tag_array<T>::begin() -> iterator { return data.begin(); } +template<class T> auto tag_array<T>::end() -> iterator { return data.end(); } +template<class T> auto tag_array<T>::begin() const -> const_iterator { return data.begin(); } +template<class T> auto tag_array<T>::end() const -> const_iterator { return data.end(); } +template<class T> auto tag_array<T>::cbegin() const -> const_iterator { return data.cbegin(); } +template<class T> auto tag_array<T>::cend() const -> const_iterator { return data.cend(); } + +template<class T> +bool operator==(const tag_array<T>& lhs, const tag_array<T>& rhs) +{ + return lhs.data == rhs.data; +} + +template<class T> +bool operator!=(const tag_array<T>& lhs, const tag_array<T>& rhs) +{ + return !(lhs == rhs); +} + } #endif // TAG_ARRAY_H_INCLUDED |
