Index: src/parsing/preparsed-scope-data.cc |
diff --git a/src/parsing/preparsed-scope-data.cc b/src/parsing/preparsed-scope-data.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ef69f805104ab3ee471be71aceb9a433fa47b3a1 |
--- /dev/null |
+++ b/src/parsing/preparsed-scope-data.cc |
@@ -0,0 +1,39 @@ |
+// Copyright 2017 the V8 project authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "src/parsing/preparsed-scope-data.h" |
+ |
+namespace v8 { |
+namespace internal { |
+ |
+PreParsedScopeData::ScopeScope::ScopeScope(PreParsedScopeData* data, |
+ ScopeType scope_type, |
+ int start_position, int end_position) |
+ : data_(data), |
+ previous_scope_(data->current_scope_), |
+ inner_scope_count_(0), |
+ variable_count_(0) { |
+ data->current_scope_ = this; |
+ if (previous_scope_ != nullptr) { |
+ ++previous_scope_->inner_scope_count_; |
jochen (gone - plz use gerrit)
2017/01/25 11:16:01
inner_scope_count_ is just one-level down, right?
marja
2017/01/25 11:50:28
Yes. Why?
jochen (gone - plz use gerrit)
2017/01/25 12:01:22
just wanted to verify I understood the code correc
|
+ } |
+ |
+ data->backing_store_.push_back(scope_type); |
+ data->backing_store_.push_back(start_position); |
+ data->backing_store_.push_back(end_position); |
+ // Reserve space for variable and inner scope count (we don't know yet how |
+ // many will be added). |
+ index_in_data_ = data->backing_store_.size(); |
+ data->backing_store_.push_back(0); |
jochen (gone - plz use gerrit)
2017/01/25 11:16:01
maybe use -1, so it's easier to debug... right now
marja
2017/01/25 11:50:28
Done.
|
+ data->backing_store_.push_back(0); |
+} |
+ |
+PreParsedScopeData::ScopeScope::~ScopeScope() { |
+ data_->current_scope_ = previous_scope_; |
+ data_->backing_store_[index_in_data_] = inner_scope_count_; |
+ data_->backing_store_[index_in_data_ + 1] = variable_count_; |
+} |
+ |
+} // namespace internal |
+} // namespace v8 |