From d0832ce43f9cebb57006886992ab312529a681af Mon Sep 17 00:00:00 2001 From: Robert Ashton Date: Fri, 19 Mar 2021 10:11:53 +0000 Subject: [PATCH] Add resources as explicit arg of translator_register and add additional test --- DESCRIPTION | 2 +- R/translator.R | 6 ++++-- man/translator.Rd | 7 ++++++- tests/testthat/test-translator.R | 26 ++++++++++++++++++++++++++ 4 files changed, 37 insertions(+), 4 deletions(-) diff --git a/DESCRIPTION b/DESCRIPTION index 86888a0..f2a7146 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,6 +1,6 @@ Package: traduire Title: Example Translation in a Package -Version: 0.0.5 +Version: 0.0.6 Authors@R: c(person(given = "Rich", family = "FitzJohn", diff --git a/R/translator.R b/R/translator.R index 95a7788..5df3f90 100644 --- a/R/translator.R +++ b/R/translator.R @@ -57,6 +57,8 @@ ##' ##' @title Register a translator ##' +##' @inheritParams i18n +##' ##' @param ... For \code{translator_register}, arguments passed to ##' \code{\link{traduire_options}} to build the translator object. All ##' arguments are accepted. For \code{translator_translate} and @@ -85,9 +87,9 @@ ##' traduire::t_("hello", language = "fr", name = "myexample") ##' "myexample" %in% traduire::translator_list() ##' traduire::translator_unregister("myexample") -translator_register <- function(..., name = NULL) { +translator_register <- function(resources, ..., name = NULL) { name <- name_from_context(name, NULL, strict = TRUE) - translators[[name]] <- i18n(...) + translators[[name]] <- i18n(resources = resources, ...) } diff --git a/man/translator.Rd b/man/translator.Rd index 2f82e2a..5546ce5 100644 --- a/man/translator.Rd +++ b/man/translator.Rd @@ -10,7 +10,7 @@ \alias{translator_list} \title{Register a translator} \usage{ -translator_register(..., name = NULL) +translator_register(resources, ..., name = NULL) translator_unregister(name = NULL) @@ -25,6 +25,11 @@ translator_set_language(language, name = NULL, package = NULL) translator_list() } \arguments{ +\item{resources}{Path to a json file containing translation +resources. If given in this way, then on-demand translation +loading (via \code{resource_pattern}) is disabled unless a +currently unexposed i18next option is used.} + \item{...}{For \code{translator_register}, arguments passed to \code{\link{traduire_options}} to build the translator object. All arguments are accepted. For \code{translator_translate} and diff --git a/tests/testthat/test-translator.R b/tests/testthat/test-translator.R index b620f2e..829e839 100644 --- a/tests/testthat/test-translator.R +++ b/tests/testthat/test-translator.R @@ -113,3 +113,29 @@ test_that("translate from another package", { }) mockery::expect_args(mock_translator, 1, "name", "package") }) + + +test_that("translator registered with resource_pattern", { + root <- traduire_file("examples/structured") + name <- rand_str() + res <- translator_register( + NULL, + name = name, + resource_pattern = sprintf("%s/{language}-{namespace}.json", root), + default_namespace = "common", + namespaces = c("common", "login"), + language = "en", + languages = c("en", "fr")) + expect_is(res, "i18n") + expect_true(name %in% translator_list()) + + expect_identical(translator(name), res) + expect_equal(translator_translate("hello", language = "fr", name = name), + "salut le monde") + expect_equal(t_("hello", language = "fr", name = name), + "salut le monde") + expect_true(exists(name, translators)) + translator_unregister(name) + expect_false(exists(name, translators)) + expect_false(name %in% translator_list()) +})