亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? stdio.cpp

?? Evc編的一個在wince5.0上運行的flash播放器
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// Copyright 1998, Ben Goetter.  All rights reserved.

/* stdio.cpp */

#if (defined(WIN32_PLATFORM_PSPC) || (_WIN32_WCE >= 300)) || defined(x86)
#else

#include "stdinc.h"
#include <limits.h>
#define SZ_DEFAULT_CAPTION __T("STDIO")
//#include "assert.h"

#define IMPLEMENTS_STDIO
#include "stdio.h"
#include "stdioimp.h"


#define MAXOPENFILES 10
#define assert(x)	1
// These two have streams defined and owned by the client
FILE StdioStdin = {FALSE, NULL};
FILE StdioStdout = {FALSE, NULL};
// These all have streams owned by stdio itself
FILE RgStdioFiles[MAXOPENFILES] = {
	{FALSE, NULL},
	{FALSE, NULL},
	{FALSE, NULL},
	{FALSE, NULL},
	{FALSE, NULL},
	{FALSE, NULL},
	{FALSE, NULL},
	{FALSE, NULL},
	{FALSE, NULL},
	{FALSE, NULL}
};


inline BOOL IsInvalidFile(FILE* pfile)
{
	return ((NULL == pfile) || (!pfile->fActive));
}


// DLL entry point

HANDLE g_hinstDll = NULL;

BOOL WINAPI DllMain(HANDLE hinstDll, DWORD fdwReason, LPVOID)
{
 	if (DLL_PROCESS_ATTACH == fdwReason)
 	{
		g_hinstDll = hinstDll;
 	}
	else if (DLL_PROCESS_DETACH == fdwReason)
	{
		for (int i = 0; i < MAXOPENFILES; ++i)
			if (RgStdioFiles[i].fActive)
				delete RgStdioFiles[i].pstream;
	}

 	return TRUE;
}


//$ BUGBUG - this package needs errno/strerror, 
// or some other way of getting an errorcode out of the stdio-ish interface
// Also - support _fmode, ferror, _doserrno


// A small buffer 
// that allocates itself from the frame whenever possible

class CLocalTempBuffer
{
private:
	BYTE _rgbFrame[256];
	BYTE* _pbAlloc;

public:
	CLocalTempBuffer() : _pbAlloc(NULL) {}
	~CLocalTempBuffer()
		{ if (_pbAlloc) ::LocalFree(_pbAlloc); }

	BOOL Init(unsigned cb)
	{
		assert(NULL == _pbAlloc);
		if (cb > sizeof(_rgbFrame))
		{
			_pbAlloc = (BYTE*)::LocalAlloc(LMEM_FIXED, cb);
			if (NULL == _pbAlloc)
				return FALSE;
		}
		return TRUE;
	}

	BYTE* GetBuffer() const
		{ return ((_pbAlloc == NULL) ? (BYTE*)_rgbFrame : _pbAlloc); }
};



// Exported to main wndproc holder - called on WM_HIBERNATE

void StdioOnHibernate()
{
	//$ BUGBUG - may be called from UI thread while streams in use by SIOD
	// should guard with critical section

	if (StdioStdin.fActive)
		StdioStdin.pstream->OnHibernate();
	if (StdioStdout.fActive)
		StdioStdout.pstream->OnHibernate();
	for (int i = 0; i < MAXOPENFILES; ++i)
		if (RgStdioFiles[i].fActive)
			RgStdioFiles[i].pstream->OnHibernate();
}


void StdioInitStdin(CXStdioStream* pstreamStdin)
{
	StdioStdin.pstream = pstreamStdin;
	StdioStdin.fActive = (NULL != pstreamStdin);
}


void StdioInitStdout(CXStdioStream* pstreamStdout)
{
	StdioStdout.pstream = pstreamStdout;
	StdioStdout.fActive = (NULL != pstreamStdout);
}


CXStdioStream::CXStdioStream() : 
		_fPushback(FALSE), _chPushback(0), 
		_fReading(FALSE), _fWriting(FALSE), _fAppending(FALSE),
		_fCooked(FALSE)
{}


CXStdioStream::~CXStdioStream()
{}


