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

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

?? zipstorage.cpp

?? 這是一個用VC++編寫的靜態庫
?? CPP
字號:
// ZipStorage.cpp: implementation of the CZipStorage class.
//
////////////////////////////////////////////////////////////////////////////////
//  Copyright (C) 2000 Tadeusz Dracz.
//  For conditions of distribution and use, see copyright notice in ZipArchive.h
////////////////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "ZipStorage.h"
#include "ZipArchive.h"

//////////////////////////////////////////////////////////////////////
// disk spanning objectives:
// - sinature at the first disk at the beginning
// - headers and central dir records not divided between disks
// - each file has a data descriptor preceded by the signature
//	(bit 3 set in flag);


char CZipStorage::m_gszExtHeaderSignat[] = {0x50, 0x4b, 0x07, 0x08};
CZipStorage::CZipStorage()
{
	m_pCallbackData = m_pZIPCALLBACKFUN = NULL;
	m_iWriteBufferSize = 65535;
	m_iCurrentDisk = -1;
	m_pFile = NULL;
}

CZipStorage::~CZipStorage()
{

}

DWORD CZipStorage::Read(void *pBuf, DWORD iSize, bool bAtOnce)
{
	if (iSize == 0)
		return 0;
	DWORD iRead = 0;
	while (!iRead)
	{
		iRead = m_pFile->Read(pBuf, iSize);
		if (!iRead)
			if (IsSpanMode())
				ChangeDisk(m_iCurrentDisk + 1);
			else
				ThrowError(ZIP_BADZIPFILE);
	}

	if (iRead == iSize)
		return iRead;
	else if (bAtOnce || !IsSpanMode())
		ThrowError(ZIP_BADZIPFILE);

	while (iRead < iSize)
	{
		ChangeDisk(m_iCurrentDisk + 1);
		UINT iNewRead = m_pFile->Read((char*)pBuf + iRead, iSize - iRead);
		if (!iNewRead && iRead < iSize)
			ThrowError(ZIP_BADZIPFILE);
		iRead += iNewRead;
	}

	return iRead;
}

void CZipStorage::Open(LPCTSTR szPathName, int iMode, int iVolumeSize)
{
	m_pWriteBuffer.Allocate(m_iWriteBufferSize); 
	m_uBytesInWriteBuffer = 0;
	m_bNewSpan = false;
	m_pFile = &m_internalfile;

	if ((iMode == CZipArchive::create) ||(iMode == CZipArchive::createSpan)) // create new archive
	{
		m_iCurrentDisk = 0;
		if (iMode == CZipArchive::create)
		{
			m_iSpanMode = noSpan;
			OpenFile(szPathName, CFile::modeCreate | CFile::modeReadWrite);
		}
		else // create disk spanning archive
		{
			m_bNewSpan = true;
			m_iBytesWritten = 0;
			if (iVolumeSize <= 0) // pkzip span
			{
				if (!m_pZIPCALLBACKFUN)
					ThrowError(ZIP_NOCALLBACK);
				if (!CZipArchive::IsDriveRemovable(szPathName))
					ThrowError(ZIP_NONREMOVABLE);
				m_iSpanMode = pkzipSpan;
			}
			else
			{
				m_iTdSpanData = iVolumeSize;
				m_iSpanMode = tdSpan;
			}

			NextDisk(4, szPathName);
			Write(m_gszExtHeaderSignat, 4, true);
		}
	}
	else // open existing
	{
		OpenFile(szPathName, CFile::modeNoTruncate | ((iMode == CZipArchive::openReadOnly) ? CFile::modeRead : CFile::modeReadWrite));
		// m_uData, m_bAllowModif i m_iSpanMode ustalane automatycznie podczas odczytu central dir
		m_iSpanMode = iVolumeSize == 0 ? suggestedAuto : suggestedTd;
	}
		
}


void CZipStorage::Open(CMemFile& mf, int iMode)
{
	m_pWriteBuffer.Allocate(m_iWriteBufferSize); 
	m_uBytesInWriteBuffer = 0;
	m_bNewSpan = false;
	m_pFile = &mf;

	if (iMode == CZipArchive::create)
	{
		m_iCurrentDisk = 0;
		m_iSpanMode = noSpan;
		mf.SetLength(0);
	}
	else // open existing
	{
		mf.SeekToBegin();
		m_iSpanMode = suggestedAuto;
	}
}


