From 0a23fc7b294e2dd30482f9a36196d31ebc47fc81 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Rico=20Sch=C3=BCller?= Date: Wed, 20 Apr 2011 07:58:34 +0200 Subject: [PATCH] d3dx9: Implement ID3DXBaseEffect::GetPassByName(). --- dlls/d3dx9_36/effect.c | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/dlls/d3dx9_36/effect.c b/dlls/d3dx9_36/effect.c index 287e468960a..081da3149a3 100644 --- a/dlls/d3dx9_36/effect.c +++ b/dlls/d3dx9_36/effect.c @@ -688,8 +688,29 @@ static D3DXHANDLE WINAPI ID3DXBaseEffectImpl_GetPass(ID3DXBaseEffect *iface, D3D static D3DXHANDLE WINAPI ID3DXBaseEffectImpl_GetPassByName(ID3DXBaseEffect *iface, D3DXHANDLE technique, LPCSTR name) { struct ID3DXBaseEffectImpl *This = impl_from_ID3DXBaseEffect(iface); + struct d3dx_technique *tech = is_valid_technique(This, technique); + + TRACE("iface %p, technique %p, name %s\n", This, technique, debugstr_a(name)); + + if (!tech) tech = get_technique_struct(iface->lpVtbl->GetTechniqueByName(iface, technique)); + + if (tech && name) + { + unsigned int i; + + for (i = 0; i < tech->pass_count; ++i) + { + struct d3dx_pass *pass = get_pass_struct(tech->pass_handles[i]); - FIXME("iface %p, technique %p, name %s stub\n", This, technique, debugstr_a(name)); + if (!strcmp(pass->name, name)) + { + TRACE("Returning pass %p\n", tech->pass_handles[i]); + return tech->pass_handles[i]; + } + } + } + + WARN("Invalid argument specified.\n"); return NULL; } -- 2.11.4.GIT