aboutsummaryrefslogtreecommitdiff
path: root/build_keyboard.mk
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 /build_keyboard.mk
parentdb5c3b74fb6541879bfad9930d2a659b1d89cd83 (diff)
downloadqmk_firmware-67b294ca66fd9da341ab93019a380d91ac589c96.tar.gz
qmk_firmware-67b294ca66fd9da341ab93019a380d91ac589c96.zip
Actual compilation
Diffstat (limited to 'build_keyboard.mk')
-rw-r--r--build_keyboard.mk171
1 files changed, 42 insertions, 129 deletions
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)