summaryrefslogtreecommitdiff
path: root/cpp/examples/messaging
diff options
context:
space:
mode:
authorJonathan Robie <jonathan@apache.org>2010-05-05 20:56:16 +0000
committerJonathan Robie <jonathan@apache.org>2010-05-05 20:56:16 +0000
commit5cf37bb132d40253d5d62e648fc0ffc6760a6d6b (patch)
tree67934b181c6238ff5b150f41d6dff018de2256cc /cpp/examples/messaging
parent146ebebd374590b952cd6e72b33178363d28e383 (diff)
downloadqpid-python-5cf37bb132d40253d5d62e648fc0ffc6760a6d6b.tar.gz
Added hello_xml.cpp example.
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@941482 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/examples/messaging')
-rw-r--r--cpp/examples/messaging/Makefile.am6
-rw-r--r--cpp/examples/messaging/hello_xml.cpp64
2 files changed, 69 insertions, 1 deletions
diff --git a/cpp/examples/messaging/Makefile.am b/cpp/examples/messaging/Makefile.am
index 502e81bc8b..1f5f2ede2a 100644
--- a/cpp/examples/messaging/Makefile.am
+++ b/cpp/examples/messaging/Makefile.am
@@ -24,11 +24,14 @@ INCLUDES = -I$(top_srcdir)/include -I$(top_builddir)/include
CLIENT_LIB=$(top_builddir)/src/libqpidclient.la
CLIENTFLAGS=-lqpidclient
-noinst_PROGRAMS=drain spout client server map_sender map_receiver hello_world
+noinst_PROGRAMS=drain spout client server map_sender map_receiver hello_world hello_xml
hello_world_SOURCES=hello_world.cpp
hello_world_LDADD=$(CLIENT_LIB)
+hello_xml_SOURCES=hello_xml.cpp
+hello_xml_LDADD=$(CLIENT_LIB)
+
drain_SOURCES=drain.cpp OptionParser.h OptionParser.cpp
drain_LDADD=$(CLIENT_LIB)
@@ -49,6 +52,7 @@ map_receiver_LDADD=$(CLIENT_LIB)
examples_DATA= \
hello_world.cpp \
+ hello_xml.cpp \
drain.cpp \
spout.cpp \
OptionParser.cpp \
diff --git a/cpp/examples/messaging/hello_xml.cpp b/cpp/examples/messaging/hello_xml.cpp
new file mode 100644
index 0000000000..ab6de25b16
--- /dev/null
+++ b/cpp/examples/messaging/hello_xml.cpp
@@ -0,0 +1,64 @@
+#include <qpid/messaging/Connection.h>
+#include <qpid/messaging/Message.h>
+#include <qpid/messaging/Receiver.h>
+#include <qpid/messaging/Sender.h>
+#include <qpid/messaging/Session.h>
+
+#include <iostream>
+#include <sstream>
+using std::stringstream;
+
+using namespace qpid::messaging;
+
+int main(int argc, char** argv) {
+ std::string broker = argc > 1 ? argv[1] : "localhost:5672";
+ std::string query =
+ "let $w := ./weather "
+ "return $w/station = 'Raleigh-Durham International Airport (KRDU)' "
+ " and $w/temperature_f > 50"
+ " and $w/temperature_f - $w/dewpoint > 5"
+ " and $w/wind_speed_mph > 7"
+ " and $w/wind_speed_mph < 20";
+
+ stringstream address;
+
+ address << "xml; {"
+ " create: always, " // This line and the next are not in docs
+ " node: { type: topic }, " // Added so it works "out of the box"
+ " link: { "
+ " x-bindings: [{ exchange: xml, key: weather, arguments: { xquery:\""
+ << query
+ << "\"} }] "
+ " } "
+ "}";
+
+ Connection connection(broker);
+ try {
+ connection.open();
+ Session session = connection.createSession();
+
+ Receiver receiver = session.createReceiver(address.str());
+
+ Message message;
+ message.setContent(
+ "<weather>"
+ "<station>Raleigh-Durham International Airport (KRDU)</station>"
+ "<wind_speed_mph>16</wind_speed_mph>"
+ "<temperature_f>70</temperature_f>"
+ "<dewpoint>35</dewpoint>"
+ "</weather>");
+ Sender sender = session.createSender("xml/weather");
+ sender.send(message);
+
+ Message response = receiver.fetch();
+
+ std::cout << response.getContent() << std::endl;
+
+ connection.close();
+ return 0;
+ } catch(const std::exception& error) {
+ std::cerr << error.what() << std::endl;
+ connection.close();
+ return 1;
+ }
+}