diff options
| author | Carl Hetherington <cth@carlh.net> | 2021-01-08 14:09:08 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2021-01-08 14:13:41 +0100 |
| commit | dbcf32baf0af10eeaac33460dd617bf1de3075ca (patch) | |
| tree | 90fb707cc1960f9c36cf9b0c47d2d35a3072fe6c | |
| parent | 3540b3350c6a172b2162c32430248cad2d236898 (diff) | |
Use std::vector instead of std::list.
| -rw-r--r-- | src/cxml.cc | 12 | ||||
| -rw-r--r-- | src/cxml.h | 8 | ||||
| -rw-r--r-- | test/tests.cc | 5 |
3 files changed, 12 insertions, 13 deletions
diff --git a/src/cxml.cc b/src/cxml.cc index 356e1df..c21bd19 100644 --- a/src/cxml.cc +++ b/src/cxml.cc @@ -24,9 +24,9 @@ #include <boost/algorithm/string.hpp> #include <cstdio> -using std::string; -using std::list; using std::shared_ptr; +using std::string; +using std::vector; using boost::optional; cxml::Node::Node () @@ -76,14 +76,14 @@ cxml::Node::optional_node_child (string name) const return n.front (); } -list<shared_ptr<cxml::Node>> +vector<shared_ptr<cxml::Node>> cxml::Node::node_children () const { if (!_node) { throw Error ("No node to read children from"); } - list<shared_ptr<cxml::Node> > n; + vector<shared_ptr<cxml::Node> > n; for (auto i: _node->get_children()) { n.push_back (shared_ptr<Node> (new Node (i))); } @@ -91,14 +91,14 @@ cxml::Node::node_children () const return n; } -list<shared_ptr<cxml::Node>> +vector<shared_ptr<cxml::Node>> cxml::Node::node_children (string name) const { /* XXX: using find / get_path should work here, but I can't follow how get_path works. */ - list<shared_ptr<cxml::Node> > n; + vector<shared_ptr<cxml::Node> > n; for (auto i: _node->get_children()) { if (i->get_name() == name) { n.push_back (shared_ptr<Node> (new Node (i))); @@ -26,7 +26,7 @@ #include <boost/algorithm/string/erase.hpp> #include <stdint.h> #include <string> -#include <list> +#include <vector> /* Hack for OS X compile failure; see https://bugs.launchpad.net/hugin/+bug/910160 */ #ifdef check @@ -223,8 +223,8 @@ public: std::shared_ptr<Node> node_child (std::string) const; std::shared_ptr<Node> optional_node_child (std::string) const; - std::list<std::shared_ptr<Node> > node_children () const; - std::list<std::shared_ptr<Node> > node_children (std::string) const; + std::vector<std::shared_ptr<Node>> node_children () const; + std::vector<std::shared_ptr<Node>> node_children (std::string) const; xmlpp::Node* node () const { return _node; @@ -234,7 +234,7 @@ protected: xmlpp::Node* _node; private: - mutable std::list<std::string> _taken; + mutable std::vector<std::string> _taken; }; typedef std::shared_ptr<cxml::Node> NodePtr; diff --git a/test/tests.cc b/test/tests.cc index 6867ac0..633aaa2 100644 --- a/test/tests.cc +++ b/test/tests.cc @@ -27,10 +27,9 @@ #define BOOST_TEST_MODULE libcxml_test #include <boost/test/unit_test.hpp> +using std::shared_ptr; using std::string; using std::vector; -using std::list; -using std::shared_ptr; BOOST_AUTO_TEST_CASE (test) { @@ -68,7 +67,7 @@ BOOST_AUTO_TEST_CASE (test) BOOST_CHECK (!document.optional_bool_child("G")); - list<shared_ptr<cxml::Node> > h = document.node_children ("H"); + vector<shared_ptr<cxml::Node>> h = document.node_children ("H"); BOOST_CHECK_EQUAL (h.size(), 1); BOOST_CHECK_EQUAL (h.front()->node_children("I").size(), 2); BOOST_CHECK_EQUAL (h.front()->node_children("I").front()->content(), "testing"); |
