1. 16 Nov, 2017 12 commits
  2. 15 Nov, 2017 24 commits
  3. 14 Nov, 2017 4 commits
    • Adam Klein's avatar
      [parser] Remove inlining of Parser::RewriteSpreads · 1abeb0ca
      Adam Klein authored
      Despite the V8_INLINE annotation, it was never actually inlined until
      18cac20c removed the NonPatternRewriter,
      causing all calls to Parser::RewriteNonPattern() to inline RewriteSpreads.
      
      This patch should recover the binary bloat in the attached bug while
      retaining the inlining of the rest of RewriteNonPattern, which in
      the common case does very little work (and doesn't call out to RewriteSpreads).
      
      Bug: chromium:784924
      Change-Id: I1c2062b41ceb51a9522d49bdb9353e1840393ca1
      Reviewed-on: https://chromium-review.googlesource.com/769442Reviewed-by: 's avatarJakob Kummerow <jkummerow@chromium.org>
      Commit-Queue: Adam Klein <adamk@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#49370}
      1abeb0ca
    • Alexey Kozyatinskiy's avatar
      [inspector] use unordered_map for frames cache · 63fbef4e
      Alexey Kozyatinskiy authored
      Otherwise we can end up with performance regression with a lot of
      frames in cache. Map requires log(N) for lookup, unordered map for
      frames ids requires - ~O(1).
      
      R=dgozman@chromium.org
      
      Bug: v8:7078
      Cq-Include-Trybots: master.tryserver.blink:linux_trusty_blink_rel
      Change-Id: Iac1ff7e35daede8c5ebd424f686a8ef8dbae9061
      Reviewed-on: https://chromium-review.googlesource.com/767035
      Commit-Queue: Aleksey Kozyatinskiy <kozyatinskiy@chromium.org>
      Reviewed-by: 's avatarAlexei Filippov <alph@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#49369}
      63fbef4e
    • Adam Klein's avatar
      [parser] RewritableExpressions should keep track of their Scope directly · 082009fc
      Adam Klein authored
      Previously, the Parser stored a Scope alongside a RewritableExpression
      for each potential destructuring assignment. This Scope was later used
      during rewriting to set the correct context for the rewriting. But this
      approach failed if a new Scope was inserted into the Scope chain between
      the time the assignment was parsed and when it was rewritten.
      
      By storing the Scope directly in RewritableExpression,
      ReparentExpressionScopes() is able to appropriately re-scope such
      expressions prior to their rewriting.
      
      Bug: chromium:779457
      Change-Id: Ieb429a3da841f76d5798610af59da4fccb000652
      Reviewed-on: https://chromium-review.googlesource.com/767666
      Commit-Queue: Adam Klein <adamk@chromium.org>
      Reviewed-by: 's avatarMarja Hölttä <marja@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#49368}
      082009fc
    • Leszek Swirski's avatar
      [compiler] Add new "no cache reason" enum values · 61e04e28
      Leszek Swirski authored
      Add enum values to the "no cache reason" API which reflect new types of
      no-cache reason we will want to distinguish.
      
      Also, renames one of the enum values (BecauseExtension ->
      BecauseV8Extension) because it was confusing. It's a V8-only type of no
      cache reason, so it shouldn't affect embedders.
      
      Bug: chromium:769203
      Cq-Include-Trybots: master.tryserver.chromium.linux:linux_chromium_rel_ng
      Change-Id: I41d4ecfb35b2e91b71562b4f23b15d20f16a943c
      Reviewed-on: https://chromium-review.googlesource.com/769010Reviewed-by: 's avatarMythri Alle <mythria@chromium.org>
      Reviewed-by: 's avatarAdam Klein <adamk@chromium.org>
      Commit-Queue: Leszek Swirski <leszeks@chromium.org>
      Cr-Commit-Position: refs/heads/master@{#49367}
      61e04e28