libstdc++
functional
Go to the documentation of this file.
1 // <functional> -*- C++ -*-
2 
3 // Copyright (C) 2001-2013 Free Software Foundation, Inc.
4 //
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 3, or (at your option)
9 // any later version.
10 
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
15 
16 // Under Section 7 of GPL version 3, you are granted additional
17 // permissions described in the GCC Runtime Library Exception, version
18 // 3.1, as published by the Free Software Foundation.
19 
20 // You should have received a copy of the GNU General Public License and
21 // a copy of the GCC Runtime Library Exception along with this program;
22 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
23 // <http://www.gnu.org/licenses/>.
24 
25 /*
26  * Copyright (c) 1997
27  * Silicon Graphics Computer Systems, Inc.
28  *
29  * Permission to use, copy, modify, distribute and sell this software
30  * and its documentation for any purpose is hereby granted without fee,
31  * provided that the above copyright notice appear in all copies and
32  * that both that copyright notice and this permission notice appear
33  * in supporting documentation. Silicon Graphics makes no
34  * representations about the suitability of this software for any
35  * purpose. It is provided "as is" without express or implied warranty.
36  *
37  */
38 
39 /** @file include/functional
40  * This is a Standard C++ Library header.
41  */
42 
43 #ifndef _GLIBCXX_FUNCTIONAL
44 #define _GLIBCXX_FUNCTIONAL 1
45 
46 #pragma GCC system_header
47 
48 #include <bits/c++config.h>
49 #include <bits/stl_function.h>
50 
51 #if __cplusplus >= 201103L
52 
53 #include <typeinfo>
54 #include <new>
55 #include <tuple>
56 #include <type_traits>
57 #include <bits/functexcept.h>
58 #include <bits/functional_hash.h>
59 
60 namespace std _GLIBCXX_VISIBILITY(default)
61 {
62 _GLIBCXX_BEGIN_NAMESPACE_VERSION
63 
64  template<typename _MemberPointer>
65  class _Mem_fn;
66  template<typename _Tp, typename _Class>
67  _Mem_fn<_Tp _Class::*>
68  mem_fn(_Tp _Class::*) noexcept;
69 
70 _GLIBCXX_HAS_NESTED_TYPE(result_type)
71 
72  /// If we have found a result_type, extract it.
73  template<bool _Has_result_type, typename _Functor>
75  { };
76 
77  template<typename _Functor>
78  struct _Maybe_get_result_type<true, _Functor>
79  { typedef typename _Functor::result_type result_type; };
80 
81  /**
82  * Base class for any function object that has a weak result type, as
83  * defined in 3.3/3 of TR1.
84  */
85  template<typename _Functor>
87  : _Maybe_get_result_type<__has_result_type<_Functor>::value, _Functor>
88  { };
89 
90  /// Retrieve the result type for a function type.
91  template<typename _Res, typename... _ArgTypes>
92  struct _Weak_result_type_impl<_Res(_ArgTypes...)>
93  { typedef _Res result_type; };
94 
95  template<typename _Res, typename... _ArgTypes>
96  struct _Weak_result_type_impl<_Res(_ArgTypes......)>
97  { typedef _Res result_type; };
98 
99  template<typename _Res, typename... _ArgTypes>
100  struct _Weak_result_type_impl<_Res(_ArgTypes...) const>
101  { typedef _Res result_type; };
102 
103  template<typename _Res, typename... _ArgTypes>
104  struct _Weak_result_type_impl<_Res(_ArgTypes......) const>
105  { typedef _Res result_type; };
106 
107  template<typename _Res, typename... _ArgTypes>
108  struct _Weak_result_type_impl<_Res(_ArgTypes...) volatile>
109  { typedef _Res result_type; };
110 
111  template<typename _Res, typename... _ArgTypes>
112  struct _Weak_result_type_impl<_Res(_ArgTypes......) volatile>
113  { typedef _Res result_type; };
114 
115  template<typename _Res, typename... _ArgTypes>
116  struct _Weak_result_type_impl<_Res(_ArgTypes...) const volatile>
117  { typedef _Res result_type; };
118 
119  template<typename _Res, typename... _ArgTypes>
120  struct _Weak_result_type_impl<_Res(_ArgTypes......) const volatile>
121  { typedef _Res result_type; };
122 
123  /// Retrieve the result type for a function reference.
124  template<typename _Res, typename... _ArgTypes>
125  struct _Weak_result_type_impl<_Res(&)(_ArgTypes...)>
126  { typedef _Res result_type; };
127 
128  template<typename _Res, typename... _ArgTypes>
129  struct _Weak_result_type_impl<_Res(&)(_ArgTypes......)>
130  { typedef _Res result_type; };
131 
132  /// Retrieve the result type for a function pointer.
133  template<typename _Res, typename... _ArgTypes>
134  struct _Weak_result_type_impl<_Res(*)(_ArgTypes...)>
135  { typedef _Res result_type; };
136 
137  template<typename _Res, typename... _ArgTypes>
138  struct _Weak_result_type_impl<_Res(*)(_ArgTypes......)>
139  { typedef _Res result_type; };
140 
141  /// Retrieve result type for a member function pointer.
142  template<typename _Res, typename _Class, typename... _ArgTypes>
143  struct _Weak_result_type_impl<_Res (_Class::*)(_ArgTypes...)>
144  { typedef _Res result_type; };
145 
146  template<typename _Res, typename _Class, typename... _ArgTypes>
147  struct _Weak_result_type_impl<_Res (_Class::*)(_ArgTypes......)>
148  { typedef _Res result_type; };
149 
150  /// Retrieve result type for a const member function pointer.
151  template<typename _Res, typename _Class, typename... _ArgTypes>
152  struct _Weak_result_type_impl<_Res (_Class::*)(_ArgTypes...) const>
153  { typedef _Res result_type; };
154 
155  template<typename _Res, typename _Class, typename... _ArgTypes>
156  struct _Weak_result_type_impl<_Res (_Class::*)(_ArgTypes......) const>
157  { typedef _Res result_type; };
158 
159  /// Retrieve result type for a volatile member function pointer.
160  template<typename _Res, typename _Class, typename... _ArgTypes>
161  struct _Weak_result_type_impl<_Res (_Class::*)(_ArgTypes...) volatile>
162  { typedef _Res result_type; };
163 
164  template<typename _Res, typename _Class, typename... _ArgTypes>
165  struct _Weak_result_type_impl<_Res (_Class::*)(_ArgTypes......) volatile>
166  { typedef _Res result_type; };
167 
168  /// Retrieve result type for a const volatile member function pointer.
169  template<typename _Res, typename _Class, typename... _ArgTypes>
170  struct _Weak_result_type_impl<_Res (_Class::*)(_ArgTypes...)
171  const volatile>
172  { typedef _Res result_type; };
173 
174  template<typename _Res, typename _Class, typename... _ArgTypes>
175  struct _Weak_result_type_impl<_Res (_Class::*)(_ArgTypes......)
176  const volatile>
177  { typedef _Res result_type; };
178 
179  /**
180  * Strip top-level cv-qualifiers from the function object and let
181  * _Weak_result_type_impl perform the real work.
182  */
183  template<typename _Functor>
185  : _Weak_result_type_impl<typename remove_cv<_Functor>::type>
186  { };
187 
188  /// Determines if the type _Tp derives from unary_function.
189  template<typename _Tp>
190  struct _Derives_from_unary_function : __sfinae_types
191  {
192  private:
193  template<typename _T1, typename _Res>
194  static __one __test(const volatile unary_function<_T1, _Res>*);
195 
196  // It's tempting to change "..." to const volatile void*, but
197  // that fails when _Tp is a function type.
198  static __two __test(...);
199 
200  public:
201  static const bool value = sizeof(__test((_Tp*)0)) == 1;
202  };
203 
204  /// Determines if the type _Tp derives from binary_function.
205  template<typename _Tp>
206  struct _Derives_from_binary_function : __sfinae_types
207  {
208  private:
209  template<typename _T1, typename _T2, typename _Res>
210  static __one __test(const volatile binary_function<_T1, _T2, _Res>*);
211 
212  // It's tempting to change "..." to const volatile void*, but
213  // that fails when _Tp is a function type.
214  static __two __test(...);
215 
216  public:
217  static const bool value = sizeof(__test((_Tp*)0)) == 1;
218  };
219 
220  /**
221  * Invoke a function object, which may be either a member pointer or a
222  * function object. The first parameter will tell which.
223  */
224  template<typename _Functor, typename... _Args>
225  inline
226  typename enable_if<
230  typename result_of<_Functor&(_Args&&...)>::type
231  >::type
232  __invoke(_Functor& __f, _Args&&... __args)
233  {
234  return __f(std::forward<_Args>(__args)...);
235  }
236 
237  template<typename _Functor, typename... _Args>
238  inline
239  typename enable_if<
240  (is_member_pointer<_Functor>::value
241  && !is_function<_Functor>::value
242  && !is_function<typename remove_pointer<_Functor>::type>::value),
243  typename result_of<_Functor(_Args&&...)>::type
244  >::type
245  __invoke(_Functor& __f, _Args&&... __args)
246  {
247  return std::mem_fn(__f)(std::forward<_Args>(__args)...);
248  }
249 
250  // To pick up function references (that will become function pointers)
251  template<typename _Functor, typename... _Args>
252  inline
253  typename enable_if<
254  (is_pointer<_Functor>::value
255  && is_function<typename remove_pointer<_Functor>::type>::value),
256  typename result_of<_Functor(_Args&&...)>::type
257  >::type
258  __invoke(_Functor __f, _Args&&... __args)
259  {
260  return __f(std::forward<_Args>(__args)...);
261  }
262 
263  /**
264  * Knowing which of unary_function and binary_function _Tp derives
265  * from, derives from the same and ensures that reference_wrapper
266  * will have a weak result type. See cases below.
267  */
268  template<bool _Unary, bool _Binary, typename _Tp>
270 
271  // None of the nested argument types.
272  template<typename _Tp>
273  struct _Reference_wrapper_base_impl<false, false, _Tp>
274  : _Weak_result_type<_Tp>
275  { };
276 
277  // Nested argument_type only.
278  template<typename _Tp>
279  struct _Reference_wrapper_base_impl<true, false, _Tp>
280  : _Weak_result_type<_Tp>
281  {
282  typedef typename _Tp::argument_type argument_type;
283  };
284 
285  // Nested first_argument_type and second_argument_type only.
286  template<typename _Tp>
287  struct _Reference_wrapper_base_impl<false, true, _Tp>
288  : _Weak_result_type<_Tp>
289  {
290  typedef typename _Tp::first_argument_type first_argument_type;
291  typedef typename _Tp::second_argument_type second_argument_type;
292  };
293 
294  // All the nested argument types.
295  template<typename _Tp>
296  struct _Reference_wrapper_base_impl<true, true, _Tp>
297  : _Weak_result_type<_Tp>
298  {
299  typedef typename _Tp::argument_type argument_type;
300  typedef typename _Tp::first_argument_type first_argument_type;
301  typedef typename _Tp::second_argument_type second_argument_type;
302  };
303 
304  _GLIBCXX_HAS_NESTED_TYPE(argument_type)
305  _GLIBCXX_HAS_NESTED_TYPE(first_argument_type)
306  _GLIBCXX_HAS_NESTED_TYPE(second_argument_type)
307 
308  /**
309  * Derives from unary_function or binary_function when it
310  * can. Specializations handle all of the easy cases. The primary
311  * template determines what to do with a class type, which may
312  * derive from both unary_function and binary_function.
313  */
314  template<typename _Tp>
317  __has_argument_type<_Tp>::value,
318  __has_first_argument_type<_Tp>::value
319  && __has_second_argument_type<_Tp>::value,
320  _Tp>
321  { };
322 
323  // - a function type (unary)
324  template<typename _Res, typename _T1>
325  struct _Reference_wrapper_base<_Res(_T1)>
326  : unary_function<_T1, _Res>
327  { };
328 
329  template<typename _Res, typename _T1>
330  struct _Reference_wrapper_base<_Res(_T1) const>
331  : unary_function<_T1, _Res>
332  { };
333 
334  template<typename _Res, typename _T1>
335  struct _Reference_wrapper_base<_Res(_T1) volatile>
336  : unary_function<_T1, _Res>
337  { };
338 
339  template<typename _Res, typename _T1>
340  struct _Reference_wrapper_base<_Res(_T1) const volatile>
341  : unary_function<_T1, _Res>
342  { };
343 
344  // - a function type (binary)
345  template<typename _Res, typename _T1, typename _T2>
346  struct _Reference_wrapper_base<_Res(_T1, _T2)>
347  : binary_function<_T1, _T2, _Res>
348  { };
349 
350  template<typename _Res, typename _T1, typename _T2>
351  struct _Reference_wrapper_base<_Res(_T1, _T2) const>
352  : binary_function<_T1, _T2, _Res>
353  { };
354 
355  template<typename _Res, typename _T1, typename _T2>
356  struct _Reference_wrapper_base<_Res(_T1, _T2) volatile>
357  : binary_function<_T1, _T2, _Res>
358  { };
359 
360  template<typename _Res, typename _T1, typename _T2>
361  struct _Reference_wrapper_base<_Res(_T1, _T2) const volatile>
362  : binary_function<_T1, _T2, _Res>
363  { };
364 
365  // - a function pointer type (unary)
366  template<typename _Res, typename _T1>
367  struct _Reference_wrapper_base<_Res(*)(_T1)>
368  : unary_function<_T1, _Res>
369  { };
370 
371  // - a function pointer type (binary)
372  template<typename _Res, typename _T1, typename _T2>
373  struct _Reference_wrapper_base<_Res(*)(_T1, _T2)>
374  : binary_function<_T1, _T2, _Res>
375  { };
376 
377  // - a pointer to member function type (unary, no qualifiers)
378  template<typename _Res, typename _T1>
379  struct _Reference_wrapper_base<_Res (_T1::*)()>
380  : unary_function<_T1*, _Res>
381  { };
382 
383  // - a pointer to member function type (binary, no qualifiers)
384  template<typename _Res, typename _T1, typename _T2>
385  struct _Reference_wrapper_base<_Res (_T1::*)(_T2)>
386  : binary_function<_T1*, _T2, _Res>
387  { };
388 
389  // - a pointer to member function type (unary, const)
390  template<typename _Res, typename _T1>
391  struct _Reference_wrapper_base<_Res (_T1::*)() const>
392  : unary_function<const _T1*, _Res>
393  { };
394 
395  // - a pointer to member function type (binary, const)
396  template<typename _Res, typename _T1, typename _T2>
397  struct _Reference_wrapper_base<_Res (_T1::*)(_T2) const>
398  : binary_function<const _T1*, _T2, _Res>
399  { };
400 
401  // - a pointer to member function type (unary, volatile)
402  template<typename _Res, typename _T1>
403  struct _Reference_wrapper_base<_Res (_T1::*)() volatile>
404  : unary_function<volatile _T1*, _Res>
405  { };
406 
407  // - a pointer to member function type (binary, volatile)
408  template<typename _Res, typename _T1, typename _T2>
409  struct _Reference_wrapper_base<_Res (_T1::*)(_T2) volatile>
410  : binary_function<volatile _T1*, _T2, _Res>
411  { };
412 
413  // - a pointer to member function type (unary, const volatile)
414  template<typename _Res, typename _T1>
415  struct _Reference_wrapper_base<_Res (_T1::*)() const volatile>
416  : unary_function<const volatile _T1*, _Res>
417  { };
418 
419  // - a pointer to member function type (binary, const volatile)
420  template<typename _Res, typename _T1, typename _T2>
421  struct _Reference_wrapper_base<_Res (_T1::*)(_T2) const volatile>
422  : binary_function<const volatile _T1*, _T2, _Res>
423  { };
424 
425  /**
426  * @brief Primary class template for reference_wrapper.
427  * @ingroup functors
428  * @{
429  */
430  template<typename _Tp>
432  : public _Reference_wrapper_base<typename remove_cv<_Tp>::type>
433  {
434  _Tp* _M_data;
435 
436  public:
437  typedef _Tp type;
438 
439  reference_wrapper(_Tp& __indata) noexcept
440  : _M_data(std::__addressof(__indata))
441  { }
442 
443  reference_wrapper(_Tp&&) = delete;
444 
445  reference_wrapper(const reference_wrapper<_Tp>& __inref) noexcept
446  : _M_data(__inref._M_data)
447  { }
448 
450  operator=(const reference_wrapper<_Tp>& __inref) noexcept
451  {
452  _M_data = __inref._M_data;
453  return *this;
454  }
455 
456  operator _Tp&() const noexcept
457  { return this->get(); }
458 
459  _Tp&
460  get() const noexcept
461  { return *_M_data; }
462 
463  template<typename... _Args>
464  typename result_of<_Tp&(_Args&&...)>::type
465  operator()(_Args&&... __args) const
466  {
467  return __invoke(get(), std::forward<_Args>(__args)...);
468  }
469  };
470 
471 
472  /// Denotes a reference should be taken to a variable.
473  template<typename _Tp>
475  ref(_Tp& __t) noexcept
476  { return reference_wrapper<_Tp>(__t); }
477 
478  /// Denotes a const reference should be taken to a variable.
479  template<typename _Tp>
480  inline reference_wrapper<const _Tp>
481  cref(const _Tp& __t) noexcept
482  { return reference_wrapper<const _Tp>(__t); }
483 
484  template<typename _Tp>
485  void ref(const _Tp&&) = delete;
486 
487  template<typename _Tp>
488  void cref(const _Tp&&) = delete;
489 
490  /// Partial specialization.
491  template<typename _Tp>
492  inline reference_wrapper<_Tp>
494  { return ref(__t.get()); }
495 
496  /// Partial specialization.
497  template<typename _Tp>
498  inline reference_wrapper<const _Tp>
500  { return cref(__t.get()); }
501 
502  // @} group functors
503 
504  template<typename... _Types>
505  struct _Pack : integral_constant<size_t, sizeof...(_Types)>
506  { };
507 
508  template<typename _From, typename _To, bool = _From::value == _To::value>
509  struct _AllConvertible : false_type
510  { };
511 
512  template<typename... _From, typename... _To>
513  struct _AllConvertible<_Pack<_From...>, _Pack<_To...>, true>
514  : __and_<is_convertible<_From, _To>...>
515  { };
516 
517  template<typename _Tp1, typename _Tp2>
518  using _NotSame = __not_<is_same<typename std::decay<_Tp1>::type,
519  typename std::decay<_Tp2>::type>>;
520 
521  /**
522  * Derives from @c unary_function or @c binary_function, or perhaps
523  * nothing, depending on the number of arguments provided. The
524  * primary template is the basis case, which derives nothing.
525  */
526  template<typename _Res, typename... _ArgTypes>
528 
529  /// Derives from @c unary_function, as appropriate.
530  template<typename _Res, typename _T1>
532  : std::unary_function<_T1, _Res> { };
533 
534  /// Derives from @c binary_function, as appropriate.
535  template<typename _Res, typename _T1, typename _T2>
536  struct _Maybe_unary_or_binary_function<_Res, _T1, _T2>
537  : std::binary_function<_T1, _T2, _Res> { };
538 
539  /// Implementation of @c mem_fn for member function pointers.
540  template<typename _Res, typename _Class, typename... _ArgTypes>
541  class _Mem_fn<_Res (_Class::*)(_ArgTypes...)>
542  : public _Maybe_unary_or_binary_function<_Res, _Class*, _ArgTypes...>
543  {
544  typedef _Res (_Class::*_Functor)(_ArgTypes...);
545 
546  template<typename _Tp, typename... _Args>
547  _Res
548  _M_call(_Tp&& __object, const volatile _Class *,
549  _Args&&... __args) const
550  {
551  return (std::forward<_Tp>(__object).*__pmf)
552  (std::forward<_Args>(__args)...);
553  }
554 
555  template<typename _Tp, typename... _Args>
556  _Res
557  _M_call(_Tp&& __ptr, const volatile void *, _Args&&... __args) const
558  { return ((*__ptr).*__pmf)(std::forward<_Args>(__args)...); }
559 
560  // Require each _Args to be convertible to corresponding _ArgTypes
561  template<typename... _Args>
562  using _RequireValidArgs
563  = _Require<_AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
564 
565  // Require each _Args to be convertible to corresponding _ArgTypes
566  // and require _Tp is not _Class, _Class& or _Class*
567  template<typename _Tp, typename... _Args>
568  using _RequireValidArgs2
569  = _Require<_NotSame<_Class, _Tp>, _NotSame<_Class*, _Tp>,
570  _AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
571 
572  // Require each _Args to be convertible to corresponding _ArgTypes
573  // and require _Tp is _Class or derived from _Class
574  template<typename _Tp, typename... _Args>
575  using _RequireValidArgs3
576  = _Require<is_base_of<_Class, _Tp>,
577  _AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
578 
579  public:
580  typedef _Res result_type;
581 
582  explicit _Mem_fn(_Functor __pmf) : __pmf(__pmf) { }
583 
584  // Handle objects
585  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
586  _Res
587  operator()(_Class& __object, _Args&&... __args) const
588  { return (__object.*__pmf)(std::forward<_Args>(__args)...); }
589 
590  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
591  _Res
592  operator()(_Class&& __object, _Args&&... __args) const
593  {
594  return (std::move(__object).*__pmf)(std::forward<_Args>(__args)...);
595  }
596 
597  // Handle pointers
598  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
599  _Res
600  operator()(_Class* __object, _Args&&... __args) const
601  { return (__object->*__pmf)(std::forward<_Args>(__args)...); }
602 
603  // Handle smart pointers, references and pointers to derived
604  template<typename _Tp, typename... _Args,
605  typename _Req = _RequireValidArgs2<_Tp, _Args...>>
606  _Res
607  operator()(_Tp&& __object, _Args&&... __args) const
608  {
609  return _M_call(std::forward<_Tp>(__object), &__object,
610  std::forward<_Args>(__args)...);
611  }
612 
613  template<typename _Tp, typename... _Args,
614  typename _Req = _RequireValidArgs3<_Tp, _Args...>>
615  _Res
616  operator()(reference_wrapper<_Tp> __ref, _Args&&... __args) const
617  { return operator()(__ref.get(), std::forward<_Args>(__args)...); }
618 
619  private:
620  _Functor __pmf;
621  };
622 
623  /// Implementation of @c mem_fn for const member function pointers.
624  template<typename _Res, typename _Class, typename... _ArgTypes>
625  class _Mem_fn<_Res (_Class::*)(_ArgTypes...) const>
626  : public _Maybe_unary_or_binary_function<_Res, const _Class*,
627  _ArgTypes...>
628  {
629  typedef _Res (_Class::*_Functor)(_ArgTypes...) const;
630 
631  template<typename _Tp, typename... _Args>
632  _Res
633  _M_call(_Tp&& __object, const volatile _Class *,
634  _Args&&... __args) const
635  {
636  return (std::forward<_Tp>(__object).*__pmf)
637  (std::forward<_Args>(__args)...);
638  }
639 
640  template<typename _Tp, typename... _Args>
641  _Res
642  _M_call(_Tp&& __ptr, const volatile void *, _Args&&... __args) const
643  { return ((*__ptr).*__pmf)(std::forward<_Args>(__args)...); }
644 
645  template<typename... _Args>
646  using _RequireValidArgs
647  = _Require<_AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
648 
649  template<typename _Tp, typename... _Args>
650  using _RequireValidArgs2
651  = _Require<_NotSame<_Class, _Tp>, _NotSame<const _Class*, _Tp>,
652  _AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
653 
654  template<typename _Tp, typename... _Args>
655  using _RequireValidArgs3
656  = _Require<is_base_of<_Class, _Tp>,
657  _AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
658 
659  public:
660  typedef _Res result_type;
661 
662  explicit _Mem_fn(_Functor __pmf) : __pmf(__pmf) { }
663 
664  // Handle objects
665  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
666  _Res
667  operator()(const _Class& __object, _Args&&... __args) const
668  { return (__object.*__pmf)(std::forward<_Args>(__args)...); }
669 
670  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
671  _Res
672  operator()(const _Class&& __object, _Args&&... __args) const
673  {
674  return (std::move(__object).*__pmf)(std::forward<_Args>(__args)...);
675  }
676 
677  // Handle pointers
678  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
679  _Res
680  operator()(const _Class* __object, _Args&&... __args) const
681  { return (__object->*__pmf)(std::forward<_Args>(__args)...); }
682 
683  // Handle smart pointers, references and pointers to derived
684  template<typename _Tp, typename... _Args,
685  typename _Req = _RequireValidArgs2<_Tp, _Args...>>
686  _Res operator()(_Tp&& __object, _Args&&... __args) const
687  {
688  return _M_call(std::forward<_Tp>(__object), &__object,
689  std::forward<_Args>(__args)...);
690  }
691 
692  template<typename _Tp, typename... _Args,
693  typename _Req = _RequireValidArgs3<_Tp, _Args...>>
694  _Res
695  operator()(reference_wrapper<_Tp> __ref, _Args&&... __args) const
696  { return operator()(__ref.get(), std::forward<_Args>(__args)...); }
697 
698  private:
699  _Functor __pmf;
700  };
701 
702  /// Implementation of @c mem_fn for volatile member function pointers.
703  template<typename _Res, typename _Class, typename... _ArgTypes>
704  class _Mem_fn<_Res (_Class::*)(_ArgTypes...) volatile>
705  : public _Maybe_unary_or_binary_function<_Res, volatile _Class*,
706  _ArgTypes...>
707  {
708  typedef _Res (_Class::*_Functor)(_ArgTypes...) volatile;
709 
710  template<typename _Tp, typename... _Args>
711  _Res
712  _M_call(_Tp&& __object, const volatile _Class *,
713  _Args&&... __args) const
714  {
715  return (std::forward<_Tp>(__object).*__pmf)
716  (std::forward<_Args>(__args)...);
717  }
718 
719  template<typename _Tp, typename... _Args>
720  _Res
721  _M_call(_Tp&& __ptr, const volatile void *, _Args&&... __args) const
722  { return ((*__ptr).*__pmf)(std::forward<_Args>(__args)...); }
723 
724  template<typename... _Args>
725  using _RequireValidArgs
726  = _Require<_AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
727 
728  template<typename _Tp, typename... _Args>
729  using _RequireValidArgs2
730  = _Require<_NotSame<_Class, _Tp>, _NotSame<volatile _Class*, _Tp>,
731  _AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
732 
733  template<typename _Tp, typename... _Args>
734  using _RequireValidArgs3
735  = _Require<is_base_of<_Class, _Tp>,
736  _AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
737 
738  public:
739  typedef _Res result_type;
740 
741  explicit _Mem_fn(_Functor __pmf) : __pmf(__pmf) { }
742 
743  // Handle objects
744  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
745  _Res
746  operator()(volatile _Class& __object, _Args&&... __args) const
747  { return (__object.*__pmf)(std::forward<_Args>(__args)...); }
748 
749  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
750  _Res
751  operator()(volatile _Class&& __object, _Args&&... __args) const
752  {
753  return (std::move(__object).*__pmf)(std::forward<_Args>(__args)...);
754  }
755 
756  // Handle pointers
757  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
758  _Res
759  operator()(volatile _Class* __object, _Args&&... __args) const
760  { return (__object->*__pmf)(std::forward<_Args>(__args)...); }
761 
762  // Handle smart pointers, references and pointers to derived
763  template<typename _Tp, typename... _Args,
764  typename _Req = _RequireValidArgs2<_Tp, _Args...>>
765  _Res
766  operator()(_Tp&& __object, _Args&&... __args) const
767  {
768  return _M_call(std::forward<_Tp>(__object), &__object,
769  std::forward<_Args>(__args)...);
770  }
771 
772  template<typename _Tp, typename... _Args,
773  typename _Req = _RequireValidArgs3<_Tp, _Args...>>
774  _Res
775  operator()(reference_wrapper<_Tp> __ref, _Args&&... __args) const
776  { return operator()(__ref.get(), std::forward<_Args>(__args)...); }
777 
778  private:
779  _Functor __pmf;
780  };
781 
782  /// Implementation of @c mem_fn for const volatile member function pointers.
783  template<typename _Res, typename _Class, typename... _ArgTypes>
784  class _Mem_fn<_Res (_Class::*)(_ArgTypes...) const volatile>
785  : public _Maybe_unary_or_binary_function<_Res, const volatile _Class*,
786  _ArgTypes...>
787  {
788  typedef _Res (_Class::*_Functor)(_ArgTypes...) const volatile;
789 
790  template<typename _Tp, typename... _Args>
791  _Res
792  _M_call(_Tp&& __object, const volatile _Class *,
793  _Args&&... __args) const
794  {
795  return (std::forward<_Tp>(__object).*__pmf)
796  (std::forward<_Args>(__args)...);
797  }
798 
799  template<typename _Tp, typename... _Args>
800  _Res
801  _M_call(_Tp&& __ptr, const volatile void *, _Args&&... __args) const
802  { return ((*__ptr).*__pmf)(std::forward<_Args>(__args)...); }
803 
804  template<typename... _Args>
805  using _RequireValidArgs
806  = _Require<_AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
807 
808  template<typename _Tp, typename... _Args>
809  using _RequireValidArgs2
810  = _Require<_NotSame<_Class, _Tp>,
811  _NotSame<const volatile _Class*, _Tp>,
812  _AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
813 
814  template<typename _Tp, typename... _Args>
815  using _RequireValidArgs3
816  = _Require<is_base_of<_Class, _Tp>,
817  _AllConvertible<_Pack<_Args...>, _Pack<_ArgTypes...>>>;
818 
819  public:
820  typedef _Res result_type;
821 
822  explicit _Mem_fn(_Functor __pmf) : __pmf(__pmf) { }
823 
824  // Handle objects
825  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
826  _Res
827  operator()(const volatile _Class& __object, _Args&&... __args) const
828  { return (__object.*__pmf)(std::forward<_Args>(__args)...); }
829 
830  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
831  _Res
832  operator()(const volatile _Class&& __object, _Args&&... __args) const
833  {
834  return (std::move(__object).*__pmf)(std::forward<_Args>(__args)...);
835  }
836 
837  // Handle pointers
838  template<typename... _Args, typename _Req = _RequireValidArgs<_Args...>>
839  _Res
840  operator()(const volatile _Class* __object, _Args&&... __args) const
841  { return (__object->*__pmf)(std::forward<_Args>(__args)...); }
842 
843  // Handle smart pointers, references and pointers to derived
844  template<typename _Tp, typename... _Args,
845  typename _Req = _RequireValidArgs2<_Tp, _Args...>>
846  _Res operator()(_Tp&& __object, _Args&&... __args) const
847  {
848  return _M_call(std::forward<_Tp>(__object), &__object,
849  std::forward<_Args>(__args)...);
850  }
851 
852  template<typename _Tp, typename... _Args,
853  typename _Req = _RequireValidArgs3<_Tp, _Args...>>
854  _Res
855  operator()(reference_wrapper<_Tp> __ref, _Args&&... __args) const
856  { return operator()(__ref.get(), std::forward<_Args>(__args)...); }
857 
858  private:
859  _Functor __pmf;
860  };
861 
862 
863  template<typename _Tp, bool>
864  struct _Mem_fn_const_or_non
865  {
866  typedef const _Tp& type;
867  };
868 
869  template<typename _Tp>
870  struct _Mem_fn_const_or_non<_Tp, false>
871  {
872  typedef _Tp& type;
873  };
874 
875  template<typename _Res, typename _Class>
876  class _Mem_fn<_Res _Class::*>
877  {
878  using __pm_type = _Res _Class::*;
879 
880  // This bit of genius is due to Peter Dimov, improved slightly by
881  // Douglas Gregor.
882  // Made less elegant to support perfect forwarding and noexcept.
883  template<typename _Tp>
884  auto
885  _M_call(_Tp&& __object, const _Class *) const noexcept
886  -> decltype(std::forward<_Tp>(__object).*std::declval<__pm_type&>())
887  { return std::forward<_Tp>(__object).*__pm; }
888 
889  template<typename _Tp, typename _Up>
890  auto
891  _M_call(_Tp&& __object, _Up * const *) const noexcept
892  -> decltype((*std::forward<_Tp>(__object)).*std::declval<__pm_type&>())
893  { return (*std::forward<_Tp>(__object)).*__pm; }
894 
895  template<typename _Tp>
896  auto
897  _M_call(_Tp&& __ptr, const volatile void*) const
898  noexcept(noexcept((*__ptr).*std::declval<__pm_type&>()))
899  -> decltype((*__ptr).*std::declval<__pm_type&>())
900  { return (*__ptr).*__pm; }
901 
902  public:
903  explicit
904  _Mem_fn(_Res _Class::*__pm) noexcept : __pm(__pm) { }
905 
906  // Handle objects
907  _Res&
908  operator()(_Class& __object) const noexcept
909  { return __object.*__pm; }
910 
911  const _Res&
912  operator()(const _Class& __object) const noexcept
913  { return __object.*__pm; }
914 
915  _Res&&
916  operator()(_Class&& __object) const noexcept
917  { return std::forward<_Class>(__object).*__pm; }
918 
919  const _Res&&
920  operator()(const _Class&& __object) const noexcept
921  { return std::forward<const _Class>(__object).*__pm; }
922 
923  // Handle pointers
924  _Res&
925  operator()(_Class* __object) const noexcept
926  { return __object->*__pm; }
927 
928  const _Res&
929  operator()(const _Class* __object) const noexcept
930  { return __object->*__pm; }
931 
932  // Handle smart pointers and derived
933  template<typename _Tp, typename _Req = _Require<_NotSame<_Class*, _Tp>>>
934  auto
935  operator()(_Tp&& __unknown) const
936  noexcept(noexcept(std::declval<_Mem_fn*>()->_M_call
937  (std::forward<_Tp>(__unknown), &__unknown)))
938  -> decltype(this->_M_call(std::forward<_Tp>(__unknown), &__unknown))
939  { return _M_call(std::forward<_Tp>(__unknown), &__unknown); }
940 
941  template<typename _Tp, typename _Req = _Require<is_base_of<_Class, _Tp>>>
942  auto
943  operator()(reference_wrapper<_Tp> __ref) const
944  noexcept(noexcept(std::declval<_Mem_fn&>()(__ref.get())))
945  -> decltype((*this)(__ref.get()))
946  { return (*this)(__ref.get()); }
947 
948  private:
949  _Res _Class::*__pm;
950  };
951 
952  // _GLIBCXX_RESOLVE_LIB_DEFECTS
953  // 2048. Unnecessary mem_fn overloads
954  /**
955  * @brief Returns a function object that forwards to the member
956  * pointer @a pm.
957  * @ingroup functors
958  */
959  template<typename _Tp, typename _Class>
960  inline _Mem_fn<_Tp _Class::*>
961  mem_fn(_Tp _Class::* __pm) noexcept
962  {
963  return _Mem_fn<_Tp _Class::*>(__pm);
964  }
965 
966  /**
967  * @brief Determines if the given type _Tp is a function object
968  * should be treated as a subexpression when evaluating calls to
969  * function objects returned by bind(). [TR1 3.6.1]
970  * @ingroup binders
971  */
972  template<typename _Tp>
974  : public false_type { };
975 
976  /**
977  * @brief Determines if the given type _Tp is a placeholder in a
978  * bind() expression and, if so, which placeholder it is. [TR1 3.6.2]
979  * @ingroup binders
980  */
981  template<typename _Tp>
984  { };
985 
986  /** @brief The type of placeholder objects defined by libstdc++.
987  * @ingroup binders
988  */
989  template<int _Num> struct _Placeholder { };
990 
991  _GLIBCXX_END_NAMESPACE_VERSION
992 
993  /** @namespace std::placeholders
994  * @brief ISO C++11 entities sub-namespace for functional.
995  * @ingroup binders
996  */
997  namespace placeholders
998  {
999  _GLIBCXX_BEGIN_NAMESPACE_VERSION
1000  /* Define a large number of placeholders. There is no way to
1001  * simplify this with variadic templates, because we're introducing
1002  * unique names for each.
1003  */
1004  extern const _Placeholder<1> _1;
1005  extern const _Placeholder<2> _2;
1006  extern const _Placeholder<3> _3;
1007  extern const _Placeholder<4> _4;
1008  extern const _Placeholder<5> _5;
1009  extern const _Placeholder<6> _6;
1010  extern const _Placeholder<7> _7;
1011  extern const _Placeholder<8> _8;
1012  extern const _Placeholder<9> _9;
1013  extern const _Placeholder<10> _10;
1014  extern const _Placeholder<11> _11;
1015  extern const _Placeholder<12> _12;
1016  extern const _Placeholder<13> _13;
1017  extern const _Placeholder<14> _14;
1018  extern const _Placeholder<15> _15;
1019  extern const _Placeholder<16> _16;
1020  extern const _Placeholder<17> _17;
1021  extern const _Placeholder<18> _18;
1022  extern const _Placeholder<19> _19;
1023  extern const _Placeholder<20> _20;
1024  extern const _Placeholder<21> _21;
1025  extern const _Placeholder<22> _22;
1026  extern const _Placeholder<23> _23;
1027  extern const _Placeholder<24> _24;
1028  extern const _Placeholder<25> _25;
1029  extern const _Placeholder<26> _26;
1030  extern const _Placeholder<27> _27;
1031  extern const _Placeholder<28> _28;
1032  extern const _Placeholder<29> _29;
1033  _GLIBCXX_END_NAMESPACE_VERSION
1034  }
1035 
1036  _GLIBCXX_BEGIN_NAMESPACE_VERSION
1037 
1038  /**
1039  * Partial specialization of is_placeholder that provides the placeholder
1040  * number for the placeholder objects defined by libstdc++.
1041  * @ingroup binders
1042  */
1043  template<int _Num>
1046  { };
1047 
1048  template<int _Num>
1049  struct is_placeholder<const _Placeholder<_Num> >
1050  : public integral_constant<int, _Num>
1051  { };
1052 
1053  /**
1054  * Used by _Safe_tuple_element to indicate that there is no tuple
1055  * element at this position.
1056  */
1057  struct _No_tuple_element;
1058 
1059  /**
1060  * Implementation helper for _Safe_tuple_element. This primary
1061  * template handles the case where it is safe to use @c
1062  * tuple_element.
1063  */
1064  template<std::size_t __i, typename _Tuple, bool _IsSafe>
1066  : tuple_element<__i, _Tuple> { };
1067 
1068  /**
1069  * Implementation helper for _Safe_tuple_element. This partial
1070  * specialization handles the case where it is not safe to use @c
1071  * tuple_element. We just return @c _No_tuple_element.
1072  */
1073  template<std::size_t __i, typename _Tuple>
1074  struct _Safe_tuple_element_impl<__i, _Tuple, false>
1075  {
1076  typedef _No_tuple_element type;
1077  };
1078 
1079  /**
1080  * Like tuple_element, but returns @c _No_tuple_element when
1081  * tuple_element would return an error.
1082  */
1083  template<std::size_t __i, typename _Tuple>
1085  : _Safe_tuple_element_impl<__i, _Tuple,
1086  (__i < tuple_size<_Tuple>::value)>
1087  { };
1088 
1089  /**
1090  * Maps an argument to bind() into an actual argument to the bound
1091  * function object [TR1 3.6.3/5]. Only the first parameter should
1092  * be specified: the rest are used to determine among the various
1093  * implementations. Note that, although this class is a function
1094  * object, it isn't entirely normal because it takes only two
1095  * parameters regardless of the number of parameters passed to the
1096  * bind expression. The first parameter is the bound argument and
1097  * the second parameter is a tuple containing references to the
1098  * rest of the arguments.
1099  */
1100  template<typename _Arg,
1101  bool _IsBindExp = is_bind_expression<_Arg>::value,
1102  bool _IsPlaceholder = (is_placeholder<_Arg>::value > 0)>
1103  class _Mu;
1104 
1105  /**
1106  * If the argument is reference_wrapper<_Tp>, returns the
1107  * underlying reference. [TR1 3.6.3/5 bullet 1]
1108  */
1109  template<typename _Tp>
1110  class _Mu<reference_wrapper<_Tp>, false, false>
1111  {
1112  public:
1113  typedef _Tp& result_type;
1114 
1115  /* Note: This won't actually work for const volatile
1116  * reference_wrappers, because reference_wrapper::get() is const
1117  * but not volatile-qualified. This might be a defect in the TR.
1118  */
1119  template<typename _CVRef, typename _Tuple>
1120  result_type
1121  operator()(_CVRef& __arg, _Tuple&) const volatile
1122  { return __arg.get(); }
1123  };
1124 
1125  /**
1126  * If the argument is a bind expression, we invoke the underlying
1127  * function object with the same cv-qualifiers as we are given and
1128  * pass along all of our arguments (unwrapped). [TR1 3.6.3/5 bullet 2]
1129  */
1130  template<typename _Arg>
1131  class _Mu<_Arg, true, false>
1132  {
1133  public:
1134  template<typename _CVArg, typename... _Args>
1135  auto
1136  operator()(_CVArg& __arg,
1137  tuple<_Args...>& __tuple) const volatile
1138  -> decltype(__arg(declval<_Args>()...))
1139  {
1140  // Construct an index tuple and forward to __call
1141  typedef typename _Build_index_tuple<sizeof...(_Args)>::__type
1142  _Indexes;
1143  return this->__call(__arg, __tuple, _Indexes());
1144  }
1145 
1146  private:
1147  // Invokes the underlying function object __arg by unpacking all
1148  // of the arguments in the tuple.
1149  template<typename _CVArg, typename... _Args, std::size_t... _Indexes>
1150  auto
1151  __call(_CVArg& __arg, tuple<_Args...>& __tuple,
1152  const _Index_tuple<_Indexes...>&) const volatile
1153  -> decltype(__arg(declval<_Args>()...))
1154  {
1155  return __arg(std::forward<_Args>(get<_Indexes>(__tuple))...);
1156  }
1157  };
1158 
1159  /**
1160  * If the argument is a placeholder for the Nth argument, returns
1161  * a reference to the Nth argument to the bind function object.
1162  * [TR1 3.6.3/5 bullet 3]
1163  */
1164  template<typename _Arg>
1165  class _Mu<_Arg, false, true>
1166  {
1167  public:
1168  template<typename _Signature> class result;
1169 
1170  template<typename _CVMu, typename _CVArg, typename _Tuple>
1171  class result<_CVMu(_CVArg, _Tuple)>
1172  {
1173  // Add a reference, if it hasn't already been done for us.
1174  // This allows us to be a little bit sloppy in constructing
1175  // the tuple that we pass to result_of<...>.
1177  - 1), _Tuple>::type
1178  __base_type;
1179 
1180  public:
1181  typedef typename add_rvalue_reference<__base_type>::type type;
1182  };
1183 
1184  template<typename _Tuple>
1185  typename result<_Mu(_Arg, _Tuple)>::type
1186  operator()(const volatile _Arg&, _Tuple& __tuple) const volatile
1187  {
1188  return std::forward<typename result<_Mu(_Arg, _Tuple)>::type>(
1189  ::std::get<(is_placeholder<_Arg>::value - 1)>(__tuple));
1190  }
1191  };
1192 
1193  /**
1194  * If the argument is just a value, returns a reference to that
1195  * value. The cv-qualifiers on the reference are the same as the
1196  * cv-qualifiers on the _Mu object. [TR1 3.6.3/5 bullet 4]
1197  */
1198  template<typename _Arg>
1199  class _Mu<_Arg, false, false>
1200  {
1201  public:
1202  template<typename _Signature> struct result;
1203 
1204  template<typename _CVMu, typename _CVArg, typename _Tuple>
1205  struct result<_CVMu(_CVArg, _Tuple)>
1206  {
1207  typedef typename add_lvalue_reference<_CVArg>::type type;
1208  };
1209 
1210  // Pick up the cv-qualifiers of the argument
1211  template<typename _CVArg, typename _Tuple>
1212  _CVArg&&
1213  operator()(_CVArg&& __arg, _Tuple&) const volatile
1214  { return std::forward<_CVArg>(__arg); }
1215  };
1216 
1217  /**
1218  * Maps member pointers into instances of _Mem_fn but leaves all
1219  * other function objects untouched. Used by tr1::bind(). The
1220  * primary template handles the non--member-pointer case.
1221  */
1222  template<typename _Tp>
1224  {
1225  typedef _Tp type;
1226 
1227  static const _Tp&
1228  __do_wrap(const _Tp& __x)
1229  { return __x; }
1230 
1231  static _Tp&&
1232  __do_wrap(_Tp&& __x)
1233  { return static_cast<_Tp&&>(__x); }
1234  };
1235 
1236  /**
1237  * Maps member pointers into instances of _Mem_fn but leaves all
1238  * other function objects untouched. Used by tr1::bind(). This
1239  * partial specialization handles the member pointer case.
1240  */
1241  template<typename _Tp, typename _Class>
1242  struct _Maybe_wrap_member_pointer<_Tp _Class::*>
1243  {
1244  typedef _Mem_fn<_Tp _Class::*> type;
1245 
1246  static type
1247  __do_wrap(_Tp _Class::* __pm)
1248  { return type(__pm); }
1249  };
1250 
1251  // Specialization needed to prevent "forming reference to void" errors when
1252  // bind<void>() is called, because argument deduction instantiates
1253  // _Maybe_wrap_member_pointer<void> outside the immediate context where
1254  // SFINAE applies.
1255  template<>
1256  struct _Maybe_wrap_member_pointer<void>
1257  {
1258  typedef void type;
1259  };
1260 
1261  // std::get<I> for volatile-qualified tuples
1262  template<std::size_t _Ind, typename... _Tp>
1263  inline auto
1264  __volget(volatile tuple<_Tp...>& __tuple)
1265  -> typename tuple_element<_Ind, tuple<_Tp...>>::type volatile&
1266  { return std::get<_Ind>(const_cast<tuple<_Tp...>&>(__tuple)); }
1267 
1268  // std::get<I> for const-volatile-qualified tuples
1269  template<std::size_t _Ind, typename... _Tp>
1270  inline auto
1271  __volget(const volatile tuple<_Tp...>& __tuple)
1272  -> typename tuple_element<_Ind, tuple<_Tp...>>::type const volatile&
1273  { return std::get<_Ind>(const_cast<const tuple<_Tp...>&>(__tuple)); }
1274 
1275  /// Type of the function object returned from bind().
1276  template<typename _Signature>
1277  struct _Bind;
1278 
1279  template<typename _Functor, typename... _Bound_args>
1280  class _Bind<_Functor(_Bound_args...)>
1281  : public _Weak_result_type<_Functor>
1282  {
1283  typedef _Bind __self_type;
1284  typedef typename _Build_index_tuple<sizeof...(_Bound_args)>::__type
1285  _Bound_indexes;
1286 
1287  _Functor _M_f;
1288  tuple<_Bound_args...> _M_bound_args;
1289 
1290  // Call unqualified
1291  template<typename _Result, typename... _Args, std::size_t... _Indexes>
1292  _Result
1293  __call(tuple<_Args...>&& __args, _Index_tuple<_Indexes...>)
1294  {
1295  return _M_f(_Mu<_Bound_args>()
1296  (get<_Indexes>(_M_bound_args), __args)...);
1297  }
1298 
1299  // Call as const
1300  template<typename _Result, typename... _Args, std::size_t... _Indexes>
1301  _Result
1302  __call_c(tuple<_Args...>&& __args, _Index_tuple<_Indexes...>) const
1303  {
1304  return _M_f(_Mu<_Bound_args>()
1305  (get<_Indexes>(_M_bound_args), __args)...);
1306  }
1307 
1308  // Call as volatile
1309  template<typename _Result, typename... _Args, std::size_t... _Indexes>
1310  _Result
1311  __call_v(tuple<_Args...>&& __args,
1312  _Index_tuple<_Indexes...>) volatile
1313  {
1314  return _M_f(_Mu<_Bound_args>()
1315  (__volget<_Indexes>(_M_bound_args), __args)...);
1316  }
1317 
1318  // Call as const volatile
1319  template<typename _Result, typename... _Args, std::size_t... _Indexes>
1320  _Result
1321  __call_c_v(tuple<_Args...>&& __args,
1322  _Index_tuple<_Indexes...>) const volatile
1323  {
1324  return _M_f(_Mu<_Bound_args>()
1325  (__volget<_Indexes>(_M_bound_args), __args)...);
1326  }
1327 
1328  public:
1329  template<typename... _Args>
1330  explicit _Bind(const _Functor& __f, _Args&&... __args)
1331  : _M_f(__f), _M_bound_args(std::forward<_Args>(__args)...)
1332  { }
1333 
1334  template<typename... _Args>
1335  explicit _Bind(_Functor&& __f, _Args&&... __args)
1336  : _M_f(std::move(__f)), _M_bound_args(std::forward<_Args>(__args)...)
1337  { }
1338 
1339  _Bind(const _Bind&) = default;
1340 
1341  _Bind(_Bind&& __b)
1342  : _M_f(std::move(__b._M_f)), _M_bound_args(std::move(__b._M_bound_args))
1343  { }
1344 
1345  // Call unqualified
1346  template<typename... _Args, typename _Result
1347  = decltype( std::declval<_Functor>()(
1348  _Mu<_Bound_args>()( std::declval<_Bound_args&>(),
1349  std::declval<tuple<_Args...>&>() )... ) )>
1350  _Result
1351  operator()(_Args&&... __args)
1352  {
1353  return this->__call<_Result>(
1354  std::forward_as_tuple(std::forward<_Args>(__args)...),
1355  _Bound_indexes());
1356  }
1357 
1358  // Call as const
1359  template<typename... _Args, typename _Result
1360  = decltype( std::declval<typename enable_if<(sizeof...(_Args) >= 0),
1361  typename add_const<_Functor>::type>::type>()(
1362  _Mu<_Bound_args>()( std::declval<const _Bound_args&>(),
1363  std::declval<tuple<_Args...>&>() )... ) )>
1364  _Result
1365  operator()(_Args&&... __args) const
1366  {
1367  return this->__call_c<_Result>(
1368  std::forward_as_tuple(std::forward<_Args>(__args)...),
1369  _Bound_indexes());
1370  }
1371 
1372  // Call as volatile
1373  template<typename... _Args, typename _Result
1374  = decltype( std::declval<typename enable_if<(sizeof...(_Args) >= 0),
1375  typename add_volatile<_Functor>::type>::type>()(
1376  _Mu<_Bound_args>()( std::declval<volatile _Bound_args&>(),
1377  std::declval<tuple<_Args...>&>() )... ) )>
1378  _Result
1379  operator()(_Args&&... __args) volatile
1380  {
1381  return this->__call_v<_Result>(
1382  std::forward_as_tuple(std::forward<_Args>(__args)...),
1383  _Bound_indexes());
1384  }
1385 
1386  // Call as const volatile
1387  template<typename... _Args, typename _Result
1388  = decltype( std::declval<typename enable_if<(sizeof...(_Args) >= 0),
1389  typename add_cv<_Functor>::type>::type>()(
1390  _Mu<_Bound_args>()( std::declval<const volatile _Bound_args&>(),
1391  std::declval<tuple<_Args...>&>() )... ) )>
1392  _Result
1393  operator()(_Args&&... __args) const volatile
1394  {
1395  return this->__call_c_v<_Result>(
1396  std::forward_as_tuple(std::forward<_Args>(__args)...),
1397  _Bound_indexes());
1398  }
1399  };
1400 
1401  /// Type of the function object returned from bind<R>().
1402  template<typename _Result, typename _Signature>
1404 
1405  template<typename _Result, typename _Functor, typename... _Bound_args>
1406  class _Bind_result<_Result, _Functor(_Bound_args...)>
1407  {
1408  typedef _Bind_result __self_type;
1409  typedef typename _Build_index_tuple<sizeof...(_Bound_args)>::__type
1410  _Bound_indexes;
1411 
1412  _Functor _M_f;
1413  tuple<_Bound_args...> _M_bound_args;
1414 
1415  // sfinae types
1416  template<typename _Res>
1417  struct __enable_if_void : enable_if<is_void<_Res>::value, int> { };
1418  template<typename _Res>
1419  struct __disable_if_void : enable_if<!is_void<_Res>::value, int> { };
1420 
1421  // Call unqualified
1422  template<typename _Res, typename... _Args, std::size_t... _Indexes>
1423  _Result
1424  __call(tuple<_Args...>&& __args, _Index_tuple<_Indexes...>,
1425  typename __disable_if_void<_Res>::type = 0)
1426  {
1427  return _M_f(_Mu<_Bound_args>()
1428  (get<_Indexes>(_M_bound_args), __args)...);
1429  }
1430 
1431  // Call unqualified, return void
1432  template<typename _Res, typename... _Args, std::size_t... _Indexes>
1433  void
1434  __call(tuple<_Args...>&& __args, _Index_tuple<_Indexes...>,
1435  typename __enable_if_void<_Res>::type = 0)
1436  {
1437  _M_f(_Mu<_Bound_args>()
1438  (get<_Indexes>(_M_bound_args), __args)...);
1439  }
1440 
1441  // Call as const
1442  template<typename _Res, typename... _Args, std::size_t... _Indexes>
1443  _Result
1444  __call(tuple<_Args...>&& __args, _Index_tuple<_Indexes...>,
1445  typename __disable_if_void<_Res>::type = 0) const
1446  {
1447  return _M_f(_Mu<_Bound_args>()
1448  (get<_Indexes>(_M_bound_args), __args)...);
1449  }
1450 
1451  // Call as const, return void
1452  template<typename _Res, typename... _Args, std::size_t... _Indexes>
1453  void
1454  __call(tuple<_Args...>&& __args, _Index_tuple<_Indexes...>,
1455  typename __enable_if_void<_Res>::type = 0) const
1456  {
1457  _M_f(_Mu<_Bound_args>()
1458  (get<_Indexes>(_M_bound_args), __args)...);
1459  }
1460 
1461  // Call as volatile
1462  template<typename _Res, typename... _Args, std::size_t... _Indexes>
1463  _Result
1464  __call(tuple<_Args...>&& __args, _Index_tuple<_Indexes...>,
1465  typename __disable_if_void<_Res>::type = 0) volatile
1466  {
1467  return _M_f(_Mu<_Bound_args>()
1468  (__volget<_Indexes>(_M_bound_args), __args)...);
1469  }
1470 
1471  // Call as volatile, return void
1472  template<typename _Res, typename... _Args, std::size_t... _Indexes>
1473  void
1474  __call(tuple<_Args...>&& __args, _Index_tuple<_Indexes...>,
1475  typename __enable_if_void<_Res>::type = 0) volatile
1476  {
1477  _M_f(_Mu<_Bound_args>()
1478  (__volget<_Indexes>(_M_bound_args), __args)...);
1479  }
1480 
1481  // Call as const volatile
1482  template<typename _Res, typename... _Args, std::size_t... _Indexes>
1483  _Result
1484  __call(tuple<_Args...>&& __args, _Index_tuple<_Indexes...>,
1485  typename __disable_if_void<_Res>::type = 0) const volatile
1486  {
1487  return _M_f(_Mu<_Bound_args>()
1488  (__volget<_Indexes>(_M_bound_args), __args)...);
1489  }
1490 
1491  // Call as const volatile, return void
1492  template<typename _Res, typename... _Args, std::size_t... _Indexes>
1493  void
1494  __call(tuple<_Args...>&& __args,
1495  _Index_tuple<_Indexes...>,
1496  typename __enable_if_void<_Res>::type = 0) const volatile
1497  {
1498  _M_f(_Mu<_Bound_args>()
1499  (__volget<_Indexes>(_M_bound_args), __args)...);
1500  }
1501 
1502  public:
1503  typedef _Result result_type;
1504 
1505  template<typename... _Args>
1506  explicit _Bind_result(const _Functor& __f, _Args&&... __args)
1507  : _M_f(__f), _M_bound_args(std::forward<_Args>(__args)...)
1508  { }
1509 
1510  template<typename... _Args>
1511  explicit _Bind_result(_Functor&& __f, _Args&&... __args)
1512  : _M_f(std::move(__f)), _M_bound_args(std::forward<_Args>(__args)...)
1513  { }
1514 
1515  _Bind_result(const _Bind_result&) = default;
1516 
1517  _Bind_result(_Bind_result&& __b)
1518  : _M_f(std::move(__b._M_f)), _M_bound_args(std::move(__b._M_bound_args))
1519  { }
1520 
1521  // Call unqualified
1522  template<typename... _Args>
1523  result_type
1524  operator()(_Args&&... __args)
1525  {
1526  return this->__call<_Result>(
1527  std::forward_as_tuple(std::forward<_Args>(__args)...),
1528  _Bound_indexes());
1529  }
1530 
1531  // Call as const
1532  template<typename... _Args>
1533  result_type
1534  operator()(_Args&&... __args) const
1535  {
1536  return this->__call<_Result>(
1537  std::forward_as_tuple(std::forward<_Args>(__args)...),
1538  _Bound_indexes());
1539  }
1540 
1541  // Call as volatile
1542  template<typename... _Args>
1543  result_type
1544  operator()(_Args&&... __args) volatile
1545  {
1546  return this->__call<_Result>(
1547  std::forward_as_tuple(std::forward<_Args>(__args)...),
1548  _Bound_indexes());
1549  }
1550 
1551  // Call as const volatile
1552  template<typename... _Args>
1553  result_type
1554  operator()(_Args&&... __args) const volatile
1555  {
1556  return this->__call<_Result>(
1557  std::forward_as_tuple(std::forward<_Args>(__args)...),
1558  _Bound_indexes());
1559  }
1560  };
1561 
1562  /**
1563  * @brief Class template _Bind is always a bind expression.
1564  * @ingroup binders
1565  */
1566  template<typename _Signature>
1567  struct is_bind_expression<_Bind<_Signature> >
1568  : public true_type { };
1569 
1570  /**
1571  * @brief Class template _Bind is always a bind expression.
1572  * @ingroup binders
1573  */
1574  template<typename _Signature>
1575  struct is_bind_expression<const _Bind<_Signature> >
1576  : public true_type { };
1577 
1578  /**
1579  * @brief Class template _Bind is always a bind expression.
1580  * @ingroup binders
1581  */
1582  template<typename _Signature>
1583  struct is_bind_expression<volatile _Bind<_Signature> >
1584  : public true_type { };
1585 
1586  /**
1587  * @brief Class template _Bind is always a bind expression.
1588  * @ingroup binders
1589  */
1590  template<typename _Signature>
1591  struct is_bind_expression<const volatile _Bind<_Signature>>
1592  : public true_type { };
1593 
1594  /**
1595  * @brief Class template _Bind_result is always a bind expression.
1596  * @ingroup binders
1597  */
1598  template<typename _Result, typename _Signature>
1599  struct is_bind_expression<_Bind_result<_Result, _Signature>>
1600  : public true_type { };
1601 
1602  /**
1603  * @brief Class template _Bind_result is always a bind expression.
1604  * @ingroup binders
1605  */
1606  template<typename _Result, typename _Signature>
1607  struct is_bind_expression<const _Bind_result<_Result, _Signature>>
1608  : public true_type { };
1609 
1610  /**
1611  * @brief Class template _Bind_result is always a bind expression.
1612  * @ingroup binders
1613  */
1614  template<typename _Result, typename _Signature>
1615  struct is_bind_expression<volatile _Bind_result<_Result, _Signature>>
1616  : public true_type { };
1617 
1618  /**
1619  * @brief Class template _Bind_result is always a bind expression.
1620  * @ingroup binders
1621  */
1622  template<typename _Result, typename _Signature>
1623  struct is_bind_expression<const volatile _Bind_result<_Result, _Signature>>
1624  : public true_type { };
1625 
1626  // Trait type used to remove std::bind() from overload set via SFINAE
1627  // when first argument has integer type, so that std::bind() will
1628  // not be a better match than ::bind() from the BSD Sockets API.
1629  template<typename _Tp, typename _Tp2 = typename decay<_Tp>::type>
1630  using __is_socketlike = __or_<is_integral<_Tp2>, is_enum<_Tp2>>;
1631 
1632  template<bool _SocketLike, typename _Func, typename... _BoundArgs>
1633  struct _Bind_helper
1634  {
1636  __maybe_type;
1637  typedef typename __maybe_type::type __func_type;
1639  };
1640 
1641  // Partial specialization for is_socketlike == true, does not define
1642  // nested type so std::bind() will not participate in overload resolution
1643  // when the first argument might be a socket file descriptor.
1644  template<typename _Func, typename... _BoundArgs>
1645  struct _Bind_helper<true, _Func, _BoundArgs...>
1646  { };
1647 
1648  /**
1649  * @brief Function template for std::bind.
1650  * @ingroup binders
1651  */
1652  template<typename _Func, typename... _BoundArgs>
1653  inline typename
1654  _Bind_helper<__is_socketlike<_Func>::value, _Func, _BoundArgs...>::type
1655  bind(_Func&& __f, _BoundArgs&&... __args)
1656  {
1657  typedef _Bind_helper<false, _Func, _BoundArgs...> __helper_type;
1658  typedef typename __helper_type::__maybe_type __maybe_type;
1659  typedef typename __helper_type::type __result_type;
1660  return __result_type(__maybe_type::__do_wrap(std::forward<_Func>(__f)),
1661  std::forward<_BoundArgs>(__args)...);
1662  }
1663 
1664  template<typename _Result, typename _Func, typename... _BoundArgs>
1665  struct _Bindres_helper
1666  {
1667  typedef _Maybe_wrap_member_pointer<typename decay<_Func>::type>
1668  __maybe_type;
1669  typedef typename __maybe_type::type __functor_type;
1670  typedef _Bind_result<_Result,
1671  __functor_type(typename decay<_BoundArgs>::type...)>
1672  type;
1673  };
1674 
1675  /**
1676  * @brief Function template for std::bind<R>.
1677  * @ingroup binders
1678  */
1679  template<typename _Result, typename _Func, typename... _BoundArgs>
1680  inline
1681  typename _Bindres_helper<_Result, _Func, _BoundArgs...>::type
1682  bind(_Func&& __f, _BoundArgs&&... __args)
1683  {
1684  typedef _Bindres_helper<_Result, _Func, _BoundArgs...> __helper_type;
1685  typedef typename __helper_type::__maybe_type __maybe_type;
1686  typedef typename __helper_type::type __result_type;
1687  return __result_type(__maybe_type::__do_wrap(std::forward<_Func>(__f)),
1688  std::forward<_BoundArgs>(__args)...);
1689  }
1690 
1691  template<typename _Signature>
1692  struct _Bind_simple;
1693 
1694  template<typename _Callable, typename... _Args>
1695  struct _Bind_simple<_Callable(_Args...)>
1696  {
1697  typedef typename result_of<_Callable(_Args...)>::type result_type;
1698 
1699  template<typename... _Args2, typename = typename
1700  enable_if< sizeof...(_Args) == sizeof...(_Args2)>::type>
1701  explicit
1702  _Bind_simple(const _Callable& __callable, _Args2&&... __args)
1703  : _M_bound(__callable, std::forward<_Args2>(__args)...)
1704  { }
1705 
1706  template<typename... _Args2, typename = typename
1707  enable_if< sizeof...(_Args) == sizeof...(_Args2)>::type>
1708  explicit
1709  _Bind_simple(_Callable&& __callable, _Args2&&... __args)
1710  : _M_bound(std::move(__callable), std::forward<_Args2>(__args)...)
1711  { }
1712 
1713  _Bind_simple(const _Bind_simple&) = default;
1714  _Bind_simple(_Bind_simple&&) = default;
1715 
1716  result_type
1717  operator()()
1718  {
1719  typedef typename _Build_index_tuple<sizeof...(_Args)>::__type _Indices;
1720  return _M_invoke(_Indices());
1721  }
1722 
1723  private:
1724 
1725  template<std::size_t... _Indices>
1726  typename result_of<_Callable(_Args...)>::type
1727  _M_invoke(_Index_tuple<_Indices...>)
1728  {
1729  // std::bind always forwards bound arguments as lvalues,
1730  // but this type can call functions which only accept rvalues.
1731  return std::forward<_Callable>(std::get<0>(_M_bound))(
1732  std::forward<_Args>(std::get<_Indices+1>(_M_bound))...);
1733  }
1734 
1735  std::tuple<_Callable, _Args...> _M_bound;
1736  };
1737 
1738  template<typename _Func, typename... _BoundArgs>
1739  struct _Bind_simple_helper
1740  {
1741  typedef _Maybe_wrap_member_pointer<typename decay<_Func>::type>
1742  __maybe_type;
1743  typedef typename __maybe_type::type __func_type;
1744  typedef _Bind_simple<__func_type(typename decay<_BoundArgs>::type...)>
1745  __type;
1746  };
1747 
1748  // Simplified version of std::bind for internal use, without support for
1749  // unbound arguments, placeholders or nested bind expressions.
1750  template<typename _Callable, typename... _Args>
1751  typename _Bind_simple_helper<_Callable, _Args...>::__type
1752  __bind_simple(_Callable&& __callable, _Args&&... __args)
1753  {
1754  typedef _Bind_simple_helper<_Callable, _Args...> __helper_type;
1755  typedef typename __helper_type::__maybe_type __maybe_type;
1756  typedef typename __helper_type::__type __result_type;
1757  return __result_type(
1758  __maybe_type::__do_wrap( std::forward<_Callable>(__callable)),
1759  std::forward<_Args>(__args)...);
1760  }
1761 
1762  /**
1763  * @brief Exception class thrown when class template function's
1764  * operator() is called with an empty target.
1765  * @ingroup exceptions
1766  */
1768  {
1769  public:
1770  virtual ~bad_function_call() noexcept;
1771 
1772  const char* what() const noexcept;
1773  };
1774 
1775  /**
1776  * Trait identifying "location-invariant" types, meaning that the
1777  * address of the object (or any of its members) will not escape.
1778  * Also implies a trivial copy constructor and assignment operator.
1779  */
1780  template<typename _Tp>
1782  : integral_constant<bool, (is_pointer<_Tp>::value
1783  || is_member_pointer<_Tp>::value)>
1784  { };
1785 
1786  class _Undefined_class;
1787 
1788  union _Nocopy_types
1789  {
1790  void* _M_object;
1791  const void* _M_const_object;
1792  void (*_M_function_pointer)();
1793  void (_Undefined_class::*_M_member_pointer)();
1794  };
1795 
1796  union _Any_data
1797  {
1798  void* _M_access() { return &_M_pod_data[0]; }
1799  const void* _M_access() const { return &_M_pod_data[0]; }
1800 
1801  template<typename _Tp>
1802  _Tp&
1803  _M_access()
1804  { return *static_cast<_Tp*>(_M_access()); }
1805 
1806  template<typename _Tp>
1807  const _Tp&
1808  _M_access() const
1809  { return *static_cast<const _Tp*>(_M_access()); }
1810 
1811  _Nocopy_types _M_unused;
1812  char _M_pod_data[sizeof(_Nocopy_types)];
1813  };
1814 
1815  enum _Manager_operation
1816  {
1817  __get_type_info,
1818  __get_functor_ptr,
1819  __clone_functor,
1820  __destroy_functor
1821  };
1822 
1823  // Simple type wrapper that helps avoid annoying const problems
1824  // when casting between void pointers and pointers-to-pointers.
1825  template<typename _Tp>
1826  struct _Simple_type_wrapper
1827  {
1828  _Simple_type_wrapper(_Tp __value) : __value(__value) { }
1829 
1830  _Tp __value;
1831  };
1832 
1833  template<typename _Tp>
1834  struct __is_location_invariant<_Simple_type_wrapper<_Tp> >
1835  : __is_location_invariant<_Tp>
1836  { };
1837 
1838  // Converts a reference to a function object into a callable
1839  // function object.
1840  template<typename _Functor>
1841  inline _Functor&
1842  __callable_functor(_Functor& __f)
1843  { return __f; }
1844 
1845  template<typename _Member, typename _Class>
1846  inline _Mem_fn<_Member _Class::*>
1847  __callable_functor(_Member _Class::* &__p)
1848  { return std::mem_fn(__p); }
1849 
1850  template<typename _Member, typename _Class>
1851  inline _Mem_fn<_Member _Class::*>
1852  __callable_functor(_Member _Class::* const &__p)
1853  { return std::mem_fn(__p); }
1854 
1855  template<typename _Member, typename _Class>
1856  inline _Mem_fn<_Member _Class::*>
1857  __callable_functor(_Member _Class::* volatile &__p)
1858  { return std::mem_fn(__p); }
1859 
1860  template<typename _Member, typename _Class>
1861  inline _Mem_fn<_Member _Class::*>
1862  __callable_functor(_Member _Class::* const volatile &__p)
1863  { return std::mem_fn(__p); }
1864 
1865  template<typename _Signature>
1866  class function;
1867 
1868  /// Base class of all polymorphic function object wrappers.
1870  {
1871  public:
1872  static const std::size_t _M_max_size = sizeof(_Nocopy_types);
1873  static const std::size_t _M_max_align = __alignof__(_Nocopy_types);
1874 
1875  template<typename _Functor>
1876  class _Base_manager
1877  {
1878  protected:
1879  static const bool __stored_locally =
1881  && sizeof(_Functor) <= _M_max_size
1882  && __alignof__(_Functor) <= _M_max_align
1883  && (_M_max_align % __alignof__(_Functor) == 0));
1884 
1885  typedef integral_constant<bool, __stored_locally> _Local_storage;
1886 
1887  // Retrieve a pointer to the function object
1888  static _Functor*
1889  _M_get_pointer(const _Any_data& __source)
1890  {
1891  const _Functor* __ptr =
1892  __stored_locally? std::__addressof(__source._M_access<_Functor>())
1893  /* have stored a pointer */ : __source._M_access<_Functor*>();
1894  return const_cast<_Functor*>(__ptr);
1895  }
1896 
1897  // Clone a location-invariant function object that fits within
1898  // an _Any_data structure.
1899  static void
1900  _M_clone(_Any_data& __dest, const _Any_data& __source, true_type)
1901  {
1902  new (__dest._M_access()) _Functor(__source._M_access<_Functor>());
1903  }
1904 
1905  // Clone a function object that is not location-invariant or
1906  // that cannot fit into an _Any_data structure.
1907  static void
1908  _M_clone(_Any_data& __dest, const _Any_data& __source, false_type)
1909  {
1910  __dest._M_access<_Functor*>() =
1911  new _Functor(*__source._M_access<_Functor*>());
1912  }
1913 
1914  // Destroying a location-invariant object may still require
1915  // destruction.
1916  static void
1917  _M_destroy(_Any_data& __victim, true_type)
1918  {
1919  __victim._M_access<_Functor>().~_Functor();
1920  }
1921 
1922  // Destroying an object located on the heap.
1923  static void
1924  _M_destroy(_Any_data& __victim, false_type)
1925  {
1926  delete __victim._M_access<_Functor*>();
1927  }
1928 
1929  public:
1930  static bool
1931  _M_manager(_Any_data& __dest, const _Any_data& __source,
1932  _Manager_operation __op)
1933  {
1934  switch (__op)
1935  {
1936 #ifdef __GXX_RTTI
1937  case __get_type_info:
1938  __dest._M_access<const type_info*>() = &typeid(_Functor);
1939  break;
1940 #endif
1941  case __get_functor_ptr:
1942  __dest._M_access<_Functor*>() = _M_get_pointer(__source);
1943  break;
1944 
1945  case __clone_functor:
1946  _M_clone(__dest, __source, _Local_storage());
1947  break;
1948 
1949  case __destroy_functor:
1950  _M_destroy(__dest, _Local_storage());
1951  break;
1952  }
1953  return false;
1954  }
1955 
1956  static void
1957  _M_init_functor(_Any_data& __functor, _Functor&& __f)
1958  { _M_init_functor(__functor, std::move(__f), _Local_storage()); }
1959 
1960  template<typename _Signature>
1961  static bool
1962  _M_not_empty_function(const function<_Signature>& __f)
1963  { return static_cast<bool>(__f); }
1964 
1965  template<typename _Tp>
1966  static bool
1967  _M_not_empty_function(const _Tp*& __fp)
1968  { return __fp; }
1969 
1970  template<typename _Class, typename _Tp>
1971  static bool
1972  _M_not_empty_function(_Tp _Class::* const& __mp)
1973  { return __mp; }
1974 
1975  template<typename _Tp>
1976  static bool
1977  _M_not_empty_function(const _Tp&)
1978  { return true; }
1979 
1980  private:
1981  static void
1982  _M_init_functor(_Any_data& __functor, _Functor&& __f, true_type)
1983  { new (__functor._M_access()) _Functor(std::move(__f)); }
1984 
1985  static void
1986  _M_init_functor(_Any_data& __functor, _Functor&& __f, false_type)
1987  { __functor._M_access<_Functor*>() = new _Functor(std::move(__f)); }
1988  };
1989 
1990  template<typename _Functor>
1991  class _Ref_manager : public _Base_manager<_Functor*>
1992  {
1993  typedef _Function_base::_Base_manager<_Functor*> _Base;
1994 
1995  public:
1996  static bool
1997  _M_manager(_Any_data& __dest, const _Any_data& __source,
1998  _Manager_operation __op)
1999  {
2000  switch (__op)
2001  {
2002 #ifdef __GXX_RTTI
2003  case __get_type_info:
2004  __dest._M_access<const type_info*>() = &typeid(_Functor);
2005  break;
2006 #endif
2007  case __get_functor_ptr:
2008  __dest._M_access<_Functor*>() = *_Base::_M_get_pointer(__source);
2010  break;
2011 
2012  default:
2013  _Base::_M_manager(__dest, __source, __op);
2014  }
2015  return false;
2016  }
2017 
2018  static void
2019  _M_init_functor(_Any_data& __functor, reference_wrapper<_Functor> __f)
2020  {
2021  _Base::_M_init_functor(__functor, std::__addressof(__f.get()));
2022  }
2023  };
2024 
2025  _Function_base() : _M_manager(0) { }
2026 
2027  ~_Function_base()
2028  {
2029  if (_M_manager)
2030  _M_manager(_M_functor, _M_functor, __destroy_functor);
2031  }
2032 
2033 
2034  bool _M_empty() const { return !_M_manager; }
2035 
2036  typedef bool (*_Manager_type)(_Any_data&, const _Any_data&,
2037  _Manager_operation);
2038 
2039  _Any_data _M_functor;
2040  _Manager_type _M_manager;
2041  };
2042 
2043  template<typename _Signature, typename _Functor>
2044  class _Function_handler;
2045 
2046  template<typename _Res, typename _Functor, typename... _ArgTypes>
2047  class _Function_handler<_Res(_ArgTypes...), _Functor>
2048  : public _Function_base::_Base_manager<_Functor>
2049  {
2050  typedef _Function_base::_Base_manager<_Functor> _Base;
2051 
2052  public:
2053  static _Res
2054  _M_invoke(const _Any_data& __functor, _ArgTypes... __args)
2055  {
2056  return (*_Base::_M_get_pointer(__functor))(
2057  std::forward<_ArgTypes>(__args)...);
2058  }
2059  };
2060 
2061  template<typename _Functor, typename... _ArgTypes>
2062  class _Function_handler<void(_ArgTypes...), _Functor>
2063  : public _Function_base::_Base_manager<_Functor>
2064  {
2065  typedef _Function_base::_Base_manager<_Functor> _Base;
2066 
2067  public:
2068  static void
2069  _M_invoke(const _Any_data& __functor, _ArgTypes... __args)
2070  {
2071  (*_Base::_M_get_pointer(__functor))(
2072  std::forward<_ArgTypes>(__args)...);
2073  }
2074  };
2075 
2076  template<typename _Res, typename _Functor, typename... _ArgTypes>
2077  class _Function_handler<_Res(_ArgTypes...), reference_wrapper<_Functor> >
2078  : public _Function_base::_Ref_manager<_Functor>
2079  {
2080  typedef _Function_base::_Ref_manager<_Functor> _Base;
2081 
2082  public:
2083  static _Res
2084  _M_invoke(const _Any_data& __functor, _ArgTypes... __args)
2085  {
2086  return __callable_functor(**_Base::_M_get_pointer(__functor))(
2087  std::forward<_ArgTypes>(__args)...);
2088  }
2089  };
2090 
2091  template<typename _Functor, typename... _ArgTypes>
2092  class _Function_handler<void(_ArgTypes...), reference_wrapper<_Functor> >
2093  : public _Function_base::_Ref_manager<_Functor>
2094  {
2095  typedef _Function_base::_Ref_manager<_Functor> _Base;
2096 
2097  public:
2098  static void
2099  _M_invoke(const _Any_data& __functor, _ArgTypes... __args)
2100  {
2101  __callable_functor(**_Base::_M_get_pointer(__functor))(
2102  std::forward<_ArgTypes>(__args)...);
2103  }
2104  };
2105 
2106  template<typename _Class, typename _Member, typename _Res,
2107  typename... _ArgTypes>
2108  class _Function_handler<_Res(_ArgTypes...), _Member _Class::*>
2109  : public _Function_handler<void(_ArgTypes...), _Member _Class::*>
2110  {
2111  typedef _Function_handler<void(_ArgTypes...), _Member _Class::*>
2112  _Base;
2113 
2114  public:
2115  static _Res
2116  _M_invoke(const _Any_data& __functor, _ArgTypes... __args)
2117  {
2118  return std::mem_fn(_Base::_M_get_pointer(__functor)->__value)(
2119  std::forward<_ArgTypes>(__args)...);
2120  }
2121  };
2122 
2123  template<typename _Class, typename _Member, typename... _ArgTypes>
2124  class _Function_handler<void(_ArgTypes...), _Member _Class::*>
2125  : public _Function_base::_Base_manager<
2126  _Simple_type_wrapper< _Member _Class::* > >
2127  {
2128  typedef _Member _Class::* _Functor;
2129  typedef _Simple_type_wrapper<_Functor> _Wrapper;
2130  typedef _Function_base::_Base_manager<_Wrapper> _Base;
2131 
2132  public:
2133  static bool
2134  _M_manager(_Any_data& __dest, const _Any_data& __source,
2135  _Manager_operation __op)
2136  {
2137  switch (__op)
2138  {
2139 #ifdef __GXX_RTTI
2140  case __get_type_info:
2141  __dest._M_access<const type_info*>() = &typeid(_Functor);
2142  break;
2143 #endif
2144  case __get_functor_ptr:
2145  __dest._M_access<_Functor*>() =
2146  &_Base::_M_get_pointer(__source)->__value;
2147  break;
2148 
2149  default:
2150  _Base::_M_manager(__dest, __source, __op);
2151  }
2152  return false;
2153  }
2154 
2155  static void
2156  _M_invoke(const _Any_data& __functor, _ArgTypes... __args)
2157  {
2158  std::mem_fn(_Base::_M_get_pointer(__functor)->__value)(
2159  std::forward<_ArgTypes>(__args)...);
2160  }
2161  };
2162 
2163  /**
2164  * @brief Primary class template for std::function.
2165  * @ingroup functors
2166  *
2167  * Polymorphic function wrapper.
2168  */
2169  template<typename _Res, typename... _ArgTypes>
2170  class function<_Res(_ArgTypes...)>
2171  : public _Maybe_unary_or_binary_function<_Res, _ArgTypes...>,
2172  private _Function_base
2173  {
2174  typedef _Res _Signature_type(_ArgTypes...);
2175 
2176  template<typename _Functor>
2177  using _Invoke = decltype(__callable_functor(std::declval<_Functor&>())
2178  (std::declval<_ArgTypes>()...) );
2179 
2180  template<typename _CallRes, typename _Res1>
2181  struct _CheckResult
2182  : is_convertible<_CallRes, _Res1> { };
2183 
2184  template<typename _CallRes>
2185  struct _CheckResult<_CallRes, void>
2186  : true_type { };
2187 
2188  template<typename _Functor>
2189  using _Callable = _CheckResult<_Invoke<_Functor>, _Res>;
2190 
2191  template<typename _Cond, typename _Tp>
2192  using _Requires = typename enable_if<_Cond::value, _Tp>::type;
2193 
2194  public:
2195  typedef _Res result_type;
2196 
2197  // [3.7.2.1] construct/copy/destroy
2198 
2199  /**
2200  * @brief Default construct creates an empty function call wrapper.
2201  * @post @c !(bool)*this
2202  */
2203  function() noexcept
2204  : _Function_base() { }
2205 
2206  /**
2207  * @brief Creates an empty function call wrapper.
2208  * @post @c !(bool)*this
2209  */
2210  function(nullptr_t) noexcept
2211  : _Function_base() { }
2212 
2213  /**
2214  * @brief %Function copy constructor.
2215  * @param __x A %function object with identical call signature.
2216  * @post @c bool(*this) == bool(__x)
2217  *
2218  * The newly-created %function contains a copy of the target of @a
2219  * __x (if it has one).
2220  */
2221  function(const function& __x);
2222 
2223  /**
2224  * @brief %Function move constructor.
2225  * @param __x A %function object rvalue with identical call signature.
2226  *
2227  * The newly-created %function contains the target of @a __x
2228  * (if it has one).
2229  */
2230  function(function&& __x) : _Function_base()
2231  {
2232  __x.swap(*this);
2233  }
2234 
2235  // TODO: needs allocator_arg_t
2236 
2237  /**
2238  * @brief Builds a %function that targets a copy of the incoming
2239  * function object.
2240  * @param __f A %function object that is callable with parameters of
2241  * type @c T1, @c T2, ..., @c TN and returns a value convertible
2242  * to @c Res.
2243  *
2244  * The newly-created %function object will target a copy of
2245  * @a __f. If @a __f is @c reference_wrapper<F>, then this function
2246  * object will contain a reference to the function object @c
2247  * __f.get(). If @a __f is a NULL function pointer or NULL
2248  * pointer-to-member, the newly-created object will be empty.
2249  *
2250  * If @a __f is a non-NULL function pointer or an object of type @c
2251  * reference_wrapper<F>, this function will not throw.
2252  */
2253  template<typename _Functor,
2254  typename = _Requires<_Callable<_Functor>, void>>
2255  function(_Functor);
2256 
2257  /**
2258  * @brief %Function assignment operator.
2259  * @param __x A %function with identical call signature.
2260  * @post @c (bool)*this == (bool)x
2261  * @returns @c *this
2262  *
2263  * The target of @a __x is copied to @c *this. If @a __x has no
2264  * target, then @c *this will be empty.
2265  *
2266  * If @a __x targets a function pointer or a reference to a function
2267  * object, then this operation will not throw an %exception.
2268  */
2269  function&
2270  operator=(const function& __x)
2271  {
2272  function(__x).swap(*this);
2273  return *this;
2274  }
2275 
2276  /**
2277  * @brief %Function move-assignment operator.
2278  * @param __x A %function rvalue with identical call signature.
2279  * @returns @c *this
2280  *
2281  * The target of @a __x is moved to @c *this. If @a __x has no
2282  * target, then @c *this will be empty.
2283  *
2284  * If @a __x targets a function pointer or a reference to a function
2285  * object, then this operation will not throw an %exception.
2286  */
2287  function&
2288  operator=(function&& __x)
2289  {
2290  function(std::move(__x)).swap(*this);
2291  return *this;
2292  }
2293 
2294  /**
2295  * @brief %Function assignment to zero.
2296  * @post @c !(bool)*this
2297  * @returns @c *this
2298  *
2299  * The target of @c *this is deallocated, leaving it empty.
2300  */
2301  function&
2302  operator=(nullptr_t)
2303  {
2304  if (_M_manager)
2305  {
2306  _M_manager(_M_functor, _M_functor, __destroy_functor);
2307  _M_manager = 0;
2308  _M_invoker = 0;
2309  }
2310  return *this;
2311  }
2312 
2313  /**
2314  * @brief %Function assignment to a new target.
2315  * @param __f A %function object that is callable with parameters of
2316  * type @c T1, @c T2, ..., @c TN and returns a value convertible
2317  * to @c Res.
2318  * @return @c *this
2319  *
2320  * This %function object wrapper will target a copy of @a
2321  * __f. If @a __f is @c reference_wrapper<F>, then this function
2322  * object will contain a reference to the function object @c
2323  * __f.get(). If @a __f is a NULL function pointer or NULL
2324  * pointer-to-member, @c this object will be empty.
2325  *
2326  * If @a __f is a non-NULL function pointer or an object of type @c
2327  * reference_wrapper<F>, this function will not throw.
2328  */
2329  template<typename _Functor>
2330  _Requires<_Callable<_Functor>, function&>
2331  operator=(_Functor&& __f)
2332  {
2333  function(std::forward<_Functor>(__f)).swap(*this);
2334  return *this;
2335  }
2336 
2337  /// @overload
2338  template<typename _Functor>
2339  function&
2340  operator=(reference_wrapper<_Functor> __f) noexcept
2341  {
2342  function(__f).swap(*this);
2343  return *this;
2344  }
2345 
2346  // [3.7.2.2] function modifiers
2347 
2348  /**
2349  * @brief Swap the targets of two %function objects.
2350  * @param __x A %function with identical call signature.
2351  *
2352  * Swap the targets of @c this function object and @a __f. This
2353  * function will not throw an %exception.
2354  */
2355  void swap(function& __x)
2356  {
2357  std::swap(_M_functor, __x._M_functor);
2358  std::swap(_M_manager, __x._M_manager);
2359  std::swap(_M_invoker, __x._M_invoker);
2360  }
2361 
2362  // TODO: needs allocator_arg_t
2363  /*
2364  template<typename _Functor, typename _Alloc>
2365  void
2366  assign(_Functor&& __f, const _Alloc& __a)
2367  {
2368  function(allocator_arg, __a,
2369  std::forward<_Functor>(__f)).swap(*this);
2370  }
2371  */
2372 
2373  // [3.7.2.3] function capacity
2374 
2375  /**
2376  * @brief Determine if the %function wrapper has a target.
2377  *
2378  * @return @c true when this %function object contains a target,
2379  * or @c false when it is empty.
2380  *
2381  * This function will not throw an %exception.
2382  */
2383  explicit operator bool() const noexcept
2384  { return !_M_empty(); }
2385 
2386  // [3.7.2.4] function invocation
2387 
2388  /**
2389  * @brief Invokes the function targeted by @c *this.
2390  * @returns the result of the target.
2391  * @throws bad_function_call when @c !(bool)*this
2392  *
2393  * The function call operator invokes the target function object
2394  * stored by @c this.
2395  */
2396  _Res operator()(_ArgTypes... __args) const;
2397 
2398 #ifdef __GXX_RTTI
2399  // [3.7.2.5] function target access
2400  /**
2401  * @brief Determine the type of the target of this function object
2402  * wrapper.
2403  *
2404  * @returns the type identifier of the target function object, or
2405  * @c typeid(void) if @c !(bool)*this.
2406  *
2407  * This function will not throw an %exception.
2408  */
2409  const type_info& target_type() const noexcept;
2410 
2411  /**
2412  * @brief Access the stored target function object.
2413  *
2414  * @return Returns a pointer to the stored target function object,
2415  * if @c typeid(Functor).equals(target_type()); otherwise, a NULL
2416  * pointer.
2417  *
2418  * This function will not throw an %exception.
2419  */
2420  template<typename _Functor> _Functor* target() noexcept;
2421 
2422  /// @overload
2423  template<typename _Functor> const _Functor* target() const noexcept;
2424 #endif
2425 
2426  private:
2427  typedef _Res (*_Invoker_type)(const _Any_data&, _ArgTypes...);
2428  _Invoker_type _M_invoker;
2429  };
2430 
2431  // Out-of-line member definitions.
2432  template<typename _Res, typename... _ArgTypes>
2433  function<_Res(_ArgTypes...)>::
2434  function(const function& __x)
2435  : _Function_base()
2436  {
2437  if (static_cast<bool>(__x))
2438  {
2439  _M_invoker = __x._M_invoker;
2440  _M_manager = __x._M_manager;
2441  __x._M_manager(_M_functor, __x._M_functor, __clone_functor);
2442  }
2443  }
2444 
2445  template<typename _Res, typename... _ArgTypes>
2446  template<typename _Functor, typename>
2447  function<_Res(_ArgTypes...)>::
2448  function(_Functor __f)
2449  : _Function_base()
2450  {
2451  typedef _Function_handler<_Signature_type, _Functor> _My_handler;
2452 
2453  if (_My_handler::_M_not_empty_function(__f))
2454  {
2455  _My_handler::_M_init_functor(_M_functor, std::move(__f));
2456  _M_invoker = &_My_handler::_M_invoke;
2457  _M_manager = &_My_handler::_M_manager;
2458  }
2459  }
2460 
2461  template<typename _Res, typename... _ArgTypes>
2462  _Res
2463  function<_Res(_ArgTypes...)>::
2464  operator()(_ArgTypes... __args) const
2465  {
2466  if (_M_empty())
2467  __throw_bad_function_call();
2468  return _M_invoker(_M_functor, std::forward<_ArgTypes>(__args)...);
2469  }
2470 
2471 #ifdef __GXX_RTTI
2472  template<typename _Res, typename... _ArgTypes>
2473  const type_info&
2474  function<_Res(_ArgTypes...)>::
2475  target_type() const noexcept
2476  {
2477  if (_M_manager)
2478  {
2479  _Any_data __typeinfo_result;
2480  _M_manager(__typeinfo_result, _M_functor, __get_type_info);
2481  return *__typeinfo_result._M_access<const type_info*>();
2482  }
2483  else
2484  return typeid(void);
2485  }
2486 
2487  template<typename _Res, typename... _ArgTypes>
2488  template<typename _Functor>
2489  _Functor*
2490  function<_Res(_ArgTypes...)>::
2491  target() noexcept
2492  {
2493  if (typeid(_Functor) == target_type() && _M_manager)
2494  {
2495  _Any_data __ptr;
2496  if (_M_manager(__ptr, _M_functor, __get_functor_ptr)
2498  return 0;
2499  else
2500  return __ptr._M_access<_Functor*>();
2501  }
2502  else
2503  return 0;
2504  }
2505 
2506  template<typename _Res, typename... _ArgTypes>
2507  template<typename _Functor>
2508  const _Functor*
2509  function<_Res(_ArgTypes...)>::
2510  target() const noexcept
2511  {
2512  if (typeid(_Functor) == target_type() && _M_manager)
2513  {
2514  _Any_data __ptr;
2515  _M_manager(__ptr, _M_functor, __get_functor_ptr);
2516  return __ptr._M_access<const _Functor*>();
2517  }
2518  else
2519  return 0;
2520  }
2521 #endif
2522 
2523  // [20.7.15.2.6] null pointer comparisons
2524 
2525  /**
2526  * @brief Compares a polymorphic function object wrapper against 0
2527  * (the NULL pointer).
2528  * @returns @c true if the wrapper has no target, @c false otherwise
2529  *
2530  * This function will not throw an %exception.
2531  */
2532  template<typename _Res, typename... _Args>
2533  inline bool
2534  operator==(const function<_Res(_Args...)>& __f, nullptr_t) noexcept
2535  { return !static_cast<bool>(__f); }
2536 
2537  /// @overload
2538  template<typename _Res, typename... _Args>
2539  inline bool
2540  operator==(nullptr_t, const function<_Res(_Args...)>& __f) noexcept
2541  { return !static_cast<bool>(__f); }
2542 
2543  /**
2544  * @brief Compares a polymorphic function object wrapper against 0
2545  * (the NULL pointer).
2546  * @returns @c false if the wrapper has no target, @c true otherwise
2547  *
2548  * This function will not throw an %exception.
2549  */
2550  template<typename _Res, typename... _Args>
2551  inline bool
2552  operator!=(const function<_Res(_Args...)>& __f, nullptr_t) noexcept
2553  { return static_cast<bool>(__f); }
2554 
2555  /// @overload
2556  template<typename _Res, typename... _Args>
2557  inline bool
2558  operator!=(nullptr_t, const function<_Res(_Args...)>& __f) noexcept
2559  { return static_cast<bool>(__f); }
2560 
2561  // [20.7.15.2.7] specialized algorithms
2562 
2563  /**
2564  * @brief Swap the targets of two polymorphic function object wrappers.
2565  *
2566  * This function will not throw an %exception.
2567  */
2568  template<typename _Res, typename... _Args>
2569  inline void
2570  swap(function<_Res(_Args...)>& __x, function<_Res(_Args...)>& __y)
2571  { __x.swap(__y); }
2572 
2573 _GLIBCXX_END_NAMESPACE_VERSION
2574 } // namespace std
2575 
2576 #endif // C++11
2577 
2578 #endif // _GLIBCXX_FUNCTIONAL