From 6c6e134f4c28786fb7c59437b3233529d7ffea2d Mon Sep 17 00:00:00 2001 From: Scott Chamberlain Date: Tue, 7 Apr 2020 08:36:58 -0700 Subject: [PATCH] fix ecoregion internals, was erroring on subsetting the input data.frame --- R/ecoregion.R | 8 +++++--- R/taxonomy-funs.R | 2 +- man/taxonomy.Rd | 2 +- 3 files changed, 7 insertions(+), 5 deletions(-) diff --git a/R/ecoregion.R b/R/ecoregion.R index 9881efa..9563001 100644 --- a/R/ecoregion.R +++ b/R/ecoregion.R @@ -75,17 +75,19 @@ eco_region <- function(x, dataset = "meow", region, x <- do_coords(x, lat, lon) z <- sf::st_as_sf(x, coords = c("longitude", "latitude")) - z <- sf::st_set_crs(z, 4326) + z <- sf::st_set_crs(z, "+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs") ref_sf <- switch(dataset, meow = regions_meow(), fao = regions_fao()) er_split <- strsplit(region, ":")[[1]] ref_target <- ref_sf[ref_sf[[ er_split[1] ]] %in% er_split[2], ] bb <- sf::st_join(z, ref_target, join = sf::st_within) - wth <- tibble::as_tibble(x[is.na(bb$FID), ]) + bb_is_na <- bb[is.na(bb$FID), ] + wth <- tibble::as_tibble(x[x$key %in% bb_is_na$key, ]) if (drop) { - x <- tibble::as_tibble(x[!is.na(bb$FID), ]) + bb_not_na <- bb[!is.na(bb$FID), ] + x <- tibble::as_tibble(x[x$key %in% bb_not_na$key, ]) } if (NROW(wth) == 0) wth <- NA row.names(wth) <- NULL diff --git a/R/taxonomy-funs.R b/R/taxonomy-funs.R index 026ec83..4864f9b 100644 --- a/R/taxonomy-funs.R +++ b/R/taxonomy-funs.R @@ -7,7 +7,7 @@ #' out bade data points as an attribute you can access. Default: `TRUE` #' @return Returns a data.frame, with attributes #' @examples -#' if (requireNamespace("rgbif", quietly = TRUE)) { +#' if (requireNamespace("rgbif", quietly = TRUE) && interactive()) { #' library("rgbif") #' res <- rgbif::occ_data(limit = 200)$data #' } else { diff --git a/man/taxonomy.Rd b/man/taxonomy.Rd index 14a454b..057eba0 100644 --- a/man/taxonomy.Rd +++ b/man/taxonomy.Rd @@ -22,7 +22,7 @@ Returns a data.frame, with attributes Taxonomy based cleaning } \examples{ -if (requireNamespace("rgbif", quietly = TRUE)) { +if (requireNamespace("rgbif", quietly = TRUE) && interactive()) { library("rgbif") res <- rgbif::occ_data(limit = 200)$data } else {