// bslalg_selecttrait.h                                               -*-C++-*-
#ifndef INCLUDED_BSLALG_SELECTTRAIT
#define INCLUDED_BSLALG_SELECTTRAIT

#include <bsls_ident.h>
BSLS_IDENT("$Id: $")

//@PURPOSE: Provide a meta-function to select a suitable trait on a type.
//
//@DEPRECATED: Use 'bslmf_selecttrait' instead.
//
//@CLASSES:
//  bslalg::SelectTrait: trait detection mechanism
//
//@SEE_ALSO:
//
//@DESCRIPTION: This component provides a meta-function, 'bslalg::SelectTrait',
// for selecting the most appropriate trait from a list of candidate traits for
// parameterized 'TYPE'.
//
///Usage
///-----

#include <bslscm_version.h>

#include <bslalg_hastrait.h>
#include <bslalg_typetraitnil.h>

#include <bslmf_metaint.h>
#include <bslmf_switch.h>

namespace BloombergLP {

namespace bslalg {

                          // =================
                          // class SelectTrait
                          // =================

template <class TYPE,
          class TRAIT1,
          class TRAIT2 = TypeTraitNil,
          class TRAIT3 = TypeTraitNil,
          class TRAIT4 = TypeTraitNil,
          class TRAIT5 = TypeTraitNil>
struct SelectTrait {
    // Select one trait out of several that the parameterized type 'T' may
    // possess.  If 'T' has the parameterized trait 'TRAIT1', then the nested
    // 'Type' is 'TRAIT1', else if 'T' has an optionally parameterized
    // 'TRAIT2', then 'Type' is 'TRAIT2', etc.  Also computes an integral
    // selection constant and meta-value.  If 'T' has none of the parameterized
    // 'TRAIT*', then the nested 'Type' is 'TypeTraitNil'.

    // PUBLIC TYPES
    enum {
        SELECTION = (HasTrait<TYPE, TRAIT1>::VALUE ? 1 :
                     HasTrait<TYPE, TRAIT2>::VALUE ? 2 :
                     HasTrait<TYPE, TRAIT3>::VALUE ? 3 :
                     HasTrait<TYPE, TRAIT4>::VALUE ? 4 :
                     HasTrait<TYPE, TRAIT5>::VALUE ? 5 :
                     0)
            // Integral value indicating which trait was selected: 1 for
            // 'TRAIT1', 2 for 'TRAIT2', etc., and 0 if none were selected.
    };

    typedef bslmf::MetaInt<SELECTION> MetaSelection;
        // A meta-value representing the same thing a 'SELECTION', but as a
        // type instead of as an integer.

    typedef typename bslmf::Switch<SELECTION,
                                   TypeTraitNil,
                                   TRAIT1,
                                   TRAIT2,
                                   TRAIT3,
                                   TRAIT4,
                                   TRAIT5>::Type Type;
        // The actual trait that was selected, or 'TypeTraitNil' if no trait
        // was selected.
};

}  // close package namespace

#ifndef BDE_OPENSOURCE_PUBLICATION  // BACKWARD_COMPATIBILITY
// ============================================================================
//                           BACKWARD COMPATIBILITY
// ============================================================================

#ifdef bslalg_SelectTrait
#undef bslalg_SelectTrait
#endif
#define bslalg_SelectTrait bslalg::SelectTrait
    // This alias is defined for backward compatibility.
#endif  // BDE_OPENSOURCE_PUBLICATION -- BACKWARD_COMPATIBILITY

}  // close enterprise namespace

#endif

// ----------------------------------------------------------------------------
// Copyright 2013 Bloomberg Finance L.P.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// ----------------------------- END-OF-FILE ----------------------------------