Chromium Code Reviews| Index: remoting/host/chromoting_param_traits.cc |
| diff --git a/remoting/host/chromoting_param_traits.cc b/remoting/host/chromoting_param_traits.cc |
| index 8b10a7f764308bca6d501b4399a94be2f7891ea4..8050dc19859375fa76c4ae51da96b72739f3de03 100644 |
| --- a/remoting/host/chromoting_param_traits.cc |
| +++ b/remoting/host/chromoting_param_traits.cc |
| @@ -5,6 +5,7 @@ |
| #include "remoting/host/chromoting_param_traits.h" |
| #include "base/strings/stringprintf.h" |
| +#include "third_party/webrtc/modules/desktop_capture/desktop_frame.h" |
| namespace IPC { |
| @@ -88,6 +89,72 @@ void ParamTraits<webrtc::DesktopRect>::Log(const webrtc::DesktopRect& p, |
| } |
| // static |
| +void ParamTraits<webrtc::MouseCursor>::Write( |
| + Message* m, |
| + const webrtc::MouseCursor& p) { |
| + ParamTraits<webrtc::DesktopSize>::Write(m, p.image()->size()); |
| + |
| + // Data is serialized in such a way that size is exactly width * height * |
| + // |kBytesPerPixel|. |
| + std::string data; |
| + uint8_t* current_row = p.image()->data(); |
| + for (int y = 0; y < p.image()->size().height(); ++y) { |
| + data.append(current_row, |
| + current_row + p.image()->size().width() * |
| + webrtc::DesktopFrame::kBytesPerPixel); |
| + current_row += p.image()->stride(); |
| + } |
| + m->WriteData(reinterpret_cast<const char*>(p.image()->data()), data.size()); |
| + |
| + ParamTraits<webrtc::DesktopVector>::Write(m, p.hotspot()); |
| +} |
| + |
| +// static |
| +bool ParamTraits<webrtc::MouseCursor>::Read( |
| + const Message* m, |
| + PickleIterator* iter, |
| + webrtc::MouseCursor* r) { |
| + webrtc::DesktopSize size; |
| + if (!ParamTraits<webrtc::DesktopSize>::Read(m, iter, &size) || |
| + size.width() <= 0 || size.width() > (SHRT_MAX / 2) || |
| + size.height() <= 0 || size.height() > (SHRT_MAX / 2)) { |
| + return false; |
| + } |
| + |
| + const int expected_length = |
| + size.width() * size.height() * webrtc::DesktopFrame::kBytesPerPixel; |
| + |
| + const char* data; |
| + int data_length; |
| + if (!m->ReadData(iter, &data, &data_length) || |
| + data_length != expected_length) { |
| + return false; |
| + } |
| + |
| + webrtc::DesktopVector hotspot; |
| + if (!ParamTraits<webrtc::DesktopVector>::Read(m, iter, &hotspot)) |
| + return false; |
|
Cris Neckar
2014/01/23 20:16:32
In the constructor for MouseCursor there is an ass
Wez
2014/01/23 20:56:18
In general it's valid to have a hotspot outside a
Sergey Ulanov
2014/01/23 21:32:14
Neither the capturers nor the PPB_MouseCursor inte
|
| + |
| + webrtc::BasicDesktopFrame* image = new webrtc::BasicDesktopFrame(size); |
| + memcpy(image->data(), data, data_length); |
| + |
| + r->set_image(image); |
| + r->set_hotspot(hotspot); |
| + return true; |
| +} |
| + |
| +// static |
| +void ParamTraits<webrtc::MouseCursor>::Log( |
| + const webrtc::MouseCursor& p, |
| + std::string* l) { |
| + l->append(base::StringPrintf( |
| + "webrtc::DesktopRect{image(%d, %d), hotspot(%d, %d)}", |
| + p.image()->size().width(), p.image()->size().height(), |
| + p.hotspot().x(), p.hotspot().y())); |
| +} |
| + |
| + |
| +// static |
| void ParamTraits<remoting::ScreenResolution>::Write( |
| Message* m, |
| const remoting::ScreenResolution& p) { |