annotate DEPENDENCIES/generic/include/boost/test/utils/runtime/cla/named_parameter.ipp @ 125:34e428693f5d vext

Vext -> Repoint
author Chris Cannam
date Thu, 14 Jun 2018 11:15:39 +0100
parents c530137014c0
children
rev   line source
Chris@16 1 // (C) Copyright Gennadiy Rozental 2005-2008.
Chris@16 2 // Use, modification, and distribution are subject to the
Chris@16 3 // Boost Software License, Version 1.0. (See accompanying file
Chris@16 4 // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
Chris@16 5
Chris@16 6 // See http://www.boost.org/libs/test for the library home page.
Chris@16 7 //
Chris@16 8 // File : $RCSfile$
Chris@16 9 //
Chris@101 10 // Version : $Revision$
Chris@16 11 //
Chris@16 12 // Description : implements model of named parameter
Chris@16 13 // ***************************************************************************
Chris@16 14
Chris@16 15 #ifndef BOOST_RT_CLA_NAMED_PARAMETER_IPP_062904GER
Chris@16 16 #define BOOST_RT_CLA_NAMED_PARAMETER_IPP_062904GER
Chris@16 17
Chris@16 18 // Boost.Runtime.Parameter
Chris@16 19 #include <boost/test/utils/runtime/config.hpp>
Chris@16 20
Chris@16 21 #include <boost/test/utils/runtime/cla/named_parameter.hpp>
Chris@16 22 #include <boost/test/utils/runtime/cla/char_parameter.hpp>
Chris@16 23
Chris@16 24 // Boost.Test
Chris@16 25 #include <boost/test/utils/algorithm.hpp>
Chris@16 26
Chris@16 27 namespace boost {
Chris@16 28
Chris@16 29 namespace BOOST_RT_PARAM_NAMESPACE {
Chris@16 30
Chris@16 31 namespace cla {
Chris@16 32
Chris@16 33 // ************************************************************************** //
Chris@16 34 // ************** string_name_policy ************** //
Chris@16 35 // ************************************************************************** //
Chris@16 36
Chris@16 37 BOOST_RT_PARAM_INLINE
Chris@16 38 string_name_policy::string_name_policy()
Chris@16 39 : basic_naming_policy( rtti::type_id<string_name_policy>() )
Chris@16 40 , m_guess_name( false )
Chris@16 41 {
Chris@16 42 assign_op( p_prefix.value, BOOST_RT_PARAM_CSTRING_LITERAL( "-" ), 0 );
Chris@16 43 }
Chris@16 44
Chris@16 45 //____________________________________________________________________________//
Chris@16 46
Chris@16 47 BOOST_RT_PARAM_INLINE bool
Chris@16 48 string_name_policy::responds_to( cstring name ) const
Chris@16 49 {
Chris@16 50 std::pair<cstring::iterator,dstring::const_iterator> mm_pos;
Chris@16 51
Chris@16 52 mm_pos = unit_test::mismatch( name.begin(), name.end(), p_name->begin(), p_name->end() );
Chris@16 53
Chris@16 54 return mm_pos.first == name.end() && (m_guess_name || (mm_pos.second == p_name->end()) );
Chris@16 55 }
Chris@16 56
Chris@16 57 //____________________________________________________________________________//
Chris@16 58
Chris@16 59 #ifdef BOOST_MSVC
Chris@16 60 # pragma warning(push)
Chris@16 61 # pragma warning(disable:4244)
Chris@16 62 #endif
Chris@16 63
Chris@16 64 BOOST_RT_PARAM_INLINE bool
Chris@16 65 string_name_policy::conflict_with( identification_policy const& id ) const
Chris@16 66 {
Chris@16 67 if( id.p_type_id == p_type_id ) {
Chris@16 68 string_name_policy const& snp = static_cast<string_name_policy const&>( id );
Chris@16 69
Chris@16 70 if( p_name->empty() || snp.p_name->empty() )
Chris@16 71 return false;
Chris@16 72
Chris@16 73 if( p_prefix != snp.p_prefix )
Chris@16 74 return false;
Chris@16 75
Chris@16 76 std::pair<dstring::const_iterator,dstring::const_iterator> mm_pos =
Chris@16 77 unit_test::mismatch( p_name->begin(), p_name->end(), snp.p_name->begin(), snp.p_name->end() );
Chris@16 78
Chris@16 79 return mm_pos.first != p_name->begin() && // there is common substring
Chris@16 80 ((m_guess_name && (mm_pos.second == snp.p_name->end()) ) || // that match other guy and I am guessing
Chris@16 81 (snp.m_guess_name && (mm_pos.first == p_name->end()) )); // or me and the other guy is
Chris@16 82 }
Chris@16 83
Chris@16 84 if( id.p_type_id == rtti::type_id<char_name_policy>() ) {
Chris@16 85 char_name_policy const& cnp = static_cast<char_name_policy const&>( id );
Chris@16 86
Chris@16 87 return m_guess_name &&
Chris@16 88 (p_prefix == cnp.p_prefix) &&
Chris@16 89 unit_test::first_char( cstring( p_name ) ) == unit_test::first_char( cstring( cnp.p_name ) );
Chris@16 90 }
Chris@16 91
Chris@16 92 return false;
Chris@16 93 }
Chris@16 94
Chris@16 95 #ifdef BOOST_MSVC
Chris@16 96 # pragma warning(pop)
Chris@16 97 #endif
Chris@16 98
Chris@16 99 //____________________________________________________________________________//
Chris@16 100
Chris@16 101 BOOST_RT_PARAM_INLINE bool
Chris@16 102 string_name_policy::match_name( argv_traverser& tr ) const
Chris@16 103 {
Chris@16 104 if( !m_guess_name )
Chris@16 105 return basic_naming_policy::match_name( tr );
Chris@16 106
Chris@16 107 cstring in = tr.input();
Chris@16 108
Chris@16 109 std::pair<cstring::iterator,dstring::const_iterator> mm_pos;
Chris@16 110
Chris@16 111 mm_pos = unit_test::mismatch( in.begin(), in.end(), p_name->begin(), p_name->end() );
Chris@16 112
Chris@16 113 if( mm_pos.first == in.begin() )
Chris@16 114 return false;
Chris@16 115
Chris@16 116 tr.trim( mm_pos.first - in.begin() );
Chris@16 117
Chris@16 118 return true;
Chris@16 119 }
Chris@16 120
Chris@16 121 //____________________________________________________________________________//
Chris@16 122
Chris@16 123 } // namespace cla
Chris@16 124
Chris@16 125 } // namespace BOOST_RT_PARAM_NAMESPACE
Chris@16 126
Chris@16 127 } // namespace boost
Chris@16 128
Chris@16 129 #endif // BOOST_RT_CLA_NAMED_PARAMETER_IPP_062904GER