Skip to content

Commit

Permalink
Bug 1288603 - Remove NumericLimits.h because all platforms have numer…
Browse files Browse the repository at this point in the history
…ic_limits<char16_t>. r=froydnj
  • Loading branch information
cpeterso committed Jul 23, 2016
1 parent be03967 commit e7c597b
Show file tree
Hide file tree
Showing 5 changed files with 52 additions and 91 deletions.
51 changes: 25 additions & 26 deletions js/src/ctypes/CTypes.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,9 @@

#include "mozilla/FloatingPoint.h"
#include "mozilla/MemoryReporting.h"
#include "mozilla/NumericLimits.h"
#include "mozilla/Vector.h"

#include <limits>
#include <math.h>
#include <stdint.h>

Expand Down Expand Up @@ -48,7 +48,6 @@
#include "jsobjinlines.h"

using namespace std;
using mozilla::NumericLimits;

using JS::AutoCheckCannotGC;

Expand Down Expand Up @@ -2498,7 +2497,7 @@ JS_STATIC_ASSERT(sizeof(long long) == 8);
JS_STATIC_ASSERT(sizeof(size_t) == sizeof(uintptr_t));
JS_STATIC_ASSERT(sizeof(float) == 4);
JS_STATIC_ASSERT(sizeof(PRFuncPtr) == sizeof(void*));
JS_STATIC_ASSERT(NumericLimits<double>::is_signed);
JS_STATIC_ASSERT(numeric_limits<double>::is_signed);

// Templated helper to convert FromType to TargetType, for the default case
// where the trivial POD constructor will do.
Expand Down Expand Up @@ -2563,15 +2562,15 @@ static MOZ_ALWAYS_INLINE bool IsAlwaysExact()
// 2) If FromType is signed, TargetType must also be signed. (Floating point
// types are always signed.)
// 3) If TargetType is an exact integral type, FromType must be also.
if (NumericLimits<TargetType>::digits < NumericLimits<FromType>::digits)
if (numeric_limits<TargetType>::digits < numeric_limits<FromType>::digits)
return false;

if (NumericLimits<FromType>::is_signed &&
!NumericLimits<TargetType>::is_signed)
if (numeric_limits<FromType>::is_signed &&
!numeric_limits<TargetType>::is_signed)
return false;

if (!NumericLimits<FromType>::is_exact &&
NumericLimits<TargetType>::is_exact)
if (!numeric_limits<FromType>::is_exact &&
numeric_limits<TargetType>::is_exact)
return false;

