2012-08-24 23:13:42 +02:00
|
|
|
//
|
|
|
|
// memq_dgram.hpp
|
|
|
|
// OpenVPN
|
|
|
|
//
|
|
|
|
// Copyright (c) 2012 OpenVPN Technologies, Inc. All rights reserved.
|
|
|
|
//
|
|
|
|
|
2012-02-06 21:39:10 +01:00
|
|
|
#ifndef OPENVPN_FRAME_MEMQ_DGRAM_H
|
|
|
|
#define OPENVPN_FRAME_MEMQ_DGRAM_H
|
2011-10-25 19:32:26 +02:00
|
|
|
|
|
|
|
#include <openvpn/common/types.hpp>
|
|
|
|
#include <openvpn/common/exception.hpp>
|
|
|
|
#include <openvpn/buffer/memq.hpp>
|
|
|
|
#include <openvpn/frame/frame.hpp>
|
|
|
|
|
|
|
|
namespace openvpn {
|
|
|
|
|
|
|
|
class MemQDgram : public MemQBase {
|
|
|
|
public:
|
|
|
|
OPENVPN_SIMPLE_EXCEPTION(frame_uninitialized);
|
|
|
|
|
|
|
|
MemQDgram() {}
|
2011-12-11 09:28:55 +01:00
|
|
|
explicit MemQDgram(const Frame::Ptr& frame) : frame_(frame) {}
|
|
|
|
void set_frame(const Frame::Ptr& frame) { frame_ = frame; }
|
2011-10-25 19:32:26 +02:00
|
|
|
|
|
|
|
size_t pending() const
|
|
|
|
{
|
|
|
|
return empty() ? 0 : q.front()->size();
|
|
|
|
}
|
|
|
|
|
|
|
|
void write(const unsigned char *data, size_t size)
|
|
|
|
{
|
|
|
|
if (frame_)
|
|
|
|
{
|
|
|
|
const Frame::Context& fc = (*frame_)[Frame::READ_BIO_MEMQ_STREAM];
|
|
|
|
q.push_back(fc.alloc_with_data(data, size));
|
|
|
|
length += size;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
throw frame_uninitialized();
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t read(unsigned char *data, size_t len)
|
|
|
|
{
|
|
|
|
BufferPtr& b = q.front();
|
|
|
|
if (len > b->size())
|
|
|
|
len = b->size();
|
|
|
|
b->read(data, len);
|
|
|
|
if (b->empty())
|
|
|
|
q.pop_front();
|
|
|
|
length -= len;
|
|
|
|
return len;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2011-12-11 09:28:55 +01:00
|
|
|
Frame::Ptr frame_;
|
2011-10-25 19:32:26 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace openvpn
|
|
|
|
|
2012-02-06 21:39:10 +01:00
|
|
|
#endif // OPENVPN_FRAME_MEMQ_DGRAM_H
|