• Wiktor Garbacz's avatar
    [parser] Inital parallel parse tasks implementation. · 00912d73
    Wiktor Garbacz authored
    While parsing top-level code eager functions are skipped just like lazy
    ones, but also a parse task is created for each.
    
    The parse tasks are run by the compiler dispatcher and can be executed
    either on background thread or in idle time.
    After parsing of top-level code finishes it waits for all unfinished
    parser tasks - possibly picking up and executing them on current thread.
    Afterwards parse task results are stitched together with top-level AST,
    in case of failures eager functions are treated just like lazy -
    parsing/compilation is retriggered for them in the runtime and proper
    errors are generated (performance is not optimized for error case at
    all).
    
    BUG=v8:6093
    
    Change-Id: Ie6508211a04b90becfe44139cce1c8ecec386b6e
    Reviewed-on: https://chromium-review.googlesource.com/486725Reviewed-by: 's avatarJochen Eisinger <jochen@chromium.org>
    Reviewed-by: 's avatarMarja Hölttä <marja@chromium.org>
    Reviewed-by: 's avatarDaniel Vogelheim <vogelheim@chromium.org>
    Commit-Queue: Wiktor Garbacz <wiktorg@google.com>
    Cr-Commit-Position: refs/heads/master@{#45016}
    00912d73
preparser.cc 15.6 KB