//===-- 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 { // Give singleton access to private constructors friend MI::ISingleton; // 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; virtual void InterruptReadLine(void){}; /* 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); void OnExitHandler(void); // 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; };