json_direct_scalar_binder.hpp 3.0 KB

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