In this vignette we showcase the arguments of flow_view()
and flow_run()
that affect the way the diagrams are displayed.
prefix
prefix
is used to display special comments on top of code blocks, it must start with "#"
.
library(flow)
<- function(x) {
factorial ## is the input valid ?
if(!is.integer(x) && length(x) == 1) {
## fail explicitly
stop("`x` must be integer!")
}## initialize result
<- 1
res for(i in 2:x) {
## update result
<- res * i
res ## 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.
code
code
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.
narrow
narrow
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.
<- function(mass) {
kg_to_lb if(mass < 0) {
stop("mass should not be negative!")
else {
} <- 2.20462262185 * mass
mass
}
mass
}
flow_view(kg_to_lb)
This argument is ignored when using the plantuml engine.
truncate
truncate
is used to provide the maximum number of characters to be printed per line, it works for code and headers.
<- function() {
fun ## short header
<- "__________________________long string__________________________"
x ## __________________________long header__________________________
x
}flow_view(fun, prefix = "##")
swap
By 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
.
<- function(cond) {
fun <- if(cond) this else that
x
x
}
flow_view(fun)