From b65f0ceab705b5833349c34fb514b2729e3a062a Mon Sep 17 00:00:00 2001 From: Chris Baker Date: Mon, 17 Sep 2018 17:22:40 -0400 Subject: [PATCH 1/3] use different version of file.edit depending on context (closes #204) --- R/reprex.R | 2 +- R/utils.R | 8 ++++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/R/reprex.R b/R/reprex.R index 7a24a11a..2df525d3 100644 --- a/R/reprex.R +++ b/R/reprex.R @@ -374,7 +374,7 @@ reprex <- function(x = NULL, " * ", reprex_file ) if (yep("Open the output file for manual copy?")) { - withr::defer(utils::file.edit(reprex_file)) + withr::defer(file_edit(reprex_file)) } } diff --git a/R/utils.R b/R/utils.R index ee580b8b..e6ea27a0 100644 --- a/R/utils.R +++ b/R/utils.R @@ -97,3 +97,11 @@ collapse <- function(x, sep = "\n") { backtick <- function(x) encodeString(x, quote = "`") newline <- function(x) paste0(x, "\n") + +file_edit <- function(...) { + if (exists("file.edit", envir = globalenv())) { + get("file.edit", envir = globalenv())(...) + } else { + utils::file.edit(...) + } +} From 5c79f2fa7826a8140680809d2281c1988883871b Mon Sep 17 00:00:00 2001 From: Chris Baker Date: Mon, 17 Sep 2018 17:49:28 -0400 Subject: [PATCH 2/3] have undo functions always open up a file containing the clean r code --- R/reprex-undo.R | 26 ++++++++++++++------------ man/reprex.Rd | 9 ++++----- man/un-reprex.Rd | 13 +++++++------ 3 files changed, 25 insertions(+), 23 deletions(-) diff --git a/R/reprex-undo.R b/R/reprex-undo.R index fea9c295..21400e51 100644 --- a/R/reprex-undo.R +++ b/R/reprex-undo.R @@ -10,8 +10,9 @@ #' interpreted as the path to a file containing reprex code. Otherwise, #' assumed to hold reprex code as character vector. If not provided, the #' clipboard is consulted for input. -#' @param outfile Optional basename for output file. When `NULL`, no file is -#' left behind. If `outfile = "foo"`, expect an output file in current working +#' @param outfile Optional basename for output file. When `NULL` +#' (default), reprex writes to temp files below the session temp directory. +#' If `outfile = "foo"`, expect an output file in current working #' directory named `foo_clean.R`. If `outfile = NA`, expect on output file in #' a location and with basename derived from `input`, if a path, or in #' current working directory with basename derived from [tempfile()] @@ -157,14 +158,11 @@ reprex_undo <- function(input = NULL, ) comment <- arg_option(comment) - outfile_given <- !is.null(outfile) infile <- if (where == "path") input else NULL - if (outfile_given) { - files <- make_filenames(make_filebase(outfile, infile), suffix = "clean") - r_file <- files[["r_file"]] - if (would_clobber(r_file)) { - return(invisible()) - } + files <- make_filenames(make_filebase(outfile, infile), suffix = "clean") + r_file <- files[["r_file"]] + if (would_clobber(r_file)) { + return(invisible()) } if (is_md) { ## reprex_invert @@ -184,10 +182,14 @@ reprex_undo <- function(input = NULL, clipr::write_clip(x_out) message("Clean code is on the clipboard.") } - if (outfile_given) { - writeLines(x_out, r_file) - message("Writing clean code as R script:\n * ", r_file) + + writeLines(x_out, r_file) + message("Writing clean code as R script:\n * ", r_file) + + if (interactive()) { + withr::defer(file_edit(r_file)) } + invisible(x_out) } diff --git a/man/reprex.Rd b/man/reprex.Rd index 1ce1e86f..9a74c463 100644 --- a/man/reprex.Rd +++ b/man/reprex.Rd @@ -4,11 +4,10 @@ \alias{reprex} \title{Render a reprex} \usage{ -reprex(x = NULL, input = NULL, outfile = NULL, venue = c("gh", - "so", "ds", "r", "rtf"), render = TRUE, advertise = NULL, - si = opt(FALSE), style = opt(FALSE), show = opt(TRUE), - comment = opt("#>"), tidyverse_quiet = opt(TRUE), - std_out_err = opt(FALSE)) +reprex(x = NULL, input = NULL, outfile = NULL, venue = c("gh", "so", + "ds", "r", "rtf"), render = TRUE, advertise = NULL, si = opt(FALSE), + style = opt(FALSE), show = opt(TRUE), comment = opt("#>"), + tidyverse_quiet = opt(TRUE), std_out_err = opt(FALSE)) } \arguments{ \item{x}{An expression. If not given, \code{reprex()} looks for code in diff --git a/man/un-reprex.Rd b/man/un-reprex.Rd index 432f6e45..87cae808 100644 --- a/man/un-reprex.Rd +++ b/man/un-reprex.Rd @@ -7,13 +7,13 @@ \alias{reprex_rescue} \title{Un-render a reprex} \usage{ -reprex_invert(input = NULL, outfile = NULL, venue = c("gh", "so", - "ds", "r"), comment = opt("#>")) +reprex_invert(input = NULL, outfile = NULL, venue = c("gh", "so", "ds", + "r"), comment = opt("#>")) reprex_clean(input = NULL, outfile = NULL, comment = opt("#>")) -reprex_rescue(input = NULL, outfile = NULL, - prompt = getOption("prompt"), continue = getOption("continue")) +reprex_rescue(input = NULL, outfile = NULL, prompt = getOption("prompt"), + continue = getOption("continue")) } \arguments{ \item{input}{Character. If has length one and lacks a terminating newline, @@ -21,8 +21,9 @@ interpreted as the path to a file containing reprex code. Otherwise, assumed to hold reprex code as character vector. If not provided, the clipboard is consulted for input.} -\item{outfile}{Optional basename for output file. When \code{NULL}, no file is -left behind. If \code{outfile = "foo"}, expect an output file in current working +\item{outfile}{Optional basename for output file. When \code{NULL} +(default), reprex writes to temp files below the session temp directory. +If \code{outfile = "foo"}, expect an output file in current working directory named \code{foo_clean.R}. If \code{outfile = NA}, expect on output file in a location and with basename derived from \code{input}, if a path, or in current working directory with basename derived from \code{\link[=tempfile]{tempfile()}} From e20ecba32d2823f1520036bb62187ede634fe60a Mon Sep 17 00:00:00 2001 From: Chris Baker Date: Mon, 17 Sep 2018 17:50:11 -0400 Subject: [PATCH 3/3] tell r where to find fs functions so that tests pass locally --- R/filepaths.R | 10 +++++----- tests/testthat/helper.R | 2 +- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/R/filepaths.R b/R/filepaths.R index 342b1bce..ebb51f38 100644 --- a/R/filepaths.R +++ b/R/filepaths.R @@ -2,7 +2,7 @@ make_filebase <- function(outfile = NULL, infile = NULL) { if (is.null(outfile)) { ## work inside a new directory, within session temp directory - target_dir <- path_real(dir_create(file_temp("reprex"))) + target_dir <- fs::path_real(fs::dir_create(fs::file_temp("reprex"))) ## example: /private/var/.../.../.../reprex97d77de2835c/reprex return(path(target_dir, "reprex")) } @@ -14,7 +14,7 @@ make_filebase <- function(outfile = NULL, infile = NULL) { if (is.null(infile)) { ## outfile = NA, infile = NULL --> reprex in working directory ## example: reprexbfa165580676 - path_file(file_temp("reprex")) + fs::path_file(fs::file_temp("reprex")) } else { ## outfile = NA, infile = "sthg" --> follow infile's lead ## example: basename_of_infile @@ -44,14 +44,14 @@ force_tempdir <- function(path) { if (is_in_tempdir(path)) { path } else { - file_copy(path, path_temp(path_file(path)), overwrite = TRUE) + fs::file_copy(path, fs::path_temp(fs::path_file(path)), overwrite = TRUE) } } is_in_tempdir <- function(path) { identical( - path_real(path_temp()), - path_common(path_real(c(path, path_temp()))) + fs::path_real(fs::path_temp()), + fs::path_common(fs::path_real(c(path, fs::path_temp()))) ) } diff --git a/tests/testthat/helper.R b/tests/testthat/helper.R index 374634d8..27495587 100644 --- a/tests/testthat/helper.R +++ b/tests/testthat/helper.R @@ -21,7 +21,7 @@ expect_error_free <- function(...) { ## set wd to session temp dir, execute testing code, restore previous wd temporarily <- function(env = parent.frame()) { - withr::local_dir(path_temp(), .local_envir = env) + withr::local_dir(fs::path_temp(), .local_envir = env) } ## call during interactive test development to fake being "in tests" and thereby