Ответ 1
Удалите все связанные файлы из списка изменений и он исчезнет.
Официальный способ
См. fooobar.com/questions/180969/...
svn changelist --remove --recursive --cl my_changes .
Ручной способ
то есть. svn changelist --remove file.name
D:\Programming>mkdir test
D:\Programming>cd test
D:\Programming\test>svnadmin create .
D:\Programming\test>svn co file:///D:\Programming\test co
Checked out revision 0.
D:\Programming\test>cd co
D:\Programming\test\co>echo "hello" > test.file
D:\Programming\test\co>svn add test.file
A test.file
D:\Programming\test\co>svn status
A test.file
D:\Programming\test\co>svn changelist mycl test.file
A [mycl] test.file
D:\Programming\test\co>svn status
--- Changelist 'mycl':
A test.file
D:\Programming\test\co>svn changelist --remove test.file
D [mycl] test.file
D:\Programming\test\co>svn status
A test.file
Автоматизация в Bash
# Remove all files from a specific CL
# Usage: svn_remove_cl my_changes
function svn_remove_cl() {
svn status |\
sed -n "/--- Changelist '$1':/,/--- Changelist.*/p" |\
grep -v '^--- Changelist' |\
awk '{print $2}' |\
xargs svn changelist --remove
}
Пояснение:
-
svn status
: вывод всех измененных файлов -
sed
: найдите список изменений и выведите результат после заголовка CL до следующего CL или конца выводаsvn status
-
grep
: удалить заголовки CL из буфера -
awk
: удалить статусы файлов, сохранить только имена файлов (т.е. второй столбец) -
xargs
: поместите каждую строку в качестве аргумента вsvn changelist
(могут потребоваться настройки, если у вас есть пробелы или специальные символы в именах файлов)
Пример выполнения
~/tmp/wc$ svn status
A d
--- Changelist 'cl_a':
A a
A e
A f
--- Changelist 'cl_x':
A b
A c
~/tmp/wc$ svn_remove_cl cl_x
Path 'b' is no longer a member of a changelist.
Path 'c' is no longer a member of a changelist.
~/tmp/wc$ svn status
A b
A c
A d
--- Changelist 'cl_a':
A a
A e
A f