2 * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
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
8 * http://www.apache.org/licenses/LICENSE-2.0
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.
17 * @file named_input_pipe.cpp
18 * @author Przemyslaw Dobrowolski (p.dobrowolsk@samsung.com)
20 * @brief This file is the implementation file of named input pipe
23 #include <dpl/file_input.h>
24 #include <dpl/binary_queue.h>
25 #include <dpl/log/log.h>
33 namespace // anonymous
35 const size_t DEFAULT_READ_BUFFER_SIZE = 4096;
36 } // namespace anonymous
38 FileInput::FileInput()
43 FileInput::FileInput(const std::string& fileName)
49 FileInput::~FileInput()
54 void FileInput::Open(const std::string& fileName)
57 int fd = TEMP_FAILURE_RETRY(open(fileName.c_str(), O_RDONLY | O_NONBLOCK));
59 // Throw an exception if an error occurred
61 ThrowMsg(Exception::OpenFailed, fileName);
63 // Close if any existing
66 // Save new descriptor
69 LogPedantic("Opened file: " << fileName);
72 void FileInput::Close()
77 if (TEMP_FAILURE_RETRY(close(m_fd)) == -1)
78 Throw(Exception::CloseFailed);
82 LogPedantic("Closed file");
85 BinaryQueueAutoPtr FileInput::Read(size_t size)
87 size_t bytesToRead = size > DEFAULT_READ_BUFFER_SIZE ? DEFAULT_READ_BUFFER_SIZE : size;
89 // Malloc default read buffer size
90 // It is unmanaged, so it can be then attached directly to binary queue
91 void *buffer = malloc(bytesToRead);
94 throw std::bad_alloc();
96 LogPedantic("Trying to read " << bytesToRead << " bytes");
98 ssize_t result = TEMP_FAILURE_RETRY(read(m_fd, buffer, bytesToRead));
100 LogPedantic("Read " << result << " bytes from file");
104 // Succedded to read socket data
105 BinaryQueueAutoPtr binaryQueue(new BinaryQueue());
107 // Append unmanaged memory
108 binaryQueue->AppendUnmanaged(buffer, result, &BinaryQueue::BufferDeleterFree, NULL);
113 else if (result == 0)
115 // Socket was gracefuly closed
118 // Return empty buffer
119 return BinaryQueueAutoPtr(new BinaryQueue());
123 // Must first save errno value, because it may be altered
124 int lastErrno = errno;
129 // Interpret error result
132 // FIXME: Handle specific errno
133 Throw(AbstractInput::Exception::ReadFailed);
137 WaitableHandle FileInput::WaitableReadHandle() const
139 return static_cast<WaitableHandle>(m_fd);