move *DataTypeWriter.h to separate directory v_0
authorFrantišek Kučera <franta-hg@frantovo.cz>
Sat, 21 Jul 2018 19:04:37 +0200
branchv_0
changeset 10 40ab091e5dfa
parent 9 0a40752e401d
child 11 27bc67e7c80f
move *DataTypeWriter.h to separate directory
nbproject/configurations.xml
src/BooleanDataTypeWriter.h
src/IntegerDataTypeWriter.h
src/StreamRelationalWriter.h
src/StringDataTypeWriter.h
src/types/BooleanDataTypeWriter.h
src/types/IntegerDataTypeWriter.h
src/types/StringDataTypeWriter.h
--- a/nbproject/configurations.xml	Sat Jul 21 17:30:25 2018 +0200
+++ b/nbproject/configurations.xml	Sat Jul 21 19:04:37 2018 +0200
@@ -4,14 +4,14 @@
     <logicalFolder name="HeaderFiles"
                    displayName="Header Files"
                    projectFiles="true">
-      <itemPath>src/BooleanDataTypeWriter.h</itemPath>
+      <itemPath>src/types/BooleanDataTypeWriter.h</itemPath>
       <itemPath>src/DataTypeWriter.h</itemPath>
       <itemPath>src/DataTypeWriterBase.h</itemPath>
-      <itemPath>src/IntegerDataTypeWriter.h</itemPath>
+      <itemPath>src/types/IntegerDataTypeWriter.h</itemPath>
       <itemPath>include/RelationalWriter.h</itemPath>
       <itemPath>include/RelpipeWriterException.h</itemPath>
       <itemPath>src/StreamRelationalWriter.h</itemPath>
-      <itemPath>src/StringDataTypeWriter.h</itemPath>
+      <itemPath>src/types/StringDataTypeWriter.h</itemPath>
       <itemPath>src/format.h</itemPath>
       <itemPath>include/typedefs.h</itemPath>
     </logicalFolder>
@@ -52,21 +52,21 @@
       </item>
       <item path="include/typedefs.h" ex="false" tool="3" flavor2="0">
       </item>
-      <item path="src/BooleanDataTypeWriter.h" ex="false" tool="3" flavor2="0">
-      </item>
       <item path="src/DataTypeWriter.h" ex="false" tool="3" flavor2="0">
       </item>
       <item path="src/DataTypeWriterBase.h" ex="false" tool="3" flavor2="0">
       </item>
-      <item path="src/IntegerDataTypeWriter.h" ex="false" tool="3" flavor2="0">
-      </item>
       <item path="src/RelationalWriter.cpp" ex="false" tool="1" flavor2="0">
       </item>
       <item path="src/StreamRelationalWriter.h" ex="false" tool="3" flavor2="0">
       </item>
-      <item path="src/StringDataTypeWriter.h" ex="false" tool="3" flavor2="0">
+      <item path="src/format.h" ex="false" tool="3" flavor2="0">
+      </item>
+      <item path="src/types/BooleanDataTypeWriter.h" ex="false" tool="3" flavor2="0">
       </item>
-      <item path="src/format.h" ex="false" tool="3" flavor2="0">
+      <item path="src/types/IntegerDataTypeWriter.h" ex="false" tool="3" flavor2="0">
+      </item>
+      <item path="src/types/StringDataTypeWriter.h" ex="false" tool="3" flavor2="0">
       </item>
     </conf>
     <conf name="Release" type="2">
@@ -95,21 +95,21 @@
       </item>
       <item path="include/typedefs.h" ex="false" tool="3" flavor2="0">
       </item>
-      <item path="src/BooleanDataTypeWriter.h" ex="false" tool="3" flavor2="0">
-      </item>
       <item path="src/DataTypeWriter.h" ex="false" tool="3" flavor2="0">
       </item>
       <item path="src/DataTypeWriterBase.h" ex="false" tool="3" flavor2="0">
       </item>
-      <item path="src/IntegerDataTypeWriter.h" ex="false" tool="3" flavor2="0">
-      </item>
       <item path="src/RelationalWriter.cpp" ex="false" tool="1" flavor2="0">
       </item>
       <item path="src/StreamRelationalWriter.h" ex="false" tool="3" flavor2="0">
       </item>
