Public Member Functions | Protected Member Functions | Private Attributes

TGo4ClientTask Class Reference

#include <TGo4ClientTask.h>

Inheritance diagram for TGo4ClientTask:
TGo4Task TGo4ThreadManager TGo4CommandReceiver TGo4ExampleClient

List of all members.

Public Member Functions

 TGo4ClientTask (const char *name, const char *serverhost="localhost", UInt_t negotiationport=0, Bool_t blockingmode=kTRUE, Bool_t standalone=kFALSE, Bool_t autostart=kFALSE, Bool_t autocreate=kTRUE, Bool_t ismaster=kFALSE, Bool_t autoconnect=kTRUE)
virtual ~TGo4ClientTask ()
virtual Int_t Initialization ()
virtual void Quit ()
virtual TGo4TaskStatusCreateStatus ()
TGo4TaskHandlerGetTaskHandler ()
void AddLocalCommand (TGo4Command *com)
TGo4BufferQueueGetCommandQueue (const char *task=0)
TGo4BufferQueueGetStatusQueue (const char *task=0)
TGo4BufferQueueGetDataQueue (const char *task=0)
Bool_t ConnectServer (const char *node, UInt_t negport, Go4CommandMode_t role=kGo4ComModeRefused, const char *passwd=0)
Bool_t DisconnectServer (Bool_t isterminating=kFALSE)
const char * GetServerHostName ()
Bool_t IsConnected ()

Protected Member Functions

virtual void UpdateStatus (TGo4TaskStatus *state)

Private Attributes

TGo4BufferQueuefxStatusQ
TGo4BufferQueuefxDataQ
TGo4BufferQueuefxCommandQ
TGo4TaskHandlerfxTaskHandler
TString fxServerHostname
Bool_t fbAutoConnect
Bool_t fbServerConnected

Detailed Description

This class controls a client application running in a task which is controlled by another server task via transport channels which are held by a task handler object. Apart from the transport threads, the application class which inherits from client task may provide working threads to serve the data queues and do the actual work

Definition at line 34 of file TGo4ClientTask.h.


Constructor & Destructor Documentation

TGo4ClientTask::TGo4ClientTask ( const char *  name,
const char *  serverhost = "localhost",
UInt_t  negotiationport = 0,
Bool_t  blockingmode = kTRUE,
Bool_t  standalone = kFALSE,
Bool_t  autostart = kFALSE,
Bool_t  autocreate = kTRUE,
Bool_t  ismaster = kFALSE,
Bool_t  autoconnect = kTRUE 
)
TGo4ClientTask::~TGo4ClientTask (  )  [virtual]

Definition at line 52 of file TGo4ClientTask.cxx.

References DisconnectServer(), and fxTaskHandler.


Member Function Documentation

void TGo4ClientTask::AddLocalCommand ( TGo4Command com  ) 

Put command into the command queue for local execution in main thread

Definition at line 197 of file TGo4ClientTask.cxx.

References TGo4BufferQueue::AddBufferFromObject(), TGo4Log::Debug(), and fxCommandQ.

Bool_t TGo4ClientTask::ConnectServer ( const char *  node,
UInt_t  negport,
Go4CommandMode_t  role = kGo4ComModeRefused,
const char *  passwd = 0 
)
TGo4TaskStatus * TGo4ClientTask::CreateStatus (  )  [virtual]

create a status object with information on the current client state. this object may be sent to the server or may be used to restore current status by memento mechanism

Reimplemented from TGo4Task.

Reimplemented in TGo4ExampleClient.

Definition at line 181 of file TGo4ClientTask.cxx.

References UpdateStatus().

Bool_t TGo4ClientTask::DisconnectServer ( Bool_t  isterminating = kFALSE  ) 

Disconnect the current server task, but do not terminate the client. Return value indicates success state: true if disconnected, false if connection is still existing. If isterminating=true, work threads are not restarted again.

Definition at line 147 of file TGo4ClientTask.cxx.

