forked from r-lib/devtools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvignette-r.R
80 lines (64 loc) · 2.5 KB
/
vignette-r.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
# Modified from src/library/tools/R/build.R
#
# Copyright (C) 1995-2013 The R Core Team
# Copyright (C) 2013 Hadley Wickham
#
# 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 2 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.
#
# A copy of the GNU General Public License is available at
# http://www.r-project.org/Licenses/
copy_vignettes <- function(pkg, keep_md) {
pkg <- as.package(pkg)
usethis_use_directory(pkg, "doc", ignore = TRUE)
usethis_use_git_ignore(pkg, "doc")
doc_dir <- file.path(pkg$path, "doc")
vigns <- tools::pkgVignettes(dir = pkg$path, output = TRUE, source = TRUE)
if (length(vigns$docs) == 0) return(invisible())
md_outputs <- character()
if (isTRUE(keep_md)) {
md_outputs <- list.files(path = vigns$dir, pattern = "[.]md$", full.names = TRUE)
}
out_mv <- c(md_outputs, vigns$outputs, unique(unlist(vigns$sources, use.names = FALSE)))
out_cp <- vigns$docs
message("Moving ", paste(basename(out_mv), collapse = ", "), " to doc/")
file.copy(out_mv, doc_dir, overwrite = TRUE)
file.remove(out_mv)
message("Copying ", paste(basename(out_cp), collapse = ", "), " to doc/")
file.copy(out_cp, doc_dir, overwrite = TRUE)
# Copy extra files, if needed
extra_files <- find_vignette_extras(pkg)
if (length(extra_files) == 0) return(invisible())
message(
"Copying extra files ", paste(basename(extra_files), collapse = ", "),
" to doc/"
)
file.copy(extra_files, doc_dir, recursive = TRUE)
invisible()
}
find_vignette_extras <- function(pkg = ".") {
pkg <- as.package(pkg)
vig_path <- file.path(pkg$path, "vignettes")
extras_file <- file.path(vig_path, ".install_extras")
if (!file.exists(extras_file)) return(character())
extras <- readLines(extras_file, warn = FALSE)
if (length(extras) == 0) return(character())
withr::with_dir(vig_path, {
allfiles <- dir(
all.files = TRUE, full.names = TRUE, recursive = TRUE,
include.dirs = TRUE
)
})
inst <- rep(FALSE, length(allfiles))
for (e in extras) {
inst <- inst | grepl(e, allfiles, perl = TRUE, ignore.case = TRUE)
}
normalizePath(file.path(vig_path, allfiles[inst]))
}