Merge branch 'master' into blender2.8
[blender.git] / source / blender / makesrna / intern / rna_curve_api.c
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2009 Blender Foundation.
19  * All rights reserved.
20  *
21  *
22  * Contributor(s): Blender Foundation
23  *
24  * ***** END GPL LICENSE BLOCK *****
25  */
26
27 /** \file blender/makesrna/intern/rna_curve_api.c
28  *  \ingroup RNA
29  */
30
31
32 #include <stdlib.h>
33 #include <stdio.h>
34
35 #include "RNA_define.h"
36
37 #include "BLI_sys_types.h"
38
39 #include "BLI_utildefines.h"
40
41 #include "BKE_curve.h"
42
43 #include "rna_internal.h"  /* own include */
44
45 #ifdef RNA_RUNTIME
46 static void rna_Curve_transform(Curve *cu, float *mat, bool shape_keys)
47 {
48         BKE_curve_transform(cu, (float (*)[4])mat, shape_keys, true);
49
50         DEG_id_tag_update(&cu->id, 0);
51 }
52
53 static void rna_Curve_update_gpu_tag(Curve *cu)
54 {
55         BKE_curve_batch_cache_dirty_tag(cu, BKE_CURVE_BATCH_DIRTY_ALL);
56 }
57
58 static float rna_Nurb_calc_length(Nurb *nu, int resolution_u)
59 {
60         return BKE_nurb_calc_length(nu, resolution_u);
61 }
62
63 #else
64
65 void RNA_api_curve(StructRNA *srna)
66 {
67         FunctionRNA *func;
68         PropertyRNA *parm;
69
70         func = RNA_def_function(srna, "transform", "rna_Curve_transform");
71         RNA_def_function_ui_description(func, "Transform curve by a matrix");
72         parm = RNA_def_float_matrix(func, "matrix", 4, 4, NULL, 0.0f, 0.0f, "", "Matrix", 0.0f, 0.0f);
73         RNA_def_parameter_flags(parm, 0, PARM_REQUIRED);
74         RNA_def_boolean(func, "shape_keys", 0, "", "Transform Shape Keys");
75
76         func = RNA_def_function(srna, "validate_material_indices", "BKE_curve_material_index_validate");
77         RNA_def_function_ui_description(func, "Validate material indices of splines or letters, return True when the curve "
78                                         "has had invalid indices corrected (to default 0)");
79         parm = RNA_def_boolean(func, "result", 0, "Result", "");
80         RNA_def_function_return(func, parm);
81
82         RNA_def_function(srna, "update_gpu_tag", "rna_Curve_update_gpu_tag");
83 }
84
85 void RNA_api_curve_nurb(StructRNA *srna)
86 {
87         FunctionRNA *func;
88         PropertyRNA *parm;
89
90         func = RNA_def_function(srna, "calc_length", "rna_Nurb_calc_length");
91         RNA_def_function_ui_description(func, "Calculate spline length");
92         RNA_def_int(
93                 func, "resolution", 0, 0, 1024, "Resolution",
94                 "Spline resolution to be used, 0 defaults to the resolution_u", 0, 64);
95         parm = RNA_def_float_distance(
96                 func, "length", 0.0f, 0.0f, FLT_MAX, "Length",
97                 "Length of the polygonaly approximated spline", 0.0f, FLT_MAX);
98         RNA_def_function_return(func, parm);
99 }
100
101 #endif