Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

243 lines
7.3 KiB

// odsstream.h c++ std lib output stream using win32 OutputDebugString
// copied from vc98 fstream
// Copyright (c) Microsoft Corporation 1998.
#pragma once
#if !defined(DEBUG) && (defined(_DBG) || defined(DBG) || defined(_DEBUG))
#define DEBUG 1
#endif
#if !defined(ODSSTREAM_H) && defined(DEBUG)
#define ODSSTREAM_H
#ifdef _MSC_VER
#pragma pack(push,8)
#endif /* _MSC_VER */
#include <tchar.h>
#include <ostream>
#include <tstring.h>
inline bool Debugputc(TCHAR outch) {
TCHAR o[2];
o[0] = outch;
o[1] = 0;
TCHAR *p = o;
OutputDebugString(p);
return true;
}
// TEMPLATE CLASS basic_debugbuf
template<class _E, class _Tr = std::char_traits<_E> >
class basic_debugbuf : public std::basic_streambuf<_E, _Tr> {
public:
typedef std::codecvt<_E, TCHAR, _Tr::state_type> _Cvt;
typedef std::basic_streambuf<_E, _Tr> _Mysb;
typedef basic_debugbuf<_E, _Tr> _Myt;
basic_debugbuf() : _Loc(), _Mysb() {
_Init();
}
virtual ~basic_debugbuf() {
delete _Str;
}
protected:
virtual int_type overflow(int_type _C = _Tr::eof()) {
if (_Tr::eq_int_type(_Tr::eof(), _C)) {
return (_Tr::not_eof(_C));
} else if (pptr() != 0 && pptr() < epptr()) {
*_Pninc() = _Tr::to_char_type(_C);
return (_C);
} else if (_Pcvt == 0) {
Debugputc(_Tr::to_char_type(_C));
return _C;
} else {
const int _NC = 8;
const _E _X = _Tr::to_char_type(_C);
const _E *_S;
TCHAR *_D;
_Str->erase();
for (size_t _I = _NC; ; _I += _NC) {
_Str->append(_NC, '\0');
switch (_Pcvt->out(_State,
&_X, &_X + 1, _S,
_Str->begin(), _Str->end(), _D)) {
case std::codecvt_base::partial:
if (_S == &_X)
return (_Tr::eof());
case std::codecvt_base::ok: {// can fall through
size_t _N = _D - _Str->begin();
OutputDebugString(_Str->begin());
return _C;
}
case std::codecvt_base::noconv:
Debugputc(_X);
return _C;
default:
return (_Tr::eof());
}
}
}
}
virtual int_type uflow() {return (_Tr::eof());}
void _Init() {
static _Tr::state_type _Stinit;
_Loc.locale::~locale();
new (&_Loc) std::locale;
_Str = 0;
_Mysb::_Init();
_State = _Stinit;
_State0 = _Stinit;
_Pcvt = 0;
}
void _Initcvt() {
_Pcvt = (_Cvt *)&_USE(getloc(), _Cvt);
_Loc = _ADDFAC(_Loc, _Pcvt);
if (_Pcvt->always_noconv())
_Pcvt = 0;
if (_Str == 0)
_Str = new string;
}
private:
_Cvt *_Pcvt;
_Tr::state_type _State0;
_Tr::state_type _State;
Tstring *_Str;
std::locale _Loc;
};
template<class _E, class _Tr = std::char_traits<_E> >
class basic_otstream : public std::basic_ostream<_E, _Tr> {
public:
typedef std::basic_ostream<_E, _Tr> MytBase;
typedef std::basic_ios<_E, _Tr> _Myios;
typedef std::basic_streambuf<_E, _Tr> _Mysb;
typedef basic_otstream<_E, _Tr> _Myt;
basic_otstream() {}
explicit basic_otstream(std::basic_streambuf<_E, _Tr> *_S,
bool _Isstd = false, bool _Doinit = true) : std::basic_ostream<_E, _Tr>(_S, _Isstd, _Doinit) {}
virtual ~basic_otstream()
{}
#if 0
template<class T> inline _Myt& operator<<(T i) {
MytBase::operator<<(i);
return *this;
}
#endif
inline _Myt& operator<<(_Myt& (__cdecl *_F)(_Myt&)) {
return ((*_F)(*this));
}
inline _Myt& operator<<(MytBase& (__cdecl *_F)(MytBase&)) {
MytBase::operator<<(_F);
return *this;
}
inline _Myt& operator<<(_Myios& (__cdecl *_F)(_Myios&)) {
MytBase::operator<<(f);
return *this;
}
inline _Myt& operator<<(_Mysb *b) {
MytBase::operator<<(b);
return *this;
}
inline _Myt& operator<<(const void *const i) {
MytBase::operator<<(i);
return *this;
}
inline _Myt& operator<<(float i) {
MytBase::operator<<(i);
return *this;
}
inline _Myt& operator<<(double i) {
MytBase::operator<<(i);
return *this;
}
inline _Myt& operator<<(int i) {
MytBase::operator<<(i);
return *this;
}
inline _Myt& operator<<(unsigned int i) {
MytBase::operator<<(i);
return *this;
}
inline _Myt& operator<<(long i) {
MytBase::operator<<(i);
return *this;
}
inline _Myt& operator<<(unsigned long i) {
MytBase::operator<<(i);
return *this;
}
#ifdef _UNICODE
_Myt& operator<<(LPCSTR _X) {
USES_CONVERSION;
return operator<<(A2W(_X));
}
#else
_Myt& operator<<(const OLECHAR *_X) {
USES_CONVERSION;
operator<<(W2A(_X));
return *this;
}
#endif
_Myt& operator<<(LPCTSTR _X) {
std::operator<<(static_cast<MytBase&>(*this), _X);
return *this;
}
#if 0
inline _Myt& operator<<(Tstring t) {
return operator<<(t.c_str());
}
#endif
};
typedef basic_otstream<TCHAR> tostream;
// TEMPLATE CLASS basic_ofstream
template<class _E, class _Tr = std::char_traits<_E> >
class basic_odebugstream : public basic_otstream<_E, _Tr> {
public:
typedef basic_odebugstream<_E, _Tr> _Myt;
typedef basic_debugbuf<_E, _Tr> _Myfb;
basic_odebugstream()
: basic_otstream<_E, _Tr>(&_Fb) {}
basic_odebugstream(_Myt &mt) : basic_otstream<_E, _Tr>(mt._Fb) {}
virtual ~basic_odebugstream()
{}
private:
_Myfb _Fb;
};
#ifdef _MSC_VER
#pragma pack(pop)
#endif /* _MSC_VER */
typedef basic_debugbuf<TCHAR> TdbgBuf;
typedef basic_odebugstream<TCHAR> TdbgStream;
// the msvc 6 crt fstream header this was copied from contained the following notice:
/*
* Copyright (c) 1994 by P.J. Plauger. ALL RIGHTS RESERVED.
* Consult your license regarding permissions and restrictions.
*/
#endif
// end of file odsstream.h