float.hpp 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. //
  2. // MessagePack for C++ static resolution routine
  3. //
  4. // Copyright (C) 2008-2009 FURUHASHI Sadayuki
  5. //
  6. // Distributed under the Boost Software License, Version 1.0.
  7. // (See accompanying file LICENSE_1_0.txt or copy at
  8. // http://www.boost.org/LICENSE_1_0.txt)
  9. //
  10. #ifndef MSGPACK_V1_TYPE_FLOAT_HPP
  11. #define MSGPACK_V1_TYPE_FLOAT_HPP
  12. #include "msgpack/versioning.hpp"
  13. #include "msgpack/object_fwd.hpp"
  14. #include <vector>
  15. namespace msgpack {
  16. /// @cond
  17. MSGPACK_API_VERSION_NAMESPACE(v1) {
  18. /// @endcond
  19. // FIXME check overflow, underflow
  20. namespace adaptor {
  21. template <>
  22. struct convert<float> {
  23. msgpack::object const& operator()(msgpack::object const& o, float& v) const {
  24. if(o.type == msgpack::type::FLOAT32 || o.type == msgpack::type::FLOAT64) {
  25. v = static_cast<float>(o.via.f64);
  26. }
  27. else if (o.type == msgpack::type::POSITIVE_INTEGER) {
  28. v = static_cast<float>(o.via.u64);
  29. }
  30. else if (o.type == msgpack::type::NEGATIVE_INTEGER) {
  31. v = static_cast<float>(o.via.i64);
  32. }
  33. else {
  34. throw msgpack::type_error();
  35. }
  36. return o;
  37. }
  38. };
  39. template <>
  40. struct pack<float> {
  41. template <typename Stream>
  42. msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const float& v) const {
  43. o.pack_float(v);
  44. return o;
  45. }
  46. };
  47. template <>
  48. struct convert<double> {
  49. msgpack::object const& operator()(msgpack::object const& o, double& v) const {
  50. if(o.type == msgpack::type::FLOAT32 || o.type == msgpack::type::FLOAT64) {
  51. v = o.via.f64;
  52. }
  53. else if (o.type == msgpack::type::POSITIVE_INTEGER) {
  54. v = static_cast<double>(o.via.u64);
  55. }
  56. else if (o.type == msgpack::type::NEGATIVE_INTEGER) {
  57. v = static_cast<double>(o.via.i64);
  58. }
  59. else {
  60. throw msgpack::type_error();
  61. }
  62. return o;
  63. }
  64. };
  65. template <>
  66. struct pack<double> {
  67. template <typename Stream>
  68. msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const double& v) const {
  69. o.pack_double(v);
  70. return o;
  71. }
  72. };
  73. template <>
  74. struct object<float> {
  75. void operator()(msgpack::object& o, float v) const {
  76. o.type = msgpack::type::FLOAT32;
  77. o.via.f64 = static_cast<double>(v);
  78. }
  79. };
  80. template <>
  81. struct object<double> {
  82. void operator()(msgpack::object& o, double v) const {
  83. o.type = msgpack::type::FLOAT64;
  84. o.via.f64 = v;
  85. }
  86. };
  87. template <>
  88. struct object_with_zone<float> {
  89. void operator()(msgpack::object::with_zone& o, float v) const {
  90. static_cast<msgpack::object&>(o) << v;
  91. }
  92. };
  93. template <>
  94. struct object_with_zone<double> {
  95. void operator()(msgpack::object::with_zone& o, double v) const {
  96. static_cast<msgpack::object&>(o) << v;
  97. }
  98. };
  99. } // namespace adaptor
  100. /// @cond
  101. } // MSGPACK_API_VERSION_NAMESPACE(v1)
  102. /// @endcond
  103. } // namespace msgpack
  104. #endif // MSGPACK_V1_TYPE_FLOAT_HPP