// // json_direct_map_binder.hpp // json // // Created by Sam Jaffe on 4/23/16. // #pragma once namespace json { namespace binder { template class direct_binder > : public binder_impl { public: direct_binder(std::vector T::*p, binder const&i); virtual binder_impl* clone() const override { return new direct_binder(*this); } virtual void parse(T& val, char const*& data) const override { const char ch = json::helper::get_next_element(data); if (ch != '{') { throw json::malformed_json_exception("Expected an array type"); } ++data; V to_make; std::map& vec = val.*ptr; std::string key; while (*data && *data != '}') { json::helper::parse_string(key, data); if (json::helper::get_next_element(data) != ':') { throw json::malformed_json_exception(std::string("Expected key:value pair delimited by ':', got '") + *data + "' instead"); } impl.parse(to_make, ++data); vec.emplace(key, to_make); json::helper::advance_to_boundary('}', data); } if (*data) ++data; else throw json::unterminated_json_exception("Reached end of parse string without finding object end"); } virtual void write(T const& val, std::ostream & data) const override { data << '{'; std::map const & map = val.*ptr; typename std::map::const_iterator it = map.begin(), end = map.end(); if (it != end) { data << '"' << it->first << '"' << ':'; impl.write(it->second, data); for (++it; it != end; ++it) { data << ','; data << '"' << it->first << '"' << ':'; impl.write(it->second, data); } } data << '}'; } private: std::map T::*ptr; binder impl; }; } }