int CZipStorage::IsSpanMode()
{
	return m_iSpanMode == noSpan ? 0 : (m_bNewSpan ? 1 : -1);
}

void CZipStorage::ChangeDisk(int iNumber)
{
	if (iNumber == m_iCurrentDisk)
		return;

	ASSERT(m_iSpanMode != noSpan);
	m_iCurrentDisk = iNumber;
	OpenFile(m_iSpanMode == pkzipSpan ? ChangePkzipRead() : ChangeTdRead(),
		CFile::modeNoTruncate | CFile::modeRead);
}

void CZipStorage::ThrowError(int err)
{
	AfxThrowZipException(err, m_pFile->GetFilePath());
}

bool CZipStorage::OpenFile(LPCTSTR lpszName, UINT uFlags, bool bThrow)
{
	CFileException* e = new CFileException;
	BOOL bRet = m_pFile->Open(lpszName, uFlags | CFile::shareDenyWrite, e);
	if (!bRet && bThrow)
		throw e;
	e->Delete();
	return bRet != 0;
}

// zapobiega konstrukcji ChangeDisk(++m_iCurrentDisk)
void CZipStorage::SetCurrentDisk(int iNumber)
{
	m_iCurrentDisk = iNumber;
}

int CZipStorage::GetCurrentDisk()
{
	return m_iCurrentDisk;
}

CString CZipStorage::ChangePkzipRead()
{
	CString szTemp = m_pFile->GetFilePath();
	m_pFile->Close();
	CallCallback(-1 , szTemp);
	return szTemp;
}

CString CZipStorage::ChangeTdRead()
{
	CString szTemp = GetTdVolumeName(m_iCurrentDisk == m_iTdSpanData);
	m_pFile->Close();
	return szTemp;
}

void CZipStorage::Close(bool bAfterException)
{
	if (!bAfterException)
	{
		Flush();
		if ((m_iSpanMode == tdSpan) && (m_bNewSpan))
		{
			// give to the last volume the zip extension
			CString szFileName = m_pFile->GetFilePath();
			CString szNewFileName = GetTdVolumeName(true);
			m_pFile->Close();
			if (CZipArchive::FileExists(szNewFileName))
				CFile::Remove(szNewFileName);
			CFile::Rename(szFileName, szNewFileName);
		}
		else
#ifdef _DEBUG // to prevent assertion if the file is already closed
 		if (m_pFile->m_hFile != (UINT)CFile::hFileNull)
#endif
				m_pFile->Close();
	}
	else
#ifdef _DEBUG // to prevent assertion if the file is already closed
 		if (m_pFile->m_hFile != (UINT)CFile::hFileNull)
#endif
				m_pFile->Close();


	m_pWriteBuffer.Release();
	m_iCurrentDisk = -1;
	m_iSpanMode = noSpan;
	m_pFile = NULL;
}

CString CZipStorage::GetTdVolumeName(bool bLast, LPCTSTR lpszZipName)
{
	CString szFilePath = lpszZipName ? lpszZipName : m_pFile->GetFilePath();
	CString szPath = CZipArchive::GetFilePath(szFilePath);
	CString szName = CZipArchive::GetFileTitle(szFilePath);
	CString szExt;
	if (bLast)
		szExt = _T("zip");
	else
		szExt.Format(_T("%.3d"), m_iCurrentDisk);
	return szPath + szName + _T(".") + szExt;
}

