From d8e1d66d855b0a4a1859c1668fc62800af62022a Mon Sep 17 00:00:00 2001 From: Andrew Gene Brown Date: Fri, 22 Mar 2024 11:11:04 -0700 Subject: [PATCH 1/2] fix for #312 --- R/SoilProfileCollection-setters.R | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/R/SoilProfileCollection-setters.R b/R/SoilProfileCollection-setters.R index b262a98a..c612d43f 100644 --- a/R/SoilProfileCollection-setters.R +++ b/R/SoilProfileCollection-setters.R @@ -702,7 +702,10 @@ setReplaceMethod("diagnostic_hz", # if data are already present, warn the user if(nrow(d) > 0) warning('overwriting existing diagnostic horizon data!', call.=FALSE) - + + # convert id column to character to match @site + value[[idn]] <- as.character(value[[idn]]) + # copy data over object@diagnostic <- .as.data.frame.aqp(value, metadata(object)$aqp_df_class) @@ -784,7 +787,10 @@ setReplaceMethod("restrictions", signature(object = "SoilProfileCollection"), # if data are already present, warn the user if(nrow(d) > 0) warning('overwriting existing restriction data!', call.=FALSE) - + + # convert id column to character to match @site + value[[idn]] <- as.character(value[[idn]]) + # copy data over object@restrictions <- .as.data.frame.aqp(value, metadata(object)$aqp_df_class) From 8fc9327a2394c385d7ccbc8d6d60f117c77badfe Mon Sep 17 00:00:00 2001 From: Andrew Gene Brown Date: Fri, 22 Mar 2024 11:12:59 -0700 Subject: [PATCH 2/2] diagnostic_hz<-/restrictions<-: clean up / more efficient logic for generating warnings --- R/SoilProfileCollection-setters.R | 47 ++++++++++++++++--------------- 1 file changed, 24 insertions(+), 23 deletions(-) diff --git a/R/SoilProfileCollection-setters.R b/R/SoilProfileCollection-setters.R index c612d43f..840fedb3 100644 --- a/R/SoilProfileCollection-setters.R +++ b/R/SoilProfileCollection-setters.R @@ -683,25 +683,25 @@ setReplaceMethod("diagnostic_hz", # test for the special case where internally-used functions # are copying over data from one object to another, and diagnostic_hz(obj) is a 0-row data.frame # short-circut, and return original object - if(nrow(d) == 0 & nrow(value) == 0) + if (nrow(d) == 0 && nrow(value) == 0) return(object) # test to make sure that our common ID is present in the new data - if(! idn %in% nm) - stop(paste("diagnostic horizon data are missing pedon ID column: ", idn), call.=FALSE) - - # test to make sure that at least one of the IDS in candidate data are present within SPC - if(all( ! unique(value[[idn]]) %in% pIDs) ) - warning('candidate diagnostic horizon data have NO matching IDs in target SoilProfileCollection object!', call. = FALSE) + if (!idn %in% nm) + stop(paste("diagnostic horizon data are missing pedon ID column: ", idn), call. = FALSE) + uidm <- unique(value[[idn]]) %in% pIDs # warn user if some of the IDs in the candidate data are missing - if(any( ! unique(value[[idn]]) %in% pIDs) ) { - warning('some records in candidate diagnostic horizon data have no matching IDs in target SoilProfileCollection object') + if (any(!uidm)) { + # test to make sure that at least one of the IDS in candidate data are present within SPC + if (all(!uidm)) { + warning('candidate diagnostic horizon data have NO matching IDs in target SoilProfileCollection object!', call. = FALSE) + } else warning('some records in candidate diagnostic horizon data have no matching IDs in target SoilProfileCollection object', call. = FALSE) } # if data are already present, warn the user - if(nrow(d) > 0) - warning('overwriting existing diagnostic horizon data!', call.=FALSE) + if (nrow(d) > 0) + warning('overwriting existing diagnostic horizon data!', call. = FALSE) # convert id column to character to match @site value[[idn]] <- as.character(value[[idn]]) @@ -763,29 +763,30 @@ setReplaceMethod("restrictions", signature(object = "SoilProfileCollection"), # testing the class of the new data if (!inherits(value, "data.frame")) - stop("restriction data must be a data.frame", call.=FALSE) + stop("restriction data must be a data.frame", call. = FALSE) # test for the special case where internally-used functions # are copying over data from one object to another, and diagnostic_hz(obj) is a 0-row data.frame # short-circuit, and return original object - if(nrow(d) == 0 & nrow(value) == 0) + if (nrow(d) == 0 && nrow(value) == 0) return(object) # test to make sure that our common ID is present in the new data - if(! idn %in% nm) - stop(paste("restriction data are missing pedon ID column: ", idn), call.=FALSE) - - # test to make sure that at least one of the IDs in candidate data are present within SPC - if(all(!unique(value[[idn]]) %in% pIDs) ) - warning('restriction data have no matching IDs in target SoilProfileCollection object!', call. = FALSE) - + if (!idn %in% nm) + stop(paste("restriction data are missing pedon ID column: ", idn), call. = FALSE) + + uidm <- unique(value[[idn]]) %in% pIDs # warn user if some of the IDs in the candidate data are missing - if(any( ! unique(value[[idn]]) %in% pIDs) ) { - warning('some records in restriction data have no matching IDs in target SoilProfileCollection object') + if (any(!uidm)) { + # test to make sure that at least one of the IDs in candidate data are present within SPC + if (all(!uidm)) { + warning('restriction data have no matching IDs in target SoilProfileCollection object!', call. = FALSE) + } else warning('some records in restriction data have no matching IDs in target SoilProfileCollection object', call. = FALSE) } # if data are already present, warn the user - if(nrow(d) > 0) + + if (nrow(d) > 0) warning('overwriting existing restriction data!', call.=FALSE) # convert id column to character to match @site