mirror of
https://github.com/gabime/spdlog.git
synced 2025-01-13 01:10:26 +08:00
micro optimize scoped_padder
This commit is contained in:
parent
3ff541cf77
commit
3cdf2b7f04
@ -48,31 +48,29 @@ struct padding_info
|
|||||||
class scoped_pad
|
class scoped_pad
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
static const size_t max_width = 128;
|
|
||||||
|
|
||||||
scoped_pad(size_t wrapped_size, padding_info &padinfo, fmt::memory_buffer &dest):
|
scoped_pad(size_t wrapped_size, padding_info &padinfo, fmt::memory_buffer &dest):
|
||||||
padinfo_(padinfo)
|
padinfo_(padinfo)
|
||||||
, dest_(dest)
|
, dest_(dest)
|
||||||
, nchars_(padinfo_.width_ > wrapped_size ? padinfo_.width_ - wrapped_size : 0)
|
|
||||||
{
|
{
|
||||||
|
|
||||||
if(nchars_ == 0)
|
if(padinfo_.width_ <= wrapped_size)
|
||||||
{
|
{
|
||||||
|
nchars_ = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
nchars_= padinfo.width_ - wrapped_size;
|
||||||
if (padinfo_.side_ == padding_info::left)
|
if (padinfo_.side_ == padding_info::left)
|
||||||
{
|
{
|
||||||
pad_it(nchars_);
|
pad_it(nchars_);
|
||||||
nchars_ = 0;
|
nchars_ = 0;
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
else if(padinfo_.side_ == padding_info::center)
|
else if(padinfo_.side_ == padding_info::center)
|
||||||
{
|
{
|
||||||
|
auto half_chars = nchars_/ 2;
|
||||||
pad_it(nchars_/ 2);
|
auto reminder = nchars_ % 2;
|
||||||
return;
|
pad_it(half_chars);
|
||||||
|
nchars_= half_chars + reminder; //for the right side
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,27 +81,17 @@ public:
|
|||||||
|
|
||||||
~scoped_pad()
|
~scoped_pad()
|
||||||
{
|
{
|
||||||
|
if(nchars_)
|
||||||
if(nchars_ == 0)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (padinfo_.side_ == padding_info::right)
|
|
||||||
{
|
{
|
||||||
pad_it(nchars_);
|
pad_it(nchars_);
|
||||||
}
|
}
|
||||||
else // padinfo_.side_ == padding_info::center
|
|
||||||
{
|
|
||||||
|
|
||||||
pad_it( (nchars_/ 2) + (nchars_% 2) ) ;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void pad_it(size_t count)
|
void pad_it(size_t count)
|
||||||
{
|
{
|
||||||
//count = std::min(count, spaces_.size());
|
//count = std::min(count, spaces_.size());
|
||||||
|
assert(count <= spaces_.size());
|
||||||
fmt_helper::append_string_view(string_view_t(spaces_.data(), count), dest_);
|
fmt_helper::append_string_view(string_view_t(spaces_.data(), count), dest_);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -112,7 +100,7 @@ private:
|
|||||||
fmt::memory_buffer &dest_;
|
fmt::memory_buffer &dest_;
|
||||||
size_t nchars_;
|
size_t nchars_;
|
||||||
string_view_t spaces_ = " "
|
string_view_t spaces_ = " "
|
||||||
" ";
|
" ";
|
||||||
};
|
};
|
||||||
|
|
||||||
class flag_formatter
|
class flag_formatter
|
||||||
@ -1083,7 +1071,7 @@ private:
|
|||||||
{
|
{
|
||||||
using details::padding_info;
|
using details::padding_info;
|
||||||
using details::scoped_pad;
|
using details::scoped_pad;
|
||||||
|
const size_t max_width = 128;
|
||||||
if (it == end)
|
if (it == end)
|
||||||
{
|
{
|
||||||
return padding_info();
|
return padding_info();
|
||||||
@ -1116,7 +1104,7 @@ private:
|
|||||||
auto digit = static_cast<size_t>(*it - '0');
|
auto digit = static_cast<size_t>(*it - '0');
|
||||||
width = width * 10 + digit;
|
width = width * 10 + digit;
|
||||||
}
|
}
|
||||||
return details::padding_info{std::min(width, scoped_pad::max_width), side};
|
return details::padding_info{std::min(width, max_width), side};
|
||||||
}
|
}
|
||||||
|
|
||||||
void compile_pattern_(const std::string &pattern)
|
void compile_pattern_(const std::string &pattern)
|
||||||
|
Loading…
Reference in New Issue
Block a user