summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorljfa-ag <ljfa-ag@web.de>2015-07-28 17:48:03 +0200
committerljfa-ag <ljfa-ag@web.de>2015-07-28 20:26:56 +0200
commit91cce39f2d04875b17b530a0994fe17a91f303ad (patch)
tree3987381439bca6165b068a7be9b0ef3caa46bc50
parenta5bf6ccebd957365a4eeaa761688d44bfedb0593 (diff)
downloadProject-Tick-91cce39f2d04875b17b530a0994fe17a91f303ad.tar.gz
Project-Tick-91cce39f2d04875b17b530a0994fe17a91f303ad.zip
Implement endian stream i/o for integers
Reorder declarations in header
-rw-r--r--CMakeLists.txt1
-rw-r--r--include/endian_str.h84
-rw-r--r--src/endian_str.cpp203
3 files changed, 246 insertions, 42 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 584f20d7eb..d30f8a820c 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -6,6 +6,7 @@ set(libnbt++_VERSION_MINOR 0)
add_definitions(-std=c++11)
include_directories(include)
add_library(nbt++ STATIC
+ src/endian_str.cpp
src/tag.cpp
src/tag_array.cpp
src/tag_compound.cpp
diff --git a/include/endian_str.h b/include/endian_str.h
index f636773c12..3ccd9817c7 100644
--- a/include/endian_str.h
+++ b/include/endian_str.h
@@ -31,52 +31,52 @@ namespace endian
{
///Reads number from stream in little endian
-void read_little(std::istream& str, uint8_t& x);
-void read_little(std::istream& str, uint16_t& x);
-void read_little(std::istream& str, uint32_t& x);
-void read_little(std::istream& str, uint64_t& x);
-void read_little(std::istream& str, int8_t& x);
-void read_little(std::istream& str, int16_t& x);
-void read_little(std::istream& str, int32_t& x);
-void read_little(std::istream& str, int64_t& x);
-void read_little(std::istream& str, float& x);
-void read_little(std::istream& str, double& x);
-
-///Writes number to stream in little endian
-void write_little(std::ostream& str, uint8_t x);
-void write_little(std::ostream& str, uint16_t x);
-void write_little(std::ostream& str, uint32_t x);
-void write_little(std::ostream& str, uint64_t x);
-void write_little(std::ostream& str, int8_t x);
-void write_little(std::ostream& str, int16_t x);
-void write_little(std::ostream& str, int32_t x);
-void write_little(std::ostream& str, int64_t x);
-void write_little(std::ostream& str, float x);
-void write_little(std::ostream& str, double x);
+void read_little(std::istream& is, uint8_t& x);
+void read_little(std::istream& is, uint16_t& x);
+void read_little(std::istream& is, uint32_t& x);
+void read_little(std::istream& is, uint64_t& x);
+void read_little(std::istream& is, int8_t& x);
+void read_little(std::istream& is, int16_t& x);
+void read_little(std::istream& is, int32_t& x);
+void read_little(std::istream& is, int64_t& x);
+void read_little(std::istream& is, float& x);
+void read_little(std::istream& is, double& x);
///Reads number from stream in big endian
-void read_big(std::istream& str, uint8_t& x);
-void read_big(std::istream& str, uint16_t& x);
-void read_big(std::istream& str, uint32_t& x);
-void read_big(std::istream& str, uint64_t& x);
-void read_big(std::istream& str, int8_t& x);
-void read_big(std::istream& str, int16_t& x);
-void read_big(std::istream& str, int32_t& x);
-void read_big(std::istream& str, int64_t& x);
-void read_big(std::istream& str, float& x);
-void read_big(std::istream& str, double& x);
+void read_big(std::istream& is, uint8_t& x);
+void read_big(std::istream& is, uint16_t& x);
+void read_big(std::istream& is, uint32_t& x);
+void read_big(std::istream& is, uint64_t& x);
+void read_big(std::istream& is, int8_t& x);
+void read_big(std::istream& is, int16_t& x);
+void read_big(std::istream& is, int32_t& x);
+void read_big(std::istream& is, int64_t& x);
+void read_big(std::istream& is, float& x);
+void read_big(std::istream& is, double& x);
+
+///Writes number to stream in little endian
+void write_little(std::ostream& os, uint8_t x);
+void write_little(std::ostream& os, uint16_t x);
+void write_little(std::ostream& os, uint32_t x);
+void write_little(std::ostream& os, uint64_t x);
+void write_little(std::ostream& os, int8_t x);
+void write_little(std::ostream& os, int16_t x);
+void write_little(std::ostream& os, int32_t x);
+void write_little(std::ostream& os, int64_t x);
+void write_little(std::ostream& os, float x);
+void write_little(std::ostream& os, double x);
///Writes number to stream in big endian
-void write_big(std::ostream& str, uint8_t x);
-void write_big(std::ostream& str, uint16_t x);
-void write_big(std::ostream& str, uint32_t x);
-void write_big(std::ostream& str, uint64_t x);
-void write_big(std::ostream& str, int8_t x);
-void write_big(std::ostream& str, int16_t x);
-void write_big(std::ostream& str, int32_t x);
-void write_big(std::ostream& str, int64_t x);
-void write_big(std::ostream& str, float x);
-void write_big(std::ostream& str, double x);
+void write_big(std::ostream& os, uint8_t x);
+void write_big(std::ostream& os, uint16_t x);
+void write_big(std::ostream& os, uint32_t x);
+void write_big(std::ostream& os, uint64_t x);
+void write_big(std::ostream& os, int8_t x);
+void write_big(std::ostream& os, int16_t x);
+void write_big(std::ostream& os, int32_t x);
+void write_big(std::ostream& os, int64_t x);
+void write_big(std::ostream& os, float x);
+void write_big(std::ostream& os, double x);
}
diff --git a/src/endian_str.cpp b/src/endian_str.cpp
new file mode 100644
index 0000000000..104a11312b
--- /dev/null
+++ b/src/endian_str.cpp
@@ -0,0 +1,203 @@
+/*
+ * 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 "endian_str.h"
+#include <climits>
+#include <iostream>
+
+static_assert(CHAR_BIT == 8, "Assuming that a byte has 8 bits");
+
+namespace endian
+{
+
+void read_little(std::istream& is, uint8_t& x)
+{
+ is.get(reinterpret_cast<char&>(x));
+}
+
+void read_little(std::istream& is, uint16_t& x)
+{
+ uint8_t tmp[2];
+ is.read(reinterpret_cast<char*>(tmp), 2);
+ x = uint16_t(tmp[0])
+ | (uint16_t(tmp[1]) << 8);
+}
+
+void read_little(std::istream& is, uint32_t& x)
+{
+ uint8_t tmp[4];
+ is.read(reinterpret_cast<char*>(tmp), 4);
+ x = uint32_t(tmp[0])
+ | (uint32_t(tmp[1]) << 8)
+ | (uint32_t(tmp[2]) << 16)
+ | (uint32_t(tmp[3]) << 24);
+}
+
+void read_little(std::istream& is, uint64_t& x)
+{
+ uint8_t tmp[8];
+ is.read(reinterpret_cast<char*>(tmp), 8);
+ x = uint64_t(tmp[0])
+ | (uint64_t(tmp[1]) << 8)
+ | (uint64_t(tmp[2]) << 16)
+ | (uint64_t(tmp[3]) << 24)
+ | (uint64_t(tmp[4]) << 32)
+ | (uint64_t(tmp[5]) << 40)
+ | (uint64_t(tmp[6]) << 48)
+ | (uint64_t(tmp[7]) << 56);
+}
+
+void read_little(std::istream& is, int8_t & x) { read_little(is, reinterpret_cast<uint8_t &>(x)); }
+void read_little(std::istream& is, int16_t& x) { read_little(is, reinterpret_cast<uint16_t&>(x)); }
+void read_little(std::istream& is, int32_t& x) { read_little(is, reinterpret_cast<uint32_t&>(x)); }
+void read_little(std::istream& is, int64_t& x) { read_little(is, reinterpret_cast<uint64_t&>(x)); }
+
+//------------------------------------------------------------------------------
+
+void read_big(std::istream& is, uint8_t& x)
+{
+ is.read(reinterpret_cast<char*>(&x), 1);
+}
+
+void read_big(std::istream& is, uint16_t& x)
+{
+ uint8_t tmp[2];
+ is.read(reinterpret_cast<char*>(tmp), 2);
+ x = uint16_t(tmp[1])
+ | (uint16_t(tmp[0]) << 8);
+}
+
+void read_big(std::istream& is, uint32_t& x)
+{
+ uint8_t tmp[4];
+ is.read(reinterpret_cast<char*>(tmp), 4);
+ x = uint32_t(tmp[3])
+ | (uint32_t(tmp[2]) << 8)
+ | (uint32_t(tmp[1]) << 16)
+ | (uint32_t(tmp[0]) << 24);
+}
+
+void read_big(std::istream& is, uint64_t& x)
+{
+ uint8_t tmp[8];
+ is.read(reinterpret_cast<char*>(tmp), 8);
+ x = uint64_t(tmp[7])
+ | (uint64_t(tmp[6]) << 8)
+ | (uint64_t(tmp[5]) << 16)
+ | (uint64_t(tmp[4]) << 24)
+ | (uint64_t(tmp[3]) << 32)
+ | (uint64_t(tmp[2]) << 40)
+ | (uint64_t(tmp[1]) << 48)
+ | (uint64_t(tmp[0]) << 56);
+}
+
+void read_big(std::istream& is, int8_t & x) { read_big(is, reinterpret_cast<uint8_t &>(x)); }
+void read_big(std::istream& is, int16_t& x) { read_big(is, reinterpret_cast<uint16_t&>(x)); }
+void read_big(std::istream& is, int32_t& x) { read_big(is, reinterpret_cast<uint32_t&>(x)); }
+void read_big(std::istream& is, int64_t& x) { read_big(is, reinterpret_cast<uint64_t&>(x)); }
+
+//------------------------------------------------------------------------------
+
+void write_little(std::ostream& os, uint8_t x)
+{
+ os.put(x);
+}
+
+void write_little(std::ostream& os, uint16_t x)
+{
+ uint8_t tmp[2] {
+ x & 0x00FF,
+ (x & 0xFF00) >> 8};
+ os.write(reinterpret_cast<const char*>(tmp), 2);
+}
+
+void write_little(std::ostream& os, uint32_t x)
+{
+ uint8_t tmp[4] {
+ x & 0x000000FFUL,
+ (x & 0x0000FF00UL) >> 8,
+ (x & 0x00FF0000UL) >> 16,
+ (x & 0xFF000000UL) >> 24};
+ os.write(reinterpret_cast<const char*>(tmp), 4);
+}
+
+void write_little(std::ostream& os, uint64_t x)
+{
+ uint8_t tmp[8] {
+ x & 0x00000000000000FFULL,
+ (x & 0x000000000000FF00ULL) >> 8,
+ (x & 0x0000000000FF0000ULL) >> 16,
+ (x & 0x00000000FF000000ULL) >> 24,
+ (x & 0x000000FF00000000ULL) >> 32,
+ (x & 0x0000FF0000000000ULL) >> 40,
+ (x & 0x00FF000000000000ULL) >> 48,
+ (x & 0xFF00000000000000ULL) >> 56};
+ os.write(reinterpret_cast<const char*>(tmp), 8);
+}
+
+void write_little(std::ostream& os, int8_t x) { write_little(os, static_cast<uint8_t >(x)); }
+void write_little(std::ostream& os, int16_t x) { write_little(os, static_cast<uint16_t>(x)); }
+void write_little(std::ostream& os, int32_t x) { write_little(os, static_cast<uint32_t>(x)); }
+void write_little(std::ostream& os, int64_t x) { write_little(os, static_cast<uint64_t>(x)); }
+
+//------------------------------------------------------------------------------
+
+void write_big(std::ostream& os, uint8_t x)
+{
+ os.put(x);
+}
+
+void write_big(std::ostream& os, uint16_t x)
+{
+ uint8_t tmp[2] {
+ (x & 0xFF00) >> 8,
+ x & 0x00FF};
+ os.write(reinterpret_cast<const char*>(tmp), 2);
+}
+
+void write_big(std::ostream& os, uint32_t x)
+{
+ uint8_t tmp[4] {
+ (x & 0xFF000000UL) >> 24,
+ (x & 0x00FF0000UL) >> 16,
+ (x & 0x0000FF00UL) >> 8,
+ x & 0x000000FFUL};
+ os.write(reinterpret_cast<const char*>(tmp), 4);
+}
+
+void write_big(std::ostream& os, uint64_t x)
+{
+ uint8_t tmp[8] {
+ (x & 0xFF00000000000000ULL) >> 56,
+ (x & 0x00FF000000000000ULL) >> 48,
+ (x & 0x0000FF0000000000ULL) >> 40,
+ (x & 0x000000FF00000000ULL) >> 32,
+ (x & 0x00000000FF000000ULL) >> 24,
+ (x & 0x0000000000FF0000ULL) >> 16,
+ (x & 0x000000000000FF00ULL) >> 8,
+ x & 0x00000000000000FFULL};
+ os.write(reinterpret_cast<const char*>(tmp), 8);
+}
+
+void write_big(std::ostream& os, int8_t x) { write_big(os, static_cast<uint8_t >(x)); }
+void write_big(std::ostream& os, int16_t x) { write_big(os, static_cast<uint16_t>(x)); }
+void write_big(std::ostream& os, int32_t x) { write_big(os, static_cast<uint32_t>(x)); }
+void write_big(std::ostream& os, int64_t x) { write_big(os, static_cast<uint64_t>(x)); }
+
+}