From e7d1ac86d73d70cd1d41fe46496734a49b809195 Mon Sep 17 00:00:00 2001 From: Tom Schwarzl Date: Fri, 22 Nov 2024 08:59:01 +0100 Subject: [PATCH] #502 added type checks for new_object() .parent argument enforcing S7_object and prohibiting S7_class passing. --- R/class.R | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/R/class.R b/R/class.R index 29887e47..e1ecb274 100644 --- a/R/class.R +++ b/R/class.R @@ -238,8 +238,8 @@ is_class <- function(x) inherits(x, "S7_class") # Object ------------------------------------------------------------------ -#' @param .parent,... Parent object and named properties used to construct the -#' object. +#' @param .parent,... Parent S7 object and named properties used to construct +#' the object. #' @rdname new_class #' @export new_object <- function(.parent, ...) { @@ -253,7 +253,15 @@ new_object <- function(.parent, ...) { } # force .parent before ... - # TODO: Some type checking on `.parent`? + # TODO: Some additional type checking on `.parent`? + + if (!inherits(.parent, "S7_object")) + stop("`.parent` needs to be an S7_object") + if (inherits(.parent, "S7_class")) { + stop(paste("`.parent` cannot be of type S7_class. Did you type", + "`.parent = S7_object` instead of `.parent = S7_object()`?")) + } + object <- .parent args <- list(...)