-      <item path="src/StringDataTypeWriter.h" ex="false" tool="3" flavor2="0">
+      <item path="src/format.h" ex="false" tool="3" flavor2="0">
+      </item>
+      <item path="src/types/BooleanDataTypeWriter.h" ex="false" tool="3" flavor2="0">
       </item>
-      <item path="src/format.h" ex="false" tool="3" flavor2="0">
+      <item path="src/types/IntegerDataTypeWriter.h" ex="false" tool="3" flavor2="0">
+      </item>
+      <item path="src/types/StringDataTypeWriter.h" ex="false" tool="3" flavor2="0">
       </item>
     </conf>
   </confs>
--- a/src/BooleanDataTypeWriter.h	Sat Jul 21 17:30:25 2018 +0200
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,35 +0,0 @@
-#pragma once
-
-#include <string>
-#include <iostream>
-
-#include "DataTypeWriter.h"
-#include "../include/RelpipeWriterException.h"
-#include "format.h"
-
-namespace relpipe {
-namespace writer {
-
-class BooleanDataTypeWriter : public DataTypeWriter<boolean_t> {
-private:
-	const string_t TRUE = L"true";
-	const string_t FALSE = L"false";
-public:
-
-	BooleanDataTypeWriter() : DataTypeWriter<boolean_t>(DATA_TYPE_ID_BOOLEAN, DATA_TYPE_CODE_BOOLEAN) {
-	}
-
-	void writeValue(std::ostream &output, const boolean_t &value) override {
-		output.put(value ? 1 : 0);
-	}
-
-	bool toValue(const string_t &stringValue) override {
-		if (stringValue == TRUE) return true;
-		else if (stringValue == FALSE) return false;
-		else throw RelpipeWriterException(L"Unable to convert the string to boolean");
-	}
-
-};
-
-}
-}
\ No newline at end of file
--- a/src/IntegerDataTypeWriter.h	Sat Jul 21 17:30:25 2018 +0200
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,104 +0,0 @@
-#pragma once
-
-#include <string>
-#include <iostream>
-#include <cassert>
-#include <limits>
-
-#include "DataTypeWriter.h"
-#include "format.h"
-
-namespace relpipe {
-namespace writer {
-
-/**
- * The prototype does not have various integer and other numeric data types,
- * it just works with one type of integer.
- * But this integer has variable length -- smaller values occupy only one byte, bigger ones, more bytes 1,2,4,8 + first byte (contains length signalization).
- * In the real implementation of relational pipes, there will be DataTypes for particular numeric types.
- * 
- * TODO: support also big endian architectures.
- * TODO: throw exception if a value was stored in bigger type than needed (while reading – there should be only one supported way how to encode a single value)
- * 
- * Example of encoded values:
- * -------------------------------------------------------------------------------------------------
- * $ for n in 0 1 10 250 251 252 65535 65536 4294967295 4294967296 18446744073709551615; do printf '%20s = ' $n; dist/Debug/GNU-Linux/rp-prototype write integer $n | hd | head -n 1; done
- *                    0 = 00000000  00                                                |.|
- *                    1 = 00000000  01                                                |.|
- *                   10 = 00000000  0a                                                |.|
- *                  250 = 00000000  fa                                                |.|
- *                  251 = 00000000  fb fb                                             |..|
- *                  252 = 00000000  fb fc                                             |..|
- *                65535 = 00000000  fc ff ff                                          |...|
- *                65536 = 00000000  fd 00 00 01 00                                    |.....|
- *           4294967295 = 00000000  fd ff ff ff ff                                    |.....|
- *           4294967296 = 00000000  fe 00 00 00 00 01 00 00  00                       |.........|
- * 18446744073709551615 = 00000000  fe ff ff ff ff ff ff ff  ff                       |.........|
- * -------------------------------------------------------------------------------------------------
- * 
- * Example of decoded values:
- * -------------------------------------------------------------------------------------------------
- * $ for n in 0 1 10 250 251 252 65535 65536 4294967295 4294967296 18446744073709551615; do dist/Debug/GNU-Linux/rp-prototype write integer $n | dist/Debug/GNU-Linux/rp-prototype read integer; done;
- * 0
- * 1
- * 10
- * 250
- * 251
- * 252
- * 65535
- * 65536
- * 4294967295
- * 4294967296
- * 18446744073709551615
- * -------------------------------------------------------------------------------------------------
- * 
- * Note: similar format as original idea: https://en.wikipedia.org/wiki/X.690#Length_octets
- * 
- */
-class IntegerDataTypeWriter : public DataTypeWriter<integer_t> {
-private:
-	static const uint8_t INTEGER_TYPE_UINT8 = 251;
-	static const uint8_t INTEGER_TYPE_UINT16 = 252;
-	static const uint8_t INTEGER_TYPE_UINT32 = 253;
-	static const uint8_t INTEGER_TYPE_UINT64 = 254;
-	static const uint8_t INTEGER_TYPE_RESERVED = 255;
-
-	template<typename T> void write(std::ostream &output, const integer_t &value) {
-		assert(sizeof (T) <= sizeof (value));
-		output.write(reinterpret_cast<const char *> (&value), sizeof (T));
-	}
-
-	template<typename T> void write(std::ostream &output, const uint8_t type, const integer_t &value) {
-		write<uint8_t>(output, type);
-		write<T>(output, value);
-	}
-
-	template<typename T> bool fits(const integer_t &value) {
-		return value <= numeric_limits<T>::max();
-	}
-
-public:
-
-	IntegerDataTypeWriter() : DataTypeWriter<integer_t>(DATA_TYPE_ID_INTEGER, DATA_TYPE_CODE_INTEGER) {
-	}
-
-	void writeValue(std::ostream &output, const integer_t &value) override {
-		// output << value; // by zapsalo číslo jako ASII text
-
-		if (value < INTEGER_TYPE_UINT8) write<uint8_t>(output, value);
-		else if (fits<uint8_t>(value)) write<uint8_t>(output, INTEGER_TYPE_UINT8, value);
-		else if (fits<uint16_t>(value)) write<uint16_t>(output, INTEGER_TYPE_UINT16, value);
-		else if (fits<uint32_t>(value)) write<uint32_t>(output, INTEGER_TYPE_UINT32, value);
-		else if (fits<uint64_t>(value)) write<uint64_t>(output, INTEGER_TYPE_UINT64, value);
-		else throw RelpipeWriterException(L"Error while writing integer type: value too long");
-	}
-
-	integer_t toValue(const string_t &stringValue) override {
-		// throws „terminate called after throwing an instance of 'std::invalid_argument'“ SIGABRT, core dumped on invalid number
-		return stoul(stringValue);
-	}
-
-};
-
-}
-}
\ No newline at end of file
--- a/src/StreamRelationalWriter.h	Sat Jul 21 17:30:25 2018 +0200
+++ b/src/StreamRelationalWriter.h	Sat Jul 21 19:04:37 2018 +0200
@@ -7,9 +7,9 @@
 #include "../include/typedefs.h"
 #include "../include/RelationalWriter.h"
 #include "DataTypeWriterBase.h"
