d3dx10: Implement D3DX10GetImageInfoFromFileW().
Signed-off-by: Ziqing Hui <zhui@codeweavers.com> Signed-off-by: Matteo Bruni <mbruni@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
4b8756e0b4
commit
d2406ad95e
|
@ -1383,12 +1383,10 @@ static void test_get_image_info(void)
|
|||
check_image_info(&image_info, i, __LINE__);
|
||||
}
|
||||
|
||||
todo_wine {
|
||||
hr = D3DX10GetImageInfoFromFileW(NULL, NULL, &image_info, NULL);
|
||||
ok(hr == E_FAIL, "Got unexpected hr %#x.\n", hr);
|
||||
hr = D3DX10GetImageInfoFromFileW(L"deadbeaf", NULL, &image_info, NULL);
|
||||
ok(hr == D3D10_ERROR_FILE_NOT_FOUND, "Got unexpected hr %#x.\n", hr);
|
||||
}
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(test_image); ++i)
|
||||
{
|
||||
|
@ -1396,7 +1394,7 @@ static void test_get_image_info(void)
|
|||
hr = D3DX10GetImageInfoFromFileW(path, NULL, &image_info, NULL);
|
||||
delete_file(test_filename);
|
||||
|
||||
todo_wine
|
||||
todo_wine_if(test_image[i].expected.ImageFileFormat == D3DX10_IFF_WMP)
|
||||
ok(hr == S_OK, "Test %u: Got unexpected hr %#x.\n", i, hr);
|
||||
if (hr != S_OK)
|
||||
continue;
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
*/
|
||||
|
||||
#include "wine/debug.h"
|
||||
#include "wine/heap.h"
|
||||
|
||||
#define COBJMACROS
|
||||
|
||||
|
@ -96,6 +97,57 @@ static DXGI_FORMAT get_d3dx10_dds_format(DXGI_FORMAT format)
|
|||
return format;
|
||||
}
|
||||
|
||||
static HRESULT load_file(const WCHAR *filename, void **buffer, DWORD *size)
|
||||
{
|
||||
HRESULT hr = S_OK;
|
||||
DWORD bytes_read;
|
||||
HANDLE file;
|
||||
BOOL ret;
|
||||
|
||||
file = CreateFileW(filename, GENERIC_READ, FILE_SHARE_READ, 0, OPEN_EXISTING, 0, 0);
|
||||
if (file == INVALID_HANDLE_VALUE)
|
||||
{
|
||||
hr = HRESULT_FROM_WIN32(GetLastError());
|
||||
goto done;
|
||||
}
|
||||
|
||||
*size = GetFileSize(file, NULL);
|
||||
if (*size == INVALID_FILE_SIZE)
|
||||
{
|
||||
hr = HRESULT_FROM_WIN32(GetLastError());
|
||||
goto done;
|
||||
}
|
||||
|
||||
*buffer = heap_alloc(*size);
|
||||
if (!*buffer)
|
||||
{
|
||||
hr = E_OUTOFMEMORY;
|
||||
goto done;
|
||||
}
|
||||
|
||||
ret = ReadFile(file, *buffer, *size, &bytes_read, NULL);
|
||||
if (!ret)
|
||||
{
|
||||
hr = HRESULT_FROM_WIN32(GetLastError());
|
||||
goto done;
|
||||
}
|
||||
if (bytes_read != *size)
|
||||
{
|
||||
hr = E_FAIL;
|
||||
goto done;
|
||||
}
|
||||
|
||||
done:
|
||||
if (FAILED(hr))
|
||||
{
|
||||
heap_free(*buffer);
|
||||
*buffer = NULL;
|
||||
}
|
||||
if (file != INVALID_HANDLE_VALUE)
|
||||
CloseHandle(file);
|
||||
return hr;
|
||||
}
|
||||
|
||||
HRESULT WINAPI D3DX10GetImageInfoFromFileA(const char *src_file, ID3DX10ThreadPump *pump, D3DX10_IMAGE_INFO *info,
|
||||
HRESULT *result)
|
||||
{
|
||||
|
@ -107,9 +159,23 @@ HRESULT WINAPI D3DX10GetImageInfoFromFileA(const char *src_file, ID3DX10ThreadPu
|
|||
HRESULT WINAPI D3DX10GetImageInfoFromFileW(const WCHAR *src_file, ID3DX10ThreadPump *pump, D3DX10_IMAGE_INFO *info,
|
||||
HRESULT *result)
|
||||
{
|
||||
FIXME("src_file %s, pump %p, info %p, result %p\n", debugstr_w(src_file), pump, info, result);
|
||||
void *buffer = NULL;
|
||||
DWORD size = 0;
|
||||
HRESULT hr;
|
||||
|
||||
return E_NOTIMPL;
|
||||
TRACE("src_file %s, pump %p, info %p, result %p.\n", debugstr_w(src_file), pump, info, result);
|
||||
|
||||
if (!src_file || !info)
|
||||
return E_FAIL;
|
||||
|
||||
if (FAILED(load_file(src_file, &buffer, &size)))
|
||||
return D3D10_ERROR_FILE_NOT_FOUND;
|
||||
|
||||
hr = D3DX10GetImageInfoFromMemory(buffer, size, pump, info, result);
|
||||
|
||||
heap_free(buffer);
|
||||
|
||||
return hr;
|
||||
}
|
||||
|
||||
HRESULT WINAPI D3DX10GetImageInfoFromResourceA(HMODULE module, const char *resource, ID3DX10ThreadPump *pump,
|
||||
|
|
Loading…
Reference in New Issue