]> git.sesse.net Git - casparcg/blob - core/mixer/read_frame.cpp
2.0. - read/write-frame: Doesn't need to dispatch gpu buffer destruction to ogl...
[casparcg] / core / mixer / read_frame.cpp
1 /*\r
2 * copyright (c) 2010 Sveriges Television AB <info@casparcg.com>\r
3 *\r
4 *  This file is part of CasparCG.\r
5 *\r
6 *    CasparCG is free software: you can redistribute it and/or modify\r
7 *    it under the terms of the GNU General Public License as published by\r
8 *    the Free Software Foundation, either version 3 of the License, or\r
9 *    (at your option) any later version.\r
10 *\r
11 *    CasparCG is distributed in the hope that it will be useful,\r
12 *    but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13 *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14 *    GNU General Public License for more details.\r
15 \r
16 *    You should have received a copy of the GNU General Public License\r
17 *    along with CasparCG.  If not, see <http://www.gnu.org/licenses/>.\r
18 *\r
19 */\r
20 #include "../stdafx.h"\r
21 \r
22 #include "read_frame.h"\r
23 \r
24 #include "gpu/host_buffer.h"    \r
25 #include "gpu/ogl_device.h"\r
26 \r
27 namespace caspar { namespace core {\r
28                                                                                                                                                                                                                                                                                                                         \r
29 struct read_frame::implementation : boost::noncopyable\r
30 {\r
31         std::shared_ptr<host_buffer> image_data_;\r
32         std::vector<int16_t> audio_data_;\r
33         ogl_device& ogl_;\r
34 \r
35 public:\r
36         implementation(ogl_device& ogl, safe_ptr<host_buffer>&& image_data, std::vector<int16_t>&& audio_data) \r
37                 : image_data_(std::move(image_data))\r
38                 , audio_data_(std::move(audio_data))\r
39                 , ogl_(ogl){}   \r
40         \r
41         const boost::iterator_range<const uint8_t*> image_data()\r
42         {\r
43                 if(!image_data_)\r
44                         return boost::iterator_range<const uint8_t*>();\r
45 \r
46                 auto ptr = static_cast<const uint8_t*>(image_data_->data());\r
47                 return boost::iterator_range<const uint8_t*>(ptr, ptr + image_data_->size());\r
48         }\r
49         const boost::iterator_range<const int16_t*> audio_data() const\r
50         {\r
51                 return boost::iterator_range<const int16_t*>(audio_data_.data(), audio_data_.data() + audio_data_.size());\r
52         }\r
53 };\r
54 \r
55 read_frame::read_frame(ogl_device& ogl, safe_ptr<host_buffer>&& image_data, std::vector<int16_t>&& audio_data) \r
56         : impl_(new implementation(ogl, std::move(image_data), std::move(audio_data))){}\r
57 read_frame::read_frame(){}\r
58 const boost::iterator_range<const uint8_t*> read_frame::image_data() const\r
59 {\r
60         return impl_ ? impl_->image_data() : boost::iterator_range<const uint8_t*>();\r
61 }\r
62 \r
63 const boost::iterator_range<const int16_t*> read_frame::audio_data() const\r
64 {\r
65         return impl_ ? impl_->audio_data() : boost::iterator_range<const int16_t*>();\r
66 }\r
67 \r
68 }}