References TGo4Queue::Clear(), TGo4TaskHandler::DisConnect(), fbServerConnected, fxTaskHandler, TGo4Task::Get_fgiTERMID(), GetCommandQueue(), TGo4Task::IsMaster(), TGo4Task::SendStopBuffers(), TGo4Task::StartWorkThreads(), TGo4Task::StopWorkThreads(), and TGo4Task::WakeCommandQueue().

Referenced by TGo4Master::DisconnectSlave(), Quit(), and ~TGo4ClientTask().

TGo4BufferQueue * TGo4ClientTask::GetCommandQueue ( const char *  task = 0  )  [virtual]

Reimplemented from TGo4Task.

Definition at line 210 of file TGo4ClientTask.cxx.

References fxCommandQ.

Referenced by DisconnectServer().

TGo4BufferQueue * TGo4ClientTask::GetDataQueue ( const char *  task = 0  )  [virtual]

Reimplemented from TGo4Task.

Definition at line 219 of file TGo4ClientTask.cxx.

References fxDataQ.

Referenced by TGo4ExampleClient::TGo4ExampleClient().

const char* TGo4ClientTask::GetServerHostName (  )  [inline]

Definition at line 101 of file TGo4ClientTask.h.

References fxServerHostname.

Referenced by Initialization(), and UpdateStatus().

TGo4BufferQueue * TGo4ClientTask::GetStatusQueue ( const char *  task = 0  )  [virtual]

Reimplemented from TGo4Task.

Definition at line 215 of file TGo4ClientTask.cxx.

References fxStatusQ.

TGo4TaskHandler * TGo4ClientTask::GetTaskHandler (  )  [virtual]

Reimplemented from TGo4Task.

Definition at line 58 of file TGo4ClientTask.cxx.

References fxTaskHandler.

Referenced by TGo4ClientTask(), and TGo4ExampleClient::TGo4ExampleClient().

Int_t TGo4ClientTask::Initialization (  )  [virtual]

override the ThreadManager Initialization used by AppControlTimer to let this thing initialize the client transport connection

Reimplemented from TGo4Task.

Definition at line 63 of file TGo4ClientTask.cxx.

References ConnectServer(), fbAutoConnect, TGo4ThreadManager::fbInitDone, GetServerHostName(), and TGo4Task::Terminate().

Bool_t TGo4ClientTask::IsConnected (  )  [inline]

Definition at line 104 of file TGo4ClientTask.h.

References fbServerConnected.

Referenced by TGo4TaskOwner::IsConnected().

void TGo4ClientTask::Quit (  )  [virtual]

Quit the client; method to be called from command object, may be overridden in user implementation

Reimplemented from TGo4Task.

Definition at line 171 of file TGo4ClientTask.cxx.

References TGo4Log::Debug(), DisconnectServer(), TGo4Task::IsMaster(), TGo4Task::SendStatusMessage(), and TGo4Task::Terminate().

void TGo4ClientTask::UpdateStatus ( TGo4TaskStatus state  )  [protected, virtual]

method needed by method CreateStatus of any status subclasses to set the values of the clienttask specific part of the status object.

Reimplemented from TGo4Task.

Definition at line 189 of file TGo4ClientTask.cxx.

References GetServerHostName(), and TGo4ClientStatus::SetNames().

Referenced by CreateStatus().


Member Data Documentation

!True if client task shall try to connect automatically at Initialization. This is the previous behaviour with standalone client. If false, connection will be done on ConnectServer method.

Definition at line 135 of file TGo4ClientTask.h.

Referenced by Initialization().

true if connection to server is established, otherwise false

Definition at line 140 of file TGo4ClientTask.h.

Referenced by ConnectServer(), DisconnectServer(), and IsConnected().

Definition at line 119 of file TGo4ClientTask.h.

Referenced by GetDataQueue(), and TGo4ClientTask().

hostname of server machine

Definition at line 129 of file TGo4ClientTask.h.

Referenced by GetServerHostName(), and TGo4ClientTask().

Definition at line 118 of file TGo4ClientTask.h.

Referenced by GetStatusQueue(), and TGo4ClientTask().


The documentation for this class was generated from the following files:
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines