OLD | NEW |
1 // Copyright 2009 the V8 project authors. All rights reserved. | 1 // Copyright 2009 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 198 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
209 } | 209 } |
210 return code; | 210 return code; |
211 } | 211 } |
212 | 212 |
213 | 213 |
214 // Generate the code. Takes a function literal, generates code for it, assemble | 214 // Generate the code. Takes a function literal, generates code for it, assemble |
215 // all the pieces into a Code object. This function is only to be called by | 215 // all the pieces into a Code object. This function is only to be called by |
216 // the compiler.cc code. | 216 // the compiler.cc code. |
217 Handle<Code> CodeGenerator::MakeCode(FunctionLiteral* fun, | 217 Handle<Code> CodeGenerator::MakeCode(FunctionLiteral* fun, |
218 Handle<Script> script, | 218 Handle<Script> script, |
219 bool is_eval) { | 219 bool is_eval, |
| 220 CompilationInfo* info) { |
220 if (!script->IsUndefined() && !script->source()->IsUndefined()) { | 221 if (!script->IsUndefined() && !script->source()->IsUndefined()) { |
221 int len = String::cast(script->source())->length(); | 222 int len = String::cast(script->source())->length(); |
222 Counters::total_old_codegen_source_size.Increment(len); | 223 Counters::total_old_codegen_source_size.Increment(len); |
223 } | 224 } |
224 MakeCodePrologue(fun); | 225 MakeCodePrologue(fun); |
225 // Generate code. | 226 // Generate code. |
226 const int kInitialBufferSize = 4 * KB; | 227 const int kInitialBufferSize = 4 * KB; |
227 CodeGenerator cgen(kInitialBufferSize, script, is_eval); | 228 CodeGenerator cgen(kInitialBufferSize, script, is_eval); |
228 CodeGeneratorScope scope(&cgen); | 229 CodeGeneratorScope scope(&cgen); |
229 cgen.GenCode(fun); | 230 cgen.GenCode(fun, info); |
230 if (cgen.HasStackOverflow()) { | 231 if (cgen.HasStackOverflow()) { |
231 ASSERT(!Top::has_pending_exception()); | 232 ASSERT(!Top::has_pending_exception()); |
232 return Handle<Code>::null(); | 233 return Handle<Code>::null(); |
233 } | 234 } |
234 | 235 |
235 InLoopFlag in_loop = (cgen.loop_nesting() != 0) ? IN_LOOP : NOT_IN_LOOP; | 236 InLoopFlag in_loop = (cgen.loop_nesting() != 0) ? IN_LOOP : NOT_IN_LOOP; |
236 Code::Flags flags = Code::ComputeFlags(Code::FUNCTION, in_loop); | 237 Code::Flags flags = Code::ComputeFlags(Code::FUNCTION, in_loop); |
237 return MakeCodeEpilogue(fun, cgen.masm(), flags, script); | 238 return MakeCodeEpilogue(fun, cgen.masm(), flags, script); |
238 } | 239 } |
239 | 240 |
(...skipping 260 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
500 } | 501 } |
501 } | 502 } |
502 | 503 |
503 | 504 |
504 void ApiGetterEntryStub::SetCustomCache(Code* value) { | 505 void ApiGetterEntryStub::SetCustomCache(Code* value) { |
505 info()->set_load_stub_cache(value); | 506 info()->set_load_stub_cache(value); |
506 } | 507 } |
507 | 508 |
508 | 509 |
509 } } // namespace v8::internal | 510 } } // namespace v8::internal |
OLD | NEW |