Upstream version 7.35.144.0
[platform/framework/web/crosswalk.git] / src / v8 / src / v8conversions.h
1 // Copyright 2011 the V8 project authors. All rights reserved.
2 // Redistribution and use in source and binary forms, with or without
3 // modification, are permitted provided that the following conditions are
4 // met:
5 //
6 //     * Redistributions of source code must retain the above copyright
7 //       notice, this list of conditions and the following disclaimer.
8 //     * Redistributions in binary form must reproduce the above
9 //       copyright notice, this list of conditions and the following
10 //       disclaimer in the documentation and/or other materials provided
11 //       with the distribution.
12 //     * Neither the name of Google Inc. nor the names of its
13 //       contributors may be used to endorse or promote products derived
14 //       from this software without specific prior written permission.
15 //
16 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28 #ifndef V8_V8CONVERSIONS_H_
29 #define V8_V8CONVERSIONS_H_
30
31 #include "conversions.h"
32
33 namespace v8 {
34 namespace internal {
35
36
37 static inline bool IsMinusZero(double value) {
38   static const DoubleRepresentation minus_zero(-0.0);
39   return DoubleRepresentation(value) == minus_zero;
40 }
41
42
43 // Integer32 is an integer that can be represented as a signed 32-bit
44 // integer. It has to be in the range [-2^31, 2^31 - 1].
45 // We also have to check for negative 0 as it is not an Integer32.
46 static inline bool IsInt32Double(double value) {
47   return !IsMinusZero(value) &&
48          value >= kMinInt &&
49          value <= kMaxInt &&
50          value == FastI2D(FastD2I(value));
51 }
52
53
54 // Convert from Number object to C integer.
55 inline int32_t NumberToInt32(Object* number) {
56   if (number->IsSmi()) return Smi::cast(number)->value();
57   return DoubleToInt32(number->Number());
58 }
59
60
61 inline uint32_t NumberToUint32(Object* number) {
62   if (number->IsSmi()) return Smi::cast(number)->value();
63   return DoubleToUint32(number->Number());
64 }
65
66
67 // Converts a string into a double value according to ECMA-262 9.3.1
68 double StringToDouble(UnicodeCache* unicode_cache,
69                       String* str,
70                       int flags,
71                       double empty_string_val = 0);
72
73 // Converts a string into an integer.
74 double StringToInt(UnicodeCache* unicode_cache, String* str, int radix);
75
76 inline bool TryNumberToSize(Isolate* isolate,
77                             Object* number, size_t* result) {
78   SealHandleScope shs(isolate);
79   if (number->IsSmi()) {
80     int value = Smi::cast(number)->value();
81     ASSERT(
82         static_cast<unsigned>(Smi::kMaxValue)
83           <= std::numeric_limits<size_t>::max());
84     if (value >= 0) {
85       *result = static_cast<size_t>(value);
86       return true;
87     }
88     return false;
89   } else {
90     ASSERT(number->IsHeapNumber());
91     double value = HeapNumber::cast(number)->value();
92     if (value >= 0 &&
93         value <= std::numeric_limits<size_t>::max()) {
94       *result = static_cast<size_t>(value);
95       return true;
96     } else {
97       return false;
98     }
99   }
100 }
101
102 // Converts a number into size_t.
103 inline size_t NumberToSize(Isolate* isolate,
104                            Object* number) {
105   size_t result = 0;
106   bool is_valid = TryNumberToSize(isolate, number, &result);
107   CHECK(is_valid);
108   return result;
109 }
110
111 } }  // namespace v8::internal
112
113 #endif  // V8_V8CONVERSIONS_H_