963ff849df
This patch implements inspector support for private instance methods: - Previously to implement brand checking for instances with private instance methods we store the brand both as the value with the brand itself as the key in the stances. Now we make the value the context associated with the class instead. - To retrieve the private instance methods and accessors from the instances at runtime, we look into the contexts stored with the brands, and analyze the scope info to get the names as well as context slot indices of them. - This patch extends the `PrivatePropertyDescriptor` in the inspector protocol to include optional `get` and `set` fields, and make the `value` field optional (similar to `PropertyDescriptor`s). Private fields or private instance methods are returned in the `value` field while private accessors are returned in the `get` and/or `set` field. Property previews for the instaces containing private instance methods and accessors are also updated similarly, although no additional protocol change is necessary since the `PropertyPreview` type can already be used to display accessors. Design doc: https://docs.google.com/document/d/1N91LObhQexnB0eE7EvGe57HsvNMFX16CaWu-XCTnnmY/edit Bug: v8:9839, v8:8330 Change-Id: If37090bd23833a18f75deb1249ca5c4405ca2bf2 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1934407 Commit-Queue: Joyee Cheung <joyee@igalia.com> Reviewed-by: Yang Guo <yangguo@chromium.org> Reviewed-by: Ross McIlroy <rmcilroy@chromium.org> Reviewed-by: Toon Verwaest <verwaest@chromium.org> Cr-Commit-Position: refs/heads/master@{#65337}
151 lines
3.6 KiB
Plaintext
151 lines
3.6 KiB
Plaintext
#
|
|
# Autogenerated by generate-bytecode-expectations.
|
|
#
|
|
|
|
---
|
|
wrap: no
|
|
test function name: test
|
|
private methods: yes
|
|
|
|
---
|
|
snippet: "
|
|
class A {
|
|
#a() { return 1; }
|
|
constructor() { return this.#a(); }
|
|
}
|
|
|
|
var test = A;
|
|
new A;
|
|
"
|
|
frame size: 4
|
|
parameter count: 1
|
|
bytecode array length: 31
|
|
bytecodes: [
|
|
/* 44 E> */ B(StackCheck),
|
|
B(LdaCurrentContextSlot), U8(3),
|
|
B(Star), R(1),
|
|
B(Mov), R(this), R(0),
|
|
B(Mov), R(context), R(2),
|
|
B(CallRuntime), U16(Runtime::kAddPrivateBrand), R(0), U8(3),
|
|
/* 49 S> */ B(LdaCurrentContextSlot), U8(3),
|
|
/* 61 E> */ B(LdaKeyedProperty), R(this), U8(0),
|
|
B(LdaCurrentContextSlot), U8(2),
|
|
B(Star), R(3),
|
|
/* 63 E> */ B(CallAnyReceiver), R(3), R(this), U8(1), U8(2),
|
|
/* 66 S> */ B(Return),
|
|
]
|
|
constant pool: [
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
class B {
|
|
#b() { return 1; }
|
|
constructor() { this.#b = 1; }
|
|
}
|
|
|
|
var test = B;
|
|
new test;
|
|
"
|
|
frame size: 5
|
|
parameter count: 1
|
|
bytecode array length: 32
|
|
bytecodes: [
|
|
/* 44 E> */ B(StackCheck),
|
|
B(LdaCurrentContextSlot), U8(3),
|
|
B(Star), R(1),
|
|
B(Mov), R(this), R(0),
|
|
B(Mov), R(context), R(2),
|
|
B(CallRuntime), U16(Runtime::kAddPrivateBrand), R(0), U8(3),
|
|
/* 49 S> */ B(Wide), B(LdaSmi), I16(262),
|
|
B(Star), R(3),
|
|
B(LdaConstant), U8(0),
|
|
B(Star), R(4),
|
|
/* 57 E> */ B(CallRuntime), U16(Runtime::kNewTypeError), R(3), U8(2),
|
|
B(Throw),
|
|
]
|
|
constant pool: [
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["#b"],
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
class C {
|
|
#c() { return 1; }
|
|
constructor() { this.#c++; }
|
|
}
|
|
|
|
var test = C;
|
|
new test;
|
|
"
|
|
frame size: 5
|
|
parameter count: 1
|
|
bytecode array length: 32
|
|
bytecodes: [
|
|
/* 44 E> */ B(StackCheck),
|
|
B(LdaCurrentContextSlot), U8(3),
|
|
B(Star), R(1),
|
|
B(Mov), R(this), R(0),
|
|
B(Mov), R(context), R(2),
|
|
B(CallRuntime), U16(Runtime::kAddPrivateBrand), R(0), U8(3),
|
|
/* 49 S> */ B(Wide), B(LdaSmi), I16(262),
|
|
B(Star), R(3),
|
|
B(LdaConstant), U8(0),
|
|
B(Star), R(4),
|
|
B(CallRuntime), U16(Runtime::kNewTypeError), R(3), U8(2),
|
|
B(Throw),
|
|
]
|
|
constant pool: [
|
|
ONE_BYTE_INTERNALIZED_STRING_TYPE ["#c"],
|
|
]
|
|
handlers: [
|
|
]
|
|
|
|
---
|
|
snippet: "
|
|
class D {
|
|
#d() { return 1; }
|
|
constructor() { (() => this)().#d(); }
|
|
}
|
|
|
|
var test = D;
|
|
new test;
|
|
"
|
|
frame size: 6
|
|
parameter count: 1
|
|
bytecode array length: 58
|
|
bytecodes: [
|
|
/* 44 E> */ B(StackCheck),
|
|
B(CreateFunctionContext), U8(0), U8(1),
|
|
B(PushContext), R(0),
|
|
B(Ldar), R(this),
|
|
B(StaCurrentContextSlot), U8(2),
|
|
B(LdaContextSlot), R(0), U8(3), U8(0),
|
|
B(Star), R(2),
|
|
B(Mov), R(this), R(1),
|
|
B(Mov), R(0), R(3),
|
|
B(CallRuntime), U16(Runtime::kAddPrivateBrand), R(1), U8(3),
|
|
/* 49 S> */ B(CreateClosure), U8(1), U8(0), U8(2),
|
|
B(Star), R(5),
|
|
/* 61 E> */ B(CallUndefinedReceiver0), R(5), U8(0),
|
|
B(Star), R(5),
|
|
B(LdaContextSlot), R(0), U8(3), U8(0),
|
|
/* 63 E> */ B(LdaKeyedProperty), R(5), U8(2),
|
|
B(LdaContextSlot), R(0), U8(2), U8(0),
|
|
B(Star), R(4),
|
|
/* 66 E> */ B(CallAnyReceiver), R(4), R(5), U8(1), U8(4),
|
|
B(LdaUndefined),
|
|
/* 70 S> */ B(Return),
|
|
]
|
|
constant pool: [
|
|
SCOPE_INFO_TYPE,
|
|
SHARED_FUNCTION_INFO_TYPE,
|
|
]
|
|
handlers: [
|
|
]
|
|
|