aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFred Sundvik <fsundvik@gmail.com>2016-08-08 10:26:23 +0300
committerFred Sundvik <fsundvik@gmail.com>2016-08-20 03:56:30 +0300
commit67b294ca66fd9da341ab93019a380d91ac589c96 (patch)
tree43ce564d34fc93154476ef777202b2e245fb7805
parentdb5c3b74fb6541879bfad9930d2a659b1d89cd83 (diff)
downloadqmk_firmware-67b294ca66fd9da341ab93019a380d91ac589c96.tar.gz
qmk_firmware-67b294ca66fd9da341ab93019a380d91ac589c96.zip
Actual compilation
-rw-r--r--Makefile26
-rw-r--r--build_keyboard.mk171
-rw-r--r--message.mk3
3 files changed, 59 insertions, 141 deletions
diff --git a/Makefile b/Makefile
index e5becd7ad..fc6157209 100644
--- a/Makefile
+++ b/Makefile
@@ -228,17 +228,19 @@ define PARSE_KEYMAP
228 KB_SP := $(CURRENT_KB)/$$(CURRENT_SP) 228 KB_SP := $(CURRENT_KB)/$$(CURRENT_SP)
229 endif 229 endif
230 KB_SP := $(BOLD)$$(KB_SP)$(NO_COLOR) 230 KB_SP := $(BOLD)$$(KB_SP)$(NO_COLOR)
231 MAKE_VARS := KEYBOARD=$$(CURRENT_KB) SUBPROJECT=$$(CURRENT_SP) KEYMAP=$$(CURRENT_KM)
232 MAKE_VARS += VERBOSE=$(VERBOSE) COLOR=$(COLOR) SILENT=false
231 COMMAND_$$(COMMAND) := \ 233 COMMAND_$$(COMMAND) := \
232 printf "Compiling $$(KB_SP) with $(BOLD)$$(CURRENT_KM)$(NO_COLOR)" | \ 234 printf "Compiling $$(KB_SP) with $(BOLD)$$(CURRENT_KM)$(NO_COLOR)" | \
233 $(AWK) '{ printf "%-118s", $$$$0;}'; \ 235 $(AWK) '{ printf "%-118s", $$$$0;}'; \
234 LOG=$$$$(echo "$$(MAKE) -c $(ROOT_DIR) -f build_keyboard.mk VERBOSE=$(VERBOSE) COLOR=$(COLOR) SILENT=true" 2>&1) ; \ 236 LOG=$$$$($$(MAKE) -C $(ROOT_DIR) -f build_keyboard.mk $$(MAKE_VARS) 2>&1) ; \
235 if [ $$$$? -gt 0 ]; \ 237 if [ $$$$? -gt 0 ]; \
236 then $$(PRINT_ERROR_PLAIN); \ 238 then $$(PRINT_ERROR_PLAIN); \
237 elif [ "$$$$LOG" != "" ] ; \ 239 elif [ "$$$$LOG" != "" ] ; \
238 then $$(PRINT_WARNING_PLAIN); \ 240 then $$(PRINT_WARNING_PLAIN); \
239 else \ 241 else \
240 $$(PRINT_OK); \ 242 $$(PRINT_OK); \
241 fi; 243 fi;
242endef 244endef
243 245
244define PARSE_ALL_KEYMAPS 246define PARSE_ALL_KEYMAPS
@@ -258,9 +260,11 @@ SUBPROJECTS := $(notdir $(patsubst %/Makefile,%,$(wildcard ./*/Makefile)))
258$(SUBPROJECTS): %: %-allkm 260$(SUBPROJECTS): %: %-allkm
259 261
260.PHONY: % 262.PHONY: %
261%: 263%:
264 cmp --version >/dev/null 2>&1; if [ $$? -gt 0 ]; then printf "$(MSG_NO_CMP)"; exit 1; fi;
262 $(eval $(call PARSE_RULE,$@)) 265 $(eval $(call PARSE_RULE,$@))
263 $(foreach COMMAND,$(COMMANDS),$(RUN_COMMAND)) 266 $(foreach COMMAND,$(COMMANDS),$(RUN_COMMAND))
267
264 268
265.PHONY: all 269.PHONY: all
266all: all-keyboards 270all: all-keyboards
diff --git a/build_keyboard.mk b/build_keyboard.mk
index 053c8532a..b0cb22e6a 100644
--- a/build_keyboard.mk
+++ b/build_keyboard.mk
@@ -4,44 +4,9 @@ endif
4 4
5.DEFAULT_GOAL := all 5.DEFAULT_GOAL := all
6 6
7space := $(subst ,, )
8ESCAPED_ABS_PATH = $(subst $(space),_SPACE_,$(abspath $1))
9starting_makefile := $(call ESCAPED_ABS_PATH,$(firstword $(MAKEFILE_LIST)))
10mkfile_path := $(call ESCAPED_ABS_PATH,$(lastword $(MAKEFILE_LIST))))
11abs_tmk_root := $(patsubst %/,%,$(dir $(mkfile_path)))
12
13ifneq (,$(findstring /keyboards/,$(starting_makefile)))
14 possible_keyboard:=$(patsubst %/,%,$(dir $(patsubst $(abs_tmk_root)/keyboards/%,%,$(starting_makefile))))
15 ifneq (,$(findstring /keymaps/,$(possible_keyboard)))
16 KEYMAP_DIR:=$(lastword $(subst /keymaps/, ,$(possible_keyboard)))
17 KEYBOARD_DIR:=$(firstword $(subst /keymaps/, ,$(possible_keyboard)))
18 ifneq (,$(findstring /,$(KEYBOARD_DIR)))
19 # SUBPROJECT_DIR:=$(lastword $(subst /, ,$(KEYBOARD_DIR)))
20 # KEYBOARD_DIR:=$(firstword $(subst /, ,$(KEYBOARD_DIR)))
21 tmk_root = ../../..
22 else
23 tmk_root = ../../../..
24 endif
25 else
26 KEYMAP_DIR:=default
27 KEYBOARD_DIR:=$(possible_keyboard)
28 ifneq (,$(findstring /,$(KEYBOARD_DIR)))
29 # SUBPROJECT_DIR:=$(lastword $(subst /, ,$(KEYBOARD_DIR)))
30 # KEYBOARD_DIR:=$(firstword $(subst /, ,$(KEYBOARD_DIR)))
31 tmk_root = ../../..
32 else
33 tmk_root = ../..
34 endif
35 endif
36else
37 tmk_root = .
38endif
39# $(info $(KEYBOARD_DIR))
40# $(info $(KEYMAP_DIR))
41# $(info $(SUBPROJECT_DIR))
42 7
43# Directory common source filess exist 8# Directory common source filess exist
44TOP_DIR = $(tmk_root) 9TOP_DIR = .
45TMK_DIR = tmk_core 10TMK_DIR = tmk_core
46TMK_PATH = $(TOP_DIR)/$(TMK_DIR) 11TMK_PATH = $(TOP_DIR)/$(TMK_DIR)
47LIB_PATH = $(TOP_DIR)/lib 12LIB_PATH = $(TOP_DIR)/lib
@@ -50,92 +15,49 @@ QUANTUM_DIR = quantum
50QUANTUM_PATH = $(TOP_DIR)/$(QUANTUM_DIR) 15QUANTUM_PATH = $(TOP_DIR)/$(QUANTUM_DIR)
51 16
52 17
53ifdef keyboard
54 KEYBOARD ?= $(keyboard)
55endif
56ifdef KEYBOARD_DIR
57 KEYBOARD ?= $(KEYBOARD_DIR)
58endif
59ifndef KEYBOARD
60 KEYBOARD=planck
61endif
62
63MASTER ?= left 18MASTER ?= left
64ifdef master 19ifdef master
65 MASTER = $(master) 20 MASTER = $(master)
66endif 21endif
67 22
23KEYBOARD_PATH := keyboards/$(KEYBOARD)
24KEYBOARD_C := $(KEYBOARD_PATH)/$(KEYBOARD).c
68 25
69# converts things to keyboards/subproject 26ifneq ("$(wildcard $(KEYBOARD_C))","")
70ifneq (,$(findstring /,$(KEYBOARD))) 27 include $(KEYBOARD_PATH)/rules.mk
71 TEMP:=$(KEYBOARD)
72 KEYBOARD:=$(firstword $(subst /, ,$(TEMP)))
73 SUBPROJECT:=$(lastword $(subst /, ,$(TEMP)))
74endif
75
76KEYBOARD_PATH = $(TOP_DIR)/keyboards/$(KEYBOARD)
77
78ifdef sub
79 SUBPROJECT=$(sub)
80endif
81ifdef subproject
82 SUBPROJECT=$(subproject)
83endif
84
85ifneq ("$(wildcard $(KEYBOARD_PATH)/$(KEYBOARD).c)","")
86 KEYBOARD_FILE = keyboards/$(KEYBOARD)/$(KEYBOARD).c
87 ifneq ($(call ESCAPED_ABS_PATH,$(KEYBOARD_PATH)/Makefile),$(starting_makefile))
88 -include $(KEYBOARD_PATH)/Makefile
89 endif
90else 28else
91$(error "$(KEYBOARD_PATH)/$(KEYBOARD).c" does not exist) 29 $(error "$(KEYBOARD_C)" does not exist)
92endif 30endif
93 31
94ifdef SUBPROJECT_DEFAULT 32
95 SUBPROJECT?=$(SUBPROJECT_DEFAULT) 33ifneq ($(SUBPROJECT),)
96endif 34 SUBPROJECT_PATH := keyboards/$(KEYBOARD)/$(SUBPROJECT)
97 35 SUBPROJECT_C := $(SUBPROJECT_PATH)/$(SUBPROJECT).c
98ifdef SUBPROJECT 36 ifneq ("$(wildcard $(SUBPROJECT_C))","")
99 SUBPROJECT_PATH = $(TOP_DIR)/keyboards/$(KEYBOARD)/$(SUBPROJECT) 37 OPT_DEFS += -DSUBPROJECT_$(SUBPROJECT)
100 ifneq ("$(wildcard $(SUBPROJECT_PATH)/$(SUBPROJECT).c)","") 38 include $(SUBPROJECT_PATH)/rules.mk
101 OPT_DEFS += -DSUBPROJECT_$(SUBPROJECT) 39 else
102 SUBPROJECT_FILE = keyboards/$(KEYBOARD)/$(SUBPROJECT)/$(SUBPROJECT).c 40 $(error "$(SUBPROJECT_PATH)/$(SUBPROJECT).c" does not exist)
103 ifneq ($(call ESCAPED_ABS_PATH,$(SUBPROJECT_PATH)/Makefile),$(starting_makefile)) 41 endif
104 -include $(SUBPROJECT_PATH)/Makefile 42endif
105 endif 43
106 else 44MAIN_KEYMAP_PATH := $(KEYBOARD_PATH)/keymaps/$(KEYMAP)
107$(error "$(SUBPROJECT_PATH)/$(SUBPROJECT).c" does not exist) 45MAIN_KEYMAP_C := $(MAIN_KEYMAP_PATH)/keymap.c
108 endif 46SUBPROJ_KEYMAP_PATH := $(SUBPROJECT_PATH)/keymaps/$(KEYMAP)
109endif 47SUBPROJ_KEYMAP_C := $(SUBPROJ_KEYMAP_PATH)/keymap.c
110 48ifneq ("$(wildcard $(SUBPROJ_KEYMAP_C))","")
111ifdef keymap 49 -include $(SUBPROJ_KEYMAP_PATH)/Makefile
112 KEYMAP ?= $(keymap) 50 KEYMAP_C := $(SUBPROJ_KEYMAP_C)
113endif 51 KEYMAP_PATH := $(SUBPROJ_KEYMAP_PATH)
114ifdef KEYMAP_DIR 52else ifneq ("$(wildcard $(MAIN_KEYMAP_C))","")
115 KEYMAP ?= $(KEYMAP_DIR) 53 -include $(MAIN_KEYMAP_PATH)/Makefile
116endif 54 KEYMAP_C := $(MAIN_KEYMAP_C)
117ifndef KEYMAP 55 KEYMAP_PATH := $(MAIN_KEYMAP_PATH)
118 KEYMAP = default 56else
119endif 57 $(error "$(MAIN_KEYMAP_C)/keymap.c" does not exist)
120KEYMAP_PATH = $(KEYBOARD_PATH)/keymaps/$(KEYMAP)
121ifneq ("$(wildcard $(KEYMAP_PATH)/keymap.c)","")
122 KEYMAP_FILE = keyboards/$(KEYBOARD)/keymaps/$(KEYMAP)/keymap.c
123 ifneq ($(call ESCAPED_ABS_PATH,$(KEYMAP_PATH)/Makefile),$(starting_makefile))
124 -include $(KEYMAP_PATH)/Makefile
125 endif
126else
127 ifeq ("$(wildcard $(SUBPROJECT_PATH)/keymaps/$(KEYMAP)/keymap.c)","")
128$(error "$(KEYMAP_PATH)/keymap.c" does not exist)
129 else
130 KEYMAP_PATH = $(SUBPROJECT_PATH)/keymaps/$(KEYMAP)
131 KEYMAP_FILE = keyboards/$(KEYBOARD)/$(SUBPROJECT)/keymaps/$(KEYMAP)/keymap.c
132 ifneq ($(call ESCAPED_ABS_PATH,$(KEYMAP_PATH)/Makefile),$(starting_makefile))
133 -include $(KEYMAP_PATH)/Makefile
134 endif
135 endif
136endif 58endif
137 59
138ifdef SUBPROJECT 60ifneq ($(SUBPROJECT),)
139 TARGET ?= $(KEYBOARD)_$(SUBPROJECT)_$(KEYMAP) 61 TARGET ?= $(KEYBOARD)_$(SUBPROJECT)_$(KEYMAP)
140else 62else
141 TARGET ?= $(KEYBOARD)_$(KEYMAP) 63 TARGET ?= $(KEYBOARD)_$(KEYMAP)
@@ -149,36 +71,27 @@ BUILD_DIR = $(TOP_DIR)/.build
149OBJDIR = $(BUILD_DIR)/obj_$(TARGET) 71OBJDIR = $(BUILD_DIR)/obj_$(TARGET)
150 72
151 73
152
153ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","") 74ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","")
154 CONFIG_H = $(KEYMAP_PATH)/config.h 75 CONFIG_H = $(KEYMAP_PATH)/config.h
155else 76else
156 CONFIG_H = $(KEYBOARD_PATH)/config.h 77 CONFIG_H = $(KEYBOARD_PATH)/config.h
157 ifdef SUBPROJECT 78 ifneq ($(SUBPROJECT),)
158 ifneq ("$(wildcard $(SUBPROJECT_PATH)/$(SUBPROJECT).c)","") 79 ifneq ("$(wildcard $(SUBPROJECT_C))","")
159 CONFIG_H = $(SUBPROJECT_PATH)/config.h 80 CONFIG_H = $(SUBPROJECT_PATH)/config.h
160 endif 81 endif
161 endif 82 endif
162endif 83endif
163 84
164# # project specific files 85# # project specific files
165SRC += $(KEYBOARD_FILE) \ 86SRC += $(KEYBOARD_C) \
166 $(KEYMAP_FILE) \ 87 $(KEYMAP_C) \
167 $(QUANTUM_DIR)/quantum.c \ 88 $(QUANTUM_DIR)/quantum.c \
168 $(QUANTUM_DIR)/keymap_common.c \ 89 $(QUANTUM_DIR)/keymap_common.c \
169 $(QUANTUM_DIR)/keycode_config.c \ 90 $(QUANTUM_DIR)/keycode_config.c \
170 $(QUANTUM_DIR)/process_keycode/process_leader.c 91 $(QUANTUM_DIR)/process_keycode/process_leader.c
171 92
172ifdef SUBPROJECT 93ifneq ($(SUBPROJECT),)
173 SRC += $(SUBPROJECT_FILE) 94 SRC += $(SUBPROJECT_C)
174endif
175
176ifdef SUBPROJECT
177 SRC += $(SUBPROJECT_FILE)
178endif
179
180ifdef SUBPROJECT
181 SRC += $(SUBPROJECT_FILE)
182endif 95endif
183 96
184ifndef CUSTOM_MATRIX 97ifndef CUSTOM_MATRIX
@@ -229,7 +142,7 @@ endif
229 142
230# Search Path 143# Search Path
231VPATH += $(KEYMAP_PATH) 144VPATH += $(KEYMAP_PATH)
232ifdef SUBPROJECT 145ifneq ($(SUBPROJECT),)
233 VPATH += $(SUBPROJECT_PATH) 146 VPATH += $(SUBPROJECT_PATH)
234endif 147endif
235VPATH += $(KEYBOARD_PATH) 148VPATH += $(KEYBOARD_PATH)
diff --git a/message.mk b/message.mk
index 2ebf76a58..08a4e02ab 100644
--- a/message.mk
+++ b/message.mk
@@ -32,4 +32,5 @@ PRINT_WARNING = ($(SILENT) || printf " $(WARN_STRING)" | $(AWK_STATUS)) && $(TAB
32PRINT_ERROR_PLAIN = ($(SILENT) ||printf " $(ERROR_STRING)" | $(AWK_STATUS)) && $(TAB_LOG_PLAIN) && exit 1 32PRINT_ERROR_PLAIN = ($(SILENT) ||printf " $(ERROR_STRING)" | $(AWK_STATUS)) && $(TAB_LOG_PLAIN) && exit 1
33PRINT_WARNING_PLAIN = ($(SILENT) || printf " $(WARN_STRING)" | $(AWK_STATUS)) && $(TAB_LOG_PLAIN) 33PRINT_WARNING_PLAIN = ($(SILENT) || printf " $(WARN_STRING)" | $(AWK_STATUS)) && $(TAB_LOG_PLAIN)
34PRINT_OK = $(SILENT) || printf " $(OK_STRING)" | $(AWK_STATUS) 34PRINT_OK = $(SILENT) || printf " $(OK_STRING)" | $(AWK_STATUS)
35BUILD_CMD = LOG=$$($(CMD) 2>&1) ; if [ $$? -gt 0 ]; then $(PRINT_ERROR); elif [ "$$LOG" != "" ] ; then $(PRINT_WARNING); else $(PRINT_OK); fi; \ No newline at end of file 35BUILD_CMD = LOG=$$($(CMD) 2>&1) ; if [ $$? -gt 0 ]; then $(PRINT_ERROR); elif [ "$$LOG" != "" ] ; then $(PRINT_WARNING); else $(PRINT_OK); fi;
36MSG_NO_CMP = $(ERROR_COLOR)Error:$(NO_COLOR)$(BOLD) cmp command not found, please install diffutils\n$(NO_COLOR) \ No newline at end of file