jwamicha.wordpress.com/2008/05/29/subversion-a-summary-cheat-sheet-learn-svn-in-10-minutes/
===============================================================
Основные команды
SVNADMIN CREATE - Создать хранилище файлов в SVN
Unix
svnadmin create /path/to/new/svn/repository
Windows
svnadmin create c:/path/to/new/svn/repository
SVN IMPORT - Первоначальна записать папки с файлами в хранилище файлов в SVN для создания общей структуры проекта
Структура папок вашего проекта должна быть такой.
В папке trunk находятся файлы вашего сайта.
В папке branches находятся ответвления с измененными версиями вашего основного сайта.
В папке tags находятся тэги.
Unix
svn import project file:///path/to/new/svn/repository/project -m "Comment for my First Import"
Windows
svn import project file:///c:/path/to/new/svn/repository/project -m "Comment for my First Import"
Network
svn import porject http://site_name/svn_dir/repository_name/project -m "Comment for my First Import"
Другой пример
svn import myproject --username jared --password shipit svn://opteron1/svn-repo
SVNSERVE - Запуск SVN сервера
svnserve -d -r c:/path/to/new/svn/repository
Добавление пользователей для подключения к SVN серверу.
В файле svnserve.conf, который расположен в директории вашего проекта (c:/path/to/new/svn/repository) в папке conf, раскомментируйте строки:
[general]
anon-access = read
auth-access = write
password-db = passwd
Все пароли будут хранится в файле passwd, который мы сохраним в этой же папке далее.
Создадим файл passwd и добавим в него следующее содержимое в виде логина и пароля пользователя в формате NAME = PASSWORD:
[users]
jared = shipit
SVN CHECKOUT - Выгрузка файлов из хранилища SVN на локальный компьютер
Unix
svn checkout file:///path/to/new/svn/repository/project/trunk /my/project/local/folder
Windows
svn checkout file:///c:/path/to/new/svn/repository/project/trunk c:/my/project/local/folder
Network
svn checkout http://site_name/svn_dir/repository_name/project/trunk c:/my/project/local/folder
Другой пример
svn checkout http://192.168.0.54/svn/repos/server_code server_code
svn checkout –username my_username http://192.168.0.54/svn/repos/server_code server_code
svn checkout --username jared --password shipit svn://opteron1/svn-repo
svn checkout -r 1729
SVN LIST - Получить список проектов, находящихся в хранилище SVN
Unix
svn list --verbose file:///path/to/repository/project
Network
svn list --verbose http://site_name/svn_dir/repository_name/project
SVN STATUS - Посмотреть статус внесенных изменений
Unix
svn status
(Сделать обзор всех внесенных изменений)
Например
A stuff/loot/bloo.h # file is scheduled for addition
C stuff/loot/lump.c # file has textual conflicts from an update
D stuff/fish.c # file is scheduled for deletion
M bar.c # the content in bar.c has local modifications
SVN ADD - Пометка файлов и папок для будущего добавления в хранилище в SVN
Unix
svn add file_or_directory_inside_my_project_folder
Для добавления изменений в хранилище SVN необходимо далее выполнить команду svn commit.
Другой пример
svn add my_file.txt
svn add my_folder
SVN DELETE - Пометка файлов и папок для будущего удаления из хранилища SVN
Unix
svn delete file_or_directory_inside_my_project_folder
svn delete my_file.txt
svn delete my_folder
Для добавления изменений в хранилище SVN необходимо далее выполнить команду svn commit.
В отличии от команды add можно удалить файлы напрямую из хранилища SVN.
Network
svn delete -m "Comment Deleting project directory" http://localhost/svn_dir/repository/project_dir
SVN DIFF - Посмотреть (сравнить) внесенные в проект изменения
Показать различия между текущей рабочей директорией и той же директорией в хранилище
svn diff
svn diff my_file.txt
svn diff my_folder
SVN COMMIT - Отправка (добавление) внесенных изменений из локальной папки в хранилище SVN
svn commit -m "Comment Saving recent changes" http://loaclhost/svn_dir/repository/project_dir
Другой пример
svn commit my_file.txt
svn commit my_folder
SVN UPDATE - Выгрузка последней версии файлов из хранилища SVN с целью обновления локальных файлов и их замены на файлы из хранилища
Network
svn update
Другой пример
svn update my_file.txt
svn update my_folder
svn update (update from current)
svn update -r BASE server_code (update foo from base revision)
svn update -r 1200 server_code (update foo from revision number 1200)
SVN LOG - Посмотреть кто еще переносил свои изменения в хранилище SVN
svn log
Другой пример
svn log my_file.txt
svn log my_folder
svn log -r 8
svn log -r 5:19
svn log -r 19:5
SVN COPY - Тэгирование (копирование) и создание отдельных версий проекта в хранилище SVN
Копирование содержимого директорий
svn copy directory1 directory2
Тэги создают отдельные копии проекта для будущих изменений.
В директори tags создается виртуальная копия проекта.
svn copy http://site_name/repos/project/trunk http://site_name/repos/project/tags/0.1.0 -m "Comment tagging the 0.1.0 release of the project"
Посмотреть список внесенных в проект с тэгом изменений
svn list http://192.168.0.4/svn/repos/prj1/tags/0.1.0/
Выгрузка на локальных компьютер файлов из проекта с тэгом
svn checkout http://192.168.0.4/svn/repos/prj1/tags/0.1.0/
APACHE и SVN - Настройки сервера Apache для создания виртуального хранилища SVN
В файле httpd.conf раскомментируйте следующие строки:
LoadModule dav_module modules/mod_dav.so
LoadModule dav_svn_module modules/mod_dav_svn.so
Далее проишите URL-адресе размещения хранилища SVN на сервере:
<Location /svn>
DAV svn
# All repos subdirs of d:/svn
SVNParentPath C:/svn
</Location>
TortoiseSVN - Программа для графической работы с SVN
===============================================================
Дополнительные команды
SVN REVERT - Отменить внесенные изменения
svn revert
SVN RESOLVE - Разрешить конфликт файлов
svn update
svn resolve
===============================================================
SUBVERSION COMMANDS SUMMARY
1.) Checkout the code and do an update in case of any changes made since your last update (We assume that you are using apache dav server to access your code and not svnserve):
$svn checkout http://192.168.0.54/svn/repos/server_code server_code
If your repository requires authentication:
$svn checkout –username my_username http://192.168.0.54/svn/repos/server_code server_code
Update your working copy:
$svn update
(update from current)
$svn update -r BASE server_code
(update foo from base revision)
$svn update -r 1200 server_code (update foo from revision number 1200)
2.) Make changes:
$svn add eg svn add new_directory
(add a new directory foo)
$svn delete
$svn copy directory1 directory2
(copy directory directory1 to directory2)
$svn move directory2 renamed_directory
(rename?)
3.) Examine your changes (Can be done even with no network access to the subversion repository):
$svn status
(To get an overview of all your changes)
eg
A stuff/loot/bloo.h # file is scheduled for addition
C stuff/loot/lump.c # file has textual conflicts from an update
D stuff/fish.c # file is scheduled for deletion
M bar.c # the content in bar.c has local modifications
$svn diff
(to show changes between current working directory and the same directory in the repository)
4.) Possibly undo some changes (Can also be done even with no network access to the subversion repository):
$svn revert
After running svn revert as a way to resolve local conflict with the repository copy, Run:
$svn resolve
To inform svn that the conflict has been resolved. You will now be able to successfully run svn update in case of previous conflicts.
5.) Resolve Conflicts (Merge Others’ Changes):
$svn update
$svn resolved
6.) Commit your changes:
$svn commit
eg
$svn commit -m “Removed out of mem errors.”
or
$svn commit -F comment.txt
or
$svn commit –file comment.txt
6. Logs:
$svn log (use current working directory as the default target)
$svn log server_code
(current working directory/file is server_code)
$svn log -r 5:19
(shows logs 5 through 19 in chronological order of working directory)
$svn log -r 19:5
(shows logs 5 through 19 in reverse order of working directory)
$svn log -r 8
(shows log for revision 8 of working directory)
$svn log -r 8 -v
(shows verbose? log for revision 8 of working directory)
7. Diffs (Changes):
$svn diff
$svn diff -r 3 rules.txt
(or svn diff –revision 3 rules.txt)
$svn diff -r 2:3 rules.txt
(revisions 2 and 3 are directly compared)
$svn diff -c 3 rules.txt
(compare changes between current revision and revision 2)
8. Browse a file directly:
svn cat -r 2 rules.txt
svn cat -r 2 rules.txt > rules.txt.v2 (send cat output directly to a file)
9. Browse a folder directly:
svn list http://svn.collab.net/repos/svn
svn list -v http://svn.collab.net/repos/svn
10. Fetching older repository snapshots:
$svn checkout -r 1729
(Checks out a new working copy at r1729)
$svn update -r 1729
(Updates an existing working copy to r1729)
11. If you’re building a release and wish to bundle up your files from Subversion but don’t want those pesky .svn directories in the way, then you can use svn export to create a local copy of all or part of your repository sans .svn directories. As with svn update and svn checkout, you can also pass the – -revision switch to svn export:
$svn export http://svn.example.com/svn/repos1
(Exports latest revision)
$svn export http://svn.example.com/svn/repos1 -r 1729
(Exports revision r1729)
12. Cleanup if a Subversion operation is interrupted (if the process is killed, or if the machine crashes, for example), the log files remain on disk. By re-executing the log files, Subversion can complete the previously started operation, and your working copy can get itself back into a consistent state.
$svn cleanup
13. Revision specifiers:
HEAD: The latest (or “youngest”) revision in the repository.
BASE: The revision number of an item in a working copy. If the item has been locally modified, the “BASE version” refers to the way the item appears without those local modifications.
COMMITTED: The most recent revision prior to, or equal to, BASE, in which an item changed.
PREV: The revision immediately before the last revision in which an item changed. Technically, this boils down to COMMITTED-1.
$svn diff -r PREV:COMMITTED main.c
(shows the last change committed to main.c)
$svn log -r HEAD
(shows log message for the latest repository commit)
$svn diff -r HEAD
(compares your working copy with all of its local changes to the latest version of that tree in the repository)
svn diff -r BASE:HEAD main.c
(compares the unmodified version of foo.c with the latest version of foo.c in the repository)
$svn log -r BASE:HEAD
(shows all commit logs for the current versioned directory since you last updated
$svn update -r PREV main.c
(rewinds the last change on foo.c, decreasing foo.c’s working revision)
$svn diff -r BASE:14 main.c
(compares the unmodified version of foo.c with the way foo.c looked in revision 14)
14. Checkout based on revisions:
$svn checkout -r {2006-02-17}
$svn checkout -r {15:30}
$svn checkout -r {15:30:00.200000}
$svn checkout -r {“2006-02-17 15:30″}
$svn checkout -r {“2006-02-17 15:30 +0230″}
$svn checkout -r {2006-02-17T15:30}
$svn checkout -r {2006-02-17T15:30Z}
$svn checkout -r {2006-02-17T15:30-04:00}
$svn checkout -r {20060217T1530}
$svn checkout -r {20060217T1530Z}
$svn checkout -r {20060217T1530-0500}
15. Logs based on revisions:
$svn log -r {2006-11-28}
$svn log -r {2006-11-20}:{2006-11-29}
16. Properties of files:
$svn propset copyright ‘(c) 2006 Red-Bean Software’ calc/button.c
property ‘copyright’ set on ‘calc/button.c’
$svn propset license -F /path/to/LICENSE calc/button.c
property ‘license’ set on ‘calc/button.c’
$svn propedit copyright calc/button.c
No changes to property ‘copyright’ on ‘calc/button.c’
$svn propset copyright ‘(c) 2006 Red-Bean Software’ calc/*
property ‘copyright’ set on ‘calc/Makefile’
property ‘copyright’ set on ‘calc/button.c’
property ‘copyright’ set on ‘calc/integer.c’
$svn proplist calc/button.c
Properties on ‘calc/button.c’:
copyright
license
$svn propget copyright calc/button.c
(c) 2006 Red-Bean Software
$svn proplist -v calc/button.c
$svn propset license ” calc/button.c
$svn propdel license calc/button.c
And specify the revision whose property you wish to modify
$svn propset copyright ‘(c) 2006 Red-Bean Software’ calc/button.c -r11 –revprop
17. Locking files:
$svn lock banana.jpg -m “Editing file for tomorrow’s release.”
‘banana.jpg’ locked by user ‘harry’.
$svn status
K banana.jpg
$svn info banana.jpg
Path: banana.jpg
Name: banana.jpg
URL: http://svn.example.com/repos/project/banana.jpg
Repository UUID: edb2f264-5ef2-0310-a47a-87b0ce17a8ec
Revision: 2198
Node Kind: file
Schedule: normal
Last Changed Author: frank
Last Changed Rev: 1950
Last Changed Date: 2006-03-15 12:43:04 -0600 (Wed, 15 Mar 2006)
Text Last Updated: 2006-06-08 19:23:07 -0500 (Thu, 08 Jun 2006)
Properties Last Updated: 2006-06-08 19:23:07 -0500 (Thu, 08 Jun 2006)
Checksum: 3b110d3b10638f5d1f4fe0f436a5a2a5
Lock Token: opaquelocktoken:0c0f600b-88f9-0310-9e48-355b44d4a58e
Lock Owner: harry
Lock Created: 2006-06-14 17:20:31 -0500 (Wed, 14 Jun 2006)
Lock Comment (1 line):
Editing file for tomorrow’s release.
$svnadmin lslocks /usr/local/svn/repos
$svnadmin rmlocks /usr/local/svn/repos /project/raisin.jpg
Force out someone else’s lock:
$svn unlock –force http://svn.example.com/repos/project/raisin.jpg
Force a lock over someone else’s
$ svn lock –force raisin.jpg
18. Creating branches:
$svn checkout http://svn.example.com/repos/calc bigwc
A bigwc/trunk/
A bigwc/trunk/Makefile
A bigwc/trunk/integer.c
A bigwc/trunk/button.c
A bigwc/branches/
Checked out revision 340.
Now create the branch;
$cd bigwc
$svn copy trunk branches/my-calc-branch
$svn status
A + branches/my-calc-branch
$svn commit -m “Creating a private branch of /calc/trunk.”
Adding branches/my-calc-branch
Committed revision 341.
You can do all the above in one step (Recommended way):
$svn copy http://svn.example.com/repos/calc/trunk \
http://svn.example.com/repos/calc/branches/my-calc-branch \
-m “Creating a private branch of /calc/trunk.”
Committed revision 341.
Merging branch to main trunk (Assuming you are in the working branch directory)
$svn merge -c 344 http://svn.example.com/repos/calc/trunk (merge change revision number 344 on your working directory branch)
U integer.c
$svn status
M integer.c
Merging while specifying the destination and target:
$svn merge -c 344 http://svn.example.com/repos/calc/trunk my-calc-branch
U my-calc-branch/integer.c
$svn merge http://svn.example.com/repos/branch1@150 \
http://svn.example.com/repos/branch2@212 \
my-working-copy
$svn merge -r 100:200 http://svn.example.com/repos/trunk my-working-copy
$svn merge -r 100:200 http://svn.example.com/repos/trunk
Previewing merges:
$svn merge – -dry-run -c 344 http://svn.example.com/repos/calc/trunk
U integer.c
(- -dry-run is a double dash without spaces. Word press munges the double dash into one when put together.)
$svn status
(nothing printed, working copy is still unchanged)
Merging branch changes into trunk:
$cd calc/trunk
$svn update
At revision 405.
$svn merge -r 341:405 http://svn.example.com/repos/calc/branches/my-calc-branch
U integer.c
U button.c
U Makefile
$svn status
M integer.c
M button.c
M Makefile
Examine the diffs, compile, test, etc…
$svn commit -m “Merged my-calc-branch changes r341:405 into the trunk.”
Sending integer.c
Sending button.c
Sending Makefile
Transmitting file data …
Committed revision 406
Undo a merge:
$svn merge -c -303 http://svn.example.com/repos/calc/trunk
or
$svn merge –revision 303:302 http://svn.example.com/repos/calc/trunk
U integer.c
$svn status
M integer.c
$svn diff
(Verify that the change is removed)
$svn commit -m “Undoing change committed in r303.”
Sending integer.c
Transmitting file data .
Committed revision 350.
Merging from branch to trunk:
$cd trunk-working-copy
$svn update
At revision 1910.
$svn merge http://svn.example.com/repos/calc/trunk@1910 \
http://svn.example.com/repos/calc/branches/mybranch@1910
U real.c
U integer.c
A newdirectory
A newdirectory/newfile
Resurrecting deleted items:
$svn copy -r 807 \
http://svn.example.com/repos/calc/trunk/real.c ./real.c
$ svn status
A + real.c
$svn commit -m “Resurrected real.c from revision 807, /calc/trunk/real.c.”
Adding real.c
Transmitting file data .
Committed revision 1390.
Traversing branches:
$cd calc
$svn info | grep URL
URL: http://svn.example.com/repos/calc/trunk
$svn switch http://svn.example.com/repos/calc/branches/my-calc-branch
U integer.c
U button.c
U Makefile
Updated to revision 341.
$svn info | grep URL
URL: http://svn.example.com/repos/calc/branches/my-calc-branch
Making releases using tags (snapshot of a directory at a given instant in time)
$svn copy http://svn.example.com/repos/calc/trunk \
http://svn.example.com/repos/calc/tags/release-1.0 \
-m “Tagging the 1.0 release of the ‘calc’ project.”
Committed revision 351.
Remove your branch after merge:
$svn delete http://svn.example.com/repos/calc/branches/my-calc-branch \
-m “Removing obsolete branch of calc project.”
Committed revision 375.
Commit a log message correction:
$echo “Here is the new, correct log message” > newlog.txt
$svnadmin setlog myrepos newlog.txt -r 388
Migrate repository:
Create the dump files first:
$svnadmin dump myrepos -r 23 > rev-23.dumpfile
$svnadmin dump myrepos -r 100:200 > revs-100-200.dumpfile
Load the dump files into the new repository:
$svnadmin dump myrepos -r 0:1000 > dumpfile1
$svnadmin dump myrepos -r 1001:2000 –incremental > dumpfile2
$svnadmin dump myrepos -r 2001:3000 –incremental > dumpfile3

Комментариев нет:
Отправить комментарий