blob: 40e4e8546fe420e6ed04e74266d507278dee1b36 [file] [log] [blame]
//===-- MICmnStreamStdinWindows.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: CMICmnStreamStdinWindows 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 "MICmnBase.h"
#include "MICmnStreamStdin.h"
#include "MIUtilSingletonBase.h"
//++ ============================================================================
// Details: MI common code class. Specific OS stdin handling implementation.
// CMICmnStreamStdin instance is set with stdin handler before using the
// the stream. An instance of this class must be set up and ready to give
// to the CMICmnStreamStdin before it initialises other CMICmnStreamStdin
// will give an error.
// Gotchas: None.
// Authors: Illya Rudkin 16/06/2014.
// Changes: None.
//--
class CMICmnStreamStdinWindows : public CMICmnBase,
public CMICmnStreamStdin::IOSStdinHandler,
public MI::ISingleton<CMICmnStreamStdinWindows>
{
// Give singleton access to private constructors
friend MI::ISingleton<CMICmnStreamStdinWindows>;
// Methods:
public:
bool Initialize(void);
bool Shutdown(void);
// Overridden:
public:
// From CMICmnStreamStdin::IOSpecificReadStreamStdin
virtual bool InputAvailable(bool &vwbAvail);
virtual const MIchar *ReadLine(CMIUtilString &vwErrMsg);
// Methods:
private:
/* ctor */ CMICmnStreamStdinWindows(void);
/* ctor */ CMICmnStreamStdinWindows(const CMICmnStreamStdinWindows &);
void operator=(const CMICmnStreamStdinWindows &);
//
bool InputAvailableConsoleWin(bool &vwbAvail);
bool InputAvailableApplication(bool &vwbAvail);
// Overridden:
private:
// From CMICmnBase
/* dtor */ virtual ~CMICmnStreamStdinWindows(void);
// Attributes:
private:
const MIuint m_constBufferSize;
FILE *m_pStdin;
MIchar *m_pCmdBuffer;
MIchar *m_pStdinBuffer; // Custom buffer to store std input
MIuint m_nBytesToBeRead; // Checks that ::fgets() is holding on to data while ::PeekNamedPipe() returns nothing which causes a problem
bool m_bRunningInConsoleWin; // True = The application is being run in a Windows command line prompt window, false = by other means
};