src/PosixMQHandler.h
branchv_0
changeset 2 fc9911b1d295
parent 0 a64022f9684e
child 3 be6f2e307a65
--- a/src/PosixMQHandler.h	Fri Mar 04 01:11:27 2022 +0100
+++ b/src/PosixMQHandler.h	Fri Mar 04 01:40:50 2022 +0100
@@ -29,28 +29,36 @@
 #include <relpipe/reader/handlers/RelationalReaderStringHandler.h>
 #include <relpipe/reader/handlers/AttributeMetadata.h>
 
+#include "PosixMQ.h"
+
 namespace relpipe {
 namespace out {
 namespace posixmq {
 
 class PosixMQHandler : public relpipe::reader::handlers::RelationalReaderStringHandler {
 private:
-	
+	std::wstring_convert<codecvt_utf8<wchar_t>> convertor; // TODO: support also other encodings.
+	shared_ptr<PosixMQ> mq;
+
 public:
 
 	PosixMQHandler(std::ostream& output) {
+		relpipe::common::type::StringX queueName = L"/relpipe";
+		mq.reset(PosixMQ::open(convertor.to_bytes(queueName)));
+
 	}
 
 	void startRelation(relpipe::common::type::StringX name, std::vector<relpipe::reader::handlers::AttributeMetadata> attributes) override {
-		
+
 	}
 
 	void attribute(const relpipe::common::type::StringX& value) override {
-		
+		// TODO: send only certain attributes
+		mq->send(convertor.to_bytes(value));
 	}
 
 	void endOfPipe() {
-		
+
 	}
 
 };