Nikolay Sivov : d3d10/effect: Get rid of linear search for property information.

Alexandre Julliard julliard at winehq.org
Wed Oct 13 15:59:27 CDT 2021


Module: wine
Branch: master
Commit: 1bc3ca71d6108cc7af2bfbb2a23c43298ac57b64
URL:    https://source.winehq.org/git/wine.git/?a=commit;h=1bc3ca71d6108cc7af2bfbb2a23c43298ac57b64

Author: Nikolay Sivov <nsivov at codeweavers.com>
Date:   Fri Oct  8 08:13:36 2021 +0300

d3d10/effect: Get rid of linear search for property information.

Signed-off-by: Nikolay Sivov <nsivov at codeweavers.com>
Signed-off-by: Matteo Bruni <mbruni at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/d3d10/effect.c | 23 +++++------------------
 1 file changed, 5 insertions(+), 18 deletions(-)

diff --git a/dlls/d3d10/effect.c b/dlls/d3d10/effect.c
index cd5f6517c54..71ad3f64a05 100644
--- a/dlls/d3d10/effect.c
+++ b/dlls/d3d10/effect.c
@@ -176,7 +176,7 @@ struct d3d10_effect_state_property_info
     LONG index_offset;
 };
 
-static const struct d3d10_effect_state_property_info property_info[] =
+static const struct d3d10_effect_state_property_info property_infos[] =
 {
     {0x00, "Pass.RasterizerState",                        D3D10_SVT_RASTERIZER,       1, 1, D3D10_C_PASS, FIELD_OFFSET(struct d3d10_effect_pass, rasterizer)    },
     {0x01, "Pass.DepthStencilState",                      D3D10_SVT_DEPTHSTENCIL,     1, 1, D3D10_C_PASS, FIELD_OFFSET(struct d3d10_effect_pass, depth_stencil) },
@@ -1540,19 +1540,6 @@ static HRESULT parse_fx10_anonymous_shader(struct d3d10_effect *e, struct d3d10_
     return S_OK;
 }
 
-static const struct d3d10_effect_state_property_info *get_property_info(UINT id)
-{
-    unsigned int i;
-
-    for (i = 0; i < ARRAY_SIZE(property_info); ++i)
-    {
-        if (property_info[i].id == id)
-            return &property_info[i];
-    }
-
-    return NULL;
-}
-
 static const struct d3d10_effect_state_storage_info *get_storage_info(D3D_SHADER_VARIABLE_TYPE id)
 {
     unsigned int i;
@@ -1764,14 +1751,14 @@ static HRESULT parse_fx10_property_assignment(const char *data, size_t data_size
     read_dword(ptr, &operation);
     read_dword(ptr, &value_offset);
 
-    if (!(property_info = get_property_info(id)))
+    if (id >= ARRAY_SIZE(property_infos))
     {
-        FIXME("Failed to find property info for property %#x.\n", id);
+        FIXME("Unknown property id %#x.\n", id);
         return E_FAIL;
     }
+    property_info = &property_infos[id];
 
-    TRACE("Property %s[%#x] = value list @ offset %#x.\n",
-            property_info->name, idx, value_offset);
+    TRACE("Property %s[%#x] = value list @ offset %#x.\n", property_info->name, idx, value_offset);
 
     if (property_info->container_type != container_type)
     {




More information about the wine-cvs mailing list