Learn R Programming

⚠️There's a newer version (1.1.4) of this package.Take me there.

rlang

rlang is a collection of frameworks and APIs for programming with R.

Frameworks

Two comprehensive frameworks are implemented in rlang.

  • tidy eval, a programmable data-masking framework used in tidyverse packages like dplyr and ggplot2. As a user, you will encounter the embracing operator {{ and name injection with the glue operators "{" and "{{".

  • rlang errors, a set of tools to signal and display errors. This includes backtrace capture with global_entrace() and backtrace display with last_error() and last_warnings(). Use abort() to create errors with bullet lists, structured metadata, and error chaining support.

    The display of error messages is optimised for bullet lists and chained errors and optionally integrates with the cli package (see local_use_cli()).

Argument intake

A set of tools help you check, validate, and preprocess arguments.

  • Checking function arguments, e.g. arg_match(), check_required(), and check_exclusive().

  • Checking dots, e.g. check_dots_used() and check_dots_empty().

  • Collecting dynamic dots, e.g. list2(). These dots support splicing with !!! and name injection with the glue operators "{" and "{{".

Programming interfaces

rlang provides various interfaces for working with R and R objects.

  • The R session, e.g. check_installed(), on_load(), and on_package_load().

  • Environments, e.g. env(), env_has(), env_get(), env_bind(), env_unbind(), env_print(), and local_bindings().

  • Evaluation, e.g. inject() and eval_bare().

  • Calls and symbols, e.g. call2(), is_call(), is_call_simple(), data_sym(), and data_syms().

  • Functions, e.g. new_function() and as_function(). The latter supports the purrr-style formula notation for lambda functions.

Installation

Install the released version of rlang from CRAN:

install.packages("rlang")

Or install the development version from GitHub with:

# install.packages("pak")
pak::pkg_install("r-lib/rlang")

Code of Conduct

Please note that the rlang project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.

Copy Link

Version

Install

install.packages('rlang')

Monthly Downloads

1,820,374

Version

1.1.0

License

MIT + file LICENSE

Issues

Pull Requests

Stars

Forks

Maintainer

Last Published

March 14th, 2023

Functions in rlang (1.1.0)

UQ

Deprecated UQ() and UQS() operators
as_box

Convert object to a box
arg_match

Match an argument to a character vector
are_na

Test for missing values
args_dots_empty

Helper for consistent documentation of empty dots
args_dots_used

Helper for consistent documentation of used dots
abort

Signal an error, warning, or message
args_error_context

Documentation anchor for error arguments
as_closure

Transform to a closure
args_data_masking

Argument type: data-masking
as_environment

Coerce to an environment
as_name

Extract names from symbols
as_utf8_character

Coerce to a character vector and attempt encoding conversion
as_label

Create a default name for an R object
bare-type-predicates

Bare type predicates
as_string

Cast symbol to string
bytes-class

Human readable memory sizes
box

Box a value
as_function

Convert to function
as_data_mask

Create a data mask
call_name

Extract function name or namespace of a call
call2

Create a call
call_fn

Extract function from a call
call_args

Extract arguments from a call
call_match

Match supplied arguments to function definition
call_modify

Modify the arguments of a call
caller_arg

Find the caller argument for error messages
call_inspect

Inspect a call
call_standardise

Standardise a call
catch_cnd

Catch a condition
cnd

Create a condition object
check_dots_empty

Check that dots are empty
check_dots_empty0

Check that dots are empty (low level variant)
check_required

Check that argument is supplied
check_exclusive

Check that arguments are mutually exclusive
child_env

Create a child environment
check_dots_unnamed

Check that all dots are unnamed
check_dots_used

Check that all dots have been used
chr_unserialise_unicode

Translate unicode points to UTF-8
dots_n

How many arguments are currently forwarded in dots?
cnd_message

Build an error message from parts
cnd_inherits

Does a condition or its ancestors inherit from a class?
dots_splice

Splice lists
cnd_muffle

Muffle a condition
cnd_signal

Signal a condition object
cnd_type

What type is a condition?
dev-notes-dots

Development notes - dots.R
defusing-advanced

Advanced defusal operators
enquo

Defuse function arguments
entrace

Add backtrace from error handler
dyn-dots

Dynamic dots features
embrace-operator

Embrace operator {{
dots_values

Evaluate dots with preliminary splicing
duplicate

Duplicate an R object
env_get

Get an object in an environment
env_bind

Bind symbols to objects in an environment
env

Create a new environment
env_depth

Depth of an environment chain
done

Box a final value for early termination
englue

Defuse function arguments with glue
env_binding_are_active

What kind of environment binding?
env_bury

Mask bindings by defining symbols deeper in a scope
env_browse

Browse environments
empty_env

Get the empty environment
env_inherits

Does environment inherit from another environment?
env_has

Does an environment have or see bindings?
env_binding_lock

Lock or unlock environment bindings
env_unbind

Remove bindings from an environment
env_print

Pretty-print an environment
dot-data

.data and .env pronouns
env_is_user_facing

Is frame environment user facing?
env_parent

Get parent environments
env_poke

Poke an object in an environment
env_clone

Clone or coalesce an environment
env_cache

Cache a value in an environment
env_unlock

Unlock an environment
eval_bare

Evaluate an expression in an environment
env_name

Label of an environment
env_names

Names and numbers of symbols bound in an environment
expr_label

Turn an expression to a label
expr_print

Print an expression
expr

Defuse an R expression
expr_interp

Process unquote operators in a captured expression
exec

Execute a function
fn_body

Get or set function body
eval_tidy

Evaluate an expression with quosures and pronoun support
fn_env

Return the closure environment of a function
format_error_call

Validate and format a function call for use in error messages
friendly_type

Format a type for error messages
global_entrace

Entrace unexpected errors
get_env

Get or set the environment of an object
faq-options

Global options for rlang
env_lock

Lock an environment
f_text

Turn RHS of formula into a string or label
fn_fmls

Extract arguments from a function
f_rhs

Get or set formula components
exprs_auto_name

Ensure that all elements of a list of expressions are named
format_error_bullets

Format bullets for error messages
inject

Inject objects in an R expression
inherits_any

Does an object inherit from a set of classes?
global_handle

Register default global handlers
global_prompt_install

Prompt user to install missing packages
hash

Hashing
has_name

Does an object have an element with this name?
is_callable

Is an object callable?
is_environment

Is object an environment?
is_empty

Is object an empty vector or NULL?
is_call

Is object a call?
injection-operator

Injection operator !!
invoke

Invoke a function with a list of arguments
interrupt

Simulate interrupt condition
is_condition

Is object a condition?
is_expression

Is an object an expression?
is_formula

Is object a formula?
glue-operators

Name injection with "{" and "{{"
has_length

How long is an object?
ffi_standalone_types_check

Internal API for standalone-types-check
is_dictionaryish

Is a vector uniquely named?
flatten

Flatten or squash a list of lists into a simpler vector
is_copyable

Is an object copyable?
is_interactive

Is R running interactively?
is_reference

Is an object referencing another?
is_integerish

Is a vector integer-like?
is_lang

Is object a call?
is_named

Is object named?
is_function

Is object a function?
is_installed

Are packages installed in any of the libraries?
is_symbol

Is object a symbol?
is_pairlist

Is object a node or pairlist?
list2

Collect dynamic dots in a list
is_true

Is object identical to TRUE or FALSE?
is_namespace

Is an object a namespace environment?
is_weakref

Is object a weak reference?
last_warnings

Display last messages and warnings
local_error_call

Set local error call in an execution environment
local_bindings

Temporarily change bindings of an environment
last_error

Last abort() error
lang

Create a call
local_use_cli

Use cli to format error messages
local_options

Change global options
names2

Get names of a vector
missing

Missing values
new_formula

Create a formula
missing_arg

Generate or handle a missing argument
new_quosure

Create a quosure from components
new_function

Create a function
new_node

Helpers for pairlist and language nodes
names_inform_repair

Inform about name repair
new-vector

Create vectors matching a given length
new_call

Create a new call from components
new_quosures

Create a list of quosures
obj_address

Address of an R object
ns_env

Get the namespace of a package
on_load

Run expressions on load
op-null-default

Default value for NULL
ns_registry_env

Return the namespace registry env
op-get-attr

Infix attribute accessor and setter
op-na-default

Replace missing values
pairlist2

Collect dynamic dots in a pairlist
new_weakref

Create a weak reference
quo_squash

Squash a quosure
quo_label

Format quosures for printing or labelling
qq_show

Show injected expression
quo_expr

Squash a quosure
prim_name

Name of a primitive function
parse_expr

Parse R code
rep_along

Create vectors matching the length of a given vector
return_from

Jump to or from a frame
rlang-package

rlang: Functions for Base Types and Core R and 'Tidyverse' Features
raw_deparse_str

Serialize a raw vector to a string
quosure-tools

Quosure getters, setters and predicates
seq2

Increasing sequence of integers in an interval
rlang_error

Errors of class rlang_error
set_attrs

Add attributes to an object
rlib_trace_spec

Backtrace specification
scoped_interactive

Deprecated scoped_ functions
search_envs

Search path environments
scoped_env

Deprecated scoped functions
scalar-type-predicates

Scalar type predicates
rlang_backtrace_on_error

Display backtrace on error
sym

Create a symbol or list of symbols
switch_type

Dispatch on base types
set_names

Set names of a vector
splice-operator

Splice operator !!!
stack

Get properties of the current or caller frame
topic-condition-customisation

Customising condition messages
set_expr

Set and get an expression
string

Create a string
stack-deprecated

Call stack information
splice

Splice values at dots collection time
topic-data-mask

What is data-masking and why do I need {{?
topic-condition-formatting

Formatting messages with cli
topic-embrace-constants

Why are strings and other constants enquosed in the empty environment?
topic-error-chaining

Including contextual information with error chains
topic-error-call

Including function calls in error messages
topic-double-evaluation

The double evaluation problem
topic-data-mask-programming

Data mask programming patterns
topic-embrace-non-args

Does {{ work on regular objects?
topic-defuse

Defusing R expressions
topic-data-mask-ambiguity

The data mask ambiguity
try_fetch

Try an expression with condition handlers
topic-metaprogramming

Metaprogramming patterns
trace_back

Capture a backtrace
type-predicates

Type predicates
topic-quosure

What are quosures and when are they needed?
type_of

Base type of an object
topic-inject

Injecting with !!, !!!, and glue syntax
vec_poke_n

Poke values into a vector
topic-multiple-columns

Taking multiple columns without ...
topic-inject-out-of-context

What happens if I use injection operators out of context?
wref_key

Get key/value from a weak reference object
zap_srcref

Zap source references
vector-construction

Create vectors
with_env

Evaluate an expression within a given environment
zap

Create zap objects
vector-coercion

Coerce an object to a base type
with_handlers

Establish handlers on the stack