mirror of
https://github.com/qmk/qmk_firmware
synced 2024-11-15 00:15:03 +00:00
59b017381c
* Add creation of new chlid keyboard * Add creation of new keyboard's parent directories * Remove redundant message and if statement * Divide creating new keyboard directory from copying template files * Fix variables of year placeholder * Fix filename of keyboard.[ch]
177 lines
4.8 KiB
Bash
Executable file
177 lines
4.8 KiB
Bash
Executable file
#!/bin/bash
|
|
|
|
# This script generates a new keyboard directory under keyboards/,
|
|
# and copies the template files from quantum/template/ into it.
|
|
|
|
# Print an error message with the word "ERROR" in red.
|
|
echo_error() {
|
|
echo -e "[\033[0;91mERROR\033[m]: $1"
|
|
}
|
|
|
|
# Print a message in bold.
|
|
echo_bold() {
|
|
echo -e "\033[1m$1\033[m"
|
|
}
|
|
|
|
# Prompt the user for information, showing the default value in brackets.
|
|
prompt() {
|
|
local message="$1"
|
|
local default="$2"
|
|
|
|
[ -n "$default" ] && message+=" [$default]"
|
|
message+=": "
|
|
|
|
read -rp "$message" prompt_return
|
|
[ -z "$prompt_return" ] && prompt_return="$default"
|
|
}
|
|
|
|
# Grab a username from Git config.
|
|
set_git_username() {
|
|
git_username="$(git config --get user.name)"
|
|
}
|
|
|
|
# Copy the template files to the new keyboard directory.
|
|
copy_templates() {
|
|
mkdir -p "$keyboard_dir"
|
|
|
|
echo -n "Copying base template files..."
|
|
cp -r "quantum/template/base/." "${keyboard_dir}"
|
|
echo " done"
|
|
|
|
echo -n "Copying $keyboard_type template files..."
|
|
cp -r "quantum/template/${keyboard_type}/." "${keyboard_dir}"
|
|
echo " done"
|
|
|
|
echo -n "Renaming keyboard files..."
|
|
mv "${keyboard_dir}/keyboard.c" "${keyboard_dir}/${keyboard_base_name}.c"
|
|
mv "${keyboard_dir}/keyboard.h" "${keyboard_dir}/${keyboard_base_name}.h"
|
|
echo " done"
|
|
}
|
|
|
|
# Set the inplace editing parameter for sed.
|
|
# macOS/BSD sed expects a file extension immediately following -i.
|
|
set_sed_i() {
|
|
sed_i=(-i)
|
|
|
|
case $(uname -a) in
|
|
*Darwin*) sed_i=(-i "")
|
|
esac
|
|
}
|
|
|
|
# Replace a token with a value in the given list of files.
|
|
replace_placeholders() {
|
|
local replace_token="$1"
|
|
local replace_value="$2"
|
|
shift 2
|
|
local replace_filenames=("$@")
|
|
|
|
echo -n "Replacing $replace_token with $replace_value..."
|
|
for replace_filename in "${replace_filenames[@]}"; do
|
|
sed "${sed_i[@]}" -e "s/${replace_token}/${replace_value}/g" "$replace_filename"
|
|
done
|
|
echo " done"
|
|
}
|
|
|
|
# Replace %YEAR% with the current year.
|
|
replace_year_placeholders() {
|
|
local replace_year_filenames=(
|
|
"${keyboard_dir}/config.h"
|
|
"${keyboard_dir}/${keyboard_base_name}.c"
|
|
"${keyboard_dir}/${keyboard_base_name}.h"
|
|
"${keyboard_dir}/keymaps/default/config.h"
|
|
"${keyboard_dir}/keymaps/default/keymap.c"
|
|
)
|
|
replace_placeholders "%YEAR%" "$(date +%Y)" "${replace_year_filenames[@]}"
|
|
}
|
|
|
|
# Replace %KEYBOARD% with the keyboard name.
|
|
replace_keyboard_placeholders() {
|
|
local replace_keyboard_filenames=(
|
|
"${keyboard_dir}/config.h"
|
|
"${keyboard_dir}/info.json"
|
|
"${keyboard_dir}/readme.md"
|
|
"${keyboard_dir}/${keyboard_base_name}.c"
|
|
"${keyboard_dir}/keymaps/default/readme.md"
|
|
)
|
|
replace_placeholders "%KEYBOARD%" "$keyboard_base_name" "${replace_keyboard_filenames[@]}"
|
|
}
|
|
|
|
# Replace %YOUR_NAME% with the username.
|
|
replace_name_placeholders() {
|
|
local replace_name_filenames=(
|
|
"${keyboard_dir}/config.h"
|
|
"${keyboard_dir}/info.json"
|
|
"${keyboard_dir}/readme.md"
|
|
"${keyboard_dir}/${keyboard_base_name}.c"
|
|
"${keyboard_dir}/${keyboard_base_name}.h"
|
|
"${keyboard_dir}/keymaps/default/config.h"
|
|
"${keyboard_dir}/keymaps/default/keymap.c"
|
|
)
|
|
replace_placeholders "%YOUR_NAME%" "$username" "${replace_name_filenames[@]}"
|
|
}
|
|
|
|
# Check if an array contains an element.
|
|
array_contains() {
|
|
local e match="$1"
|
|
shift
|
|
for e; do
|
|
[[ "$e" == "$match" ]] && return 0;
|
|
done
|
|
|
|
return 1
|
|
}
|
|
|
|
# If we've been started from util/, we want to be in qmk_firmware/
|
|
[[ "$PWD" == *util ]] && cd ..
|
|
|
|
# The root qmk_firmware/ directory should have a subdirectory called quantum/
|
|
if [ ! -d "quantum" ]; then
|
|
echo_error "Could not detect the QMK firmware directory!"
|
|
echo_error "Are you sure you're in the right place?"
|
|
exit 1
|
|
fi
|
|
|
|
echo_bold "Generating a new QMK keyboard directory"
|
|
echo
|
|
|
|
# Keyboard name is required, so keep prompting until we get one
|
|
while [ -z "$keyboard_name" ]; do
|
|
prompt "Keyboard Name" ""
|
|
keyboard_name=$prompt_return
|
|
keyboard_base_name=$(basename $keyboard_name)
|
|
done
|
|
|
|
keyboard_dir="keyboards/$keyboard_name"
|
|
|
|
if [ -d "$keyboard_dir" ]; then
|
|
echo_error "Keyboard $keyboard_name already exists!"
|
|
exit 1
|
|
fi
|
|
|
|
KEYBOARD_TYPES=("avr" "ps2avrgb")
|
|
|
|
prompt "Keyboard Type" "avr"
|
|
keyboard_type=$prompt_return
|
|
|
|
if ! array_contains "$keyboard_type" "${KEYBOARD_TYPES[@]}"; then
|
|
echo_error "Keyboard type must be one of: ${KEYBOARD_TYPES[*]}"
|
|
exit 1
|
|
fi
|
|
|
|
set_git_username
|
|
prompt "Your Name" "$git_username"
|
|
username=$prompt_return
|
|
|
|
echo
|
|
|
|
copy_templates
|
|
set_sed_i
|
|
replace_year_placeholders
|
|
replace_keyboard_placeholders
|
|
[ -n "$username" ] && replace_name_placeholders
|
|
|
|
echo
|
|
echo_bold "Created a new keyboard called $keyboard_name."
|
|
echo
|
|
echo_bold "To start working on things, cd into keyboards/$keyboard_name,"
|
|
echo_bold "or open the directory in your favourite text editor."
|