OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
11 // with the distribution. | 11 // with the distribution. |
12 // * Neither the name of Google Inc. nor the names of its | 12 // * Neither the name of Google Inc. nor the names of its |
13 // contributors may be used to endorse or promote products derived | 13 // contributors may be used to endorse or promote products derived |
14 // from this software without specific prior written permission. | 14 // from this software without specific prior written permission. |
15 // | 15 // |
16 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 16 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
17 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 17 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
18 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 18 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
19 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 19 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
20 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 20 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
21 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 21 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
22 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 22 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
23 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 23 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
24 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 24 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 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. | 26 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
27 | 27 |
28 #ifndef V8_HEAP_SNAPSHOT_GENERATOR_INL_H_ | 28 // Flags: --harmony-numeric-literals |
29 #define V8_HEAP_SNAPSHOT_GENERATOR_INL_H_ | |
30 | 29 |
31 #include "heap-snapshot-generator.h" | 30 function TestOctalLiteral() { |
32 | 31 assertEquals(0, 0o0); |
33 namespace v8 { | 32 assertEquals(0, 0O0); |
34 namespace internal { | 33 assertEquals(1, 0o1); |
| 34 assertEquals(7, 0o7); |
| 35 assertEquals(8, 0o10); |
| 36 assertEquals(63, 0o77); |
| 37 } |
| 38 TestOctalLiteral(); |
35 | 39 |
36 | 40 |
37 HeapEntry* HeapGraphEdge::from() const { | 41 function TestOctalLiteralUsingNumberFunction() { |
38 return &snapshot()->entries()[from_index_]; | 42 assertEquals(0, Number('0o0')); |
| 43 assertEquals(0, Number('0O0')); |
| 44 assertEquals(1, Number('0o1')); |
| 45 assertEquals(7, Number('0o7')); |
| 46 assertEquals(8, Number('0o10')); |
| 47 assertEquals(63, Number('0o77')); |
39 } | 48 } |
| 49 TestOctalLiteralUsingNumberFunction(); |
40 | 50 |
41 | 51 |
42 HeapSnapshot* HeapGraphEdge::snapshot() const { | 52 function TestBinaryLiteral() { |
43 return to_entry_->snapshot(); | 53 assertEquals(0, 0b0); |
| 54 assertEquals(0, 0B0); |
| 55 assertEquals(1, 0b1); |
| 56 assertEquals(2, 0b10); |
| 57 assertEquals(3, 0b11); |
44 } | 58 } |
| 59 TestBinaryLiteral(); |
45 | 60 |
46 | 61 |
47 int HeapEntry::index() const { | 62 function TestBinaryLiteralUsingNumberFunction() { |
48 return static_cast<int>(this - &snapshot_->entries().first()); | 63 assertEquals(0, Number('0b0')); |
| 64 assertEquals(0, Number('0B0')); |
| 65 assertEquals(1, Number('0b1')); |
| 66 assertEquals(2, Number('0b10')); |
| 67 assertEquals(3, Number('0b11')); |
49 } | 68 } |
| 69 TestBinaryLiteralUsingNumberFunction(); |
50 | 70 |
51 | 71 |
52 int HeapEntry::set_children_index(int index) { | 72 // parseInt should (probably) not support 0b and 0o. |
53 children_index_ = index; | 73 // https://bugs.ecmascript.org/show_bug.cgi?id=1585 |
54 int next_index = index + children_count_; | 74 function TestParseIntDoesNotSupportOctalNorBinary() { |
55 children_count_ = 0; | 75 assertEquals(0, parseInt('0o77')); |
56 return next_index; | 76 assertEquals(0, parseInt('0o77', 8)); |
| 77 assertEquals(0, parseInt('0b11')); |
| 78 assertEquals(0, parseInt('0b11', 2)); |
57 } | 79 } |
| 80 TestParseIntDoesNotSupportOctalNorBinary(); |
58 | 81 |
59 | 82 |
60 HeapGraphEdge** HeapEntry::children_arr() { | 83 function TestParseFloatDoesNotSupportOctalNorBinary() { |
61 ASSERT(children_index_ >= 0); | 84 assertEquals(0, parseFloat('0o77')); |
62 return &snapshot_->children()[children_index_]; | 85 assertEquals(0, parseFloat('0b11')); |
63 } | 86 } |
64 | 87 TestParseFloatDoesNotSupportOctalNorBinary(); |
65 | |
66 SnapshotObjectId HeapObjectsMap::GetNthGcSubrootId(int delta) { | |
67 return kGcRootsFirstSubrootId + delta * kObjectIdStep; | |
68 } | |
69 | |
70 | |
71 HeapObject* V8HeapExplorer::GetNthGcSubrootObject(int delta) { | |
72 return reinterpret_cast<HeapObject*>( | |
73 reinterpret_cast<char*>(kFirstGcSubrootObject) + | |
74 delta * HeapObjectsMap::kObjectIdStep); | |
75 } | |
76 | |
77 | |
78 int V8HeapExplorer::GetGcSubrootOrder(HeapObject* subroot) { | |
79 return static_cast<int>( | |
80 (reinterpret_cast<char*>(subroot) - | |
81 reinterpret_cast<char*>(kFirstGcSubrootObject)) / | |
82 HeapObjectsMap::kObjectIdStep); | |
83 } | |
84 | |
85 } } // namespace v8::internal | |
86 | |
87 #endif // V8_HEAP_SNAPSHOT_GENERATOR_INL_H_ | |
88 | |
OLD | NEW |