void CZipStorage::NextDisk(int iNeeded, LPCTSTR lpszFileName)
{
	Flush();
	ASSERT(m_iSpanMode != noSpan);
	if (m_iBytesWritten)
	{
		m_iBytesWritten = 0;
		m_iCurrentDisk++;
		if (m_iCurrentDisk >= 999)
			ThrowError(ZIP_TOOMANYVOLUMES);
	} 
	CString szFileName;
	bool bPkSpan = (m_iSpanMode == pkzipSpan);
	if (bPkSpan)
		szFileName  = lpszFileName ? lpszFileName : m_pFile->GetFilePath();
	else
		szFileName =  GetTdVolumeName(false, lpszFileName);

#ifdef _DEBUG // to prevent assertion if the file is already closed
	if (m_pFile->m_hFile != (UINT)CFile::hFileNull)
#endif
		m_pFile->Close(); // if it is closed, so it will not close

	if (bPkSpan)
	{
		int iCode = iNeeded;
		while (true)
		{
			CallCallback(iCode, szFileName);
			if (CZipArchive::FileExists(szFileName))
				iCode = -2;
			else
			{
				CString label;
				label.Format(_T("pkback# %.3d"), m_iCurrentDisk + 1);
				if (!SetVolumeLabel(CZipArchive::GetDrive(szFileName), label)) /*not write label*/
					iCode = -3;
				else if (!OpenFile(szFileName, CFile::modeCreate | CFile::modeReadWrite, false))
					iCode = -4;
				else
					break;
			}

		}
		m_uCurrentVolSize = GetFreeVolumeSpace();
	}
	else
	{
		m_uCurrentVolSize = m_iTdSpanData;
		OpenFile(szFileName, CFile::modeCreate | CFile::modeReadWrite);
	}
}

void CZipStorage::CallCallback(int iCode, CString szTemp)
{
	ASSERT(m_pZIPCALLBACKFUN);
	if (!(*m_pZIPCALLBACKFUN)(m_iCurrentDisk + 1, iCode, m_pCallbackData))
		throw new CZipException(CZipException::aborted, szTemp);
}

DWORD CZipStorage::GetFreeVolumeSpace()
{
	ASSERT (m_iSpanMode == pkzipSpan);
	DWORD SectorsPerCluster, BytesPerSector, NumberOfFreeClusters, TotalNumberOfClusters;		
	if (!GetDiskFreeSpace(
		CZipArchive::GetDrive(m_pFile->GetFilePath()),
		&SectorsPerCluster,
		&BytesPerSector,
		&NumberOfFreeClusters,
		&TotalNumberOfClusters))
			return 0;
	_int64 total = SectorsPerCluster * BytesPerSector * NumberOfFreeClusters;
	return (DWORD)total;
}


void CZipStorage::UpdateSpanMode(WORD uLastDisk)
{
	m_iCurrentDisk = uLastDisk;
	if (uLastDisk)
	{
		// disk spanning detected

		if (m_iSpanMode == suggestedAuto)
			m_iSpanMode = CZipArchive::IsDriveRemovable(m_pFile->GetFilePath()) ? 
				pkzipSpan : tdSpan;
		else
			m_iSpanMode = tdSpan;

		if (m_iSpanMode == pkzipSpan)
		{
			if (!m_pZIPCALLBACKFUN)
					ThrowError(ZIP_NOCALLBACK);
		}
		else /*if (m_iSpanMode == tdSpan)*/
			m_iTdSpanData = uLastDisk; // disk with .zip extension ( the last one)
			
		m_pWriteBuffer.Release(); // no need for this in this case
	}
	else 
		m_iSpanMode = noSpan;

}

void CZipStorage::Write(void *pBuf, DWORD iSize, bool bAtOnce)
{
	if (!IsSpanMode())
		WriteInternalBuffer((char*)pBuf, iSize);
	else
	{
		// if not at once, one byte is enough free space
		DWORD iNeeded = bAtOnce ? iSize : 1; 
		DWORD uTotal = 0;

		while (uTotal < iSize)
		{
			DWORD uFree;
			while ((uFree = VolumeLeft()) < iNeeded)
			{
				if ((m_iSpanMode == tdSpan) && !m_iBytesWritten && !m_uBytesInWriteBuffer)
					// in the tdSpan mode, if the size of the archive is less 
					// than the size of the packet to be written at once,
					// increase once the size of the volume
					m_uCurrentVolSize = iNeeded;
				else
					NextDisk(iNeeded);
			}

			DWORD uLeftToWrite = iSize - uTotal;
			DWORD uToWrite = uFree < uLeftToWrite ? uFree : uLeftToWrite;
			WriteInternalBuffer((char*)pBuf + uTotal, uToWrite);
			if (bAtOnce)
				return;
			else
				uTotal += uToWrite;
		}

	}
}