return true;
Expand All @@ -2582,7 +2581,7 @@ static MOZ_ALWAYS_INLINE bool IsAlwaysExact()
template<class TargetType, class FromType, bool TargetSigned, bool FromSigned>
struct IsExactImpl {
static MOZ_ALWAYS_INLINE bool Test(FromType i, TargetType j) {
JS_STATIC_ASSERT(NumericLimits<TargetType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<TargetType>::is_exact);
return FromType(j) == i;
}
};
Expand All @@ -2591,7 +2590,7 @@ struct IsExactImpl {
template<class TargetType, class FromType>
struct IsExactImpl<TargetType, FromType, false, true> {
static MOZ_ALWAYS_INLINE bool Test(FromType i, TargetType j) {
JS_STATIC_ASSERT(NumericLimits<TargetType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<TargetType>::is_exact);
return i >= 0 && FromType(j) == i;
}
};
Expand All @@ -2600,7 +2599,7 @@ struct IsExactImpl<TargetType, FromType, false, true> {
template<class TargetType, class FromType>
struct IsExactImpl<TargetType, FromType, true, false> {
static MOZ_ALWAYS_INLINE bool Test(FromType i, TargetType j) {
JS_STATIC_ASSERT(NumericLimits<TargetType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<TargetType>::is_exact);
return TargetType(i) >= 0 && FromType(j) == i;
}
};
Expand All @@ -2611,7 +2610,7 @@ template<class TargetType, class FromType>
static MOZ_ALWAYS_INLINE bool ConvertExact(FromType i, TargetType* result)
{
// Require that TargetType is integral, to simplify conversion.
JS_STATIC_ASSERT(NumericLimits<TargetType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<TargetType>::is_exact);

*result = Convert<TargetType>(i);

Expand All @@ -2622,8 +2621,8 @@ static MOZ_ALWAYS_INLINE bool ConvertExact(FromType i, TargetType* result)
// Return 'true' if 'i' is exactly representable in 'TargetType'.
return IsExactImpl<TargetType,
FromType,
NumericLimits<TargetType>::is_signed,
NumericLimits<FromType>::is_signed>::Test(i, *result);
numeric_limits<TargetType>::is_signed,
numeric_limits<FromType>::is_signed>::Test(i, *result);
}

// Templated helper to determine if Type 'i' is negative. Default case
Expand All @@ -2647,7 +2646,7 @@ struct IsNegativeImpl<Type, true> {
template<class Type>
static MOZ_ALWAYS_INLINE bool IsNegative(Type i)
{
return IsNegativeImpl<Type, NumericLimits<Type>::is_signed>::Test(i);
return IsNegativeImpl<Type, numeric_limits<Type>::is_signed>::Test(i);
}

// Implicitly convert val to bool, allowing bool, int, and double
Expand Down Expand Up @@ -2681,7 +2680,7 @@ template<class IntegerType>
static bool
jsvalToInteger(JSContext* cx, Value val, IntegerType* result)
{
JS_STATIC_ASSERT(NumericLimits<IntegerType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<IntegerType>::is_exact);

if (val.isInt32()) {
// Make sure the integer fits in the alotted precision, and has the right
Expand Down Expand Up @@ -2771,7 +2770,7 @@ template<class FloatType>
static bool
jsvalToFloat(JSContext* cx, Value val, FloatType* result)
{
JS_STATIC_ASSERT(!NumericLimits<FloatType>::is_exact);
JS_STATIC_ASSERT(!numeric_limits<FloatType>::is_exact);

// The following casts may silently throw away some bits, but there's
// no good way around it. Sternly requiring that the 64-bit double
Expand Down Expand Up @@ -2829,15 +2828,15 @@ static bool
StringToInteger(JSContext* cx, CharT* cp, size_t length, IntegerType* result,
bool* overflow)
{
JS_STATIC_ASSERT(NumericLimits<IntegerType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<IntegerType>::is_exact);

const CharT* end = cp + length;
if (cp == end)
return false;

IntegerType sign = 1;
if (cp[0] == '-') {
if (!NumericLimits<IntegerType>::is_signed)
if (!numeric_limits<IntegerType>::is_signed)
return false;

sign = -1;
Expand Down Expand Up @@ -2906,7 +2905,7 @@ jsvalToBigInteger(JSContext* cx,
IntegerType* result,
bool* overflow)
{
JS_STATIC_ASSERT(NumericLimits<IntegerType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<IntegerType>::is_exact);

if (val.isInt32()) {
// Make sure the integer fits in the alotted precision, and has the right
Expand Down Expand Up @@ -2978,7 +2977,7 @@ jsidToBigInteger(JSContext* cx,
bool allowString,
IntegerType* result)
{
JS_STATIC_ASSERT(NumericLimits<IntegerType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<IntegerType>::is_exact);

if (JSID_IS_INT(val)) {
// Make sure the integer fits in the alotted precision, and has the right
Expand Down Expand Up @@ -3027,7 +3026,7 @@ template<class IntegerType>
static bool
jsvalToIntegerExplicit(Value val, IntegerType* result)
{
JS_STATIC_ASSERT(NumericLimits<IntegerType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<IntegerType>::is_exact);

if (val.isDouble()) {
// Convert -Inf, Inf, and NaN to 0; otherwise, convert by C-style cast.
Expand Down Expand Up @@ -3108,7 +3107,7 @@ template<class IntegerType, class CharType, size_t N, class AP>
void
IntegerToString(IntegerType i, int radix, mozilla::Vector<CharType, N, AP>& result)
{
JS_STATIC_ASSERT(NumericLimits<IntegerType>::is_exact);
JS_STATIC_ASSERT(numeric_limits<IntegerType>::is_exact);

// The buffer must be big enough for all the bits of IntegerType to fit,
// in base-2, including '-'.
Expand Down Expand Up @@ -3195,7 +3194,7 @@ ConvertToJS(JSContext* cx,
/* Return an Int64 or UInt64 object - do not convert to a JS number. */ \
uint64_t value; \
RootedObject proto(cx); \
if (!NumericLimits<type>::is_signed) { \
if (!numeric_limits<type>::is_signed) { \
value = *static_cast<type*>(data); \
/* Get ctypes.UInt64.prototype from ctypes.CType.prototype. */ \
proto = CType::GetProtoFromType(cx, typeObj, SLOT_UINT64PROTO); \
Expand All @@ -3210,7 +3209,7 @@ ConvertToJS(JSContext* cx,
} \
\
JSObject* obj = Int64Base::Construct(cx, proto, value, \
!NumericLimits<type>::is_signed); \
!numeric_limits<type>::is_signed); \
if (!obj) \
return false; \
result.setObject(*obj); \
Expand Down Expand Up @@ -4172,7 +4171,7 @@ BuildDataSource(JSContext* cx,
#define WRAPPED_INT_CASE(name, type, ffiType) \
case TYPE_##name: \
/* Serialize as a wrapped decimal integer. */ \
if (!NumericLimits<type>::is_signed) \
if (!numeric_limits<type>::is_signed) \
AppendString(result, "ctypes.UInt64(\""); \
else \
AppendString(result, "ctypes.Int64(\""); \
Expand Down
38 changes: 0 additions & 38 deletions mfbt/NumericLimits.h

This file was deleted.

11 changes: 6 additions & 5 deletions mfbt/Saturate.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,10 @@

#include "mozilla/Attributes.h"
#include "mozilla/Move.h"
#include "mozilla/NumericLimits.h"
#include "mozilla/TypeTraits.h"

#include <limits>

namespace mozilla {
namespace detail {

Expand Down Expand Up @@ -63,8 +64,8 @@ class SaturateOp

const T& operator+=(const T& aRhs) const
{
const T min = NumericLimits<T>::min();
const T max = NumericLimits<T>::max();
const T min = std::numeric_limits<T>::min();
const T max = std::numeric_limits<T>::max();

if (aRhs > static_cast<T>(0)) {
mValue = (max - aRhs) < mValue ? max : mValue + aRhs;
Expand All @@ -76,8 +77,8 @@ class SaturateOp

const T& operator-=(const T& aRhs) const
{
const T min = NumericLimits<T>::min();
const T max = NumericLimits<T>::max();
const T min = std::numeric_limits<T>::min();
const T max = std::numeric_limits<T>::max();

if (aRhs > static_cast<T>(0)) {
mValue = (min + aRhs) > mValue ? min : mValue - aRhs;
Expand Down
1 change: 0 additions & 1 deletion mfbt/moz.build
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,6 @@ EXPORTS.mozilla = [
'Move.h',
'NotNull.h',
'NullPtr.h',
'NumericLimits.h',
'Opaque.h',
'Pair.h',
'PodOperations.h',
Expand Down
42 changes: 21 additions & 21 deletions mfbt/tests/TestSaturate.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,10 @@
#include <mozilla/Saturate.h>

#include <mozilla/Assertions.h>
#include <mozilla/NumericLimits.h>

#include <limits>

using mozilla::detail::Saturate;
using mozilla::NumericLimits;

#define A(a) MOZ_RELEASE_ASSERT(a, "Test \'" #a "\' failed.")

Expand Down Expand Up @@ -50,23 +50,23 @@ uint8_t
StartValue<uint8_t>()
{
// Picking a value near middle of uint8_t's range.
return static_cast<uint8_t>(NumericLimits<int8_t>::max());
return static_cast<uint8_t>(std::numeric_limits<int8_t>::max());
}

template<>
uint16_t
StartValue<uint16_t>()
{
// Picking a value near middle of uint16_t's range.
return static_cast<uint8_t>(NumericLimits<int16_t>::max());
return static_cast<uint8_t>(std::numeric_limits<int16_t>::max());
}

template<>
uint32_t
StartValue<uint32_t>()
{
// Picking a value near middle of uint32_t's range.
return static_cast<uint8_t>(NumericLimits<int32_t>::max());
return static_cast<uint8_t>(std::numeric_limits<int32_t>::max());
}

// Add
Expand Down Expand Up @@ -154,28 +154,28 @@ template<typename T>
static void
TestUpperBound()
{
Saturate<T> satValue(NumericLimits<T>::max());
Saturate<T> satValue(std::numeric_limits<T>::max());

A(--satValue == (NumericLimits<T>::max() - 1));
A(++satValue == (NumericLimits<T>::max()));
A(++satValue == (NumericLimits<T>::max())); // don't overflow here
A(++satValue == (NumericLimits<T>::max())); // don't overflow here
A(--satValue == (NumericLimits<T>::max() - 1)); // back at (max - 1)
A(--satValue == (NumericLimits<T>::max() - 2));
A(--satValue == (std::numeric_limits<T>::max() - 1));
A(++satValue == (std::numeric_limits<T>::max()));
A(++satValue == (std::numeric_limits<T>::max())); // don't overflow here
A(++satValue == (std::numeric_limits<T>::max())); // don't overflow here
A(--satValue == (std::numeric_limits<T>::max() - 1)); // back at (max - 1)
A(--satValue == (std::numeric_limits<T>::max() - 2));
}

template<typename T>
static void
TestLowerBound()
{
Saturate<T> satValue(NumericLimits<T>::min());
Saturate<T> satValue(std::numeric_limits<T>::min());

A(++satValue == (NumericLimits<T>::min() + 1));
A(--satValue == (NumericLimits<T>::min()));
A(--satValue == (NumericLimits<T>::min())); // don't overflow here
A(--satValue == (NumericLimits<T>::min())); // don't overflow here
A(++satValue == (NumericLimits<T>::min() + 1)); // back at (max + 1)
A(++satValue == (NumericLimits<T>::min() + 2));
A(++satValue == (std::numeric_limits<T>::min() + 1));
A(--satValue == (std::numeric_limits<T>::min()));
A(--satValue == (std::numeric_limits<T>::min())); // don't overflow here
A(--satValue == (std::numeric_limits<T>::min())); // don't overflow here
A(++satValue == (std::numeric_limits<T>::min() + 1)); // back at (max + 1)
A(++satValue == (std::numeric_limits<T>::min() + 2));
}

// Framework
Expand All @@ -187,8 +187,8 @@ TestAll()
{
// Assert that we don't accidently hit type's range limits in tests.
const T value = StartValue<T>();
A(NumericLimits<T>::min() + static_cast<T>(sNumOps) <= value);
A(NumericLimits<T>::max() - static_cast<T>(sNumOps) >= value);
A(std::numeric_limits<T>::min() + static_cast<T>(sNumOps) <= value);
A(std::numeric_limits<T>::max() - static_cast<T>(sNumOps) >= value);

TestPrefixIncr<T>();
TestPostfixIncr<T>();
Expand Down

0 comments on commit e7c597b

Please sign in to comment.