-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmake-app-data.R
62 lines (46 loc) · 2.07 KB
/
make-app-data.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
library(rcheology)
library(dplyr)
all_versions <- sort(as.package_version(unique(rcheology$Rversion)))
make_doc_anchors <- function (name, package, versions) {
r_help_versions <- sub("(1\\.[0-4])\\.0", "\\1", versions)
r_help_versions <- sub("(0\\.\\d+)\\.0", "\\1", r_help_versions)
url <- utils::URLencode(sprintf("https://hughjonesd.github.io/r-help/%s/%s/%s.html",
r_help_versions, package, name))
versions <- as.character(versions)
anchors <- paste0("<a href='", url, "' target='_blank'>", versions, "</a>")
anchors
}
# Makes ranges which may have gaps, e.g. 0.60-0.61; 1.0-1.2.0
make_range <- function (name, package, versions) {
my_doc_anchors <- function (versions) make_doc_anchors(name, package, versions)
lv <- length(all_versions)
versions <- sort(as.package_version(unique(versions)))
there <- all_versions %in% versions
stop_start <- c(as.numeric(there[1]), diff(there))
starts <- which(stop_start == 1)
stops <- which(stop_start == -1) - 1
if (stop_start[lv] == 0 && there[lv]) stops <- c(stops, lv)
start_v <- all_versions[starts]
stop_v <- all_versions[stops]
stop_v <- ifelse(start_v == stop_v, "", paste0("-", my_doc_anchors(stop_v)))
ranges <- paste0(my_doc_anchors(start_v), stop_v, sep = "", collapse = "; ")
all_versions <- paste(versions, collapse = " ")
range_string <- paste0(ranges,"<!--", all_versions ,"-->")
range_string
}
n_all_versions <- length(unique(rcheology$Rversion))
rch_summary <- rcheology |>
mutate(
# for DT search box to display as an option:
package = as.factor(package),
type = as.factor(type),
class = as.factor(class),
priority = as.factor(priority),
) |>
group_by(name, args, package, priority, type, class, exported) |>
summarize(
hidden = hidden[1],
versions = make_range(name[1], package[1], Rversion),
)
Rversions <- as.package_version(unique(rcheology$Rversion))
save(Rversions, rch_summary, file = file.path("app", "rcheology-app-data.RData"))