[PATCH 1/3] d3dx10: Implement D3DX10GetImageInfoFromFileW().

Zhiyi Zhang zzhang at codeweavers.com
Wed Sep 9 22:52:08 CDT 2020



On 2020/9/10 11:11, Ziqing Hui wrote:
> Signed-off-by: Ziqing Hui <zhui at codeweavers.com>
> ---
>  dlls/d3dx10_43/d3dx10_43_main.c | 56 +++++++++++++++++++++++++++++++--
>  dlls/d3dx10_43/tests/d3dx10.c   |  6 ++--
>  2 files changed, 57 insertions(+), 5 deletions(-)
>
>
>
> 0001-d3dx10-Implement-D3DX10GetImageInfoFromFileW.patch
>
> diff --git a/dlls/d3dx10_43/d3dx10_43_main.c b/dlls/d3dx10_43/d3dx10_43_main.c
> index 32d69ff8af..3356ebd8b5 100644
> --- a/dlls/d3dx10_43/d3dx10_43_main.c
> +++ b/dlls/d3dx10_43/d3dx10_43_main.c
> @@ -106,6 +106,43 @@ static DXGI_FORMAT get_d3dx10_dds_format(DXGI_FORMAT format)
>      return format;
>  }
>  
> +static HRESULT map_file(const WCHAR *filename, void **buffer, DWORD *size)
> +{
> +    HANDLE file, mapping = NULL;
> +    HRESULT hr = E_FAIL;
> +
> +    file = CreateFileW(filename, GENERIC_READ, FILE_SHARE_READ, 0, OPEN_EXISTING, 0, 0);
> +    if(file == INVALID_HANDLE_VALUE)
Space after 'if', you're using both styles in this function.

> +        goto end;
> +
> +    *size = GetFileSize(file, NULL);
> +    if(*size == INVALID_FILE_SIZE)
> +        goto end;
> +
> +    mapping = CreateFileMappingW(file, NULL, PAGE_READONLY, 0, 0, NULL);
> +    if(!mapping)
> +        goto end;
> +
> +    *buffer = MapViewOfFile(mapping, FILE_MAP_READ, 0, 0, 0);
> +    if(*buffer == NULL)
> +        goto end;
> +
> +    hr = S_OK;
> +
> +end:
> +    CloseHandle(mapping);
> +    CloseHandle(file);
> +
> +    if (hr != S_OK)
> +        hr = HRESULT_FROM_WIN32(GetLastError());
> +    return hr;
> +}
> +
> +static BOOL unmap_file(void *buffer)
> +{
> +    return UnmapViewOfFile(buffer);
> +}
> +
>  BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
>  {
>      switch (fdwReason)
> @@ -308,9 +345,24 @@ 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);
> +    DWORD size = 0;
> +    void *buffer;
> +    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)
> +        return E_FAIL;
> +
> +    hr = map_file(src_file, &buffer, &size);
> +    if (FAILED(hr))
> +        return D3D10_ERROR_FILE_NOT_FOUND;
> +
> +    hr = D3DX10GetImageInfoFromMemory(buffer, size, NULL, info, NULL);
> +
> +    unmap_file(buffer);
> +
> +    return hr;
>  }
>  
>  HRESULT WINAPI D3DX10GetImageInfoFromResourceA(HMODULE module, const char *resource, ID3DX10ThreadPump *pump,
> diff --git a/dlls/d3dx10_43/tests/d3dx10.c b/dlls/d3dx10_43/tests/d3dx10.c
> index 640e83fcd0..a4b7360fa1 100644
> --- a/dlls/d3dx10_43/tests/d3dx10.c
> +++ b/dlls/d3dx10_43/tests/d3dx10.c
> @@ -1383,12 +1383,12 @@ static void test_get_image_info(void)
>          check_image_info(&image_info, i, __LINE__);
>      }
>  
> -    todo_wine {
> +    /* D3DX10GetImageInfoFromFile tests */
> +
>      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 +1396,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;
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://www.winehq.org/pipermail/wine-devel/attachments/20200910/255c89d8/attachment.htm>


More information about the wine-devel mailing list