aboutsummaryrefslogtreecommitdiff
path: root/Makefile
diff options
context:
space:
mode:
Diffstat (limited to 'Makefile')
-rw-r--r--Makefile68
1 files changed, 63 insertions, 5 deletions
diff --git a/Makefile b/Makefile
index ffbdf742c..72710c2d9 100644
--- a/Makefile
+++ b/Makefile
@@ -10,19 +10,32 @@ abs_tmk_root := $(patsubst %/,%,$(dir $(mkfile_path)))
10ifneq (,$(findstring /keyboards/,$(starting_makefile))) 10ifneq (,$(findstring /keyboards/,$(starting_makefile)))
11 possible_keyboard:=$(patsubst %/,%,$(dir $(patsubst $(abs_tmk_root)/keyboards/%,%,$(starting_makefile)))) 11 possible_keyboard:=$(patsubst %/,%,$(dir $(patsubst $(abs_tmk_root)/keyboards/%,%,$(starting_makefile))))
12 ifneq (,$(findstring /keymaps/,$(possible_keyboard))) 12 ifneq (,$(findstring /keymaps/,$(possible_keyboard)))
13 KEYBOARD_DIR:=$(firstword $(subst /keymaps/, ,$(possible_keyboard)))
14 KEYMAP_DIR:=$(lastword $(subst /keymaps/, ,$(possible_keyboard))) 13 KEYMAP_DIR:=$(lastword $(subst /keymaps/, ,$(possible_keyboard)))
15 tmk_root = ../../../.. 14 KEYBOARD_DIR:=$(firstword $(subst /keymaps/, ,$(possible_keyboard)))
15 ifneq (,$(findstring /,$(KEYBOARD_DIR)))
16 # SUBPROJECT_DIR:=$(lastword $(subst /, ,$(KEYBOARD_DIR)))
17 # KEYBOARD_DIR:=$(firstword $(subst /, ,$(KEYBOARD_DIR)))
18 tmk_root = ../../..
19 else
20 tmk_root = ../../../..
21 endif
16 else 22 else
17 KEYBOARD_DIR:=$(possible_keyboard)
18 KEYMAP_DIR:=default 23 KEYMAP_DIR:=default
19 tmk_root = ../.. 24 KEYBOARD_DIR:=$(possible_keyboard)
25 ifneq (,$(findstring /,$(KEYBOARD_DIR)))
26 # SUBPROJECT_DIR:=$(lastword $(subst /, ,$(KEYBOARD_DIR)))
27 # KEYBOARD_DIR:=$(firstword $(subst /, ,$(KEYBOARD_DIR)))
28 tmk_root = ../../..
29 else
30 tmk_root = ../..
31 endif
20 endif 32 endif
21else 33else
22 tmk_root = . 34 tmk_root = .
23endif 35endif
24# $(info $(KEYBOARD_DIR)) 36# $(info $(KEYBOARD_DIR))
25# $(info $(KEYMAP_DIR)) 37# $(info $(KEYMAP_DIR))
38# $(info $(SUBPROJECT_DIR))
26 39
27# Directory common source filess exist 40# Directory common source filess exist
28TOP_DIR = $(tmk_root) 41TOP_DIR = $(tmk_root)
@@ -32,6 +45,7 @@ TMK_PATH = $(TOP_DIR)/$(TMK_DIR)
32QUANTUM_DIR = quantum 45QUANTUM_DIR = quantum
33QUANTUM_PATH = $(TOP_DIR)/$(QUANTUM_DIR) 46QUANTUM_PATH = $(TOP_DIR)/$(QUANTUM_DIR)
34 47
48
35ifdef keyboard 49ifdef keyboard
36 KEYBOARD ?= $(keyboard) 50 KEYBOARD ?= $(keyboard)
37endif 51endif
@@ -41,7 +55,16 @@ endif
41ifndef KEYBOARD 55ifndef KEYBOARD
42 KEYBOARD=planck 56 KEYBOARD=planck
43endif 57endif
58
59# converts things to keyboards/subproject
60ifneq (,$(findstring /,$(KEYBOARD)))
61 TEMP:=$(KEYBOARD)
62 KEYBOARD:=$(firstword $(subst /, ,$(TEMP)))
63 SUBPROJECT:=$(lastword $(subst /, ,$(TEMP)))
64endif
65
44KEYBOARD_PATH = $(TOP_DIR)/keyboards/$(KEYBOARD) 66KEYBOARD_PATH = $(TOP_DIR)/keyboards/$(KEYBOARD)
67
45ifneq ("$(wildcard $(KEYBOARD_PATH)/$(KEYBOARD).c)","") 68ifneq ("$(wildcard $(KEYBOARD_PATH)/$(KEYBOARD).c)","")
46 KEYBOARD_FILE = keyboards/$(KEYBOARD)/$(KEYBOARD).c 69 KEYBOARD_FILE = keyboards/$(KEYBOARD)/$(KEYBOARD).c
47 ifndef ARCH 70 ifndef ARCH
@@ -51,6 +74,28 @@ else
51$(error "$(KEYBOARD_PATH)/$(KEYBOARD).c" does not exist) 74$(error "$(KEYBOARD_PATH)/$(KEYBOARD).c" does not exist)
52endif 75endif
53 76
77ifdef sub
78 SUBPROJECT=$(sub)
79endif
80ifdef subproject
81 SUBPROJECT=$(subproject)
82endif
83
84ifdef SUBPROJECT_DEFAULT
85 SUBPROJECT?=$(SUBPROJECT_DEFAULT)
86endif
87
88ifdef SUBPROJECT
89 SUBPROJECT_PATH = $(TOP_DIR)/keyboards/$(KEYBOARD)/$(SUBPROJECT)
90 ifneq ("$(wildcard $(SUBPROJECT_PATH)/$(SUBPROJECT).c)","")
91 OPT_DEFS += -DSUBPROJECT_$(SUBPROJECT)
92 SUBPROJECT_FILE = keyboards/$(KEYBOARD)/$(SUBPROJECT)/$(SUBPROJECT).c
93 -include $(SUBPROJECT_PATH)/Makefile
94 else
95$(error "$(SUBPROJECT_PATH)/$(SUBPROJECT).c" does not exist)
96 endif
97endif
98
54ifdef keymap 99ifdef keymap
55 KEYMAP ?= $(keymap) 100 KEYMAP ?= $(keymap)
56endif 101endif
@@ -68,7 +113,13 @@ else
68$(error "$(KEYMAP_PATH)/keymap.c" does not exist) 113$(error "$(KEYMAP_PATH)/keymap.c" does not exist)
69endif 114endif
70 115
71TARGET ?= $(KEYBOARD)_$(KEYMAP) 116ifdef SUBPROJECT
117 TARGET ?= $(KEYBOARD)_$(SUBPROJECT)_$(KEYMAP)
118else
119 TARGET ?= $(KEYBOARD)_$(KEYMAP)
120endif
121
122
72 123
73ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","") 124ifneq ("$(wildcard $(KEYMAP_PATH)/config.h)","")
74 CONFIG_H = $(KEYMAP_PATH)/config.h 125 CONFIG_H = $(KEYMAP_PATH)/config.h
@@ -83,6 +134,10 @@ SRC += $(KEYBOARD_FILE) \
83 $(QUANTUM_DIR)/keymap.c \ 134 $(QUANTUM_DIR)/keymap.c \
84 $(QUANTUM_DIR)/keycode_config.c 135 $(QUANTUM_DIR)/keycode_config.c
85 136
137ifdef SUBPROJECT
138 SRC += $(SUBPROJECT_FILE)
139endif
140
86ifndef CUSTOM_MATRIX 141ifndef CUSTOM_MATRIX
87 SRC += $(QUANTUM_DIR)/matrix.c 142 SRC += $(QUANTUM_DIR)/matrix.c
88endif 143endif
@@ -104,6 +159,9 @@ endif
104 159
105# Search Path 160# Search Path
106VPATH += $(KEYMAP_PATH) 161VPATH += $(KEYMAP_PATH)
162ifdef SUBPROJECT
163 VPATH += $(SUBPROJECT_PATH)
164endif
107VPATH += $(KEYBOARD_PATH) 165VPATH += $(KEYBOARD_PATH)
108VPATH += $(TOP_DIR) 166VPATH += $(TOP_DIR)
109VPATH += $(TMK_PATH) 167VPATH += $(TMK_PATH)