initial import
[vuplus_webkit] / Source / JavaScriptCore / runtime / JSPropertyNameIterator.h
1 /*
2  * Copyright (C) 2008, 2009 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  *
8  * 1.  Redistributions of source code must retain the above copyright
9  *     notice, this list of conditions and the following disclaimer.
10  * 2.  Redistributions in binary form must reproduce the above copyright
11  *     notice, this list of conditions and the following disclaimer in the
12  *     documentation and/or other materials provided with the distribution.
13  * 3.  Neither the name of Apple Computer, Inc. ("Apple") nor the names of
14  *     its contributors may be used to endorse or promote products derived
15  *     from this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY
18  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20  * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY
21  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  */
28
29 #ifndef JSPropertyNameIterator_h
30 #define JSPropertyNameIterator_h
31
32 #include "JSObject.h"
33 #include "JSString.h"
34 #include "Operations.h"
35 #include "PropertyNameArray.h"
36
37 namespace JSC {
38
39     class Identifier;
40     class JSObject;
41
42     class JSPropertyNameIterator : public JSCell {
43         friend class JIT;
44
45     public:
46         typedef JSCell Base;
47
48         static JSPropertyNameIterator* create(ExecState*, JSObject*);
49         static JSPropertyNameIterator* create(ExecState* exec, PropertyNameArrayData* propertyNameArrayData, size_t numCacheableSlot)
50         {
51             JSPropertyNameIterator* iterator = new (allocateCell<JSPropertyNameIterator>(*exec->heap())) JSPropertyNameIterator(exec, propertyNameArrayData, numCacheableSlot);
52             iterator->finishCreation(exec, propertyNameArrayData);
53             return iterator;
54         }
55         
56         static Structure* createStructure(JSGlobalData& globalData, JSGlobalObject* globalObject, JSValue prototype)
57         {
58             return Structure::create(globalData, globalObject, prototype, TypeInfo(CompoundType, OverridesVisitChildren), &s_info);
59         }
60
61         virtual void visitChildren(SlotVisitor&);
62
63         bool getOffset(size_t i, int& offset)
64         {
65             if (i >= m_numCacheableSlots)
66                 return false;
67             offset = i;
68             return true;
69         }
70
71         JSValue get(ExecState*, JSObject*, size_t i);
72         size_t size() { return m_jsStringsSize; }
73
74         void setCachedStructure(JSGlobalData& globalData, Structure* structure)
75         {
76             ASSERT(!m_cachedStructure);
77             ASSERT(structure);
78             m_cachedStructure.set(globalData, this, structure);
79         }
80         Structure* cachedStructure() { return m_cachedStructure.get(); }
81
82         void setCachedPrototypeChain(JSGlobalData& globalData, StructureChain* cachedPrototypeChain) { m_cachedPrototypeChain.set(globalData, this, cachedPrototypeChain); }
83         StructureChain* cachedPrototypeChain() { return m_cachedPrototypeChain.get(); }
84         
85         static const ClassInfo s_info;
86
87     protected:
88         void finishCreation(ExecState* exec, PropertyNameArrayData* propertyNameArrayData)
89         {
90             Base::finishCreation(exec->globalData());
91             PropertyNameArrayData::PropertyNameVector& propertyNameVector = propertyNameArrayData->propertyNameVector();
92             for (size_t i = 0; i < m_jsStringsSize; ++i)
93                 m_jsStrings[i].set(exec->globalData(), this, jsOwnedString(exec, propertyNameVector[i].ustring()));
94         }
95
96     private:
97         JSPropertyNameIterator(ExecState*, PropertyNameArrayData* propertyNameArrayData, size_t numCacheableSlot);
98
99         WriteBarrier<Structure> m_cachedStructure;
100         WriteBarrier<StructureChain> m_cachedPrototypeChain;
101         uint32_t m_numCacheableSlots;
102         uint32_t m_jsStringsSize;
103         OwnArrayPtr<WriteBarrier<Unknown> > m_jsStrings;
104     };
105
106     inline void Structure::setEnumerationCache(JSGlobalData& globalData, JSPropertyNameIterator* enumerationCache)
107     {
108         ASSERT(!isDictionary());
109         m_enumerationCache.set(globalData, this, enumerationCache);
110     }
111
112     inline JSPropertyNameIterator* Structure::enumerationCache()
113     {
114         return m_enumerationCache.get();
115     }
116
117     ALWAYS_INLINE JSPropertyNameIterator* Register::propertyNameIterator() const
118     {
119         return static_cast<JSPropertyNameIterator*>(jsValue().asCell());
120     }
121
122 } // namespace JSC
123
124 #endif // JSPropertyNameIterator_h