Module: wine Branch: master Commit: d9c9b5c365daac4ad33d77da89eb7f10be03914e URL: http://source.winehq.org/git/wine.git/?a=commit;h=d9c9b5c365daac4ad33d77da89...
Author: Matteo Bruni mbruni@codeweavers.com Date: Fri Sep 23 17:03:20 2011 +0200
d3d10core: Fixup HRESULT in a bunch of error cases.
---
dlls/d3d10core/shader.c | 7 +++++-- dlls/d3d10core/utils.c | 2 +- 2 files changed, 6 insertions(+), 3 deletions(-)
diff --git a/dlls/d3d10core/shader.c b/dlls/d3d10core/shader.c index 357cda3..82ddadc 100644 --- a/dlls/d3d10core/shader.c +++ b/dlls/d3d10core/shader.c @@ -57,7 +57,7 @@ static HRESULT shader_extract_from_dxbc(const void *dxbc, SIZE_T dxbc_length, st memset(shader_info->output_signature, 0, sizeof(*shader_info->output_signature));
hr = parse_dxbc(dxbc, dxbc_length, shdr_handler, shader_info); - if (!shader_info->shader_code) hr = E_FAIL; + if (!shader_info->shader_code) hr = E_INVALIDARG;
if (FAILED(hr)) { @@ -267,6 +267,7 @@ HRESULT d3d10_vertex_shader_init(struct d3d10_vertex_shader *shader, struct d3d1 { WARN("Failed to create wined3d vertex shader, hr %#x.\n", hr); shader_free_signature(&shader->output_signature); + hr = E_INVALIDARG; return hr; }
@@ -411,8 +412,9 @@ HRESULT d3d10_geometry_shader_init(struct d3d10_geometry_shader *shader, struct &shader->output_signature, shader, &d3d10_geometry_shader_wined3d_parent_ops, &shader->wined3d_shader, 4); if (FAILED(hr)) { - WARN("Failed to create wined3d vertex shader, hr %#x.\n", hr); + WARN("Failed to create wined3d geometry shader, hr %#x.\n", hr); shader_free_signature(&shader->output_signature); + hr = E_INVALIDARG; return hr; }
@@ -553,6 +555,7 @@ HRESULT d3d10_pixel_shader_init(struct d3d10_pixel_shader *shader, struct d3d10_ { WARN("Failed to create wined3d pixel shader, hr %#x.\n", hr); shader_free_signature(&shader->output_signature); + hr = E_INVALIDARG; return hr; }
diff --git a/dlls/d3d10core/utils.c b/dlls/d3d10core/utils.c index 97c0347..813cae6 100644 --- a/dlls/d3d10core/utils.c +++ b/dlls/d3d10core/utils.c @@ -374,7 +374,7 @@ HRESULT parse_dxbc(const char *data, SIZE_T data_size, if (tag != TAG_DXBC) { WARN("Wrong tag.\n"); - return E_FAIL; + return E_INVALIDARG; }
/* checksum? */