Удалены упоминания неиспользуемого cust-ibank-customize authored by Николай Кальгин's avatar Николай Кальгин
# Добавление нового модуля # Добавление нового модуля
*При прочтении данной главы подразумевается, что вы уже ознакомились и поняли содержимое глав *При прочтении данной главы подразумевается, что вы уже ознакомились и поняли содержимое глав
["Основы Git"](https://source.isimplelab.com/publics/howto/wikis/git-essentials) и ["Основы Git"](https://source.isimplelab.com/docs/howto/wikis/git-essentials) и
["Работа с подмодулями"](https://source.isimplelab.com/publics/howto/wikis/submodule-basic).* ["Работа с подмодулями"](https://source.isimplelab.com/docs/howto/wikis/submodule-basic).*
1) Создать новый Git-репозиторий в соответствующей группе. Сейчас группировка репозиториев осуществляется по подсистемам, например, АБС (abs), нотификация (notify), платёжные системы (plat), ядро (core), кастомизации (ibank) и т.д. 1) Создать новый Git-репозиторий в соответствующей группе. Сейчас группировка репозиториев осуществляется по подсистемам, например, АБС (abs), нотификация (notify), платёжные системы (plat), ядро (core), кастомизации (ibank) и т.д.
Если с определением подходящей группы возникают сложности, следует обратиться за помощью к более опытному сотруднику. Если с определением подходящей группы возникают сложности, следует обратиться за помощью к более опытному сотруднику.
...@@ -19,7 +19,7 @@ git clone git@source.isimplelab.com:/<group_name>/<new_module_name.git> ...@@ -19,7 +19,7 @@ git clone git@source.isimplelab.com:/<group_name>/<new_module_name.git>
Наполняем его полезным содержимым и фиксируем это содержимое, добиваемся того чтобы новый модуль компилировался без ошибок (программа минимум) и выполнял свою работу в рамках поставленной задачи (то к чему нужно стремиться). Наполняем его полезным содержимым и фиксируем это содержимое, добиваемся того чтобы новый модуль компилировался без ошибок (программа минимум) и выполнял свою работу в рамках поставленной задачи (то к чему нужно стремиться).
- **Только когда обе цели будут достигнуты**, необходимо опубликовать свои наработки в удаленном репозитории данного модуля, иначе говоря сделать *push* в основной ствол и, при необходимости, в стабильную ветку: - **Только когда обе цели будут достигнуты**, необходимо опубликовать свои наработки в удаленном репозитории данного модуля, иначе говоря сделать *push* в основной ствол и, при необходимости, в стабильную ветку:
``` ```bash
git commit -m "Создан новый модуль имя_нового_модуля" git commit -m "Создан новый модуль имя_нового_модуля"
# публикуем изменения в основном стволе центрального репозитория # публикуем изменения в основном стволе центрального репозитория
git push origin master git push origin master
...@@ -35,19 +35,18 @@ git push origin ibankfl-branch-2-0-12-393 ...@@ -35,19 +35,18 @@ git push origin ibankfl-branch-2-0-12-393
- Добавить в каталоге проекта ibank_root в файл settings.gradle в раздел include имя нового модуля. - Добавить в каталоге проекта ibank_root в файл settings.gradle в раздел include имя нового модуля.
Имя нового модуля совпадает с именем каталога, куда он был склонирован. Имя нового модуля совпадает с именем каталога, куда он был склонирован.
Добавить изменённый settings.gradle в индекс: Добавить изменённый settings.gradle в индекс:
``` ```bash
git add settings.gradle git add settings.gradle
``` ```
- Определиться чем является новый модуль. Кастомизацией конкретного банка или функциональным блоком, пригодным к использованию в нескольких банках. От этого выбора зависит куда дальше мы прописываем инструкции сборки. - Определиться чем является новый модуль. Кастомизацией конкретного банка или функциональным блоком, пригодным к использованию в нескольких банках. От этого выбора зависит куда дальше мы прописываем инструкции сборки.
Если модуль является кастомизацией конкретного банка, то следующий шаг будет выполняться в модуле *cust-ibank-customize*
Если модуль является функциональным блоком, пригодным к использованию в различных банках, то следующий шаг будет выполняться в модуле *cust-ibank-ul-installer* Если модуль является функциональным блоком, пригодным к использованию в различных банках, то следующий шаг будет выполняться в модуле *cust-ibank-ul-installer*
- Добавить в build.gradle в раздел dependencies дерективу - Добавить в build.gradle в раздел dependencies дерективу
``` ```
compile project(':имя_нового_модуля') compile project(':имя_нового_модуля')
``` ```
- Изменения build.gradle, внесённые в cust-ibank-customize или cust-ibank-ul-installer, необходимо зафиксировать и опубликовать. - Изменения build.gradle, внесённые в cust-ibank-ul-installer, необходимо зафиксировать и опубликовать.
``` ```
git add build.gradle git add build.gradle
git commit -m "Добавлен новый модуль имя_нового_модуля" git commit -m "Добавлен новый модуль имя_нового_модуля"
...@@ -67,16 +66,15 @@ git submodule add git@source.isimplelab.com:/<group_name>/<new_module_name.git> ...@@ -67,16 +66,15 @@ git submodule add git@source.isimplelab.com:/<group_name>/<new_module_name.git>
Изменения отражаются в файле `.gitmodules`. Изменения отражаются в файле `.gitmodules`.
- Добавляем в индекс изменения, внесённые ранее в cust-ibank-customize или cust-ibank-ul-installer: - Добавляем в индекс изменения:
``` ```
git add cust-ibank-customize
git add cust-ibank-ul-installer git add cust-ibank-ul-installer
``` ```
Таким образом в следующий коммит ibank_root обязательно должны войти изменения в: Таким образом в следующий коммит ibank_root обязательно должны войти изменения в:
1. `settings.gradle`; 1. `settings.gradle`;
2. `build.gradle` модулей cust-ibank-customize или cust-ibank-ul-installer внесённые ранее; 2. `build.gradle` модуля cust-ibank-ul-installer внесённые ранее;
3. Добавление нового подмодуля Git. 3. Добавление нового подмодуля Git.
Убедиться в этом можно просмотрев вывод команды `git status`, находясь в каталоге ibank_root. Убедиться в этом можно просмотрев вывод команды `git status`, находясь в каталоге ibank_root.
... ...
......