| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 346 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 357 v8::Local<v8::Value> result = PreCompileCompileRun(source); | 357 v8::Local<v8::Value> result = PreCompileCompileRun(source); |
| 358 CHECK(result->IsString()); | 358 CHECK(result->IsString()); |
| 359 v8::String::Utf8Value utf8(result); | 359 v8::String::Utf8Value utf8(result); |
| 360 CHECK_EQ("foo", *utf8); | 360 CHECK_EQ("foo", *utf8); |
| 361 } | 361 } |
| 362 } | 362 } |
| 363 | 363 |
| 364 namespace v8 { | 364 namespace v8 { |
| 365 namespace internal { | 365 namespace internal { |
| 366 | 366 |
| 367 void FakeWritingSymbolIdInPreParseData(i::CompleteParserRecorder* log, | 367 struct CompleteParserRecorderFriend { |
| 368 int number) { | 368 static void FakeWritingSymbolIdInPreParseData(CompleteParserRecorder* log, |
| 369 log->WriteNumber(number); | 369 int number) { |
| 370 if (log->symbol_id_ < number + 1) { | 370 log->WriteNumber(number); |
| 371 log->symbol_id_ = number + 1; | 371 if (log->symbol_id_ < number + 1) { |
| 372 log->symbol_id_ = number + 1; |
| 373 } |
| 372 } | 374 } |
| 373 } | 375 static int symbol_position(CompleteParserRecorder* log) { |
| 376 return log->symbol_store_.size(); |
| 377 } |
| 378 static int symbol_ids(CompleteParserRecorder* log) { |
| 379 return log->symbol_id_; |
| 380 } |
| 381 static int function_position(CompleteParserRecorder* log) { |
| 382 return log->function_store_.size(); |
| 383 } |
| 384 }; |
| 374 | 385 |
| 375 } | 386 } |
| 376 } | 387 } |
| 377 | 388 |
| 378 | 389 |
| 379 TEST(StoringNumbersInPreParseData) { | 390 TEST(StoringNumbersInPreParseData) { |
| 380 // Symbol IDs are split into chunks of 7 bits for storing. This is a | 391 // Symbol IDs are split into chunks of 7 bits for storing. This is a |
| 381 // regression test for a bug where a symbol id was incorrectly stored if some | 392 // regression test for a bug where a symbol id was incorrectly stored if some |
| 382 // of the chunks in the middle were all zeros. | 393 // of the chunks in the middle were all zeros. |
| 394 typedef i::CompleteParserRecorderFriend F; |
| 383 i::CompleteParserRecorder log; | 395 i::CompleteParserRecorder log; |
| 384 for (int i = 0; i < 18; ++i) { | 396 for (int i = 0; i < 18; ++i) { |
| 385 FakeWritingSymbolIdInPreParseData(&log, 1 << i); | 397 F::FakeWritingSymbolIdInPreParseData(&log, 1 << i); |
| 386 } | 398 } |
| 387 for (int i = 1; i < 18; ++i) { | 399 for (int i = 1; i < 18; ++i) { |
| 388 FakeWritingSymbolIdInPreParseData(&log, (1 << i) + 1); | 400 F::FakeWritingSymbolIdInPreParseData(&log, (1 << i) + 1); |
| 389 } | 401 } |
| 390 for (int i = 6; i < 18; ++i) { | 402 for (int i = 6; i < 18; ++i) { |
| 391 FakeWritingSymbolIdInPreParseData(&log, (3 << i) + (5 << (i - 6))); | 403 F::FakeWritingSymbolIdInPreParseData(&log, (3 << i) + (5 << (i - 6))); |
| 392 } | 404 } |
| 393 i::Vector<unsigned> store = log.ExtractData(); | 405 i::Vector<unsigned> store = log.ExtractData(); |
| 394 i::ScriptDataImpl script_data(store); | 406 i::ScriptDataImpl script_data(store); |
| 395 script_data.Initialize(); | 407 script_data.Initialize(); |
| 396 // Check that we get the same symbols back. | 408 // Check that we get the same symbols back. |
| 397 for (int i = 0; i < 18; ++i) { | 409 for (int i = 0; i < 18; ++i) { |
| 398 CHECK_EQ(1 << i, script_data.GetSymbolIdentifier()); | 410 CHECK_EQ(1 << i, script_data.GetSymbolIdentifier()); |
| 399 } | 411 } |
| 400 for (int i = 1; i < 18; ++i) { | 412 for (int i = 1; i < 18; ++i) { |
| 401 CHECK_EQ((1 << i) + 1, script_data.GetSymbolIdentifier()); | 413 CHECK_EQ((1 << i) + 1, script_data.GetSymbolIdentifier()); |
| (...skipping 1599 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2001 // Labels, variables and functions insize lazy functions are not recorded. | 2013 // Labels, variables and functions insize lazy functions are not recorded. |
| 2002 {"function lazy() { var a, b, c; }", 1, 1}, | 2014 {"function lazy() { var a, b, c; }", 1, 1}, |
| 2003 {"function lazy() { a: 1; b: 2; c: 3; }", 1, 1}, | 2015 {"function lazy() { a: 1; b: 2; c: 3; }", 1, 1}, |
| 2004 {"function lazy() { function a() {} function b() {} function c() {} }", 1, | 2016 {"function lazy() { function a() {} function b() {} function c() {} }", 1, |
| 2005 1}, | 2017 1}, |
| 2006 {NULL, 0, 0} | 2018 {NULL, 0, 0} |
| 2007 }; | 2019 }; |
| 2008 // Each function adds 5 elements to the preparse function data. | 2020 // Each function adds 5 elements to the preparse function data. |
| 2009 const int kDataPerFunction = 5; | 2021 const int kDataPerFunction = 5; |
| 2010 | 2022 |
| 2023 typedef i::CompleteParserRecorderFriend F; |
| 2011 uintptr_t stack_limit = CcTest::i_isolate()->stack_guard()->real_climit(); | 2024 uintptr_t stack_limit = CcTest::i_isolate()->stack_guard()->real_climit(); |
| 2012 for (int i = 0; test_cases[i].program; i++) { | 2025 for (int i = 0; test_cases[i].program; i++) { |
| 2013 const char* program = test_cases[i].program; | 2026 const char* program = test_cases[i].program; |
| 2014 i::Utf8ToUtf16CharacterStream stream( | 2027 i::Utf8ToUtf16CharacterStream stream( |
| 2015 reinterpret_cast<const i::byte*>(program), | 2028 reinterpret_cast<const i::byte*>(program), |
| 2016 static_cast<unsigned>(strlen(program))); | 2029 static_cast<unsigned>(strlen(program))); |
| 2017 i::CompleteParserRecorder log; | 2030 i::CompleteParserRecorder log; |
| 2018 i::Scanner scanner(CcTest::i_isolate()->unicode_cache()); | 2031 i::Scanner scanner(CcTest::i_isolate()->unicode_cache()); |
| 2019 scanner.Initialize(&stream); | 2032 scanner.Initialize(&stream); |
| 2020 | 2033 |
| 2021 i::PreParser preparser(&scanner, &log, stack_limit); | 2034 i::PreParser preparser(&scanner, &log, stack_limit); |
| 2022 preparser.set_allow_lazy(true); | 2035 preparser.set_allow_lazy(true); |
| 2023 preparser.set_allow_natives_syntax(true); | 2036 preparser.set_allow_natives_syntax(true); |
| 2024 i::PreParser::PreParseResult result = preparser.PreParseProgram(); | 2037 i::PreParser::PreParseResult result = preparser.PreParseProgram(); |
| 2025 CHECK_EQ(i::PreParser::kPreParseSuccess, result); | 2038 CHECK_EQ(i::PreParser::kPreParseSuccess, result); |
| 2026 if (log.symbol_ids() != test_cases[i].symbols) { | 2039 if (F::symbol_ids(&log) != test_cases[i].symbols) { |
| 2027 i::OS::Print( | 2040 i::OS::Print( |
| 2028 "Expected preparse data for program:\n" | 2041 "Expected preparse data for program:\n" |
| 2029 "\t%s\n" | 2042 "\t%s\n" |
| 2030 "to contain %d symbols, however, received %d symbols.\n", | 2043 "to contain %d symbols, however, received %d symbols.\n", |
| 2031 program, test_cases[i].symbols, log.symbol_ids()); | 2044 program, test_cases[i].symbols, F::symbol_ids(&log)); |
| 2032 CHECK(false); | 2045 CHECK(false); |
| 2033 } | 2046 } |
| 2034 if (log.function_position() != test_cases[i].functions * kDataPerFunction) { | 2047 if (F::function_position(&log) != |
| 2048 test_cases[i].functions * kDataPerFunction) { |
| 2035 i::OS::Print( | 2049 i::OS::Print( |
| 2036 "Expected preparse data for program:\n" | 2050 "Expected preparse data for program:\n" |
| 2037 "\t%s\n" | 2051 "\t%s\n" |
| 2038 "to contain %d functions, however, received %d functions.\n", | 2052 "to contain %d functions, however, received %d functions.\n", |
| 2039 program, test_cases[i].functions, | 2053 program, test_cases[i].functions, |
| 2040 log.function_position() / kDataPerFunction); | 2054 F::function_position(&log) / kDataPerFunction); |
| 2041 CHECK(false); | 2055 CHECK(false); |
| 2042 } | 2056 } |
| 2043 i::ScriptDataImpl data(log.ExtractData()); | 2057 i::ScriptDataImpl data(log.ExtractData()); |
| 2044 CHECK(!data.has_error()); | 2058 CHECK(!data.has_error()); |
| 2045 } | 2059 } |
| 2046 } | 2060 } |
| 2047 | 2061 |
| 2048 | 2062 |
| 2049 TEST(FunctionDeclaresItselfStrict) { | 2063 TEST(FunctionDeclaresItselfStrict) { |
| 2050 // Tests that we produce the right kinds of errors when a function declares | 2064 // Tests that we produce the right kinds of errors when a function declares |
| (...skipping 298 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2349 | 2363 |
| 2350 const char* statement_data[] = { | 2364 const char* statement_data[] = { |
| 2351 statement, | 2365 statement, |
| 2352 NULL | 2366 NULL |
| 2353 }; | 2367 }; |
| 2354 | 2368 |
| 2355 // The test is quite slow, so run it with a reduced set of flags. | 2369 // The test is quite slow, so run it with a reduced set of flags. |
| 2356 static const ParserFlag empty_flags[] = {kAllowLazy}; | 2370 static const ParserFlag empty_flags[] = {kAllowLazy}; |
| 2357 RunParserSyncTest(context_data, statement_data, kError, empty_flags, 1); | 2371 RunParserSyncTest(context_data, statement_data, kError, empty_flags, 1); |
| 2358 } | 2372 } |
| OLD | NEW |