In this vignette we showcase the arguments of flow_view() and flow_run() that affect the way the diagrams are displayed.
prefixprefix is used to display special comments on top of code blocks, it must start with "#".
library(flow)
factorial <- function(x) {
## is the input valid ?
if(!is.integer(x) && length(x) == 1) {
## fail explicitly
stop("`x` must be integer!")
}
## initialize result
res <- 1
for(i in 2:x) {
## update result
res <- res * i
## is the result to big ?
if(res > 1000) {
## fail explicitly
stop("too big!!!")
}
}
res
}
flow_view(factorial, prefix = "##")prefix can be of length > 1 in which case all given prefixes are consideredif) will serve as headers for control flow header blocks.{} after if (n == 0L) if we want to use a prefixed commentThis argument is ignored when using the plantuml engine.
codecode is used to choose whether to display the code in code blocks or only the header, if NA the code will be displayed only if no header is defined by special comments.
flow_view(factorial, code = FALSE)This argument is ignored when using the plantuml engine.
narrownarrow is used to narrow makes sure the diagram stays centered on one column, it will be longer but won’t shift, which might be easier to display on web pages for instance.
kg_to_lb <- function(mass) {
if(mass < 0) {
stop("mass should not be negative!")
} else {
mass <- 2.20462262185 * mass
}
mass
}
flow_view(kg_to_lb)This argument is ignored when using the plantuml engine.
truncatetruncate is used to provide the maximum number of characters to be printed per line, it works for code and headers.
fun <- function() {
## short header
x <- "__________________________long string__________________________"
## __________________________long header__________________________
x
}
flow_view(fun, prefix = "##")swapBy default calls like x <- if(cond) a else b are automatically transformed into if(cond) x <- a else x <- b so we can display the logic in a proper diagram.
If this is not acceptable this can be turned off by setting swap to FALSE.
fun <- function(cond) {
x <- if(cond) this else that
x
}
flow_view(fun)