• Benedikt Meurer's avatar
    [console] Proper type conversions in console builtins. · 099cb420
    Benedikt Meurer authored
    This updates the following set of console builtins in V8 to match the
    Console Standard (https://console.spec.whatwg.org) with respect to
    (potentially side effecting) type conversions:
    
      - console.debug
      - console.error
      - console.info
      - console.log
      - console.trace
      - console.warn
      - console.group
      - console.groupCollapsed
      - console.assert
    
    The V8 implementation only performs the type conversions and updates
    the arguments in-place with the results from the %String% constructor,
    %parseInt%, or %parseFloat% invocations. The actual formatting is
    still left completely to the debugger front-end.
    
    To give a concrete example, the following code
    
    ```js
    const msgFmt = {
      toString() { return 'Message %i' }
    };
    console.log('LOG: %s`, msgFmt, 42);
    ```
    
    sends the following parameters to the debugger front-end
    
    ```js
    ["LOG: %s", "Message %i", 42]
    ```
    
    and it's then the job of the front-end to perform the actual string
    substitutions.
    
    It's also worth calling out that the console builtins are only
    concerned with %s, %f, %d, and %i formatting specifiers, since
    these are the only ones that trigger type conversions, and %o, %O,
    and %c can only be implemented in a meaningful way at a higher
    level.
    
    Fixed: chromium:1277944
    Bug: chromium:1282076
    Doc: https://bit.ly/v8-proper-console-type-conversions
    Spec: https://console.spec.whatwg.org
    Change-Id: I0996680811aa96236bd0d879e4a11101629ef1a7
    Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3352118Reviewed-by: 's avatarKim-Anh Tran <kimanh@chromium.org>
    Auto-Submit: Benedikt Meurer <bmeurer@chromium.org>
    Reviewed-by: 's avatarIgor Sheludko <ishell@chromium.org>
    Commit-Queue: Igor Sheludko <ishell@chromium.org>
    Cr-Commit-Position: refs/heads/main@{#78432}
    099cb420
Name
Last commit
Last update
..
add-binding-expected.txt Loading commit data...
add-binding.js Loading commit data...
await-promise-expected.txt Loading commit data...
await-promise.js Loading commit data...
call-function-on-async-expected.txt Loading commit data...
call-function-on-async.js Loading commit data...
call-function-on-side-effect-free-expected.txt Loading commit data...
call-function-on-side-effect-free.js Loading commit data...
clear-of-command-line-api-expected.txt Loading commit data...
clear-of-command-line-api.js Loading commit data...
client-console-api-message-expected.txt Loading commit data...
client-console-api-message.js Loading commit data...
command-line-api-expected.txt Loading commit data...
command-line-api-without-side-effects-expected.txt Loading commit data...
command-line-api-without-side-effects.js Loading commit data...
command-line-api.js Loading commit data...
compile-script-expected.txt Loading commit data...
compile-script.js Loading commit data...
console-api-repeated-in-console-expected.txt Loading commit data...
console-api-repeated-in-console.js Loading commit data...
console-assert-expected.txt Loading commit data...
console-assert.js Loading commit data...
console-context-expected.txt Loading commit data...
console-context.js Loading commit data...
console-formatter-expected.txt Loading commit data...
console-formatter.js Loading commit data...
console-line-and-column-expected.txt Loading commit data...
console-line-and-column.js Loading commit data...
console-log-doesnt-run-microtasks-expected.txt Loading commit data...
console-log-doesnt-run-microtasks.js Loading commit data...
console-memory-expected.txt Loading commit data...
console-memory.js Loading commit data...
console-message-omit-data-urls-expected.txt Loading commit data...
console-message-omit-data-urls.js Loading commit data...
console-messages-limits-expected.txt Loading commit data...
console-messages-limits.js Loading commit data...
console-methods-expected.txt Loading commit data...
console-methods.js Loading commit data...
console-spec-expected.txt Loading commit data...
console-spec.js Loading commit data...
console-table-expected.txt Loading commit data...
console-table.js Loading commit data...
console-time-end-format-expected.txt Loading commit data...
console-time-end-format.js Loading commit data...
console-time-log-expected.txt Loading commit data...
console-time-log.js Loading commit data...
console-time-repeat-expected.txt Loading commit data...
console-time-repeat.js Loading commit data...
console-timestamp-expected.txt Loading commit data...
console-timestamp.js Loading commit data...
context-destroyed-on-context-collected-expected.txt Loading commit data...
context-destroyed-on-context-collected.js Loading commit data...
create-context-expected.txt Loading commit data...
create-context.js Loading commit data...
custom-preview-expected.txt Loading commit data...
custom-preview.js Loading commit data...
enable-async-stack-expected.txt Loading commit data...
enable-async-stack.js Loading commit data...
error-preview-expected.txt Loading commit data...
error-preview.js Loading commit data...
es6-module-expected.txt Loading commit data...
es6-module.js Loading commit data...
evaluate-async-expected.txt Loading commit data...
evaluate-async-with-wrap-error-expected.txt Loading commit data...
evaluate-async-with-wrap-error.js Loading commit data...
evaluate-async.js Loading commit data...
evaluate-empty-stack-expected.txt Loading commit data...
evaluate-empty-stack.js Loading commit data...
evaluate-new-function-error-expected.txt Loading commit data...
evaluate-new-function-error.js Loading commit data...
evaluate-repl-await-expected.txt Loading commit data...
evaluate-repl-await.js Loading commit data...
evaluate-repl-mode-code-cache-expected.txt Loading commit data...
evaluate-repl-mode-code-cache.js Loading commit data...
evaluate-repl-mode-expected.txt Loading commit data...
evaluate-repl-mode-side-effecting-expected.txt Loading commit data...
evaluate-repl-mode-side-effecting.js Loading commit data...
evaluate-repl-mode.js Loading commit data...
evaluate-run-microtasks-expected.txt Loading commit data...
evaluate-run-microtasks.js Loading commit data...
evaluate-timeout-expected.txt Loading commit data...
evaluate-timeout.js Loading commit data...
evaluate-unique-context-id-expected.txt Loading commit data...
evaluate-unique-context-id.js Loading commit data...
evaluate-unserializable-expected.txt Loading commit data...
evaluate-unserializable.js Loading commit data...
evaluate-with-context-id-equal-zero-expected.txt Loading commit data...
evaluate-with-context-id-equal-zero.js Loading commit data...
evaluate-with-disable-breaks-expected.txt Loading commit data...
evaluate-with-disable-breaks.js Loading commit data...
evaluate-with-generate-preview-expected.txt Loading commit data...
evaluate-with-generate-preview.js Loading commit data...
evaluate-without-side-effects-expected.txt Loading commit data...
evaluate-without-side-effects-i18n-expected.txt Loading commit data...
evaluate-without-side-effects-i18n.js Loading commit data...
evaluate-without-side-effects.js Loading commit data...
exception-thrown-expected.txt Loading commit data...
exception-thrown-metadata-expected.txt Loading commit data...
exception-thrown-metadata.js Loading commit data...
exception-thrown.js Loading commit data...
exceptionthrown-on-connect-expected.txt Loading commit data...
exceptionthrown-on-connect.js Loading commit data...
function-location-expected.txt Loading commit data...
function-location.js Loading commit data...
function-scopes-expected.txt Loading commit data...
function-scopes.js Loading commit data...
get-heap-usage-expected.txt Loading commit data...
get-heap-usage.js Loading commit data...
get-isolate-id-expected.txt Loading commit data...
get-isolate-id.js Loading commit data...
get-properties-expected.txt Loading commit data...
get-properties-on-proxy-expected.txt Loading commit data...
get-properties-on-proxy.js Loading commit data...
get-properties-preview-expected.txt Loading commit data...
get-properties-preview.js Loading commit data...
get-properties.js Loading commit data...
internal-properties-entries-expected.txt Loading commit data...
internal-properties-entries.js Loading commit data...
internal-properties-expected.txt Loading commit data...
internal-properties.js Loading commit data...
length-or-size-description-expected.txt Loading commit data...
length-or-size-description.js Loading commit data...
property-on-console-proto-expected.txt Loading commit data...
property-on-console-proto.js Loading commit data...
protocol-works-with-different-locale-expected.txt Loading commit data...
protocol-works-with-different-locale.js Loading commit data...
query-objects-expected.txt Loading commit data...
query-objects.js Loading commit data...
regress-1075763-expected.txt Loading commit data...
regress-1075763.js Loading commit data...
regress-1078205-expected.txt Loading commit data...
regress-1078205.js Loading commit data...
regress-986051-expected.txt Loading commit data...
regress-986051.js Loading commit data...
regression-1052721-expected.txt Loading commit data...
regression-1052721.js Loading commit data...
regression-1140845-expected.txt Loading commit data...
regression-1140845.js Loading commit data...
regression-732717-expected.txt Loading commit data...
regression-732717.js Loading commit data...
regression-736302-expected.txt Loading commit data...
regression-736302.js Loading commit data...
release-object-expected.txt Loading commit data...
release-object.js Loading commit data...
remote-object-expected.txt Loading commit data...
remote-object-get-properties-expected.txt Loading commit data...
remote-object-get-properties.js Loading commit data...
remote-object.js Loading commit data...
run-script-async-expected.txt Loading commit data...
run-script-async.js Loading commit data...
runtime-disable-preserve-injected-script-expected.txt Loading commit data...
runtime-disable-preserve-injected-script.js Loading commit data...
runtime-evaluate-null-property-expected.txt Loading commit data...
runtime-evaluate-null-property.js Loading commit data...
runtime-evaluate-with-dirty-context-expected.txt Loading commit data...
runtime-evaluate-with-dirty-context.js Loading commit data...
runtime-get-properties-and-accessor-expected.txt Loading commit data...
runtime-get-properties-and-accessor.js Loading commit data...
runtime-global-lexical-scope-names-expected.txt Loading commit data...
runtime-global-lexical-scope-names.js Loading commit data...
runtime-restore-expected.txt Loading commit data...
runtime-restore.js Loading commit data...
set-max-call-stack-size-expected.txt Loading commit data...
set-max-call-stack-size.js Loading commit data...
set-or-map-entries-expected.txt Loading commit data...
set-or-map-entries.js Loading commit data...
terminate-execution-expected.txt Loading commit data...
terminate-execution.js Loading commit data...