From 242d81bfcdeb3a0feb4fc7bd50f4ccf6f5870709 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ma=C3=ABlle=20Salmon?= Date: Fri, 5 Apr 2024 15:14:11 +0200 Subject: [PATCH] fix: make curly and math protections compatible --- R/translate.R | 2 +- inst/example-equations-curly.md | 5 +++++ tests/testthat/_snaps/translate.md | 7 +++++++ .../api/translate-adef71-POST.json | 8 ++++++++ tests/testthat/test-translate.R | 18 ++++++++++++++++++ 5 files changed, 39 insertions(+), 1 deletion(-) create mode 100644 inst/example-equations-curly.md create mode 100644 tests/testthat/fixtures/example-equations-curly/api/translate-adef71-POST.json diff --git a/R/translate.R b/R/translate.R index ec18cfe..39ae1d2 100644 --- a/R/translate.R +++ b/R/translate.R @@ -157,8 +157,8 @@ translate_part <- function(xml, woolish$body <- fakify_xml(xml) ## protect content inside curly braces and math ---- - woolish$body <- tinkr::protect_curly(woolish$body) woolish$body <- tinkr::protect_math(woolish$body) + woolish$body <- tinkr::protect_curly(woolish$body) curlies <- xml2::xml_find_all(woolish$body, "//*[@curly]") purrr::walk(curlies, protect_curly) maths <- xml2::xml_find_all(woolish$body, "//*[@asis='true']") diff --git a/inst/example-equations-curly.md b/inst/example-equations-curly.md new file mode 100644 index 0000000..9bbfa60 --- /dev/null +++ b/inst/example-equations-curly.md @@ -0,0 +1,5 @@ +--- +title: "les équations dans babeldown" +--- + +$a_{ij}$ diff --git a/tests/testthat/_snaps/translate.md b/tests/testthat/_snaps/translate.md index 8379f04..07a724a 100644 --- a/tests/testthat/_snaps/translate.md +++ b/tests/testthat/_snaps/translate.md @@ -57,3 +57,10 @@ [4] "" [5] "" +# deepl_translate() handles equations with curly well + + Code + foot_curly_lines[5] + Output + [1] "$a_{ij}$" + diff --git a/tests/testthat/fixtures/example-equations-curly/api/translate-adef71-POST.json b/tests/testthat/fixtures/example-equations-curly/api/translate-adef71-POST.json new file mode 100644 index 0000000..b66f6c9 --- /dev/null +++ b/tests/testthat/fixtures/example-equations-curly/api/translate-adef71-POST.json @@ -0,0 +1,8 @@ +{ + "translations": [ + { + "detected_source_language": "FR", + "text": "\n\n\n \n \n $a_{ij}$<\/math>\n \n <\/paragraph>\n<\/document>\n" + } + ] +} diff --git a/tests/testthat/test-translate.R b/tests/testthat/test-translate.R index 35a92e9..01962e3 100644 --- a/tests/testthat/test-translate.R +++ b/tests/testthat/test-translate.R @@ -240,3 +240,21 @@ test_that("deepl_translate() handles equations+footnote well", { expect_snapshot(foot_math_lines) }) + +test_that("deepl_translate() handles equations with curly well", { + to_translate <- system.file("example-equations-curly.md", package = "babeldown") + out_path <- withr::local_tempfile() + with_mock_dir("example-equations-curly", { + deepl_translate( + path = to_translate, + out_path = out_path, + source_lang = "FR", + target_lang = "EN-US", + yaml_fields = NULL + ) + }) + foot_curly_lines <- brio::read_lines(out_path) + expect_snapshot(foot_curly_lines[5]) +}) + +