-
Notifications
You must be signed in to change notification settings - Fork 3
/
Makefile
113 lines (89 loc) · 3.63 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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
# makefile written using https://yuukidach.github.io/p/makefile-for-projects-with-subdirectories/ as template
TARGET = website
OUTDIR = ./docs
SRCDIR = ./src
##DIR_OBJ = ./obj
OUTDIR_ABS=$(abspath $(OUTDIR))
PROJROOT_ABS=$(abspath .)
# needed to ensure that sub make calls as used by cmdstanr do not emit "Entering/Leaving" directory messages
# these additional messages interfer otherwise with cmdstanr which
# infers via make print-STANCFLAGS - for example - the value of these variables
# Todo: consider moving this bit into the configuration of R
MAKEFLAGS += --no-print-directory
# scripts and includes
INCS = $(SRCDIR)/setup.R
INCS += $(SRCDIR)/cmq_brm.R
INCS += $(SRCDIR)/_macros.qmd
INCS += $(SRCDIR)/install_dependencies.R
SRCS = $(wildcard [0-9][0-9]*.qmd $(foreach fd, $(SRCDIR), $(fd)/[0-9][0-9]*.qmd))
NODIR_SRC = $(notdir $(SRCS))
OBJS = $(SRCS:qmd=html)
# OBJS = $(patsubst %.qmd, %.md, $(SRCS))
# set default R and quarto cmd's
R_CMD ?= `R RHOME`/bin/R
QUARTO_CMD ?= quarto
#
#INC_DIRS = -I./ $(addprefix -I, $(SUBDIR))
#LIBS = -largp
#LIB_DIRS = -L/usr/local/Cellar/argp-standalone/1.3/lib
# rule which allows to monitor the R code as it gets executed; useful for debugging
%.Rlog : %.qmd
cd $(@D); $(R_CMD_PREFIX) $(R_CMD) -q -e "knitr::purl('$(<F)', '$(patsubst %.qmd,%.R,$(<F))')" -e "source('$(patsubst %.qmd,%.R,$(<F))', echo=TRUE)" | tee $(@F) 2>&1
# tell makefile how to turn a qmd files into things we want
%.html : %.qmd
@echo running per-document html quarto render $(<F) --to html --profile $(QUARTO_PROFILE)
cd $(@D); $(QUARTO_CMD_PREFIX) $(QUARTO_CMD) render $(<F) --to html --profile $(QUARTO_PROFILE) $(QUARTO_CMD_POSTFIX)
PHONY := $(TARGET)
# enforce that we first setup the web-site and then run the remainder
# potentially with parallelism. TODO: enforcing the order should
# actually be possible to do via dependencies.
$(TARGET):
$(MAKE) $(OUTDIR)/$(QUARTO_PROFILE)/bookdown-website
# $(OUTDIR)/$(QUARTO_PROFILE)/%.html : %.qmd
# @echo running per-document html quarto render $< --profile $(QUARTO_PROFILE)
# $(QUARTO_CMD) render $< --profile $(QUARTO_PROFILE)
# note that the md's are run in the directory itself to cast the
# Quarto rendering process to be a standalone run. The intended effect
# is to populate the _cache directory of the respective document which
# can then get reused when rendering the full web-site
%.md : %.qmd
@echo running per-document md quarto render $(<F) --to md --output $(@F) --profile $(QUARTO_PROFILE)
cd $(@D); $(QUARTO_CMD) render $(<F) --to md --output $(@F) --profile $(QUARTO_PROFILE)
%.pdf : %.qmd
@echo running per-document pdf quarto render $< --to pdf
$(QUARTO_CMD_PREFIX) $(QUARTO_CMD) render $< --to pdf --output $(@F) --profile $(QUARTO_PROFILE) $(QUARTO_CMD_POSTFIX)
$(OUTDIR)/$(QUARTO_PROFILE)/bookdown-website : index.qmd _quarto.yml $(OBJS)
@echo Rendering website
$(QUARTO_CMD) render --to html --profile $(QUARTO_PROFILE)
touch $(OUTDIR)/$(QUARTO_PROFILE)/bookdown-website
# ensure that R markdowns honor dependency on setup file
$(OBJS) : $(SRCDIR)/setup.R
# \{\.content-hidden when-profile="public"\}[\s\S]*?::://g' $< > $@
# :::
#$(DIR_OBJ)/%.o: %.c $(INCS)
# mkdir -p $(@D)
# $(CC) -o $@ $(CFLAGS) -c $< $(INC_DIRS)
PHONY += clean
clean:
# rm -rf $(OUTDIR)/*
rm -rf src/*.html
rm -rf brms-cache
rm -rf .brms-cache
rm -rf _brms-cache
rm -rf src/*_files
rm -rf src/*_cache
rm -rf src/_freeze
rm -rf _freeze
rm -rf src/.quarto
rm -rf .quarto
rm -rf build
PHONY += echoes
echoes:
@echo "INC files: $(INCS)"
@echo "SRC files: $(SRCS)"
@echo "OBJ files: $(OBJS)"
##
# Debug target that allows you to print a variable
##
print-% : ; @echo $* = $($*)
.PHONY = $(PHONY)