json_direct_scalar_binder.hpp 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. //
  2. // json_direct_scalar_binder.hpp
  3. // json
  4. //
  5. // Created by Sam Jaffe on 4/23/16.
  6. //
  7. #pragma once
  8. #include "json_binder.hpp"
  9. #include "json_direct_binder.hpp"
  10. #include <string>
  11. namespace json { namespace binder {
  12. template <typename T>
  13. class direct_binder<T, bool> : public binder_impl<T> {
  14. public:
  15. explicit direct_binder(bool T::*p) : ptr(p) {}
  16. virtual binder_impl<T>* clone() const override {
  17. return new direct_binder(*this);
  18. }
  19. virtual void parse(T& val, char const*& data,
  20. parser::options) const override {
  21. if (!strncmp(data, "true", 4)) {
  22. val.*ptr = true;
  23. data += 4;
  24. } else if (!strncmp(data, "false", 5)) {
  25. val.*ptr = false;
  26. data += 5;
  27. } else {
  28. throw json::malformed_json_exception("Expected a boolean type here");
  29. }
  30. }
  31. virtual void write(T const& val, std::ostream & data) const override {
  32. data << (val.*ptr ? "true" : "false");
  33. }
  34. private:
  35. bool T::*ptr;
  36. };
  37. #define JSON_IS_INTEGRAL_T(Type) \
  38. typename std::enable_if<std::is_integral<Type>::value>::type
  39. template <typename T, typename N>
  40. class direct_binder<T, N, JSON_IS_INTEGRAL_T(N)> : public binder_impl<T> {
  41. public:
  42. explicit direct_binder(N T::*p) : ptr(p) {}
  43. virtual binder_impl<T>* clone() const override {
  44. return new direct_binder(*this);
  45. }
  46. virtual void parse(T& val, char const*& data,
  47. parser::options) const override {
  48. json::helper::parse_numeric(val.*ptr, data);
  49. }
  50. virtual void write(T const& val, std::ostream & data) const override {
  51. data << val.*ptr;
  52. }
  53. private:
  54. N T::*ptr;
  55. };
  56. #define JSON_IS_FLOATING_T(Type) \
  57. typename std::enable_if<std::is_floating_point<Type>::value>::type
  58. template <typename T, typename N>
  59. class direct_binder<T, N, JSON_IS_FLOATING_T(N)> : public binder_impl<T> {
  60. public:
  61. explicit direct_binder(N T::*p) : ptr(p) {}
  62. virtual binder_impl<T>* clone() const override {
  63. return new direct_binder(*this);
  64. }
  65. virtual void parse(T& val, char const*& data,
  66. parser::options) const override {
  67. json::helper::parse_double(val.*ptr, data);
  68. }
  69. virtual void write(T const& val, std::ostream & data) const override {
  70. data << std::fixed << val.*ptr;
  71. }
  72. private:
  73. N T::*ptr;
  74. };
  75. template <typename T>
  76. class direct_binder<T, std::string> : public binder_impl<T> {
  77. public:
  78. explicit direct_binder(std::string T::*p) : ptr(p) {}
  79. virtual binder_impl<T>* clone() const override {
  80. return new direct_binder(*this);
  81. }
  82. virtual void parse(T& val, char const*& data,
  83. parser::options) const override {
  84. json::helper::parse_string(val.*ptr, data);
  85. }
  86. virtual void write(T const& val, std::ostream & data) const override {
  87. data << "\"" << json::helper::replace_all(val.*ptr, "\"", "\\\"") << "\"";
  88. }
  89. private:
  90. std::string T::*ptr;
  91. };
  92. } }