blob: edd79f60b8d41f39729851ed396611d7b8ffbedf [file] [log] [blame]
//===-- MIUtilStreamStdin.h -------------------------------------*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//++
// File: MIUtilStreamStdin.h
//
// Overview: CMICmnStreamStdin interface.
//
// Environment: Compilers: Visual C++ 12.
// gcc (Ubuntu/Linaro 4.8.1-10ubuntu9) 4.8.1
// Libraries: See MIReadmetxt.
//
// Copyright: None.
//--
#pragma once
// In-house headers:
#include "MIUtilString.h"
#include "MIUtilThreadBaseStd.h"
#include "MICmnBase.h"
#include "MIUtilSingletonBase.h"
//++ ============================================================================
// Details: MI common code class. Used to handle stream data from Stdin.
// Singleton class using the Visitor pattern. A driver using the interface
// provide can receive callbacks when a new line of data is received.
// Each line is determined by a carriage return.
// A singleton class.
// Gotchas: None.
// Authors: Illya Rudkin 10/02/2014.
// Changes: Factored out OS specific handling of reading stdin - IOR 16/06/2014.
//--
class CMICmnStreamStdin
: public CMICmnBase
, public CMIUtilThreadActiveObjBase
, public MI::ISingleton< CMICmnStreamStdin >
{
// Give singleton access to private constructors
friend MI::ISingleton< CMICmnStreamStdin >;
// Class:
public:
//++
// Description: Visitor pattern. Driver(s) use this interface to get a callback
// on each new line of data received from stdin.
//--
class IStreamStdin
{
public:
virtual bool ReadLine( const CMIUtilString & vStdInBuffer, bool & vrwbYesExit ) = 0;
/* dtor */ virtual ~IStreamStdin( void ) {};
};
//++
// Description: Specific OS stdin handling implementations are created and used by *this
// class. Seperates out functionality and enables handler to be set
// dynamically depended on the OS detected.
//--
class IOSStdinHandler
{
public:
virtual bool InputAvailable( bool & vwbAvail ) = 0;
virtual const MIchar * ReadLine( CMIUtilString & vwErrMsg ) = 0;
/* dtor */ virtual ~IOSStdinHandler( void ) {};
};
// Methods:
public:
bool Initialize( void );
bool Shutdown( void );
//
const CMIUtilString & GetPrompt( void ) const;
bool SetPrompt( const CMIUtilString & vNewPrompt );
void SetEnablePrompt( const bool vbYes );
bool GetEnablePrompt( void ) const;
void SetCtrlCHit( void );
bool SetVisitor( IStreamStdin & vrVisitor );
bool SetOSStdinHandler( IOSStdinHandler & vrHandler );
// Overridden:
public:
// From CMIUtilThreadActiveObjBase
virtual const CMIUtilString & ThreadGetName( void ) const;
// Overridden:
protected:
// From CMIUtilThreadActiveObjBase
virtual bool ThreadRun( bool & vrIsAlive );
virtual bool ThreadFinish( void ); // Let this thread clean up after itself
// Methods:
private:
/* ctor */ CMICmnStreamStdin( void );
/* ctor */ CMICmnStreamStdin( const CMICmnStreamStdin & );
void operator=( const CMICmnStreamStdin & );
bool MonitorStdin( bool & vrwbYesExit );
const MIchar * ReadLine( CMIUtilString & vwErrMsg );
bool InputAvailable( bool & vbAvail ); // Bytes are available on stdin
// Overridden:
private:
// From CMICmnBase
/* dtor */ virtual ~CMICmnStreamStdin( void );
// Attributes:
private:
const CMIUtilString m_constStrThisThreadname;
IStreamStdin * m_pVisitor;
CMIUtilString m_strPromptCurrent; // Command line prompt as shown to the user
volatile bool m_bKeyCtrlCHit; // True = User hit Ctrl-C, false = has not yet
bool m_bShowPrompt; // True = Yes prompt is shown/output to the user (stdout), false = no prompt
bool m_bRedrawPrompt; // True = Prompt needs to be redrawn
IOSStdinHandler * m_pStdinReadHandler;
};