Project

General

Profile

1 256 aaronmk
selfDir_3d1bc249 := $(dir $(lastword $(MAKEFILE_LIST)))
2 250 aaronmk
3 368 aaronmk
# Make
4 415 aaronmk
subMake = $(MAKE) $(@F) --directory=$(@D)
5 404 aaronmk
+_ = $(+:_%=)
6 368 aaronmk
addBeforeExt = $(basename $(2))$(1)$(suffix $(2))
7
8
# Commands
9 395 aaronmk
CP = cp -p
10
DIFF = diff --unified=2
11 368 aaronmk
12 415 aaronmk
tablesSort := plots organisms stems
13
vegxMaps := $(wildcard $(tablesSort:%=map.VegX.%.csv))
14
tables := $(vegxMaps:map.VegX.%.csv=%)
15 264 aaronmk
vegbienMaps := $(subst .VegX.,.VegBIEN.,$(vegxMaps))
16 247 aaronmk
17 368 aaronmk
root := $(selfDir_3d1bc249)..
18
psqlAsBien := $(root)/bin/psql_vegbien
19 353 aaronmk
20 401 aaronmk
# Config
21
test_n ?= 2
22
23 250 aaronmk
#####
24
25 418 aaronmk
all: _always maps ;
26 247 aaronmk
27
.SUFFIXES:
28
29 383 aaronmk
_always:
30
.PHONY: _always
31 250 aaronmk
32 383 aaronmk
clean: _always
33 256 aaronmk
	$(RM) $(all)
34
35 423 aaronmk
remake: _always clean all ;
36
37 383 aaronmk
%.out: % _always
38 368 aaronmk
	./$* >$@
39
.PRECIOUS: %.out
40
41 408 aaronmk
all += $(wildcard *.out)
42
43 415 aaronmk
$(root)/%: _always
44
	+$(subMake)
45
46 250 aaronmk
#####
47
48 418 aaronmk
reinstall: _always uninstall install ;
49 264 aaronmk
50
#####
51
52 418 aaronmk
maps: $(vegbienMaps) _always ;
53 368 aaronmk
54
all += $(vegbienMaps)
55
56 415 aaronmk
map.VegBIEN.%.csv: map.VegX.%.csv $(root)/mappings/VegX-VegBIEN.%.csv
57
	$(root)/bin/join_sort <$+ >$@
58 264 aaronmk
.PRECIOUS: map.VegBIEN.%.csv
59
60 368 aaronmk
#####
61
62 418 aaronmk
import: _always $(addprefix import-,$(tables)) verify ;
63 368 aaronmk
64
log = $*$(if $(n),.n=$(n),).log
65
66 339 aaronmk
logs := $(wildcard *.log)
67
68 383 aaronmk
rm_logs: _always
69 339 aaronmk
	$(RM) $(logs)
70
71 264 aaronmk
#####
72
73 418 aaronmk
verify: _always $(addprefix verify-,$(tables)) ;
74 368 aaronmk
75 383 aaronmk
verify-%: verify.%.ref verify.%.out _always
76 404 aaronmk
	$(DIFF) $(+_)
77 368 aaronmk
78 383 aaronmk
%.out: %.sql _always
79 429 aaronmk
	$(out_cmd)
80 370 aaronmk
.PRECIOUS: %.out
81 429 aaronmk
out_cmd = $(psqlAsBien) --no-align --field-separator='	' --pset=footer=off \
82
--pset=null=NULL <$< >$@
83 369 aaronmk
84 368 aaronmk
#####
85
86 418 aaronmk
test: _always $(addprefix test-,$(tables)) ;
87 368 aaronmk
88 395 aaronmk
test-%: test.%.out _always
89
	$(DIFF) $(<:.out=.ref) $<
90 368 aaronmk
91 395 aaronmk
accept-%: _always
92
	$(CP) $* $(*:.out=.ref)
93
94 368 aaronmk
#####
95
96 256 aaronmk
ifdef db
97
98 264 aaronmk
mapEnv := in_engine=$(dbEngine) in_database=$(db)
99 256 aaronmk
100 368 aaronmk
####
101 256 aaronmk
102 368 aaronmk
ifeq ($(dbEngine),MySQL)
103 339 aaronmk
104 368 aaronmk
bienPassword := $(shell cat $(root)/config/bien_password)
105
mysqlAs = mysql --user=$(1) --password='$(bienPassword)'
106
mysqlAsRoot := $(call mysqlAs,root)
107
mysqlAsBien := $(call mysqlAs,bien)
108
109 383 aaronmk
import-%: map.VegBIEN.%.csv _always
110 385 aaronmk
	-$(import_cmd)
111 383 aaronmk
import_cmd = (set -x; "time" env commit=1 $(map) $<) \
112 368 aaronmk
$(if $(n),,>>$(log)) 2>&1$(if $(n),|tee -a $(log))
113 256 aaronmk
114 369 aaronmk
%.ref: %.ref.sql
115 371 aaronmk
	$(mysqlAsBien) $(db) <$< >$@
116 369 aaronmk
.PRECIOUS: %.ref
117 368 aaronmk
118
###
119
120 418 aaronmk
install: _always db ;
121 256 aaronmk
122 418 aaronmk
uninstall: _always rm_db ;
123 256 aaronmk
124 383 aaronmk
db: src.$(db).sql _always
125 368 aaronmk
	-$(mysqlAsRoot) <$<
126
	echo "GRANT SELECT ON $(db).* TO 'bien'@'localhost';"|$(mysqlAsRoot)
127 255 aaronmk
# ignore errors in db import so that GRANT will still be run
128 250 aaronmk
129 383 aaronmk
rm_db: _always
130 368 aaronmk
	-echo "REVOKE ALL ON $(db).* FROM 'bien'@'localhost';"|$(mysqlAsRoot)
131
	echo "DROP DATABASE IF EXISTS $(db);"|$(mysqlAsRoot)
132 365 aaronmk
# ignore errors if grant not defined
133 250 aaronmk
134 368 aaronmk
###
135
136
else
137
$(error dbEngine variable must be one of the following: MySQL, PostgreSQL)
138
endif
139
140
####
141
142 383 aaronmk
test.%.out: map.VegBIEN.%.csv _always
143 401 aaronmk
	env test=1 n=$(test_n) $(map) $< >$@ 2>&1 || { e=$$?; cat $@; exit $$e;}
144 368 aaronmk
.PRECIOUS: test.%.out
145
146 256 aaronmk
#####
147
148
else
149
$(error db variable must be set)
150
endif
151 368 aaronmk
152
#####
153
154
# Must come after mapEnv is set
155
map := env $(mapEnv) out_database=vegbien $(root)/map