A better new_project.sh (#5191)
* A better new_project.sh * Fix docstrings * Use single quotes for anything not shown to user * Missed this docstring * Simplify get_git_username() Thanks @vomindoraan * chmod +x * Add docstring for print_error() * Break up git username call into multiple lines * Use with statement here * Conform to PEP 8 even more * Turn it back into a shell script * chmod +x again * Update docs to reflect new keyboard generator usage * Tweak wording slightly * Trim trailing whitespace * Don't actually need to escape the newlines here * As I suspected, you can pass shift a number * Prepend ./ to match the other code block * Minor syntax tweaks * The username token has changed * Replace name in the readme too * Make some reasonable assumptions about the presence of Gitplanck-ez-a5-high
parent
c3be0520c4
commit
53c51f1d16
@ -0,0 +1,159 @@ |
||||
#!/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() { |
||||
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}/template.c" "${keyboard_dir}/${keyboard_name}.c" |
||||
mv "${keyboard_dir}/template.h" "${keyboard_dir}/${keyboard_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 %KEYBOARD% with the keyboard name. |
||||
replace_keyboard_placeholders() { |
||||
local replace_keyboard_filenames=( |
||||
"${keyboard_dir}/config.h" |
||||
"${keyboard_dir}/readme.md" |
||||
"${keyboard_dir}/${keyboard_name}.c" |
||||
"${keyboard_dir}/keymaps/default/readme.md" |
||||
) |
||||
replace_placeholders "%KEYBOARD%" "$keyboard_name" "${replace_keyboard_filenames[@]}" |
||||
} |
||||
|
||||
# Replace %YOUR_NAME% with the username. |
||||
replace_name_placeholders() { |
||||
local replace_name_filenames=( |
||||
"${keyboard_dir}/config.h" |
||||
"${keyboard_dir}/readme.md" |
||||
"${keyboard_dir}/${keyboard_name}.c" |
||||
"${keyboard_dir}/${keyboard_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 |
||||
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_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." |
@ -1,70 +0,0 @@ |
||||
#!/bin/sh |
||||
# Script to make a new quantum project |
||||
# Jack Humbert 2015 |
||||
|
||||
KEYBOARD=$1 |
||||
KEYBOARD_TYPE=$2 |
||||
|
||||
if [ -z "$KEYBOARD" ]; then |
||||
echo "Usage: $0 <keyboard_name> <keyboard_type>" |
||||
echo "Example: $0 gh60 avr" |
||||
echo "Example: $0 bfake ps2avrgb" |
||||
exit 1 |
||||
elif [ -z "$KEYBOARD_TYPE" ]; then |
||||
KEYBOARD_TYPE=avr |
||||
fi |
||||
|
||||
if [ "$KEYBOARD_TYPE" != "avr" ] && [ "$KEYBOARD_TYPE" != "ps2avrgb" ]; then |
||||
echo "Invalid keyboard type target" |
||||
exit 1 |
||||
fi |
||||
|
||||
if [ -e "keyboards/$1" ]; then |
||||
echo "Error! keyboards/$1 already exists!" |
||||
exit 1 |
||||
fi |
||||
|
||||
cd "$(dirname "$0")/.." || exit |
||||
|
||||
KEYBOARD_NAME=$(basename "$1") |
||||
KEYBOARD_NAME_UPPERCASE=$(echo "$KEYBOARD_NAME" | awk '{print toupper($0)}') |
||||
NEW_KBD=keyboards/${KEYBOARD} |
||||
|
||||
|
||||
cp -r quantum/template/base "$NEW_KBD" |
||||
cp -r "quantum/template/$KEYBOARD_TYPE/." "$NEW_KBD" |
||||
|
||||
mv "${NEW_KBD}/template.c" "${NEW_KBD}/${KEYBOARD_NAME}.c" |
||||
mv "${NEW_KBD}/template.h" "${NEW_KBD}/${KEYBOARD_NAME}.h" |
||||
find "${NEW_KBD}" -type f -exec sed -i '' -e "s;%KEYBOARD%;${KEYBOARD_NAME};g" {} \; |
||||
find "${NEW_KBD}" -type f -exec sed -i '' -e "s;%KEYBOARD_UPPERCASE%;${KEYBOARD_NAME_UPPERCASE};g" {} \; |
||||
|
||||
GIT=$(whereis git) |
||||
if [ "$GIT" != "" ]; then |
||||
IS_GIT_REPO=$($GIT log >>/dev/null 2>&1; echo $?) |
||||
if [ "$IS_GIT_REPO" -eq 0 ]; then |
||||
ID="$($GIT config --get user.name)" |
||||
read -rp "What is your name? [$ID] " YOUR_NAME |
||||
if [ -n "$YOUR_NAME" ]; then |
||||
ID=$YOUR_NAME |
||||
fi |
||||
echo "Using $ID as user name" |
||||
|
||||
for i in "$NEW_KBD/config.h" \ |
||||
"$NEW_KBD/$KEYBOARD_NAME.c" \ |
||||
"$NEW_KBD/$KEYBOARD_NAME.h" \ |
||||
"$NEW_KBD/keymaps/default/config.h" \ |
||||
"$NEW_KBD/keymaps/default/keymap.c" |
||||
do |
||||
awk -v id="$ID" '{sub(/%YOUR_NAME%/,id); print}' < "$i" > "$i.$$" |
||||
mv "$i.$$" "$i" |
||||
done |
||||
fi |
||||
fi |
||||
|
||||
cat <<-EOF |
||||
###################################################### |
||||
# $NEW_KBD project created. To start |
||||
# working on things, cd into $NEW_KBD |
||||
###################################################### |
||||
EOF |
Loading…
Reference in new issue