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

Provide options to specify working directory for Quarto, .Rmd, notebooks #4692

Closed
juliasilge opened this issue Sep 16, 2024 Discussed in #4688 · 3 comments
Closed

Provide options to specify working directory for Quarto, .Rmd, notebooks #4692

juliasilge opened this issue Sep 16, 2024 Discussed in #4688 · 3 comments
Labels
area: core Issues related to Core category. area: quarto Issues related to Quarto category. enhancement New feature or request support

Comments

@juliasilge
Copy link
Contributor

juliasilge commented Sep 16, 2024

Folks coming from RStudio are used to having options for what their .Rmd and .qmd files use as the working directory:

Discussed in #4688

Originally posted by AndrewSkelton September 15, 2024

Hi,

Typical behavior in RStudio was that when an Rmd file was open, paths in the notebook were relative to where the file was located, this doesn't seem to be the same in Positron. Is there a setting to enable that?

Thanks,

Andrew

In #2648 we changed the working directory for .ipynb files to default to the location of the notebook file, and this is like an analogous request for our other notebook-ish files.

RStudio offers this as an option:

Screenshot 2024-09-16 at 11 25 29 AM

I will say that personally I find this behavior for notebooks and notebook-adjacent things pretty confusing (it has surprised me more times than I would like to admit!) and I like that RStudio lets me opt out from this automatic mucking about with my working directory.

@juliasilge juliasilge added area: core Issues related to Core category. area: quarto Issues related to Quarto category. enhancement New feature or request support labels Sep 16, 2024
@jmcphers
Copy link
Collaborator

There's also an issue requesting that we do this for Python scripts. #3156

@juliasilge juliasilge added this to the 2024.12.0 Pre-Release milestone Sep 16, 2024
@juliasilge
Copy link
Contributor Author

juliasilge commented Nov 20, 2024

I was just experimenting in RStudio and is it right that the working directory only changes if you render the whole document? Not when executing code interactively? Because that would be much easier to offer as an option, especially only for .Rmd and not for Quarto.

EDIT: Quarto already does evaluate in the directory of your .qmd if you use the button or command palette to render/preview! And our r.rmarkdownRender command also evaluates in the directory of your .qmd (not your current console working directory)!

Is there anything still to do here? AFAICT RStudio does not try to change up the working directory in the console if the code you are executing came from an .Rmd file in a different directory. (And honestly to me that sounds bananas to try to manage or understand as a user.)

@juliasilge
Copy link
Contributor Author

OK, I am going to sum up the current situation:

  • The defaults right now are similar to RStudio's behavior; we use the file's directory as the working directory when rendering, and there are no changes to the console's working directory for code coming from .Rmd or .qmd. All of this can be set/changed by the user, using here::here() or the knit_root_dir argument to rmarkdown::render() or by explicitly changing the working directory.
  • Positron does not have inline output, which is I bet what the original discussion was getting at. Setting the working directory in inline output makes sense, but it doesn't really for send-to-console execution.
  • We could address this use case in the future with a treatment similar to what we land on for Python cells are evaluated in the project or current working directory #3156, for example providing a way to spawn a new, quasi-notebook-like console session for .Rmd and .qmd files.

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Dec 5, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
area: core Issues related to Core category. area: quarto Issues related to Quarto category. enhancement New feature or request support
Projects
None yet
Development

No branches or pull requests

2 participants