 Chromium Code Reviews
 Chromium Code Reviews Issue 700963002:
  Replace C++ bitfields with our own BitFields  (Closed) 
  Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
    
  
    Issue 700963002:
  Replace C++ bitfields with our own BitFields  (Closed) 
  Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge| OLD | NEW | 
|---|---|
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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 // Features shared by parsing and pre-parsing scanners. | 5 // Features shared by parsing and pre-parsing scanners. | 
| 6 | 6 | 
| 7 #include <stdint.h> | 7 #include <stdint.h> | 
| 8 | 8 | 
| 9 #include <cmath> | 9 #include <cmath> | 
| 10 | 10 | 
| (...skipping 227 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 238 // Spidermonkey. | 238 // Spidermonkey. | 
| 239 return c == 0xFFFE; | 239 return c == 0xFFFE; | 
| 240 } | 240 } | 
| 241 | 241 | 
| 242 | 242 | 
| 243 bool Scanner::SkipWhiteSpace() { | 243 bool Scanner::SkipWhiteSpace() { | 
| 244 int start_position = source_pos(); | 244 int start_position = source_pos(); | 
| 245 | 245 | 
| 246 while (true) { | 246 while (true) { | 
| 247 while (true) { | 247 while (true) { | 
| 248 // The unicode cache accepts unsigned inputs. | |
| 249 if (c0_ < 0) break; | |
| 
Sven Panne
2014/11/05 09:11:49
How is this related to the bitfield fiddling?
 
Jakob Kummerow
2014/11/05 12:13:46
As the comment says, the unicode_cache_ only accep
 | |
| 248 // Advance as long as character is a WhiteSpace or LineTerminator. | 250 // Advance as long as character is a WhiteSpace or LineTerminator. | 
| 249 // Remember if the latter is the case. | 251 // Remember if the latter is the case. | 
| 250 if (unicode_cache_->IsLineTerminator(c0_)) { | 252 if (unicode_cache_->IsLineTerminator(c0_)) { | 
| 251 has_line_terminator_before_next_ = true; | 253 has_line_terminator_before_next_ = true; | 
| 252 } else if (!unicode_cache_->IsWhiteSpace(c0_) && | 254 } else if (!unicode_cache_->IsWhiteSpace(c0_) && | 
| 253 !IsLittleEndianByteOrderMark(c0_)) { | 255 !IsLittleEndianByteOrderMark(c0_)) { | 
| 254 break; | 256 break; | 
| 255 } | 257 } | 
| 256 Advance(); | 258 Advance(); | 
| 257 } | 259 } | 
| (...skipping 360 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 618 | 620 | 
| 619 case '?': | 621 case '?': | 
| 620 token = Select(Token::CONDITIONAL); | 622 token = Select(Token::CONDITIONAL); | 
| 621 break; | 623 break; | 
| 622 | 624 | 
| 623 case '~': | 625 case '~': | 
| 624 token = Select(Token::BIT_NOT); | 626 token = Select(Token::BIT_NOT); | 
| 625 break; | 627 break; | 
| 626 | 628 | 
| 627 default: | 629 default: | 
| 628 if (unicode_cache_->IsIdentifierStart(c0_)) { | 630 if (c0_ < 0) { | 
| 631 token = Token::EOS; | |
| 
Sven Panne
2014/11/05 09:11:49
Same here...
 | |
| 632 } else if (unicode_cache_->IsIdentifierStart(c0_)) { | |
| 629 token = ScanIdentifierOrKeyword(); | 633 token = ScanIdentifierOrKeyword(); | 
| 630 } else if (IsDecimalDigit(c0_)) { | 634 } else if (IsDecimalDigit(c0_)) { | 
| 631 token = ScanNumber(false); | 635 token = ScanNumber(false); | 
| 632 } else if (SkipWhiteSpace()) { | 636 } else if (SkipWhiteSpace()) { | 
| 633 token = Token::WHITESPACE; | 637 token = Token::WHITESPACE; | 
| 634 } else if (c0_ < 0) { | |
| 635 token = Token::EOS; | |
| 636 } else { | 638 } else { | 
| 637 token = Select(Token::ILLEGAL); | 639 token = Select(Token::ILLEGAL); | 
| 638 } | 640 } | 
| 639 break; | 641 break; | 
| 640 } | 642 } | 
| 641 | 643 | 
| 642 // Continue scanning for tokens as long as we're just skipping | 644 // Continue scanning for tokens as long as we're just skipping | 
| 643 // whitespace. | 645 // whitespace. | 
| 644 } while (token == Token::WHITESPACE); | 646 } while (token == Token::WHITESPACE); | 
| 645 | 647 | 
| (...skipping 698 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1344 } | 1346 } | 
| 1345 backing_store_.Add(static_cast<uint8_t>((one_byte_length >> 7) | 0x80u)); | 1347 backing_store_.Add(static_cast<uint8_t>((one_byte_length >> 7) | 0x80u)); | 
| 1346 } | 1348 } | 
| 1347 backing_store_.Add(static_cast<uint8_t>(one_byte_length & 0x7f)); | 1349 backing_store_.Add(static_cast<uint8_t>(one_byte_length & 0x7f)); | 
| 1348 | 1350 | 
| 1349 backing_store_.AddBlock(bytes); | 1351 backing_store_.AddBlock(bytes); | 
| 1350 return backing_store_.EndSequence().start(); | 1352 return backing_store_.EndSequence().start(); | 
| 1351 } | 1353 } | 
| 1352 | 1354 | 
| 1353 } } // namespace v8::internal | 1355 } } // namespace v8::internal | 
| OLD | NEW |