File: first_positive.cpp

package info (click to toggle)
boost 1.32.0-6
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 93,952 kB
  • ctags: 128,458
  • sloc: cpp: 492,477; xml: 52,125; python: 13,519; ansic: 13,013; sh: 1,773; yacc: 853; makefile: 526; perl: 418; lex: 110; csh: 6
file content (48 lines) | stat: -rw-r--r-- 1,216 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Boost.Signals library

// Copyright Douglas Gregor 2001-2003. Use, modification and
// distribution is subject to 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)

// For more information, see http://www.boost.org

#include <boost/signals/signal2.hpp>
#include <iostream>

template<typename T>
struct first_positive {
  typedef T result_type;

  template<typename InputIterator>
  T operator()(InputIterator first, InputIterator last) const
  {
    while (first != last && !(*first > 0)) { ++first; }
    return (first == last) ? 0
                           : *first;
  }
};

template<typename T>
struct noisy_divide {
  typedef T result_type;

  T operator()(const T& x, const T& y) const
  {
    std::cout << "Dividing " << x << " and " << y << std::endl;
    return x/y;
  }
};

int main()
{
  boost::signal2<int, int, int, first_positive<int> > sig_positive;
  sig_positive.connect(std::plus<int>());
  sig_positive.connect(std::multiplies<int>());
  sig_positive.connect(std::minus<int>());
  sig_positive.connect(noisy_divide<int>());

  assert(sig_positive(3, -5) == 8); // returns 8, but prints nothing

  return 0;
}