blob: fade5c9fcab2fe4a56ab65d128d61cb5c7f59ecb [file] [log] [blame]
Steve Block6ded16b2010-05-10 14:33:55 +01001// Copyright 2010 the V8 project authors. All rights reserved.
Ben Murdochb8a8cc12014-11-26 15:28:44 +00002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
Steve Block6ded16b2010-05-10 14:33:55 +01004
5#ifndef V8_CACHED_POWERS_H_
6#define V8_CACHED_POWERS_H_
7
Ben Murdochb8a8cc12014-11-26 15:28:44 +00008#include "src/base/logging.h"
9#include "src/diy-fp.h"
Steve Block6ded16b2010-05-10 14:33:55 +010010
11namespace v8 {
12namespace internal {
13
John Reck59135872010-11-02 12:39:01 -070014class PowersOfTenCache {
15 public:
John Reck59135872010-11-02 12:39:01 -070016 // Not all powers of ten are cached. The decimal exponent of two neighboring
17 // cached numbers will differ by kDecimalExponentDistance.
18 static const int kDecimalExponentDistance;
19
20 static const int kMinDecimalExponent;
21 static const int kMaxDecimalExponent;
22
23 // Returns a cached power-of-ten with a binary exponent in the range
24 // [min_exponent; max_exponent] (boundaries included).
25 static void GetCachedPowerForBinaryExponentRange(int min_exponent,
26 int max_exponent,
27 DiyFp* power,
28 int* decimal_exponent);
29
30 // Returns a cached power of ten x ~= 10^k such that
31 // k <= decimal_exponent < k + kCachedPowersDecimalDistance.
32 // The given decimal_exponent must satisfy
33 // kMinDecimalExponent <= requested_exponent, and
34 // requested_exponent < kMaxDecimalExponent + kDecimalExponentDistance.
35 static void GetCachedPowerForDecimalExponent(int requested_exponent,
36 DiyFp* power,
37 int* found_exponent);
38};
Steve Block6ded16b2010-05-10 14:33:55 +010039
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000040} // namespace internal
41} // namespace v8
Steve Block6ded16b2010-05-10 14:33:55 +010042
43#endif // V8_CACHED_POWERS_H_