forked from swiftlang/swift
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Scope.h
111 lines (94 loc) · 3.22 KB
/
Scope.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
//===--- Scope.h - Declarations for scope RAII objects ----------*- C++ -*-===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2016 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See http://swift.org/LICENSE.txt for license information
// See http://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
//
// This file defines the Scope and FullExpr RAII objects.
//
//===----------------------------------------------------------------------===//
#ifndef SCOPE_H
#define SCOPE_H
#include "SILGenFunction.h"
#include "swift/SIL/SILDebugScope.h"
#include "Cleanup.h"
namespace swift {
namespace Lowering {
/// A Scope is a RAII object recording that a scope (e.g. a brace
/// statement) has been entered.
class LLVM_LIBRARY_VISIBILITY Scope {
CleanupManager &Cleanups;
CleanupsDepth Depth;
CleanupsDepth SavedInnermostScope;
CleanupLocation Loc;
void popImpl() {
Cleanups.Stack.checkIterator(Depth);
Cleanups.Stack.checkIterator(Cleanups.InnermostScope);
assert(Cleanups.InnermostScope == Depth && "popping scopes out of order");
Cleanups.InnermostScope = SavedInnermostScope;
Cleanups.endScope(Depth, Loc);
Cleanups.Stack.checkIterator(Cleanups.InnermostScope);
Cleanups.popTopDeadCleanups(Cleanups.InnermostScope);
}
public:
explicit Scope(CleanupManager &Cleanups, CleanupLocation L)
: Cleanups(Cleanups), Depth(Cleanups.getCleanupsDepth()),
SavedInnermostScope(Cleanups.InnermostScope),
Loc(L) {
assert(Depth.isValid());
Cleanups.Stack.checkIterator(Cleanups.InnermostScope);
Cleanups.InnermostScope = Depth;
}
void pop() {
assert(Depth.isValid() && "popping a scope twice!");
popImpl();
Depth = CleanupsDepth::invalid();
}
~Scope() {
if (Depth.isValid()) popImpl();
}
};
/// A FullExpr is a RAII object recording that a full-expression has
/// been entered. A full-expression is essentially a very small scope
/// for the temporaries in an expression, with the added complexity
/// that (eventually, very likely) we have to deal with expressions
/// that are only conditionally evaluated.
class LLVM_LIBRARY_VISIBILITY FullExpr : private Scope {
public:
explicit FullExpr(CleanupManager &Cleanups, CleanupLocation Loc)
: Scope(Cleanups, Loc) {}
using Scope::pop;
};
/// A LexicalScope is a Scope that is also exposed to the debug info.
class LLVM_LIBRARY_VISIBILITY LexicalScope : private Scope {
SILGenFunction& SGF;
public:
explicit LexicalScope(CleanupManager &Cleanups,
SILGenFunction& SGF,
CleanupLocation Loc)
: Scope(Cleanups, Loc), SGF(SGF) {
SGF.enterDebugScope(Loc);
}
using Scope::pop;
~LexicalScope() {
SGF.leaveDebugScope();
}
};
/// A scope that only exists in the debug info.
class LLVM_LIBRARY_VISIBILITY DebugScope {
SILGenFunction &SGF;
public:
explicit DebugScope(SILGenFunction &SGF, CleanupLocation Loc) : SGF(SGF) {
SGF.enterDebugScope(Loc);
}
~DebugScope() { SGF.leaveDebugScope(); }
};
} // end namespace Lowering
} // end namespace swift
#endif