2.5: UV Edit
[blender.git] / source / blender / makesrna / intern / rna_object_api.c
1 /**
2  * $Id$
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version. 
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
19  *
20  * The Original Code is Copyright (C) 2009 Blender Foundation.
21  * All rights reserved.
22  *
23  * 
24  * Contributor(s): Blender Foundation
25  *
26  * ***** END GPL LICENSE BLOCK *****
27  */
28
29 #include <stdlib.h>
30 #include <stdio.h>
31
32 #include "RNA_define.h"
33 #include "RNA_types.h"
34
35 #ifdef RNA_RUNTIME
36
37 #include "MEM_guardedalloc.h"
38
39 #include "BKE_customdata.h"
40 #include "BKE_DerivedMesh.h"
41
42 #include "DNA_mesh_types.h"
43 #include "DNA_scene_types.h"
44
45 /* copied from init_render_mesh (render code) */
46 Mesh *rna_Object_create_render_mesh(Object *ob, Scene *scene)
47 {
48         CustomDataMask mask = CD_MASK_BAREMESH|CD_MASK_MTFACE|CD_MASK_MCOL;
49         DerivedMesh *dm;
50         Mesh *me;
51         
52         /* TODO: other types */
53         if(ob->type != OB_MESH)
54                 return NULL;
55         
56         dm= mesh_create_derived_render(scene, ob, mask);
57
58         if(!dm)
59                 return NULL;
60
61         me= add_mesh("tmp_render_mesh");
62         me->id.us--; /* we don't assign it to anything */
63         DM_to_mesh(dm, me);
64         dm->release(dm);
65
66
67         {       /* update the material */
68                 short i, *totcol =give_totcolp(ob);
69
70                 /* free the current material list */
71                 if(me->mat)
72                         MEM_freeN((void *)me->mat);
73
74                 me->mat= (Material **)MEM_callocN(sizeof(void *)*(*totcol), "matarray");
75
76                 for(i=0; i<*totcol; i++) {
77                         Material *mat= give_current_material(ob, i+1);
78                         if(mat) {
79                                 me->mat[i]= mat;
80                                 mat->id.us++;
81                         }
82                 }
83         }
84
85         return me;
86 }
87
88 #else
89
90 void RNA_api_object(StructRNA *srna)
91 {
92         FunctionRNA *func;
93         PropertyRNA *prop;
94
95         func= RNA_def_function(srna, "create_render_mesh", "rna_Object_create_render_mesh");
96         RNA_def_function_ui_description(func, "Create a Mesh datablock with all modifiers applied.");
97         prop= RNA_def_pointer(func, "scene", "Scene", "", "");
98         RNA_def_property_flag(prop, PROP_REQUIRED);
99         prop= RNA_def_pointer(func, "mesh", "Mesh", "", "Mesh created from object, remove it if it is only used for export.");
100         RNA_def_function_return(func, prop);
101 }
102
103 #endif
104