diff --git a/cpp/ci_logic.cpp b/cpp/ci_logic.cpp index cb3e152..0278ffc 100644 --- a/cpp/ci_logic.cpp +++ b/cpp/ci_logic.cpp @@ -639,69 +639,63 @@ std::string CiLogic::queue_pull_tarball(std::vector std::mutex task_assignment_mutex; try { - std::vector> futures; for (auto &r : repos) { - futures.push_back(std::async(std::launch::async, [this, &task_queue, &job_statuses, - &encountered_items, &task_assignment_mutex, - &r]() mutable { - { - std::lock_guard lock(task_assignment_mutex); - auto found_it = encountered_items.find(r->package->name); - if (found_it != encountered_items.end()) { - // GHOST pull - auto existing_item = found_it->second; + { + std::lock_guard lock(task_assignment_mutex); + auto found_it = encountered_items.find(r->package->name); + if (found_it != encountered_items.end()) { + // GHOST pull + auto existing_item = found_it->second; - // Assign tasks (reuse the same Task objects for "pull"/"tarball") - r->assign_task(job_statuses->at("pull"), existing_item->first_pull_task, r); - r->assign_task(job_statuses->at("tarball"), existing_item->first_tarball_task, r); + // Assign tasks (reuse the same Task objects for "pull"/"tarball") + r->assign_task(job_statuses->at("pull"), existing_item->first_pull_task, r); + r->assign_task(job_statuses->at("tarball"), existing_item->first_tarball_task, r); - // Point packaging_commit/upstream_commit to the real pkgconf's pointers - r->packaging_commit = existing_item->first_pkgconf->packaging_commit; - r->upstream_commit = existing_item->first_pkgconf->upstream_commit; - r->sync(); - return; - } + // Point packaging_commit/upstream_commit to the real pkgconf's pointers + r->packaging_commit = existing_item->first_pkgconf->packaging_commit; + r->upstream_commit = existing_item->first_pkgconf->upstream_commit; + r->sync(); + return; } - // REAL pull - auto new_item = std::make_shared(); - new_item->first_pkgconf = r; - r->sync(); + } + // REAL pull + auto new_item = std::make_shared(); + new_item->first_pkgconf = r; + r->sync(); - // Enqueue "pull" - task_queue->enqueue( - job_statuses->at("pull"), - [this, r](std::shared_ptr log) mutable { - pull_project(r, log); - r->sync(); - }, - r - ); + // Enqueue "pull" + task_queue->enqueue( + job_statuses->at("pull"), + [this, r](std::shared_ptr log) mutable { + pull_project(r, log); + r->sync(); + }, + r + ); - { - std::lock_guard lock(task_assignment_mutex); - new_item->first_pull_task = r->get_task_by_jobstatus(job_statuses->at("pull")); - } + { + std::lock_guard lock(task_assignment_mutex); + new_item->first_pull_task = r->get_task_by_jobstatus(job_statuses->at("pull")); + } - // Enqueue "tarball" - task_queue->enqueue( - job_statuses->at("tarball"), - [this, r](std::shared_ptr log) mutable { - create_project_tarball(r, log); - r->sync(); - }, - r - ); + // Enqueue "tarball" + task_queue->enqueue( + job_statuses->at("tarball"), + [this, r](std::shared_ptr log) mutable { + create_project_tarball(r, log); + r->sync(); + }, + r + ); - { - std::lock_guard lock(task_assignment_mutex); - new_item->first_tarball_task = r->get_task_by_jobstatus(job_statuses->at("tarball")); - encountered_items[r->package->name] = new_item; - } + { + std::lock_guard lock(task_assignment_mutex); + new_item->first_tarball_task = r->get_task_by_jobstatus(job_statuses->at("tarball")); + encountered_items[r->package->name] = new_item; + } - r->sync(); - })); + r->sync(); } - for (auto& future : futures) future.get(); msg = "Succeeded"; } catch (...) { msg = "Failed";