Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Multiple consoles: support for running scripts in separate process #3173

Open
jthomasmock opened this issue May 17, 2024 · 8 comments
Open
Labels
area: api Issues related to API category. area: core Issues related to Core category. enhancement New feature or request
Milestone

Comments

@jthomasmock
Copy link
Contributor

We have integrated testing and build processes into alternate panes or background processes as mentioned in #1303

However, we don't fully support running arbitrary user code in separate processes but the same runtime, i.e., Background Jobs from RStudio. Given that we only have one console, it feels a bit awkward to need to drop into the terminal and lose all of the default behavior to execute long-running scripts in the background.

These may not be as necessary given Python apps/APIs are typically run via the terminal and the Shiny extension runs R/Python via the terminal but it does feel like a gap compared to RStudio.

I also saw this recently of a VS Code R user asking for the jobs R package to work with VS Code: https://twitter.com/strengejacke/status/1791224380602622355

@jthomasmock jthomasmock added the enhancement New feature or request label May 17, 2024
@jmcphers
Copy link
Collaborator

RStudio's Background Jobs have been pretty popular but I think for Positron we could do better. The distinction between the foreground/background session feature in RStudio is a sort of artifact of the fact that RStudio can only have one foreground R session. Positron is designed to have several. So in my view we could build this out as more of a multi-session feature, wherein you can shelve sessions to the background while they are computing and then re-attach them to your UI when they're done.

Which is not to say that we can't support background jobs, just that the API would look more like "start a new session and don't make it the foreground" than anything else.

@juliasilge juliasilge added area: api Issues related to API category. area: core Issues related to Core category. labels May 17, 2024
@jthomasmock
Copy link
Contributor Author

jthomasmock commented May 17, 2024

Totally agree Jonathan! I just didn't want to lose on what was part of the initial ask in #1303 of multiple interactive sessions or background processes, likely with all the benefits of Positron's integrations rather than just a fairly "barebone" terminal.

@juliasilge juliasilge added this to the Future milestone May 28, 2024
@juliasilge
Copy link
Contributor

Request for multiple consoles from a private beta user: https://github.com/posit-dev/positron-beta/discussions/224

@rmflight
Copy link

rmflight commented Jul 1, 2024

Given that multiple consoles / terminals is one of the "killer features" of VSCode, this feels like a "must have" eventually. Glad to see it's on the radar, whether it's for having "background jobs" or just "multiple consoles".

@abduazizR
Copy link

Not sure if I can comment here, but just want to confirm that these features are not yet implemented but they're in the developers' plans, right?

@juliasilge
Copy link
Contributor

Yes, that's right @abduazizR! This feature is not slated for immediate work but it is helpful to know how important it is for our users so adding a 👍 or similar is most welcome.

@juliasilge
Copy link
Contributor

Request for multiple consoles in discussions here: #4657 (reply in thread)

@Aariq
Copy link

Aariq commented Jan 24, 2025

Just wanted to chime in and say that I'd love for targets::tar_make(as_job=TRUE) to "just work" in Positron. So having some kind of ability to run code in a separate session would be great!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area: api Issues related to API category. area: core Issues related to Core category. enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

6 participants