void CZipStorage::WriteInternalBuffer(char *pBuf, DWORD uSize)
{
	DWORD uWritten = 0;
	while (uWritten < uSize)
	{
		DWORD uFreeInBuffer = GetFreeInBuffer();
		if (uFreeInBuffer == 0)
		{
			Flush();
			uFreeInBuffer = m_pWriteBuffer.GetSize();
		}
		DWORD uLeftToWrite = uSize - uWritten;
		DWORD uToCopy = uLeftToWrite < uFreeInBuffer ? uLeftToWrite : uFreeInBuffer;
		memcpy(m_pWriteBuffer + m_uBytesInWriteBuffer, pBuf + uWritten, uToCopy);
		uWritten += uToCopy;
		m_uBytesInWriteBuffer += uToCopy;
	}
}

DWORD CZipStorage::VolumeLeft()
{
	// for pkzip span m_uCurrentVolSize is updated after each flush()
	return m_uCurrentVolSize  - m_uBytesInWriteBuffer - ((m_iSpanMode == pkzipSpan) ? 0 : m_iBytesWritten);
}

void CZipStorage::Flush()
{
	m_iBytesWritten += m_uBytesInWriteBuffer;
	if (m_uBytesInWriteBuffer)
	{
		m_pFile->Write(m_pWriteBuffer, m_uBytesInWriteBuffer);
		m_uBytesInWriteBuffer = 0;
	}
	if (m_iSpanMode == pkzipSpan) 
		// after writting it is difficult to predict the free space due to 
		// not completly written clusters, write operation may start from 
		// the new cluster
		m_uCurrentVolSize = GetFreeVolumeSpace();
}

DWORD CZipStorage::GetPosition()
{
	return m_pFile->GetPosition() + m_uBytesInWriteBuffer;
}


