mirror of
https://github.com/matrix-construct/construct
synced 2025-01-01 02:14:13 +01:00
ircd::buffer: Add some doc; fixes.
This commit is contained in:
parent
84d7746165
commit
eeceba51b8
1 changed files with 23 additions and 6 deletions
|
@ -106,6 +106,8 @@ namespace ircd
|
||||||
using buffer::mutable_buffers;
|
using buffer::mutable_buffers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Base for all buffer types
|
||||||
|
///
|
||||||
template<class it>
|
template<class it>
|
||||||
struct ircd::buffer::buffer
|
struct ircd::buffer::buffer
|
||||||
:std::tuple<it, it>
|
:std::tuple<it, it>
|
||||||
|
@ -160,6 +162,9 @@ namespace ircd::buffer
|
||||||
template<class T> struct mutable_buffer_base;
|
template<class T> struct mutable_buffer_base;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Base for mutable buffers, or buffers which can be written to because they
|
||||||
|
/// are not const.
|
||||||
|
///
|
||||||
template<class T>
|
template<class T>
|
||||||
struct ircd::buffer::mutable_buffer_base
|
struct ircd::buffer::mutable_buffer_base
|
||||||
:buffer<T>
|
:buffer<T>
|
||||||
|
@ -179,14 +184,19 @@ struct ircd::buffer::mutable_buffer_base
|
||||||
}
|
}
|
||||||
|
|
||||||
using buffer<T>::buffer;
|
using buffer<T>::buffer;
|
||||||
|
mutable_buffer_base(): buffer<T>{} {}
|
||||||
|
|
||||||
// lvalue string reference offered to write through to a std::string as
|
// lvalue string reference offered to write through to a std::string as
|
||||||
// the buffer. not explicit; should be hard to bind by accident...
|
// the buffer. not explicit; should be hard to bind by accident...
|
||||||
mutable_buffer_base(std::string &buf)
|
mutable_buffer_base(std::string &buf)
|
||||||
:mutable_buffer_base<iterator>{const_cast<char *>(buf.data()), buf.size()}
|
:mutable_buffer_base<iterator>{const_cast<iterator>(buf.data()), buf.size()}
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// A writable buffer of signed char data. Convention is for this buffer to
|
||||||
|
/// represent readable strings, which may or may not be null terminated. This
|
||||||
|
/// is just a convention; not a gurantee of the type.
|
||||||
|
///
|
||||||
struct ircd::buffer::mutable_buffer
|
struct ircd::buffer::mutable_buffer
|
||||||
:mutable_buffer_base<char *>
|
:mutable_buffer_base<char *>
|
||||||
{
|
{
|
||||||
|
@ -196,13 +206,19 @@ struct ircd::buffer::mutable_buffer
|
||||||
using mutable_buffer_base<char *>::mutable_buffer_base;
|
using mutable_buffer_base<char *>::mutable_buffer_base;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/// A writable buffer of unsigned signed char data. Convention is for this
|
||||||
|
/// buffer to represent unreadable binary data. It may also be constructed
|
||||||
|
/// from a mutable_buffer because a buffer of any data (this one) can also
|
||||||
|
/// be readable data. The inverse is not true, mutable_buffer cannot be
|
||||||
|
/// constructed from this class.
|
||||||
|
///
|
||||||
struct ircd::buffer::mutable_raw_buffer
|
struct ircd::buffer::mutable_raw_buffer
|
||||||
:mutable_buffer_base<unsigned char *>
|
:mutable_buffer_base<unsigned char *>
|
||||||
{
|
{
|
||||||
// Conversion offered for the analogous asio buffer
|
// Conversion offered for the analogous asio buffer
|
||||||
operator boost::asio::mutable_buffer() const;
|
operator boost::asio::mutable_buffer() const;
|
||||||
|
|
||||||
using mutable_buffer_base<unsigned char *>::mutable_buffer_base;
|
using mutable_buffer_base<iterator>::mutable_buffer_base;
|
||||||
|
|
||||||
mutable_raw_buffer(const mutable_buffer &b)
|
mutable_raw_buffer(const mutable_buffer &b)
|
||||||
:mutable_buffer_base<iterator>{reinterpret_cast<iterator>(data(b)), size(b)}
|
:mutable_buffer_base<iterator>{reinterpret_cast<iterator>(data(b)), size(b)}
|
||||||
|
@ -221,18 +237,19 @@ struct ircd::buffer::const_buffer_base
|
||||||
using iterator = typename buffer<T>::iterator;
|
using iterator = typename buffer<T>::iterator;
|
||||||
using value_type = typename buffer<T>::value_type;
|
using value_type = typename buffer<T>::value_type;
|
||||||
|
|
||||||
using buffer<T>::buffer;
|
using buffer<iterator>::buffer;
|
||||||
|
const_buffer_base(): buffer<T>{} {}
|
||||||
|
|
||||||
const_buffer_base(const mutable_buffer &b)
|
const_buffer_base(const mutable_buffer &b)
|
||||||
:buffer<T>{data(b), size(b)}
|
:buffer<iterator>{reinterpret_cast<iterator>(data(b)), size(b)}
|
||||||
{}
|
{}
|
||||||
|
|
||||||
const_buffer_base(const string_view &s)
|
const_buffer_base(const string_view &s)
|
||||||
:buffer<T>{std::begin(s), std::end(s)}
|
:buffer<iterator>{reinterpret_cast<iterator>(s.data()), s.size()}
|
||||||
{}
|
{}
|
||||||
|
|
||||||
explicit const_buffer_base(const std::string &s)
|
explicit const_buffer_base(const std::string &s)
|
||||||
:buffer<T>{s.data(), s.size()}
|
:buffer<iterator>{reinterpret_cast<iterator>(s.data()), s.size()}
|
||||||
{}
|
{}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue