From e10f131a5a3de4d9123de7ecc9c9cdca6c0b37a0 Mon Sep 17 00:00:00 2001 From: serr Date: Sun, 13 Apr 2025 17:06:27 +0300 Subject: [PATCH] eye.sh new ver --- eye.sh | 62 +++++++++++++++++++++++++++++++++++----------------------- 1 file changed, 37 insertions(+), 25 deletions(-) diff --git a/eye.sh b/eye.sh index 2c0e2e5..458e21a 100755 --- a/eye.sh +++ b/eye.sh @@ -3,29 +3,28 @@ stty -echoctl # Отключает вывод управляющих симво # НАСТРОЙКА СКРИПТА ТУТ ########################################################### DURATION=1 # Задержка между проверками в секундах -WATCH_DIRS=("posts" "mvc" "assets" "tools") # Массив директорий для наблюдения +WATCH_TARGETS=("assets" "mvc" "posts" "tools" "main.go") # Массив целей для наблюдения (директории и файлы) BINARY_PATH="./main" # Путь до бинарного файла BUILD_CMD="go build -o $BINARY_PATH main.go" # Команда для сборки ################################################################################### -# Массивы для хранения информации о директориях +# Массивы для хранения информации о целях declare -A LAST_MODS declare -A LAST_COUNTS CLEANUP_DONE=0 -# # Вывод в синем цвете blue() { - echo -e "\033[34m$1\033[0m" + echo -e "\033[34mEYE | $1\033[0m" } # Очистка при завершении работы скрипта cleanup() { [ $CLEANUP_DONE -eq 1 ] && exit 0 - blue "EYE | cleanup..." + blue "cleanup..." kill_proc $1 rm -f $BINARY_PATH - blue "EYE | see you later!" + blue "see you later!" CLEANUP_DONE=1 exit 0 } @@ -35,23 +34,33 @@ kill_proc() { local pid=$1 if [ -n "$pid" ] && kill -0 $pid 2>/dev/null; then kill $pid - blue "EYE | process killed (PID: $pid)" + blue "process killed (PID: $pid)" fi } -# Проверка изменений в директориях +# Проверка изменений в целях check_changes() { local changed=0 - for dir in "${WATCH_DIRS[@]}"; do - local current_mod=$(find "$dir" -type f -exec stat -c %Y {} \; | sort -nr | head -1) - local current_count=$(find "$dir" -type f 2>/dev/null | wc -l) + for target in "${WATCH_TARGETS[@]}"; do + local current_mod=0 + local current_count=0 - if { [ -n "$current_mod" ] && [ "$current_mod" -gt "${LAST_MODS[$dir]}" ]; } || [ "$current_count" -ne "${LAST_COUNTS[$dir]}" ]; then + if [ -f "$target" ]; then + # Обработка файла + current_mod=$(stat -c %Y "$target") + current_count=1 + elif [ -d "$target" ]; then + # Обработка директории + current_mod=$(find "$target" -type f -exec stat -c %Y {} \; | sort -nr | head -1) + current_count=$(find "$target" -type f | wc -l) + fi + + if { [ -n "$current_mod" ] && [ "${LAST_MODS[$target]:-0}" -lt "$current_mod" ]; } || [ "${LAST_COUNTS[$target]:-0}" -ne "$current_count" ]; then changed=1 - LAST_MODS["$dir"]=$current_mod - LAST_COUNTS["$dir"]=$current_count - [ -n "$1" ] && blue "EYE | changes detected in \033[94m$dir\033[0m" + LAST_MODS["$target"]=$current_mod + LAST_COUNTS["$target"]=$current_count + [ -n "$1" ] && blue "changes detected in \033[94m$target\033[0m" fi done @@ -64,30 +73,33 @@ main() { # Ловушка для сигналов завершения trap 'cleanup $pid' SIGINT SIGTERM SIGHUP SIGQUIT EXIT - # # Инициализация массивов - for dir in "${WATCH_DIRS[@]}"; do - LAST_MODS["$dir"]=0 - LAST_COUNTS["$dir"]=$(find "$dir" -type f 2>/dev/null | wc -l) - blue "EYE | started watching the directory \033[94m$dir\033[0m" + for target in "${WATCH_TARGETS[@]}"; do + if [ -f "$target" ]; then + LAST_MODS["$target"]=0 + LAST_COUNTS["$target"]=1 + elif [ -d "$target" ]; then + LAST_MODS["$target"]=0 + LAST_COUNTS["$target"]=$(find "$target" -type f 2>/dev/null | wc -l) + fi + blue "started watching \033[94m$target\033[0m" done - # # Основной цикл работы скрипта while true; do check_changes $pid if [ $? -eq 1 ]; then - blue "EYE | rebuilding..." + blue "rebuilding..." $BUILD_CMD if [ $? -eq 0 ]; then - blue "EYE | build successful. restarting..." + blue "build successful. restarting..." kill_proc $pid $BINARY_PATH & pid=$! - blue "EYE | started new process (PID: $pid)" + blue "started new process (PID: $pid)" else - blue "EYE | build failed" + blue "build failed" fi fi