From c1cba0fdae00b47a5487af0e2159d8a41ca29dcd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dawid=20Ka=C5=82=C4=99dkowski?= Date: Tue, 7 Jan 2025 12:17:00 +0100 Subject: [PATCH] datanames in vignettes (#357) see https://github.com/insightsengineering/teal.code/pull/239 Refers to #338 Modified a documentation a little bit to emphasize inheritance from environment. --- R/teal_data-constructor.R | 22 ++++++++++++++++++++-- R/teal_data-show.R | 3 ++- man/cdisc_data.Rd | 2 +- man/teal_data-class.Rd | 2 +- man/teal_data.Rd | 23 +++++++++++++++++++++-- vignettes/teal-data.Rmd | 29 +++++++++++++++-------------- 6 files changed, 60 insertions(+), 21 deletions(-) diff --git a/R/teal_data-constructor.R b/R/teal_data-constructor.R index f79350126..8168bd457 100644 --- a/R/teal_data-constructor.R +++ b/R/teal_data-constructor.R @@ -3,7 +3,7 @@ #' @description #' `r lifecycle::badge("stable")` #' -#' Universal function to pass data to teal application. +#' Initializes a data for `teal` application. #' #' @param ... any number of objects (presumably data objects) provided as `name = value` pairs. #' @@ -14,10 +14,28 @@ #' @param code (`character`, `language`) optional code to reproduce the datasets provided in `...`. #' Note this code is not executed and the `teal_data` may not be reproducible #' -#' Use [verify()] to verify code reproducibility . +#' Use [verify()] to verify code reproducibility. +#' +#' @details +#' +#' A `teal_data` is meant to be used for reproducibility purposes. The class inherits from +#' [`teal.data::qenv`] and we encourage to get familiar with \CRANpkg{teal.code} first. +#' `teal_data` has following characteristics: +#' +#' - It inherits from the environment and methods such as [`$`], [get()], [ls()], [as.list()], +#' [parent.env()] work out of the box. +#' - `teal_data` is a locked environment, and data modification is only possible through the +#' [teal.code::eval_code()] and [within.qenv()] functions. +#' - It stores metadata about the code used to create the data (see [get_code()]). +#' - It supports slicing (see [`teal.code::subset-qenv`]) +#' - Is immutable which means that each code evaluation does not modify the original `teal_data` +#' environment directly. +#' - It maintains information about relationships between datasets (see [join_keys()]). #' #' @return A `teal_data` object. #' +#' @seealso [`teal.code::eval_code`], [get_code()], [join_keys()], [names.teal_data()] +#' #' @export #' #' @examples diff --git a/R/teal_data-show.R b/R/teal_data-show.R index fca8cf66e..4ce54d8b8 100644 --- a/R/teal_data-show.R +++ b/R/teal_data-show.R @@ -16,5 +16,6 @@ setMethod("show", signature = "teal_data", function(object) { } else { cat("\u2716", "unverified teal_data object\n") } - rlang::env_print(teal.code::get_env(object)) + methods::callNextMethod(object) + invisible(object) }) diff --git a/man/cdisc_data.Rd b/man/cdisc_data.Rd index fe9f80de8..7ce24d5aa 100644 --- a/man/cdisc_data.Rd +++ b/man/cdisc_data.Rd @@ -21,7 +21,7 @@ For ADAM datasets it would be automatically derived.} \item{code}{(\code{character}, \code{language}) optional code to reproduce the datasets provided in \code{...}. Note this code is not executed and the \code{teal_data} may not be reproducible -Use \code{\link[=verify]{verify()}} to verify code reproducibility .} +Use \code{\link[=verify]{verify()}} to verify code reproducibility.} } \value{ A \code{teal_data} object. diff --git a/man/teal_data-class.Rd b/man/teal_data-class.Rd index 494010499..d046b4bd3 100644 --- a/man/teal_data-class.Rd +++ b/man/teal_data-class.Rd @@ -24,7 +24,7 @@ Access variables with \code{\link[=get]{get()}}, \code{\link{$}}, \code{\link[te No setter provided. Evaluate code to add variables into \verb{@.xData}.} \item{\code{code}}{(\code{list} of \code{character}) representing code necessary to reproduce the contents of \code{qenv}. -Access with \code{\link[teal.code:qenv]{teal.code::get_code()}}. +Access with \code{\link[teal.code:get_code]{teal.code::get_code()}}. No setter provided. Evaluate code to append code to the slot.} \item{\code{join_keys}}{(\code{join_keys}) object specifying joining keys for data sets in diff --git a/man/teal_data.Rd b/man/teal_data.Rd index 98985d108..a142c2b1e 100644 --- a/man/teal_data.Rd +++ b/man/teal_data.Rd @@ -19,7 +19,7 @@ If empty then no joins between pairs of objects.} \item{code}{(\code{character}, \code{language}) optional code to reproduce the datasets provided in \code{...}. Note this code is not executed and the \code{teal_data} may not be reproducible -Use \code{\link[=verify]{verify()}} to verify code reproducibility .} +Use \code{\link[=verify]{verify()}} to verify code reproducibility.} \item{x}{(\code{teal_data})} @@ -31,7 +31,23 @@ A \code{teal_data} object. \description{ \ifelse{html}{\href{https://lifecycle.r-lib.org/articles/stages.html#stable}{\figure{lifecycle-stable.svg}{options: alt='[Stable]'}}}{\strong{[Stable]}} -Universal function to pass data to teal application. +Initializes a data for \code{teal} application. +} +\details{ +A \code{teal_data} is meant to be used for reproducibility purposes. The class inherits from +\code{\link{qenv}} and we encourage to get familiar with \CRANpkg{teal.code} first. +\code{teal_data} has following characteristics: +\itemize{ +\item It inherits from the environment and methods such as \code{\link{$}}, \code{\link[=get]{get()}}, \code{\link[=ls]{ls()}}, \code{\link[=as.list]{as.list()}}, +\code{\link[=parent.env]{parent.env()}} work out of the box. +\item \code{teal_data} is a locked environment, and data modification is only possible through the +\code{\link[teal.code:eval_code]{teal.code::eval_code()}} and \code{\link[=within.qenv]{within.qenv()}} functions. +\item It stores metadata about the code used to create the data (see \code{\link[=get_code]{get_code()}}). +\item It supports slicing (see \code{\link[teal.code:subset-qenv]{teal.code::subset-qenv}}) +\item Is immutable which means that each code evaluation does not modify the original \code{teal_data} +environment directly. +\item It maintains information about relationships between datasets (see \code{\link[=join_keys]{join_keys()}}). +} } \section{Subsetting}{ @@ -56,3 +72,6 @@ join_keys(data)["a"] # should show empty keys join_keys(data)["b"] } +\seealso{ +\code{\link[teal.code:eval_code]{teal.code::eval_code}}, \code{\link[=get_code]{get_code()}}, \code{\link[=join_keys]{join_keys()}}, \code{\link[=names.teal_data]{names.teal_data()}} +} diff --git a/vignettes/teal-data.Rmd b/vignettes/teal-data.Rmd index 1301814b3..174bb2633 100644 --- a/vignettes/teal-data.Rmd +++ b/vignettes/teal-data.Rmd @@ -11,12 +11,21 @@ vignette: > # Introduction The `teal.data` package specifies the data format used in `teal` applications. -The `teal_data` class inherits from [`qenv`](https://insightsengineering.github.io/teal.code/latest-tag/articles/qenv.html) and is meant to be used for reproducibility purposes. + + +A `teal_data` is meant to be used for reproducibility purposes. The class inherits from [`qenv`](https://insightsengineering.github.io/teal.code/latest-tag/articles/qenv.html) and we encourage to get familiar with [`teal.code`](https://insightsengineering.github.io/teal.code/latest-tag/) first. `teal_data` has following characteristics: + +- It inherits from the environment and methods such as `$`, `get()`, `ls()`, `as.list()` work out of the box. +- `teal_data` is a locked environment, and data modification is only possible through the `teal.code::eval_code()` and `within.qenv()` functions. +- It stores metadata about the code used to create the data (see [reproducibility](#reproducibility)). +- It supports slicing by `[`. +- It is immutable which means that each code evaluation does not modify the original `teal_data` environment directly. +- It maintains information about relationships between datasets (see [Join Keys](#relational-data-models)). ## Quick Start To create an object of class `teal_data`, use the `teal_data` function. -`teal_data` has a number of methods to manage relevant information in private class slots. +`teal_data` has a number of methods to interact with the object. ```{r, results = 'hide', message = FALSE} library(teal.data) @@ -46,6 +55,7 @@ get_code(my_data) # get code just for specific object get_code(my_data, names = "data2") + # get datanames names(my_data) @@ -53,16 +63,6 @@ names(my_data) print(my_data) ``` - -## `teal_data` characteristics - -A `teal_data` object keeps the following information: - -- `env` - an environment containing data. -- `code` - a string containing code to reproduce `env` (details in [reproducibility](teal-data-reproducibility.html)). -- `names` - a character vector listing objects of interest to `teal` modules (details in [this `teal` vignette](https://insightsengineering.github.io/teal/latest-tag/articles/including-data-in-teal-applications.html)). -- `join_keys` - a `join_keys` object defining relationships between datasets (details in [Join Keys](join-keys.html)). - ### Reproducibility The primary function of `teal_data` is to provide reproducibility of data. @@ -104,8 +104,8 @@ join_keys(my_data["child"]) ### Hidden objects -An object is hidden in `teal_data` if its name starts with a dot (`.`). -This can be used to pass auxiliary objects / function in the `teal_data` instance, without being visible in the `teal` summary and filter panel. +An object is hidden in `teal_data` if its name starts with a dot (`.`). This can be used to pass auxiliary objects in +the `teal_data` instance, without being visible in the `teal` summary and filter panel. ```{r} my_data <- teal_data() @@ -114,5 +114,6 @@ my_data <- within(my_data, { .data2 <- data.frame(id = 1:20, data_id = c(1:10, 1:10), y = 21:30) }) +ls(my_data) names(my_data) ```