WiiFlow_Lite/source/unzip/ZipFile.cpp

134 lines
3.0 KiB
C++
Raw Normal View History

2012-01-21 21:57:41 +01:00
/****************************************************************************
* Copyright (C) 2009
* by Dimok
*
* This software is provided 'as-is', without any express or implied
* warranty. In no event will the authors be held liable for any
* damages arising from the use of this software.
*
* Permission is granted to anyone to use this software for any
* purpose, including commercial applications, and to alter it and
* redistribute it freely, subject to the following restrictions:
*
* 1. The origin of this software must not be misrepresented; you
* must not claim that you wrote the original software. If you use
* this software in a product, an acknowledgment in the product
* documentation would be appreciated but is not required.
*
* 2. Altered source versions must be plainly marked as such, and
* must not be misrepresented as being the original software.
*
* 3. This notice may not be removed or altered from any source
* distribution.
*
* ZipFile.cpp
*
* ZipFile Class
* for Wii-FileXplorer 2009
*
* STILL UNCOMPLETE AND UNDER CONSTRUCTION
***************************************************************************/
#include <ogcsys.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
2012-01-21 21:57:41 +01:00
#include "ZipFile.h"
#include "fileOps/fileOps.h"
#include "memory/mem2.hpp"
2012-01-21 21:57:41 +01:00
ZipFile::ZipFile(const char *filepath)
{
File = unzOpen(filepath);
if(File)
this->LoadList();
2012-01-21 21:57:41 +01:00
}
ZipFile::~ZipFile()
{
unzClose(File);
2012-01-21 21:57:41 +01:00
}
bool ZipFile::LoadList()
{
return true;
2012-01-21 21:57:41 +01:00
}
bool ZipFile::ExtractAll(const char *dest)
{
if(!File)
return false;
2012-01-21 21:57:41 +01:00
bool Stop = false;
2012-01-21 21:57:41 +01:00
u32 blocksize = 1024 * 50;
u8 *buffer = (u8*)MEM2_memalign(32, blocksize);
if(buffer == NULL)
return false;
2012-01-21 21:57:41 +01:00
char writepath[MAXPATHLEN];
char filename[MAXPATHLEN];
memset(filename, 0, sizeof(filename));
2012-01-21 21:57:41 +01:00
int ret = unzGoToFirstFile(File);
if(ret != UNZ_OK)
Stop = true;
2012-01-21 21:57:41 +01:00
while(!Stop)
{
if(unzGetCurrentFileInfo(File, &cur_file_info, filename, sizeof(filename), NULL, 0, NULL, 0) != UNZ_OK)
2012-01-21 21:57:41 +01:00
Stop = true;
if(!Stop && filename[strlen(filename) - 1] != '/')
{
u32 uncompressed_size = cur_file_info.uncompressed_size;
2012-01-21 21:57:41 +01:00
u32 done = 0;
char *pointer = NULL;
2012-01-21 21:57:41 +01:00
ret = unzOpenCurrentFile(File);
2012-01-21 21:57:41 +01:00
snprintf(writepath, sizeof(writepath), "%s/%s", dest, filename);
2012-01-21 21:57:41 +01:00
pointer = strrchr(writepath, '/');
int position = pointer - writepath + 2;
2012-01-21 21:57:41 +01:00
char temppath[strlen(writepath)];
snprintf(temppath, position, "%s", writepath);
2012-01-21 21:57:41 +01:00
fsop_MakeFolder(temppath);
2012-01-21 21:57:41 +01:00
if(ret == UNZ_OK)
{
FILE *pfile = fopen(writepath, "wb");
2012-01-21 21:57:41 +01:00
do
{
if(uncompressed_size - done < blocksize)
blocksize = uncompressed_size - done;
2012-01-21 21:57:41 +01:00
ret = unzReadCurrentFile(File, buffer, blocksize);
2012-01-21 21:57:41 +01:00
if(ret == 0)
break;
2012-01-21 21:57:41 +01:00
fwrite(buffer, 1, blocksize, pfile);
2012-01-21 21:57:41 +01:00
done += ret;
2012-01-21 21:57:41 +01:00
} while(done < uncompressed_size);
2012-01-21 21:57:41 +01:00
fclose(pfile);
unzCloseCurrentFile(File);
}
}
if(unzGoToNextFile(File) != UNZ_OK)
Stop = true;
}
MEM2_free(buffer);
buffer = NULL;
2012-01-21 21:57:41 +01:00
return true;
2012-01-21 21:57:41 +01:00
}