diff options
author | Loïc Hoguin <[email protected]> | 2013-05-28 20:38:18 +0200 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2013-05-28 20:38:18 +0200 |
commit | 9f3a42a730a38a92846995170aa29280cc284529 (patch) | |
tree | 521fffcdf9c0fd06c2a2c4e47177e5b2fdd57532 /erlang.mk | |
parent | e3277f8ee00c27fd4bc38fcd023f480cc3b9daae (diff) | |
download | erlang.mk-9f3a42a730a38a92846995170aa29280cc284529.tar.gz erlang.mk-9f3a42a730a38a92846995170aa29280cc284529.tar.bz2 erlang.mk-9f3a42a730a38a92846995170aa29280cc284529.zip |
Add support for ErlyDTL files found in templates/*.dtl
Diffstat (limited to 'erlang.mk')
-rw-r--r-- | erlang.mk | 34 |
1 files changed, 27 insertions, 7 deletions
@@ -19,9 +19,12 @@ V ?= 0 appsrc_verbose_0 = @echo " APP " $(PROJECT).app.src; appsrc_verbose = $(appsrc_verbose_$(V)) -erlc_verbose_0 = @echo " ERLC " $(?F); +erlc_verbose_0 = @echo " ERLC " $(filter-out %.dtl,$(?F)); erlc_verbose = $(erlc_verbose_$(V)) +dtl_verbose_0 = @echo " DTL " $(filter %.dtl,$(?F)); +dtl_verbose = $(dtl_verbose_$(V)) + gen_verbose_0 = @echo " GEN " $@; gen_verbose = $(gen_verbose_$(V)) @@ -48,18 +51,35 @@ all: deps app clean-all: clean clean-deps clean-docs $(gen_verbose) rm -rf .$(PROJECT).plt $(DEPS_DIR) logs -MODULES = $(shell ls src/*.erl $(wildcard src/*.core) \ - | sed 's/src\///;s/\.core/,/;s/\.erl/,/' | sed '$$s/.$$//') - app: ebin/$(PROJECT).app + $(eval MODULES := $(shell ls ebin/*.beam \ + | sed 's/ebin\///;s/\.beam/,/' | sed '$$s/.$$//')) $(appsrc_verbose) cat src/$(PROJECT).app.src \ | sed 's/{modules, \[\]}/{modules, \[$(MODULES)\]}/' \ > ebin/$(PROJECT).app -ebin/$(PROJECT).app: src/*.erl $(wildcard src/*.core) - @mkdir -p ebin/ +define compile_erl = $(erlc_verbose) ERL_LIBS=deps erlc -v $(ERLC_OPTS) -o ebin/ -pa ebin/ \ - $(COMPILE_FIRST_PATHS) $? + $(COMPILE_FIRST_PATHS) $(1) +endef + +define compile_dtl = + $(dtl_verbose) erl -noshell -pa ebin/ deps/erlydtl/ebin/ -eval ' \ + Compile = fun(F) -> \ + Module = list_to_atom( \ + string:to_lower(filename:basename(F, ".dtl")) ++ "_dtl"), \ + erlydtl_compiler:compile(F, Module, [{out_dir, "ebin/"}]) \ + end, \ + _ = [Compile(F) || F <- string:tokens("$(1)", " ")], \ + init:stop()' +endef + +ebin/$(PROJECT).app: src/*.erl $(wildcard src/*.core) $(wildcard templates/*.dtl) + @mkdir -p ebin/ + $(if $(strip $(filter-out %.dtl,$?)), \ + $(call compile_erl,$(filter-out %.dtl,$?))) + $(if $(strip $(filter %.dtl,$?)), \ + $(call compile_dtl,$(filter %.dtl,$?))) clean: $(gen_verbose) rm -rf ebin/ test/*.beam erl_crash.dump |