mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 09:41:11 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			180 lines
		
	
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			180 lines
		
	
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //  (C) Copyright Gennadiy Rozental 2005-2008.
 | |
| //  Distributed under the Boost Software License, Version 1.0.
 | |
| //  (See accompanying file LICENSE_1_0.txt or copy at 
 | |
| //  http://www.boost.org/LICENSE_1_0.txt)
 | |
| 
 | |
| //  See http://www.boost.org/libs/test for the library home page.
 | |
| //
 | |
| //  File        : $RCSfile$
 | |
| //
 | |
| //  Version     : $Revision: 57992 $
 | |
| //
 | |
| //  Description : implements XML Log formatter
 | |
| // ***************************************************************************
 | |
| 
 | |
| #ifndef BOOST_TEST_XML_LOG_FORMATTER_IPP_020105GER
 | |
| #define BOOST_TEST_XML_LOG_FORMATTER_IPP_020105GER
 | |
| 
 | |
| // Boost.Test
 | |
| #include <boost/test/output/xml_log_formatter.hpp>
 | |
| #include <boost/test/unit_test_suite_impl.hpp>
 | |
| #include <boost/test/framework.hpp>
 | |
| #include <boost/test/utils/basic_cstring/io.hpp>
 | |
| 
 | |
| #include <boost/test/utils/xml_printer.hpp>
 | |
| 
 | |
| // Boost
 | |
| #include <boost/version.hpp>
 | |
| 
 | |
| // STL
 | |
| #include <iostream>
 | |
| 
 | |
| #include <boost/test/detail/suppress_warnings.hpp>
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| namespace boost {
 | |
| 
 | |
| namespace unit_test {
 | |
| 
 | |
| namespace output {
 | |
| 
 | |
| static const_string tu_type_name( test_unit const& tu )
 | |
| {
 | |
|     return tu.p_type == tut_case ? "TestCase" : "TestSuite";
 | |
| }
 | |
| 
 | |
| // ************************************************************************** //
 | |
| // **************               xml_log_formatter              ************** //
 | |
| // ************************************************************************** //
 | |
| 
 | |
| void
 | |
| xml_log_formatter::log_start( std::ostream& ostr, counter_t )
 | |
| {
 | |
|     ostr  << "<TestLog>";
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| xml_log_formatter::log_finish( std::ostream& ostr )
 | |
| {
 | |
|     ostr  << "</TestLog>";
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| xml_log_formatter::log_build_info( std::ostream& ostr )
 | |
| {
 | |
|     ostr  << "<BuildInfo"
 | |
|             << " platform"  << attr_value() << BOOST_PLATFORM
 | |
|             << " compiler"  << attr_value() << BOOST_COMPILER
 | |
|             << " stl"       << attr_value() << BOOST_STDLIB
 | |
|             << " boost=\""  << BOOST_VERSION/100000     << "."
 | |
|                             << BOOST_VERSION/100 % 1000 << "."
 | |
|                             << BOOST_VERSION % 100      << '\"'
 | |
|             << "/>";
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| xml_log_formatter::test_unit_start( std::ostream& ostr, test_unit const& tu )
 | |
| {
 | |
|     ostr << "<" << tu_type_name( tu ) << " name" << attr_value() << tu.p_name.get() << ">";
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| xml_log_formatter::test_unit_finish( std::ostream& ostr, test_unit const& tu, unsigned long elapsed )
 | |
| {
 | |
|     if( tu.p_type == tut_case )
 | |
|         ostr << "<TestingTime>" << elapsed << "</TestingTime>";
 | |
|         
 | |
|     ostr << "</" << tu_type_name( tu ) << ">";
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| xml_log_formatter::test_unit_skipped( std::ostream& ostr, test_unit const& tu )
 | |
| {
 | |
|     ostr << "<" << tu_type_name( tu )
 | |
|          << " name"    << attr_value() << tu.p_name.get()
 | |
|          << " skipped" << attr_value() << "yes"
 | |
|          << "/>";
 | |
| }
 | |
|     
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| xml_log_formatter::log_exception( std::ostream& ostr, log_checkpoint_data const& checkpoint_data, execution_exception const& ex )
 | |
| {
 | |
|     execution_exception::location const& loc = ex.where();
 | |
| 
 | |
|     ostr << "<Exception file" << attr_value() << loc.m_file_name
 | |
|          << " line"           << attr_value() << loc.m_line_num;
 | |
| 
 | |
|     if( !loc.m_function.is_empty() )
 | |
|         ostr << " function"   << attr_value() << loc.m_function;
 | |
| 
 | |
|     ostr << ">" << cdata() << ex.what();
 | |
| 
 | |
|     if( !checkpoint_data.m_file_name.is_empty() ) {
 | |
|         ostr << "<LastCheckpoint file" << attr_value() << checkpoint_data.m_file_name
 | |
|              << " line"                << attr_value() << checkpoint_data.m_line_num
 | |
|              << ">"
 | |
|              << cdata() << checkpoint_data.m_message
 | |
|              << "</LastCheckpoint>";
 | |
|     }
 | |
| 
 | |
|     ostr << "</Exception>";
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| xml_log_formatter::log_entry_start( std::ostream& ostr, log_entry_data const& entry_data, log_entry_types let )
 | |
| {
 | |
|     static literal_string xml_tags[] = { "Info", "Message", "Warning", "Error", "FatalError" };
 | |
| 
 | |
|     m_curr_tag = xml_tags[let];
 | |
|     ostr << '<' << m_curr_tag
 | |
|          << BOOST_TEST_L( " file" ) << attr_value() << entry_data.m_file_name
 | |
|          << BOOST_TEST_L( " line" ) << attr_value() << entry_data.m_line_num
 | |
|          << BOOST_TEST_L( "><![CDATA[" );
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| xml_log_formatter::log_entry_value( std::ostream& ostr, const_string value )
 | |
| {
 | |
|     ostr << value;
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| void
 | |
| xml_log_formatter::log_entry_finish( std::ostream& ostr )
 | |
| {
 | |
|     ostr << BOOST_TEST_L( "]]></" ) << m_curr_tag << BOOST_TEST_L( ">" );
 | |
| 
 | |
|     m_curr_tag.clear();
 | |
| }
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| } // namespace output
 | |
| 
 | |
| } // namespace unit_test
 | |
| 
 | |
| } // namespace boost
 | |
| 
 | |
| //____________________________________________________________________________//
 | |
| 
 | |
| #include <boost/test/detail/enable_warnings.hpp>
 | |
| 
 | |
| #endif // BOOST_TEST_XML_LOG_FORMATTER_IPP_020105GER
 | 
