-
Notifications
You must be signed in to change notification settings - Fork 21
/
install-afc.sh
executable file
·316 lines (275 loc) · 11.2 KB
/
install-afc.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
#!/usr/bin/env bash
# Armored Turtle Automated Filament Changer
#
# Copyright (C) 2024 Armored Turtle
#
# This file may be distributed under the terms of the GNU GPLv3 license.
set -e
export LC_ALL=C
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
for include_file in "${SCRIPT_DIR}/include/"*; do
source "$include_file"
done
# Debugging: Check if the directory exists
if [ ! -d "${AFC_PATH}/include/" ]; then
echo "Directory ${AFC_PATH}/include/ does not exist."
exit 1
fi
# Debugging: Check if there are any files in the directory
if [ -z "$(ls -A "${AFC_PATH}/include/")" ]; then
echo "No files found in ${AFC_PATH}/include/"
exit 1
fi
install_type() {
while true; do
echo -ne "
${PROMPT}Please select your installation type:
${CYAN}1) Box Turtle
${CYAN}2) Exit
${PROMPT}Please select an option: ${RESET}"
read -r input
case $input in
1) INSTALLATION_TYPE="Box_Turtle"; break ;;
2) echo "Exiting..."; exit 0 ;;
*) echo "Invalid selection. Please try again." ;;
esac
done
}
choose_board_type() {
while true; do
echo -ne "
${PROMPT}Please select your board type:
${CYAN}1) AFC-Lite
${CYAN}2) MMB v1.0
${CYAN}3) MMB v1.1
${CYAN}4) Exit
${PROMPT}Please select an option: ${RESET}"
read -r input
case $input in
1) BOARD_TYPE="AFC_Lite"; break ;;
2) BOARD_TYPE="MMB_1.0"; break ;;
3) BOARD_TYPE="MMB_1.1"; break ;;
4) echo "Exiting..."; exit 0 ;;
*) echo "Invalid selection" ;;
esac
done
}
toolhead_pin() {
while true; do
echo -ne "
${PROMPT}Please enter your toolhead sensor pin (if known).
${PROMPT}This should be in the format of 'MCU:Pin' (e.g 'EBBCan:PB2').
${ERROR}This is required to be set.
${PROMPT}Press enter if unknown.
${PROMPT}Pin: ${RESET}"
read -r input
TOOLHEAD_PIN=${input:-"UNKNOWN"}
break
done
}
buffer_system() {
while true; do
echo -ne "
${PROMPT}Please select your buffer system:
${CYAN}1) TurtleNeck Buffer
${CYAN}2) TurtleNeck v2 Buffer
${CYAN}3) Annex Belay
${CYAN}4) Other
${PROMPT}Please select an option: ${RESET}"
read -r input
case $input in
1) BUFFER_SYSTEM="TurtleNeck"; break ;;
2) BUFFER_SYSTEM="TurtleNeckV2"; break ;;
3) BUFFER_SYSTEM="AnnexBelay"; break ;;
4) BUFFER_SYSTEM="Other"; break ;;
*) echo "Invalid selection" ;;
esac
done
}
macro_helpers() {
# Function to prompt the user with a series of questions to enable/disable various functions.
# The user's responses will be stored in corresponding variables.
#
# Local variables:
# question - The current question being asked.
# var - The variable name to store the user's response.
# default - The default value for the question.
# ordered_questions - An array of questions to be asked in order.
local question var default ordered_questions
print_msg PROMPT " The following questions will enable / disable various functions."
print_msg WARNING " Further configuration for your system is required to be setup in the 'AFC_Macro_Vars.cfg' file."
declare -A questions=(
["Do you want to add AFC includes to your printer.cfg file automatically?"]="INCLUDE_AFC_CFG True"
["Do you want to enable tip forming?"]="ENABLE_FORM_TIP False"
["Do you want to enable a toolhead cutter?"]="ENABLE_TOOL_CUT True"
["Do you want to enable the hub cutter?"]="ENABLE_HUB_CUT False"
["Do you want to enable the park macro?"]="ENABLE_PARK_MACRO True"
["Do you want to enable the poop macro?"]="ENABLE_POOP_MACRO True"
["Do you want to enable the kick macro?"]="ENABLE_KICK_MACRO True"
["Do you want to enable the wipe macro?"]="ENABLE_WIPE_MACRO True"
)
ordered_questions=(
"Do you want to add AFC includes to your printer.cfg file automatically?"
"Do you want to enable tip forming?"
"Do you want to enable a toolhead cutter?"
"Do you want to enable the hub cutter?"
"Do you want to enable the park macro?"
"Do you want to enable the poop macro?"
"Do you want to enable the kick macro?"
"Do you want to enable the wipe macro?"
)
for question in "${ordered_questions[@]}"; do
IFS=' ' read -r var default <<< "${questions[$question]}"
prompt_boolean " $question" "$var" "$default"
done
}
###################### Main script logic below ######################
while getopts "k:s:m:b:uh" arg; do
case ${arg} in
k) KLIPPER_PATH=${OPTARG} ;;
m) MOONRAKER_PATH=${OPTARG} ;;
s) KLIPPER_SERVICE=${OPTARG} ;;
b) BRANCH=${OPTARG} ;;
u) UNINSTALL=True ;;
h)
show_help
exit 0
;;
*) exit 1 ;;
esac
done
# Basic checks
clear
check_root
check_for_hh
# Uninstall procedure
if [ "$UNINSTALL" = "True" ]; then
unlink_extensions
manage_include "${PRINTER_CONFIG_PATH}/printer.cfg" "remove"
print_msg INFO " Uninstall complete."
backup_afc_config
print_msg WARNING "Ensure you perform the following steps:"
print_msg INFO " 1. Review your printer.cfg to ensure the AFC configuration is removed."
print_msg INFO " 2. Remove any AFC configuration from your moonraker config."
print_msg INFO " 3. Restart your Klipper service."
restart_klipper
exit 0
fi
# Since we aren't uninstalling, we need to do some basic functions
clone_repo
check_existing_install
check_old_config_version
check_for_prereqs
set_install_version_if_missing
if [ "$FORCE_UPDATE_NO_VERSION" == "False" ]; then
check_version_and_set_force_update
fi
info_menu
# Check if the user wants to update the configuration files and FORCE_UPDATE isn't True when a prior installation is detected.
if [ "$PRIOR_INSTALLATION" = "True" ] && [ "$FORCE_UPDATE" = False ]; then
print_msg WARNING " A prior installation of AFC has been detected."
print_msg WARNING " Would you like to update your existing configuration files with the latest settings?"
print_msg WARNING " This will preserve your existing configuration, and add any additional configuration options."
print_msg WARNING " A backup will be created prior to this operation."
print_msg ERROR " This will only work with the AFC-Lite boards. Select False if you have an MMB board."
prompt_boolean "Select False if you prefer to replace your existing config files with the latest ones from the repository" "auto_update_config" "True"
if [ "$auto_update_config" = "True" ]; then
print_msg WARNING " Updating AFC Klipper extensions..."
link_extensions
backup_afc_config_copy
AUTO_UPDATE_CONFIG=True
else
print_msg WARNING " Updating AFC Klipper extensions..."
link_extensions
print_msg WARNING " Warning: Replacing your configuration will overwrite your current settings."
print_msg WARNING " Selecting False will require you to manually update the configuration files, but no changes will be made."
prompt_boolean "Select True to proceed with replacing your configuration files or False to exit." "update_config_repo" "False"
if [ "$update_config_repo" = "True" ]; then
backup_afc_config
UPDATE_CONFIG=True
else
print_msg INFO " Skipping configuration update."
exit_afc_install
fi
fi
fi
# If an existing installation is found, and we want to run some auto-update configurations.
if [ "$PRIOR_INSTALLATION" = "True" ] && [ "$AUTO_UPDATE_CONFIG" = True ]; then
print_msg INFO " Auto updating configuration files..."
print_msg INFO " Please review your configuration files for accuracy."
auto_update
exit_afc_install
fi
# If an existing installation is found, and we want to force run configuration changes.
if [ "$PRIOR_INSTALLATION" = "True" ] && { [ "$FORCE_UPDATE" = True ] || [ "$FORCE_UPDATE_NO_VERSION" = True ]; }; then
print_msg WARNING " Due to many required changes in the software, we are unable to perform an automatic update of the"
print_msg WARNING " configuration files. Your existing configuration will be backed up to $PRINTER_CONFIG_PATH/AFC.backup.$BACKUP_DATE"
print_msg WARNING " Your Box Turtle must be unloaded before continuing."
confirm_continue
backup_afc_config
rm -f "${AFC_CONFIG_PATH}"/AFC{,.var}.tool
rm -f "${AFC_CONFIG_PATH}"/AFC{,.var}.unit
PRIOR_INSTALLATION=False
fi
# If no prior installation is found, or we want to update the configuration files.
if [ "$PRIOR_INSTALLATION" = "False" ] || [ "$UPDATE_CONFIG" = "True" ]; then
link_extensions
copy_config
install_type
choose_board_type
toolhead_pin
buffer_system
replace_varfile_path "${AFC_CONFIG_PATH}/AFC.cfg"
print_section_delimiter
macro_helpers
print_msg INFO " Updating configuration files with selected values..."
# Make sure to copy the right AFC_Hardware.cfg file based on the board type.
if [ "$BOARD_TYPE" == "AFC_Lite" ]; then
cp "${AFC_PATH}/templates/AFC_Hardware-AFC.cfg" "${AFC_CONFIG_PATH}/AFC_Hardware.cfg"
else
cp "${AFC_PATH}/templates/AFC_Hardware-MMB.cfg" "${AFC_CONFIG_PATH}/AFC_Hardware.cfg"
fi
## This section will choose the correct board type for MMB
if [ "$BOARD_TYPE" == "MMB_1.0" ] || [ "$BOARD_TYPE" == "MMB_1.1" ]; then
uncomment_board_type "${AFC_CONFIG_PATH}/AFC_Hardware.cfg" "${BOARD_TYPE}"
fi
# The below section will update configuration values in the AFC configuration files. This takes the format of
# update_config_value <file_path> <key> <new_value>. Any trailing comments will be preserved.
update_config_value "${AFC_CONFIG_PATH}/AFC.cfg" "Type" "${INSTALLATION_TYPE}"
update_config_value "${AFC_CONFIG_PATH}/AFC.cfg" "tool_cut" "${ENABLE_TOOL_CUT}"
update_config_value "${AFC_CONFIG_PATH}/AFC.cfg" "park" "${ENABLE_PARK_MACRO}"
update_config_value "${AFC_CONFIG_PATH}/AFC.cfg" "hub_cut" "${ENABLE_HUB_CUT}"
update_config_value "${AFC_CONFIG_PATH}/AFC.cfg" "poop" "${ENABLE_POOP_MACRO}"
update_config_value "${AFC_CONFIG_PATH}/AFC.cfg" "kick" "${ENABLE_KICK_MACRO}"
update_config_value "${AFC_CONFIG_PATH}/AFC.cfg" "wipe" "${ENABLE_WIPE_MACRO}"
update_config_value "${AFC_CONFIG_PATH}/AFC.cfg" "form_tip" "${ENABLE_FORM_TIP}"
# The section will update the toolhead pin in the AFC_Hardware.cfg file.
update_switch_pin "${AFC_CONFIG_PATH}/AFC_Hardware.cfg" "${TOOLHEAD_PIN}"
# Update printer.cfg if selected
if [ "$INCLUDE_AFC_CFG" = "True" ]; then
manage_include "${PRINTER_CONFIG_PATH}/printer.cfg" "add"
fi
# Update buffer configuration
if [ "$BUFFER_SYSTEM" == "TurtleNeck" ]; then
query_tn_pins "TN"
append_buffer_config "TurtleNeck" "$tn_advance_pin" "$tn_trailing_pin"
add_buffer_to_extruder "${AFC_CONFIG_PATH}/AFC_Hardware.cfg" "TN"
elif [ "$BUFFER_SYSTEM" == "TurtleNeckV2" ]; then
append_buffer_config "TurtleNeckV2"
add_buffer_to_extruder "${AFC_CONFIG_PATH}/AFC_Hardware.cfg" "TN2"
elif [ "$BUFFER_SYSTEM" == "AnnexBelay" ]; then
append_buffer_config "AnnexBelay"
add_buffer_to_extruder "${AFC_CONFIG_PATH}/AFC_Hardware.cfg" "Belay"
else
print_msg WARNING " Buffer not configured, skipping configuration."
fi
# Any additional configuration can be added here.
check_and_append_prep "${AFC_CONFIG_PATH}/AFC.cfg"
exclude_from_klipper_git
remove_t_macros
# Update moonraker config
update_moonraker_config
print_msg INFO " Prior to starting Klipper, please review all files in the AFC directory to ensure they are correct."
print_msg WARNING " This includes especially the AFC_Macro_Vars.cfg file and the pins in AFC_Hardware.cfg"
exit_afc_install
fi