[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [55822] trunk/blender/intern/cycles/render /attribute.cpp: Code cleanup / Cycles / Object Attributes:
Thomas Dinges
blender at dingto.org
Fri Apr 5 19:03:59 CEST 2013
Revision: 55822
http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=55822
Author: dingto
Date: 2013-04-05 17:03:59 +0000 (Fri, 05 Apr 2013)
Log Message:
-----------
Code cleanup / Cycles / Object Attributes:
* Change some long "else if" conditions into switch case.
Modified Paths:
--------------
trunk/blender/intern/cycles/render/attribute.cpp
Modified: trunk/blender/intern/cycles/render/attribute.cpp
===================================================================
--- trunk/blender/intern/cycles/render/attribute.cpp 2013-04-05 16:59:19 UTC (rev 55821)
+++ trunk/blender/intern/cycles/render/attribute.cpp 2013-04-05 17:03:59 UTC (rev 55822)
@@ -72,20 +72,33 @@
size_t Attribute::element_size(int numverts, int numtris, int numcurves, int numkeys) const
{
- if(element == ATTR_ELEMENT_VALUE)
- return 1;
- if(element == ATTR_ELEMENT_VERTEX)
- return numverts;
- else if(element == ATTR_ELEMENT_FACE)
- return numtris;
- else if(element == ATTR_ELEMENT_CORNER)
- return numtris*3;
- else if(element == ATTR_ELEMENT_CURVE)
- return numcurves;
- else if(element == ATTR_ELEMENT_CURVE_KEY)
- return numkeys;
+ size_t size;
- return 0;
+ switch(element) {
+ case ATTR_ELEMENT_VALUE:
+ size = 1;
+ break;
+ case ATTR_ELEMENT_VERTEX:
+ size = numverts;
+ break;
+ case ATTR_ELEMENT_FACE:
+ size = numtris;
+ break;
+ case ATTR_ELEMENT_CORNER:
+ size = numtris*3;
+ break;
+ case ATTR_ELEMENT_CURVE:
+ size = numcurves;
+ break;
+ case ATTR_ELEMENT_CURVE_KEY:
+ size = numkeys;
+ break;
+ default:
+ size = 0;
+ break;
+ }
+
+ return size;
}
size_t Attribute::buffer_size(int numverts, int numtris, int numcurves, int numkeys) const
@@ -214,44 +227,66 @@
name = Attribute::standard_name(std);
if(triangle_mesh) {
- if(std == ATTR_STD_VERTEX_NORMAL)
- attr = add(name, TypeDesc::TypeNormal, ATTR_ELEMENT_VERTEX);
- else if(std == ATTR_STD_FACE_NORMAL)
- attr = add(name, TypeDesc::TypeNormal, ATTR_ELEMENT_FACE);
- else if(std == ATTR_STD_UV)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CORNER);
- else if(std == ATTR_STD_UV_TANGENT)
- attr = add(name, TypeDesc::TypeVector, ATTR_ELEMENT_CORNER);
- else if(std == ATTR_STD_UV_TANGENT_SIGN)
- attr = add(name, TypeDesc::TypeFloat, ATTR_ELEMENT_CORNER);
- else if(std == ATTR_STD_GENERATED)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
- else if(std == ATTR_STD_POSITION_UNDEFORMED)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
- else if(std == ATTR_STD_POSITION_UNDISPLACED)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
- else if(std == ATTR_STD_MOTION_PRE)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
- else if(std == ATTR_STD_MOTION_POST)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
- else
- assert(0);
+ switch(std) {
+ case ATTR_STD_VERTEX_NORMAL:
+ attr = add(name, TypeDesc::TypeNormal, ATTR_ELEMENT_VERTEX);
+ break;
+ case ATTR_STD_FACE_NORMAL:
+ attr = add(name, TypeDesc::TypeNormal, ATTR_ELEMENT_FACE);
+ break;
+ case ATTR_STD_UV:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CORNER);
+ break;
+ case ATTR_STD_UV_TANGENT:
+ attr = add(name, TypeDesc::TypeVector, ATTR_ELEMENT_CORNER);
+ break;
+ case ATTR_STD_UV_TANGENT_SIGN:
+ attr = add(name, TypeDesc::TypeFloat, ATTR_ELEMENT_CORNER);
+ break;
+ case ATTR_STD_GENERATED:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
+ break;
+ case ATTR_STD_POSITION_UNDEFORMED:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
+ break;
+ case ATTR_STD_POSITION_UNDISPLACED:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
+ break;
+ case ATTR_STD_MOTION_PRE:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
+ break;
+ case ATTR_STD_MOTION_POST:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_VERTEX);
+ break;
+ default:
+ assert(0);
+ break;
+ }
}
else if(curve_mesh) {
- if(std == ATTR_STD_UV)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CURVE);
- else if(std == ATTR_STD_GENERATED)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CURVE);
- else if(std == ATTR_STD_MOTION_PRE)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CURVE_KEY);
- else if(std == ATTR_STD_MOTION_POST)
- attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CURVE_KEY);
- else if(std == ATTR_STD_CURVE_TANGENT)
- attr = add(name, TypeDesc::TypeVector, ATTR_ELEMENT_CURVE_KEY);
- else if(std == ATTR_STD_CURVE_INTERCEPT)
- attr = add(name, TypeDesc::TypeFloat, ATTR_ELEMENT_CURVE_KEY);
- else
- assert(0);
+ switch(std) {
+ case ATTR_STD_UV:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CURVE);
+ break;
+ case ATTR_STD_GENERATED:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CURVE);
+ break;
+ case ATTR_STD_MOTION_PRE:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CURVE_KEY);
+ break;
+ case ATTR_STD_MOTION_POST:
+ attr = add(name, TypeDesc::TypePoint, ATTR_ELEMENT_CURVE_KEY);
+ break;
+ case ATTR_STD_CURVE_TANGENT:
+ attr = add(name, TypeDesc::TypeVector, ATTR_ELEMENT_CURVE_KEY);
+ break;
+ case ATTR_STD_CURVE_INTERCEPT:
+ attr = add(name, TypeDesc::TypeFloat, ATTR_ELEMENT_CURVE_KEY);
+ break;
+ default:
+ assert(0);
+ break;
+ }
}
attr->std = std;
More information about the Bf-blender-cvs
mailing list