data:image/s3,"s3://crabby-images/808d9/808d9bf4e19738c7b52addad92a1930fe3331bbd" alt=""
data:image/s3,"s3://crabby-images/f278d/f278dfedb4fdeea574acdd459d39edaa0dd4d0c4" alt=""
Содержание
-
История и внутреннее устройство
-
Локальный репозиторий
-
Практика
-
Удаленный репозиторий
-
Продвинутые команды
Система контроля версий (СКВ)
- Записывает изменения файлов
- Возвращает к старой версии
- Показывает изменения и кто их сделал
data:image/s3,"s3://crabby-images/20d0d/20d0dc421e6ca5a2c1bc9019a037776f7808671f" alt=""
Централизованные СКВ
data:image/s3,"s3://crabby-images/bc321/bc32186ea12dcaa6e4d25a89b03bc8d89af5e7a5" alt=""
Децентрализованные СКВ
data:image/s3,"s3://crabby-images/fef94/fef941268ecff80737c2b9578421c42c14d21cb0" alt=""
data:image/s3,"s3://crabby-images/e5716/e571638c8b2c42498a12e8c7f684873e6afbacef" alt=""
data:image/s3,"s3://crabby-images/98bd6/98bd697659daea687138994c79908836b396c7e7" alt=""
data:image/s3,"s3://crabby-images/46889/46889ce1bdf8b6b5f5848649d7eecb5cad81df10" alt=""
S
V
N
G
I
T
Про git
- Создатель Линус Торвальдс
-
He described the tool as "the stupid content tracker"
-
- Спроектирован для версионирования ядра линукс
- Первая версия через 3 дня
- Основные цели:
- Скорость
- Поддержка параллельной разработки
- Полная децентрализация
data:image/s3,"s3://crabby-images/4acad/4acadfa287f3938aa8dd4f5e21f0571517f1992d" alt=""
data:image/s3,"s3://crabby-images/f66d7/f66d7c41c31895034d9dd89528bac033b7c6b395" alt=""
data:image/s3,"s3://crabby-images/ddd40/ddd4022a193c3ccb89b2877fd13ff65b8e8c7874" alt=""
data:image/s3,"s3://crabby-images/24324/2432489f553f14049e2af9be05bb89a3c29a2b03" alt=""
data:image/s3,"s3://crabby-images/47711/47711c24fb74c4f1c4c49c6c2d3695568ad72221" alt=""
data:image/s3,"s3://crabby-images/bcae8/bcae8bdda65d4a8b414616675c1052b83bc74cd9" alt=""
Содержание
-
История и внутреннее устройство
-
Локальный репозиторий
-
Практика
-
Удаленный репозиторий
-
Продвинутые команды
Создание ветки
data:image/s3,"s3://crabby-images/fc596/fc596415c8e43daeb2f093e976d4761dc45f32c8" alt=""
Создание ветки
data:image/s3,"s3://crabby-images/fc596/fc596415c8e43daeb2f093e976d4761dc45f32c8" alt=""
$ git branch testing
Создание ветки
$ git checkout testing
data:image/s3,"s3://crabby-images/ff395/ff395c2ca82bbbc409b9f482404ed37eb50d0df9" alt=""
Создание ветки
data:image/s3,"s3://crabby-images/9ff67/9ff67e8fa7a474dd5e7ab8aad5fbda33c5c02de9" alt=""
$ git commit -m "A"
$ git checkout master
$ git commit -m "B"
Слияние веток
data:image/s3,"s3://crabby-images/dfe7c/dfe7c71423196ccfa9654404cd7fab09558033ab" alt=""
Слияние веток
data:image/s3,"s3://crabby-images/171c1/171c1d9edb704af17687e3ace7bd5d1ac6d4b9ce" alt=""
$ git checkout master
$ git merge hotfix
Updating f42c576..3a0874c
Fast-forward
index.html | 2 ++
1 file changed, 2 insertions(+)
Three-way merge
data:image/s3,"s3://crabby-images/fad0f/fad0fe014cddf8e9808d63afea9033aac3ab2d7e" alt=""
Three-way merge
data:image/s3,"s3://crabby-images/f7f7b/f7f7bb206a82460fcab179078085f3571def7cd8" alt=""
$ git checkout master
Switched to branch 'master'
$ git merge iss53
Merge made by the 'recursive' strategy.
index.html | 1 +
1 file changed, 1 insertion(+)
Three-way merge
data:image/s3,"s3://crabby-images/e70c5/e70c59550b0435acf2ef6e731f997bf7753e3b9c" alt=""
Содержание
-
История и внутреннее устройство
-
Локальный репозиторий
-
Практика
-
Удаленный репозиторий
-
Продвинутые команды
Начало работы
- установка git
- Утилита git config
- /etc/gitconfig (--system)
- ~/.gitconfig (--global)
- .git/config
- помощь
- git help add
- man git-add
- git add --help
Начало работы
$ git init
Initialized empty Git repository in /home/eugene/temp/test_git/.git/
$ vim big_integer.h # edit big_integer.h
$ git add big_integer.h
$ git commit -m "add constructors from int and from string"
[master (root-commit) 34c2334] add constructors from int and from string
1 file changed, 8 insertions(+)
create mode 100644 big_integer.h
git diff
$ git diff
$ git diff
diff --git a/big_integer.h b/big_integer.h
index 00968ba..3e719b0 100644
--- a/big_integer.h
+++ b/big_integer.h
@@ -5,4 +5,6 @@
class big_integer {
big_integer(int x);
big_integer(const std::string &s);
+
+ std::string to_string() const;
};
$ git add big_integer.h
$ git diff
$ echo -n "\nbig_integer operator+;\n" >> big_integer.h
$ git diff
diff --git a/big_integer.h b/big_integer.h
index 3e719b0..b864002 100644
--- a/big_integer.h
+++ b/big_integer.h
@@ -8,3 +8,4 @@ class big_integer {
std::string to_string() const;
};
+big_integer operator+;
$ git status
On branch master
Changes to be committed:
(use "git reset HEAD <file>..." to unstage)
modified: big_integer.h
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: big_integer.h
git log
$ git log
commit ca82a6dff817ec66f44342007202690a93763949
Author: Scott Chacon <schacon@gee-mail.com>
Date: Mon Mar 17 21:52:11 2008 -0700
changed the version number
commit 085bb3bcb608e1e8451d4b2432f8ecbe6306e7e7
Author: Scott Chacon <schacon@gee-mail.com>
Date: Sat Mar 15 16:40:33 2008 -0700
removed unnecessary test
$ git log -2
$ git log -p
$ git log --stat
$ git log --graph
* 2d3acf9 ignore errors from SIGCHLD on trap
* 5e3ee11 Merge branch 'master' of git://github.com/dustin/grit
|\
| * 420eac9 Added a method for getting the current branch.
* | 30e367c timeout code and tests
* | 5a09431 add timeout protection to grit
* | e1193f8 support for heads with slashes in them
|/
* d6016bc require time for xmlschema
$ git log --pretty
git branch
$ git branch
iss53
* master
testing
$ git branch -v
iss53 93b412c fix javascript issue
* master 7a98805 Merge branch 'iss53'
testing 782fd34 add scott to the author list in the readmes
$ git branch testing
$ git branch -d testing
error: The branch 'testing' is not fully merged.
If you are sure you want to delete it, run 'git branch -D testing'.
.gitignore
$ cat .gitignore
# no .a files
*.a
# but do track lib.a, even though you're ignoring .a files above
!lib.a
# only ignore the root TODO file, not subdir/TODO
/TODO
# ignore all files in the build/ directory
build/
# ignore doc/notes.txt, but not doc/server/arch.txt
doc/*.txt
# ignore all .txt files in the doc/ directory
doc/**/*.txt
Содержание
-
История и внутреннее устройство
-
Локальный репозиторий
-
Практика
-
Удаленный репозиторий
-
Продвинутые команды
data:image/s3,"s3://crabby-images/a3822/a38222242135c89069aa48124e7bd87fd8a6df91" alt=""
Удаленный репозиторий
Удаленный репозиторий
data:image/s3,"s3://crabby-images/18598/18598e5254f00dc561e8e8ee2b1505d926e0fd64" alt=""
Удаленный репозиторий
$ git clone https://github.com/sorokin/cpp-course.git cpp_course
$ git remote
origin
$ git remote add upstream https://github.com/paulboone/ticgit
$ git remote
origin
upstream
$ git fetch upstream
$ git push origin master
$ git remote show origin
* remote origin
Fetch URL: https://github.com/schacon/ticgit
Push URL: https://github.com/schacon/ticgit
HEAD branch: master
Remote branches:
master tracked
................
Удаленный репозиторий
data:image/s3,"s3://crabby-images/45750/45750d20c26c085659e3a2269c806f49d9e79b04" alt=""
Жизненный цикл
data:image/s3,"s3://crabby-images/881bf/881bf640d7c9e5b6c2f9abf1fe867f52f9438eb0" alt=""
data:image/s3,"s3://crabby-images/76f69/76f6941926903c3ba64b514fb71a5c5b43b11802" alt=""
Содержание
-
История и внутреннее устройство
-
Локальный репозиторий
-
Практика
-
Удаленный репозиторий
-
Продвинутые команды
data:image/s3,"s3://crabby-images/3270f/3270ff4b05eb7546c0c27bbf34f12cc87fb0c5e9" alt=""
data:image/s3,"s3://crabby-images/6a272/6a272550746521199bba68b628511b714144e394" alt=""
data:image/s3,"s3://crabby-images/65e69/65e6992dcd14f03355a117b0dd549b7a68af6260" alt=""
data:image/s3,"s3://crabby-images/8ec99/8ec99521df6005d5fc8c1f764ee1dc3ec48df768" alt=""
data:image/s3,"s3://crabby-images/18455/1845524a7b77ea7ce960827b7042f69b25698f66" alt=""
deck
By Eugene Nemchenko
deck
- 1,133