Merge master.
[libdcp.git] / src / xml.h
index 85589a0f41d885e52913bd82da40a2d38ffa3d63..5978ff7ec10d7346a941d5ebbb71297c3fc5b33c 100644 (file)
--- a/src/xml.h
+++ b/src/xml.h
@@ -1,96 +1,91 @@
-#ifndef LIBDCP_XML_H
-#define LIBDCP_XML_H
+/*
+    Copyright (C) 2013 Carl Hetherington <cth@carlh.net>
 
-#include <string>
-#include <list>
-#include <stdint.h>
-#include <glibmm.h>
-#include <boost/shared_ptr.hpp>
-#include "types.h"
-#include "exceptions.h"
-#include "dcp_time.h"
+    This program is free software; you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation; either version 2 of the License, or
+    (at your option) any later version.
 
-namespace xmlpp {
-       class Node;
-       class DomParser;
-}
+    This program 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 General Public License for more details.
 
-namespace libdcp {
+    You should have received a copy of the GNU General Public License
+    along with this program; if not, write to the Free Software
+    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
-class XMLNode
-{
-public:
-       XMLNode ();
-       XMLNode (xmlpp::Node const * node);
+*/
 
-protected:
-       std::string string_node (std::string);
-       std::string optional_string_node (std::string);
-       ContentKind kind_node (std::string);
-       Fraction fraction_node (std::string);
-       int64_t int64_node (std::string);
-       int64_t optional_int64_node (std::string);
-       float float_node (std::string);
-       void ignore_node (std::string);
-       void done ();
+#ifndef LIBDCP_XML_H
+#define LIBDCP_XML_H
 
-       Time time_attribute (std::string);
-       float float_attribute (std::string);
-       std::string string_attribute (std::string);
+#include <libcxml/cxml.h>
+#include "exceptions.h"
 
-       std::string content ();
+namespace libdcp
+{
 
-       template <class T>
-       boost::shared_ptr<T> sub_node (std::string name) {
-               return boost::shared_ptr<T> (new T (xml_node (name)));
+template <class T>
+boost::shared_ptr<T>
+optional_type_child (cxml::Node const & node, std::string name)
+{
+       std::list<boost::shared_ptr<cxml::Node> > n = node.node_children (name);
+       if (n.size() > 1) {
+               throw XMLError ("duplicate XML tag");
+       } else if (n.empty ()) {
+               return boost::shared_ptr<T> ();
        }
 
-       template <class T>
-       boost::shared_ptr<T> optional_sub_node (std::string name) {
-               std::list<xmlpp::Node*> n = xml_nodes (name);
-               if (n.size() > 1) {
-                       throw XMLError ("duplicate XML tag");
-               } else if (n.empty ()) {
-                       return boost::shared_ptr<T> ();
-               }
-               
-               return boost::shared_ptr<T> (new T (n.front ()));
-       }
+       return boost::shared_ptr<T> (new T (n.front ()));
+}
+
+template <class T>
+boost::shared_ptr<T> type_child (boost::shared_ptr<const cxml::Node> node, std::string name) {
+       return boost::shared_ptr<T> (new T (node->node_child (name)));
+}
        
-       template <class T>
-       std::list<boost::shared_ptr<T> > sub_nodes (std::string name) {
-               std::list<xmlpp::Node*> n = xml_nodes (name);
-               std::list<boost::shared_ptr<T> > r;
-               for (typename std::list<xmlpp::Node*>::iterator i = n.begin(); i != n.end(); ++i) {
-                       r.push_back (boost::shared_ptr<T> (new T (*i)));
-               }
-               return r;
-       }
+template <class T>
+boost::shared_ptr<T>
+optional_type_child (boost::shared_ptr<const cxml::Node> node, std::string name)
+{
+       return optional_type_child<T> (*node.get(), name);
+}
 
-       template <class T>
-       std::list<boost::shared_ptr<T> > sub_nodes (std::string name, std::string sub) {
-               XMLNode p (xml_node (name));
-               return p.sub_nodes<T> (sub);
+template <class T>
+std::list<boost::shared_ptr<T> >
+type_children (cxml::Node const & node, std::string name)
+{
+       std::list<boost::shared_ptr<cxml::Node> > n = node.node_children (name);
+        std::list<boost::shared_ptr<T> > r;
+        for (typename std::list<boost::shared_ptr<cxml::Node> >::iterator i = n.begin(); i != n.end(); ++i) {
+               r.push_back (boost::shared_ptr<T> (new T (*i)));
        }
+       return r;
+}
 
-       xmlpp::Node const * _node;
-
-private:
-       xmlpp::Node* xml_node (std::string);
-       std::list<xmlpp::Node*> xml_nodes (std::string);
-       std::list<Glib::ustring> _taken;
-};
-
-class XMLFile : public XMLNode
+template <class T>
+std::list<boost::shared_ptr<T> >
+type_children (boost::shared_ptr<const cxml::Node> node, std::string name)
 {
-public:
-       XMLFile (std::string file, std::string root_name);
-       virtual ~XMLFile ();
-
-private:
-       xmlpp::DomParser* _parser;
-};
+       return type_children<T> (*node.get(), name);
+}
+       
+template <class T>
+std::list<boost::shared_ptr<T> >
+type_grand_children (cxml::Node const & node, std::string name, std::string sub)
+{
+       boost::shared_ptr<const cxml::Node> p = node.node_child (name);
+       return type_children<T> (p, sub);
+}
 
+template <class T>
+std::list<boost::shared_ptr<T> >
+type_grand_children (boost::shared_ptr<const cxml::Node> node, std::string name, std::string sub)
+{
+       return type_grand_children<T> (*node.get(), name, sub);
+}
+       
 }
 
 #endif