2010-03-11 14:49:35 +00:00
|
|
|
// Copyright 2010 the V8 project authors. All rights reserved.
|
2014-04-29 06:42:26 +00:00
|
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
|
|
// found in the LICENSE file.
|
2010-03-11 14:49:35 +00:00
|
|
|
|
|
|
|
#ifndef V8_CACHED_POWERS_H_
|
|
|
|
#define V8_CACHED_POWERS_H_
|
|
|
|
|
2014-06-30 13:25:46 +00:00
|
|
|
#include "src/base/logging.h"
|
2014-06-03 08:12:43 +00:00
|
|
|
#include "src/diy-fp.h"
|
2010-03-11 14:49:35 +00:00
|
|
|
|
|
|
|
namespace v8 {
|
|
|
|
namespace internal {
|
|
|
|
|
2010-10-21 11:54:32 +00:00
|
|
|
class PowersOfTenCache {
|
|
|
|
public:
|
|
|
|
// Not all powers of ten are cached. The decimal exponent of two neighboring
|
|
|
|
// cached numbers will differ by kDecimalExponentDistance.
|
|
|
|
static const int kDecimalExponentDistance;
|
|
|
|
|
|
|
|
static const int kMinDecimalExponent;
|
|
|
|
static const int kMaxDecimalExponent;
|
|
|
|
|
|
|
|
// Returns a cached power-of-ten with a binary exponent in the range
|
|
|
|
// [min_exponent; max_exponent] (boundaries included).
|
|
|
|
static void GetCachedPowerForBinaryExponentRange(int min_exponent,
|
|
|
|
int max_exponent,
|
|
|
|
DiyFp* power,
|
|
|
|
int* decimal_exponent);
|
|
|
|
|
|
|
|
// Returns a cached power of ten x ~= 10^k such that
|
|
|
|
// k <= decimal_exponent < k + kCachedPowersDecimalDistance.
|
|
|
|
// The given decimal_exponent must satisfy
|
|
|
|
// kMinDecimalExponent <= requested_exponent, and
|
|
|
|
// requested_exponent < kMaxDecimalExponent + kDecimalExponentDistance.
|
|
|
|
static void GetCachedPowerForDecimalExponent(int requested_exponent,
|
|
|
|
DiyFp* power,
|
|
|
|
int* found_exponent);
|
|
|
|
};
|
2010-03-11 14:49:35 +00:00
|
|
|
|
2015-09-30 13:46:56 +00:00
|
|
|
} // namespace internal
|
|
|
|
} // namespace v8
|
2010-03-11 14:49:35 +00:00
|
|
|
|
|
|
|
#endif // V8_CACHED_POWERS_H_
|