remove unused includes
[blender.git] / source / blender / python / intern / bpy_operator_wrap.c
1
2 /**
3  * $Id$
4  *
5  * ***** BEGIN GPL LICENSE BLOCK *****
6  *
7  * This program is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License
9  * as published by the Free Software Foundation; either version 2
10  * of the License, or (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software Foundation,
19  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20  *
21  * Contributor(s): Campbell Barton
22  *
23  * ***** END GPL LICENSE BLOCK *****
24  */
25
26 #include "bpy_operator_wrap.h"
27 #include "WM_api.h"
28 #include "WM_types.h"
29
30 #include "RNA_define.h"
31
32 #include "bpy_rna.h"
33
34 static void operator_properties_init(wmOperatorType *ot)
35 {
36         PyObject *py_class = ot->ext.data;
37         PyObject *item= ((PyTypeObject*)py_class)->tp_dict; /* getattr(..., "__dict__") returns a proxy */
38
39         RNA_struct_blender_type_set(ot->ext.srna, ot);
40
41         if(item) {
42                 /* only call this so pyrna_deferred_register_props gives a useful error
43                  * WM_operatortype_append_ptr will call RNA_def_struct_identifier
44                  * later */
45                 RNA_def_struct_identifier(ot->srna, ot->idname);
46
47                 if(pyrna_deferred_register_props(ot->srna, item) != 0) {
48                         PyErr_Print(); /* failed to register operator props */
49                         PyErr_Clear();
50                 }
51         }
52         else {
53                 PyErr_Clear();
54         }
55 }
56
57 void operator_wrapper(wmOperatorType *ot, void *userdata)
58 {
59         /* take care not to overwrite anything set in
60          * WM_operatortype_append_ptr before opfunc() is called */
61         StructRNA *srna = ot->srna;
62         *ot= *((wmOperatorType *)userdata);
63         ot->srna= srna; /* restore */
64
65         operator_properties_init(ot);
66
67         {       /* XXX - not nice, set the first enum as searchable, should have a way for python to set */
68                 PointerRNA ptr;
69                 PropertyRNA *prop;
70
71                 RNA_pointer_create(NULL, ot->srna, NULL, &ptr);
72                 prop = RNA_struct_find_property(&ptr, "type");
73                 if(prop)
74                         ot->prop= prop;
75         }
76 }
77
78 void macro_wrapper(wmOperatorType *ot, void *userdata)
79 {
80         wmOperatorType *data = (wmOperatorType *)userdata;
81
82         /* only copy a couple of things, the rest is set by the macro registration */
83         ot->name = data->name;
84         ot->idname = data->idname;
85         ot->description = data->description;
86         ot->flag |= data->flag; /* append flags to the one set by registration */
87         ot->pyop_poll = data->pyop_poll;
88         ot->ui = data->ui;
89         ot->ext = data->ext;
90
91         operator_properties_init(ot);
92 }
93
94 PyObject *PYOP_wrap_macro_define(PyObject *self, PyObject *args)
95 {
96         wmOperatorType *ot;
97         wmOperatorTypeMacro *otmacro;
98         PyObject *macro;
99         PointerRNA ptr_otmacro;
100         StructRNA *srna;
101
102         char *opname;
103         const char *macroname;
104
105         if (!PyArg_ParseTuple(args, "Os:_bpy.ops.macro_define", &macro, &opname))
106                 return NULL;
107
108         if (WM_operatortype_exists(opname) == NULL) {
109                 PyErr_Format(PyExc_ValueError, "Macro Define: '%s' is not a valid operator id", opname);
110                 return NULL;
111         }
112
113         /* identifiers */
114         srna= srna_from_self(macro);
115         macroname = RNA_struct_identifier(srna);
116
117         ot = WM_operatortype_exists(macroname);
118
119         if (!ot) {
120                 PyErr_Format(PyExc_ValueError, "Macro Define: '%s' is not a valid macro or hasn't been registered yet", macroname);
121                 return NULL;
122         }
123
124         otmacro = WM_operatortype_macro_define(ot, opname);
125
126         RNA_pointer_create(NULL, &RNA_OperatorTypeMacro, otmacro, &ptr_otmacro);
127
128         return pyrna_struct_CreatePyObject(&ptr_otmacro);
129 }
130