pd_is {styler} | R Documentation |
What is a parse table representing?
Description
Check whether a parse table corresponds to a certain expression.
Usage
is_curly_expr(pd)
is_for_expr(pd)
is_conditional_expr(pd)
is_while_expr(pd)
is_function_call(pd)
is_function_declaration(pd)
is_comment(pd)
is_tilde_expr(pd, tilde_pos = c(1L, 2L))
is_asymmetric_tilde_expr(pd)
is_symmetric_tilde_expr(pd)
Arguments
pd |
A parse table. |
tilde_pos |
Integer vector indicating row-indices that should be checked for tilde. See 'Details'. |
Details
A tilde is on the top row in the parse table if it is an asymmetric tilde
expression (like ~column
), in the second row if it is a symmetric tilde
expression (like a~b
).
Functions
-
is_curly_expr()
: Checks whetherpd
contains an expression wrapped in curly brackets. -
is_for_expr()
: Checks whetherpd
contains afor
loop. -
is_conditional_expr()
: Checks whetherpd
contains is a conditional expression. -
is_while_expr()
: Checks whetherpd
contains awhile
loop. -
is_function_call()
: Checks whetherpd
is a function call. -
is_function_declaration()
: Checks whetherpd
is a function declaration. -
is_comment()
: Checks for every token whether or not it is a comment. -
is_tilde_expr()
: Checks whetherpd
contains a tilde. -
is_asymmetric_tilde_expr()
: Ifpd
contains a tilde, checks whether it is asymmetrical. -
is_symmetric_tilde_expr()
: Ifpd
contains a tilde, checks whether it is symmetrical.
See Also
Other third-party style guide helpers:
next_non_comment()
,
scope_normalize()
Examples
code <- "if (TRUE) { 1 }"
pd <- compute_parse_data_nested(code)
is_curly_expr(pd)
child_of_child <- pd$child[[1]]$child[[5]]
is_curly_expr(child_of_child)
code <- "for (i in 1:5) print(1:i)"
pd <- compute_parse_data_nested(code)
is_for_expr(pd)
is_for_expr(pd$child[[1]])
code <- "if (TRUE) x <- 1 else x <- 0"
pd <- compute_parse_data_nested(code)
is_conditional_expr(pd)
is_conditional_expr(pd$child[[1]])
code <- "x <- list(1:3)"
pd <- compute_parse_data_nested(code)
is_function_call(pd)
child_of_child <- pd$child[[1]]$child[[3]]
is_function_call(child_of_child)
code <- "foo <- function() NULL"
pd <- compute_parse_data_nested(code)
is_function_declaration(pd)
child_of_child <- pd$child[[1]]$child[[3]]
is_function_declaration(child_of_child)
code <- "x <- 1 # TODO: check value"
pd <- compute_parse_data_nested(code)
is_comment(pd)
code <- "lm(wt ~ mpg, mtcars)"
pd <- compute_parse_data_nested(code)
is_tilde_expr(pd$child[[1]]$child[[3]])
is_symmetric_tilde_expr(pd$child[[1]]$child[[3]])
is_asymmetric_tilde_expr(pd$child[[1]]$child[[3]])