R/addons-scuttle.R

Defines functions append_transpilers_for_scuttle

# scuttle::logNormCounts(sce) =>
#
# with(doFuture::registerDoFuture(flavor = "%dofuture%"), {
#   options(future.disposable = <future arguments>)
#   scuttle::logNormCounts(sce, BPPARAM = BiocParallel::DoparParam())
# })
#
append_transpilers_for_scuttle <- function() {
  ## These scuttle functions accept BPPARAM via '...' (S4 generics) or
  ## directly in their formals
  names <- c(
    "calculateAverage",
    "logNormCounts", "normalizeCounts",
    "perCellQCMetrics", "perFeatureQCMetrics",
    "addPerCellQCMetrics", "addPerFeatureQCMetrics",
    "addPerCellQC", "addPerFeatureQC",
    "numDetectedAcrossCells", "numDetectedAcrossFeatures",
    "sumCountsAcrossCells", "sumCountsAcrossFeatures",
    "summarizeAssayByGroup",
    "aggregateAcrossCells", "aggregateAcrossFeatures",
    "librarySizeFactors", "computeLibraryFactors",
    "geometricSizeFactors", "computeGeometricFactors",
    "medianSizeFactors", "computeMedianFactors",
    "pooledSizeFactors", "computePooledFactors",
    "fitLinearModel"
  )

  ns <- getNamespace("scuttle")
  transpilers <- list()
  for (name in names) {
    if (exists(name, mode = "function", envir = ns, inherits = TRUE)) {
      args <- list(BPPARAM = quote(BiocParallel::DoparParam()))
      transpilers[[name]] <- list(
        label = sprintf("scuttle::%s() ~> scuttle::%s(..., BPPARAM = BiocParallel::DoparParam())", name, name),
        transpiler = make_futurize_for_doFuture(args = args)
      )
    }
  }

  transpilers <- list(transpilers)
  names(transpilers) <- "scuttle"

  append_transpilers("futurize::add-on", transpilers)

  ## Return required packages
  c("scuttle", "BiocParallel", "doFuture")
}

Try the futurize package in your browser

Any scripts or data that you put into this service are public.

futurize documentation built on March 19, 2026, 1:07 a.m.