From 8c6a809fafa6befff7e2b1adc3df2bdb47042dd1 Mon Sep 17 00:00:00 2001 From: Jonathan Beck Date: Wed, 11 Nov 2009 00:18:14 +0100 Subject: Move some methods and drop Utils class in C++ binding. --- src/CMakeLists.txt | 1 - src/Node.cpp | 49 ++++++++++++++++++++++++ src/Structure.cpp | 34 +++++++++++++++++ src/Utils.cpp | 109 ----------------------------------------------------- 4 files changed, 83 insertions(+), 110 deletions(-) delete mode 100644 src/Utils.cpp (limited to 'src') 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 #include #include +#include +#include +#include +#include +#include +#include +#include +#include +#include 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(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& 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 -#include -#include -#include -#include -#include -#include -#include -#include -#include - -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(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& bin) -{ - plist_t root = NULL; - plist_from_bin(&bin[0], bin.size(), &root); - - return ImportStruct(root); - -} - -}; -- cgit v1.1-32-gdbae