2014-05-16 18:51:01 +08:00
|
|
|
//===-- MIUtilStreamStdin.h -------------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
//++
|
2014-11-18 02:06:21 +08:00
|
|
|
// File: MIUtilStreamStdin.h
|
2014-05-16 18:51:01 +08:00
|
|
|
//
|
2014-11-18 02:06:21 +08:00
|
|
|
// Overview: CMICmnStreamStdin interface.
|
2014-05-16 18:51:01 +08:00
|
|
|
//
|
2014-11-18 02:06:21 +08:00
|
|
|
// Environment: Compilers: Visual C++ 12.
|
|
|
|
// gcc (Ubuntu/Linaro 4.8.1-10ubuntu9) 4.8.1
|
|
|
|
// Libraries: See MIReadmetxt.
|
2014-05-16 18:51:01 +08:00
|
|
|
//
|
2014-11-18 02:06:21 +08:00
|
|
|
// Copyright: None.
|
2014-05-16 18:51:01 +08:00
|
|
|
//--
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// In-house headers:
|
|
|
|
#include "MIUtilString.h"
|
|
|
|
#include "MIUtilThreadBaseStd.h"
|
|
|
|
#include "MICmnBase.h"
|
|
|
|
#include "MIUtilSingletonBase.h"
|
|
|
|
|
|
|
|
//++ ============================================================================
|
2014-11-18 02:06:21 +08:00
|
|
|
// 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.
|
2014-05-16 18:51:01 +08:00
|
|
|
//--
|
2014-11-18 02:06:21 +08:00
|
|
|
class CMICmnStreamStdin : public CMICmnBase, public CMIUtilThreadActiveObjBase, public MI::ISingleton<CMICmnStreamStdin>
|
2014-05-16 18:51:01 +08:00
|
|
|
{
|
2014-11-18 02:06:21 +08:00
|
|
|
// Give singleton access to private constructors
|
|
|
|
friend MI::ISingleton<CMICmnStreamStdin>;
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2014-11-18 02:06:21 +08:00
|
|
|
// 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;
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2014-11-18 02:06:21 +08:00
|
|
|
/* dtor */ virtual ~IStreamStdin(void){};
|
|
|
|
};
|
2014-06-25 00:35:50 +08:00
|
|
|
|
2014-11-18 02:06:21 +08:00
|
|
|
//++
|
|
|
|
// 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;
|
2014-12-16 03:09:40 +08:00
|
|
|
virtual void InterruptReadLine(void){};
|
2014-06-25 00:35:50 +08:00
|
|
|
|
2014-11-18 02:06:21 +08:00
|
|
|
/* dtor */ virtual ~IOSStdinHandler(void){};
|
|
|
|
};
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2014-11-18 02:06:21 +08:00
|
|
|
// 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);
|
2014-12-16 03:09:40 +08:00
|
|
|
void OnExitHandler(void);
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2014-11-18 02:06:21 +08:00
|
|
|
// Overridden:
|
|
|
|
public:
|
|
|
|
// From CMIUtilThreadActiveObjBase
|
|
|
|
virtual const CMIUtilString &ThreadGetName(void) const;
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2014-11-18 02:06:21 +08:00
|
|
|
// 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
|
2014-05-16 18:51:01 +08:00
|
|
|
|
2014-11-18 02:06:21 +08:00
|
|
|
// 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;
|
|
|
|
};
|