fix: -Wunsafe-buffer-usage warnings in GetNextZoomLevel() (#44163)
fixup e8948397
really fix the warning this time
Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com>
Co-authored-by: Charles Kerr <charles@charleskerr.com>
This commit is contained in:
parent
af5901bc6a
commit
5244fcecd3
1 changed files with 9 additions and 9 deletions
|
@ -120,20 +120,20 @@ void SetZoomLevelForWebContents(content::WebContents* web_contents,
|
|||
content::HostZoomMap::SetZoomLevel(web_contents, level);
|
||||
}
|
||||
|
||||
double GetNextZoomLevel(const double level, const bool out) {
|
||||
double GetNextZoomLevel(double level, bool out) {
|
||||
static constexpr std::array<double, 16U> kPresetFactors{
|
||||
0.25, 0.333, 0.5, 0.666, 0.75, 0.9, 1.0, 1.1,
|
||||
1.25, 1.5, 1.75, 2.0, 2.5, 3.0, 4.0, 5.0};
|
||||
static constexpr auto kBegin = kPresetFactors.begin();
|
||||
static constexpr auto kEnd = kPresetFactors.end();
|
||||
static constexpr size_t size = std::size(kPresetFactors);
|
||||
|
||||
const double factor = blink::ZoomLevelToZoomFactor(level);
|
||||
auto matches = [=](auto val) { return blink::ZoomValuesEqual(factor, val); };
|
||||
if (auto iter = std::find_if(kBegin, kEnd, matches); iter != kEnd) {
|
||||
if (out && iter != kBegin)
|
||||
return blink::ZoomFactorToZoomLevel(*--iter);
|
||||
if (!out && ++iter != kEnd)
|
||||
return blink::ZoomFactorToZoomLevel(*iter);
|
||||
for (size_t i = 0U; i < size; ++i) {
|
||||
if (!blink::ZoomValuesEqual(kPresetFactors[i], factor))
|
||||
continue;
|
||||
if (out && i > 0U)
|
||||
return blink::ZoomFactorToZoomLevel(kPresetFactors[i - 1U]);
|
||||
if (!out && i + 1U < size)
|
||||
return blink::ZoomFactorToZoomLevel(kPresetFactors[i + 1U]);
|
||||
}
|
||||
return level;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue