-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathmakefile
94 lines (75 loc) · 3.23 KB
/
makefile
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
## Makefile for R package development.
##
## My general strategy here is to use calls to devtools:: functions, rather than
## calling 'R CMD ...' directly.
##
## The Makefile is intended to live in a package's top-level folder. It should work
## from there with no need for package-specific mods.
##
## I use GNU make. Be warned.
##
R.OPTS := --vanilla -e
DATE := $(shell date " %Y%m%d")
PKG.VERS := $(shell Rscript $(R.OPTS) "cat(read.dcf('DESCRIPTION', fields='Version'))")
PKG.NAME := $(shell Rscript $(R.OPTS) "cat(read.dcf('DESCRIPTION', fields='Package'))")
BUILT.PKG := $(PKG.NAME)_$(PKG.VERS).tar.gz
## TODO:
help:
## Print Constants and Targets defined in this Makefile
@echo Constants::
@echo R.OPTS: $(R.OPTS)
@echo DATE: $(DATE)
@echo PKG.VERS: $(PKG.VERS)
@echo PKG.NAME: $(PKG.NAME)
@echo BUILT.PKG: $(BUILT.PKG)
@echo
@echo Targets::
@echo --
@grep -E -A 1 "^[^\# ] :" Makefile
@echo --
@echo
.phoney: help build checkbuilt check pkgdown document manual versiontag install.gh install.local
## Few targets correspond to files, so, list them here to ensure they always run.
##### Targets to build and check package.
build:
## Build package with 'binary=FALSE' for portability. Put tarball in parent to source directory.
R $(R.OPTS) "devtools::build(pkg='.', binary=FALSE, vignettes=TRUE, manual=FALSE)"
checkbuilt:
## Check the built package for current version number.
## TODO: 1st check existence of '..$(built.pkg); build it if necessary (make build)
R $(R.OPTS) "devtools::check_built(path=here::here('..', '$(BUILT.PKG)'))"
check:
## Build and check the package. Does not save built package.
R $(R.OPTS) "devtools::check(pkg='.')"
##### install or uninstall package
uninstall:
## uninstall package from locations identified in .libPaths(). Does not unload.
R $(R.OPTS) "devtools::uninstall(pkg='.')"
install.src:
## install package from source using devtools_install().
R $(R.OPTS) "devtools::install(pkg='.')"
install.gh:
## Install most recent release available on github using remotes::install_github().
## TODO: FIXME! Does not work, presently
R $(R.OPTS) "remotes::install_github(repo='davebraze/$(PKG.NAME)', lib=.libPaths()[1])"
install.loc:
## Install current version from a local tarball using remotes::install_local().
## Looks to the parent of the package source directory to find the tarball.
## TODO: 1st check existence of the tarball; build it if necessary (make build).
R $(R.OPTS) "remotes::install_local(path=here::here('..', '$(BUILT.PKG)'), lib=.libPaths()[1])"
##### targets to build documentation in various formats, mostly to see it's ok before release
document:
## Build rds documentation via roxygen2.
R $(R.OPTS) "devtools::document(pkg='.')"
pkgdown: document
## Build pkgdown site from scratch (online documentation). Overwrites existing site.
R $(R.OPTS) "pkgdown::clean_site(pkg='.')"
R $(R.OPTS) "pkgdown::build_site(pkg='.', preview=TRUE)"
manual: document
## Build PDF manual and put it in the parent directory to the package.
R $(R.OPTS) "devtools::build_manual(pkg='.')"
##### Prepare for release of new version
versiontag:
## Set a version tag with git and push it to remote. Manually edit DESCRIPTION to set version.
git tag -a v$(PKG.VERS) -m "new release version v$(PKG.VERS)"
git push --tags