diff --git a/DOM/NamedNodeMap.h b/DOM/NamedNodeMap.h index f48b3cfc..2ec65140 100644 --- a/DOM/NamedNodeMap.h +++ b/DOM/NamedNodeMap.h @@ -69,6 +69,8 @@ template class NamedNodeMap_impl { public: + virtual ~NamedNodeMap_impl() { } + /////////////////////////////////////////////////////// // Ref counting virtual void addRef() = 0; diff --git a/DOM/NodeList.h b/DOM/NodeList.h index 39f48d69..450fa015 100644 --- a/DOM/NodeList.h +++ b/DOM/NodeList.h @@ -48,6 +48,8 @@ template class NodeList_impl { public: + virtual ~NodeList_impl() { } + /////////////////////////////////////////////////////// // Ref counting virtual void addRef() = 0; diff --git a/SAX/SAX.vcproj b/SAX/SAX.vcproj index adc253b2..845cbc19 100644 --- a/SAX/SAX.vcproj +++ b/SAX/SAX.vcproj @@ -448,15 +448,84 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/SAX/wrappers/saxlibxml2.h b/SAX/wrappers/saxlibxml2.h index 6daae350..2137a147 100644 --- a/SAX/wrappers/saxlibxml2.h +++ b/SAX/wrappers/saxlibxml2.h @@ -41,6 +41,9 @@ extern "C" class libxml2_base { + protected: + virtual ~libxml2_base() { } + private: virtual void SAXstartDocument() = 0; virtual void SAXendDocument() = 0; diff --git a/Utils/impl/codecvt_specialisations.cpp b/Utils/impl/codecvt_specialisations.cpp index 02fdf3be..5839f27a 100644 --- a/Utils/impl/codecvt_specialisations.cpp +++ b/Utils/impl/codecvt_specialisations.cpp @@ -6,6 +6,11 @@ namespace std { +codecvt:: +~codecvt() +{ +} // ~codecvt + //////////////////////////////////////////////////////////////////////// codecvt_base::result codecvt:: diff --git a/Utils/impl/codecvt_specialisations.h b/Utils/impl/codecvt_specialisations.h index d6b0edac..9557293b 100644 --- a/Utils/impl/codecvt_specialisations.h +++ b/Utils/impl/codecvt_specialisations.h @@ -10,6 +10,8 @@ template<> class codecvt { protected: + virtual ~codecvt(); + virtual codecvt_base::result do_out(mbstate_t&, const char* from, const char* from_end, diff --git a/XPath/impl/xpath_function_resolver.hpp b/XPath/impl/xpath_function_resolver.hpp index 77ada120..8bb01fdb 100644 --- a/XPath/impl/xpath_function_resolver.hpp +++ b/XPath/impl/xpath_function_resolver.hpp @@ -21,6 +21,8 @@ public: class FunctionResolver { public: + virtual ~FunctionResolver() { } + // TODO: should make this a QName virtual XPathFunction* resolveFunction(const std::string& name, const std::vector& argExprs) const = 0; diff --git a/test/XPath/node_test_test.cpp b/test/XPath/node_test_test.cpp index 2dee289b..bb83a3a3 100644 --- a/test/XPath/node_test_test.cpp +++ b/test/XPath/node_test_test.cpp @@ -260,4 +260,3 @@ TestSuite* NodeTestTest_suite() return suiteOfTests; } // NodeTestTest_suite - \ No newline at end of file