From 5f1ab04193ad0130ca8204aadaceae083aca9881 Mon Sep 17 00:00:00 2001 From: Feng Qian Date: Wed, 17 Jun 2009 12:12:20 -0700 Subject: Get WebKit r44544. --- JavaScriptCore/runtime/StructureChain.cpp | 38 ++++++------------------------- 1 file changed, 7 insertions(+), 31 deletions(-) (limited to 'JavaScriptCore/runtime/StructureChain.cpp') diff --git a/JavaScriptCore/runtime/StructureChain.cpp b/JavaScriptCore/runtime/StructureChain.cpp index 4d00263..085876c 100644 --- a/JavaScriptCore/runtime/StructureChain.cpp +++ b/JavaScriptCore/runtime/StructureChain.cpp @@ -32,42 +32,18 @@ namespace JSC { -StructureChain::StructureChain(Structure* structure) +StructureChain::StructureChain(Structure* head) { - size_t size = 1; - - Structure* tmp = structure; - while (!tmp->storedPrototype().isNull()) { + size_t size = 0; + for (Structure* current = head; current; current = current->storedPrototype().isNull() ? 0 : asObject(current->storedPrototype())->structure()) ++size; - tmp = asCell(tmp->storedPrototype())->structure(); - } m_vector.set(new RefPtr[size + 1]); - size_t i; - for (i = 0; i < size - 1; ++i) { - m_vector[i] = structure; - structure = asObject(structure->storedPrototype())->structure(); - } - m_vector[i] = structure; - m_vector[i + 1] = 0; -} - -bool structureChainsAreEqual(StructureChain* chainA, StructureChain* chainB) -{ - if (!chainA || !chainB) - return false; - - RefPtr* a = chainA->head(); - RefPtr* b = chainB->head(); - while (1) { - if (*a != *b) - return false; - if (!*a) - return true; - a++; - b++; - } + size_t i = 0; + for (Structure* current = head; current; current = current->storedPrototype().isNull() ? 0 : asObject(current->storedPrototype())->structure()) + m_vector[i++] = current; + m_vector[i] = 0; } } // namespace JSC -- cgit v1.1