Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(145)

Side by Side Diff: src/objects-debug.cc

Issue 8135003: Fix verification of weak maps during initialization. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Created 9 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « src/objects.cc ('k') | src/objects-inl.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2011 the V8 project authors. All rights reserved. 1 // Copyright 2011 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
(...skipping 480 matching lines...) Expand 10 before | Expand all | Expand 10 after
491 ASSERT(elements()->IsUndefined() || 491 ASSERT(elements()->IsUndefined() ||
492 elements()->IsFixedArray() || 492 elements()->IsFixedArray() ||
493 elements()->IsFixedDoubleArray()); 493 elements()->IsFixedDoubleArray());
494 } 494 }
495 495
496 496
497 void JSWeakMap::JSWeakMapVerify() { 497 void JSWeakMap::JSWeakMapVerify() {
498 CHECK(IsJSWeakMap()); 498 CHECK(IsJSWeakMap());
499 JSObjectVerify(); 499 JSObjectVerify();
500 VerifyHeapPointer(table()); 500 VerifyHeapPointer(table());
501 ASSERT(table()->IsHashTable()); 501 ASSERT(table()->IsHashTable() || table()->IsUndefined());
502 } 502 }
503 503
504 504
505 void JSRegExp::JSRegExpVerify() { 505 void JSRegExp::JSRegExpVerify() {
506 JSObjectVerify(); 506 JSObjectVerify();
507 ASSERT(data()->IsUndefined() || data()->IsFixedArray()); 507 ASSERT(data()->IsUndefined() || data()->IsFixedArray());
508 switch (TypeTag()) { 508 switch (TypeTag()) {
509 case JSRegExp::ATOM: { 509 case JSRegExp::ATOM: {
510 FixedArray* arr = FixedArray::cast(data()); 510 FixedArray* arr = FixedArray::cast(data());
511 ASSERT(arr->get(JSRegExp::kAtomPatternIndex)->IsString()); 511 ASSERT(arr->get(JSRegExp::kAtomPatternIndex)->IsString());
(...skipping 307 matching lines...) Expand 10 before | Expand all | Expand 10 after
819 ASSERT(e->IsUndefined()); 819 ASSERT(e->IsUndefined());
820 } 820 }
821 } 821 }
822 } 822 }
823 } 823 }
824 824
825 825
826 #endif // DEBUG 826 #endif // DEBUG
827 827
828 } } // namespace v8::internal 828 } } // namespace v8::internal
OLDNEW
« no previous file with comments | « src/objects.cc ('k') | src/objects-inl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698