summaryrefslogtreecommitdiff
path: root/TAO/orbsvcs/orbsvcs/LWFT/SSA_AMI_Handler.h
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/orbsvcs/orbsvcs/LWFT/SSA_AMI_Handler.h')
-rw-r--r--TAO/orbsvcs/orbsvcs/LWFT/SSA_AMI_Handler.h48
1 files changed, 48 insertions, 0 deletions
diff --git a/TAO/orbsvcs/orbsvcs/LWFT/SSA_AMI_Handler.h b/TAO/orbsvcs/orbsvcs/LWFT/SSA_AMI_Handler.h
new file mode 100644
index 00000000000..4899a3b3ab3
--- /dev/null
+++ b/TAO/orbsvcs/orbsvcs/LWFT/SSA_AMI_Handler.h
@@ -0,0 +1,48 @@
+#ifndef __SSA_AMI_HANDLER_H
+#define __SSA_AMI_HANDLER_H
+
+#include "StateSynchronizationAgentS.h"
+#include "ssa_export.h"
+#include <ace/Condition_T.h>
+#include <ace/Thread_Mutex.h>
+#include <ace/Time_Value.h>
+
+class SSA_Export SSA_AMI_Handler
+ : public ::POA_AMI_StateSynchronizationAgentHandler
+{
+ private:
+ size_t accumulated_results_;
+ bool success_;
+ ACE_Thread_Mutex ami_result_lock_;
+ //ACE_Thread_Mutex phase_wait_mutex_;
+ //ACE_Condition<ACE_Thread_Mutex> phase_end_condition_;
+
+ //void release();
+
+ public:
+ SSA_AMI_Handler();
+ bool wait_for_results(size_t expected_results, ACE_Time_Value abstime);
+ //void ssa_invoked();
+
+ virtual void state_changed() {}
+ virtual void state_changed_excep(Messaging::ExceptionHolder*) {}
+
+ virtual void precommit_state(CORBA::Boolean);
+ virtual void precommit_state_excep(Messaging::ExceptionHolder*);
+
+ virtual void commit_state();
+ virtual void commit_state_excep(Messaging::ExceptionHolder*);
+
+ virtual void transfer_state();
+ virtual void transfer_state_excep(Messaging::ExceptionHolder*);
+
+ virtual void update_rank_list() {}
+ virtual void update_rank_list_excep(Messaging::ExceptionHolder*) {}
+
+ virtual void register_application() {}
+ virtual void register_application_excep(Messaging::ExceptionHolder*) {}
+};
+
+#endif // __SSA_AMI_HANDLER_H
+
+