]>
git.saurik.com Git - apple/javascriptcore.git/blob - bytecompiler/LabelScope.h
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 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 bool operator!() const { return !m_owner
; }
122 LabelScope
& operator*() { ASSERT(m_owner
); return m_owner
->at(m_index
); }
123 LabelScope
* operator->() { ASSERT(m_owner
); return &m_owner
->at(m_index
); }
124 const LabelScope
& operator*() const { ASSERT(m_owner
); return m_owner
->at(m_index
); }
125 const LabelScope
* operator->() const { ASSERT(m_owner
); return &m_owner
->at(m_index
); }
127 static LabelScopePtr
null() { return LabelScopePtr(); }
130 LabelScopeStore
* m_owner
;
136 #endif // LabelScope_h