mirror of
https://github.com/mongodb/mongo.git
synced 2024-12-01 09:32:32 +01:00
task
This commit is contained in:
parent
d2e6035de9
commit
13fc91124c
@ -43,6 +43,7 @@
|
|||||||
#include "module.h"
|
#include "module.h"
|
||||||
#include "cmdline.h"
|
#include "cmdline.h"
|
||||||
#include "stats/snapshots.h"
|
#include "stats/snapshots.h"
|
||||||
|
#include "../util/concurrency/task.h"
|
||||||
|
|
||||||
namespace mongo {
|
namespace mongo {
|
||||||
|
|
||||||
|
@ -18,17 +18,79 @@
|
|||||||
|
|
||||||
#include "pch.h"
|
#include "pch.h"
|
||||||
#include "task.h"
|
#include "task.h"
|
||||||
|
//#include "../goodies.h"
|
||||||
|
|
||||||
namespace mongo {
|
namespace mongo {
|
||||||
|
|
||||||
namespace task {
|
namespace task {
|
||||||
|
|
||||||
Task::~Task() { }
|
|
||||||
|
|
||||||
void Task::run() { }
|
/*
|
||||||
|
#define MS_VC_EXCEPTION 0x406D1388
|
||||||
|
|
||||||
|
#pragma pack(push,8)
|
||||||
|
typedef struct tagTHREADNAME_INFO
|
||||||
|
{
|
||||||
|
DWORD dwType; // Must be 0x1000.
|
||||||
|
LPCSTR szName; // Pointer to name (in user addr space).
|
||||||
|
DWORD dwThreadID; // Thread ID (-1=caller thread).
|
||||||
|
DWORD dwFlags; // Reserved for future use, must be zero.
|
||||||
|
} THREADNAME_INFO;
|
||||||
|
#pragma pack(pop)
|
||||||
|
|
||||||
|
void SetThreadName( DWORD dwThreadID, char* threadName)
|
||||||
|
{
|
||||||
|
Sleep(10);
|
||||||
|
THREADNAME_INFO info;
|
||||||
|
info.dwType = 0x1000;
|
||||||
|
info.szName = threadName;
|
||||||
|
info.dwThreadID = dwThreadID;
|
||||||
|
info.dwFlags = 0;
|
||||||
|
|
||||||
|
__try
|
||||||
|
{
|
||||||
|
RaiseException( MS_VC_EXCEPTION, 0, sizeof(info)/sizeof(ULONG_PTR), (ULONG_PTR*)&info );
|
||||||
|
}
|
||||||
|
__except(EXCEPTION_EXECUTE_HANDLER)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
void fork(const shared_ptr<Task>& t) {
|
Task::Task() {
|
||||||
cout << "not yet implemented" << endl;
|
n = 0;
|
||||||
|
repeat = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Task::halt() { repeat = 0; }
|
||||||
|
|
||||||
|
void Task::run() {
|
||||||
|
//SetThreadName(-1, "A Task");
|
||||||
|
assert( n == 0 );
|
||||||
|
while( 1 ) {
|
||||||
|
n++;
|
||||||
|
try {
|
||||||
|
doWork();
|
||||||
|
}
|
||||||
|
catch(...) { }
|
||||||
|
if( repeat == 0 )
|
||||||
|
break;
|
||||||
|
sleepmillis(repeat);
|
||||||
|
}
|
||||||
|
me.reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Task::begin(shared_ptr<Task> t) {
|
||||||
|
me = t;
|
||||||
|
go();
|
||||||
|
}
|
||||||
|
|
||||||
|
void fork(shared_ptr<Task> t) {
|
||||||
|
t->begin(t);
|
||||||
|
}
|
||||||
|
|
||||||
|
void repeat(shared_ptr<Task> t, unsigned millis) {
|
||||||
|
t->repeat = millis;
|
||||||
|
t->begin(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -24,22 +24,36 @@ namespace mongo {
|
|||||||
|
|
||||||
namespace task {
|
namespace task {
|
||||||
|
|
||||||
class Task : protected BackgroundJob {
|
class Task : private BackgroundJob {
|
||||||
virtual void run();
|
|
||||||
protected:
|
protected:
|
||||||
virtual void go() = 0;
|
virtual void doWork() = 0;
|
||||||
public:
|
public:
|
||||||
virtual ~Task();
|
Task();
|
||||||
|
|
||||||
|
/** for a repeating task, stop after current invocation ends. */
|
||||||
|
void halt();
|
||||||
|
|
||||||
|
private:
|
||||||
|
shared_ptr<Task> me;
|
||||||
|
unsigned n, repeat;
|
||||||
|
friend void fork(shared_ptr<Task> t);
|
||||||
|
friend void repeat(shared_ptr<Task> t, unsigned millis);
|
||||||
|
virtual void run();
|
||||||
|
void begin(shared_ptr<Task>);
|
||||||
};
|
};
|
||||||
|
|
||||||
void fork(const shared_ptr<Task>& t);
|
/* run once */
|
||||||
|
void fork(shared_ptr<Task> t);
|
||||||
|
|
||||||
|
/* run doWork() over and over, with a pause between runs of millis */
|
||||||
|
void repeat(shared_ptr<Task> t, unsigned millis);
|
||||||
|
|
||||||
/*** Example ***
|
/*** Example ***
|
||||||
inline void sample() {
|
inline void sample() {
|
||||||
class Sample : public Task {
|
class Sample : public Task {
|
||||||
public:
|
public:
|
||||||
int result;
|
int result;
|
||||||
virtual void go() { result = 1234; }
|
virtual void doWork() { result = 1234; }
|
||||||
Sample() : result(0) { }
|
Sample() : result(0) { }
|
||||||
};
|
};
|
||||||
shared_ptr<Sample> q( new Sample() );
|
shared_ptr<Sample> q( new Sample() );
|
||||||
|
Loading…
Reference in New Issue
Block a user