std::logical_and
From cppreference.com
                    
                                        
                    < cpp | utility | functional
                    
                                                            
                    |   Defined in header  
<functional>
  | 
||
|   template< class T > 
struct logical_and;  | 
(until C++14) | |
|   template< class T = void > 
struct logical_and;  | 
(since C++14) | |
Function object for performing logical AND (logical conjunction). Effectively calls operator&& on type T.
Contents | 
[edit] Specializations
| 
 The standard library provides a specialization of  
  | 
(since C++14) | 
[edit] Member types
| Type | Definition | 
  result_type
 | 
  bool
 | 
  first_argument_type
 | 
  T
 | 
  second_argument_type
 | 
  T
 | 
[edit] Member functions
|    operator()  | 
   returns the logical AND of the two arguments  (public member function)  | 
std::logical_and::operator()
|   bool operator()( const T& lhs, const T& rhs ) const; 
 | 
(until C++14) | |
|   constexpr bool operator()( const T& lhs, const T& rhs ) const; 
 | 
(since C++14) | |
Returns the logical AND of lhs and rhs.
Parameters
| lhs, rhs | - | values to compute logical AND of | 
Return value
The result of lhs && rhs.
Exceptions
(none)
Possible implementation
constexpr bool operator()(const T &lhs, const T &rhs) const { return lhs && rhs; }  |