mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-24 01:31:46 +00:00
Remove deprecated Task class (#550)
This commit is contained in:
committed by
Peter Johnson
parent
462b231dac
commit
0cd03c66e3
@@ -1,72 +0,0 @@
|
||||
/*----------------------------------------------------------------------------*/
|
||||
/* Copyright (c) FIRST 2008-2017. All Rights Reserved. */
|
||||
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
||||
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
||||
/* the project. */
|
||||
/*----------------------------------------------------------------------------*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
#include <string>
|
||||
#include <thread>
|
||||
|
||||
#include "ErrorBase.h"
|
||||
#include "HAL/HAL.h"
|
||||
#include "support/deprecated.h"
|
||||
|
||||
namespace frc {
|
||||
|
||||
/**
|
||||
* Wrapper class around std::thread that allows changing thread priority
|
||||
*/
|
||||
class WPI_DEPRECATED(
|
||||
"Task API scheduled for removal in 2018. Replace with std::thread, and use "
|
||||
"Threads API for setting priority") Task : public ErrorBase {
|
||||
public:
|
||||
static const int kDefaultPriority = 60;
|
||||
|
||||
Task() = default;
|
||||
Task(const Task&) = delete;
|
||||
Task& operator=(const Task&) = delete;
|
||||
Task& operator=(Task&& task);
|
||||
|
||||
template <class Function, class... Args>
|
||||
Task(const std::string& name, Function&& function, Args&&... args);
|
||||
|
||||
virtual ~Task();
|
||||
|
||||
bool joinable() const noexcept;
|
||||
void join();
|
||||
void detach();
|
||||
std::thread::id get_id() const noexcept;
|
||||
std::thread::native_handle_type native_handle();
|
||||
|
||||
bool Verify();
|
||||
|
||||
int GetPriority();
|
||||
|
||||
bool SetPriority(int priority);
|
||||
|
||||
std::string GetName() const;
|
||||
|
||||
private:
|
||||
std::thread m_thread;
|
||||
std::string m_taskName;
|
||||
|
||||
typedef int32_t TASK_STATUS;
|
||||
|
||||
static constexpr int32_t TASK_OK = 0;
|
||||
static constexpr int32_t TASK_ERROR = -1;
|
||||
static constexpr int32_t TaskLib_ILLEGAL_PRIORITY = 22; // 22 is EINVAL
|
||||
|
||||
bool HandleError(TASK_STATUS results);
|
||||
TASK_STATUS VerifyTaskId();
|
||||
TASK_STATUS GetTaskPriority(int32_t* priority);
|
||||
TASK_STATUS SetTaskPriority(int32_t priority);
|
||||
};
|
||||
|
||||
} // namespace frc
|
||||
|
||||
#include "Task.inc"
|
||||
@@ -1,44 +0,0 @@
|
||||
/*----------------------------------------------------------------------------*/
|
||||
/* Copyright (c) FIRST 2016-2017. All Rights Reserved. */
|
||||
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
||||
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
||||
/* the project. */
|
||||
/*----------------------------------------------------------------------------*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
#include <atomic>
|
||||
#include <iostream>
|
||||
#include <string>
|
||||
#include <utility>
|
||||
|
||||
namespace frc {
|
||||
|
||||
/**
|
||||
* Create and launch a task.
|
||||
*
|
||||
* @param name The name of the task. "FRC_" will be prepended to the task name.
|
||||
* @param function The address of the function to run as the new task.
|
||||
* @param args A parameter pack of arguments to pass to the function.
|
||||
*/
|
||||
template <class Function, class... Args>
|
||||
Task::Task(const std::string& name, Function&& function, Args&&... args) {
|
||||
m_taskName = "FRC_";
|
||||
m_taskName += name;
|
||||
|
||||
std::cout << "[HAL] Starting task " << m_taskName << "..." << std::endl;
|
||||
|
||||
m_thread = std::thread(std::forward<std::decay_t<Function>>(function),
|
||||
std::forward<Args>(args)...);
|
||||
// TODO: lvuser does not currently have permissions to set the priority.
|
||||
// SetPriority(kDefaultPriority);
|
||||
|
||||
static std::atomic<int32_t> instances{0};
|
||||
instances++;
|
||||
HAL_Report(HALUsageReporting::kResourceType_Task, instances, 0,
|
||||
m_taskName.c_str());
|
||||
}
|
||||
|
||||
} // namespace frc
|
||||
@@ -1,140 +0,0 @@
|
||||
/*----------------------------------------------------------------------------*/
|
||||
/* Copyright (c) FIRST 2008-2017. All Rights Reserved. */
|
||||
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
||||
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
||||
/* the project. */
|
||||
/*----------------------------------------------------------------------------*/
|
||||
|
||||
#include "Task.h"
|
||||
|
||||
#include <signal.h>
|
||||
|
||||
#include <cerrno>
|
||||
|
||||
#include "WPIErrors.h"
|
||||
|
||||
namespace frc {
|
||||
|
||||
const int Task::kDefaultPriority;
|
||||
|
||||
Task& Task::operator=(Task&& task) {
|
||||
m_thread.swap(task.m_thread);
|
||||
m_taskName = std::move(task.m_taskName);
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
Task::~Task() {
|
||||
if (m_thread.joinable()) {
|
||||
std::cout << "[HAL] Exited task " << m_taskName << std::endl;
|
||||
}
|
||||
}
|
||||
|
||||
bool Task::joinable() const noexcept { return m_thread.joinable(); }
|
||||
|
||||
void Task::join() { m_thread.join(); }
|
||||
|
||||
void Task::detach() { m_thread.detach(); }
|
||||
|
||||
std::thread::id Task::get_id() const noexcept { return m_thread.get_id(); }
|
||||
|
||||
std::thread::native_handle_type Task::native_handle() {
|
||||
return m_thread.native_handle();
|
||||
}
|
||||
|
||||
/**
|
||||
* Verifies a task still exists.
|
||||
*
|
||||
* @return true on success.
|
||||
*/
|
||||
bool Task::Verify() { return VerifyTaskId() == TASK_OK; }
|
||||
|
||||
/**
|
||||
* Gets the priority of a task.
|
||||
*
|
||||
* @return task priority or 0 if an error occured
|
||||
*/
|
||||
int Task::GetPriority() {
|
||||
int priority;
|
||||
if (HandleError(GetTaskPriority(&priority)))
|
||||
return priority;
|
||||
else
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* This routine changes a task's priority to a specified priority.
|
||||
* Priorities range from 1, the lowest priority, to 99, the highest priority.
|
||||
* Default task priority is 60.
|
||||
*
|
||||
* @param priority The priority at which the internal thread should run.
|
||||
* @return true on success.
|
||||
*/
|
||||
bool Task::SetPriority(int priority) {
|
||||
return HandleError(SetTaskPriority(priority));
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the name of the task.
|
||||
*
|
||||
* @return The name of the task.
|
||||
*/
|
||||
std::string Task::GetName() const { return m_taskName; }
|
||||
|
||||
Task::TASK_STATUS Task::VerifyTaskId() {
|
||||
auto task = m_thread.native_handle();
|
||||
if (pthread_kill(task, 0) == 0) {
|
||||
return TASK_OK;
|
||||
} else {
|
||||
return TASK_ERROR;
|
||||
}
|
||||
}
|
||||
|
||||
Task::TASK_STATUS Task::GetTaskPriority(int32_t* priority) {
|
||||
auto task = m_thread.native_handle();
|
||||
int32_t policy = 0;
|
||||
struct sched_param param;
|
||||
|
||||
if (VerifyTaskId() == TASK_OK &&
|
||||
pthread_getschedparam(task, &policy, ¶m) == 0) {
|
||||
*priority = param.sched_priority;
|
||||
return TASK_OK;
|
||||
} else {
|
||||
return TASK_ERROR;
|
||||
}
|
||||
}
|
||||
|
||||
Task::TASK_STATUS Task::SetTaskPriority(int32_t priority) {
|
||||
auto task = m_thread.native_handle();
|
||||
int32_t policy = 0;
|
||||
struct sched_param param;
|
||||
|
||||
if (VerifyTaskId() == TASK_OK &&
|
||||
pthread_getschedparam(task, &policy, ¶m) == 0) {
|
||||
param.sched_priority = priority;
|
||||
if (pthread_setschedparam(task, SCHED_FIFO, ¶m) == 0) {
|
||||
return TASK_OK;
|
||||
} else {
|
||||
return TASK_ERROR;
|
||||
}
|
||||
} else {
|
||||
return TASK_ERROR;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Handles errors generated by task related code.
|
||||
*/
|
||||
bool Task::HandleError(TASK_STATUS results) {
|
||||
if (results != TASK_ERROR) return true;
|
||||
int errsv = errno;
|
||||
if (errsv == TaskLib_ILLEGAL_PRIORITY) {
|
||||
wpi_setWPIErrorWithContext(TaskPriorityError, m_taskName.c_str());
|
||||
} else {
|
||||
std::printf("ERROR: errno=%i", errsv);
|
||||
wpi_setWPIErrorWithContext(TaskError, m_taskName.c_str());
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
} // namespace frc
|
||||
Reference in New Issue
Block a user