| 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 11 matching lines...) Expand all Loading... |
| 22 : function(Handle<JSFunction>::null()), result(NULL) { | 22 : function(Handle<JSFunction>::null()), result(NULL) { |
| 23 ScopedVector<char> program(kBufferSize); | 23 ScopedVector<char> program(kBufferSize); |
| 24 SNPrintF(program, "function f(a,b,c) { %s; } f;", body); | 24 SNPrintF(program, "function f(a,b,c) { %s; } f;", body); |
| 25 v8::Local<v8::Value> v = CompileRun(program.start()); | 25 v8::Local<v8::Value> v = CompileRun(program.start()); |
| 26 Handle<Object> obj = v8::Utils::OpenHandle(*v); | 26 Handle<Object> obj = v8::Utils::OpenHandle(*v); |
| 27 function = Handle<JSFunction>::cast(obj); | 27 function = Handle<JSFunction>::cast(obj); |
| 28 } | 28 } |
| 29 | 29 |
| 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 ParseInfo parse_info(main_zone()); |
| 33 parse_info.InitializeFromJSFunction(function); |
| 34 CompilationInfo info(&parse_info); |
| 33 | 35 |
| 34 CHECK(Parser::ParseStatic(&info)); | 36 CHECK(Parser::ParseStatic(&parse_info)); |
| 35 CHECK(Rewriter::Rewrite(&info)); | 37 CHECK(Rewriter::Rewrite(&parse_info)); |
| 36 CHECK(Scope::Analyze(&info)); | 38 CHECK(Scope::Analyze(&parse_info)); |
| 37 | 39 |
| 38 Scope* scope = info.function()->scope(); | 40 Scope* scope = info.function()->scope(); |
| 39 AstValueFactory* factory = info.ast_value_factory(); | 41 AstValueFactory* factory = parse_info.ast_value_factory(); |
| 40 CHECK(scope); | 42 CHECK(scope); |
| 41 | 43 |
| 42 if (result == NULL) { | 44 if (result == NULL) { |
| 43 AstLoopAssignmentAnalyzer analyzer(main_zone(), &info); | 45 AstLoopAssignmentAnalyzer analyzer(main_zone(), &info); |
| 44 result = analyzer.Analyze(); | 46 result = analyzer.Analyze(); |
| 45 CHECK(result); | 47 CHECK(result); |
| 46 } | 48 } |
| 47 | 49 |
| 48 const i::AstRawString* name = factory->GetOneByteString(var_name); | 50 const i::AstRawString* name = factory->GetOneByteString(var_name); |
| 49 | 51 |
| (...skipping 235 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 285 " while (1) z++;" | 287 " while (1) z++;" |
| 286 " }" | 288 " }" |
| 287 "}" | 289 "}" |
| 288 "w;"); | 290 "w;"); |
| 289 | 291 |
| 290 f.CheckLoopAssignedCount(1, "x"); | 292 f.CheckLoopAssignedCount(1, "x"); |
| 291 f.CheckLoopAssignedCount(3, "y"); | 293 f.CheckLoopAssignedCount(3, "y"); |
| 292 f.CheckLoopAssignedCount(5, "z"); | 294 f.CheckLoopAssignedCount(5, "z"); |
| 293 f.CheckLoopAssignedCount(0, "w"); | 295 f.CheckLoopAssignedCount(0, "w"); |
| 294 } | 296 } |
| OLD | NEW |