summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRemko Tronçon <git@el-tramo.be>2009-07-21 14:56:02 (GMT)
committerRemko Tronçon <git@el-tramo.be>2009-07-21 14:56:02 (GMT)
commit0c0df47a4667a0cd5b0005b70c1beda376678d09 (patch)
tree058075878cb581a9d7cafef1b058edd2b9008a5a /Slimber
parentf4f175051b0c95edad200d66fa12f1b9511e2c6b (diff)
downloadswift-0c0df47a4667a0cd5b0005b70c1beda376678d09.zip
swift-0c0df47a4667a0cd5b0005b70c1beda376678d09.tar.bz2
Load stored VCard.
Diffstat (limited to 'Slimber')
-rw-r--r--Slimber/Cocoa/Makefile.inc2
-rw-r--r--Slimber/FileVCardCollection.cpp17
-rw-r--r--Slimber/FileVCardCollection.h1
3 files changed, 17 insertions, 3 deletions
diff --git a/Slimber/Cocoa/Makefile.inc b/Slimber/Cocoa/Makefile.inc
index 6658dea..e4a9c67 100644
--- a/Slimber/Cocoa/Makefile.inc
+++ b/Slimber/Cocoa/Makefile.inc
@@ -3,6 +3,8 @@ SLIMBER_COCOA_BINARY = \
Slimber/Cocoa/Slimber
SLIMBER_COCOA_SOURCES = \
Slimber/Server.cpp \
+ Slimber/VCardCollection.cpp \
+ Slimber/FileVCardCollection.cpp \
Slimber/Cocoa/MainController.mm \
Slimber/Cocoa/Slimber.mm \
Slimber/Cocoa/main.mm \
diff --git a/Slimber/FileVCardCollection.cpp b/Slimber/FileVCardCollection.cpp
index 16c53c4..eb7d9cc 100644
--- a/Slimber/FileVCardCollection.cpp
+++ b/Slimber/FileVCardCollection.cpp
@@ -2,17 +2,30 @@
#include <boost/filesystem/fstream.hpp>
+#include "Swiften/Base/ByteArray.h"
#include "Swiften/Elements/VCard.h"
#include "Swiften/Serializer/PayloadSerializers/VCardSerializer.h"
+#include "Swiften/Parser/PayloadParsers/UnitTest/PayloadParserTester.h"
+#include "Swiften/Parser/PayloadParsers/VCardParser.h"
namespace Swift {
FileVCardCollection::FileVCardCollection(boost::filesystem::path dir) : vcardsPath(dir) {
- vcard = boost::shared_ptr<VCard>(new VCard());
}
boost::shared_ptr<VCard> FileVCardCollection::getOwnVCard() const {
- return vcard;
+ if (boost::filesystem::exists(vcardsPath / std::string("vcard.xml"))) {
+ ByteArray data;
+ data.readFromFile(boost::filesystem::path(vcardsPath / std::string("vcard.xml")).string());
+
+ VCardParser parser;
+ PayloadParserTester tester(&parser);
+ tester.parse(String(data.getData(), data.getSize()));
+ return boost::dynamic_pointer_cast<VCard>(parser.getPayload());
+ }
+ else {
+ return boost::shared_ptr<VCard>(new VCard());
+ }
}
void FileVCardCollection::setOwnVCard(boost::shared_ptr<VCard> v) {
diff --git a/Slimber/FileVCardCollection.h b/Slimber/FileVCardCollection.h
index 3d805a8..dde47df 100644
--- a/Slimber/FileVCardCollection.h
+++ b/Slimber/FileVCardCollection.h
@@ -15,6 +15,5 @@ namespace Swift {
private:
boost::filesystem::path vcardsPath;
- boost::shared_ptr<VCard> vcard;
};
}