* 在超时或结束后移除单个 waiter,避免残留无效回调。
(waiterKey: string, target: () => void)
| 296 | * 在超时或结束后移除单个 waiter,避免残留无效回调。 |
| 297 | */ |
| 298 | private removeWaiter(waiterKey: string, target: () => void): void { |
| 299 | const waiters = this.waiters.get(waiterKey) |
| 300 | if (!waiters?.length) return |
| 301 | |
| 302 | const nextWaiters = waiters.filter((waiter) => waiter !== target) |
| 303 | if (nextWaiters.length > 0) { |
| 304 | this.waiters.set(waiterKey, nextWaiters) |
| 305 | } else { |
| 306 | this.waiters.delete(waiterKey) |
| 307 | } |
| 308 | } |
| 309 | |
| 310 | /** |
| 311 | * 为单个 WebContents + toolName 生成稳定的 waiter 键。 |
no test coverage detected