catch2/include/internal/catch_section_info.hpp

103 lines
2.8 KiB
C++
Raw Normal View History

/*
* Created by Phil Nash on 4/5/2012
* Copyright 2012 Two Blue Cubes Ltd. All rights reserved.
*
* 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)
*/
#ifndef TWOBLUECUBES_INTERNAL_CATCH_SECTION_INFO_HPP_INCLUDED
#define TWOBLUECUBES_INTERNAL_CATCH_SECTION_INFO_HPP_INCLUDED
#include "catch_common.h"
#include <map>
#include <string>
2012-05-16 00:58:23 +02:00
namespace Catch {
class SectionInfo {
public:
2012-05-16 00:58:23 +02:00
enum Status {
Root,
Unknown,
Branch,
TestedBranch,
TestedLeaf
};
2012-05-16 00:58:23 +02:00
SectionInfo( SectionInfo* parent )
: m_status( Unknown ),
m_parent( parent )
2012-05-16 00:58:23 +02:00
{}
2012-05-16 00:58:23 +02:00
SectionInfo()
: m_status( Root ),
m_parent( NULL )
2012-05-16 00:58:23 +02:00
{}
2012-05-16 00:58:23 +02:00
~SectionInfo() {
deleteAllValues( m_subSections );
}
2012-05-16 00:58:23 +02:00
bool shouldRun() const {
return m_status < TestedBranch;
}
2012-05-16 00:58:23 +02:00
bool ran() {
if( m_status < Branch ) {
m_status = TestedLeaf;
return true;
}
return false;
}
2012-05-16 00:58:23 +02:00
bool isBranch() const {
return m_status == Branch;
}
2012-05-16 00:58:23 +02:00
void ranToCompletion() {
if( m_status == Branch && !hasUntestedSections() )
m_status = TestedBranch;
}
2012-05-16 00:58:23 +02:00
SectionInfo* findSubSection( const std::string& name ) {
std::map<std::string, SectionInfo*>::const_iterator it = m_subSections.find( name );
return it != m_subSections.end()
? it->second
: NULL;
}
2012-05-16 00:58:23 +02:00
SectionInfo* addSubSection( const std::string& name ) {
SectionInfo* subSection = new SectionInfo( this );
m_subSections.insert( std::make_pair( name, subSection ) );
m_status = Branch;
return subSection;
}
2012-05-16 00:58:23 +02:00
SectionInfo* getParent() {
return m_parent;
}
2012-05-16 00:58:23 +02:00
bool hasUntestedSections() const {
if( m_status == Unknown )
return true;
std::map<std::string, SectionInfo*>::const_iterator it = m_subSections.begin();
std::map<std::string, SectionInfo*>::const_iterator itEnd = m_subSections.end();
2012-05-16 00:58:23 +02:00
for(; it != itEnd; ++it ) {
if( it->second->hasUntestedSections() )
return true;
}
return false;
}
private:
Status m_status;
std::map<std::string, SectionInfo*> m_subSections;
SectionInfo* m_parent;
};
}
#endif // TWOBLUECUBES_INTERNAL_CATCH_SECTION_INFO_HPP_INCLUDED