## from https://github.com/hadley/httr/blob/4624451f8cc395a90730b5a10b50ba005187f2ff/R/oauth-cache.R
add_line <- function(line, path, quiet = FALSE) {
if (file.exists(path)) {
lines <- readLines(path, warn = FALSE)
lines <- lines[lines != ""]
} else {
lines <- character()
}
if (line %in% lines) return(TRUE)
if (!quiet) message("Adding ", line, " to ", path)
lines <- c(lines, line)
writeLines(lines, path)
TRUE
}
# Given a string, indent every line by some number of spaces.
# The exception is to not add spaces after a trailing \n.
#' @author Winston Chang \email{winston@@stdout.org}
indent <- function(str, indent = 0) {
gsub("(^|\\n)(?!$)",
paste0("\\1", paste(rep(" ", indent), collapse = "")),
str,
perl = TRUE
)
}
#' Timestamp to R date
#' @keywords internal
timestamp_to_r <- function(t){
as.POSIXct(t, format = "%Y-%m-%dT%H:%M:%S")
}
#' if argument is NULL, no line output
#'
#' @keywords internal
cat0 <- function(prefix = "", x){
if(!is.null(x)){
cat(prefix, x, "\n")
}
}
#' A helper function that tests whether an object is either NULL _or_
#' a list of NULLs
#'
#' @keywords internal
is.NullOb <- function(x) is.null(x) | all(sapply(x, is.null))
#' Recursively step down into list, removing all such objects
#'
#' @keywords internal
rmNullObs <- function(x) {
x <- Filter(Negate(is.NullOb), x)
lapply(x, function(x) if (is.list(x)) rmNullObs(x) else x)
}
#' Is this a try error?
#'
#' Utility to test errors
#'
#' @param test_me an object created with try()
#'
#' @return Boolean
#'
#' @keywords internal
is.error <- function(test_me){
inherits(test_me, "try-error")
}
#' Get the error message
#'
#' @param test_me an object that has failed is.error
#'
#' @return The error message
#'
#' @keywords internal
error.message <- function(test_me){
if(is.error(test_me)) attr(test_me, "condition")$message
}
#' Idempotency
#'
#' A random code to ensure no repeats
#'
#' @return A random 15 digit hash
#' @keywords internal
idempotency <- function(){
paste(sample(c(LETTERS, letters, 0:9), 15, TRUE),collapse="")
}
#' Custom message log level
#'
#' @param ... The message(s)
#' @param level The severity
#'
#' @keywords internal
myMessage <- function(..., level = 2){
compare_level <- 1
if(level >= compare_level){
message(Sys.time() ,"> ", ...)
}
}
#' Custom message API error
#'
#' @param ... The error(s)
#'
#' @keywords internal
myAPIError <- function(ex){
if (grepl("\n",ex$message))
return(strsplit(ex$message,"\n")[[1]][1])
else
return(ex$message)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.