core_messages.sh 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618
  1. #!/bin/bash
  2. # LinuxGSM core_messages.sh module
  3. # Author: Daniel Gibbs
  4. # Contributors: http://linuxgsm.com/contrib
  5. # Website: https://linuxgsm.com
  6. # Description: Defines on-screen messages such as [ OK ] and how script logs look.
  7. moduleselfname="$(basename "$(readlink -f "${BASH_SOURCE[0]}")")"
  8. # nl: new line: message is following by a new line.
  9. # eol: end of line: message is placed at the end of the current line.
  10. fn_ansi_loader() {
  11. if [ "${ansi}" != "off" ]; then
  12. # echo colors
  13. default="\e[0m"
  14. black="\e[30m"
  15. red="\e[31m"
  16. lightred="\e[91m"
  17. green="\e[32m"
  18. lightgreen="\e[92m"
  19. yellow="\e[33m"
  20. lightyellow="\e[93m"
  21. blue="\e[34m"
  22. lightblue="\e[94m"
  23. magenta="\e[35m"
  24. lightmagenta="\e[95m"
  25. cyan="\e[36m"
  26. lightcyan="\e[96m"
  27. darkgrey="\e[90m"
  28. lightgrey="\e[37m"
  29. white="\e[97m"
  30. fi
  31. # carriage return & erase to end of line.
  32. creeol="\r\033[K"
  33. if command -v tput > /dev/null 2>&1; then
  34. if num_colors=$(tput colors 2> /dev/null) && [ "${num_colors:-0}" -ge 8 ]; then
  35. # Enable colors
  36. tputreset="$(tput sgr 0)"
  37. tputbold="$(tput bold)"
  38. tputdim="$(tput dim)"
  39. fi
  40. fi
  41. }
  42. fn_sleep_time() {
  43. if [ "${sleeptime}" != "0" ] || [ "${travistest}" != "1" ]; then
  44. if [ -z "${sleeptime}" ]; then
  45. sleeptime=0.5
  46. fi
  47. sleep "${sleeptime}"
  48. fi
  49. }
  50. # Log display
  51. ########################
  52. ## Feb 28 14:56:58 ut99-server: Monitor:
  53. fn_script_log() {
  54. if [ -d "${lgsmlogdir}" ]; then
  55. if [ -n "${commandname}" ]; then
  56. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: ${1}" >> "${lgsmlog}"
  57. else
  58. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${1}" >> "${lgsmlog}"
  59. fi
  60. fi
  61. }
  62. ## Feb 28 14:56:58 ut99-server: Monitor: PASS:
  63. fn_script_log_pass() {
  64. if [ -d "${lgsmlogdir}" ]; then
  65. if [ -n "${commandname}" ]; then
  66. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: PASS: ${1}" >> "${lgsmlog}"
  67. else
  68. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: PASS: ${1}" >> "${lgsmlog}"
  69. fi
  70. fi
  71. exitcode=0
  72. }
  73. ## Feb 28 14:56:58 ut99-server: Monitor: FATAL:
  74. fn_script_log_fatal() {
  75. if [ -d "${lgsmlogdir}" ]; then
  76. if [ -n "${commandname}" ]; then
  77. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: FATAL: ${1}" >> "${lgsmlog}"
  78. else
  79. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: FATAL: ${1}" >> "${lgsmlog}"
  80. fi
  81. fi
  82. exitcode=1
  83. }
  84. ## Feb 28 14:56:58 ut99-server: Monitor: ERROR:
  85. fn_script_log_error() {
  86. if [ -d "${lgsmlogdir}" ]; then
  87. if [ -n "${commandname}" ]; then
  88. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: ERROR: ${1}" >> "${lgsmlog}"
  89. else
  90. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ERROR: ${1}" >> "${lgsmlog}"
  91. fi
  92. fi
  93. exitcode=2
  94. }
  95. ## Feb 28 14:56:58 ut99-server: Monitor: WARN:
  96. fn_script_log_warn() {
  97. if [ -d "${lgsmlogdir}" ]; then
  98. if [ -n "${commandname}" ]; then
  99. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: WARN: ${1}" >> "${lgsmlog}"
  100. else
  101. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: WARN: ${1}" >> "${lgsmlog}"
  102. fi
  103. fi
  104. exitcode=3
  105. }
  106. ## Feb 28 14:56:58 ut99-server: Monitor: INFO:
  107. fn_script_log_info() {
  108. if [ -d "${lgsmlogdir}" ]; then
  109. if [ -n "${commandname}" ]; then
  110. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: INFO: ${1}" >> "${lgsmlog}"
  111. else
  112. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: INFO: ${1}" >> "${lgsmlog}"
  113. fi
  114. fi
  115. }
  116. ## Feb 28 14:56:58 ut99-server: Monitor: UPDATE:
  117. fn_script_log_update() {
  118. if [ -d "${lgsmlogdir}" ]; then
  119. if [ -n "${commandname}" ]; then
  120. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: UPDATE: ${1}" >> "${lgsmlog}"
  121. else
  122. echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: UPDATE: ${1}" >> "${lgsmlog}"
  123. fi
  124. fi
  125. }
  126. # On-Screen - Automated functions
  127. ##################################
  128. # [ .... ]
  129. fn_print_dots() {
  130. if [ "${commandaction}" ]; then
  131. echo -en "${tputbold}${creeol}[ .... ]${tputreset} ${commandaction} ${selfname}: $*"
  132. else
  133. echo -en "${tputbold}${creeol}[ .... ]${tputreset} $*"
  134. fi
  135. fn_sleep_time
  136. }
  137. fn_print_dots_nl() {
  138. if [ "${commandaction}" ]; then
  139. echo -e "${tputbold}${creeol}[ .... ]${tputreset} ${commandaction} ${selfname}: $*"
  140. else
  141. echo -e "${tputbold}${creeol}[ .... ]${tputreset} $*"
  142. fi
  143. fn_sleep_time
  144. echo -en "\n"
  145. }
  146. # [ OK ]
  147. fn_print_ok() {
  148. if [ "${commandaction}" ]; then
  149. echo -en "${tputbold}${creeol}[${green} OK ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  150. else
  151. echo -en "${tputbold}${creeol}[${green} OK ${default}]${tputreset} $*"
  152. fi
  153. fn_sleep_time
  154. }
  155. fn_print_ok_nl() {
  156. if [ "${commandaction}" ]; then
  157. echo -en "${tputbold}${creeol}[${green} OK ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  158. else
  159. echo -en "${tputbold}${creeol}[${green} OK ${default}]${tputreset} $*"
  160. fi
  161. fn_sleep_time
  162. echo -en "\n"
  163. }
  164. # [ FAIL ]
  165. fn_print_fail() {
  166. if [ "${commandaction}" ]; then
  167. echo -en "${tputbold}${creeol}[${red} FAIL ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  168. else
  169. echo -en "${tputbold}${creeol}[${red} FAIL ${default}]${tputreset} $*"
  170. fi
  171. fn_sleep_time
  172. }
  173. fn_print_fail_nl() {
  174. if [ "${commandaction}" ]; then
  175. echo -en "${tputbold}${creeol}[${red} FAIL ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  176. else
  177. echo -en "${tputbold}${creeol}[${red} FAIL ${default}]${tputreset} $*"
  178. fi
  179. fn_sleep_time
  180. echo -en "\n"
  181. }
  182. # [ ERROR ]
  183. fn_print_error() {
  184. if [ "${commandaction}" ]; then
  185. echo -en "${tputbold}${creeol}[${red} ERROR ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  186. else
  187. echo -en "${tputbold}${creeol}[${red} ERROR ${default}]${tputreset} $*"
  188. fi
  189. fn_sleep_time
  190. }
  191. fn_print_error_nl() {
  192. if [ "${commandaction}" ]; then
  193. echo -en "${tputbold}${creeol}[${red} ERROR ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  194. else
  195. echo -en "${tputbold}${creeol}[${red} ERROR ${default}]${tputreset} $*"
  196. fi
  197. fn_sleep_time
  198. echo -en "\n"
  199. }
  200. # [ WARN ]
  201. fn_print_warn() {
  202. if [ "${commandaction}" ]; then
  203. echo -en "${tputbold}${creeol}[${lightyellow} WARN ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  204. else
  205. echo -en "${tputbold}${creeol}[${lightyellow} WARN ${default}]${tputreset} $*"
  206. fi
  207. fn_sleep_time
  208. }
  209. fn_print_warn_nl() {
  210. if [ "${commandaction}" ]; then
  211. echo -en "${tputbold}${creeol}[${lightyellow} WARN ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  212. else
  213. echo -en "${tputbold}${creeol}[${lightyellow} WARN ${default}]${tputreset} $*"
  214. fi
  215. fn_sleep_time
  216. echo -en "\n"
  217. }
  218. # [ INFO ]
  219. fn_print_info() {
  220. if [ "${commandaction}" ]; then
  221. echo -en "${tputbold}${creeol}[${cyan} INFO ${default}] ${commandaction} ${selfname}:${tputreset} $*"
  222. else
  223. echo -en "${tputbold}${creeol}[${cyan} INFO ${default}]${tputreset} $*"
  224. fi
  225. fn_sleep_time
  226. }
  227. fn_print_info_nl() {
  228. if [ "${commandaction}" ]; then
  229. echo -en "${tputbold}${creeol}[${cyan} INFO ${default}] ${commandaction} ${selfname}:${tputreset} $*"
  230. else
  231. echo -en "${tputbold}${creeol}[${cyan} INFO ${default}]${tputreset} $*"
  232. fi
  233. fn_sleep_time
  234. echo -en "\n"
  235. }
  236. # [ START ]
  237. fn_print_start() {
  238. if [ "${commandaction}" ]; then
  239. echo -en "${tputbold}${creeol}[${lightgreen} START ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  240. else
  241. echo -en "${tputbold}${creeol}[${lightgreen} START ${default}]${tputreset} $*"
  242. fi
  243. fn_sleep_time
  244. }
  245. fn_print_start_nl() {
  246. if [ "${commandaction}" ]; then
  247. echo -en "${tputbold}${creeol}[${lightgreen} START ${default}]${tputreset} ${commandaction} ${selfname}: $*"
  248. else
  249. echo -en "${tputbold}${creeol}[${lightgreen} START ${default}]${tputreset} $*"
  250. fi
  251. fn_sleep_time
  252. echo -en "\n"
  253. }
  254. # On-Screen - Interactive messages
  255. ##################################
  256. # No More Room in Hell Debug
  257. # =================================
  258. fn_print_header() {
  259. echo -e ""
  260. echo -e "${lightyellow}${gamename} ${commandaction}${default}"
  261. echo -e "=================================${default}"
  262. }
  263. # Complete!
  264. fn_print_complete() {
  265. echo -en "${green}Complete!${default} $*"
  266. fn_sleep_time
  267. }
  268. fn_print_complete_nl() {
  269. echo -e "${green}Complete!${default} $*"
  270. fn_sleep_time
  271. }
  272. # Failure!
  273. fn_print_failure() {
  274. echo -en "${red}Failure!${default} $*"
  275. fn_sleep_time
  276. }
  277. fn_print_failure_nl() {
  278. echo -e "${red}Failure!${default} $*"
  279. fn_sleep_time
  280. }
  281. # Error!
  282. fn_print_error2() {
  283. echo -en "${red}Error!${default} $*"
  284. fn_sleep_time
  285. }
  286. fn_print_error2_nl() {
  287. echo -e "${red}Error!${default} $*"
  288. fn_sleep_time
  289. }
  290. # Warning!
  291. fn_print_warning() {
  292. echo -en "${lightyellow}Warning!${default} $*"
  293. fn_sleep_time
  294. }
  295. fn_print_warning_nl() {
  296. echo -e "${lightyellow}Warning!${default} $*"
  297. fn_sleep_time
  298. }
  299. # Information!
  300. fn_print_information() {
  301. echo -en "${cyan}Information!${default} $*"
  302. fn_sleep_time
  303. }
  304. fn_print_information_nl() {
  305. echo -e "${cyan}Information!${default} $*"
  306. fn_sleep_time
  307. }
  308. # Y/N Prompt
  309. fn_prompt_yn() {
  310. local prompt="$1"
  311. local initial="$2"
  312. if [ "${initial}" == "Y" ]; then
  313. prompt+=" [Y/n] "
  314. elif [ "${initial}" == "N" ]; then
  315. prompt+=" [y/N] "
  316. else
  317. prompt+=" [y/n] "
  318. fi
  319. while true; do
  320. read -e -i "${initial}" -p "${prompt}" -r yn
  321. case "${yn}" in
  322. [Yy] | [Yy][Ee][Ss]) return 0 ;;
  323. [Nn] | [Nn][Oo]) return 1 ;;
  324. *) echo -e "Please answer yes or no." ;;
  325. esac
  326. done
  327. }
  328. # Prompt for message
  329. fn_prompt_message() {
  330. while true; do
  331. unset prompt
  332. local prompt="$1"
  333. read -e -p "${prompt}" -r answer
  334. if fn_prompt_yn "Continue" Y; then
  335. break
  336. fi
  337. done
  338. echo "${answer}"
  339. }
  340. # On-Screen End of Line
  341. ##################################
  342. # YES
  343. fn_print_yes_eol() {
  344. echo -en "${cyan}YES${default}"
  345. fn_sleep_time
  346. }
  347. fn_print_yes_eol_nl() {
  348. echo -e "${cyan}YES${default}"
  349. fn_sleep_time
  350. }
  351. # NO
  352. fn_print_no_eol() {
  353. echo -en "${red}NO${default}"
  354. fn_sleep_time
  355. }
  356. fn_print_no_eol_nl() {
  357. echo -e "${red}NO${default}"
  358. fn_sleep_time
  359. }
  360. # OK
  361. fn_print_ok_eol() {
  362. echo -en "${green}OK${default}"
  363. fn_sleep_time
  364. }
  365. fn_print_ok_eol_nl() {
  366. echo -e "${green}OK${default}"
  367. fn_sleep_time
  368. }
  369. # FAIL
  370. fn_print_fail_eol() {
  371. echo -en "${red}FAIL${default}"
  372. fn_sleep_time
  373. }
  374. fn_print_fail_eol_nl() {
  375. echo -e "${red}FAIL${default}"
  376. fn_sleep_time
  377. }
  378. # ERROR
  379. fn_print_error_eol() {
  380. echo -en "${red}ERROR${default}"
  381. fn_sleep_time
  382. }
  383. fn_print_error_eol_nl() {
  384. echo -e "${red}ERROR${default}"
  385. fn_sleep_time
  386. }
  387. # WAIT
  388. fn_print_wait_eol() {
  389. echo -en "${cyan}WAIT${default}"
  390. fn_sleep_time
  391. }
  392. fn_print_wait_eol_nl() {
  393. echo -e "${cyan}WAIT${default}"
  394. fn_sleep_time
  395. }
  396. # WARN
  397. fn_print_warn_eol() {
  398. echo -en "${lightyellow}WARN${default}"
  399. fn_sleep_time
  400. }
  401. fn_print_warn_eol_nl() {
  402. echo -e "${lightyellow}WARN${default}"
  403. fn_sleep_time
  404. }
  405. # INFO
  406. fn_print_info_eol() {
  407. echo -en "${cyan}INFO${default}"
  408. fn_sleep_time
  409. }
  410. fn_print_info_eol_nl() {
  411. echo -e "${cyan}INFO${default}"
  412. fn_sleep_time
  413. }
  414. # QUERYING
  415. fn_print_querying_eol() {
  416. echo -en "${cyan}QUERYING${default}"
  417. fn_sleep_time
  418. }
  419. fn_print_querying_eol_nl() {
  420. echo -e "${cyan}QUERYING${default}"
  421. fn_sleep_time
  422. }
  423. # CHECKING
  424. fn_print_checking_eol() {
  425. echo -en "${cyan}CHECKING${default}"
  426. fn_sleep_time
  427. }
  428. fn_print_checking_eol_nl() {
  429. echo -e "${cyan}CHECKING${default}"
  430. fn_sleep_time
  431. }
  432. # DELAY
  433. fn_print_delay_eol() {
  434. echo -en "${green}DELAY${default}"
  435. fn_sleep_time
  436. }
  437. fn_print_delay_eol_nl() {
  438. echo -e "${green}DELAY${default}"
  439. fn_sleep_time
  440. }
  441. # CANCELED
  442. fn_print_canceled_eol() {
  443. echo -en "${lightyellow}CANCELED${default}"
  444. fn_sleep_time
  445. }
  446. fn_print_canceled_eol_nl() {
  447. echo -e "${lightyellow}CANCELED${default}"
  448. fn_sleep_time
  449. }
  450. # REMOVED
  451. fn_print_removed_eol() {
  452. echo -en "${red}REMOVED${default}"
  453. fn_sleep_time
  454. }
  455. fn_print_removed_eol_nl() {
  456. echo -e "${red}REMOVED${default}"
  457. fn_sleep_time
  458. }
  459. # UPDATE
  460. fn_print_update_eol() {
  461. echo -en "${cyan}UPDATE${default}"
  462. fn_sleep_time
  463. }
  464. fn_print_update_eol_nl() {
  465. echo -e "${cyan}UPDATE${default}"
  466. fn_sleep_time
  467. }
  468. # SKIP
  469. fn_print_skip_eol() {
  470. echo -en "${cyan}SKIP${default}"
  471. fn_sleep_time
  472. }
  473. fn_print_skip_eol_nl() {
  474. echo -e "${cyan}SKIP${default}"
  475. fn_sleep_time
  476. }
  477. fn_print_ascii_logo() {
  478. echo -e ""
  479. echo -e " mdMMMMbm"
  480. echo -e " mMMMMMMMMMMm"
  481. echo -e " mMMMMMMMMMMMMm"
  482. echo -e " mMMMMMMMMMMMMMMm"
  483. echo -e " hMMMV^VMMV^VMMMh"
  484. echo -e " MMMMM MM MMMMM"
  485. echo -e " hMMs vv sMMh"
  486. echo -e " hMMM: :MMMh"
  487. echo -e " .hMMMh hMMMh."
  488. echo -e " -dMMMh ${lightgrey}__${default} hMMMd-"
  489. echo -e " :mMMMs ${lightgrey}||${default} sMMMm:"
  490. echo -e " :MMMM+ ${lightgrey}||${default} ${red}_${default} +NMMN:"
  491. echo -e " .mMMM+ ${lightgrey}========${default} +MMMm."
  492. echo -e " yMMMy ${darkgrey}##############${default} yMMMy"
  493. echo -e " mMMM: ${darkgrey}##############${default} :MMMm"
  494. echo -e " mMM ${lightyellow}nn${default} ${lightyellow}nn${default} ${lightyellow}nn${default} ${lightyellow}nn${default} MMm"
  495. echo -e " o ${lightyellow}nNNNNNNNn${default} ${lightyellow}nNNNNNNNn${default} o"
  496. echo -e " ${lightyellow}nNNNNNNNNNn${default} ${lightyellow}nNNNNNNNNNn${default}"
  497. echo -e " ${lightyellow}nNNNNNNNNNNN${default} ${lightyellow}NNNNNNNNNNNn${default}"
  498. echo -e " ${lightyellow}+NNNNNNNNN:${default} ${lightyellow}:NNNNNNNNN+${default}"
  499. echo -e " ${lightyellow}nNNNNNNN${default} /\ ${lightyellow}NNNNNNNn${default}"
  500. echo -e " ${lightyellow}nnnnn${default} db ${lightyellow}nnnnn${default}"
  501. echo -e ""
  502. echo -e "${lightyellow}888${default} ${lightyellow}d8b${default} ${default}.d8888b. .d8888b. 888b d888"
  503. echo -e "${lightyellow}888 Y8P ${default}d88P Y88b d88P Y88b 8888b d8888"
  504. echo -e "${lightyellow}888${default} ${default}888${default} 888 Y88b. 88888b.d88888"
  505. echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}88888b.${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} 888 Y888b. 888Y88888P888"
  506. echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}88b${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}Y8bd8P${default} 888 88888 Y88b. 888 Y888P 888"
  507. echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}X88K${default} 888 888 888 888 Y8P 888"
  508. echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}Y88b${default} ${lightyellow}88Y${default} ${lightyellow}.d8pq8b.${default} Y88b d88P Y88b d88P 888 * 888"
  509. echo -e "${lightyellow}LinuxGSM${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}Y8888Y${default} ${lightyellow}888${default} ${lightyellow}888${default} Y2012P88 Y8888P 888 888"
  510. echo -e ""
  511. }
  512. fn_print_restart_warning() {
  513. fn_print_warn "${selfname} will be restarted"
  514. fn_script_log_warn "${selfname} will be restarted"
  515. totalseconds=3
  516. for seconds in {3..1}; do
  517. fn_print_warn "${selfname} will be restarted: ${totalseconds}"
  518. totalseconds=$((totalseconds - 1))
  519. sleep 1
  520. if [ "${seconds}" == "0" ]; then
  521. break
  522. fi
  523. done
  524. fn_print_warn_nl "${selfname} will be restarted"
  525. }
  526. # Functions below are used to ensure that logs and UI correctly reflect the command it is actually running.
  527. # Useful when a command has to call upon another command causing the other command to overrite commandname variables
  528. # Used to remember the command that ran first.
  529. fn_firstcommand_set() {
  530. if [ -z "${firstcommandname}" ]; then
  531. firstcommandname="${commandname}"
  532. firstcommandaction="${commandaction}"
  533. fi
  534. }
  535. # Used to reset commandname variables to the command the script ran first.
  536. fn_firstcommand_reset() {
  537. commandname="${firstcommandname}"
  538. commandaction="${firstcommandaction}"
  539. }