亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
一区二区三区欧美| 亚洲色图一区二区| 日韩欧美中文字幕制服| 欧美裸体bbwbbwbbw| 欧美日韩国产中文| 欧美日韩精品一区二区天天拍小说| 91在线视频播放地址| 99久久99久久精品国产片果冻| av亚洲产国偷v产偷v自拍| 丰满少妇久久久久久久| 国产成人高清视频| 91影院在线观看| 91丝袜美腿高跟国产极品老师 | 精品国产免费人成在线观看| 欧美www视频| 欧美国产日本视频| 一区二区视频免费在线观看| 亚洲v精品v日韩v欧美v专区| 六月丁香婷婷久久| 粉嫩嫩av羞羞动漫久久久| av成人动漫在线观看| 色视频成人在线观看免| 91精品国产综合久久福利软件 | 亚洲国产成人porn| 午夜久久久久久久久久一区二区| 另类人妖一区二区av| 国产91在线看| 欧美性受xxxx黑人xyx性爽| 91精品在线观看入口| 久久精品欧美一区二区三区不卡| 中文字幕av一区 二区| 亚洲国产视频直播| 国产二区国产一区在线观看| 99国产精品一区| 欧美一区二区在线免费播放| 国产欧美一区二区三区在线看蜜臀| 亚洲激情男女视频| 国产精品99久久久久| 91精品1区2区| 久久精品视频一区| 婷婷开心激情综合| 成人h动漫精品一区二| 欧美高清www午色夜在线视频| 中文字幕乱码日本亚洲一区二区| 丝袜国产日韩另类美女| 波多野结衣视频一区| 精品国产乱码久久久久久1区2区| 一区二区免费看| 国产成人av影院| 日韩一区二区精品葵司在线| 亚洲精品少妇30p| 国产剧情在线观看一区二区| 538在线一区二区精品国产| 中文字幕制服丝袜一区二区三区| 久久97超碰色| 欧美裸体一区二区三区| 亚洲精品视频在线看| 国产精品自拍三区| 精品久久一区二区三区| 亚洲丰满少妇videoshd| 色哦色哦哦色天天综合| 国产精品理论在线观看| 国产高清无密码一区二区三区| 日韩一区二区在线看| 午夜久久久久久久久| 色婷婷综合久久久久中文 | 美女mm1313爽爽久久久蜜臀| 欧美三级视频在线观看| 伊人夜夜躁av伊人久久| 在线欧美日韩精品| 一区二区三区小说| 欧美视频一二三区| 婷婷久久综合九色综合绿巨人 | 国产日韩欧美综合一区| 国产剧情一区在线| 欧美韩国日本不卡| 国产99久久久久久免费看农村| 国产欧美一区二区在线| 高清视频一区二区| 国产精品午夜久久| 成人激情免费网站| 亚洲蜜臀av乱码久久精品| 色婷婷久久一区二区三区麻豆| 亚洲综合免费观看高清在线观看| 日本高清不卡视频| 性做久久久久久免费观看欧美| 欧美一区二区三区视频| 国产酒店精品激情| 国产精品毛片高清在线完整版| 91女厕偷拍女厕偷拍高清| 一区二区三区不卡视频在线观看| 欧美三级午夜理伦三级中视频| 裸体歌舞表演一区二区| 日本一区二区电影| 日本道免费精品一区二区三区| 日韩精品欧美精品| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 青青草国产成人99久久| 国产视频一区二区在线| 在线观看视频一区二区| 日韩精品一二区| 亚洲国产精品传媒在线观看| 欧美性大战久久| 久久99精品久久久久久久久久久久| 中文字幕免费观看一区| 在线观看网站黄不卡| 精品一二三四区| **网站欧美大片在线观看| 欧美精品精品一区| 国产精品一区二区免费不卡 | 精品一区二区三区香蕉蜜桃| 2020国产精品自拍| 色综合久久久久综合体桃花网| 日韩国产一二三区| 国产女人18毛片水真多成人如厕 | 欧美肥胖老妇做爰| 久久精品国产第一区二区三区| ●精品国产综合乱码久久久久| 日韩欧美一级二级三级| 色综合久久久久综合体| 国产精品99久久久久久似苏梦涵| 亚洲大尺度视频在线观看| 国产精品久久久久久久久晋中 | 亚洲国产裸拍裸体视频在线观看乱了 | 久久综合丝袜日本网| 欧美美女直播网站| 91麻豆国产在线观看| 国产一区二区三区日韩| 亚洲精品精品亚洲| 日本一区二区免费在线| 制服丝袜国产精品| 欧洲一区二区三区免费视频| proumb性欧美在线观看| 美女被吸乳得到大胸91| 五月激情综合婷婷| 亚洲精品乱码久久久久久黑人| 国产欧美日产一区| 精品国产一区二区三区久久久蜜月 | 亚洲国产一区二区三区青草影视| 国产精品美女www爽爽爽| 久久久久久久一区| 久久这里只精品最新地址| 91麻豆精品国产综合久久久久久| 欧美中文字幕不卡| 色婷婷综合久久久中文一区二区| 波多野结衣欧美| 成人av在线播放网站| 99久久精品费精品国产一区二区| 国产精品自拍毛片| 丰满岳乱妇一区二区三区| 成人美女在线观看| 国产suv一区二区三区88区| 国产91精品免费| 国产成人午夜片在线观看高清观看| 色老汉一区二区三区| 91免费在线看| 在线观看91视频| 欧美丰满美乳xxx高潮www| 日韩一区国产二区欧美三区| 日韩精品一区二区三区视频播放| 精品国产青草久久久久福利| 国产无人区一区二区三区| 欧美韩国日本一区| 亚洲乱码国产乱码精品精可以看| 亚洲人亚洲人成电影网站色| 亚洲精品伦理在线| 日韩激情av在线| 国产成都精品91一区二区三| 99精品久久99久久久久| 欧美日韩三级一区| 日韩欧美美女一区二区三区| 中国av一区二区三区| 亚洲女人小视频在线观看| 午夜精品爽啪视频| 精品一区二区三区免费播放| 成人丝袜高跟foot| 欧美制服丝袜第一页| 精品国产一区二区三区忘忧草 | 成人丝袜视频网| 欧美在线999| 日韩欧美一区电影| 久久五月婷婷丁香社区| 亚洲视频免费看| 日本aⅴ免费视频一区二区三区| 国产精品一区二区三区四区| 色8久久人人97超碰香蕉987| 欧美xxxxx裸体时装秀| 亚洲柠檬福利资源导航| 蜜臀久久久久久久| 丁香六月综合激情| 欧美电影在哪看比较好| 国产亚洲综合av| 日韩影院精彩在线| 成人av免费在线观看| 在线播放/欧美激情| 国产精品嫩草99a| 久久av老司机精品网站导航| 在线免费不卡视频| 国产视频一区二区在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎 |