new_keyboard.sh 4.8 KB

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