summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGravatar Jonathan Beck2009-11-11 00:18:14 +0100
committerGravatar Jonathan Beck2009-11-11 00:18:14 +0100
commit8c6a809fafa6befff7e2b1adc3df2bdb47042dd1 (patch)
tree2336ae7ee66dbb639c8b8bd8c06171c1f6f6e334 /src
parent53a9f891f82e973440709593d259bd7c1f22dd1a (diff)
downloadlibplist-8c6a809fafa6befff7e2b1adc3df2bdb47042dd1.tar.gz
libplist-8c6a809fafa6befff7e2b1adc3df2bdb47042dd1.tar.bz2
Move some methods and drop Utils class in C++ binding.
Diffstat (limited to 'src')
-rw-r--r--src/CMakeLists.txt1
-rw-r--r--src/Node.cpp49
-rw-r--r--src/Structure.cpp34
-rw-r--r--src/Utils.cpp109
4 files changed, 83 insertions, 110 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 3c6ac09..afeb33b 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -18,7 +18,6 @@ SET(libplist++_SRC
Structure.cpp
Array.cpp
Dictionary.cpp
- Utils.cpp
)
ADD_LIBRARY( plist SHARED ${libplist_SRC} )
diff --git a/src/Node.cpp b/src/Node.cpp
index b0cc96a..3122322 100644
--- a/src/Node.cpp
+++ b/src/Node.cpp
@@ -21,6 +21,15 @@
#include <stdlib.h>
#include <plist/Node.h>
#include <plist/Structure.h>
+#include <plist/Utils.h>
+#include <plist/Dictionary.h>
+#include <plist/Array.h>
+#include <plist/Boolean.h>
+#include <plist/Integer.h>
+#include <plist/Real.h>
+#include <plist/String.h>
+#include <plist/Data.h>
+#include <plist/Date.h>
namespace PList
{
@@ -96,4 +105,44 @@ Node* Node::GetParent()
return _parent;
}
+Node* Node::FromPlist(plist_t node, Node* parent)
+{
+ Node* ret = NULL;
+ if (node)
+ {
+ plist_type type = plist_get_node_type(node);
+ switch (type)
+ {
+ case PLIST_DICT:
+ ret = new Dictionary(node, parent);
+ break;
+ case PLIST_ARRAY:
+ ret = new Array(node, parent);
+ break;
+ case PLIST_BOOLEAN:
+ ret = new Boolean(node, parent);
+ break;
+ case PLIST_UINT:
+ ret = new Integer(node, parent);
+ break;
+ case PLIST_REAL:
+ ret = new Real(node, parent);
+ break;
+ case PLIST_STRING:
+ ret = new String(node, parent);
+ break;
+ case PLIST_DATE:
+ ret = new Date(node, parent);
+ break;
+ case PLIST_DATA:
+ ret = new Data(node, parent);
+ break;
+ default:
+ plist_free(node);
+ break;
+ }
+ }
+ return ret;
+}
+
};
diff --git a/src/Structure.cpp b/src/Structure.cpp
index cf7c611..18b19ef 100644
--- a/src/Structure.cpp
+++ b/src/Structure.cpp
@@ -85,5 +85,39 @@ void Structure::UpdateNodeParent(Node* node)
node->_parent = this;
}
+static Structure* ImportStruct(plist_t root)
+{
+ Structure* ret = NULL;
+ plist_type type = plist_get_node_type(root);
+
+ if (PLIST_ARRAY == type || PLIST_DICT == type)
+ {
+ ret = static_cast<Structure*>(Node::FromPlist(root));
+ }
+ else
+ {
+ plist_free(root);
+ }
+
+ return ret;
+}
+
+Structure* Structure::FromXml(const std::string& xml)
+{
+ plist_t root = NULL;
+ plist_from_xml(xml.c_str(), xml.size(), &root);
+
+ return ImportStruct(root);
+}
+
+Structure* Structure::FromBin(const std::vector<char>& bin)
+{
+ plist_t root = NULL;
+ plist_from_bin(&bin[0], bin.size(), &root);
+
+ return ImportStruct(root);
+
+}
+
};
diff --git a/src/Utils.cpp b/src/Utils.cpp
deleted file mode 100644
index cb6da5e..0000000
--- a/src/Utils.cpp
+++ /dev/null
@@ -1,109 +0,0 @@
-/*
- * Utils.cpp
- *
- * Copyright (c) 2009 Jonathan Beck All Rights Reserved.
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- */
-
-#include <stdlib.h>
-#include <plist/Utils.h>
-#include <plist/Dictionary.h>
-#include <plist/Array.h>
-#include <plist/Boolean.h>
-#include <plist/Integer.h>
-#include <plist/Real.h>
-#include <plist/String.h>
-#include <plist/Data.h>
-#include <plist/Date.h>
-
-namespace PList
-{
-
-Node* Utils::FromPlist(plist_t node, Node* parent)
-{
- Node* ret = NULL;
- if (node)
- {
- plist_type type = plist_get_node_type(node);
- switch (type)
- {
- case PLIST_DICT:
- ret = new Dictionary(node, parent);
- break;
- case PLIST_ARRAY:
- ret = new Array(node, parent);
- break;
- case PLIST_BOOLEAN:
- ret = new Boolean(node, parent);
- break;
- case PLIST_UINT:
- ret = new Integer(node, parent);
- break;
- case PLIST_REAL:
- ret = new Real(node, parent);
- break;
- case PLIST_STRING:
- ret = new String(node, parent);
- break;
- case PLIST_DATE:
- ret = new Date(node, parent);
- break;
- case PLIST_DATA:
- ret = new Data(node, parent);
- break;
- default:
- plist_free(node);
- break;
- }
- }
- return ret;
-}
-
-static Structure* ImportStruct(plist_t root)
-{
- Structure* ret = NULL;
- plist_type type = plist_get_node_type(root);
-
- if (PLIST_ARRAY == type || PLIST_DICT == type)
- {
- ret = static_cast<Structure*>(Utils::FromPlist(root));
- }
- else
- {
- plist_free(root);
- }
-
- return ret;
-}
-
-Structure* Utils::FromXml(const std::string& xml)
-{
- plist_t root = NULL;
- plist_from_xml(xml.c_str(), xml.size(), &root);
-
- return ImportStruct(root);
-}
-
-Structure* Utils::FromBin(const std::vector<char>& bin)
-{
- plist_t root = NULL;
- plist_from_bin(&bin[0], bin.size(), &root);
-
- return ImportStruct(root);
-
-}
-
-};