} // namespace
+Directive::~Directive() {}
+
Replace::Replace(const string &str)
: str(str) {}
}
}
-Clone::Clone(const std::vector<Directive *> &subdirectives)
+Clone::Clone(const vector<Directive *> &subdirectives)
+ : subdirectives(subdirectives) {}
+
+Clone::Clone(initializer_list<Directive *> subdirectives)
: subdirectives(subdirectives) {}
-void Clone::process(xmlNode *node, bool clean) {
+Clone::~Clone()
+{
+ for (auto it : subdirectives) {
+ delete it;
+ }
+}
+
+void Clone::process(xmlNode *node, bool clean)
+{
// We can't use xmlNewDocFragment, since xmlDOMWrapCloneNode only knows
// how to clone elements.
vector<xmlNode *> new_nodes;
Substitute::Substitute(const unordered_map<string, Directive*> &substitution_map)
: substitution_map(substitution_map) {}
+
+Substitute::Substitute(initializer_list<pair<const string, Directive*>> substitution_map)
+ : substitution_map(substitution_map) {}
+
+Substitute::~Substitute()
+{
+ for (auto it : substitution_map) {
+ delete it.second;
+ }
+}
-void Substitute::process(xmlNode *node, bool clean) {
+void Substitute::process(xmlNode *node, bool clean)
+{
for (xmlNode *child = node->children; child != NULL; child = child->next) {
bool processed = false;
xmlDocPtr doc = xmlParseFile(input_filename.c_str());
root_directive->process(xmlDocGetRootElement(doc), true);
xmlSaveFile(output_filename.c_str(), doc);
+ xmlFreeDoc(doc);
xmlCleanupParser();
xmlMemoryDump();