Rico Schüller : d3d10: Implement ID3D10EffectVariable: :GetAnnotationByIndex().

Alexandre Julliard julliard at winehq.org
Thu Sep 10 09:08:47 CDT 2009


Module: wine
Branch: master
Commit: 4d91fba96f8fe6c66981b6bfb6ad3dda2ae05b74
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=4d91fba96f8fe6c66981b6bfb6ad3dda2ae05b74

Author: Rico Schüller <kgbricola at web.de>
Date:   Wed Sep  9 19:17:17 2009 +0200

d3d10: Implement ID3D10EffectVariable::GetAnnotationByIndex().

---

 dlls/d3d10/effect.c |   17 +++++++++++++++--
 1 files changed, 15 insertions(+), 2 deletions(-)

diff --git a/dlls/d3d10/effect.c b/dlls/d3d10/effect.c
index d85cbe4..cffd645 100644
--- a/dlls/d3d10/effect.c
+++ b/dlls/d3d10/effect.c
@@ -1650,9 +1650,22 @@ static HRESULT STDMETHODCALLTYPE d3d10_effect_variable_GetDesc(ID3D10EffectVaria
 static struct ID3D10EffectVariable * STDMETHODCALLTYPE d3d10_effect_variable_GetAnnotationByIndex(
         ID3D10EffectVariable *iface, UINT index)
 {
-    FIXME("iface %p, index %u stub!\n", iface, index);
+    struct d3d10_effect_variable *This = (struct d3d10_effect_variable *)iface;
+    struct d3d10_effect_variable *a;
 
-    return NULL;
+    TRACE("iface %p, index %u\n", iface, index);
+
+    if (index >= This->annotation_count)
+    {
+        WARN("Invalid index specified\n");
+        return (ID3D10EffectVariable *)&null_variable;
+    }
+
+    a = &This->annotations[index];
+
+    TRACE("Returning annotation %p, %s\n", a, debugstr_a(a->name));
+
+    return (ID3D10EffectVariable *)a;
 }
 
 static struct ID3D10EffectVariable * STDMETHODCALLTYPE d3d10_effect_variable_GetAnnotationByName(




More information about the wine-cvs mailing list