Данная лабораторная работа посвещена изучению систем контроля версий на примере Git.
$ open https://git-scm.com- 1. Создать публичный репозиторий с названием lab02 и с лиценцией MIT
- 2. Сгенирировать токен для доступа к сервису GitHub с правами repo
- 3. Ознакомиться со ссылками учебного материала
- 4. Выполнить инструкцию учебного материала
- 5. Составить отчет и отправить ссылку личным сообщением в Slack
$ export GITHUB_USERNAME=<имя_пользователя> $ export GITHUB_EMAIL=<адрес_почтового_ящика> $ export GITHUB_TOKEN=<сгенирированный_токен>
$ alias edit=<nano|vi|vim|subl>
$ cd ${GITHUB_USERNAME}/workspace
$ source scripts/activate
$ mkdir ~/.config
$ cat > ~/.config/hub <<EOF github.com:
- user:
${GITHUB_USERNAME} oauth_token: $ {GITHUB_TOKEN} protocol: https EOF
$ git config --global hub.protocol https
$ mkdir projects/lab02 && cd projects/lab02
$ git init
$ git config --global user.name
$ git config -e --global
$ git remote add origin https://github.com/${GITHUB_USERNAME}/lab02.git
$ git pull origin master
$ touch README.md
$ git status
$ git add README.md
$ git commit -m "added README.md"
$ git push origin master
Добавить на сервисе GitHub в репозитории lab02 файл .gitignore со следующем содержимом:
build/ install/ *.swp .idea/
$ git pull origin master
$ git log
$ mkdir sources $ mkdir include $ mkdir examples
$ cat > sources/print.cpp <<EOF
void print(const std::string& text, std::ostream& out) { out << text; } void print(const std::string& text, std::ofstream& out) { out << text; } EOF
$ cat > include/print.hpp <<EOF
void print(const std::string& text, std::ofstream& out); void print(const std::string& text, std::ostream& out = std::cout); EOF
$ cat > examples/example1.cpp <<EOF
int main(int argc, char** argv) { print("hello"); } EOF
$ cat > examples/example2.cpp <<EOF
int main(int argc, char** argv) { std::ofstream file("log.txt"); print(std::string("hello"), file); } EOF
$ edit README.md
$ git status
$ git add .
$ git commit -m" added sources"
$ git push origin master
- Создайте пустой репозиторий на сервисе github.com (или gitlab.com, или bitbucket.com).
- Выполните инструкцию по созданию первого коммита на странице репозитория, созданного на предыдещем шаге.
- Создайте файл
hello_world.cppв локальной копии репозитория (который должен был появиться на шаге 2). Реализуйте программу Hello world на языке C++ используя плохой стиль кода. Например, после заголовочных файлов вставьте строкуusing namespace std;. - Добавьте этот файл в локальную копию репозитория.
- Закоммитьте изменения с осмысленным сообщением.
- Изменитьте исходный код так, чтобы программа через стандартный поток ввода запрашивалось имя пользователя. А в стандартный поток вывода печаталось сообщение
Hello world from @name, где@nameимя пользователя. - Закоммитьте новую версию программы. Почему не надо добавлять файл повторно
git add? - Запуште изменения в удалёный репозиторий.
- Проверьте, что история коммитов доступна в удалёный репозитории.
Note: Работать продолжайте с теми же репоззиториями, что и в первой части задания.
- В локальной копии репозитория создайте локальную ветку
patch1. - Внесите изменения в ветке
patch1по исправлению кода и избавления отusing namespace std;. - commit, push локальную ветку в удалённый репозиторий.
- Проверьте, что ветка
patch1доступна в удалёный репозитории. - Создайте pull-request
patch1 -> master. - В локальной копии в ветке
patch1добавьте в исходный код комментарии. - commit, push.
- Проверьте, что новые изменения есть в созданном на шаге 5 pull-request
- В удалённый репозитории выполните слияние PR
patch1 -> masterи удалите веткуpatch1в удаленном репозитории. - Локально выполните pull.
- С помощью команды git log просмотрите историю в локальной версии ветки
master. - Удалите локальную ветку
patch1.
Note: Работать продолжайте с теми же репоззиториями, что и в первой части задания.
- Создайте новую локальную ветку
patch2. - Измените code style с помощью утилиты clang-format. Например, используя опцию
-style=Mozilla. - commit, push, создайте pull-request
patch2 -> master. - В ветке master в удаленном репозитории измените комментарии, например, расставьте знаки препинания, переведите комментарии на другой язык.
- Убедитесь, что в pull-request появились конфликтны.
- Для этого локально выполните pull + rebase (точную последовательность команд, следует узнать самостоятельно). Исправьте конфликты.
- Сделайте force push в ветку
patch2 - Убедитель, что в pull-request пропали конфликтны.
- Вмержите pull-request
patch2 -> master.
Copyright (c) 2015-2019 The ISC Authors