#include <Inquirer.h>

Inheritance diagram for Ipc::Inquirer:
Collaboration diagram for Ipc::Inquirer:

Public Types

typedef CbcPointer< AsyncJobPointer
 

Public Member Functions

 Inquirer (Request::Pointer aRequest, const Ipc::StrandCoords &coords, double aTimeout)
 
virtual ~Inquirer ()
 
virtual void callException (const std::exception &e)
 called when the job throws during an async call More...
 
bool canBeCalled (AsyncCall &call) const
 whether we can be called More...
 
void callStart (AsyncCall &call)
 
virtual void callEnd ()
 called right after the called job method More...
 
virtual void * toCbdata ()=0
 

Static Public Member Functions

static void HandleRemoteAck (const Response &response)
 finds and calls the right Inquirer upon strand's response More...
 
static Pointer Start (AsyncJob *job)
 starts a freshly created job (i.e., makes the job asynchronous) More...
 

Protected Types

typedef std::map< unsigned int, AsyncCall::PointerRequestsMap
 maps request->id to Inquirer::handleRemoteAck callback More...
 

Protected Member Functions

virtual void start ()
 called by AsyncStart; do not call directly More...
 
virtual void swanSong ()
 
virtual bool doneAll () const
 whether positive goal has been reached More...
 
virtual const char * status () const
 internal cleanup; do not call directly More...
 
virtual void inquire ()
 inquire the next strand More...
 
virtual void cleanup ()
 perform cleanup actions on completion of job More...
 
virtual void handleException (const std::exception &e)
 do specific exception handling More...
 
virtual void sendResponse ()=0
 send response to client More...
 
virtual bool aggregate (Response::Pointer aResponse)=0
 perform aggregating of responses and returns true if need to continue More...
 
void deleteThis (const char *aReason)
 
void mustStop (const char *aReason)
 
bool done () const
 the job is destroyed in callEnd() when done() More...
 

Protected Attributes

Request::Pointer request
 cache manager request received from client More...
 
Ipc::StrandCoords strands
 all strands we want to query, in order More...
 
Ipc::StrandCoords::const_iterator pos
 strand we should query now More...
 
const double timeout
 number of seconds to wait for strand response More...
 
const char * stopReason
 reason for forcing done() to be true More...
 
const char * typeName
 kid (leaf) class name, for debugging More...
 
AsyncCall::Pointer inCall
 the asynchronous call being handled, if any More...
 
const InstanceId< AsyncJobid
 job identifier More...
 

Static Protected Attributes

static RequestsMap TheRequestsMap
 pending strand requests More...
 
static unsigned int LastRequestId = 0
 last requestId used More...
 

Private Types

typedef UnaryMemFunT< Inquirer, Response::Pointer, Response::PointerHandleAckDialer
 

Private Member Functions

 CBDATA_CLASS (Inquirer)
 
void handleRemoteAck (Response::Pointer response)
 called when a strand is done writing its output More...
 
void requestTimedOut ()
 called when the strand failed to respond (or finish responding) in time More...
 
void removeTimeoutEvent ()
 called when we are no longer waiting for the strand to respond More...
 

Static Private Member Functions

static AsyncCall::Pointer DequeueRequest (unsigned int requestId)
 returns and forgets the right Inquirer callback for strand request More...
 
static void RequestTimedOut (void *param)
 Ipc::Inquirer::requestTimedOut wrapper. More...
 

Detailed Description

Coordinator's job that sends a cache manage request to each strand, aggregating individual strand responses and dumping the result if needed

Definition at line 27 of file Inquirer.h.

Member Typedef Documentation

◆ HandleAckDialer

◆ Pointer

Definition at line 34 of file AsyncJob.h.

◆ RequestsMap

typedef std::map<unsigned int, AsyncCall::Pointer> Ipc::Inquirer::RequestsMap
protected

Definition at line 79 of file Inquirer.h.

Constructor & Destructor Documentation

◆ Inquirer()

Ipc::Inquirer::Inquirer ( Request::Pointer  aRequest,
const Ipc::StrandCoords coords,
double  aTimeout 
)

Definition at line 33 of file Inquirer.cc.

References debugs, HERE(), LesserStrandByKidId(), and strands.

◆ ~Inquirer()

Ipc::Inquirer::~Inquirer ( )
virtual

Definition at line 44 of file Inquirer.cc.

References debugs, and HERE().

Member Function Documentation

◆ aggregate()

virtual bool Ipc::Inquirer::aggregate ( Response::Pointer  aResponse)
protectedpure virtual

Implemented in Mgr::Inquirer, and Snmp::Inquirer.

◆ callEnd()

void AsyncJob::callEnd ( )
virtualinherited

◆ callException()

void Ipc::Inquirer::callException ( const std::exception &  e)
virtual

Reimplemented from AsyncJob.

Definition at line 128 of file Inquirer.cc.

References AsyncJob::callException(), DBG_CRITICAL, debugs, and HERE().

◆ callStart()

void AsyncJob::callStart ( AsyncCall call)
inherited

◆ canBeCalled()

bool AsyncJob::canBeCalled ( AsyncCall call) const
inherited

