diff options
Diffstat (limited to 'source/blender/python/gpu/gpu_py_vertex_format.c')
-rw-r--r-- | source/blender/python/gpu/gpu_py_vertex_format.c | 144 |
1 files changed, 29 insertions, 115 deletions
diff --git a/source/blender/python/gpu/gpu_py_vertex_format.c b/source/blender/python/gpu/gpu_py_vertex_format.c index 67f612f8ba3..343cf06b20a 100644 --- a/source/blender/python/gpu/gpu_py_vertex_format.c +++ b/source/blender/python/gpu/gpu_py_vertex_format.c @@ -32,115 +32,31 @@ #include "gpu_py_vertex_format.h" /* own include */ -#ifdef __BIG_ENDIAN__ -/* big endian */ -# define MAKE_ID2(c, d) ((c) << 8 | (d)) -# define MAKE_ID3(a, b, c) ((int)(a) << 24 | (int)(b) << 16 | (c) << 8) -# define MAKE_ID4(a, b, c, d) ((int)(a) << 24 | (int)(b) << 16 | (c) << 8 | (d)) -#else -/* little endian */ -# define MAKE_ID2(c, d) ((d) << 8 | (c)) -# define MAKE_ID3(a, b, c) ((int)(c) << 16 | (b) << 8 | (a)) -# define MAKE_ID4(a, b, c, d) ((int)(d) << 24 | (int)(c) << 16 | (b) << 8 | (a)) -#endif - /* -------------------------------------------------------------------- */ /** \name Enum Conversion * * Use with PyArg_ParseTuple's "O&" formatting. * \{ */ -static int pygpu_vertformat_parse_component_type(const char *str, int length) -{ - if (length == 2) { - switch (*((ushort *)str)) { - case MAKE_ID2('I', '8'): - return GPU_COMP_I8; - case MAKE_ID2('U', '8'): - return GPU_COMP_U8; - default: - break; - } - } - else if (length == 3) { - switch (*((uint *)str)) { - case MAKE_ID3('I', '1', '6'): - return GPU_COMP_I16; - case MAKE_ID3('U', '1', '6'): - return GPU_COMP_U16; - case MAKE_ID3('I', '3', '2'): - return GPU_COMP_I32; - case MAKE_ID3('U', '3', '2'): - return GPU_COMP_U32; - case MAKE_ID3('F', '3', '2'): - return GPU_COMP_F32; - case MAKE_ID3('I', '1', '0'): - return GPU_COMP_I10; - default: - break; - } - } - return -1; -} - -static int pygpu_vertformat_parse_fetch_mode(const char *str, int length) -{ -#define MATCH_ID(id) \ - if (length == strlen(STRINGIFY(id))) { \ - if (STREQ(str, STRINGIFY(id))) { \ - return GPU_FETCH_##id; \ - } \ - } \ - ((void)0) - - MATCH_ID(FLOAT); - MATCH_ID(INT); - MATCH_ID(INT_TO_FLOAT_UNIT); - MATCH_ID(INT_TO_FLOAT); -#undef MATCH_ID - - return -1; -} - -static int pygpu_ParseVertCompType(PyObject *o, void *p) -{ - Py_ssize_t length; - const char *str = PyUnicode_AsUTF8AndSize(o, &length); - - if (str == NULL) { - PyErr_Format(PyExc_ValueError, "expected a string, got %s", Py_TYPE(o)->tp_name); - return 0; - } - - const int comp_type = pygpu_vertformat_parse_component_type(str, length); - if (comp_type == -1) { - PyErr_Format(PyExc_ValueError, "unknown component type: '%s", str); - return 0; - } - - *((GPUVertCompType *)p) = comp_type; - return 1; -} - -static int pygpu_ParseVertFetchMode(PyObject *o, void *p) -{ - Py_ssize_t length; - const char *str = PyUnicode_AsUTF8AndSize(o, &length); - - if (str == NULL) { - PyErr_Format(PyExc_ValueError, "expected a string, got %s", Py_TYPE(o)->tp_name); - return 0; - } - - const int fetch_mode = pygpu_vertformat_parse_fetch_mode(str, length); - if (fetch_mode == -1) { - PyErr_Format(PyExc_ValueError, "unknown type literal: '%s'", str); - return 0; - } +static struct PyC_StringEnumItems pygpu_vertcomptype_items[] = { + {GPU_COMP_I8, "I8"}, + {GPU_COMP_U8, "U8"}, + {GPU_COMP_I16, "I16"}, + {GPU_COMP_U16, "U16"}, + {GPU_COMP_I32, "I32"}, + {GPU_COMP_U32, "U32"}, + {GPU_COMP_F32, "F32"}, + {GPU_COMP_I10, "I10"}, + {0, NULL}, +}; - (*(GPUVertFetchMode *)p) = fetch_mode; - return 1; -} +static struct PyC_StringEnumItems pygpu_vertfetchmode_items[] = { + {GPU_FETCH_FLOAT, "FLOAT"}, + {GPU_FETCH_INT, "INT"}, + {GPU_FETCH_INT_TO_FLOAT_UNIT, "INT_TO_FLOAT_UNIT"}, + {GPU_FETCH_INT_TO_FLOAT, "INT_TO_FLOAT"}, + {0, NULL}, +}; /** \} */ @@ -181,12 +97,10 @@ PyDoc_STRVAR( " :type fetch_mode: `str`\n"); static PyObject *pygpu_vertformat_attr_add(BPyGPUVertFormat *self, PyObject *args, PyObject *kwds) { - struct { - const char *id; - GPUVertCompType comp_type; - uint len; - GPUVertFetchMode fetch_mode; - } params; + const char *id; + uint len; + struct PyC_StringEnum comp_type = {pygpu_vertcomptype_items, GPU_COMP_I8}; + struct PyC_StringEnum fetch_mode = {pygpu_vertfetchmode_items, GPU_FETCH_FLOAT}; if (self->fmt.attr_len == GPU_VERT_ATTR_MAX_LEN) { PyErr_SetString(PyExc_ValueError, "Maximum attr reached " STRINGIFY(GPU_VERT_ATTR_MAX_LEN)); @@ -198,17 +112,17 @@ static PyObject *pygpu_vertformat_attr_add(BPyGPUVertFormat *self, PyObject *arg if (!_PyArg_ParseTupleAndKeywordsFast(args, kwds, &_parser, - ¶ms.id, - pygpu_ParseVertCompType, - ¶ms.comp_type, - ¶ms.len, - pygpu_ParseVertFetchMode, - ¶ms.fetch_mode)) { + &id, + PyC_ParseStringEnum, + &comp_type, + &len, + PyC_ParseStringEnum, + &fetch_mode)) { return NULL; } uint attr_id = GPU_vertformat_attr_add( - &self->fmt, params.id, params.comp_type, params.len, params.fetch_mode); + &self->fmt, id, comp_type.value_found, len, fetch_mode.value_found); return PyLong_FromLong(attr_id); } |