diff options
-rw-r--r-- | depends/libnbtplusplus/include/tag_compound.h | 6 | ||||
-rw-r--r-- | depends/libnbtplusplus/include/tag_primitive.h | 16 |
2 files changed, 14 insertions, 8 deletions
diff --git a/depends/libnbtplusplus/include/tag_compound.h b/depends/libnbtplusplus/include/tag_compound.h index 5ec818a3..66fe18b4 100644 --- a/depends/libnbtplusplus/include/tag_compound.h +++ b/depends/libnbtplusplus/include/tag_compound.h @@ -124,9 +124,9 @@ public: void read_payload(io::stream_reader& reader) override; void write_payload(io::stream_writer& writer) const override; - friend bool operator==(const tag_compound& lhs, const tag_compound& rhs) + NBT___EXPORT friend bool operator==(const tag_compound& lhs, const tag_compound& rhs) { return lhs.tags == rhs.tags; } - friend bool operator!=(const tag_compound& lhs, const tag_compound& rhs) + NBT___EXPORT friend bool operator!=(const tag_compound& lhs, const tag_compound& rhs) { return !(lhs == rhs); } private: @@ -134,7 +134,7 @@ private: }; template<class T, class... Args> -std::pair<tag_compound::iterator, bool> tag_compound::emplace(const std::string& key, Args&&... args) +NBT___EXPORT std::pair<tag_compound::iterator, bool> tag_compound::emplace(const std::string& key, Args&&... args) { return put(key, value(make_unique<T>(std::forward<Args>(args)...))); } diff --git a/depends/libnbtplusplus/include/tag_primitive.h b/depends/libnbtplusplus/include/tag_primitive.h index 8b70c147..c83e695e 100644 --- a/depends/libnbtplusplus/include/tag_primitive.h +++ b/depends/libnbtplusplus/include/tag_primitive.h @@ -38,7 +38,7 @@ namespace nbt * Common class for tag_byte, tag_short, tag_int, tag_long, tag_float and tag_double. */ template<class T> -class tag_primitive final : public detail::crtp_tag<tag_primitive<T>> +class NBT___EXPORT tag_primitive final : public detail::crtp_tag<tag_primitive<T>> { public: ///The type of the value @@ -66,10 +66,16 @@ private: T value; }; -template<class T> bool operator==(const tag_primitive<T>& lhs, const tag_primitive<T>& rhs) -{ return lhs.get() == rhs.get(); } -template<class T> bool operator!=(const tag_primitive<T>& lhs, const tag_primitive<T>& rhs) -{ return !(lhs == rhs); } +template<class T> +NBT___EXPORT bool operator==(const tag_primitive<T>& lhs, const tag_primitive<T>& rhs) +{ + return lhs.get() == rhs.get(); +} +template<class T> +NBT___EXPORT bool operator!=(const tag_primitive<T>& lhs, const tag_primitive<T>& rhs) +{ + return !(lhs == rhs); +} //Typedefs that should be used instead of the template tag_primitive. typedef tag_primitive<int8_t> tag_byte; |