Definition at line 101 of file AsyncJob.cc.

References AsyncCall::cancel(), debugs, HERE(), AsyncJob::inCall, and NULL.

◆ CBDATA_CLASS()

Ipc::Inquirer::CBDATA_CLASS ( Inquirer  )
private

◆ cleanup()

void Ipc::Inquirer::cleanup ( )
protectedvirtual

Reimplemented in Mgr::Inquirer, and Snmp::Inquirer.

Definition at line 51 of file Inquirer.cc.

◆ deleteThis()

void AsyncJob::deleteThis ( const char *  aReason)
protectedinherited

◆ DequeueRequest()

AsyncCall::Pointer Ipc::Inquirer::DequeueRequest ( unsigned int  requestId)
staticprivate

Definition at line 141 of file Inquirer.cc.

References debugs, HERE(), Must, NULL, and request().

◆ done()

bool AsyncJob::done ( ) const
protectedinherited

◆ doneAll()

bool Ipc::Inquirer::doneAll ( ) const
protectedvirtual

Reimplemented from AsyncJob.

Reimplemented in Mgr::Inquirer, and Snmp::Inquirer.

Definition at line 115 of file Inquirer.cc.

Referenced by Snmp::Inquirer::doneAll(), and Mgr::Inquirer::doneAll().

◆ handleException()

void Ipc::Inquirer::handleException ( const std::exception &  e)
protectedvirtual

Reimplemented in Snmp::Inquirer.

Definition at line 121 of file Inquirer.cc.

References debugs, and HERE().

Referenced by Snmp::Inquirer::handleException().

◆ HandleRemoteAck()

◆ handleRemoteAck()

void Ipc::Inquirer::handleRemoteAck ( Response::Pointer  response)
private

Definition at line 87 of file Inquirer.cc.

References debugs, HERE(), Must, and request().

Referenced by inquire().

◆ inquire()

void Ipc::Inquirer::inquire ( )
protectedvirtual

◆ mustStop()

◆ removeTimeoutEvent()

void Ipc::Inquirer::removeTimeoutEvent ( )
private

Definition at line 170 of file Inquirer.cc.

References eventDelete(), eventFind(), and RequestTimedOut().

◆ requestTimedOut()

void Ipc::Inquirer::requestTimedOut ( )
private

Definition at line 189 of file Inquirer.cc.

References debugs, HERE(), Must, and request().

◆ RequestTimedOut()

void Ipc::Inquirer::RequestTimedOut ( void *  param)
staticprivate

Definition at line 178 of file Inquirer.cc.

References CallJobHere, debugs, HERE(), Must, and NULL.

Referenced by inquire(), and removeTimeoutEvent().

◆ sendResponse()

virtual void Ipc::Inquirer::sendResponse ( )
protectedpure virtual

Implemented in Mgr::Inquirer, and Snmp::Inquirer.

◆ start()

void Ipc::Inquirer::start ( )
protectedvirtual

Reimplemented from AsyncJob.

Reimplemented in Mgr::Inquirer, and Snmp::Inquirer.

Definition at line 56 of file Inquirer.cc.

References request().

Referenced by Snmp::Inquirer::start(), and Mgr::Inquirer::start().

◆ Start()

◆ status()

const char * Ipc::Inquirer::status ( ) const
protectedvirtual

for debugging, starts with space

Reimplemented from AsyncJob.

Definition at line 202 of file Inquirer.cc.

References buf, and request().

◆ swanSong()

void Ipc::Inquirer::swanSong ( )
protectedvirtual

Reimplemented from AsyncJob.

Definition at line 102 of file Inquirer.cc.

References debugs, HERE(), and request().

◆ toCbdata()

virtual void* CbdataParent::toCbdata ( )
pure virtualinherited

Member Data Documentation

◆ id

const InstanceId<AsyncJob> AsyncJob::id
protectedinherited

Definition at line 72 of file AsyncJob.h.

◆ inCall

AsyncCall::Pointer AsyncJob::inCall
protectedinherited

◆ LastRequestId

unsigned int Ipc::Inquirer::LastRequestId = 0
staticprotected

Definition at line 82 of file Inquirer.h.

◆ pos

Ipc::StrandCoords::const_iterator Ipc::Inquirer::pos
protected

Definition at line 74 of file Inquirer.h.

◆ request

Request::Pointer Ipc::Inquirer::request
protected

Definition at line 71 of file Inquirer.h.

Referenced by Snmp::Inquirer::Inquirer().

◆ stopReason

const char* AsyncJob::stopReason
protectedinherited

◆ strands

Ipc::StrandCoords Ipc::Inquirer::strands
protected

Definition at line 73 of file Inquirer.h.

Referenced by Inquirer().

◆ TheRequestsMap

Ipc::Inquirer::RequestsMap Ipc::Inquirer::TheRequestsMap
staticprotected

Definition at line 80 of file Inquirer.h.

◆ timeout

const double Ipc::Inquirer::timeout
protected

Definition at line 76 of file Inquirer.h.

◆ typeName


The documentation for this class was generated from the following files:

 

Introduction

Documentation

Support

Miscellaneous

Web Site Translations

Mirrors