Open nightroman opened 1 year ago
Unfortunately that's currently just how it works until we finish https://github.com/PowerShell/vscode-powershell/pull/4065. So consider this in progress!
@andschwa Noted, thank you. Looking forward to the progress and improvements.
FWIW, I believe (strongly) it used to work fine, breakpoints were not removed. That was my usual workflow - set breakpoints in the app, then start VSCode debugging. Granted, it was some time ago. Maybe newer versions are "not supposed to work" due to their new tech issues.
Hard to say if/when the behavior changed. As far as I remember the debugger has always issued a "clear breakpoints" command on startup, but it's a project with a looong history.
Some sort of proof, my user manual -- https://github.com/nightroman/FarNet/tree/main/PowerShellFar#debugging
Select this debugger as active and start (F5). In the shown list of processes hosting PowerShell select Far Manager. Assuming you have set some breakpoints (in Far Manager, not VSCode), run your PowerShellFar code. If breakpoints are hit then VSCode debugger opens the source code at the active breakpoint.
Updated the manual and gave the users some hope :)
With the latest VSCode and PowerShell breakpoints set in Far Manager are removed when VSCode debugger attaches. If you experience this issue, set breakpoints in VSCode instead. Hopefully, this issue will be fixed, #4489.
Yes I think at one point it "worked" in that it just didn't try to manage breakpoints in the remote session at all. Or at most just repeatedly set the same breakpoints every time you attached. I know it's not the best for your scenario but the old behavior leads to some pretty wonky UX if you are trying to set breakpoints in the UI.
As Andy said though, #4065 should make the behavior more consistent (and I'll be returning to it shortly). I don't think I touch existing breakpoints in remote sessions.
FWIW, PowerShellFar (Far Manager PS host) takes care of breakpoint updates via events, i.e. breakpoints set by a user in UI, or by commands, or, as I can see, even set in VSCode after attaching the debugger.
Then once that PR is in, breakpoints should automatically sync in both UI's regardless of where they're added 🤞
Anyway, it's good to know that issue is known and addressed, one way or another. I'll adjust.
Hello, with the recent development on fixing the debugger (https://github.com/PowerShell/vscode-powershell/releases/tag/v2024.3.0-preview), is there any chance this issue gets some progress?
That work is happening with https://github.com/PowerShell/vscode-powershell/pull/4065 which is still in progress.
@andyleejordan It looks a little stagnated though, for a not involved observer. But I hope that "in progress" is the true status and I look forward for the fix. This is needed for some known practical scenarios, when BPs are set in a custom IDE before starting VSCode debugging.
FWIW, not complaining about anything, but please take a look at the manual for my users on using VSCode PowerShell debugger. You might and should be interested in the section "Known issues" (4). It's a lot of pain to make it working, apart from configuring, and IMHO many users will never enjoy VSCode PowerShell debugging by attaching (which actually works at this point, wow!).
https://github.com/nightroman/FarNet/wiki/PowerShellFar-debugging
@nightroman it's a very tricky PR and @SeeminglyScience who owns it has been on leave for a bit. It is moving forward however.
{
"type": "PowerShell",
"request": "attach",
"name": "PowerShell attach",
"processId": "${command:PickPSHostProcess}",
"runspaceId": 1
},
{ "type": "PowerShell", "request": "attach", "name": "PowerShell attach", "processId": "${command:PickPSHostProcess}", "runspaceId": 1 },
Prerequisites
Summary
I use VSCode PowerShell debugger by attaching to a process hosting PowerShell. Attaching removes breakpoints that I have already set in my session.
PowerShell Version
Visual Studio Code Version
Extension Version
Steps to Reproduce
(1) Invoke the below script
test1.ps1
in some PowerShell session. E.g. I used and saw the problem in powershell and pwsh consoles and in my application hosting PowerShell as well.(2) Run
Get-PSBreakpoint
-- see 2 breakpoints(3) In VSCode, launch/attach PowerShell debugger configured as below. Select the target process where we have set 2 breakpoints.
(4) With the debugger attached, run
Get-PSBreakpoint
again -- see that breakpoints are gone.Visuals
No response
Logs
No response