Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(152)

Side by Side Diff: src/ast/ast.h

Issue 1695393003: [es6] Implement for-of iterator finalization (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Disable iterator test for Ignition Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | src/ast/ast.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2012 the V8 project authors. All rights reserved. 1 // Copyright 2012 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef V8_AST_AST_H_ 5 #ifndef V8_AST_AST_H_
6 #define V8_AST_AST_H_ 6 #define V8_AST_AST_H_
7 7
8 #include "src/assembler.h" 8 #include "src/assembler.h"
9 #include "src/ast/ast-value-factory.h" 9 #include "src/ast/ast-value-factory.h"
10 #include "src/ast/modules.h" 10 #include "src/ast/modules.h"
(...skipping 181 matching lines...) Expand 10 before | Expand all | Expand 10 after
192 explicit AstNode(int position): position_(position) {} 192 explicit AstNode(int position): position_(position) {}
193 virtual ~AstNode() {} 193 virtual ~AstNode() {}
194 194
195 virtual void Accept(AstVisitor* v) = 0; 195 virtual void Accept(AstVisitor* v) = 0;
196 virtual NodeType node_type() const = 0; 196 virtual NodeType node_type() const = 0;
197 int position() const { return position_; } 197 int position() const { return position_; }
198 198
199 #ifdef DEBUG 199 #ifdef DEBUG
200 void PrettyPrint(Isolate* isolate); 200 void PrettyPrint(Isolate* isolate);
201 void PrettyPrint(); 201 void PrettyPrint();
202 void PrintAst(Isolate* isolate); 202 void Print(Isolate* isolate);
203 void PrintAst(); 203 void Print();
204 #endif // DEBUG 204 #endif // DEBUG
205 205
206 // Type testing & conversion functions overridden by concrete subclasses. 206 // Type testing & conversion functions overridden by concrete subclasses.
207 #define DECLARE_NODE_FUNCTIONS(type) \ 207 #define DECLARE_NODE_FUNCTIONS(type) \
208 bool Is##type() const { return node_type() == AstNode::k##type; } \ 208 bool Is##type() const { return node_type() == AstNode::k##type; } \
209 type* As##type() { \ 209 type* As##type() { \
210 return Is##type() ? reinterpret_cast<type*>(this) : NULL; \ 210 return Is##type() ? reinterpret_cast<type*>(this) : NULL; \
211 } \ 211 } \
212 const type* As##type() const { \ 212 const type* As##type() const { \
213 return Is##type() ? reinterpret_cast<const type*>(this) : NULL; \ 213 return Is##type() ? reinterpret_cast<const type*>(this) : NULL; \
(...skipping 662 matching lines...) Expand 10 before | Expand all | Expand 10 after
876 }; 876 };
877 877
878 878
879 class ForOfStatement final : public ForEachStatement { 879 class ForOfStatement final : public ForEachStatement {
880 public: 880 public:
881 DECLARE_NODE_TYPE(ForOfStatement) 881 DECLARE_NODE_TYPE(ForOfStatement)
882 882
883 void Initialize(Expression* each, 883 void Initialize(Expression* each,
884 Expression* subject, 884 Expression* subject,
885 Statement* body, 885 Statement* body,
886 Variable* iterator,
886 Expression* assign_iterator, 887 Expression* assign_iterator,
887 Expression* next_result, 888 Expression* next_result,
888 Expression* result_done, 889 Expression* result_done,
889 Expression* assign_each) { 890 Expression* assign_each) {
890 ForEachStatement::Initialize(each, subject, body); 891 ForEachStatement::Initialize(each, subject, body);
892 iterator_ = iterator;
891 assign_iterator_ = assign_iterator; 893 assign_iterator_ = assign_iterator;
892 next_result_ = next_result; 894 next_result_ = next_result;
893 result_done_ = result_done; 895 result_done_ = result_done;
894 assign_each_ = assign_each; 896 assign_each_ = assign_each;
895 } 897 }
896 898
897 Expression* iterable() const { 899 Expression* iterable() const {
898 return subject(); 900 return subject();
899 } 901 }
900 902
903 Variable* iterator() const {
904 return iterator_;
905 }
906
901 // iterator = subject[Symbol.iterator]() 907 // iterator = subject[Symbol.iterator]()
902 Expression* assign_iterator() const { 908 Expression* assign_iterator() const {
903 return assign_iterator_; 909 return assign_iterator_;
904 } 910 }
905 911
906 // result = iterator.next() // with type check 912 // result = iterator.next() // with type check
907 Expression* next_result() const { 913 Expression* next_result() const {
908 return next_result_; 914 return next_result_;
909 } 915 }
910 916
(...skipping 14 matching lines...) Expand all
925 931
926 BailoutId ContinueId() const override { return EntryId(); } 932 BailoutId ContinueId() const override { return EntryId(); }
927 BailoutId StackCheckId() const override { return BackEdgeId(); } 933 BailoutId StackCheckId() const override { return BackEdgeId(); }
928 934
929 static int num_ids() { return parent_num_ids() + 1; } 935 static int num_ids() { return parent_num_ids() + 1; }
930 BailoutId BackEdgeId() const { return BailoutId(local_id(0)); } 936 BailoutId BackEdgeId() const { return BailoutId(local_id(0)); }
931 937
932 protected: 938 protected:
933 ForOfStatement(Zone* zone, ZoneList<const AstRawString*>* labels, int pos) 939 ForOfStatement(Zone* zone, ZoneList<const AstRawString*>* labels, int pos)
934 : ForEachStatement(zone, labels, pos), 940 : ForEachStatement(zone, labels, pos),
941 iterator_(NULL),
935 assign_iterator_(NULL), 942 assign_iterator_(NULL),
936 next_result_(NULL), 943 next_result_(NULL),
937 result_done_(NULL), 944 result_done_(NULL),
938 assign_each_(NULL) {} 945 assign_each_(NULL) {}
939 static int parent_num_ids() { return ForEachStatement::num_ids(); } 946 static int parent_num_ids() { return ForEachStatement::num_ids(); }
940 947
941 private: 948 private:
942 int local_id(int n) const { return base_id() + parent_num_ids() + n; } 949 int local_id(int n) const { return base_id() + parent_num_ids() + n; }
943 950
951 Variable* iterator_;
944 Expression* assign_iterator_; 952 Expression* assign_iterator_;
945 Expression* next_result_; 953 Expression* next_result_;
946 Expression* result_done_; 954 Expression* result_done_;
947 Expression* assign_each_; 955 Expression* assign_each_;
948 }; 956 };
949 957
950 958
951 class ExpressionStatement final : public Statement { 959 class ExpressionStatement final : public Statement {
952 public: 960 public:
953 DECLARE_NODE_TYPE(ExpressionStatement) 961 DECLARE_NODE_TYPE(ExpressionStatement)
(...skipping 2558 matching lines...) Expand 10 before | Expand all | Expand 10 after
3512 // the parser-level zone. 3520 // the parser-level zone.
3513 Zone* parser_zone_; 3521 Zone* parser_zone_;
3514 AstValueFactory* ast_value_factory_; 3522 AstValueFactory* ast_value_factory_;
3515 }; 3523 };
3516 3524
3517 3525
3518 } // namespace internal 3526 } // namespace internal
3519 } // namespace v8 3527 } // namespace v8
3520 3528
3521 #endif // V8_AST_AST_H_ 3529 #endif // V8_AST_AST_H_
OLDNEW
« no previous file with comments | « no previous file | src/ast/ast.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698