blob: e4ed2d98797e17ae0fbb933030789fd645030119 [file] [log] [blame]
//===-- MICmdInvoker.h ------------------------------------------*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//++
// File: MICmdInvoker.h
//
// Overview: CMICmdInvoker interface.
//
// Environment: Compilers: Visual C++ 12.
// gcc (Ubuntu/Linaro 4.8.1-10ubuntu9) 4.8.1
// Libraries: See MIReadmetxt.
//
// Copyright: None.
//--
#pragma once
// Third party headers
#include <map>
// In-house headers:
#include "MICmnBase.h"
#include "MICmdData.h"
#include "MICmdMgrSetCmdDeleteCallback.h"
#include "MIUtilSingletonBase.h"
// Declarations:
class CMICmdBase;
class CMICmnStreamStdout;
//++ ============================================================================
// Details: MI Command Invoker. The Invoker works on the command pattern design.
// There two main jobs; action command Execute() function, followed by
// the command's Acknowledge() function. When a command has finished its
// execute function it returns to the invoker. The invoker then calls the
// command's Acknowledge() function to do more work, form and give
// back a MI result. In the meantime the Command Monitor is monitoring
// the each command doing their Execute() function work so they do not
// exceed a time limit which if it exceeds informs the command(s) to
// stop work.
// The work by the Invoker is carried out in the main thread.
// The Invoker takes ownersip of any commands created which means it
// is the only object to delete them when a command is finished working.
// A singleton class.
// Gotchas: None.
// Authors: Illya Rudkin 19/02/2014.
// Changes: None.
//--
class CMICmdInvoker
: public CMICmnBase
, public CMICmdMgrSetCmdDeleteCallback::ICallback
, public MI::ISingleton< CMICmdInvoker >
{
friend class MI::ISingleton< CMICmdInvoker >;
// Class:
public:
//++
// Description: Invoker's interface for commands to implement.
//--
class ICmd
{
public:
virtual bool Acknowledge( void ) = 0;
virtual bool Execute( void ) = 0;
virtual bool ParseArgs( void ) = 0;
virtual bool SetCmdData( const SMICmdData & vCmdData ) = 0;
virtual const SMICmdData & GetCmdData( void ) const = 0;
virtual const CMIUtilString & GetErrorDescription( void ) const = 0;
virtual void CmdFinishedTellInvoker( void ) const = 0;
virtual const CMIUtilString & GetMIResultRecord( void ) const = 0;
virtual const CMIUtilString & GetMIResultRecordExtra( void ) const = 0;
virtual bool HasMIResultRecordExtra( void ) const = 0;
/* dtor */ virtual ~ICmd( void ) {};
};
// Methods:
public:
bool Initialize( void );
bool Shutdown( void );
bool CmdExecute( CMICmdBase & vCmd );
bool CmdExecuteFinished( CMICmdBase & vCmd );
// Typedefs:
private:
typedef std::map< MIuint, CMICmdBase * > MapCmdIdToCmd_t;
typedef std::pair< MIuint, CMICmdBase * > MapPairCmdIdToCmd_t;
// Methods:
private:
/* ctor */ CMICmdInvoker( void );
/* ctor */ CMICmdInvoker( const CMICmdInvoker & );
void operator=( const CMICmdInvoker & );
void CmdDeleteAll( void );
bool CmdDelete( const MIuint vCmdId, const bool vbYesDeleteCmd = false );
bool CmdAdd( const CMICmdBase & vCmd );
bool CmdStdout( const SMICmdData & vCmdData ) const;
// Overridden:
private:
// From CMICmnBase
/* dtor */ virtual ~CMICmdInvoker( void );
// From CMICmdMgrSetCmdDeleteCallback::ICallback
virtual void Delete( SMICmdData & vCmd );
// Attributes:
private:
MapCmdIdToCmd_t m_mapCmdIdToCmd;
CMICmnStreamStdout & m_rStreamOut;
};