Nothing
#######################################################################
# nuggets: An R framework for exploration of patterns in data
# Copyright (C) 2025 Michal Burda
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#######################################################################
#' Extract values from predicate names
#'
#' This function extracts the value part from a character vector of predicate
#' names. Each element of `x` is expected to follow the pattern
#' `<varname>=<value>`, where `<varname>` is a variable name and `<value>` is
#' the associated value.
#'
#' If an element does not contain an equal sign (`=`), the function returns an
#' empty string for that element.
#'
#' @details
#' This function is the counterpart to [var_names()], which extracts the
#' variable part of predicates. Together, [var_names()] and `values()` provide
#' a convenient way to split predicate strings into their variable and value
#' components.
#'
#' @param x A character vector of predicate names.
#'
#' @return A character vector containing the `<value>` parts of predicate
#' names in `x`. Elements without an equal sign return an empty string.
#' If `x` is `NULL`, the function returns `NULL`. If `x` is an empty
#' vector (`character(0)`), the function returns an empty vector
#' (`character(0)`).
#'
#' @seealso [var_names()]
#'
#' @author Michal Burda
#'
#' @examples
#' values(c("a=1", "a=2", "b=x", "b=y"))
#' # returns c("1", "2", "x", "y")
#'
#' values(c("a", "b=3"))
#' # returns c("", "3")
#'
#' @export
values <- function(x) {
.must_be_character_vector(x, null = TRUE)
if (is.null(x))
return(NULL)
has_eq <- grepl("=", x)
res <- x
res[!has_eq] <- ""
res[has_eq] <- sub("^[^=]*=", "", x[has_eq])
res
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.