Skip to content

Commit

Permalink
Merge pull request #1700 from rstudio/length-delayed-module
Browse files Browse the repository at this point in the history
restore `length(<delayed_module>)` not forcing the module.
  • Loading branch information
t-kalinowski authored Nov 14, 2024
2 parents 39e98aa + d7adb2c commit 2afa8b9
Showing 1 changed file with 5 additions and 2 deletions.
7 changes: 5 additions & 2 deletions R/python.R
Original file line number Diff line number Diff line change
Expand Up @@ -819,7 +819,10 @@ length.python.builtin.list <- function(x) {
length.python.builtin.object <- function(x) {

# return 0 if Python not yet available
if (py_is_null_xptr(x) || !py_available())
# Note: some packages (rgeedim) use `length(module) == 0` as a way to check if
# an object is a delayed module without forcing it to load.
# Note, a better way to check is: reticulate::py_module_available("module_name")
if (py_is_module_proxy(x) || !py_available() || py_is_null_xptr(x))
return(0L)

# otherwise, try to invoke the object's __len__ method
Expand Down Expand Up @@ -1067,7 +1070,7 @@ py_str.python.builtin.object <- function(object, ...) {

#' @export
format.python.builtin.module <- function(x, ...) {
if(py_is_module_proxy(x))
if (py_is_module_proxy(x))
return(paste0("Module(", get("module", envir = x), ")", sep = ""))
NextMethod()
}
Expand Down

0 comments on commit 2afa8b9

Please sign in to comment.