| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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 #include "src/compiler/ast-loop-assignment-analyzer.h" | 5 #include "src/compiler/ast-loop-assignment-analyzer.h" |
| 6 #include "src/parser.h" | 6 #include "src/parser.h" |
| 7 #include "src/rewriter.h" | 7 #include "src/rewriter.h" |
| 8 #include "src/scopes.h" | 8 #include "src/scopes.h" |
| 9 #include "test/cctest/cctest.h" | 9 #include "test/cctest/cctest.h" |
| 10 | 10 |
| (...skipping 19 matching lines...) Expand all Loading... |
| 30 void CheckLoopAssignedCount(int expected, const char* var_name) { | 30 void CheckLoopAssignedCount(int expected, const char* var_name) { |
| 31 // TODO(titzer): don't scope analyze every single time. | 31 // TODO(titzer): don't scope analyze every single time. |
| 32 CompilationInfo info(function, main_zone()); | 32 CompilationInfo info(function, main_zone()); |
| 33 | 33 |
| 34 CHECK(Parser::Parse(&info)); | 34 CHECK(Parser::Parse(&info)); |
| 35 CHECK(Rewriter::Rewrite(&info)); | 35 CHECK(Rewriter::Rewrite(&info)); |
| 36 CHECK(Scope::Analyze(&info)); | 36 CHECK(Scope::Analyze(&info)); |
| 37 | 37 |
| 38 Scope* scope = info.function()->scope(); | 38 Scope* scope = info.function()->scope(); |
| 39 AstValueFactory* factory = info.ast_value_factory(); | 39 AstValueFactory* factory = info.ast_value_factory(); |
| 40 CHECK_NE(NULL, scope); | 40 CHECK(scope); |
| 41 | 41 |
| 42 if (result == NULL) { | 42 if (result == NULL) { |
| 43 AstLoopAssignmentAnalyzer analyzer(main_zone(), &info); | 43 AstLoopAssignmentAnalyzer analyzer(main_zone(), &info); |
| 44 result = analyzer.Analyze(); | 44 result = analyzer.Analyze(); |
| 45 CHECK_NE(NULL, result); | 45 CHECK(result); |
| 46 } | 46 } |
| 47 | 47 |
| 48 const i::AstRawString* name = factory->GetOneByteString(var_name); | 48 const i::AstRawString* name = factory->GetOneByteString(var_name); |
| 49 | 49 |
| 50 i::Variable* var = scope->Lookup(name); | 50 i::Variable* var = scope->Lookup(name); |
| 51 CHECK_NE(NULL, var); | 51 CHECK(var); |
| 52 | 52 |
| 53 if (var->location() == Variable::UNALLOCATED) { | 53 if (var->location() == Variable::UNALLOCATED) { |
| 54 CHECK_EQ(0, expected); | 54 CHECK_EQ(0, expected); |
| 55 } else { | 55 } else { |
| 56 CHECK(var->IsStackAllocated()); | 56 CHECK(var->IsStackAllocated()); |
| 57 CHECK_EQ(expected, result->GetAssignmentCountForTesting(scope, var)); | 57 CHECK_EQ(expected, result->GetAssignmentCountForTesting(scope, var)); |
| 58 } | 58 } |
| 59 } | 59 } |
| 60 }; | 60 }; |
| 61 } | 61 } |
| (...skipping 223 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 285 " while (1) z++;" | 285 " while (1) z++;" |
| 286 " }" | 286 " }" |
| 287 "}" | 287 "}" |
| 288 "w;"); | 288 "w;"); |
| 289 | 289 |
| 290 f.CheckLoopAssignedCount(1, "x"); | 290 f.CheckLoopAssignedCount(1, "x"); |
| 291 f.CheckLoopAssignedCount(3, "y"); | 291 f.CheckLoopAssignedCount(3, "y"); |
| 292 f.CheckLoopAssignedCount(5, "z"); | 292 f.CheckLoopAssignedCount(5, "z"); |
| 293 f.CheckLoopAssignedCount(0, "w"); | 293 f.CheckLoopAssignedCount(0, "w"); |
| 294 } | 294 } |
| OLD | NEW |