cpp_photon/include/util/Task.hpp

154 lines
4.0 KiB
C++
Raw Normal View History

2005-03-15 19:21:51 +00:00
//This file is part of Photon (http://photon.sourceforge.net)
//Copyright (C) 2004-2005 James Turk
//
// Author:
// James Turk (jpt2433@rit.edu)
//
// Version:
2005-08-17 06:35:54 +00:00
// $Id: Task.hpp,v 1.1 2005/08/17 06:35:56 cozman Exp $
2005-03-15 19:21:51 +00:00
2005-08-17 06:35:54 +00:00
#ifndef PHOTON_UTIL_TASK_HPP
#define PHOTON_UTIL_TASK_HPP
2005-03-15 19:21:51 +00:00
#include <string>
#include "types.hpp"
namespace photon
{
2005-08-17 06:35:54 +00:00
namespace util
{
// Title: Task
2005-03-15 19:21:51 +00:00
// Enum: PriorityLevel
// Enumeration defining priority of a Task.
//
// Values:
// PRI_LOWEST - Lowest priority available.
// PRI_LOW - Lower-than-usual priority.
// PRI_NORMAL - Normal priority, suitable for most tasks.
// PRI_HIGH - Lower-than-usual priority.
// PRI_HIGHEST - Highest priority available.
enum PriorityLevel
{
PRI_HIGHEST,
PRI_HIGH,
PRI_NORMAL,
PRI_LOW,
PRI_LOWEST
};
2005-03-15 19:21:51 +00:00
// Class: Task
2005-08-17 06:35:54 +00:00
// Abstract class for tasks, which are runnable classes for use with
// <TaskManager>.
2005-03-15 19:21:51 +00:00
//
// When writing a task, only update() needs to be overloaded.
class Task
{
// Group: (Con/De)structors
public:
// Function: Task
// Constructor, every task needs a name and priority.
//
// Parameters:
// name - Name for task, must be unique!
// priority - Optional argument for desired priority for the Task,
2005-08-17 06:35:54 +00:00
// controls order in which tasks are run by the <TaskManager>.
// Default Priority is PRI_NORMAL
Task(const std::string& name, PriorityLevel priority=PRI_NORMAL);
2005-03-15 19:21:51 +00:00
// Function: ~Task
// Virtual destructor, exists simply to make inheritance safe.
virtual ~Task();
// Group: Control
public:
// Function: update
// Pure virtual, every child task must overload it's own update(), when a
// task is active this is called every 'frame.'
//
// Parameters:
// timeDelta - The time elapsed between frames, possibly fixed via
// <Application::setFixedUpdateStep>.
virtual void update(scalar timeDelta)=0;
2005-03-15 19:21:51 +00:00
// Function: onStart
// Virtual function, overload to define behavior when the task is started.
virtual void onStart();
// Function: onKill
// Virtual function, overload to define behavior when the task is killed.
virtual void onKill();
// Function: onPause
// Virtual function, overload to define behavior every time that the
// task is paused.
//
// Note:
// Children of onPause should call Task::onPause to let the task know it's
// been paused.
virtual void onPause();
// Function: onUnpause
// Virtual function, overload to define behavior every time that the
// task is unpaused.
//
// Note:
// Children of onUnpause should call Task::onUnpause to let the task know
// it's been paused.
virtual void onUnpause();
// Function: kill
2005-08-17 06:35:54 +00:00
// Sets state of task to dead, dead tasks remove themselves from the
// <TaskManager>'s task pool.
2005-03-15 19:21:51 +00:00
void kill();
// Group: Accessors
public:
// Function: getName
// Get the name of the task.
//
// Return:
// Name of task.
std::string getName() const;
// Function: getPriority
// Get the priority of the task.
//
// Return:
// priority of task.
uint getPriority() const;
2005-03-15 19:21:51 +00:00
// Function: isAlive
// Check if task is alive or not.
//
// Return:
// true if task is alive, false if task has been killed
bool isAlive() const;
// Function: isPaused
// Check if task is paused or not.
//
// Return:
// true iff task is paused
bool isPaused() const;
// data members
private:
2005-07-19 01:31:37 +00:00
std::string name_; // all tasks need a unique name
PriorityLevel priority_; // priority determines ordering of tasks
2005-07-19 01:31:37 +00:00
bool alive_; // if false, task will be pruned
bool paused_; // if false task won't be executed
2005-03-15 19:21:51 +00:00
};
// Type: TaskPtr
// Pointer to a task, used since Task is abstract and will always be accessed
// via a pointer.
typedef shared_ptr<Task> TaskPtr;
2005-08-17 06:35:54 +00:00
}
2005-03-15 19:21:51 +00:00
}
2005-08-17 06:35:54 +00:00
#endif //PHOTON_UTIL_TASK_HPP