| 1 | //  boost cast.hpp header file  ----------------------------------------------// | 
|---|
| 2 |  | 
|---|
| 3 | //  (C) Copyright Kevlin Henney and Dave Abrahams 1999. | 
|---|
| 4 | //  Distributed under the Boost | 
|---|
| 5 | //  Software License, Version 1.0. (See accompanying file | 
|---|
| 6 | //  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) | 
|---|
| 7 |  | 
|---|
| 8 | //  See http://www.boost.org/libs/conversion for Documentation. | 
|---|
| 9 |  | 
|---|
| 10 | //  Revision History | 
|---|
| 11 | //  23 JUn 05  numeric_cast removed and redirected to the new verion (Fernando Cacciola) | 
|---|
| 12 | //  02 Apr 01  Removed BOOST_NO_LIMITS workarounds and included | 
|---|
| 13 | //             <boost/limits.hpp> instead (the workaround did not | 
|---|
| 14 | //             actually compile when BOOST_NO_LIMITS was defined in | 
|---|
| 15 | //             any case, so we loose nothing). (John Maddock) | 
|---|
| 16 | //  21 Jan 01  Undid a bug I introduced yesterday. numeric_cast<> never | 
|---|
| 17 | //             worked with stock GCC; trying to get it to do that broke | 
|---|
| 18 | //             vc-stlport. | 
|---|
| 19 | //  20 Jan 01  Moved BOOST_NO_LIMITS_COMPILE_TIME_CONSTANTS to config.hpp. | 
|---|
| 20 | //             Removed unused BOOST_EXPLICIT_TARGET macro. Moved | 
|---|
| 21 | //             boost::detail::type to boost/type.hpp. Made it compile with | 
|---|
| 22 | //             stock gcc again (Dave Abrahams) | 
|---|
| 23 | //  29 Nov 00  Remove nested namespace cast, cleanup spacing before Formal | 
|---|
| 24 | //             Review (Beman Dawes) | 
|---|
| 25 | //  19 Oct 00  Fix numeric_cast for floating-point types (Dave Abrahams) | 
|---|
| 26 | //  15 Jul 00  Suppress numeric_cast warnings for GCC, Borland and MSVC | 
|---|
| 27 | //             (Dave Abrahams) | 
|---|
| 28 | //  30 Jun 00  More MSVC6 wordarounds.  See comments below.  (Dave Abrahams) | 
|---|
| 29 | //  28 Jun 00  Removed implicit_cast<>.  See comment below. (Beman Dawes) | 
|---|
| 30 | //  27 Jun 00  More MSVC6 workarounds | 
|---|
| 31 | //  15 Jun 00  Add workarounds for MSVC6 | 
|---|
| 32 | //   2 Feb 00  Remove bad_numeric_cast ";" syntax error (Doncho Angelov) | 
|---|
| 33 | //  26 Jan 00  Add missing throw() to bad_numeric_cast::what(0 (Adam Levar) | 
|---|
| 34 | //  29 Dec 99  Change using declarations so usages in other namespaces work | 
|---|
| 35 | //             correctly (Dave Abrahams) | 
|---|
| 36 | //  23 Sep 99  Change polymorphic_downcast assert to also detect M.I. errors | 
|---|
| 37 | //             as suggested Darin Adler and improved by Valentin Bonnard. | 
|---|
| 38 | //   2 Sep 99  Remove controversial asserts, simplify, rename. | 
|---|
| 39 | //  30 Aug 99  Move to cast.hpp, replace value_cast with numeric_cast, | 
|---|
| 40 | //             place in nested namespace. | 
|---|
| 41 | //   3 Aug 99  Initial version | 
|---|
| 42 |  | 
|---|
| 43 | #ifndef BOOST_CAST_HPP | 
|---|
| 44 | #define BOOST_CAST_HPP | 
|---|
| 45 |  | 
|---|
| 46 | # include <boost/config.hpp> | 
|---|
| 47 | # include <boost/assert.hpp> | 
|---|
| 48 | # include <typeinfo> | 
|---|
| 49 | # include <boost/type.hpp> | 
|---|
| 50 | # include <boost/limits.hpp> | 
|---|
| 51 | # include <boost/detail/select_type.hpp> | 
|---|
| 52 |  | 
|---|
| 53 | //  It has been demonstrated numerous times that MSVC 6.0 fails silently at link | 
|---|
| 54 | //  time if you use a template function which has template parameters that don't | 
|---|
| 55 | //  appear in the function's argument list. | 
|---|
| 56 | // | 
|---|
| 57 | //  TODO: Add this to config.hpp? | 
|---|
| 58 | # if defined(BOOST_MSVC) && BOOST_MSVC < 1300 | 
|---|
| 59 | #  define BOOST_EXPLICIT_DEFAULT_TARGET , ::boost::type<Target>* = 0 | 
|---|
| 60 | # else | 
|---|
| 61 | #  define BOOST_EXPLICIT_DEFAULT_TARGET | 
|---|
| 62 | # endif | 
|---|
| 63 |  | 
|---|
| 64 | namespace boost | 
|---|
| 65 | { | 
|---|
| 66 | //  See the documentation for descriptions of how to choose between | 
|---|
| 67 | //  static_cast<>, dynamic_cast<>, polymorphic_cast<> and polymorphic_downcast<> | 
|---|
| 68 |  | 
|---|
| 69 | //  polymorphic_cast  --------------------------------------------------------// | 
|---|
| 70 |  | 
|---|
| 71 |     //  Runtime checked polymorphic downcasts and crosscasts. | 
|---|
| 72 |     //  Suggested in The C++ Programming Language, 3rd Ed, Bjarne Stroustrup, | 
|---|
| 73 |     //  section 15.8 exercise 1, page 425. | 
|---|
| 74 |  | 
|---|
| 75 |     template <class Target, class Source> | 
|---|
| 76 |     inline Target polymorphic_cast(Source* x BOOST_EXPLICIT_DEFAULT_TARGET) | 
|---|
| 77 |     { | 
|---|
| 78 |         Target tmp = dynamic_cast<Target>(x); | 
|---|
| 79 |         if ( tmp == 0 ) throw std::bad_cast(); | 
|---|
| 80 |         return tmp; | 
|---|
| 81 |     } | 
|---|
| 82 |  | 
|---|
| 83 | //  polymorphic_downcast  ----------------------------------------------------// | 
|---|
| 84 |  | 
|---|
| 85 |     //  BOOST_ASSERT() checked polymorphic downcast.  Crosscasts prohibited. | 
|---|
| 86 |  | 
|---|
| 87 |     //  WARNING: Because this cast uses BOOST_ASSERT(), it violates | 
|---|
| 88 |     //  the One Definition Rule if used in multiple translation units | 
|---|
| 89 |     //  where BOOST_DISABLE_ASSERTS, BOOST_ENABLE_ASSERT_HANDLER | 
|---|
| 90 |     //  NDEBUG are defined inconsistently. | 
|---|
| 91 |  | 
|---|
| 92 |     //  Contributed by Dave Abrahams | 
|---|
| 93 |  | 
|---|
| 94 |     template <class Target, class Source> | 
|---|
| 95 |     inline Target polymorphic_downcast(Source* x BOOST_EXPLICIT_DEFAULT_TARGET) | 
|---|
| 96 |     { | 
|---|
| 97 |         BOOST_ASSERT( dynamic_cast<Target>(x) == x );  // detect logic error | 
|---|
| 98 |         return static_cast<Target>(x); | 
|---|
| 99 |     } | 
|---|
| 100 |  | 
|---|
| 101 | #  undef BOOST_EXPLICIT_DEFAULT_TARGET | 
|---|
| 102 |  | 
|---|
| 103 | } // namespace boost | 
|---|
| 104 |  | 
|---|
| 105 | # include <boost/numeric/conversion/cast.hpp> | 
|---|
| 106 |  | 
|---|
| 107 | #endif  // BOOST_CAST_HPP | 
|---|