]> git.donarmstrong.com Git - qmk_firmware.git/blob - util/new_keyboard.sh
Software backlight improvements (#7255)
[qmk_firmware.git] / util / new_keyboard.sh
1 #!/bin/bash
2
3 # This script generates a new keyboard directory under keyboards/,
4 # and copies the template files from quantum/template/ into it.
5
6 # Print an error message with the word "ERROR" in red.
7 echo_error() {
8     echo -e "[\033[0;91mERROR\033[m]: $1"
9 }
10
11 # Print a message in bold.
12 echo_bold() {
13     echo -e "\033[1m$1\033[m"
14 }
15
16 # Prompt the user for information, showing the default value in brackets.
17 prompt() {
18     local message="$1"
19     local default="$2"
20
21     [ -n "$default" ] && message+=" [$default]"
22     message+=": "
23
24     read -rp "$message" prompt_return
25     [ -z "$prompt_return" ] && prompt_return="$default"
26 }
27
28 # Grab a username from Git config.
29 set_git_username() {
30     git_username="$(git config --get user.name)"
31 }
32
33 # Copy the template files to the new keyboard directory.
34 copy_templates() {
35     echo -n "Copying base template files..."
36     cp -r "quantum/template/base" "${keyboard_dir}"
37     echo " done"
38
39     echo -n "Copying $keyboard_type template files..."
40     cp -r "quantum/template/${keyboard_type}/." "${keyboard_dir}"
41     echo " done"
42
43     echo -n "Renaming keyboard files..."
44     mv "${keyboard_dir}/keyboard.c" "${keyboard_dir}/${keyboard_name}.c"
45     mv "${keyboard_dir}/keyboard.h" "${keyboard_dir}/${keyboard_name}.h"
46     echo " done"
47 }
48
49 # Set the inplace editing parameter for sed.
50 # macOS/BSD sed expects a file extension immediately following -i.
51 set_sed_i() {
52     sed_i=(-i)
53
54     case $(uname -a) in
55         *Darwin*) sed_i=(-i "")
56     esac
57 }
58
59 # Replace a token with a value in the given list of files.
60 replace_placeholders() {
61     local replace_token="$1"
62     local replace_value="$2"
63     shift 2
64     local replace_filenames=("$@")
65
66     echo -n "Replacing $replace_token with $replace_value..."
67     for replace_filename in "${replace_filenames[@]}"; do
68         sed "${sed_i[@]}" -e "s/${replace_token}/${replace_value}/g" "$replace_filename"
69     done
70     echo " done"
71 }
72
73 # Replace %YEAR% with the current year.
74 replace_year_placeholders() {
75     local replace_year_filenames=(
76         "${keyboard_dir}/config.h"
77         "${keyboard_dir}/${keyboard_name}.c"
78         "${keyboard_dir}/${keyboard_name}.h"
79         "${keyboard_dir}/keymaps/default/config.h"
80         "${keyboard_dir}/keymaps/default/keymap.c"
81     )
82     replace_placeholders "%YEAR%" "$(date +%Y)" "${replace_year_filenames[@]}"
83 }
84
85 # Replace %KEYBOARD% with the keyboard name.
86 replace_keyboard_placeholders() {
87     local replace_keyboard_filenames=(
88         "${keyboard_dir}/config.h"
89         "${keyboard_dir}/info.json"
90         "${keyboard_dir}/readme.md"
91         "${keyboard_dir}/${keyboard_name}.c"
92         "${keyboard_dir}/keymaps/default/readme.md"
93     )
94     replace_placeholders "%KEYBOARD%" "$keyboard_name" "${replace_keyboard_filenames[@]}"
95 }
96
97 # Replace %YOUR_NAME% with the username.
98 replace_name_placeholders() {
99     local replace_name_filenames=(
100         "${keyboard_dir}/config.h"
101         "${keyboard_dir}/info.json"
102         "${keyboard_dir}/readme.md"
103         "${keyboard_dir}/${keyboard_name}.c"
104         "${keyboard_dir}/${keyboard_name}.h"
105         "${keyboard_dir}/keymaps/default/config.h"
106         "${keyboard_dir}/keymaps/default/keymap.c"
107     )
108     replace_placeholders "%YOUR_NAME%" "$username" "${replace_name_filenames[@]}"
109 }
110
111 # Check if an array contains an element.
112 array_contains() {
113     local e match="$1"
114     shift
115     for e; do
116         [[ "$e" == "$match" ]] && return 0;
117     done
118
119     return 1
120 }
121
122 # If we've been started from util/, we want to be in qmk_firmware/
123 [[ "$PWD" == *util ]] && cd ..
124
125 # The root qmk_firmware/ directory should have a subdirectory called quantum/
126 if [ ! -d "quantum" ]; then
127     echo_error "Could not detect the QMK firmware directory!"
128     echo_error "Are you sure you're in the right place?"
129     exit 1
130 fi
131
132 echo_bold "Generating a new QMK keyboard directory"
133 echo
134
135 # Keyboard name is required, so keep prompting until we get one
136 while [ -z "$keyboard_name" ]; do
137     prompt "Keyboard Name" ""
138     keyboard_name=$prompt_return
139 done
140
141 keyboard_dir="keyboards/$keyboard_name"
142
143 if [ -d "$keyboard_dir" ]; then
144     echo_error "Keyboard $keyboard_name already exists!"
145     exit 1
146 fi
147
148 KEYBOARD_TYPES=("avr" "ps2avrgb")
149
150 prompt "Keyboard Type" "avr"
151 keyboard_type=$prompt_return
152
153 if ! array_contains "$keyboard_type" "${KEYBOARD_TYPES[@]}"; then
154     echo_error "Keyboard type must be one of: ${KEYBOARD_TYPES[*]}"
155     exit 1
156 fi
157
158 set_git_username
159 prompt "Your Name" "$git_username"
160 username=$prompt_return
161
162 echo
163
164 copy_templates
165 set_sed_i
166 replace_year_placeholders
167 replace_keyboard_placeholders
168 [ -n "$username" ] && replace_name_placeholders
169
170 echo
171 echo_bold "Created a new keyboard called $keyboard_name."
172 echo
173 echo_bold "To start working on things, cd into keyboards/$keyboard_name,"
174 echo_bold "or open the directory in your favourite text editor."