DWORD CZipStorage::GetFreeInBuffer()
{
	return m_pWriteBuffer.GetSize() - m_uBytesInWriteBuffer;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美偷拍另类a∨色屁股| 亚洲视频一二三区| 91浏览器在线视频| 国产成人鲁色资源国产91色综 | 日本中文字幕一区二区视频 | 国产宾馆实践打屁股91| 首页亚洲欧美制服丝腿| 亚洲精选一二三| 国产精品理论片在线观看| 精品国产a毛片| 欧美变态口味重另类| 欧美高清视频在线高清观看mv色露露十八| 高清国产午夜精品久久久久久| 久久草av在线| 国产综合色在线| 国内一区二区在线| 九九九久久久精品| 精品一区二区三区免费播放| 热久久国产精品| 日本午夜一本久久久综合| 午夜精品一区二区三区免费视频| 亚洲综合一二区| 一区二区三区蜜桃网| 一区二区欧美国产| 性做久久久久久免费观看 | 成人午夜视频福利| 国产成人免费视频网站高清观看视频| 日本sm残虐另类| 精品一区二区久久| 国产a视频精品免费观看| 粉嫩绯色av一区二区在线观看| 国产福利精品一区二区| 岛国精品在线观看| 不卡的看片网站| 91国内精品野花午夜精品| 欧美日韩精品欧美日韩精品| 欧美美女bb生活片| 日韩女优av电影在线观看| 欧美mv日韩mv亚洲| 久久久久久久久免费| 日本一区二区三区视频视频| 亚洲国产激情av| 亚洲免费观看高清完整版在线观看| 国产精品久久久久久亚洲毛片| 国产日韩精品一区二区三区| 国产精品毛片大码女人| 亚洲一区二区综合| 男人的j进女人的j一区| 国内偷窥港台综合视频在线播放| 处破女av一区二区| 欧美综合欧美视频| 欧美精品国产精品| 日韩欧美精品在线| 久久久国际精品| 亚洲精品欧美专区| 欧美96一区二区免费视频| 国产91综合网| 欧美视频一区二| 精品国产区一区| 亚洲精品国产高清久久伦理二区| 五月天精品一区二区三区| 国产一区久久久| 色偷偷一区二区三区| 欧美一区二区三区男人的天堂| 欧美一区二区精品在线| 欧美激情中文字幕一区二区| 亚洲午夜精品网| 国产在线观看一区二区| 色美美综合视频| 精品国产精品网麻豆系列| 综合欧美亚洲日本| 天堂蜜桃一区二区三区| 国产电影一区在线| 91久久奴性调教| 久久久国产精品麻豆| 亚洲va欧美va国产va天堂影院| 国内精品久久久久影院薰衣草| 欧美在线你懂得| 国产精品视频你懂的| 首页亚洲欧美制服丝腿| 91在线一区二区三区| 欧美电影精品一区二区| 亚洲色图欧美在线| 国产一区二区三区不卡在线观看| 在线视频亚洲一区| 国产日产精品一区| 青青草视频一区| 欧美制服丝袜第一页| 国产人成亚洲第一网站在线播放 | 成人av电影在线观看| 欧美日本一道本在线视频| 中文字幕一区二区视频| 蜜桃av一区二区| 91蝌蚪porny| 国产欧美一区二区精品性色超碰| 日韩高清一级片| 欧美调教femdomvk| 亚洲黄色av一区| 久久精品免费看| 欧美日韩一级二级三级| 国产精品国产三级国产普通话蜜臀 | 2023国产精华国产精品| 丝袜美腿亚洲一区二区图片| 成人app下载| 国产婷婷精品av在线| 久久aⅴ国产欧美74aaa| 欧美中文字幕亚洲一区二区va在线 | 亚洲麻豆国产自偷在线| 国产精品亚洲午夜一区二区三区 | 亚洲另类在线一区| 成人激情免费电影网址| 久久久久久久久久美女| 日本中文在线一区| 91精品国产色综合久久不卡蜜臀 | 1000精品久久久久久久久| 91亚洲精品久久久蜜桃| 亚洲精品中文在线| 欧美日韩高清在线播放| 日本怡春院一区二区| 日韩欧美一区在线| 国产精品香蕉一区二区三区| 中文字幕av免费专区久久| 不卡欧美aaaaa| 一区二区三区高清| 555夜色666亚洲国产免| 久久er精品视频| 国产精品久久久久9999吃药| 一本大道av伊人久久综合| 性做久久久久久久久| 精品少妇一区二区三区在线播放| 国产不卡在线视频| 亚洲日本成人在线观看| 欧美情侣在线播放| 精品在线视频一区| 国产精品久99| 欧美日韩精品系列| 国产精品综合一区二区三区| 亚洲天堂福利av| 欧美一卡2卡三卡4卡5免费| 国产精品亚洲成人| 一二三四区精品视频| 精品国产91亚洲一区二区三区婷婷| 国产99精品视频| 亚洲bt欧美bt精品777| 久久在线免费观看| 欧美在线制服丝袜| 精品一区二区三区在线观看| 成人免费在线观看入口| 欧美人与z0zoxxxx视频| 国产91精品欧美| 亚洲午夜一二三区视频| 26uuu国产在线精品一区二区| 99久久精品免费看| 久久99国产精品免费网站| 亚洲天堂网中文字| 欧美v国产在线一区二区三区| 成人午夜在线视频| 热久久国产精品| 亚洲九九爱视频| 国产欧美中文在线| 欧美猛男gaygay网站| 成人教育av在线| 蜜桃视频一区二区| 亚洲一区在线播放| 国产精品色眯眯| 欧美电影免费观看高清完整版| 色综合视频一区二区三区高清| 久久国产视频网| 亚洲国产cao| 国产精品日日摸夜夜摸av| 日韩一级在线观看| 91极品视觉盛宴| 成人综合在线观看| 久久av中文字幕片| 日韩制服丝袜av| 亚洲自拍偷拍欧美| 中文字幕在线不卡| 国产亚洲一区二区三区四区| 在线播放亚洲一区| 在线观看区一区二| 不卡在线视频中文字幕| 国产一区久久久| 麻豆久久一区二区| 日韩中文字幕1| 亚洲大片免费看| 亚洲欧美日韩综合aⅴ视频| 国产女主播视频一区二区| 精品国产1区二区| 精品女同一区二区| 欧美一区二区三区四区久久| 欧美日韩三级一区| 色一区在线观看| 91麻豆高清视频| 91在线视频免费91| 成人福利电影精品一区二区在线观看| 国精品**一区二区三区在线蜜桃| 麻豆一区二区在线| 美女一区二区在线观看| 日韩中文字幕1| 免费看日韩a级影片|