2 * Copyright (C) 2008 Apple Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
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.
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.
32 #include <wtf/PassRefPtr.h>
41 enum Type { Loop, Switch, NamedLabel };
43 LabelScope(Type type, const Identifier* name, int scopeDepth, PassRefPtr<Label> breakTarget, PassRefPtr<Label> continueTarget)
47 , m_scopeDepth(scopeDepth)
48 , m_breakTarget(breakTarget)
49 , m_continueTarget(continueTarget)
52 int refCount() const { return m_refCount; }
54 Label* breakTarget() const { return m_breakTarget.get(); }
55 Label* continueTarget() const { return m_continueTarget.get(); }
57 Type type() const { return m_type; }
58 const Identifier* name() const { return m_name; }
59 int scopeDepth() const { return m_scopeDepth; }
62 friend class LabelScopePtr;
64 void ref() { ++m_refCount; }
68 ASSERT(m_refCount >= 0);
73 const Identifier* m_name;
75 RefPtr<Label> m_breakTarget;
76 RefPtr<Label> m_continueTarget;
79 typedef Vector<LabelScope, 8> LabelScopeStore;
88 LabelScopePtr(LabelScopeStore* owner, size_t index)
92 m_owner->at(index).ref();
95 LabelScopePtr(const LabelScopePtr& other)
96 : m_owner(other.m_owner)
97 , m_index(other.m_index)
100 m_owner->at(m_index).ref();
103 const LabelScopePtr& operator=(const LabelScopePtr& other)
106 other.m_owner->at(other.m_index).ref();
108 m_owner->at(m_index).deref();
109 m_owner = other.m_owner;
110 m_index = other.m_index;
117 m_owner->at(m_index).deref();
120 LabelScope& operator*() { ASSERT(m_owner); return m_owner->at(m_index); }
121 LabelScope* operator->() { ASSERT(m_owner); return &m_owner->at(m_index); }
122 const LabelScope& operator*() const { ASSERT(m_owner); return m_owner->at(m_index); }
123 const LabelScope* operator->() const { ASSERT(m_owner); return &m_owner->at(m_index); }
126 LabelScopeStore* m_owner;
132 #endif // LabelScope_h