Chromium Code Reviews| Index: src/ast.h |
| diff --git a/src/ast.h b/src/ast.h |
| index f22c96ccdfc7a2f3972202844c500ab78bfab1ce..81682cff9a9abececc9a156872ade0430fbc4bbf 100644 |
| --- a/src/ast.h |
| +++ b/src/ast.h |
| @@ -171,7 +171,6 @@ typedef ZoneList<Handle<Object> > ZoneObjectList; |
| enum AstPropertiesFlag { |
| kDontInline, |
| - kDontOptimize, |
| kDontSelfOptimize, |
| kDontSoftInline, |
| kDontCache |
| @@ -2314,6 +2313,15 @@ class FunctionLiteral V8_FINAL : public Expression { |
| void set_ast_properties(AstProperties* ast_properties) { |
| ast_properties_ = *ast_properties; |
| } |
| + inline BailoutReason dont_optimize_reason() { |
|
yurys
2013/09/02 14:40:05
No need to add inline, the compiler should be smar
loislo
2013/09/02 16:03:45
Done.
|
| + return dont_optimize_reason_; |
| + } |
| + inline void set_dont_optimize_reason(BailoutReason reason) { |
| + dont_optimize_reason_ = reason; |
| + } |
| + inline bool dont_optimize() { |
| + return dont_optimize_reason_ != kNoReason; |
| + } |
| protected: |
| FunctionLiteral(Isolate* isolate, |
| @@ -2334,6 +2342,7 @@ class FunctionLiteral V8_FINAL : public Expression { |
| scope_(scope), |
| body_(body), |
| inferred_name_(isolate->factory()->empty_string()), |
| + dont_optimize_reason_(kNoReason), |
| materialized_literal_count_(materialized_literal_count), |
| expected_property_count_(expected_property_count), |
| handler_count_(handler_count), |
| @@ -2355,6 +2364,7 @@ class FunctionLiteral V8_FINAL : public Expression { |
| ZoneList<Statement*>* body_; |
| Handle<String> inferred_name_; |
| AstProperties ast_properties_; |
| + BailoutReason dont_optimize_reason_; |
| int materialized_literal_count_; |
| int expected_property_count_; |
| @@ -2829,9 +2839,11 @@ private: \ |
| class AstConstructionVisitor BASE_EMBEDDED { |
| public: |
| - AstConstructionVisitor() { } |
| + AstConstructionVisitor() : dont_optimize_reason_(kNoReason) { |
| + } |
| AstProperties* ast_properties() { return &properties_; } |
| + BailoutReason dont_optimize_reason() { return dont_optimize_reason_; } |
| private: |
| template<class> friend class AstNodeFactory; |
| @@ -2844,8 +2856,12 @@ class AstConstructionVisitor BASE_EMBEDDED { |
| void increase_node_count() { properties_.add_node_count(1); } |
| void add_flag(AstPropertiesFlag flag) { properties_.flags()->Add(flag); } |
| + void set_dont_optimize_reason(BailoutReason reason) { |
| + dont_optimize_reason_ = reason; |
| + } |
| AstProperties properties_; |
| + BailoutReason dont_optimize_reason_; |
| }; |