mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-24 14:49:42 -06:00
Wrapped fopen/close/read/write functions inside a simple "IOFile" class. Reading, writing, and error checking became simpler in most cases. It should be near impossible to forget to close a file now that the destructor takes care of it. (I hope this fixes Issue 3635) I have tested the functionality of most things, but it is possible I broke something. :p
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7328 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
@ -15,11 +15,11 @@
|
||||
// Official SVN repository and contact information can be found at
|
||||
// http://code.google.com/p/dolphin-emu/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <list>
|
||||
#include <vector>
|
||||
|
||||
#include "ImageWrite.h"
|
||||
#include "FileUtil.h"
|
||||
|
||||
#pragma pack(push, 1)
|
||||
|
||||
@ -47,32 +47,30 @@ struct TGA_HEADER
|
||||
|
||||
bool SaveTGA(const char* filename, int width, int height, void* pdata)
|
||||
{
|
||||
TGA_HEADER hdr;
|
||||
FILE* f = fopen(filename, "wb");
|
||||
if (f == NULL)
|
||||
return false;
|
||||
TGA_HEADER hdr;
|
||||
File::IOFile f(filename, "wb");
|
||||
if (!f)
|
||||
return false;
|
||||
|
||||
_assert_(sizeof(TGA_HEADER) == 18 && sizeof(hdr) == 18);
|
||||
_assert_(sizeof(TGA_HEADER) == 18 && sizeof(hdr) == 18);
|
||||
|
||||
memset(&hdr, 0, sizeof(hdr));
|
||||
hdr.imagetype = 2;
|
||||
hdr.bits = 32;
|
||||
hdr.width = width;
|
||||
hdr.height = height;
|
||||
hdr.descriptor |= 8|(1<<5); // 8bit alpha, flip vertical
|
||||
memset(&hdr, 0, sizeof(hdr));
|
||||
hdr.imagetype = 2;
|
||||
hdr.bits = 32;
|
||||
hdr.width = width;
|
||||
hdr.height = height;
|
||||
hdr.descriptor |= 8|(1<<5); // 8bit alpha, flip vertical
|
||||
|
||||
fwrite(&hdr, sizeof(hdr), 1, f);
|
||||
fwrite(pdata, width * height * 4, 1, f);
|
||||
fclose(f);
|
||||
return true;
|
||||
f.WriteArray(&hdr, 1);
|
||||
f.WriteBytes(pdata, width * height * 4);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool SaveData(const char* filename, const char* data)
|
||||
{
|
||||
FILE *f = fopen(filename, "wb");
|
||||
if (!f)
|
||||
return false;
|
||||
fwrite(data, strlen(data), 1, f);
|
||||
fclose(f);
|
||||
return true;
|
||||
std::ofstream f(filename, std::ios::binary);
|
||||
f << data;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -105,22 +105,20 @@ void TexDecoder_OpenCL_Initialize()
|
||||
filename = File::GetUserPath(D_OPENCL_IDX) + "kernel.bin";
|
||||
snprintf(dolphin_rev, HEADER_SIZE, "%-31s", svn_rev_str);
|
||||
|
||||
FILE *input = NULL;
|
||||
|
||||
input = fopen(filename.c_str(), "rb");
|
||||
if (input == NULL)
|
||||
{
|
||||
File::IOFile input(filename, "rb");
|
||||
if (!input)
|
||||
{
|
||||
binary_size = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
binary_size = File::GetSize(input);
|
||||
binary_size = input.GetSize();
|
||||
header = new char[HEADER_SIZE];
|
||||
binary = new char[binary_size];
|
||||
fread(header, sizeof(char), HEADER_SIZE, input);
|
||||
binary_size = fread(binary, sizeof(char),
|
||||
binary_size - HEADER_SIZE, input);
|
||||
fclose(input);
|
||||
input.ReadBytes(header, HEADER_SIZE);
|
||||
input.ReadBytes(binary, binary_size);
|
||||
}
|
||||
}
|
||||
|
||||
if (binary_size > 0)
|
||||
@ -202,19 +200,17 @@ void TexDecoder_OpenCL_Initialize()
|
||||
if (!err)
|
||||
{
|
||||
filename = File::GetUserPath(D_OPENCL_IDX) + "kernel.bin";
|
||||
FILE *output = NULL;
|
||||
output = fopen(filename.c_str(), "wb");
|
||||
|
||||
if (output == NULL)
|
||||
File::IOFile output(filename, "wb");
|
||||
if (!output)
|
||||
{
|
||||
binary_size = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
// Supporting one OpenCL device for now
|
||||
fwrite(dolphin_rev, sizeof(char), HEADER_SIZE, output);
|
||||
fwrite(binaries[0], sizeof(char), binary_sizes[0], output);
|
||||
fclose(output);
|
||||
output.WriteBytes(dolphin_rev, HEADER_SIZE);
|
||||
output.WriteBytes(binaries[0], binary_sizes[0]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user