aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/makefile_escaping
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--makefile_escaping/env_vars.mk19
-rw-r--r--makefile_escaping/shell.mk7
2 files changed, 20 insertions, 6 deletions
diff --git a/makefile_escaping/env_vars.mk b/makefile_escaping/env_vars.mk
index 47c1647..7fdc087 100644
--- a/makefile_escaping/env_vars.mk
+++ b/makefile_escaping/env_vars.mk
@@ -1,15 +1,22 @@
escape = $(subst ','\'',$(1))
-escape_var = $(call escape,$(value $(1)))
test_var ?= This is safe.
+test_var := $(value test_var)
export test_var
-echo_test_var := printf '%s\n' '$(call escape_var,test_var)'
-bash_test_var := bash -c '$(call escape_var,echo_test_var)'
+inner_var := Inner variable
+outer_var := Outer variable - $(inner_var) - $(test_var)
+
+echo_test_var := printf '%s\n' '$(call escape,$(test_var))'
+bash_test_var := bash -c '$(call escape,$(echo_test_var))'
+
+echo_outer_var := printf '%s\n' '$(call escape,$(outer_var))'
.PHONY: test
test:
- @printf '%s\n' '$(call escape_var,test_var)'
+ @printf '%s\n' '$(call escape,$(test_var))'
@printf '%s\n' "$$test_var"
- @bash -c '$(call escape_var,echo_test_var)'
- @bash -c '$(call escape_var,bash_test_var)'
+ @bash -c '$(call escape,$(echo_test_var))'
+ @bash -c '$(call escape,$(bash_test_var))'
+ @printf '%s\n' '$(call escape,$(outer_var))'
+ @bash -c '$(call escape,$(echo_outer_var))'
diff --git a/makefile_escaping/shell.mk b/makefile_escaping/shell.mk
index 36db8d8..23f8f30 100644
--- a/makefile_escaping/shell.mk
+++ b/makefile_escaping/shell.mk
@@ -3,12 +3,19 @@ escape = $(subst ','\'',$(1))
cwd := $(shell basename -- "$$( pwd )")
export cwd
+inner_var := Inner variable
+outer_var := Outer variable - $(inner_var) - $(cwd)
+
echo_cwd := printf '%s\n' '$(call escape,$(cwd))'
bash_cwd := bash -c '$(call escape,$(echo_cwd))'
+echo_outer_var := printf '%s\n' '$(call escape,$(outer_var))'
+
.PHONY: test
test:
@printf '%s\n' '$(call escape,$(cwd))'
@printf '%s\n' "$$cwd"
@bash -c '$(call escape,$(echo_cwd))'
@bash -c '$(call escape,$(bash_cwd))'
+ @printf '%s\n' '$(call escape,$(outer_var))'
+ @bash -c '$(call escape,$(echo_outer_var))'