summaryrefslogtreecommitdiff
path: root/TAO/tests/Time_Policy_Custom/Custom_Time_Policy_Strategy.cpp
diff options
context:
space:
mode:
authormcorino <mcorino@users.noreply.github.com>2011-12-08 18:35:38 +0000
committermcorino <mcorino@users.noreply.github.com>2011-12-08 18:35:38 +0000
commit01eb039cbc2232bb44b589635d11952e656902fa (patch)
tree1a632c5f5641b72fbdc137866384f49fa5c6442d /TAO/tests/Time_Policy_Custom/Custom_Time_Policy_Strategy.cpp
parentbc9acf7697ed3ebf81153735dd29a3bb5a41fc4a (diff)
downloadATCD-01eb039cbc2232bb44b589635d11952e656902fa.tar.gz
merged time policy changes from local branch
Diffstat (limited to 'TAO/tests/Time_Policy_Custom/Custom_Time_Policy_Strategy.cpp')
-rw-r--r--TAO/tests/Time_Policy_Custom/Custom_Time_Policy_Strategy.cpp63
1 files changed, 63 insertions, 0 deletions
diff --git a/TAO/tests/Time_Policy_Custom/Custom_Time_Policy_Strategy.cpp b/TAO/tests/Time_Policy_Custom/Custom_Time_Policy_Strategy.cpp
new file mode 100644
index 00000000000..737b881c498
--- /dev/null
+++ b/TAO/tests/Time_Policy_Custom/Custom_Time_Policy_Strategy.cpp
@@ -0,0 +1,63 @@
+// $Id$
+
+#include "Custom_Time_Policy_Strategy.h"
+
+#include "ace/Timer_Heap_T.h"
+#include "ace/Event_Handler_Handle_Timeout_Upcall.h"
+#include "ace/High_Res_Timer.h"
+
+#if (TAO_HAS_TIME_POLICY == 1)
+
+class ACE_Export Custom_Time_Policy
+{
+public:
+ /// Return the current time according to this policy
+ ACE_Time_Value operator() () const
+ {
+ ACE_Time_Value tv = ACE_High_Res_Timer::gettimeofday_hr ();
+ return (tv += ACE_Time_Value (10, 0));
+ }
+};
+
+static ACE_Time_Policy_T<Custom_Time_Policy> custom_time_policy_;
+
+Custom_Time_Policy_Strategy::~Custom_Time_Policy_Strategy ()
+{
+}
+
+ACE_Timer_Queue * Custom_Time_Policy_Strategy::create_timer_queue (void)
+{
+ ACE_Timer_Queue * tmq = 0;
+
+ typedef ACE_Timer_Heap_T<ACE_Event_Handler *,
+ ACE_Event_Handler_Handle_Timeout_Upcall,
+ ACE_SYNCH_RECURSIVE_MUTEX,
+ Custom_Time_Policy> timer_queue_type;
+ ACE_NEW_RETURN (tmq, timer_queue_type (), 0);
+
+ return tmq;
+}
+
+void
+Custom_Time_Policy_Strategy::destroy_timer_queue (ACE_Timer_Queue *tmq)
+{
+ delete tmq;
+}
+
+ACE_Dynamic_Time_Policy_Base * Custom_Time_Policy_Strategy::get_time_policy (void)
+{
+ return &custom_time_policy_;
+}
+
+
+ACE_STATIC_SVC_DEFINE (Custom_Time_Policy_Strategy,
+ ACE_TEXT ("CUSTOM_TIME_POLICY"),
+ ACE_SVC_OBJ_T,
+ &ACE_SVC_NAME (Custom_Time_Policy_Strategy),
+ ACE_Service_Type::DELETE_THIS |
+ ACE_Service_Type::DELETE_OBJ,
+ 0)
+
+ACE_FACTORY_DEFINE (TPTEST, Custom_Time_Policy_Strategy)
+
+#endif /* TAO_HAS_TIME_POLICY */