--- boost/archive/impl/basic_xml_grammar.hpp | 16 ++++++++-------- libs/serialization/src/basic_xml_grammar.ipp | 14 +++++++------- 2 files changed, 15 insertions(+), 15 deletions(-) Index: boost/archive/impl/basic_xml_grammar.hpp =================================================================== --- boost/archive/impl/basic_xml_grammar.hpp.orig 2015-05-23 20:51:06.000000000 +0200 +++ boost/archive/impl/basic_xml_grammar.hpp 2015-12-08 15:47:11.506885556 +0100 @@ -135,7 +135,7 @@ private: Sch, NameChar; - void init_chset(); + BOOST_SYMBOL_VISIBLE void init_chset(); bool my_parse( IStream & is, @@ -143,7 +143,7 @@ private: const CharType delimiter = L'>' ) const ; public: - struct return_values { + BOOST_SYMBOL_VISIBLE struct return_values { StringType object_name; StringType contents; //class_id_type class_id; @@ -159,12 +159,12 @@ public: tracking_level(false) {} } rv; - bool parse_start_tag(IStream & is) /*const*/; - bool parse_end_tag(IStream & is) const; - bool parse_string(IStream & is, StringType & s) /*const*/; - void init(IStream & is); - void windup(IStream & is); - basic_xml_grammar(); + BOOST_SYMBOL_VISIBLE bool parse_start_tag(IStream & is) /*const*/; + BOOST_SYMBOL_VISIBLE bool parse_end_tag(IStream & is) const; + BOOST_SYMBOL_VISIBLE bool parse_string(IStream & is, StringType & s) /*const*/; + BOOST_SYMBOL_VISIBLE void init(IStream & is); + BOOST_SYMBOL_VISIBLE void windup(IStream & is); + BOOST_SYMBOL_VISIBLE basic_xml_grammar(); }; } // namespace archive Index: libs/serialization/src/basic_xml_grammar.ipp =================================================================== --- libs/serialization/src/basic_xml_grammar.ipp.orig 2015-05-23 20:51:06.000000000 +0200 +++ libs/serialization/src/basic_xml_grammar.ipp 2015-12-08 15:41:23.620854565 +0100 @@ -173,7 +173,7 @@ struct append_lit { } // namespace anonymous template -bool basic_xml_grammar::my_parse( +BOOST_SYMBOL_VISIBLE bool basic_xml_grammar::my_parse( typename basic_xml_grammar::IStream & is, const rule_t & rule_, CharType delimiter @@ -211,7 +211,7 @@ bool basic_xml_grammar::my_par } template -bool basic_xml_grammar::parse_start_tag( +BOOST_SYMBOL_VISIBLE bool basic_xml_grammar::parse_start_tag( typename basic_xml_grammar::IStream & is ){ rv.class_name.resize(0); @@ -219,12 +219,12 @@ bool basic_xml_grammar::parse_ } template -bool basic_xml_grammar::parse_end_tag(IStream & is) const { +BOOST_SYMBOL_VISIBLE bool basic_xml_grammar::parse_end_tag(IStream & is) const { return my_parse(is, ETag); } template -bool basic_xml_grammar::parse_string(IStream & is, StringType & s){ +BOOST_SYMBOL_VISIBLE bool basic_xml_grammar::parse_string(IStream & is, StringType & s){ rv.contents.resize(0); bool result = my_parse(is, content, '<'); // note: unget caused a problem with dinkumware. replace with @@ -237,7 +237,7 @@ bool basic_xml_grammar::parse_ } template -basic_xml_grammar::basic_xml_grammar(){ +BOOST_SYMBOL_VISIBLE basic_xml_grammar::basic_xml_grammar(){ init_chset(); S = @@ -434,7 +434,7 @@ basic_xml_grammar::basic_xml_g } template -void basic_xml_grammar::init(IStream & is){ +BOOST_SYMBOL_VISIBLE void basic_xml_grammar::init(IStream & is){ init_chset(); if(! my_parse(is, XMLDecl)) boost::serialization::throw_exception( @@ -455,7 +455,7 @@ void basic_xml_grammar::init(I } template -void basic_xml_grammar::windup(IStream & is){ +BOOST_SYMBOL_VISIBLE void basic_xml_grammar::windup(IStream & is){ if(is.fail() || is.eof()) return; // uh-oh - don't throw exception from code called by a destructor !