| Index: src/compiler/common-operator.h
|
| diff --git a/src/compiler/common-operator.h b/src/compiler/common-operator.h
|
| index aa1aac7de82a19abab4da6baad9cbfdebcf62017..2ef178b8386fdb66db6fec0c520c9c447e4a636c 100644
|
| --- a/src/compiler/common-operator.h
|
| +++ b/src/compiler/common-operator.h
|
| @@ -191,37 +191,37 @@ class CommonOperatorBuilder {
|
| template <typename T>
|
| struct CommonOperatorTraits {
|
| static inline bool Equals(T a, T b);
|
| - static inline bool HasValue(Operator* op);
|
| - static inline T ValueOf(Operator* op);
|
| + static inline bool HasValue(const Operator* op);
|
| + static inline T ValueOf(const Operator* op);
|
| };
|
|
|
| template <>
|
| struct CommonOperatorTraits<int32_t> {
|
| static inline bool Equals(int32_t a, int32_t b) { return a == b; }
|
| - static inline bool HasValue(Operator* op) {
|
| + static inline bool HasValue(const Operator* op) {
|
| return op->opcode() == IrOpcode::kInt32Constant ||
|
| op->opcode() == IrOpcode::kNumberConstant;
|
| }
|
| - static inline int32_t ValueOf(Operator* op) {
|
| + static inline int32_t ValueOf(const Operator* op) {
|
| if (op->opcode() == IrOpcode::kNumberConstant) {
|
| // TODO(titzer): cache the converted int32 value in NumberConstant.
|
| - return FastD2I(reinterpret_cast<Operator1<double>*>(op)->parameter());
|
| + return FastD2I(OpParameter<double>(op));
|
| }
|
| CHECK_EQ(IrOpcode::kInt32Constant, op->opcode());
|
| - return static_cast<Operator1<int32_t>*>(op)->parameter();
|
| + return OpParameter<int32_t>(op);
|
| }
|
| };
|
|
|
| template <>
|
| struct CommonOperatorTraits<uint32_t> {
|
| static inline bool Equals(uint32_t a, uint32_t b) { return a == b; }
|
| - static inline bool HasValue(Operator* op) {
|
| + static inline bool HasValue(const Operator* op) {
|
| return CommonOperatorTraits<int32_t>::HasValue(op);
|
| }
|
| - static inline uint32_t ValueOf(Operator* op) {
|
| + static inline uint32_t ValueOf(const Operator* op) {
|
| if (op->opcode() == IrOpcode::kNumberConstant) {
|
| // TODO(titzer): cache the converted uint32 value in NumberConstant.
|
| - return FastD2UI(reinterpret_cast<Operator1<double>*>(op)->parameter());
|
| + return FastD2UI(OpParameter<double>(op));
|
| }
|
| return static_cast<uint32_t>(CommonOperatorTraits<int32_t>::ValueOf(op));
|
| }
|
| @@ -230,27 +230,27 @@ struct CommonOperatorTraits<uint32_t> {
|
| template <>
|
| struct CommonOperatorTraits<int64_t> {
|
| static inline bool Equals(int64_t a, int64_t b) { return a == b; }
|
| - static inline bool HasValue(Operator* op) {
|
| + static inline bool HasValue(const Operator* op) {
|
| return op->opcode() == IrOpcode::kInt32Constant ||
|
| op->opcode() == IrOpcode::kInt64Constant ||
|
| op->opcode() == IrOpcode::kNumberConstant;
|
| }
|
| - static inline int64_t ValueOf(Operator* op) {
|
| + static inline int64_t ValueOf(const Operator* op) {
|
| if (op->opcode() == IrOpcode::kInt32Constant) {
|
| return static_cast<int64_t>(CommonOperatorTraits<int32_t>::ValueOf(op));
|
| }
|
| CHECK_EQ(IrOpcode::kInt64Constant, op->opcode());
|
| - return static_cast<Operator1<int64_t>*>(op)->parameter();
|
| + return OpParameter<int64_t>(op);
|
| }
|
| };
|
|
|
| template <>
|
| struct CommonOperatorTraits<uint64_t> {
|
| static inline bool Equals(uint64_t a, uint64_t b) { return a == b; }
|
| - static inline bool HasValue(Operator* op) {
|
| + static inline bool HasValue(const Operator* op) {
|
| return CommonOperatorTraits<int64_t>::HasValue(op);
|
| }
|
| - static inline uint64_t ValueOf(Operator* op) {
|
| + static inline uint64_t ValueOf(const Operator* op) {
|
| return static_cast<uint64_t>(CommonOperatorTraits<int64_t>::ValueOf(op));
|
| }
|
| };
|
| @@ -260,15 +260,15 @@ struct CommonOperatorTraits<double> {
|
| static inline bool Equals(double a, double b) {
|
| return DoubleRepresentation(a).bits == DoubleRepresentation(b).bits;
|
| }
|
| - static inline bool HasValue(Operator* op) {
|
| + static inline bool HasValue(const Operator* op) {
|
| return op->opcode() == IrOpcode::kFloat64Constant ||
|
| op->opcode() == IrOpcode::kInt32Constant ||
|
| op->opcode() == IrOpcode::kNumberConstant;
|
| }
|
| - static inline double ValueOf(Operator* op) {
|
| + static inline double ValueOf(const Operator* op) {
|
| if (op->opcode() == IrOpcode::kFloat64Constant ||
|
| op->opcode() == IrOpcode::kNumberConstant) {
|
| - return reinterpret_cast<Operator1<double>*>(op)->parameter();
|
| + return OpParameter<double>(op);
|
| }
|
| return static_cast<double>(CommonOperatorTraits<int32_t>::ValueOf(op));
|
| }
|
| @@ -279,43 +279,44 @@ struct CommonOperatorTraits<ExternalReference> {
|
| static inline bool Equals(ExternalReference a, ExternalReference b) {
|
| return a == b;
|
| }
|
| - static inline bool HasValue(Operator* op) {
|
| + static inline bool HasValue(const Operator* op) {
|
| return op->opcode() == IrOpcode::kExternalConstant;
|
| }
|
| - static inline ExternalReference ValueOf(Operator* op) {
|
| + static inline ExternalReference ValueOf(const Operator* op) {
|
| CHECK_EQ(IrOpcode::kExternalConstant, op->opcode());
|
| - return static_cast<Operator1<ExternalReference>*>(op)->parameter();
|
| + return OpParameter<ExternalReference>(op);
|
| }
|
| };
|
|
|
| template <typename T>
|
| struct CommonOperatorTraits<PrintableUnique<T> > {
|
| - static inline bool HasValue(Operator* op) {
|
| + static inline bool HasValue(const Operator* op) {
|
| return op->opcode() == IrOpcode::kHeapConstant;
|
| }
|
| - static inline PrintableUnique<T> ValueOf(Operator* op) {
|
| + static inline PrintableUnique<T> ValueOf(const Operator* op) {
|
| CHECK_EQ(IrOpcode::kHeapConstant, op->opcode());
|
| - return static_cast<Operator1<PrintableUnique<T> >*>(op)->parameter();
|
| + return OpParameter<PrintableUnique<T> >(op);
|
| }
|
| };
|
|
|
| template <typename T>
|
| struct CommonOperatorTraits<Handle<T> > {
|
| - static inline bool HasValue(Operator* op) {
|
| + static inline bool HasValue(const Operator* op) {
|
| return CommonOperatorTraits<PrintableUnique<T> >::HasValue(op);
|
| }
|
| - static inline Handle<T> ValueOf(Operator* op) {
|
| + static inline Handle<T> ValueOf(const Operator* op) {
|
| return CommonOperatorTraits<PrintableUnique<T> >::ValueOf(op).handle();
|
| }
|
| };
|
|
|
|
|
| template <typename T>
|
| -inline T ValueOf(Operator* op) {
|
| +inline T ValueOf(const Operator* op) {
|
| return CommonOperatorTraits<T>::ValueOf(op);
|
| }
|
| -}
|
| -}
|
| -} // namespace v8::internal::compiler
|
| +
|
| +} // namespace compiler
|
| +} // namespace internal
|
| +} // namespace v8
|
|
|
| #endif // V8_COMPILER_COMMON_OPERATOR_H_
|
|
|