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

Side by Side Diff: src/codegen.cc

Issue 552232: Introduce a stack-allocated structure to encapsulate compile-time information. (Closed)
Patch Set: Remove inadvertently included files. Created 10 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 | « src/ast.h ('k') | src/compiler.h » ('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 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
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
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
OLDNEW
« no previous file with comments | « src/ast.h ('k') | src/compiler.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698