diff options
author | Remko Tronçon <git@el-tramo.be> | 2010-09-17 09:59:40 (GMT) |
---|---|---|
committer | Remko Tronçon <git@el-tramo.be> | 2010-09-17 09:59:40 (GMT) |
commit | 83d55c4e8ffdc5e0efb41a2b4f0cd76cc1e5d8d1 (patch) | |
tree | e66ff0b14c277f07090f604c2ac9ef77b9186630 /Swiften/Examples/ParserTester | |
parent | 4b6a520ff560cdb16140d4cd3c25660b3d76227a (diff) | |
download | swift-83d55c4e8ffdc5e0efb41a2b4f0cd76cc1e5d8d1.zip swift-83d55c4e8ffdc5e0efb41a2b4f0cd76cc1e5d8d1.tar.bz2 |
Added XMPP parser tester.
Diffstat (limited to 'Swiften/Examples/ParserTester')
-rw-r--r-- | Swiften/Examples/ParserTester/.gitignore | 1 | ||||
-rw-r--r-- | Swiften/Examples/ParserTester/ParserTester.cpp | 55 | ||||
-rw-r--r-- | Swiften/Examples/ParserTester/SConscript | 11 |
3 files changed, 67 insertions, 0 deletions
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"]) |