===== Разработка и логическая отладка программы по шаблону =====
TempletSDK содержит библиотеку времени исполнения gprt, которая реализует последовательное исполнение, что значительно упрощает отладку. Задачи извлекаются из очереди и завершаются в порядке их добавления в очередь, что является единственным отличием от параллельной версии и не является проблемой при правильной структуре программы. Реализация метода run приведена ниже:
void TBag::run()
{
task=createTask();
while(if_job()){ //проверка наличия задач для обработки
get(task); //вызов метода для получения данных задачи
task->cur=0;task->send_task(); //заполнение буфера данными задачи
task->cur=0;task->recv_task(); //чтение данных задачи из буфера
proc(task); //вызов обработчика задачи
task->cur=0;task->send_result(); //заполнение буфера данными результата обработки
task->cur=0;task->recv_result(); //чтение результатов обработки из буфера
put(task); //вызов обработчика результатов вычислений
}
delete task;
}
В отладочной версии библиотеки времени исполнения симулируется передача данных между вычислительными узлами, несмотря на то, что приложение работает в общей памяти.
Если после начала разработки приложения, уже был выбран отличная от gprt библиотека времени исполнения, то необходимо переключится на неё. Для этого необходимо заменить параметр rtl и путь к заголовочному файлу в файле описания структуры приложения. После чего файл gpTBag.txt должен выглядить подобным образом:
Генерируемая часть исходного кода приложения обновляется только при сборке проекта.