forked from OSchip/llvm-project
126 lines
3.8 KiB
C++
126 lines
3.8 KiB
C++
//===-- 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;
|
|
};
|
|
|