diff options
| author | Sefa Eyeoglu <contact@scrumplex.net> | 2022-04-15 16:01:48 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-04-15 16:01:48 +0200 |
| commit | 2203af7eeb48c45398139b583615134efd8d407f (patch) | |
| tree | 2d34d59bac71a7c922e77c6ca5533cd9abceda94 | |
| parent | 5bbeb216d27f60bb8063e9ab01f7ea6976a2e0b4 (diff) | |
| parent | 129be45a7f91920e76673af104534d215c497d85 (diff) | |
| download | Project-Tick-2203af7eeb48c45398139b583615134efd8d407f.tar.gz Project-Tick-2203af7eeb48c45398139b583615134efd8d407f.zip | |
Merge pull request #3 from oynqr/build/lto
Move templated methods to header
| -rw-r--r-- | CMakeLists.txt | 1 | ||||
| -rw-r--r-- | include/tag_array.h | 104 | ||||
| -rw-r--r-- | src/tag_array.cpp | 134 |
3 files changed, 104 insertions, 135 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index adbd3443d0..389da31bc9 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -21,7 +21,6 @@ include(GenerateExportHeader) set(NBT_SOURCES src/endian_str.cpp src/tag.cpp - src/tag_array.cpp src/tag_compound.cpp src/tag_list.cpp src/tag_string.cpp diff --git a/include/tag_array.h b/include/tag_array.h index bed84d8070..a12c22688b 100644 --- a/include/tag_array.h +++ b/include/tag_array.h @@ -21,8 +21,11 @@ #define TAG_ARRAY_H_INCLUDED #include "crtp_tag.h" +#include "io/stream_reader.h" +#include "io/stream_writer.h" #include <type_traits> #include <vector> +#include <istream> namespace nbt { @@ -121,6 +124,107 @@ template<class T> bool operator==(const tag_array<T>& lhs, const tag_array<T>& r template<class T> bool operator!=(const tag_array<T>& lhs, const tag_array<T>& rhs) { return !(lhs == rhs); } +//Slightly different between byte_array and int_array +//Reading +template<> +inline void tag_array<int8_t>::read_payload(io::stream_reader& reader) +{ + int32_t length; + reader.read_num(length); + if(length < 0) + reader.get_istr().setstate(std::ios::failbit); + if(!reader.get_istr()) + throw io::input_error("Error reading length of tag_byte_array"); + + data.resize(length); + reader.get_istr().read(reinterpret_cast<char*>(data.data()), length); + if(!reader.get_istr()) + throw io::input_error("Error reading contents of tag_byte_array"); +} + +template<typename T> +inline void tag_array<T>::read_payload(io::stream_reader& reader) +{ + int32_t length; + reader.read_num(length); + if(length < 0) + reader.get_istr().setstate(std::ios::failbit); + if(!reader.get_istr()) + throw io::input_error("Error reading length of generic array tag"); + + data.clear(); + data.reserve(length); + for(T i = 0; i < length; ++i) + { + T val; + reader.read_num(val); + data.push_back(val); + } + if(!reader.get_istr()) + throw io::input_error("Error reading contents of generic array tag"); +} + +template<> +inline void tag_array<int64_t>::read_payload(io::stream_reader& reader) +{ + int32_t length; + reader.read_num(length); + if(length < 0) + reader.get_istr().setstate(std::ios::failbit); + if(!reader.get_istr()) + throw io::input_error("Error reading length of tag_long_array"); + + data.clear(); + data.reserve(length); + for(int32_t i = 0; i < length; ++i) + { + int64_t val; + reader.read_num(val); + data.push_back(val); + } + if(!reader.get_istr()) + throw io::input_error("Error reading contents of tag_long_array"); +} + +//Writing +template<> +inline void tag_array<int8_t>::write_payload(io::stream_writer& writer) const +{ + if(size() > io::stream_writer::max_array_len) + { + writer.get_ostr().setstate(std::ios::failbit); + throw std::length_error("Byte array is too large for NBT"); + } + writer.write_num(static_cast<int32_t>(size())); + writer.get_ostr().write(reinterpret_cast<const char*>(data.data()), data.size()); +} + +template<typename T> +inline void tag_array<T>::write_payload(io::stream_writer& writer) const +{ + if(size() > io::stream_writer::max_array_len) + { + writer.get_ostr().setstate(std::ios::failbit); + throw std::length_error("Generic array is too large for NBT"); + } + writer.write_num(static_cast<int32_t>(size())); + for(T i: data) + writer.write_num(i); +} + +template<> +inline void tag_array<int64_t>::write_payload(io::stream_writer& writer) const +{ + if(size() > io::stream_writer::max_array_len) + { + writer.get_ostr().setstate(std::ios::failbit); + throw std::length_error("Long array is too large for NBT"); + } + writer.write_num(static_cast<int32_t>(size())); + for(int64_t i: data) + writer.write_num(i); +} + //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; diff --git a/src/tag_array.cpp b/src/tag_array.cpp deleted file mode 100644 index a48f52a9c2..0000000000 --- a/src/tag_array.cpp +++ /dev/null @@ -1,134 +0,0 @@ -/* - * libnbt++ - A library for the Minecraft Named Binary Tag format. - * Copyright (C) 2013, 2015 ljfa-ag - * - * This file is part of libnbt++. - * - * libnbt++ is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * libnbt++ 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 Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public License - * along with libnbt++. If not, see <http://www.gnu.org/licenses/>. - */ -#include "tag_array.h" -#include "io/stream_reader.h" -#include "io/stream_writer.h" -#include <istream> - -namespace nbt -{ - -//Slightly different between byte_array and int_array -//Reading -template<> -void tag_array<int8_t>::read_payload(io::stream_reader& reader) -{ - int32_t length; - reader.read_num(length); - if(length < 0) - reader.get_istr().setstate(std::ios::failbit); - if(!reader.get_istr()) - throw io::input_error("Error reading length of tag_byte_array"); - - data.resize(length); - reader.get_istr().read(reinterpret_cast<char*>(data.data()), length); - if(!reader.get_istr()) - throw io::input_error("Error reading contents of tag_byte_array"); -} - -template<typename T> -void tag_array<T>::read_payload(io::stream_reader& reader) -{ - int32_t length; - reader.read_num(length); - if(length < 0) - reader.get_istr().setstate(std::ios::failbit); - if(!reader.get_istr()) - throw io::input_error("Error reading length of generic array tag"); - - data.clear(); - data.reserve(length); - for(T i = 0; i < length; ++i) - { - T val; - reader.read_num(val); - data.push_back(val); - } - if(!reader.get_istr()) - throw io::input_error("Error reading contents of generic array tag"); -} - -template<> -void tag_array<int64_t>::read_payload(io::stream_reader& reader) -{ - int32_t length; - reader.read_num(length); - if(length < 0) - reader.get_istr().setstate(std::ios::failbit); - if(!reader.get_istr()) - throw io::input_error("Error reading length of tag_long_array"); - - data.clear(); - data.reserve(length); - for(int32_t i = 0; i < length; ++i) - { - int64_t val; - reader.read_num(val); - data.push_back(val); - } - if(!reader.get_istr()) - throw io::input_error("Error reading contents of tag_long_array"); -} - -//Writing -template<> -void tag_array<int8_t>::write_payload(io::stream_writer& writer) const -{ - if(size() > io::stream_writer::max_array_len) - { - writer.get_ostr().setstate(std::ios::failbit); - throw std::length_error("Byte array is too large for NBT"); - } - writer.write_num(static_cast<int32_t>(size())); - writer.get_ostr().write(reinterpret_cast<const char*>(data.data()), data.size()); -} - -template<typename T> -void tag_array<T>::write_payload(io::stream_writer& writer) const -{ - if(size() > io::stream_writer::max_array_len) - { - writer.get_ostr().setstate(std::ios::failbit); - throw std::length_error("Generic array is too large for NBT"); - } - writer.write_num(static_cast<int32_t>(size())); - for(T i: data) - writer.write_num(i); -} - -template<> -void tag_array<int64_t>::write_payload(io::stream_writer& writer) const -{ - if(size() > io::stream_writer::max_array_len) - { - writer.get_ostr().setstate(std::ios::failbit); - throw std::length_error("Long array is too large for NBT"); - } - writer.write_num(static_cast<int32_t>(size())); - for(int64_t i: data) - writer.write_num(i); -} - -//Explicit instantiations -template class NBT_EXPORT tag_array<int8_t>; -template class NBT_EXPORT tag_array<int32_t>; -template class NBT_EXPORT tag_array<int64_t>; - -} |
