Skip to content

TylerGrantSmith/colonoscopy

Repository files navigation

colonoscopy

Codecov test coverage Lifecycle: experimental R-CMD-check

colonoscopy provides functions and RStudio addins to easily add or remove explicit package scoping (::, :::)

Installation

# install.packages("devtools")
devtools::install_github("TylerGrantSmith/colonoscopy")

Example

scope will modify expressions or functions by appending explicit package references.

library(colonoscopy)
library(ggplot2)
scope("aes")
#> ggplot2::aes
aes
#> function (x, y, ...) 
#> {
#>     exprs <- enquos(x = x, y = y, ..., .ignore_empty = "all")
#>     aes <- new_aes(exprs, env = parent.frame())
#>     rename_aes(aes)
#> }
#> <bytecode: 0x000000000f16d908>
#> <environment: namespace:ggplot2>
scope(aes)
#> function (x, y, ...)
#> {
#>     exprs <- rlang::enquos(x = x, y = y, ..., .ignore_empty = "all")
#>     aes <- new_aes(exprs, env = parent.frame())
#>     rename_aes(aes)
#> }
scope(aes, inPackage = FALSE)
#> function (x, y, ...)
#> {
#>     exprs <- rlang::enquos(x = x, y = y, ..., .ignore_empty = "all")
#>     aes <- ggplot2:::new_aes(exprs, env = parent.frame())
#>     ggplot2:::rename_aes(aes)
#> }

unscope will modify expressions or functions by removing :: and ::: operators (and the package name).

unscope("ggplot2::alpha")
#> alpha
alpha
#> function (colour, alpha = NA) 
#> {
#>     if (length(colour) != length(alpha)) {
#>         if (length(colour) > 1 && length(alpha) > 1) {
#>             stop("Only one of colour and alpha can be vectorised")
#>         }
#>         if (length(colour) > 1) {
#>             alpha <- rep(alpha, length.out = length(colour))
#>         }
#>         else {
#>             colour <- rep(colour, length.out = length(alpha))
#>         }
#>     }
#>     rgb <- farver::decode_colour(colour, alpha = TRUE)
#>     rgb[!is.na(alpha), 4] <- alpha[!is.na(alpha)]
#>     farver::encode_colour(rgb, rgb[, 4])
#> }
#> <bytecode: 0x000000000f7d89d0>
#> <environment: namespace:scales>
unscope(alpha)
#> function (colour, alpha = NA)
#> {
#>     if (length(colour) != length(alpha)) {
#>         if (length(colour) > 1 && length(alpha) > 1) {
#>             stop("Only one of colour and alpha can be vectorised")
#>         }
#>         if (length(colour) > 1) {
#>             alpha <- rep(alpha, length.out = length(colour))
#>         }
#>         else {
#>             colour <- rep(colour, length.out = length(alpha))
#>         }
#>     }
#>     rgb <- decode_colour(colour, alpha = TRUE)
#>     rgb[!is.na(alpha), 4] <- alpha[!is.na(alpha)]
#>     encode_colour(rgb, rgb[, 4])
#> }

About

A package to add and remove namespace access operators

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages