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

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

?? zipstorage.cpp

?? 用BKZIP方式解壓縮文件
?? 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一区二区三区免费野_久草精品视频
国产成人一级电影| 中文字幕国产一区| 国产精品久线在线观看| 亚洲成人动漫一区| 不卡的av电影| 日韩一区二区免费高清| 亚洲精品欧美专区| 国产综合色视频| 欧美精品123区| 日韩毛片高清在线播放| 国产一区 二区 三区一级| 欧美精品在线视频| 亚洲一区二区欧美| 色婷婷av一区二区三区gif| 国产丝袜欧美中文另类| 久久9热精品视频| 6080日韩午夜伦伦午夜伦| 亚洲精品免费在线| 99精品久久99久久久久| 中文字幕乱码亚洲精品一区| 久久国产欧美日韩精品| 777奇米成人网| 日韩精品欧美精品| 欧美精品在欧美一区二区少妇| 一区二区三区国产精华| 色综合激情五月| 自拍偷拍亚洲欧美日韩| 99精品热视频| 亚洲免费色视频| 在线观看一区二区视频| 一区二区三区国产精品| 欧美色成人综合| 五月婷婷久久丁香| 欧美一区二区三区在线电影 | 色网站国产精品| ...av二区三区久久精品| av激情亚洲男人天堂| 亚洲欧美韩国综合色| 欧美影视一区在线| 午夜视频在线观看一区二区三区| 欧美日韩免费一区二区三区 | 日韩精品一区二区在线| 免费欧美日韩国产三级电影| 日韩欧美亚洲另类制服综合在线| 青青青伊人色综合久久| 欧美一级片免费看| 国产伦精品一区二区三区免费| 国产欧美日韩一区二区三区在线观看| 国产麻豆精品在线观看| 亚洲特级片在线| 欧美伊人久久久久久久久影院 | 亚洲天堂成人在线观看| 91福利国产成人精品照片| 午夜精品久久久久久久久久 | 国产露脸91国语对白| 国产精品国产三级国产aⅴ原创| 91免费版pro下载短视频| 亚洲一二三四在线| 日韩精品在线一区| 成人激情开心网| 亚洲午夜日本在线观看| 久久综合色综合88| 色偷偷88欧美精品久久久| 午夜国产不卡在线观看视频| 久久午夜色播影院免费高清| 色婷婷综合久久久| 久久99精品网久久| 亚洲男人的天堂av| 久久综合久久鬼色| 欧美午夜精品理论片a级按摩| 国产一区二区三区视频在线播放| 日韩毛片一二三区| 精品国产伦一区二区三区观看体验 | 91丨九色丨蝌蚪丨老版| 理论电影国产精品| 亚洲综合精品自拍| 中文字幕精品一区| 91精品国产综合久久福利| 成人网在线免费视频| 男人的天堂亚洲一区| 亚洲人吸女人奶水| 国产亚洲美州欧州综合国| 欧美日韩一二三区| 99久久久国产精品| 国产精一品亚洲二区在线视频| 午夜在线电影亚洲一区| 成人免费小视频| 国产偷v国产偷v亚洲高清| 欧美一区二区三区播放老司机| 99久久婷婷国产综合精品电影| 国产美女一区二区| 毛片av一区二区| 亚洲成人综合在线| 一区二区三区中文字幕| 国产精品欧美一区二区三区| 日韩一区二区三区电影| 777欧美精品| 69久久99精品久久久久婷婷| 在线观看一区二区视频| 91高清视频在线| 91色在线porny| av午夜精品一区二区三区| 国产电影一区在线| 国产a级毛片一区| 国精产品一区一区三区mba视频| 日韩电影免费一区| 日本伊人午夜精品| 天堂成人免费av电影一区| 亚洲成a人片综合在线| 亚洲一区二区三区美女| 亚洲电影你懂得| 天天操天天干天天综合网| 亚洲chinese男男1069| 亚洲高清不卡在线观看| 亚洲小说欧美激情另类| 亚洲综合色网站| 性感美女久久精品| 免费高清成人在线| 国产一区三区三区| 成人在线综合网站| 91啪九色porn原创视频在线观看| 99re免费视频精品全部| 色狠狠一区二区三区香蕉| 欧美亚洲国产一区在线观看网站| 欧洲在线/亚洲| 欧美精品123区| xvideos.蜜桃一区二区| 欧美国产一区二区在线观看| 中文字幕欧美一| 亚洲一区二区在线播放相泽| 日韩成人一级大片| 国内成人免费视频| 成人av在线一区二区| 91福利区一区二区三区| 欧美一区二区三区在线| 久久久久久免费网| 成人免费在线视频| 日本sm残虐另类| 丁香网亚洲国际| 欧美日韩一区二区三区不卡| 欧美一卡2卡3卡4卡| 国产精品亲子伦对白| 亚洲成人午夜影院| 国产精品99久久久久久宅男| 色88888久久久久久影院按摩| 欧美精品乱码久久久久久| 国产亚洲欧洲一区高清在线观看| 亚洲欧美日韩一区| 激情深爱一区二区| 91丨porny丨国产| 日韩欧美电影一二三| 日韩理论在线观看| 激情综合网天天干| 在线亚洲欧美专区二区| 精品国产乱码久久| 亚洲宅男天堂在线观看无病毒| 韩国精品久久久| 欧美日韩日本视频| 国产精品久久久久久久久免费桃花| 三级精品在线观看| 97se狠狠狠综合亚洲狠狠| 日韩一区二区在线看| 亚洲欧美视频在线观看视频| 九色综合国产一区二区三区| 精品美女被调教视频大全网站| 亚洲天堂网中文字| 亚洲人成小说网站色在线| 欧美aaa在线| 欧美日韩免费高清一区色橹橹 | 亚洲午夜电影在线| 亚洲精品免费视频| 国产综合久久久久久久久久久久| 日韩丝袜美女视频| 国内久久精品视频| 国产婷婷一区二区| 99久久99久久综合| 亚洲综合999| 91麻豆精品国产91久久久使用方法 | 91麻豆国产自产在线观看| 亚洲视频中文字幕| 欧美艳星brazzers| 欧美a一区二区| 国产亚洲一区二区三区四区| 成人自拍视频在线| 亚洲在线成人精品| 欧美一区二区三区性视频| 国产精品一区二区三区四区| 中文字幕制服丝袜成人av| 色哟哟一区二区在线观看| 午夜精品福利一区二区三区av| 日韩精品资源二区在线| 成人黄色小视频| 亚洲va韩国va欧美va精品| 日韩欧美高清在线| 国产福利一区在线| 一区二区三区国产精华| 日韩欧美精品在线| 成人午夜电影网站| 亚洲成精国产精品女| 久久久国际精品|