basic_format_arg -> basic_arg, Buffer -> buffer
This commit is contained in:
parent
bf0f107564
commit
7ae8bd7073
101
fmt/format.h
101
fmt/format.h
@ -371,7 +371,7 @@ typedef basic_writer<char> writer;
|
|||||||
typedef basic_writer<wchar_t> wwriter;
|
typedef basic_writer<wchar_t> wwriter;
|
||||||
|
|
||||||
template <typename Context>
|
template <typename Context>
|
||||||
class basic_format_arg;
|
class basic_arg;
|
||||||
|
|
||||||
template <typename Char>
|
template <typename Char>
|
||||||
class ArgFormatter;
|
class ArgFormatter;
|
||||||
@ -587,16 +587,16 @@ inline T *make_ptr(T *ptr, std::size_t) { return ptr; }
|
|||||||
\endrst
|
\endrst
|
||||||
*/
|
*/
|
||||||
template <typename T>
|
template <typename T>
|
||||||
class Buffer {
|
class buffer {
|
||||||
private:
|
private:
|
||||||
FMT_DISALLOW_COPY_AND_ASSIGN(Buffer);
|
FMT_DISALLOW_COPY_AND_ASSIGN(buffer);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
T *ptr_;
|
T *ptr_;
|
||||||
std::size_t size_;
|
std::size_t size_;
|
||||||
std::size_t capacity_;
|
std::size_t capacity_;
|
||||||
|
|
||||||
Buffer(T *ptr = 0, std::size_t capacity = 0)
|
buffer(T *ptr = 0, std::size_t capacity = 0)
|
||||||
: ptr_(ptr), size_(0), capacity_(capacity) {}
|
: ptr_(ptr), size_(0), capacity_(capacity) {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -608,7 +608,7 @@ class Buffer {
|
|||||||
virtual void grow(std::size_t size) = 0;
|
virtual void grow(std::size_t size) = 0;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual ~Buffer() {}
|
virtual ~buffer() {}
|
||||||
|
|
||||||
/** Returns the size of this buffer. */
|
/** Returns the size of this buffer. */
|
||||||
std::size_t size() const { return size_; }
|
std::size_t size() const { return size_; }
|
||||||
@ -653,7 +653,7 @@ class Buffer {
|
|||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
template <typename U>
|
template <typename U>
|
||||||
void Buffer<T>::append(const U *begin, const U *end) {
|
void buffer<T>::append(const U *begin, const U *end) {
|
||||||
std::size_t new_size = size_ + internal::to_unsigned(end - begin);
|
std::size_t new_size = size_ + internal::to_unsigned(end - begin);
|
||||||
if (new_size > capacity_)
|
if (new_size > capacity_)
|
||||||
grow(new_size);
|
grow(new_size);
|
||||||
@ -667,7 +667,7 @@ namespace internal {
|
|||||||
// A memory buffer for trivially copyable/constructible types with the first
|
// A memory buffer for trivially copyable/constructible types with the first
|
||||||
// SIZE elements stored in the object itself.
|
// SIZE elements stored in the object itself.
|
||||||
template <typename T, std::size_t SIZE, typename Allocator = std::allocator<T> >
|
template <typename T, std::size_t SIZE, typename Allocator = std::allocator<T> >
|
||||||
class MemoryBuffer : private Allocator, public Buffer<T> {
|
class MemoryBuffer : private Allocator, public buffer<T> {
|
||||||
private:
|
private:
|
||||||
T data_[SIZE];
|
T data_[SIZE];
|
||||||
|
|
||||||
@ -681,7 +681,7 @@ class MemoryBuffer : private Allocator, public Buffer<T> {
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
explicit MemoryBuffer(const Allocator &alloc = Allocator())
|
explicit MemoryBuffer(const Allocator &alloc = Allocator())
|
||||||
: Allocator(alloc), Buffer<T>(data_, SIZE) {}
|
: Allocator(alloc), buffer<T>(data_, SIZE) {}
|
||||||
~MemoryBuffer() { deallocate(); }
|
~MemoryBuffer() { deallocate(); }
|
||||||
|
|
||||||
#if FMT_USE_RVALUE_REFERENCES
|
#if FMT_USE_RVALUE_REFERENCES
|
||||||
@ -743,9 +743,10 @@ void MemoryBuffer<T, SIZE, Allocator>::grow(std::size_t size) {
|
|||||||
|
|
||||||
// A fixed-size buffer.
|
// A fixed-size buffer.
|
||||||
template <typename Char>
|
template <typename Char>
|
||||||
class FixedBuffer : public fmt::Buffer<Char> {
|
class FixedBuffer : public fmt::buffer<Char> {
|
||||||
public:
|
public:
|
||||||
FixedBuffer(Char *array, std::size_t size) : fmt::Buffer<Char>(array, size) {}
|
FixedBuffer(Char *array, std::size_t size)
|
||||||
|
: fmt::buffer<Char>(array, size) {}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
FMT_API void grow(std::size_t size);
|
FMT_API void grow(std::size_t size);
|
||||||
@ -1322,34 +1323,34 @@ template <typename Context>
|
|||||||
class ArgMap;
|
class ArgMap;
|
||||||
|
|
||||||
template <typename Context, typename T>
|
template <typename Context, typename T>
|
||||||
basic_format_arg<Context> make_arg(const T &value);
|
basic_arg<Context> make_arg(const T &value);
|
||||||
} // namespace internal
|
} // namespace internal
|
||||||
|
|
||||||
struct monostate {};
|
struct monostate {};
|
||||||
|
|
||||||
template <typename Context>
|
template <typename Context>
|
||||||
class basic_format_args;
|
class basic_args;
|
||||||
|
|
||||||
// A formatting argument. It is a trivially copyable/constructible type to
|
// A formatting argument. It is a trivially copyable/constructible type to
|
||||||
// allow storage in internal::MemoryBuffer.
|
// allow storage in internal::MemoryBuffer.
|
||||||
template <typename Context>
|
template <typename Context>
|
||||||
class basic_format_arg {
|
class basic_arg {
|
||||||
private:
|
private:
|
||||||
internal::value<Context> value_;
|
internal::value<Context> value_;
|
||||||
internal::Type type_;
|
internal::Type type_;
|
||||||
|
|
||||||
template <typename ContextType, typename T>
|
template <typename ContextType, typename T>
|
||||||
friend basic_format_arg<ContextType> internal::make_arg(const T &value);
|
friend basic_arg<ContextType> internal::make_arg(const T &value);
|
||||||
|
|
||||||
template <typename Visitor, typename Ctx>
|
template <typename Visitor, typename Ctx>
|
||||||
friend typename std::result_of<Visitor(int)>::type
|
friend typename std::result_of<Visitor(int)>::type
|
||||||
visit(Visitor &&vis, basic_format_arg<Ctx> arg);
|
visit(Visitor &&vis, basic_arg<Ctx> arg);
|
||||||
|
|
||||||
friend class basic_format_args<Context>;
|
friend class basic_args<Context>;
|
||||||
friend class internal::ArgMap<Context>;
|
friend class internal::ArgMap<Context>;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
basic_format_arg() : type_(internal::NONE) {}
|
basic_arg() : type_(internal::NONE) {}
|
||||||
|
|
||||||
explicit operator bool() const noexcept { return type_ != internal::NONE; }
|
explicit operator bool() const noexcept { return type_ != internal::NONE; }
|
||||||
|
|
||||||
@ -1368,8 +1369,8 @@ class basic_format_arg {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef basic_format_arg<format_context> format_arg;
|
typedef basic_arg<format_context> format_arg;
|
||||||
typedef basic_format_arg<wformat_context> wformat_arg;
|
typedef basic_arg<wformat_context> wformat_arg;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
\rst
|
\rst
|
||||||
@ -1380,7 +1381,7 @@ typedef basic_format_arg<wformat_context> wformat_arg;
|
|||||||
*/
|
*/
|
||||||
template <typename Visitor, typename Context>
|
template <typename Visitor, typename Context>
|
||||||
typename std::result_of<Visitor(int)>::type
|
typename std::result_of<Visitor(int)>::type
|
||||||
visit(Visitor &&vis, basic_format_arg<Context> arg) {
|
visit(Visitor &&vis, basic_arg<Context> arg) {
|
||||||
typedef typename Context::char_type Char;
|
typedef typename Context::char_type Char;
|
||||||
switch (arg.type_) {
|
switch (arg.type_) {
|
||||||
case internal::NONE:
|
case internal::NONE:
|
||||||
@ -1422,8 +1423,8 @@ typename std::result_of<Visitor(int)>::type
|
|||||||
namespace internal {
|
namespace internal {
|
||||||
|
|
||||||
template <typename Context, typename T>
|
template <typename Context, typename T>
|
||||||
basic_format_arg<Context> make_arg(const T &value) {
|
basic_arg<Context> make_arg(const T &value) {
|
||||||
basic_format_arg<Context> arg;
|
basic_arg<Context> arg;
|
||||||
arg.type_ = internal::type<T>();
|
arg.type_ = internal::type<T>();
|
||||||
arg.value_ = value;
|
arg.value_ = value;
|
||||||
return arg;
|
return arg;
|
||||||
@ -1474,14 +1475,14 @@ void format_value(basic_writer<Char> &, const T &, Formatter &, const Char *) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename Context>
|
template <typename Context>
|
||||||
struct NamedArg : basic_format_arg<Context> {
|
struct NamedArg : basic_arg<Context> {
|
||||||
typedef typename Context::char_type Char;
|
typedef typename Context::char_type Char;
|
||||||
|
|
||||||
BasicStringRef<Char> name;
|
BasicStringRef<Char> name;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
NamedArg(BasicStringRef<Char> argname, const T &value)
|
NamedArg(BasicStringRef<Char> argname, const T &value)
|
||||||
: basic_format_arg<Context>(make_arg<Context>(value)), name(argname) {}
|
: basic_arg<Context>(make_arg<Context>(value)), name(argname) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
class RuntimeError : public std::runtime_error {
|
class RuntimeError : public std::runtime_error {
|
||||||
@ -1508,7 +1509,7 @@ inline typename std::enable_if<IS_PACKED, value<Context>>::type
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <bool IS_PACKED, typename Context, typename T>
|
template <bool IS_PACKED, typename Context, typename T>
|
||||||
inline typename std::enable_if<!IS_PACKED, basic_format_arg<Context>>::type
|
inline typename std::enable_if<!IS_PACKED, basic_arg<Context>>::type
|
||||||
make_arg(const T& value) {
|
make_arg(const T& value) {
|
||||||
return make_arg<Context>(value);
|
return make_arg<Context>(value);
|
||||||
}
|
}
|
||||||
@ -1525,7 +1526,7 @@ class format_arg_store {
|
|||||||
typedef typename Context::char_type char_type;
|
typedef typename Context::char_type char_type;
|
||||||
|
|
||||||
typedef typename std::conditional<IS_PACKED,
|
typedef typename std::conditional<IS_PACKED,
|
||||||
internal::value<Context>, basic_format_arg<Context>>::type value_type;
|
internal::value<Context>, basic_arg<Context>>::type value_type;
|
||||||
|
|
||||||
// If the arguments are not packed, add one more element to mark the end.
|
// If the arguments are not packed, add one more element to mark the end.
|
||||||
typedef std::array<value_type, NUM_ARGS + (IS_PACKED ? 0 : 1)> Array;
|
typedef std::array<value_type, NUM_ARGS + (IS_PACKED ? 0 : 1)> Array;
|
||||||
@ -1554,10 +1555,10 @@ inline format_arg_store<format_context, Args...>
|
|||||||
|
|
||||||
/** Formatting arguments. */
|
/** Formatting arguments. */
|
||||||
template <typename Context>
|
template <typename Context>
|
||||||
class basic_format_args {
|
class basic_args {
|
||||||
public:
|
public:
|
||||||
typedef unsigned size_type;
|
typedef unsigned size_type;
|
||||||
typedef basic_format_arg<Context> format_arg;
|
typedef basic_arg<Context> format_arg;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// To reduce compiled code size per formatting function call, types of first
|
// To reduce compiled code size per formatting function call, types of first
|
||||||
@ -1610,10 +1611,10 @@ class basic_format_args {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
basic_format_args() : types_(0) {}
|
basic_args() : types_(0) {}
|
||||||
|
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
basic_format_args(const format_arg_store<Context, Args...> &store)
|
basic_args(const format_arg_store<Context, Args...> &store)
|
||||||
: types_(store.TYPES) {
|
: types_(store.TYPES) {
|
||||||
set_data(store.data());
|
set_data(store.data());
|
||||||
}
|
}
|
||||||
@ -1626,8 +1627,8 @@ class basic_format_args {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef basic_format_args<format_context> format_args;
|
typedef basic_args<format_context> format_args;
|
||||||
typedef basic_format_args<wformat_context> wformat_args;
|
typedef basic_args<wformat_context> wformat_args;
|
||||||
|
|
||||||
enum Alignment {
|
enum Alignment {
|
||||||
ALIGN_DEFAULT, ALIGN_LEFT, ALIGN_RIGHT, ALIGN_CENTER, ALIGN_NUMERIC
|
ALIGN_DEFAULT, ALIGN_LEFT, ALIGN_RIGHT, ALIGN_CENTER, ALIGN_NUMERIC
|
||||||
@ -1791,15 +1792,15 @@ class ArgMap {
|
|||||||
private:
|
private:
|
||||||
typedef typename Context::char_type Char;
|
typedef typename Context::char_type Char;
|
||||||
typedef std::vector<
|
typedef std::vector<
|
||||||
std::pair<fmt::BasicStringRef<Char>, basic_format_arg<Context> > > MapType;
|
std::pair<fmt::BasicStringRef<Char>, basic_arg<Context> > > MapType;
|
||||||
typedef typename MapType::value_type Pair;
|
typedef typename MapType::value_type Pair;
|
||||||
|
|
||||||
MapType map_;
|
MapType map_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void init(const basic_format_args<Context> &args);
|
void init(const basic_args<Context> &args);
|
||||||
|
|
||||||
const basic_format_arg<Context>
|
const basic_arg<Context>
|
||||||
*find(const fmt::BasicStringRef<Char> &name) const {
|
*find(const fmt::BasicStringRef<Char> &name) const {
|
||||||
// The list is unsorted, so just return the first matching name.
|
// The list is unsorted, so just return the first matching name.
|
||||||
for (typename MapType::const_iterator it = map_.begin(), end = map_.end();
|
for (typename MapType::const_iterator it = map_.begin(), end = map_.end();
|
||||||
@ -1812,7 +1813,7 @@ class ArgMap {
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <typename Context>
|
template <typename Context>
|
||||||
void ArgMap<Context>::init(const basic_format_args<Context> &args) {
|
void ArgMap<Context>::init(const basic_args<Context> &args) {
|
||||||
if (!map_.empty())
|
if (!map_.empty())
|
||||||
return;
|
return;
|
||||||
typedef internal::NamedArg<Context> NamedArg;
|
typedef internal::NamedArg<Context> NamedArg;
|
||||||
@ -1987,17 +1988,17 @@ template <typename Char, typename Context>
|
|||||||
class format_context_base {
|
class format_context_base {
|
||||||
private:
|
private:
|
||||||
const Char *ptr_;
|
const Char *ptr_;
|
||||||
basic_format_args<Context> args_;
|
basic_args<Context> args_;
|
||||||
int next_arg_index_;
|
int next_arg_index_;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
typedef basic_format_arg<Context> format_arg;
|
typedef basic_arg<Context> format_arg;
|
||||||
|
|
||||||
format_context_base(const Char *format_str, basic_format_args<Context> args)
|
format_context_base(const Char *format_str, basic_args<Context> args)
|
||||||
: ptr_(format_str), args_(args), next_arg_index_(0) {}
|
: ptr_(format_str), args_(args), next_arg_index_(0) {}
|
||||||
~format_context_base() {}
|
~format_context_base() {}
|
||||||
|
|
||||||
basic_format_args<Context> args() const { return args_; }
|
basic_args<Context> args() const { return args_; }
|
||||||
|
|
||||||
// Returns the argument with specified index.
|
// Returns the argument with specified index.
|
||||||
format_arg do_get_arg(unsigned arg_index, const char *&error) {
|
format_arg do_get_arg(unsigned arg_index, const char *&error) {
|
||||||
@ -2097,7 +2098,7 @@ class basic_format_context :
|
|||||||
\endrst
|
\endrst
|
||||||
*/
|
*/
|
||||||
basic_format_context(const Char *format_str,
|
basic_format_context(const Char *format_str,
|
||||||
basic_format_args<basic_format_context> args)
|
basic_args<basic_format_context> args)
|
||||||
: Base(format_str, args) {}
|
: Base(format_str, args) {}
|
||||||
|
|
||||||
// Parses argument id and returns corresponding argument.
|
// Parses argument id and returns corresponding argument.
|
||||||
@ -2203,7 +2204,7 @@ class basic_writer {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
// Output buffer.
|
// Output buffer.
|
||||||
Buffer<Char> &buffer_;
|
buffer<Char> &buffer_;
|
||||||
|
|
||||||
FMT_DISALLOW_COPY_AND_ASSIGN(basic_writer);
|
FMT_DISALLOW_COPY_AND_ASSIGN(basic_writer);
|
||||||
|
|
||||||
@ -2306,7 +2307,7 @@ class basic_writer {
|
|||||||
/**
|
/**
|
||||||
Constructs a ``basic_writer`` object.
|
Constructs a ``basic_writer`` object.
|
||||||
*/
|
*/
|
||||||
explicit basic_writer(Buffer<Char> &b) : buffer_(b) {}
|
explicit basic_writer(buffer<Char> &b) : buffer_(b) {}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
@ -2348,7 +2349,7 @@ class basic_writer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void vformat(BasicCStringRef<Char> format,
|
void vformat(BasicCStringRef<Char> format,
|
||||||
basic_format_args<basic_format_context<Char>> args);
|
basic_args<basic_format_context<Char>> args);
|
||||||
/**
|
/**
|
||||||
\rst
|
\rst
|
||||||
Writes formatted data.
|
Writes formatted data.
|
||||||
@ -2447,7 +2448,7 @@ class basic_writer {
|
|||||||
|
|
||||||
void clear() FMT_NOEXCEPT { buffer_.clear(); }
|
void clear() FMT_NOEXCEPT { buffer_.clear(); }
|
||||||
|
|
||||||
Buffer<Char> &buffer() FMT_NOEXCEPT { return buffer_; }
|
buffer<Char> &buffer() FMT_NOEXCEPT { return buffer_; }
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename Char>
|
template <typename Char>
|
||||||
@ -3242,7 +3243,7 @@ unsigned parse_nonnegative_int(const Char *&s) {
|
|||||||
|
|
||||||
template <typename Char>
|
template <typename Char>
|
||||||
inline void require_numeric_argument(
|
inline void require_numeric_argument(
|
||||||
const basic_format_arg<Char> &arg, char spec) {
|
const basic_arg<Char> &arg, char spec) {
|
||||||
if (!arg.is_numeric()) {
|
if (!arg.is_numeric()) {
|
||||||
FMT_THROW(fmt::format_error(
|
FMT_THROW(fmt::format_error(
|
||||||
fmt::format("format specifier '{}' requires numeric argument", spec)));
|
fmt::format("format specifier '{}' requires numeric argument", spec)));
|
||||||
@ -3264,7 +3265,7 @@ struct IsUnsigned {
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <typename Char, typename Context>
|
template <typename Char, typename Context>
|
||||||
void check_sign(const Char *&s, const basic_format_arg<Context> &arg) {
|
void check_sign(const Char *&s, const basic_arg<Context> &arg) {
|
||||||
char sign = static_cast<char>(*s);
|
char sign = static_cast<char>(*s);
|
||||||
require_numeric_argument(arg, sign);
|
require_numeric_argument(arg, sign);
|
||||||
if (visit(IsUnsigned(), arg)) {
|
if (visit(IsUnsigned(), arg)) {
|
||||||
@ -3378,7 +3379,7 @@ inline typename basic_format_context<Char>::format_arg
|
|||||||
|
|
||||||
// Formats a single argument.
|
// Formats a single argument.
|
||||||
template <typename ArgFormatter, typename Char, typename Context>
|
template <typename ArgFormatter, typename Char, typename Context>
|
||||||
void do_format_arg(basic_writer<Char> &writer, basic_format_arg<Context> arg,
|
void do_format_arg(basic_writer<Char> &writer, basic_arg<Context> arg,
|
||||||
Context &ctx) {
|
Context &ctx) {
|
||||||
const Char *&s = ctx.ptr();
|
const Char *&s = ctx.ptr();
|
||||||
basic_format_specs<Char> spec;
|
basic_format_specs<Char> spec;
|
||||||
@ -3505,7 +3506,7 @@ void do_format_arg(basic_writer<Char> &writer, basic_format_arg<Context> arg,
|
|||||||
/** Formats arguments and writes the output to the writer. */
|
/** Formats arguments and writes the output to the writer. */
|
||||||
template <typename ArgFormatter, typename Char, typename Context>
|
template <typename ArgFormatter, typename Char, typename Context>
|
||||||
void vwrite(basic_writer<Char> &writer, BasicCStringRef<Char> format_str,
|
void vwrite(basic_writer<Char> &writer, BasicCStringRef<Char> format_str,
|
||||||
basic_format_args<Context> args) {
|
basic_args<Context> args) {
|
||||||
basic_format_context<Char> ctx(format_str.c_str(), args);
|
basic_format_context<Char> ctx(format_str.c_str(), args);
|
||||||
const Char *&s = ctx.ptr();
|
const Char *&s = ctx.ptr();
|
||||||
const Char *start = s;
|
const Char *start = s;
|
||||||
@ -3531,7 +3532,7 @@ void vwrite(basic_writer<Char> &writer, BasicCStringRef<Char> format_str,
|
|||||||
template <typename Char>
|
template <typename Char>
|
||||||
inline void basic_writer<Char>::vformat(
|
inline void basic_writer<Char>::vformat(
|
||||||
BasicCStringRef<Char> format,
|
BasicCStringRef<Char> format,
|
||||||
basic_format_args<basic_format_context<Char>> args) {
|
basic_args<basic_format_context<Char>> args) {
|
||||||
vwrite<ArgFormatter<Char>>(*this, format, args);
|
vwrite<ArgFormatter<Char>>(*this, format, args);
|
||||||
}
|
}
|
||||||
} // namespace fmt
|
} // namespace fmt
|
||||||
|
@ -23,11 +23,11 @@ class FormatBuf : public std::basic_streambuf<Char> {
|
|||||||
typedef typename std::basic_streambuf<Char>::int_type int_type;
|
typedef typename std::basic_streambuf<Char>::int_type int_type;
|
||||||
typedef typename std::basic_streambuf<Char>::traits_type traits_type;
|
typedef typename std::basic_streambuf<Char>::traits_type traits_type;
|
||||||
|
|
||||||
Buffer<Char> &buffer_;
|
buffer<Char> &buffer_;
|
||||||
Char *start_;
|
Char *start_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
FormatBuf(Buffer<Char> &buffer) : buffer_(buffer), start_(&buffer[0]) {
|
FormatBuf(buffer<Char> &buffer) : buffer_(buffer), start_(&buffer[0]) {
|
||||||
this->setp(start_, start_ + buffer_.capacity());
|
this->setp(start_, start_ + buffer_.capacity());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
20
fmt/printf.h
20
fmt/printf.h
@ -85,11 +85,11 @@ class ArgConverter {
|
|||||||
private:
|
private:
|
||||||
typedef typename Context::char_type Char;
|
typedef typename Context::char_type Char;
|
||||||
|
|
||||||
basic_format_arg<Context> &arg_;
|
basic_arg<Context> &arg_;
|
||||||
typename Context::char_type type_;
|
typename Context::char_type type_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ArgConverter(basic_format_arg<Context> &arg, Char type)
|
ArgConverter(basic_arg<Context> &arg, Char type)
|
||||||
: arg_(arg), type_(type) {}
|
: arg_(arg), type_(type) {}
|
||||||
|
|
||||||
void operator()(bool value) {
|
void operator()(bool value) {
|
||||||
@ -139,7 +139,7 @@ class ArgConverter {
|
|||||||
// type depending on the type specifier: 'd' and 'i' - signed, other -
|
// type depending on the type specifier: 'd' and 'i' - signed, other -
|
||||||
// unsigned).
|
// unsigned).
|
||||||
template <typename T, typename Context, typename Char>
|
template <typename T, typename Context, typename Char>
|
||||||
void convert_arg(basic_format_arg<Context> &arg, Char type) {
|
void convert_arg(basic_arg<Context> &arg, Char type) {
|
||||||
visit(ArgConverter<T, Context>(arg, type), arg);
|
visit(ArgConverter<T, Context>(arg, type), arg);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -147,12 +147,12 @@ void convert_arg(basic_format_arg<Context> &arg, Char type) {
|
|||||||
template <typename Context>
|
template <typename Context>
|
||||||
class CharConverter {
|
class CharConverter {
|
||||||
private:
|
private:
|
||||||
basic_format_arg<Context> &arg_;
|
basic_arg<Context> &arg_;
|
||||||
|
|
||||||
FMT_DISALLOW_COPY_AND_ASSIGN(CharConverter);
|
FMT_DISALLOW_COPY_AND_ASSIGN(CharConverter);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit CharConverter(basic_format_arg<Context> &arg) : arg_(arg) {}
|
explicit CharConverter(basic_arg<Context> &arg) : arg_(arg) {}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
typename std::enable_if<std::is_integral<T>::value>::type
|
typename std::enable_if<std::is_integral<T>::value>::type
|
||||||
@ -287,7 +287,7 @@ class PrintfArgFormatter : public internal::ArgFormatterBase<Char> {
|
|||||||
/** Formats an argument of a custom (user-defined) type. */
|
/** Formats an argument of a custom (user-defined) type. */
|
||||||
void operator()(internal::CustomValue<Char> c) {
|
void operator()(internal::CustomValue<Char> c) {
|
||||||
const Char format_str[] = {'}', '\0'};
|
const Char format_str[] = {'}', '\0'};
|
||||||
auto args = basic_format_args<basic_format_context<Char>>();
|
auto args = basic_args<basic_format_context<Char>>();
|
||||||
basic_format_context<Char> ctx(format_str, args);
|
basic_format_context<Char> ctx(format_str, args);
|
||||||
c.format(this->writer(), c.value, &ctx);
|
c.format(this->writer(), c.value, &ctx);
|
||||||
}
|
}
|
||||||
@ -328,7 +328,7 @@ class printf_context :
|
|||||||
\endrst
|
\endrst
|
||||||
*/
|
*/
|
||||||
explicit printf_context(BasicCStringRef<Char> format_str,
|
explicit printf_context(BasicCStringRef<Char> format_str,
|
||||||
basic_format_args<printf_context> args)
|
basic_args<printf_context> args)
|
||||||
: Base(format_str.c_str(), args) {}
|
: Base(format_str.c_str(), args) {}
|
||||||
|
|
||||||
/** Formats stored arguments and writes the output to the writer. */
|
/** Formats stored arguments and writes the output to the writer. */
|
||||||
@ -516,11 +516,11 @@ void format_value(basic_writer<Char> &w, const T &value,
|
|||||||
|
|
||||||
template <typename Char>
|
template <typename Char>
|
||||||
void printf(basic_writer<Char> &w, BasicCStringRef<Char> format,
|
void printf(basic_writer<Char> &w, BasicCStringRef<Char> format,
|
||||||
basic_format_args<printf_context<Char>> args) {
|
basic_args<printf_context<Char>> args) {
|
||||||
printf_context<Char>(format, args).format(w);
|
printf_context<Char>(format, args).format(w);
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef basic_format_args<printf_context<char>> printf_args;
|
typedef basic_args<printf_context<char>> printf_args;
|
||||||
|
|
||||||
inline std::string vsprintf(CStringRef format, printf_args args) {
|
inline std::string vsprintf(CStringRef format, printf_args args) {
|
||||||
MemoryWriter w;
|
MemoryWriter w;
|
||||||
@ -543,7 +543,7 @@ inline std::string sprintf(CStringRef format_str, const Args & ... args) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline std::wstring vsprintf(
|
inline std::wstring vsprintf(
|
||||||
WCStringRef format, basic_format_args<printf_context<wchar_t>> args) {
|
WCStringRef format, basic_args<printf_context<wchar_t>> args) {
|
||||||
WMemoryWriter w;
|
WMemoryWriter w;
|
||||||
printf(w, format, args);
|
printf(w, format, args);
|
||||||
return w.str();
|
return w.str();
|
||||||
|
@ -18,7 +18,7 @@ namespace internal {
|
|||||||
|
|
||||||
// A buffer that stores data in ``std::string``.
|
// A buffer that stores data in ``std::string``.
|
||||||
template <typename Char>
|
template <typename Char>
|
||||||
class StringBuffer : public Buffer<Char> {
|
class StringBuffer : public buffer<Char> {
|
||||||
private:
|
private:
|
||||||
std::basic_string<Char> data_;
|
std::basic_string<Char> data_;
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ void format_value(writer &w, const std::tm &tm, format_context &ctx) {
|
|||||||
internal::MemoryBuffer<char, internal::INLINE_BUFFER_SIZE> format;
|
internal::MemoryBuffer<char, internal::INLINE_BUFFER_SIZE> format;
|
||||||
format.append(s, end + 1);
|
format.append(s, end + 1);
|
||||||
format[format.size() - 1] = '\0';
|
format[format.size() - 1] = '\0';
|
||||||
Buffer<char> &buffer = w.buffer();
|
buffer<char> &buffer = w.buffer();
|
||||||
std::size_t start = buffer.size();
|
std::size_t start = buffer.size();
|
||||||
for (;;) {
|
for (;;) {
|
||||||
std::size_t size = buffer.capacity() - start;
|
std::size_t size = buffer.capacity() - start;
|
||||||
|
@ -63,7 +63,7 @@ typedef fmt::printf_context<char, CustomPrintfArgFormatter>
|
|||||||
|
|
||||||
std::string custom_vsprintf(
|
std::string custom_vsprintf(
|
||||||
const char* format_str,
|
const char* format_str,
|
||||||
fmt::basic_format_args<CustomPrintfFormatter> args) {
|
fmt::basic_args<CustomPrintfFormatter> args) {
|
||||||
fmt::MemoryWriter writer;
|
fmt::MemoryWriter writer;
|
||||||
CustomPrintfFormatter formatter(format_str, args);
|
CustomPrintfFormatter formatter(format_str, args);
|
||||||
formatter.format(writer);
|
formatter.format(writer);
|
||||||
|
@ -136,7 +136,7 @@ TEST(OStreamTest, WriteToOStreamMaxSize) {
|
|||||||
|
|
||||||
class TestWriter : public fmt::basic_writer<char> {
|
class TestWriter : public fmt::basic_writer<char> {
|
||||||
private:
|
private:
|
||||||
struct TestBuffer : fmt::Buffer<char> {
|
struct TestBuffer : fmt::buffer<char> {
|
||||||
explicit TestBuffer(std::size_t size) { size_ = size; }
|
explicit TestBuffer(std::size_t size) { size_ = size; }
|
||||||
void grow(std::size_t) {}
|
void grow(std::size_t) {}
|
||||||
} buffer_;
|
} buffer_;
|
||||||
|
@ -52,9 +52,9 @@
|
|||||||
#undef min
|
#undef min
|
||||||
#undef max
|
#undef max
|
||||||
|
|
||||||
using fmt::basic_format_arg;
|
using fmt::basic_arg;
|
||||||
using fmt::format_arg;
|
using fmt::format_arg;
|
||||||
using fmt::Buffer;
|
using fmt::buffer;
|
||||||
using fmt::StringRef;
|
using fmt::StringRef;
|
||||||
using fmt::internal::MemoryBuffer;
|
using fmt::internal::MemoryBuffer;
|
||||||
using fmt::internal::value;
|
using fmt::internal::value;
|
||||||
@ -74,7 +74,7 @@ void format_value(fmt::basic_writer<Char> &w, Test,
|
|||||||
}
|
}
|
||||||
|
|
||||||
template <typename Context, typename T>
|
template <typename Context, typename T>
|
||||||
basic_format_arg<Context> make_arg(const T &value) {
|
basic_arg<Context> make_arg(const T &value) {
|
||||||
return fmt::internal::make_arg<Context>(value);
|
return fmt::internal::make_arg<Context>(value);
|
||||||
}
|
}
|
||||||
} // namespace
|
} // namespace
|
||||||
@ -107,24 +107,24 @@ TEST(AllocatorTest, AllocatorRef) {
|
|||||||
|
|
||||||
#if FMT_USE_TYPE_TRAITS
|
#if FMT_USE_TYPE_TRAITS
|
||||||
TEST(BufferTest, Noncopyable) {
|
TEST(BufferTest, Noncopyable) {
|
||||||
EXPECT_FALSE(std::is_copy_constructible<Buffer<char> >::value);
|
EXPECT_FALSE(std::is_copy_constructible<buffer<char> >::value);
|
||||||
EXPECT_FALSE(std::is_copy_assignable<Buffer<char> >::value);
|
EXPECT_FALSE(std::is_copy_assignable<buffer<char> >::value);
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(BufferTest, Nonmoveable) {
|
TEST(BufferTest, Nonmoveable) {
|
||||||
EXPECT_FALSE(std::is_move_constructible<Buffer<char> >::value);
|
EXPECT_FALSE(std::is_move_constructible<buffer<char> >::value);
|
||||||
EXPECT_FALSE(std::is_move_assignable<Buffer<char> >::value);
|
EXPECT_FALSE(std::is_move_assignable<buffer<char> >::value);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// A test buffer with a dummy grow method.
|
// A test buffer with a dummy grow method.
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct TestBuffer : Buffer<T> {
|
struct TestBuffer : buffer<T> {
|
||||||
void grow(std::size_t size) { this->capacity_ = size; }
|
void grow(std::size_t size) { this->capacity_ = size; }
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct MockBuffer : Buffer<T> {
|
struct MockBuffer : buffer<T> {
|
||||||
MOCK_METHOD1(do_grow, void (std::size_t size));
|
MOCK_METHOD1(do_grow, void (std::size_t size));
|
||||||
|
|
||||||
void grow(std::size_t size) {
|
void grow(std::size_t size) {
|
||||||
@ -133,8 +133,8 @@ struct MockBuffer : Buffer<T> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
MockBuffer() {}
|
MockBuffer() {}
|
||||||
MockBuffer(T *ptr) : Buffer<T>(ptr) {}
|
MockBuffer(T *ptr) : buffer<T>(ptr) {}
|
||||||
MockBuffer(T *ptr, std::size_t capacity) : Buffer<T>(ptr, capacity) {}
|
MockBuffer(T *ptr, std::size_t capacity) : buffer<T>(ptr, capacity) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
TEST(BufferTest, Ctor) {
|
TEST(BufferTest, Ctor) {
|
||||||
@ -170,7 +170,7 @@ TEST(BufferTest, VirtualDtor) {
|
|||||||
typedef StrictMock<DyingBuffer> StictMockBuffer;
|
typedef StrictMock<DyingBuffer> StictMockBuffer;
|
||||||
StictMockBuffer *mock_buffer = new StictMockBuffer();
|
StictMockBuffer *mock_buffer = new StictMockBuffer();
|
||||||
EXPECT_CALL(*mock_buffer, die());
|
EXPECT_CALL(*mock_buffer, die());
|
||||||
Buffer<int> *buffer = mock_buffer;
|
buffer<int> *buffer = mock_buffer;
|
||||||
delete buffer;
|
delete buffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -181,7 +181,7 @@ TEST(BufferTest, Access) {
|
|||||||
EXPECT_EQ(11, buffer[0]);
|
EXPECT_EQ(11, buffer[0]);
|
||||||
buffer[3] = 42;
|
buffer[3] = 42;
|
||||||
EXPECT_EQ(42, *(&buffer[0] + 3));
|
EXPECT_EQ(42, *(&buffer[0] + 3));
|
||||||
const Buffer<char> &const_buffer = buffer;
|
const fmt::buffer<char> &const_buffer = buffer;
|
||||||
EXPECT_EQ(42, const_buffer[3]);
|
EXPECT_EQ(42, const_buffer[3]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user