summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRemko Tronçon <git@el-tramo.be>2010-09-17 09:59:40 (GMT)
committerRemko Tronçon <git@el-tramo.be>2010-09-17 09:59:40 (GMT)
commit83d55c4e8ffdc5e0efb41a2b4f0cd76cc1e5d8d1 (patch)
treee66ff0b14c277f07090f604c2ac9ef77b9186630
parent4b6a520ff560cdb16140d4cd3c25660b3d76227a (diff)
downloadswift-contrib-83d55c4e8ffdc5e0efb41a2b4f0cd76cc1e5d8d1.zip
swift-contrib-83d55c4e8ffdc5e0efb41a2b4f0cd76cc1e5d8d1.tar.bz2
Added XMPP parser tester.
-rw-r--r--Swiften/Examples/EchoBot/SConscript3
-rw-r--r--Swiften/Examples/ParserTester/.gitignore1
-rw-r--r--Swiften/Examples/ParserTester/ParserTester.cpp55
-rw-r--r--Swiften/Examples/ParserTester/SConscript11
-rw-r--r--Swiften/Examples/SConscript1
5 files changed, 70 insertions, 1 deletions
diff --git a/Swiften/Examples/EchoBot/SConscript b/Swiften/Examples/EchoBot/SConscript
index 711d8ea..fb7749d 100644
--- a/Swiften/Examples/EchoBot/SConscript
+++ b/Swiften/Examples/EchoBot/SConscript
@@ -10,4 +10,5 @@ myenv.MergeFlags(myenv["OPENSSL_FLAGS"])
myenv.MergeFlags(myenv.get("LIBXML_FLAGS", ""))
myenv.MergeFlags(myenv.get("EXPAT_FLAGS", ""))
myenv.MergeFlags(myenv["PLATFORM_FLAGS"])
-tester = myenv.Program("EchoBot", ["EchoBot.cpp"])
+
+myenv.Program("EchoBot", ["EchoBot.cpp"])
diff --git a/Swiften/Examples/ParserTester/.gitignore b/Swiften/Examples/ParserTester/.gitignore
new file mode 100644
index 0000000..cbc6f36
--- /dev/null
+++ b/Swiften/Examples/ParserTester/.gitignore
@@ -0,0 +1 @@
+ParserTester
diff --git a/Swiften/Examples/ParserTester/ParserTester.cpp b/Swiften/Examples/ParserTester/ParserTester.cpp
new file mode 100644
index 0000000..3cc87e1
--- /dev/null
+++ b/Swiften/Examples/ParserTester/ParserTester.cpp
@@ -0,0 +1,55 @@
+/*
+ * Copyright (c) 2010 Remko Tronçon
+ * Licensed under the GNU General Public License v3.
+ * See Documentation/Licenses/GPLv3.txt for more information.
+ */
+
+#include <iostream>
+#include <fstream>
+#include <typeinfo>
+
+#include "Swiften/Parser/UnitTest/ParserTester.h"
+#include "Swiften/Parser/XMPPParser.h"
+#include "Swiften/Parser/XMPPParserClient.h"
+#include "Swiften/Parser/PayloadParsers/FullPayloadParserFactoryCollection.h"
+
+using namespace Swift;
+
+class MyXMPPParserClient : public XMPPParserClient {
+ public:
+ virtual void handleStreamStart(const ProtocolHeader&) {
+ std::cout << "-> Stream start" << std::endl;
+ }
+ virtual void handleElement(boost::shared_ptr<Element> element) {
+ std::cout << "-> Element " << typeid(*element.get()).name() << std::endl;
+ }
+ virtual void handleStreamEnd() {
+ std::cout << "-> Stream end" << std::endl;
+ }
+};
+
+int main(int argc, char* argv[]) {
+ if (argc != 2) {
+ std::cerr << "Usage: " << argv[0] << " file" << std::endl;
+ return 0;
+ }
+ FullPayloadParserFactoryCollection factories;
+ MyXMPPParserClient parserClient;
+ XMPPParser parser(&parserClient, &factories);
+ ParserTester<XMLParserClient> tester(&parser);
+
+ std::string line;
+ std::ifstream myfile (argv[1]);
+ if (myfile.is_open()) {
+ while (!myfile.eof()) {
+ getline (myfile,line);
+ std::cout << "Parsing: " << line << std::endl;
+ tester.parse(line);
+ }
+ myfile.close();
+ }
+ else {
+ std::cerr << "Unable to open file " << argv[1] << std::endl;
+ }
+ return 0;
+}
diff --git a/Swiften/Examples/ParserTester/SConscript b/Swiften/Examples/ParserTester/SConscript
new file mode 100644
index 0000000..e3df0ba
--- /dev/null
+++ b/Swiften/Examples/ParserTester/SConscript
@@ -0,0 +1,11 @@
+Import("env")
+
+myenv = env.Clone()
+myenv.MergeFlags(myenv["SWIFTEN_FLAGS"])
+myenv.MergeFlags(myenv["LIBIDN_FLAGS"])
+myenv.MergeFlags(myenv["BOOST_FLAGS"])
+myenv.MergeFlags(myenv.get("LIBXML_FLAGS", ""))
+myenv.MergeFlags(myenv.get("EXPAT_FLAGS", ""))
+myenv.MergeFlags(myenv["PLATFORM_FLAGS"])
+
+myenv.Program("ParserTester", ["ParserTester.cpp"])
diff --git a/Swiften/Examples/SConscript b/Swiften/Examples/SConscript
index 1c95e85..64d1859 100644
--- a/Swiften/Examples/SConscript
+++ b/Swiften/Examples/SConscript
@@ -7,4 +7,5 @@ SConscript(dirs = [
"ConnectivityTest",
"LinkLocalTool",
"EchoBot",
+ "ParserTester",
])