|
1 | 1 | // Copyright (c) Microsoft Corporation.
|
2 | 2 | // Licensed under the MIT License.
|
3 | 3 |
|
| 4 | +using System.Management.Automation; |
| 5 | +using System.Management.Automation.Language; |
| 6 | +using System.Threading; |
| 7 | +using System.Threading.Tasks; |
4 | 8 | using Microsoft.Extensions.Logging;
|
5 | 9 | using Microsoft.PowerShell.EditorServices.Services;
|
6 | 10 | using Microsoft.PowerShell.EditorServices.Services.DebugAdapter;
|
|
13 | 17 | using OmniSharp.Extensions.DebugAdapter.Protocol.Events;
|
14 | 18 | using OmniSharp.Extensions.DebugAdapter.Protocol.Requests;
|
15 | 19 | using OmniSharp.Extensions.DebugAdapter.Protocol.Server;
|
16 |
| -using System.Management.Automation; |
17 |
| -using System.Management.Automation.Language; |
18 |
| -using System.Threading; |
19 |
| -using System.Threading.Tasks; |
20 | 20 |
|
21 | 21 | namespace Microsoft.PowerShell.EditorServices.Handlers
|
22 | 22 | {
|
@@ -102,48 +102,14 @@ public Task<ConfigurationDoneResponse> Handle(ConfigurationDoneArguments request
|
102 | 102 |
|
103 | 103 | private async Task LaunchScriptAsync(string scriptToLaunch)
|
104 | 104 | {
|
105 |
| - // Is this an untitled script? |
106 |
| - if (ScriptFile.IsUntitledPath(scriptToLaunch)) |
107 |
| - { |
108 |
| - ScriptFile untitledScript = _workspaceService.GetFile(scriptToLaunch); |
109 |
| - |
110 |
| - if (BreakpointApiUtils.SupportsBreakpointApis(_runspaceContext.CurrentRunspace)) |
111 |
| - { |
112 |
| - // Parse untitled files with their `Untitled:` URI as the file name which will cache the URI & contents within the PowerShell parser. |
113 |
| - // By doing this, we light up the ability to debug Untitled files with breakpoints. |
114 |
| - // This is only possible via the direct usage of the breakpoint APIs in PowerShell because |
115 |
| - // Set-PSBreakpoint validates that paths are actually on the filesystem. |
116 |
| - ScriptBlockAst ast = Parser.ParseInput(untitledScript.Contents, untitledScript.DocumentUri.ToString(), out Token[] tokens, out ParseError[] errors); |
117 |
| - |
118 |
| - // This seems to be the simplest way to invoke a script block (which contains breakpoint information) via the PowerShell API. |
119 |
| - // |
120 |
| - // TODO: Fix this so the added script doesn't show up. |
121 |
| - var cmd = new PSCommand().AddScript(". $args[0]").AddArgument(ast.GetScriptBlock()); |
122 |
| - await _executionService |
123 |
| - .ExecutePSCommandAsync<object>(cmd, CancellationToken.None, s_debuggerExecutionOptions) |
124 |
| - .ConfigureAwait(false); |
125 |
| - } |
126 |
| - else |
127 |
| - { |
128 |
| - await _executionService |
129 |
| - .ExecutePSCommandAsync( |
130 |
| - new PSCommand().AddScript(untitledScript.Contents), |
131 |
| - CancellationToken.None, |
132 |
| - s_debuggerExecutionOptions) |
133 |
| - .ConfigureAwait(false); |
134 |
| - } |
135 |
| - } |
136 |
| - else |
137 |
| - { |
138 |
| - // TODO: Fix this so the added script doesn't show up. |
139 |
| - await _executionService |
140 |
| - .ExecutePSCommandAsync( |
141 |
| - PSCommandHelpers.BuildCommandFromArguments(scriptToLaunch, _debugStateService.Arguments), |
142 |
| - CancellationToken.None, |
143 |
| - s_debuggerExecutionOptions) |
144 |
| - .ConfigureAwait(false); |
145 |
| - } |
146 |
| - |
| 105 | + // TODO: Theoretically we can make PowerShell respect line breakpoints in untitled |
| 106 | + // files, but the previous method was a hack that conflicted with correct passing of |
| 107 | + // arguments to the debugged script. We are prioritizing the latter over the former, as |
| 108 | + // command breakpoints and `Wait-Debugger` work fine. |
| 109 | + PSCommand cmd = ScriptFile.IsUntitledPath(scriptToLaunch) |
| 110 | + ? PSCommandHelpers.BuildCommandFromArguments(string.Concat("{ ", _workspaceService.GetFile(scriptToLaunch).Contents, " }"), _debugStateService.Arguments) |
| 111 | + : PSCommandHelpers.BuildCommandFromArguments(string.Concat('"', scriptToLaunch, '"'), _debugStateService.Arguments); |
| 112 | + await _executionService.ExecutePSCommandAsync(cmd, CancellationToken.None, s_debuggerExecutionOptions).ConfigureAwait(false); |
147 | 113 | _debugAdapterServer.SendNotification(EventNames.Terminated);
|
148 | 114 | }
|
149 | 115 | }
|
|
0 commit comments