89ed8fc891920a8a3fff4c7391dd02a2cb4b657e
[platform/framework/web/wrt-commons.git] / modules / core / include / dpl / abstract_input.h
1 /*
2  * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  *    Licensed under the Apache License, Version 2.0 (the "License");
5  *    you may not use this file except in compliance with the License.
6  *    You may obtain a copy of the License at
7  *
8  *        http://www.apache.org/licenses/LICENSE-2.0
9  *
10  *    Unless required by applicable law or agreed to in writing, software
11  *    distributed under the License is distributed on an "AS IS" BASIS,
12  *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  *    See the License for the specific language governing permissions and
14  *    limitations under the License.
15  */
16 /*
17  * @file        abstract_input.h
18  * @author      Przemyslaw Dobrowolski (p.dobrowolsk@samsung.com)
19  * @version     1.0
20  * @brief       This file is the header file of abstract input
21  */
22 #ifndef DPL_ABSTRACT_INPUT_H
23 #define DPL_ABSTRACT_INPUT_H
24
25 #include <dpl/exception.h>
26 #include <memory>
27
28 namespace DPL
29 {
30 class BinaryQueue;
31 typedef std::auto_ptr<BinaryQueue> BinaryQueueAutoPtr;
32
33 class AbstractInput
34 {
35 public:
36     class Exception
37     {
38     public:
39         DECLARE_EXCEPTION_TYPE(DPL::Exception, Base)
40         DECLARE_EXCEPTION_TYPE(Base, ReadFailed)
41     };
42
43 public:
44     virtual ~AbstractInput() {}
45
46     /**
47      * Read binary data from input
48      * If no data is available method returns NULL buffer.
49      * In case connection was successfuly close, method returns empty buffer
50      *
51      * @param[in] size Maximum number of bytes to read from input
52      * @return Buffer containing read bytes
53      * @throw  ReadFailed
54      */
55     virtual BinaryQueueAutoPtr Read(size_t size) = 0;
56 };
57 } // namespace DPL
58
59 #endif // DPL_ABSTRACT_INPUT_H