Разработать иерархию классов в соответствии со следующей диаграммой:
Перечень классов:
- Employee - работник. Основной родительский класс для всех разновидностей работников.
- Pesonal - работник по найму с оплатой за фактически отработанное время. Имеет ставку за час.
- Engineer - инженер. Имеет ставку и оплату за час + бонусы от выполняемого проекта.
- Manager - менеджер. Оплату получает из денег проекта, которым руководит.
- Cleaner - уборщица.
- Driver - водитель.
- Programmer - инженер-программист.
- TeamLeader - ведущий программист.
- Tester - инженер по тестированию.
- ProjectManager - проектный менеджер.
- SeniorManager - руководитель направления.
Перечень интерфейсов:
- WorkTime - расчет оплаты исходя из отработанного времени (часы умножаются на ставку).
- Project - расчет оплаты исходя из участия в проекте (бюджет проекта делится пропорционально персональному вкладу).
- Heading - расчет оплаты исходя из руководства (количество подчиненных).
Этот, наиболее важный класс, должен содержать поля:
- id - идентификационный номер.
- name - ФИО.
- worktime - отработанное время.
- payment - заработная плата.
Заработная плата работникам начисляется, исходя из должности, почасовой ставки и участию в проектах.
Подготовить текстовый файл со списком сотрудников. Информация о каждом сотруднике должна включать:
- id - идентификационный номер.
- name - ФИО сотрудника.
- position - должность.
- base - базовая ставка руб./час (если нужна).
- project - название проекта (если нужен).
Написать демонстрационное приложение, которое создает штат сотрудников на основе данных из текстового файла и рассчитывает им зарплату, исходя из отработанного времени и участия в проектах. Информация о сотрудниках, об отработанном времени и заработной плате выводится на экран в виде таблицы.
ФИО | Имя ветки |
---|
Для выполнения работы необходимо:
- Выполнить fork репозитария в свой аккаунт.
- Выполнить клонирование репозитария из своего аккаунта к себе на локальную машину (
git clone
). - Создать ветку git с индивидуальным номером (
git branch имя_ветки
). - Сделать ветку активной (
git checkout имя
). - Необходимо разместить как исходные файлы с решениями задач, поместив cpp файлы в src, а заголовочные - в include.
- Добавить файлы в хранилище (
git add
). - Выполнить фиксацию изменений (
git commit -m "комментарий"
). - Отправить содержимое ветки в свой удаленный репозитарий (
git push origin имя_ветки
). - Создать пул-запрос в репозитарий группы и ждать результата от Travis-CI.