Есть такой кусок кода:
for DIR_UDEL in $1
do
for DIR_DEL_UNIT in ${UNIT_DIR}
do
if [ -d "${DIR_UDEL}" ] && [ ${DIR_UDEL} == ${DIR_DEL_UNIT} ] # сравнение содержимого каталога со списком, если совпадает и является каталогом, то происходит переход в верхний цикл. Иначе удаляется.
then
continue 2
else
rm -R ${DIR_UDEL}
echo «${DIR_UDEL} удалён, так как его не должно быть»
fi
done
done
Коряво конечно… Смысл в том чтобы получить содержимое папки. Сравнить его со списком, и если не найдено ни одного соответствия, пристрелить файл или папку.
[ -d "${DIR_UDEL}" ] && [ ${DIR_UDEL} == ${DIR_DEL_UNIT} ] — это выражение всегда false.
Что я тут лишнего напридумывал? Вариант с написанием двух for не кажется мне удачным, а два if уж совсем. Но и сообразить в чём дело в данном контексте не получается.
Последние комментарии
-
fhunter, сегодня в 9:23 → Математика в школе 17
-
fhunter, сегодня в 9:22 → Как настроить чтоб работало две сетевые платы — две сети 3
-
fhunter, сегодня в 9:22 → посоветуйте!!Как ой велосипед приобрести девушке? 10
-
rgo, 11 января в 10:28 → Как «замокать» файл для юниттеста в Python? 1
-
ilyas490, 8 декабря в 13:27 → Книги по Bash? 13

Попробуй так, хотя не уверен.