2016-09-13 22:11 GMT+02:00 Fabian Maurer dark.shadow4@web.de:
Signed-off-by: Fabian Maurer dark.shadow4@web.de
dlls/d3dx11_43/async.c | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-)
diff --git a/dlls/d3dx11_43/async.c b/dlls/d3dx11_43/async.c index 90c60fa..1e3042b 100644 --- a/dlls/d3dx11_43/async.c +++ b/dlls/d3dx11_43/async.c @@ -1989,16 +1989,36 @@ HRESULT WINAPI D3DX11CompileFromFileA(const char *filename, const D3D10_SHADER_M return E_NOTIMPL; }
Stray newline.
HRESULT WINAPI D3DX11CompileFromFileW(const WCHAR *filename, const D3D10_SHADER_MACRO *defines, ID3D10Include *include, const char *entry_point, const char *target, UINT sflags, UINT eflags, ID3DX11ThreadPump *pump, ID3D10Blob **shader, ID3D10Blob **error_messages, HRESULT *hresult) {
- FIXME("filename %s, defines %p, include %p, entry_point %s, target %s, sflags %#x, "
- void *file_buffer;
- HRESULT hr;
- DWORD file_size;
- LPSTR filename_converted;
Please use "char *" instead.
- UINT filename_converted_len;
Probably you can call it just "size".
- TRACE("filename %s, defines %p, include %p, entry_point %s, target %s, sflags %#x, " "eflags %#x, pump %p, shader %p, error_messages %p, hresult %p stub.\n",
The "stub" part should go away.
debugstr_w(filename), defines, include, debugstr_a(entry_point), debugstr_a(target), sflags, eflags, pump, shader, error_messages, hresult);
- return E_NOTIMPL;
- if (FAILED(hr = map_view_of_file(filename, &file_buffer, &file_size)))
return hr;
- filename_converted_len = WideCharToMultiByte(CP_ACP, 0, filename, -1, NULL, 0, NULL, NULL);
- filename_converted = HeapAlloc(GetProcessHeap(), 0, filename_converted_len);
- WideCharToMultiByte(CP_ACP, 0, filename, -1, filename_converted, filename_converted_len, NULL, NULL);
- hr = D3DX11CompileFromMemory(file_buffer, file_size, filename_converted, defines, include, entry_point, target,
sflags, eflags, pump, shader, error_messages, hresult);
- HeapFree(GetProcessHeap(), 0, filename_converted);
- UnmapViewOfFile(file_buffer);
- return hr;
}
This would be okay otherwise but, as mentioned for patch [4/5], maybe it's a good idea to implement and make use of D3DX11CreateAsyncFileLoaderW() here too.