How to get rid of "Terminal will be reused by tasks, press any key to close it." behaviour?
Asked Answered
E

6

69

Upon executing a task (cargo build in this case), the following appears in the VSCode terminal:

> Executing task: cargo build <

(output of the task here)

Terminal will be reused by tasks, press any key to close it.

Annoyingly, this takes me out of the normal terminal and then I have to acquire focus of the terminal window and press a key to get back. And when I do so, the output of cargo build disappears.

How do I stop this behaviour?

How do I get rid of the first and last lines of text?

Extended answered 22/12, 2017 at 20:11 Comment(3)
I am also wondering how to get rid of it. I am using "dependsOn"-feature. At the moment i need to go to console to multiple times click any key.Susian
Same problem. I didn't have problems with it earlier. Is it a version or system dependent problem?Manoeuvre
I would like to automatically close the old terminal when I execute a new task. I have students reading old error messages because they assume all the terminal content is freshly created after a task.Iconostasis
D
67

Check if the new feature from VSCode 1.57 (May 2021, 2.5 years after the OP) could help:

Automatically close task terminals

The task presentation property has a new close property.
Setting close to true will cause the terminal to close when the task exits.

{
  "type": "shell",
  "command": "node build/lib/preLaunch.js",
  "label": "Ensure Prelaunch Dependencies",
  "presentation": {
      "reveal": "silent",
      "revealProblems": "onProblem",
      "close": true
  }
}

[EDIT: 18-08-2018] Making it switch into the Problems tab is better when using the close option as that ensures the task terminal is closed, but the problems are properly highlighted. This is from VSCode 1.59.0.


Danin adds in the comments:

After fiddling around, I found an easy way to do it in-app;
Terminal > Configure Tasks > (select your desired task) > add "presentation": { .. } block to level containing matching "task:" entry.

Danin also mentions:

I also omitted the "reveal" entry because I prefer to see the terminal briefly -- it just interferes with workflows to have it stick around.

Defect answered 7/6, 2021 at 13:3 Comment(6)
This should now be the accepted solution based on the evolution of VS Code and its ability to close automatically a terminal after the execution of a command.Cotquean
The "presentation" key is to be added into the file tasks.json as a key to "task" dictionary in the file.Isthmian
This worked for me, thank you. When it has issues, they go into the Problems tabUmbrageous
This is fantastic, but as a user with little experience "correcting" VSCode, it leaves me with no actual answer. Even with the source link, I don't have the context to decypher which part instructs one on where to put this block of information. Can we please clarify with a filename/path?Raceme
After fiddling around, I found an easy way to do it in-app; Terminal > Configure Tasks > (select your desired task) > add "presentation": { .. } block to level containing matching "task:" entry.Raceme
@Defect - Thanks!For what it's worth I also omitted the "reveal" entry because I prefer to see the terminal briefly -- it just interferes with workflows to have it stick around. Not sure if this is worthy of main-thread mention since it's a bit offtopic but I found it helpful.Raceme
B
27

To be clear, executing a task will always create a new integrated terminal in VS Code. There is no way around that. The most important thing is for the original terminal to be displayed instead of the newly created integrated terminal. (We want the original terminal revealed.)

@Gregory Cosmo Haun's solution will suppress the message "Terminal will be reused by tasks, press any key to close it". However, it still reveals the new integrated terminal instead of the normal terminal. (so you still have to press "any key" to close that terminal and reveal the original terminal)

A better solution would be to set "reveal": "silent", which will still create a new integrated terminal, but not reveal it unless there is an error while executing your task. I also set "clear": true (which is optional) so that the terminal is cleared before executing the task. I deliberately omit "showReuseMessage": false (which is optional) but you can add it. Who cares if the prompt is suppressed or not? The most important thing is that the newly created terminal is not revealed so I don't have to "press any key" to close it.

"presentation": {
  "reveal": "silent",
  "clear": true
}

BTW, you can also set "reveal": "never", but you would normally want to see the error message if there is a problem with executing your task.

In my opinion, this is the best possible solution. Yes, a new integrated terminal will always be created when executing a task, but at least it won't be revealed (unless there is an error) and you can safely ignore it without having to press any key to close it.

Bake answered 5/8, 2019 at 8:50 Comment(2)
where should I put these configurations?Exercise
@Exercise - the task.json file in the .vscode folder. see code.visualstudio.com/docs/editor/tasksBake
V
8

There is a new presentation option called showReuseMessage. Add the following to your task definition.

"presentation": {
     "showReuseMessage": false
}
Vail answered 30/10, 2018 at 18:43 Comment(4)
This worked perfectly for me in VSCode-win32-x64-1.34.0Lxx
This literally only hides the message "Press any key to close the terminal.". You still need to press any key to see your terminal.Theophylline
I agree with @rustyx. This might suppress the message, but a new integrated terminal is revealed instead of the original terminal. A slightly improved solution would be to also set "reveal": "silent". This way, you don't have to press any key. Please see my answer.Bake
Very nice explanationPhlegethon
L
3

After upgrading to VSCode 1.69.0 I started seeing this. I found the simplest change is to add this to my tasks.json file:

    "presentation": {
        "showReuseMessage": false
    },

It's described here as:

  /**
   * Controls whether to show the `Terminal will be reused by tasks,
   * press any key to close it` message.
   */
  showReuseMessage?: boolean;
Lunisolar answered 9/7, 2022 at 2:47 Comment(0)
M
2

One possibility is to add the following command to the "tasks":

"presentation": {
            "panel": "new"
        },

as

"tasks": [
    {
        "label": "python",
        "type": "shell",
        "command": "python",
        "presentation": {
            "panel": "new"
        }
    }
]

This does not fully solve the problem but at least does not pile all the results one after the other in the panel.

Inspired by https://github.com/Microsoft/vscode/issues/35642

Manoeuvre answered 15/2, 2018 at 8:8 Comment(4)
still prompts: Press any key to close the terminal.Lithea
@GangYin - you still need to set "showReuseMessage": false to suppress the message.Bake
I don't think "panel": "new" is a good idea. This would add a new integrated terminal every time you launch the task. I think the default "panel": "shared" is perfectly fine and you should instead set "showReuseMessage": false and "reveal": "silent"Bake
This helps for github.com/jeremiah-c-leary/vhdl-style-guide integration into visual studio. Without it the second time you run it won't highlight results.Sedillo
T
2

An alternative solution is to set the output window to auto-focus.

Add this to the task definition:

    "presentation": {
        "focus": true
    }

Then it's not that annoying anymore because you can dismiss the compiler output with a single key press.

The benefit of this is that the task output is visible, so you can see if there were any errors or warnings.

Theophylline answered 13/7, 2019 at 10:0 Comment(3)
but this would mean you still have to "press any key" to close the integrated terminal that opens from launching a task. I would much prefer to silently ignore the prompt, which can be done by setting "reveal": "silent" and "showReuseMessage": falseBake
Yes, that's a solution for when one don't want to see the task output.Theophylline
I think that is the next best thing (to hide the task output), since its not possible to prevent the task output from being displayed.Bake

© 2022 - 2024 — McMap. All rights reserved.