-#include "BooleanDataTypeWriter.h"
-#include "IntegerDataTypeWriter.h"
-#include "StringDataTypeWriter.h"
+#include "types/BooleanDataTypeWriter.h"
+#include "types/IntegerDataTypeWriter.h"
+#include "types/StringDataTypeWriter.h"
 
 namespace relpipe {
 namespace writer {
@@ -17,9 +17,9 @@
 class StreamRelationalWriter : public RelationalWriter {
 private:
 	std::ostream &output;
-	BooleanDataTypeWriter booleanWriter;
-	IntegerDataTypeWriter integerWriter;
-	StringDataTypeWriter stringWriter;
+	types::BooleanDataTypeWriter booleanWriter;
+	types::IntegerDataTypeWriter integerWriter;
+	types::StringDataTypeWriter stringWriter;
 	vector<DataTypeWriterBase*> writers = {&booleanWriter, &integerWriter, &stringWriter};
 
 	void writeString(const string_t &stringValue, const integer_t typeId) {
--- a/src/StringDataTypeWriter.h	Sat Jul 21 17:30:25 2018 +0200
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,43 +0,0 @@
-#pragma once
-
-#include <string>
-#include <sstream>
-#include <iostream>
-#include <vector>
-#include <locale>
-#include <codecvt>
-
-#include "DataTypeWriter.h"
-#include "format.h"
-
-namespace relpipe {
-namespace writer {
-
-/**
- * The prototype does not recognize any encoding,
- * it just works with c++ strings in encoding default to given platform. 
- * In the real implementation of relational pipes, there will be DataTypes for particular encodings.
- */
-class StringDataTypeWriter : public DataTypeWriter<string_t> {
-private:
-	IntegerDataTypeWriter integerType;
-	std::wstring_convert<std::codecvt_utf8<wchar_t>> convertor; // TODO: support also other encodings.
-public:
-
-	StringDataTypeWriter() : DataTypeWriter<string_t>(DATA_TYPE_ID_STRING, DATA_TYPE_CODE_STRING) {
-	}
-
-	void writeValue(std::ostream &output, const string_t &value) override {
-		std::string s = convertor.to_bytes(value);
-		integerType.writeValue(output, s.length());
-		output << s.c_str();
-	}
-
-	wstring toValue(const string_t &stringValue) override {
-		return stringValue;
-	}
-
-};
-
-}
-}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/types/BooleanDataTypeWriter.h	Sat Jul 21 19:04:37 2018 +0200
@@ -0,0 +1,39 @@
+#pragma once
+
+#include <string>
+#include <iostream>
+
+#include "../../include/RelpipeWriterException.h"
+#include "../DataTypeWriter.h"
+#include "../format.h"
+
+namespace relpipe {
+namespace writer {
+namespace types {
+
+using namespace relpipe::writer;
+
+class BooleanDataTypeWriter : public DataTypeWriter<boolean_t> {
+private:
+	const string_t TRUE = L"true";
+	const string_t FALSE = L"false";
+public:
+
+	BooleanDataTypeWriter() : DataTypeWriter<boolean_t>(DATA_TYPE_ID_BOOLEAN, DATA_TYPE_CODE_BOOLEAN) {
+	}
+
+	void writeValue(std::ostream &output, const boolean_t &value) override {
+		output.put(value ? 1 : 0);
+	}
+
+	bool toValue(const string_t &stringValue) override {
+		if (stringValue == TRUE) return true;
+		else if (stringValue == FALSE) return false;
+		else throw RelpipeWriterException(L"Unable to convert the string to boolean");
+	}
+
+};
+
+}
+}
+}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/types/IntegerDataTypeWriter.h	Sat Jul 21 19:04:37 2018 +0200
@@ -0,0 +1,108 @@
+#pragma once
+
+#include <string>
+#include <iostream>
+#include <cassert>
+#include <limits>
+
+#include "../DataTypeWriter.h"
+#include "../format.h"
+
+namespace relpipe {
+namespace writer {
+namespace types {
+
+using namespace relpipe::writer;
+
+/**
+ * The prototype does not have various integer and other numeric data types,
+ * it just works with one type of integer.
+ * But this integer has variable length -- smaller values occupy only one byte, bigger ones, more bytes 1,2,4,8 + first byte (contains length signalization).
+ * In the real implementation of relational pipes, there will be DataTypes for particular numeric types.
+ * 
+ * TODO: support also big endian architectures.
+ * TODO: throw exception if a value was stored in bigger type than needed (while reading – there should be only one supported way how to encode a single value)
+ * 
+ * Example of encoded values:
+ * -------------------------------------------------------------------------------------------------
+ * $ for n in 0 1 10 250 251 252 65535 65536 4294967295 4294967296 18446744073709551615; do printf '%20s = ' $n; dist/Debug/GNU-Linux/rp-prototype write integer $n | hd | head -n 1; done
+ *                    0 = 00000000  00                                                |.|
+ *                    1 = 00000000  01                                                |.|
+ *                   10 = 00000000  0a                                                |.|
+ *                  250 = 00000000  fa                                                |.|
+ *                  251 = 00000000  fb fb                                             |..|
+ *                  252 = 00000000  fb fc                                             |..|
+ *                65535 = 00000000  fc ff ff                                          |...|
+ *                65536 = 00000000  fd 00 00 01 00                                    |.....|
+ *           4294967295 = 00000000  fd ff ff ff ff                                    |.....|
+ *           4294967296 = 00000000  fe 00 00 00 00 01 00 00  00                       |.........|
+ * 18446744073709551615 = 00000000  fe ff ff ff ff ff ff ff  ff                       |.........|
+ * -------------------------------------------------------------------------------------------------
+ * 
+ * Example of decoded values:
+ * -------------------------------------------------------------------------------------------------
+ * $ for n in 0 1 10 250 251 252 65535 65536 4294967295 4294967296 18446744073709551615; do dist/Debug/GNU-Linux/rp-prototype write integer $n | dist/Debug/GNU-Linux/rp-prototype read integer; done;
+ * 0
+ * 1
+ * 10
+ * 250
+ * 251
+ * 252
+ * 65535
+ * 65536
+ * 4294967295
+ * 4294967296
+ * 18446744073709551615
+ * -------------------------------------------------------------------------------------------------
+ * 
+ * Note: similar format as original idea: https://en.wikipedia.org/wiki/X.690#Length_octets
+ * 
+ */
+class IntegerDataTypeWriter : public DataTypeWriter<integer_t> {
+private:
+	static const uint8_t INTEGER_TYPE_UINT8 = 251;
+	static const uint8_t INTEGER_TYPE_UINT16 = 252;
+	static const uint8_t INTEGER_TYPE_UINT32 = 253;
+	static const uint8_t INTEGER_TYPE_UINT64 = 254;
+	static const uint8_t INTEGER_TYPE_RESERVED = 255;
+
+	template<typename T> void write(std::ostream &output, const integer_t &value) {
+		assert(sizeof (T) <= sizeof (value));
+		output.write(reinterpret_cast<const char *> (&value), sizeof (T));
+	}
+
+	template<typename T> void write(std::ostream &output, const uint8_t type, const integer_t &value) {
+		write<uint8_t>(output, type);
+		write<T>(output, value);
+	}
+
+	template<typename T> bool fits(const integer_t &value) {
+		return value <= numeric_limits<T>::max();
+	}
+
+public:
+
+	IntegerDataTypeWriter() : DataTypeWriter<integer_t>(DATA_TYPE_ID_INTEGER, DATA_TYPE_CODE_INTEGER) {
+	}
+
+	void writeValue(std::ostream &output, const integer_t &value) override {
+		// output << value; // by zapsalo číslo jako ASII text
+
+		if (value < INTEGER_TYPE_UINT8) write<uint8_t>(output, value);
+		else if (fits<uint8_t>(value)) write<uint8_t>(output, INTEGER_TYPE_UINT8, value);
+		else if (fits<uint16_t>(value)) write<uint16_t>(output, INTEGER_TYPE_UINT16, value);
+		else if (fits<uint32_t>(value)) write<uint32_t>(output, INTEGER_TYPE_UINT32, value);
+		else if (fits<uint64_t>(value)) write<uint64_t>(output, INTEGER_TYPE_UINT64, value);
+		else throw RelpipeWriterException(L"Error while writing integer type: value too long");
+	}
+
+	integer_t toValue(const string_t &stringValue) override {
+		// throws „terminate called after throwing an instance of 'std::invalid_argument'“ SIGABRT, core dumped on invalid number
+		return stoul(stringValue);
+	}
+
+};
+
+}
+}
+}
\ No newline at end of file
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/types/StringDataTypeWriter.h	Sat Jul 21 19:04:37 2018 +0200
@@ -0,0 +1,46 @@
+#pragma once
+
+#include <string>
+#include <sstream>
+#include <iostream>
+#include <vector>
+#include <locale>
+#include <codecvt>
+
+#include "../DataTypeWriter.h"
+#include "../format.h"
+
+namespace relpipe {
+namespace writer {
+namespace types {
+
+using namespace relpipe::writer;
+/**
+ * The prototype does not recognize any encoding,
+ * it just works with c++ strings in encoding default to given platform. 
+ * In the real implementation of relational pipes, there will be DataTypes for particular encodings.
+ */
+class StringDataTypeWriter : public DataTypeWriter<string_t> {
+private:
+	IntegerDataTypeWriter integerType;
+	std::wstring_convert<std::codecvt_utf8<wchar_t>> convertor; // TODO: support also other encodings.
+public:
+
+	StringDataTypeWriter() : DataTypeWriter<string_t>(DATA_TYPE_ID_STRING, DATA_TYPE_CODE_STRING) {
+	}
+
+	void writeValue(std::ostream &output, const string_t &value) override {
+		std::string s = convertor.to_bytes(value);
+		integerType.writeValue(output, s.length());
+		output << s.c_str();
+	}
+
+	wstring toValue(const string_t &stringValue) override {
+		return stringValue;
+	}
+
+};
+
+}
+}
+}
\ No newline at end of file