void CXStdioStream::Flush()
{
	// Default implementation only clears pushback buffer
	// (good enough for stdin/out)
	_fPushback = FALSE;
}

unsigned CXStdioStream::Tell()
{
	// not implemented in stdin/stdout
	return 0;
}

BOOL CXStdioStream::Seek(int ibOffset, int nType)
{
	// not implemented in stdin/stdout
	return FALSE;
}

void CXStdioStream::Read(BYTE* pbIn, unsigned cbInMax, unsigned* pcbInActual)
{
	// not implemented in stdout
	*pcbInActual = 0;
}

void CXStdioStream::Write(const BYTE* pbOut, unsigned cbOut, unsigned* pcbOutActual)
{
	// not implemented in stdin
	*pcbOutActual = 0;
}

void CXStdioStream::Pushback(unsigned char ch)
{
	_chPushback = ch;
	_fPushback = TRUE;
}

int CXStdioStream::CharReady()
{
	// The default - only needs override for tty devices
	return 1;
}


CXBufferedStream::CXBufferedStream() 
	: _pbBuffer(NULL), _cbBuffer(0)
{}


CXBufferedStream::~CXBufferedStream()
{
	if (_pbBuffer)
		::LocalFree(_pbBuffer);
}


BOOL CXBufferedStream::RequireBuffer(unsigned cbRequired)
{
	if (cbRequired > _cbBuffer)
	{
		if (_pbBuffer)
		{
			::LocalFree(_pbBuffer);
			_pbBuffer = NULL;
			_cbBuffer = 0;
		}
		// Round to multiple of 256b as anti-heap-frag measure
		const unsigned cbAlloc = (((cbRequired-1)/256)+1) * 256;
		_pbBuffer = (BYTE*)::LocalAlloc(LMEM_FIXED, cbAlloc);
		if (!_pbBuffer)
		{
			return FALSE; // Signal EOF
		}
		_cbBuffer = cbAlloc;
	}
	return TRUE;
}


void CXBufferedStream::ReleaseBuffer()
{
	if (_pbBuffer)
	{
		::LocalFree(_pbBuffer);
		_pbBuffer = NULL;
		_cbBuffer = 0;
	}
}


CXBufferedReadStream::CXBufferedReadStream() : 
#if 0 // for stdin Seek/Tell - nyi
		_cbReadTotal(0), 
#endif
		_cbActual(0), _ibCurrent(0)
{}


CXBufferedReadStream::~CXBufferedReadStream()
{}


void CXBufferedReadStream::OnHibernate()
{
	if (_cbBuffer > 0 && (0 == _cbActual || _cbActual == _ibCurrent))
	{
		ResetReadBuffer();
		ReleaseBuffer();
	}
}


void CXBufferedReadStream::Read(BYTE* pbIn, unsigned cbInMax, unsigned* pcbInActual)
{
	unsigned cbReadActual = 0;

	if (_fPushback && cbInMax > 0)
	{
		*pbIn++ = _chPushback;
		_fPushback = FALSE;
		--cbInMax;
		++cbReadActual;
	}

	while (cbInMax > 0) // didn't get it all out of pushback? what a surprise
	{
		if (cbInMax > 0 && _cbActual > 0 && _ibCurrent < _cbActual)
		{
			// Get what we can out of the read-buffer

			unsigned cbAvailable = min(cbInMax, (_cbActual-_ibCurrent));
			memcpy(pbIn, _pbBuffer+_ibCurrent, cbAvailable);
			pbIn += cbAvailable;
			cbInMax -= cbAvailable;
			_ibCurrent += cbAvailable;
			cbReadActual += cbAvailable;
		}

		if (cbInMax > 0) // As necessary, reload the read-buffer
		{
			ResetReadBuffer();
			if (!LoadReadBuffer(cbInMax)) // pass remaining amt needed as hint
				break;
		}
	}

#if 0 // track for stdin/stdout Seek/Tell
	_cbReadTotal += cbReadActual;
#endif
	*pcbInActual = cbReadActual;
}


// Convert to MBCS, flattening CRLF sequences to LF as we go

