4. Что у нас есть?
•
Много проектов (уже больше 300);
•
Разные языки программирования;
•
Разные версии продуктов;
•
Разные команды;
•
Много разработчиков (тех, которые вносят
изменения).
8. А чего мы добиваемся?
•
Контроль изменений:
•
•
•
Откат;
Просмотр изменений между ревизиями.
Коллективная работа:
•
Слияние изменений;
•
Разрешение конфликтов.
17. Объекты в GIT: BLOB
$ find .git/objects -type f
.git/objects/1f/7a7a472abf3dd9643fd615f6da379c4acb3e3a
.git/objects/83/baae61804e65cc73a7201a7252750c76066a30
$ git cat-file -p 1f7a7a472abf3dd9643fd615f6da379c4acb3e3a
version 2
18. Объекты в GIT: Tree
$ git cat-file -p master^{tree}
100644 blob a906cb2a4a904a152e80877d4088654daad0c859
README
100644 blob 8f94139338f9404f26296befa88755fc2598c289
Rakefile
040000 tree 99f1a6d12cb4b6f19c8655fca46c3ecf317074e0
lib
$ git cat-file -p 99f1a6d12cb4b6f19c8655fca46c3ecf317074e0
100644 blob 47c6340d6459e05787f644c2447d2595f5d3a54b
simplegit.rb
23. GIT: Фишки
•
Локальный и удаленный репозиторий;
•
Очистка мусора (pack-объекты);
•
Вместо полного имени ревизии можно указывать
короткое;
•
Продвинутая работа с ветками.
25. Магия GIT: Rebase
$ git rebase -i HEAD~3
pick f7f3f6d changed my name a bit
pick 310154e updated README formatting and added blame
pick a5f4a0d added cat-file
# Rebase 710f0f8..a5f4a0d onto 710f0f8
# Commands:
#
p, pick = use commit
#
e, edit = use commit, but stop for amending
#
s, squash = use commit, but meld into previous commit
26. Редактирование коммитов
edit f7f3f6d changed my name a bit
pick 310154e updated README formatting and added blame
pick a5f4a0d added cat-file
$ git rebase -i HEAD~3
Stopped at 7482e0d... updated the gemspec to hopefully work better
You can amend the commit now, with
git commit --amend
Once you’re satisfied with your changes, run
git rebase --continue
27. Уплотнение коммитов
pick f7f3f6d changed my name a bit
squash 310154e updated README formatting and added blame
squash a5f4a0d added cat-file
# This is a combination of 3 commits.
# The first commit's message is:
changed my name a bit
# This is the 2nd commit message:
updated README formatting and added blame
# This is the 3rd commit message:
added cat-file
28. Разбиение коммитов
pick f7f3f6d changed my name a bit
edit 310154e updated README formatting and added blame
pick a5f4a0d added cat-file
$ git reset HEAD^
$ git add README
$ git commit -m 'updated README formatting'
$ git add lib/simplegit.rb
$ git commit -m 'added blame'
$ git rebase --continue