Не могу понять, как MsgPack упаковывает данные
Я пытаюсь исследовать исходный код MsgPack. В примере есть фрагмент:
std::vector<std::string> vec;
vec.push_back("MessagePack");
msgpack::sbuffer sbuf;
msgpack::pack(sbuf, vec);
В /usr/include/msgpack/object.hpp я вижу, что для упаковываемого объекта должен быть метод msgpack_pack:
template <typename Stream, typename T>
inline packer<Stream>& operator<< (packer<Stream>& o, const T& v)
{
return detail::packer_serializer<Stream, T>::pack(o, v);
}
namespace detail {
template <typename Stream, typename T>
struct packer_serializer {
static packer<Stream>& pack(packer<Stream>& o, const T& v) {
v.msgpack_pack(o);
return o;
}
};
}
Поэтому я не могу понять, как компилятор позволяет передавать std::vector в msgpack::pack.
1 ответ
Решение
MessagePack включает в себя встроенную поддержку STL.
Как вы видете src/msgpack/type/vector.hpp
реализует <<
оператор для std::vector
:
template <typename Stream, typename T>
inline packer<Stream>& operator<< (packer<Stream>& o, const std::vector<T>& v)
{
o.pack_array(v.size());
for(typename std::vector<T>::const_iterator it(v.begin()), it_end(v.end());
it != it_end; ++it) {
o.pack(*it);
}
return o;
}
А также src/msgpack/type/string.hpp
реализует тот же оператор для std::string
:
template <typename Stream>
inline packer<Stream>& operator<< (packer<Stream>& o, const std::string& v)
{
o.pack_raw(v.size());
o.pack_raw_body(v.data(), v.size());
return o;
}
Таким образом, нет проблем, чтобы упаковать std::vector<std::string>
,