PyAPI: add intern strings
Avoid string conversion on each use.
This commit is contained in:
@@ -530,7 +530,8 @@ static bool python_script_exec(
|
||||
|
||||
if (py_dict) {
|
||||
#ifdef PYMODULE_CLEAR_WORKAROUND
|
||||
PyModuleObject *mmod = (PyModuleObject *)PyDict_GetItemString(PyThreadState_GET()->interp->modules, "__main__");
|
||||
PyModuleObject *mmod = (PyModuleObject *)PyDict_GetItem(
|
||||
PyThreadState_GET()->interp->modules, bpy_intern_str___main__);
|
||||
PyObject *dict_back = mmod->md_dict;
|
||||
/* freeing the module will clear the namespace,
|
||||
* gives problems running classes defined in this namespace being used later. */
|
||||
|
||||
@@ -34,21 +34,23 @@
|
||||
|
||||
#include "BLI_utildefines.h"
|
||||
|
||||
static PyObject *bpy_intern_str_arr[13];
|
||||
static PyObject *bpy_intern_str_arr[15];
|
||||
|
||||
PyObject *bpy_intern_str_register;
|
||||
PyObject *bpy_intern_str_unregister;
|
||||
PyObject *bpy_intern_str_bl_rna;
|
||||
PyObject *bpy_intern_str_bl_property;
|
||||
PyObject *bpy_intern_str_bpy_types;
|
||||
PyObject *bpy_intern_str_order;
|
||||
PyObject *bpy_intern_str_attr;
|
||||
PyObject *bpy_intern_str_self;
|
||||
PyObject *bpy_intern_str_frame;
|
||||
PyObject *bpy_intern_str___slots__;
|
||||
PyObject *bpy_intern_str___name__;
|
||||
PyObject *bpy_intern_str___doc__;
|
||||
PyObject *bpy_intern_str___main__;
|
||||
PyObject *bpy_intern_str___module__;
|
||||
PyObject *bpy_intern_str___name__;
|
||||
PyObject *bpy_intern_str___slots__;
|
||||
PyObject *bpy_intern_str_attr;
|
||||
PyObject *bpy_intern_str_bl_property;
|
||||
PyObject *bpy_intern_str_bl_rna;
|
||||
PyObject *bpy_intern_str_bpy_types;
|
||||
PyObject *bpy_intern_str_frame;
|
||||
PyObject *bpy_intern_str_order;
|
||||
PyObject *bpy_intern_str_properties;
|
||||
PyObject *bpy_intern_str_register;
|
||||
PyObject *bpy_intern_str_self;
|
||||
PyObject *bpy_intern_str_unregister;
|
||||
|
||||
void bpy_intern_string_init(void)
|
||||
{
|
||||
@@ -57,19 +59,21 @@ void bpy_intern_string_init(void)
|
||||
#define BPY_INTERN_STR(var, str) \
|
||||
{ var = bpy_intern_str_arr[i++] = PyUnicode_FromString(str); } (void)0
|
||||
|
||||
BPY_INTERN_STR(bpy_intern_str_register, "register");
|
||||
BPY_INTERN_STR(bpy_intern_str_unregister, "unregister");
|
||||
BPY_INTERN_STR(bpy_intern_str_bl_rna, "bl_rna");
|
||||
BPY_INTERN_STR(bpy_intern_str_bl_property, "bl_property");
|
||||
BPY_INTERN_STR(bpy_intern_str_bpy_types, "bpy.types");
|
||||
BPY_INTERN_STR(bpy_intern_str_order, "order");
|
||||
BPY_INTERN_STR(bpy_intern_str_attr, "attr");
|
||||
BPY_INTERN_STR(bpy_intern_str_self, "self");
|
||||
BPY_INTERN_STR(bpy_intern_str_frame, "frame");
|
||||
BPY_INTERN_STR(bpy_intern_str___slots__, "__slots__");
|
||||
BPY_INTERN_STR(bpy_intern_str___name__, "__name__");
|
||||
BPY_INTERN_STR(bpy_intern_str___doc__, "__doc__");
|
||||
BPY_INTERN_STR(bpy_intern_str___main__, "__main__");
|
||||
BPY_INTERN_STR(bpy_intern_str___module__, "__module__");
|
||||
BPY_INTERN_STR(bpy_intern_str___name__, "__name__");
|
||||
BPY_INTERN_STR(bpy_intern_str___slots__, "__slots__");
|
||||
BPY_INTERN_STR(bpy_intern_str_attr, "attr");
|
||||
BPY_INTERN_STR(bpy_intern_str_bl_property, "bl_property");
|
||||
BPY_INTERN_STR(bpy_intern_str_bl_rna, "bl_rna");
|
||||
BPY_INTERN_STR(bpy_intern_str_bpy_types, "bpy.types");
|
||||
BPY_INTERN_STR(bpy_intern_str_frame, "frame");
|
||||
BPY_INTERN_STR(bpy_intern_str_order, "order");
|
||||
BPY_INTERN_STR(bpy_intern_str_properties, "properties");
|
||||
BPY_INTERN_STR(bpy_intern_str_register, "register");
|
||||
BPY_INTERN_STR(bpy_intern_str_self, "self");
|
||||
BPY_INTERN_STR(bpy_intern_str_unregister, "unregister");
|
||||
|
||||
#undef BPY_INTERN_STR
|
||||
|
||||
|
||||
@@ -30,18 +30,20 @@
|
||||
void bpy_intern_string_init(void);
|
||||
void bpy_intern_string_exit(void);
|
||||
|
||||
extern PyObject *bpy_intern_str_register;
|
||||
extern PyObject *bpy_intern_str_unregister;
|
||||
extern PyObject *bpy_intern_str_bl_rna;
|
||||
extern PyObject *bpy_intern_str_bl_property;
|
||||
extern PyObject *bpy_intern_str_bpy_types;
|
||||
extern PyObject *bpy_intern_str_order;
|
||||
extern PyObject *bpy_intern_str_attr;
|
||||
extern PyObject *bpy_intern_str_self;
|
||||
extern PyObject *bpy_intern_str_frame;
|
||||
extern PyObject *bpy_intern_str___slots__;
|
||||
extern PyObject *bpy_intern_str___name__;
|
||||
extern PyObject *bpy_intern_str___doc__;
|
||||
extern PyObject *bpy_intern_str___main__;
|
||||
extern PyObject *bpy_intern_str___module__;
|
||||
extern PyObject *bpy_intern_str___name__;
|
||||
extern PyObject *bpy_intern_str___slots__;
|
||||
extern PyObject *bpy_intern_str_attr;
|
||||
extern PyObject *bpy_intern_str_bl_property;
|
||||
extern PyObject *bpy_intern_str_bl_rna;
|
||||
extern PyObject *bpy_intern_str_bpy_types;
|
||||
extern PyObject *bpy_intern_str_frame;
|
||||
extern PyObject *bpy_intern_str_order;
|
||||
extern PyObject *bpy_intern_str_properties;
|
||||
extern PyObject *bpy_intern_str_register;
|
||||
extern PyObject *bpy_intern_str_self;
|
||||
extern PyObject *bpy_intern_str_unregister;
|
||||
|
||||
#endif /* __BPY_INTERN_STRING_H__ */
|
||||
|
||||
@@ -1842,7 +1842,7 @@ static int pyrna_py_to_prop(
|
||||
(BPy_StructRNA_Check(value)) &&
|
||||
(RNA_struct_is_a(((BPy_StructRNA *)value)->ptr.type, &RNA_Operator)))
|
||||
{
|
||||
value = PyObject_GetAttrString(value, "properties");
|
||||
value = PyObject_GetAttr(value, bpy_intern_str_properties);
|
||||
value_new = value;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user