Initial setup.sh version.
This commit is contained in:
parent
7b3bd01d9b
commit
e9c2b84c82
1 changed files with 104 additions and 0 deletions
104
docs/static/setup.sh
vendored
Normal file
104
docs/static/setup.sh
vendored
Normal file
|
@ -0,0 +1,104 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
repo_path="https://github.com/zmkfirmware/zmk-config-split-template.git"
|
||||||
|
title="ZMK Config Setup:"
|
||||||
|
|
||||||
|
|
||||||
|
# TODO: Check for git being installed
|
||||||
|
# TODO: Check for user.name and user.email git configs being set
|
||||||
|
|
||||||
|
prompt="Pick an MCU board:"
|
||||||
|
options=("nice!nano" "QMK Proton-C")
|
||||||
|
|
||||||
|
echo "$title"
|
||||||
|
echo ""
|
||||||
|
echo "MCU Board Selection:"
|
||||||
|
PS3="$prompt "
|
||||||
|
select opt in "${options[@]}" "Quit"; do
|
||||||
|
|
||||||
|
case "$REPLY" in
|
||||||
|
|
||||||
|
1 ) board="nice_nano"; break;;
|
||||||
|
2 ) board="proton_c"; break;;
|
||||||
|
|
||||||
|
$(( ${#options[@]}+1 )) ) echo "Goodbye!"; exit;;
|
||||||
|
*) echo "Invalid option. Try another one.";continue;;
|
||||||
|
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
#read -p "Is this board a complete keyboard [yN]: " complete
|
||||||
|
#echo "$complete"
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "Keyboard Shield Selection:"
|
||||||
|
|
||||||
|
prompt="Pick an keyboard:"
|
||||||
|
options=("Kyria" "Lily58")
|
||||||
|
|
||||||
|
PS3="$prompt "
|
||||||
|
select opt in "${options[@]}" "Other" "Quit"; do
|
||||||
|
|
||||||
|
case "$REPLY" in
|
||||||
|
|
||||||
|
1 ) shield_title="Kyria" shield="kyria"; split="y"; break;;
|
||||||
|
2 ) shield_title="Lily58" shield="lily58"; split="y"; break;;
|
||||||
|
|
||||||
|
# Add link to docs on adding your own custom shield in your ZMK config!
|
||||||
|
$(( ${#options[@]}+1 )) ) echo "Other!"; break;;
|
||||||
|
$(( ${#options[@]}+2 )) ) echo "Goodbye!"; exit;;
|
||||||
|
*) echo "Invalid option. Try another one.";continue;;
|
||||||
|
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
read -p "GitHub Username (leave empty to skip GitHub repo creation): " github_user
|
||||||
|
if [ -n "$github_user" ]; then
|
||||||
|
read -p "GitHub Repo Name [zmk-config]: " repo_name
|
||||||
|
if [ -z "$repo_name" ]; then repo_name="zmk-config"; fi
|
||||||
|
|
||||||
|
read -p "GitHub Repo [https://github.com/${github_user}/${repo_name}.git]: " github_repo
|
||||||
|
|
||||||
|
if [ -z "$github_repo" ]; then github_repo="https://github.com/${github_user}/${repo_name}.git"; fi
|
||||||
|
else
|
||||||
|
repo_name="zmk-config"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
echo "Preparing a user config for:"
|
||||||
|
echo "* MCU Board: ${board}"
|
||||||
|
echo "* Shield: ${shield}"
|
||||||
|
if [ -n "$github_repo" ]; then
|
||||||
|
echo "* GitHub Repo To Push (please create this in GH first!): ${github_repo}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
read -p "Continue? [Yn]: " do_it
|
||||||
|
|
||||||
|
if [ -n "$do_it" ] && [ "$do_it" != "y" ]; then
|
||||||
|
echo "Aborting..."
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
git clone --single-branch $repo_path ${repo_name}
|
||||||
|
cd ${repo_name}
|
||||||
|
|
||||||
|
sed -i \
|
||||||
|
-e "s/BOARD_NAME/$board/" \
|
||||||
|
-e "s/SHIELD_NAME/$shield/" \
|
||||||
|
-e "s/KEYBOARD_TITLE/$shield_title/" \
|
||||||
|
.github/workflows/build.yml
|
||||||
|
|
||||||
|
mv config/prj.conf "config/${shield}.conf"
|
||||||
|
|
||||||
|
rm -rf .git
|
||||||
|
git init .
|
||||||
|
git add .
|
||||||
|
git commit -m "Initial User Config."
|
||||||
|
|
||||||
|
if [ -n "$github_repo" ]; then
|
||||||
|
git remote add origin "$github_repo"
|
||||||
|
git push --set-upstream origin $(git branch --show-current)
|
||||||
|
fi
|
Loading…
Reference in a new issue