BOOL CookInputTextWA(const WCHAR* pwchSrc, unsigned cchSrc, 
				     char* pchDst0, unsigned cbInAvail, unsigned* pcbEmitted,
				     BOOL* pfHadTrailingCR,
				     unsigned* pcchCRsEaten)
{
	char* pchDst = pchDst0; // retain original for pcbEmitted calc

	unsigned cchCRsEaten = 0; // count number of CRLF sequences flattened

	if (cchSrc > 0 && cbInAvail > 0)
	{
		const WCHAR* pwchEol = NULL;
		while (pwchEol = wcsstr(pwchSrc, __T("\r\n")))
		{
			const int cchLine = pwchEol - pwchSrc;
			if (cchLine > 0)
			{
				const int cbMbcs = ::WideCharToMultiByte(CP_ACP, 0, 
					pwchSrc, cchLine,
					pchDst, cbInAvail, NULL, NULL);
				if (0 == cbMbcs)
					return FALSE; // Signal EOF
				pchDst += cbMbcs;
				cbInAvail -= cbMbcs;
			}
			*pchDst++ = '\n';
			--cbInAvail;
			pwchSrc = pwchEol + 2; // CRLF
			cchSrc -= cchLine+2;
			++cchCRsEaten;
		}
	}
	if (cchSrc > 0 && cbInAvail > 0)
	{
		// Need to detect a final CR character,
		// to catch the case where a CRLF sequence crosses the boundary of a read buffer.
		// Caller can look ahead and patch the final char in the outstring as necessary

		if (NULL != pfHadTrailingCR)
			*pfHadTrailingCR = (__T('\r') == pwchSrc[cchSrc-1]);

		const int cbMbcs = ::WideCharToMultiByte(CP_ACP, 0, 
			pwchSrc, cchSrc,
			pchDst, cbInAvail, NULL, NULL);
		if (0 == cbMbcs)
			return FALSE; // Signal EOF
		pchDst += cbMbcs;
	}
	else
	{
		if (NULL != pfHadTrailingCR) 
			*pfHadTrailingCR = FALSE; // all were converted
	}

	*pcbEmitted = pchDst - pchDst0;
	if (NULL != pcchCRsEaten)
		*pcchCRsEaten = cchCRsEaten;
	return TRUE;
}


// Flatten CRLF sequences to LF - no Unicode decoding necessary

BOOL CookInputTextAA(const char* pchSrc, unsigned cchSrc, 
				     char* pchDst0, unsigned cbInAvail, unsigned* pcbEmitted,
				     BOOL* pfHadTrailingCR,
				     unsigned* pcchCRsEaten)
{
	char* pchDst = pchDst0; // retain original for pcbEmitted calc

	unsigned cchCRsEaten = 0; // count number of CRLF sequences flattened

	if (cchSrc > 0 && cbInAvail > 0)
	{
		const char* pchEol = NULL;
		while (pchEol = strstr(pchSrc, "\r\n"))
		{
			const int cchLine = pchEol - pchSrc;
			if (cchLine > 0)
			{
				const int cbCopy = min(cchLine, (int)cbInAvail);
				memcpy(pchDst, pchSrc, cbCopy);
				pchDst += cbCopy;
				cbInAvail -= cbCopy;
			}
			*pchDst++ = '\n';
			--cbInAvail;
			pchSrc = pchEol + 2; // CRLF
			cchSrc -= cchLine+2;
			++cchCRsEaten;
		}
	}
	if (cchSrc > 0 && cbInAvail > 0)
	{
		// Need to detect a final CR character,
		// to catch the case where a CRLF sequence crosses the boundary of a read buffer.
		// Caller can look ahead and patch the final char in the outstring as necessary

		if (NULL != pfHadTrailingCR)
			*pfHadTrailingCR = ('\r' == pchSrc[cchSrc-1]);

		const int cbCopy = min(cchSrc, cbInAvail);
		memcpy(pchDst, pchSrc, cbCopy);
		pchDst += cbCopy;
	}
	else
	{
		if (NULL != pfHadTrailingCR) 
			*pfHadTrailingCR = FALSE; // all were converted
	}

	*pcbEmitted = pchDst - pchDst0;
	if (NULL != pcchCRsEaten)
		*pcchCRsEaten = cchCRsEaten;
	return TRUE;
}


