Денис Чистяков: Системы контроля версий

Preview:

Citation preview

Руководитель группы разработки

Системы контроля версийЧистяков Денис

Школа Разработки Интерфейсов,Екатеринбург, 19 сентября 2013

Мир без VCS

Резервные копии

3

Резервные копии

•Плюсы– Простой старт– Не требует дополнительных навыков и программ

•Минусы– Проект разрастается и папочек становится слишком много

– Сложно находить различия между «версиями»

– Непригодно для совместной разработки4

Для чего нам нужны VCS

•Архивация и восстановление•Синхронизация работы команды•Хранение истории разработки•Отмена изменений•Экспериментальные реализации

5

Базовые термины

•репозиторий, сервер, клиент•рабочая копия, ревизия, коммит, описание коммита

•ветки, слияния, конфликты

6

ЦентрализованныеSVN, CVS, Perforce

ДецентрализованныеGIT, Mercurial, Bazaar

VCS бывают

Централизованные

Децентрализованные

Приготовим обед в GIT`е

10

git add milkgit commit -m 'Добавлено молоко'git add eggsgit commit -m 'Добавлены яйца'git add juicegit commit -m 'Добавлен сок'git rm juicegit add soupgit commit -m 'Добавлен суп'git push origin master

Добавление, удаление, коммит и

11

Ветвление

12

git checkout -b 'rice'git add ricegit commit -m 'Добавлен рис'git push origin rice

Ветвление

13

Ветка «Рис»:

Мастер:

git checkout mastergit add breadgit commit -m 'Добавлен хлеб'git push origin master

14

Ветвление

Слияние

15

Мастер:

git checkout mastergit pullgit merge ricegit push origin master

16

Слияние

Конфликты

17

Мастер:

git checkout mastergit pullgit merge ricegit checkout eggs --ours / --theirsgit add eggsgit commitgit push origin master

18

Конфликты

Базовые действия

•clone•checkout•add / rm•commit•branch•merge•diff•pull•push

19

GitHub Flow

Fork

Fork

Fork`и и PullRequest`ы - это не магия

Полезные ссылки

• http://io.git-init.ru/git-trainer/ — визуальный эмулятор GIT

• http://windows.github.com/ — GUI-клиент для Windows

• http://try.github.io/ — набор уроков по GIT с визуализацией

• http://git-scm.com/book/ru — электронная книга Pro GIT

22

Фронтенд разработчик

dench@yandex-team.ru@denchistyakov

Спасибо!

Чистяков Денис