aboutsummaryrefslogtreecommitdiff
path: root/src/shared
diff options
context:
space:
mode:
Diffstat (limited to 'src/shared')
-rw-r--r--src/shared/DelayExecutor.cpp57
-rw-r--r--src/shared/DelayExecutor.h12
2 files changed, 35 insertions, 34 deletions
diff --git a/src/shared/DelayExecutor.cpp b/src/shared/DelayExecutor.cpp
index 07a691d6357..9a718823232 100644
--- a/src/shared/DelayExecutor.cpp
+++ b/src/shared/DelayExecutor.cpp
@@ -4,16 +4,15 @@
#include "DelayExecutor.h"
-DelayExecutor*
-DelayExecutor::instance()
+DelayExecutor* DelayExecutor::instance()
{
return ACE_Singleton<DelayExecutor, ACE_Thread_Mutex>::instance();
}
-DelayExecutor::DelayExecutor():
-activated_ (false),
-pre_svc_hook_ (0),
-post_svc_hook_ (0) {}
+DelayExecutor::DelayExecutor()
+ : activated_(false), pre_svc_hook_(0), post_svc_hook_(0)
+{
+}
DelayExecutor::~DelayExecutor()
{
@@ -23,49 +22,46 @@ DelayExecutor::~DelayExecutor()
if (post_svc_hook_)
delete post_svc_hook_;
- this->deactivate ();
+ deactivate();
}
int DelayExecutor::deactivate()
{
- if (!this->activated())
+ if (!activated())
return -1;
- this->activated(false);
-
- this->queue_.queue()->deactivate();
-
- this->wait();
+ activated(false);
+ queue_.queue()->deactivate();
+ wait();
return 0;
}
-int DelayExecutor::svc (void)
+int DelayExecutor::svc()
{
if (pre_svc_hook_)
pre_svc_hook_->call();
for (;;)
{
- ACE_Method_Request* rq = this->queue_.dequeue();
+ ACE_Method_Request* rq = queue_.dequeue();
- if (!rq)
- break;
+ if (!rq)
+ break;
- rq->call();
-
- delete rq;
+ rq->call();
+ delete rq;
}
if (post_svc_hook_)
post_svc_hook_->call();
- return 0;
+ return 0;
}
int DelayExecutor::activate(int num_threads, ACE_Method_Request* pre_svc_hook, ACE_Method_Request* post_svc_hook)
{
- if (this->activated())
+ if (activated())
return -1;
if (num_threads < 1)
@@ -77,15 +73,15 @@ int DelayExecutor::activate(int num_threads, ACE_Method_Request* pre_svc_hook, A
if (post_svc_hook_)
delete post_svc_hook_;
- this->pre_svc_hook_ = pre_svc_hook;
- this->post_svc_hook_ = post_svc_hook;
+ pre_svc_hook_ = pre_svc_hook;
+ post_svc_hook_ = post_svc_hook;
- this->queue_.queue ()->activate ();
+ queue_.queue()->activate();
if (ACE_Task_Base::activate(THR_NEW_LWP | THR_JOINABLE | THR_INHERIT_SCHED, num_threads) == -1)
- return -1;
+ return -1;
- this->activated(true);
+ activated(true);
return true;
}
@@ -95,20 +91,21 @@ int DelayExecutor::execute(ACE_Method_Request* new_req)
if (new_req == NULL)
return -1;
- if (this->queue_.enqueue(new_req,(ACE_Time_Value*)&ACE_Time_Value::zero) == -1)
+ if (queue_.enqueue(new_req, (ACE_Time_Value*)&ACE_Time_Value::zero) == -1)
{
delete new_req;
ACE_ERROR_RETURN((LM_ERROR, ACE_TEXT("(%t) %p\n"), ACE_TEXT("DelayExecutor::execute enqueue")), -1);
}
+
return 0;
}
bool DelayExecutor::activated()
{
- return this->activated_;
+ return activated_;
}
void DelayExecutor::activated(bool s)
{
- this->activated_ = s;
+ activated_ = s;
}
diff --git a/src/shared/DelayExecutor.h b/src/shared/DelayExecutor.h
index 7a160d5ec92..664d8ca78a2 100644
--- a/src/shared/DelayExecutor.h
+++ b/src/shared/DelayExecutor.h
@@ -1,5 +1,5 @@
#ifndef _M_DELAY_EXECUTOR_H
-#define _M_DELAY_EXECUTOR_H
+#define _M_DELAY_EXECUTOR_H
#include <ace/Task.h>
#include <ace/Activation_Queue.h>
@@ -8,6 +8,7 @@
class DelayExecutor : protected ACE_Task_Base
{
public:
+
DelayExecutor();
virtual ~DelayExecutor();
@@ -15,19 +16,22 @@ class DelayExecutor : protected ACE_Task_Base
int execute(ACE_Method_Request* new_req);
- int activate(int num_threads = 1, ACE_Method_Request* pre_svc_hook = 0, ACE_Method_Request* post_svc_hook = 0);
+ int activate(int num_threads = 1, ACE_Method_Request* pre_svc_hook = NULL, ACE_Method_Request* post_svc_hook = NULL);
int deactivate();
bool activated();
- virtual int svc(void);
+ virtual int svc();
+
private:
+
ACE_Activation_Queue queue_;
ACE_Method_Request* pre_svc_hook_;
ACE_Method_Request* post_svc_hook_;
+ bool activated_;
void activated(bool s);
- bool activated_;
};
+
#endif // _M_DELAY_EXECUTOR_H