// Convert to Unicode, expanding newlines into CRNL sequences

BOOL CookOutputTextAW(const char* pchSrc, unsigned cbSrc, unsigned cbNewlines,
                      WCHAR* pwchDst, unsigned cchAvailable, unsigned* pcchEmitted )
{
	unsigned cchOut = 0; // count of characters written to pwchOut

	if (cbNewlines > 0 && cbSrc > 0)
	{
		// Seeking newlines in the sourcetext, one line at a time
		// Thought: since we have cbNewlines, could use strchr here,
		// decrementing a count of the # of newlines found.
		// That approach would easily transition to an approach
		// where the initial cbNewline count also saved offsets.
		const char* pch = pchSrc;
		unsigned cb = cbSrc;
		while (cb--)
		{
			if (*pch++ == '\n') //$ BUGBUG DBCS, again
			{
				// Copy/convert everything but the newline
				const int cbLine = cbSrc - cb - 1;
				if (cbLine > 0)
				{
					const int cch = ::MultiByteToWideChar(CP_ACP, MB_PRECOMPOSED, 
						pchSrc, cbLine,
						pwchDst, cchAvailable);
					if (0 == cch)
					{
						*pcchEmitted = cchOut;
						return FALSE;
					}
					cchOut += cch;
					pwchDst += cch;
					cchAvailable -= cch;
				}
				// Emit a 'cooked' newline sequence to replace the newline
				*pwchDst++ = __T('\r');
				*pwchDst++ = __T('\n');
				cchOut += 2;
				cchAvailable -= 2;

				cbSrc = cb;
				pchSrc = pch;
			}
		}
	}
	if (cbSrc > 0)
	{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91丨porny丨最新| av不卡免费电影| 欧美一二三区精品| 三级精品在线观看| 欧美丝袜丝交足nylons图片| 樱花影视一区二区| 色综合一个色综合| 亚洲欧美国产三级| 91蜜桃在线观看| 亚洲蜜桃精久久久久久久| 99精品桃花视频在线观看| 日本一区二区三区四区| 国产精品一品视频| 久久老女人爱爱| 国产精品一区三区| 国产欧美一区二区在线观看| 国产成人精品三级麻豆| 亚洲国产精品精华液ab| 成人永久看片免费视频天堂| 中国色在线观看另类| 不卡的av电影| 一区二区三区欧美| 欧美日韩高清影院| 免费欧美高清视频| 精品少妇一区二区三区| 国产老肥熟一区二区三区| 久久久久久久综合狠狠综合| 大桥未久av一区二区三区中文| 国产精品美女久久久久av爽李琼| av在线免费不卡| 亚洲一区二区三区国产| 欧美一级高清大全免费观看| 久久91精品国产91久久小草| 国产日韩欧美不卡在线| 成a人片国产精品| 尤物av一区二区| 欧美美女bb生活片| 激情五月播播久久久精品| 欧美国产精品一区二区三区| 99riav一区二区三区| 亚洲一区二区三区四区的| 69堂亚洲精品首页| 国产一区二三区好的| 国产精品理伦片| 欧美图片一区二区三区| 美女视频黄 久久| 欧美国产一区视频在线观看| 91麻豆视频网站| 婷婷久久综合九色国产成人| 精品国产百合女同互慰| 不卡一区二区在线| 亚洲超丰满肉感bbw| 精品久久久久久久一区二区蜜臀| 不卡视频免费播放| 午夜精品久久久久久| xnxx国产精品| 色老综合老女人久久久| 热久久久久久久| 国产精品人人做人人爽人人添| 精品视频1区2区| 国产精品一区二区不卡| 亚洲综合视频在线观看| 欧美mv和日韩mv的网站| 99久久婷婷国产| 日本aⅴ亚洲精品中文乱码| 国产精品毛片大码女人| 欧美精品tushy高清| 国产不卡一区视频| 亚洲制服丝袜在线| 国产网站一区二区| 欧美日韩精品专区| 丁香婷婷深情五月亚洲| 丝袜国产日韩另类美女| 中文字幕五月欧美| 欧美一区二区久久久| 99久久伊人精品| 精品一区二区三区免费视频| 亚洲免费高清视频在线| 欧美精品一区男女天堂| 欧美伊人久久久久久久久影院| 国产一区欧美日韩| 日韩精品欧美精品| 中文字幕一区三区| 精品91自产拍在线观看一区| 欧洲在线/亚洲| 国产**成人网毛片九色| 免费在线观看一区| 有坂深雪av一区二区精品| 国产日韩欧美一区二区三区乱码 | 精品国产乱码91久久久久久网站| 一本大道av伊人久久综合| 国产精品一级在线| 日韩av中文在线观看| 亚洲欧美日韩电影| 久久精品人人做人人综合| 9191久久久久久久久久久| 99视频有精品| 韩国成人福利片在线播放| 日韩专区中文字幕一区二区| 亚洲精品va在线观看| 国产精品入口麻豆九色| 欧美精品一区二区三区蜜桃视频| 欧美日韩激情一区二区| 91麻豆.com| 不卡av在线网| 国产suv一区二区三区88区| 精品中文字幕一区二区 | 日韩美女精品在线| 久久亚洲捆绑美女| 欧美成人一区二区三区在线观看| 欧美日韩一二区| 色一区在线观看| eeuss鲁一区二区三区| 国产一区二区三区久久久| 免费精品99久久国产综合精品| 亚洲国产视频直播| 亚洲乱码中文字幕| 一区二区中文字幕在线| 亚洲国产高清在线观看视频| 久久久久久电影| 久久人人爽人人爽| 精品国产欧美一区二区| 日韩一区二区视频| 欧美人妇做爰xxxⅹ性高电影| 欧美日韩一区二区欧美激情| 一本高清dvd不卡在线观看| 色综合中文综合网| 91精品福利在线一区二区三区| 欧美综合在线视频| 在线免费av一区| 色综合久久中文综合久久97| 一本久久综合亚洲鲁鲁五月天| 91麻豆免费观看| 日本乱人伦aⅴ精品| 色噜噜偷拍精品综合在线| av亚洲精华国产精华| 福利电影一区二区三区| 国产一区二区久久| 国产精品一线二线三线精华| 国产成人高清在线| 成人的网站免费观看| 99久久99久久久精品齐齐| 成人免费福利片| 国产成人8x视频一区二区| 国产白丝精品91爽爽久久| 国产99久久久国产精品潘金网站| 不卡一区二区在线| 色婷婷久久久亚洲一区二区三区| 95精品视频在线| 色综合久久久久综合体| 欧美亚洲一区二区在线观看| 欧美久久免费观看| 欧美一区二区久久| 久久久亚洲精品一区二区三区| 欧美精彩视频一区二区三区| 欧美韩国日本一区| 一区二区三区自拍| 性久久久久久久久久久久| 免费人成在线不卡| 国产一区二区视频在线播放| 成人综合婷婷国产精品久久 | 99久久精品国产一区| 色综合久久天天综合网| 制服.丝袜.亚洲.中文.综合| 欧美成人精品3d动漫h| 精品国产乱子伦一区| 国产日韩精品一区二区三区| 亚洲欧美区自拍先锋| 亚洲一区二区三区美女| 精品一区二区综合| 国产精品一区免费在线观看| 99久久婷婷国产| 777奇米成人网| 久久久99精品免费观看不卡| 亚洲天堂福利av| 青青草一区二区三区| 国产一区二区三区电影在线观看 | aaa欧美色吧激情视频| 91在线国产观看| 欧美亚洲动漫制服丝袜| 日韩色视频在线观看| 国产欧美中文在线| 性欧美疯狂xxxxbbbb| 国产麻豆精品95视频| 91在线视频观看| 日韩欧美高清dvd碟片| 国产精品久久久久久久久免费桃花| 亚洲一区二区视频在线| 国产麻豆视频一区二区| 欧美亚一区二区| 精品国产在天天线2019| 中文字幕综合网| 精品亚洲成av人在线观看| caoporen国产精品视频| 欧美一区二区三级| **欧美大码日韩| 久久99国产精品麻豆| 在线免费观看视频一区| 欧美激情综合五月色丁香小说| 婷婷久久综合九色综合伊人色|