From d9d1613a07f10c4912a91eb405c43c6de50938bc Mon Sep 17 00:00:00 2001 From: Sergio Oller Date: Tue, 25 Apr 2023 15:59:19 +0200 Subject: [PATCH] Show line numbers in progress bar when options(knitr.progress.linenums = TRUE) --- NEWS.md | 2 +- R/output.R | 24 ++++++++++++++---------- 2 files changed, 15 insertions(+), 11 deletions(-) diff --git a/NEWS.md b/NEWS.md index 7a62963de8..a7f1add2bb 100644 --- a/NEWS.md +++ b/NEWS.md @@ -26,7 +26,7 @@ - `imgur_upload()` requires fewer package dependencies now. It only requires the **curl** package; **httr** is no longer required, and **xml2** has become optional. -- Progress bar includes the chunk location (`chunk-name @ file:line`) (@zeehio, #2232) +- Progress bar includes the chunk location (`chunk-name @ file:line`) when `options(knitr.progress.linenums = TRUE)` is set. (@zeehio, #2232) # CHANGES IN knitr VERSION 1.42 diff --git a/R/output.R b/R/output.R index d833b5449b..d361b6a1d2 100644 --- a/R/output.R +++ b/R/output.R @@ -291,16 +291,20 @@ process_file = function(text, output) { labels = unlist(lapply(groups, function(g) { if (is.list(g$params)) g[[c('params', 'label')]] else '' })) - linenums <- unlist(lapply(seq_along(groups), function(i) { - curr_lines <- current_lines(i) - sprintf( - "%s:%d-%d", - knit_concord$get('infile'), - curr_lines[1], - curr_lines[2] - ) - })) - labels_linenums <- paste(labels, linenums, sep = " @ ") + if (getOption("knitr.progress.linenums", default = FALSE)) { + linenums <- unlist(lapply(seq_along(groups), function(i) { + curr_lines <- current_lines(i) + sprintf( + "%s:%d-%d", + knit_concord$get('infile'), + curr_lines[1], + curr_lines[2] + ) + })) + labels_linenums <- paste(labels, linenums, sep = " @ ") + } else { + labels_linenums <- labels + } if (progress) { pb_fun = getOption('knitr.progress.fun', txt_pb) pb = if (is.function(pb_fun)) pb_fun(n, labels_linenums)