summaryrefslogtreecommitdiffstats
path: root/src/Dictionary.cpp
diff options
context:
space:
mode:
authorGravatar Jonathan Beck2009-10-16 22:26:13 +0200
committerGravatar Jonathan Beck2009-10-16 22:26:13 +0200
commit32be8ec384bfd78e189d3de6609e50cf4dd072a2 (patch)
treeac7edad0f19be2a31efaaaaa3acd477dd2f3c233 /src/Dictionary.cpp
parent8aeef4dd2331445fea8a7a40466b19973e9d09c4 (diff)
downloadlibplist-32be8ec384bfd78e189d3de6609e50cf4dd072a2.tar.gz
libplist-32be8ec384bfd78e189d3de6609e50cf4dd072a2.tar.bz2
Fix Node lifecycle and change argument as reference to const reference.
Diffstat (limited to 'src/Dictionary.cpp')
-rw-r--r--src/Dictionary.cpp20
1 files changed, 13 insertions, 7 deletions
diff --git a/src/Dictionary.cpp b/src/Dictionary.cpp
index 6879e33..15df0b4 100644
--- a/src/Dictionary.cpp
+++ b/src/Dictionary.cpp
@@ -85,7 +85,7 @@ Dictionary::Dictionary(plist_t node) : Structure()
free(it);
}
-Dictionary::Dictionary(Dictionary& d)
+Dictionary::Dictionary(PList::Dictionary& d) : Structure()
{
for (Dictionary::iterator it = _map.begin(); it != _map.end(); it++)
{
@@ -142,7 +142,7 @@ Dictionary::Dictionary(Dictionary& d)
free(it);
}
-Dictionary& Dictionary::operator=(const Dictionary& d)
+Dictionary& Dictionary::operator=(PList::Dictionary& d)
{
for (Dictionary::iterator it = _map.begin(); it != _map.end(); it++)
{
@@ -209,7 +209,12 @@ Dictionary::~Dictionary()
_map.clear();
}
-Node* Dictionary::operator[](std::string& key)
+Node* Dictionary::Clone()
+{
+ return new Dictionary(*this);
+}
+
+Node* Dictionary::operator[](const std::string& key)
{
return _map[key];
}
@@ -224,13 +229,14 @@ Dictionary::iterator Dictionary::End()
return _map.end();
}
-void Dictionary::Insert(std::string& key, Node* node)
+void Dictionary::Insert(const std::string& key, Node* node)
{
if (node)
{
- plist_dict_insert_item(_node, key.c_str(), node->GetPlist());
+ Node* clone = node->Clone();
+ plist_dict_insert_item(_node, key.c_str(), clone->GetPlist());
delete _map[key];
- _map[key] = node;
+ _map[key] = clone;
}
}
@@ -247,7 +253,7 @@ void Dictionary::Remove(Node* node)
}
}
-void Dictionary::Remove(std::string& key)
+void Dictionary::Remove(const std::string& key)
{
plist_dict_remove_item(_node, key.c_str());
delete _map[key];