22d8d3be5a
It's no longer needed. Bug: v8:12552 Change-Id: I3522ab621001ee07ce7037888934279e4050dea9 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3484318 Auto-Submit: Jakob Gruber <jgruber@chromium.org> Reviewed-by: Leszek Swirski <leszeks@chromium.org> Commit-Queue: Leszek Swirski <leszeks@chromium.org> Cr-Commit-Position: refs/heads/main@{#79235}
43 lines
1.1 KiB
JavaScript
43 lines
1.1 KiB
JavaScript
// Copyright 2019 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// Flags: --allow-natives-syntax --opt --no-always-opt
|
|
|
|
var expect_interpreted = true;
|
|
|
|
class C {
|
|
get prop() {
|
|
return 42;
|
|
}
|
|
set prop(v) {
|
|
if (!%IsDictPropertyConstTrackingEnabled()) {
|
|
// TODO(v8:11457) If v8_dict_property_const_tracking is enabled, then
|
|
// C.prototype is a dictionary mode object and we cannot inline the call
|
|
// to this setter, yet.
|
|
assertEquals(expect_interpreted, %IsBeingInterpreted());
|
|
}
|
|
%TurbofanStaticAssert(v === 43);
|
|
}
|
|
}
|
|
|
|
const c = new C();
|
|
|
|
function foo() {
|
|
assertEquals(expect_interpreted, %IsBeingInterpreted());
|
|
%TurbofanStaticAssert(c.prop === 42);
|
|
c.prop = 43;
|
|
}
|
|
|
|
%PrepareFunctionForOptimization(
|
|
Object.getOwnPropertyDescriptor(C.prototype, 'prop').get);
|
|
%PrepareFunctionForOptimization(
|
|
Object.getOwnPropertyDescriptor(C.prototype, 'prop').set);
|
|
%PrepareFunctionForOptimization(foo);
|
|
|
|
foo();
|
|
foo();
|
|
expect_interpreted = false;
|
|
%OptimizeFunctionOnNextCall(foo);
|
|
foo();
|