mirror of
https://github.com/privatevoid-net/nix-super.git
synced 2024-11-21 21:46:15 +02:00
Create compile-commands.json with Make
This commit is contained in:
parent
5c8983b9e6
commit
83fc988bec
5 changed files with 55 additions and 3 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -142,6 +142,7 @@ GTAGS
|
||||||
|
|
||||||
# auto-generated compilation database
|
# auto-generated compilation database
|
||||||
compile_commands.json
|
compile_commands.json
|
||||||
|
*.compile_commands.json
|
||||||
|
|
||||||
nix-rust/target
|
nix-rust/target
|
||||||
|
|
||||||
|
|
11
mk/compilation-database.mk
Normal file
11
mk/compilation-database.mk
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
compile-commands-json-files :=
|
||||||
|
|
||||||
|
define write-compile-commands
|
||||||
|
_srcs := $$(sort $$(foreach src, $$($(1)_SOURCES), $$(src)))
|
||||||
|
|
||||||
|
$(1)_COMPILE_COMMANDS_JSON := $$(addprefix $(buildprefix), $$(addsuffix .compile_commands.json, $$(basename $$(_srcs))))
|
||||||
|
|
||||||
|
compile-commands-json-files += $$($(1)_COMPILE_COMMANDS_JSON)
|
||||||
|
|
||||||
|
clean-files += $$($(1)_COMPILE_COMMANDS_JSON)
|
||||||
|
endef
|
|
@ -68,6 +68,7 @@ include mk/patterns.mk
|
||||||
include mk/templates.mk
|
include mk/templates.mk
|
||||||
include mk/cxx-big-literal.mk
|
include mk/cxx-big-literal.mk
|
||||||
include mk/tests.mk
|
include mk/tests.mk
|
||||||
|
include mk/compilation-database.mk
|
||||||
|
|
||||||
|
|
||||||
# Include all sub-Makefiles.
|
# Include all sub-Makefiles.
|
||||||
|
@ -97,6 +98,13 @@ $(foreach test-group, $(install-tests-groups), \
|
||||||
$(eval $(call run-test,$(test),$(install_test_init))) \
|
$(eval $(call run-test,$(test),$(install_test_init))) \
|
||||||
$(eval $(test-group).test-group: $(test).test)))
|
$(eval $(test-group).test-group: $(test).test)))
|
||||||
|
|
||||||
|
# Compilation database.
|
||||||
|
$(foreach lib, $(libraries), $(eval $(call write-compile-commands,$(lib))))
|
||||||
|
$(foreach prog, $(programs), $(eval $(call write-compile-commands,$(prog))))
|
||||||
|
|
||||||
|
compile_commands.json: $(compile-commands-json-files)
|
||||||
|
@jq --slurp '.' $^ >$@
|
||||||
|
|
||||||
# Include makefiles requiring built programs.
|
# Include makefiles requiring built programs.
|
||||||
$(foreach mf, $(makefiles-late), $(eval $(call include-sub-makefile,$(mf))))
|
$(foreach mf, $(makefiles-late), $(eval $(call include-sub-makefile,$(mf))))
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,41 @@
|
||||||
|
|
||||||
|
# These are the complete command lines we use to compile C and C++ files.
|
||||||
|
# - $< is the source file.
|
||||||
|
# - $1 is the object file to create.
|
||||||
|
CC_CMD=$(CC) -o $1 -c $< $(CPPFLAGS) $(GLOBAL_CFLAGS) $(CFLAGS) $($1_CFLAGS) -MMD -MF $(call filename-to-dep,$1) -MP
|
||||||
|
CXX_CMD=$(CXX) -o $1 -c $< $(CPPFLAGS) $(GLOBAL_CXXFLAGS_PCH) $(GLOBAL_CXXFLAGS) $(CXXFLAGS) $($1_CXXFLAGS) $(ERROR_SWITCH_ENUM) -MMD -MF $(call filename-to-dep,$1) -MP
|
||||||
|
|
||||||
|
# We use COMPILE_COMMANDS_JSON_CMD to turn a compilation command (like CC_CMD
|
||||||
|
# or CXX_CMD above) into a comple_commands.json file. We rely on bash native
|
||||||
|
# word splitting to define the positional arguments.
|
||||||
|
# - $< is the source file being compiled.
|
||||||
|
COMPILE_COMMANDS_JSON_CMD=jq --null-input '{ directory: $$ENV.PWD, file: "$<", arguments: $$ARGS.positional }' --args --
|
||||||
|
|
||||||
|
|
||||||
$(buildprefix)%.o: %.cc
|
$(buildprefix)%.o: %.cc
|
||||||
@mkdir -p "$(dir $@)"
|
@mkdir -p "$(dir $@)"
|
||||||
$(trace-cxx) $(CXX) -o $@ -c $< $(CPPFLAGS) $(GLOBAL_CXXFLAGS_PCH) $(GLOBAL_CXXFLAGS) $(CXXFLAGS) $($@_CXXFLAGS) $(ERROR_SWITCH_ENUM) -MMD -MF $(call filename-to-dep, $@) -MP
|
$(trace-cxx) $(call CXX_CMD,$@)
|
||||||
|
|
||||||
$(buildprefix)%.o: %.cpp
|
$(buildprefix)%.o: %.cpp
|
||||||
@mkdir -p "$(dir $@)"
|
@mkdir -p "$(dir $@)"
|
||||||
$(trace-cxx) $(CXX) -o $@ -c $< $(CPPFLAGS) $(GLOBAL_CXXFLAGS_PCH) $(GLOBAL_CXXFLAGS) $(CXXFLAGS) $($@_CXXFLAGS) $(ERROR_SWITCH_ENUM) -MMD -MF $(call filename-to-dep, $@) -MP
|
$(trace-cxx) $(call CXX_CMD,$@)
|
||||||
|
|
||||||
$(buildprefix)%.o: %.c
|
$(buildprefix)%.o: %.c
|
||||||
@mkdir -p "$(dir $@)"
|
@mkdir -p "$(dir $@)"
|
||||||
$(trace-cc) $(CC) -o $@ -c $< $(CPPFLAGS) $(GLOBAL_CFLAGS) $(CFLAGS) $($@_CFLAGS) -MMD -MF $(call filename-to-dep, $@) -MP
|
$(trace-cc) $(call CC_CMD,$@)
|
||||||
|
|
||||||
|
# In the following we need to replace the .compile_commands.json extension in $@ with .o
|
||||||
|
# to make the object file. This is needed because CC_CMD and CXX_CMD do further expansions
|
||||||
|
# based on the object file name (i.e. *_CXXFLAGS and filename-to-dep).
|
||||||
|
|
||||||
|
$(buildprefix)%.compile_commands.json: %.cc
|
||||||
|
@mkdir -p "$(dir $@)"
|
||||||
|
$(trace-jq) $(COMPILE_COMMANDS_JSON_CMD) $(call CXX_CMD,$(@:.compile_commands.json=.o)) > $@
|
||||||
|
|
||||||
|
$(buildprefix)%.compile_commands.json: %.cpp
|
||||||
|
@mkdir -p "$(dir $@)"
|
||||||
|
$(trace-jq) $(COMPILE_COMMANDS_JSON_CMD) $(call CXX_CMD,$(@:.compile_commands.json=.o)) > $@
|
||||||
|
|
||||||
|
$(buildprefix)%.compile_commands.json: %.c
|
||||||
|
@mkdir -p "$(dir $@)"
|
||||||
|
$(trace-jq) $(COMPILE_COMMANDS_JSON_CMD) $(call CC_CMD,$(@:.compile_commands.json=.o)) > $@
|
||||||
|
|
|
@ -10,6 +10,8 @@ ifeq ($(V), 0)
|
||||||
trace-install = @echo " INST " $@;
|
trace-install = @echo " INST " $@;
|
||||||
trace-mkdir = @echo " MKDIR " $@;
|
trace-mkdir = @echo " MKDIR " $@;
|
||||||
trace-test = @echo " TEST " $@;
|
trace-test = @echo " TEST " $@;
|
||||||
|
trace-sh = @echo " SH " $@;
|
||||||
|
trace-jq = @echo " JQ " $@;
|
||||||
|
|
||||||
suppress = @
|
suppress = @
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue