Skip to content

Commit

Permalink
Restore previously opened device (#245)
Browse files Browse the repository at this point in the history
Fixes #138
  • Loading branch information
hadley committed Jan 10, 2024
1 parent ab158d7 commit ceb26d9
Show file tree
Hide file tree
Showing 4 changed files with 49 additions and 20 deletions.
3 changes: 3 additions & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
# withr (development version)

* `local_pdf()` and friends now correctly restore to the previously
active device (#138).

* `local_()` now works even if withr isn't attached (#207).

* `defer()` is now a thin wrapper around `base::on.exit()`. This is
Expand Down
49 changes: 29 additions & 20 deletions R/devices.R
Original file line number Diff line number Diff line change
Expand Up @@ -77,40 +77,49 @@ jpeg_dev <- function(filename, ...) {
#' )
NULL

dev_close <- function(which) {
prev <- dev.prev(which)
grDevices::dev.off(which)
if (prev != which) # no devices active
dev.set(prev)

prev
}

#' @describeIn devices BMP device
#' @export
with_bmp <- with_(bmp_dev, grDevices::dev.off)
with_bmp <- with_(bmp_dev, dev_close)

#' @rdname devices
#' @export
local_bmp <- local_(bmp_dev, grDevices::dev.off)
local_bmp <- local_(bmp_dev, dev_close)

#' @describeIn devices CAIRO_PDF device
#' @inheritParams grDevices::cairo_pdf
#' @export
with_cairo_pdf <- with_(cairo_pdf_dev, grDevices::dev.off)
with_cairo_pdf <- with_(cairo_pdf_dev, dev_close)

#' @rdname devices
#' @export
local_cairo_pdf <- local_(cairo_pdf_dev, grDevices::dev.off)
local_cairo_pdf <- local_(cairo_pdf_dev, dev_close)

#' @describeIn devices CAIRO_PS device
#' @inheritParams grDevices::cairo_ps
#' @export
with_cairo_ps <- with_(cairo_ps_dev, grDevices::dev.off)
with_cairo_ps <- with_(cairo_ps_dev, dev_close)

#' @rdname devices
#' @export
local_cairo_ps <- local_(cairo_ps_dev, grDevices::dev.off)
local_cairo_ps <- local_(cairo_ps_dev, dev_close)

#' @describeIn devices PDF device
#' @inheritParams grDevices::pdf
#' @export
with_pdf <- with_(pdf_dev, grDevices::dev.off)
with_pdf <- with_(pdf_dev, dev_close)

#' @rdname devices
#' @export
local_pdf <- local_(pdf_dev, grDevices::dev.off)
local_pdf <- local_(pdf_dev, dev_close)

#' @describeIn devices POSTSCRIPT device
#' @inheritParams grDevices::postscript
Expand All @@ -119,51 +128,51 @@ local_pdf <- local_(pdf_dev, grDevices::dev.off)
#' length limit is \code{2*PATH_MAX}, typically 8096 bytes on unix systems and
#' 520 bytes on windows.
#' @export
with_postscript <- with_(postscript_dev, grDevices::dev.off)
with_postscript <- with_(postscript_dev, dev_close)

#' @rdname devices
#' @export
local_postscript <- local_(postscript_dev, grDevices::dev.off)
local_postscript <- local_(postscript_dev, dev_close)

#' @describeIn devices SVG device
#' @inheritParams grDevices::svg
#' @export
with_svg <- with_(svg_dev, grDevices::dev.off)
with_svg <- with_(svg_dev, dev_close)

#' @rdname devices
#' @export
local_svg <- local_(svg_dev, grDevices::dev.off)
local_svg <- local_(svg_dev, dev_close)

#' @describeIn devices TIFF device
#' @export
with_tiff <- with_(tiff_dev, grDevices::dev.off)
with_tiff <- with_(tiff_dev, dev_close)


#' @rdname devices
#' @export
local_tiff <- local_(tiff_dev, grDevices::dev.off)
local_tiff <- local_(tiff_dev, dev_close)

#' @describeIn devices XFIG device
#' @inheritParams grDevices::xfig
#' @export
with_xfig <- with_(xfig_dev, grDevices::dev.off)
with_xfig <- with_(xfig_dev, dev_close)

#' @rdname devices
#' @export
local_xfig <- local_(xfig_dev, grDevices::dev.off)
local_xfig <- local_(xfig_dev, dev_close)

#' @describeIn devices PNG device
#' @export
with_png <- with_(png_dev, grDevices::dev.off)
with_png <- with_(png_dev, dev_close)

#' @rdname devices
#' @export
local_png <- local_(png_dev, grDevices::dev.off)
local_png <- local_(png_dev, dev_close)

#' @describeIn devices JPEG device
#' @export
with_jpeg <- with_(jpeg_dev, grDevices::dev.off)
with_jpeg <- with_(jpeg_dev, dev_close)

#' @rdname devices
#' @export
local_jpeg <- local_(jpeg_dev, grDevices::dev.off)
local_jpeg <- local_(jpeg_dev, dev_close)
4 changes: 4 additions & 0 deletions tests/testthat/helper.R
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
set_state_inspector(function() {
dir(".")
})

expect_no_output <- function(...) {
testthat::expect_output(..., regexp = NA)
}
Expand Down
13 changes: 13 additions & 0 deletions tests/testthat/test-devices.R
Original file line number Diff line number Diff line change
Expand Up @@ -77,3 +77,16 @@ test_that("local_device functions create a plot file", {

unlink(plot_dir)
})

test_that("multiple devices closed in correct order", {
dev1 <- local_pdf(tempfile())

local({
dev2 <- local_pdf(tempfile())

local(withr::local_pdf(tempfile()))
expect_equal(dev.cur(), dev2)
})

expect_equal(dev.cur(), dev1)
})

0 comments on commit ceb26d9

Please sign in to comment.