Cleanup: BKE_library: remove 'test' param of id_copy.
[blender.git] / source / blender / modifiers / intern / MOD_normal_edit.c
1 /*
2  * This program is free software; you can redistribute it and/or
3  * modify it under the terms of the GNU General Public License
4  * as published by the Free Software Foundation; either version 2
5  * of the License, or (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software  Foundation,
14  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
15  */
16
17 /** \file blender/modifiers/intern/MOD_normal_edit.c
18  *  \ingroup modifiers
19  */
20
21 #include <string.h>
22
23 #include "MEM_guardedalloc.h"
24
25 #include "DNA_object_types.h"
26 #include "DNA_meshdata_types.h"
27 #include "DNA_mesh_types.h"
28
29 #include "BLI_math.h"
30 #include "BLI_utildefines.h"
31 #include "BLI_bitmap.h"
32
33 #include "BKE_library.h"
34 #include "BKE_library_query.h"
35 #include "BKE_mesh.h"
36 #include "BKE_deform.h"
37
38 #include "DEG_depsgraph_query.h"
39
40 #include "MOD_util.h"
41
42
43 static void generate_vert_coordinates(
44         Mesh *mesh, Object *ob, Object *ob_center, const float offset[3],
45         const int num_verts, float (*r_cos)[3], float r_size[3])
46 {
47         float min_co[3], max_co[3];
48         float diff[3];
49         bool do_diff = false;
50
51         INIT_MINMAX(min_co, max_co);
52
53         MVert *mv = mesh->mvert;
54         for (int i = 0; i < mesh->totvert; i++, mv++) {
55                 copy_v3_v3(r_cos[i], mv->co);
56                 if (r_size != NULL && ob_center == NULL) {
57                         minmax_v3v3_v3(min_co, max_co, r_cos[i]);
58                 }
59         }
60
61         /* Get size (i.e. deformation of the spheroid generating normals), either from target object, or own geometry. */
62         if (r_size != NULL) {
63                 if (ob_center != NULL) {
64                         /* Not we are not interested in signs here - they are even troublesome actually, due to security clamping! */
65                         abs_v3_v3(r_size, ob_center->size);
66                 }
67                 else {
68                         /* Set size. */
69                         sub_v3_v3v3(r_size, max_co, min_co);
70                 }
71
72                 /* Error checks - we do not want one or more of our sizes to be null! */
73                 if (is_zero_v3(r_size)) {
74                         r_size[0] = r_size[1] = r_size[2] = 1.0f;
75                 }
76                 else {
77                         CLAMP_MIN(r_size[0], FLT_EPSILON);
78                         CLAMP_MIN(r_size[1], FLT_EPSILON);
79                         CLAMP_MIN(r_size[2], FLT_EPSILON);
80                 }
81         }
82
83         if (ob_center != NULL) {
84                 float inv_obmat[4][4];
85
86                 /* Translate our coordinates so that center of ob_center is at (0, 0, 0). */
87                 /* Get ob_center (world) coordinates in ob local coordinates.
88                  * No need to take into account ob_center's space here, see T44027. */
89                 invert_m4_m4(inv_obmat, ob->obmat);
90                 mul_v3_m4v3(diff, inv_obmat, ob_center->obmat[3]);
91                 negate_v3(diff);
92
93                 do_diff = true;
94         }
95         else if (offset != NULL && !is_zero_v3(offset)) {
96                 negate_v3_v3(diff, offset);
97
98                 do_diff = true;
99         }
100         /* Else, no need to change coordinates! */
101
102         if (do_diff) {
103                 int i = num_verts;
104                 while (i--) {
105                         add_v3_v3(r_cos[i], diff);
106                 }
107         }
108 }
109
110 /* Note this modifies nos_new in-place. */
111 static void mix_normals(
112         const float mix_factor, MDeformVert *dvert, const int defgrp_index, const bool use_invert_vgroup,
113         const float mix_limit, const short mix_mode,
114         const int num_verts, MLoop *mloop, float (*nos_old)[3], float (*nos_new)[3], const int num_loops)
115 {
116         /* Mix with org normals... */
117         float *facs = NULL, *wfac;
118         float (*no_new)[3], (*no_old)[3];
119         int i;
120
121         if (dvert) {
122                 facs = MEM_malloc_arrayN((size_t)num_loops, sizeof(*facs), __func__);
123                 BKE_defvert_extract_vgroup_to_loopweights(
124                             dvert, defgrp_index, num_verts, mloop, num_loops, facs, use_invert_vgroup);
125         }
126
127         for (i = num_loops, no_new = nos_new, no_old = nos_old, wfac = facs; i--; no_new++, no_old++, wfac++) {
128                 const float fac = facs ? *wfac * mix_factor : mix_factor;
129
130                 switch (mix_mode) {
131                         case MOD_NORMALEDIT_MIX_ADD:
132                                 add_v3_v3(*no_new, *no_old);
133                                 normalize_v3(*no_new);
134                                 break;
135                         case MOD_NORMALEDIT_MIX_SUB:
136                                 sub_v3_v3(*no_new, *no_old);
137                                 normalize_v3(*no_new);
138                                 break;
139                         case MOD_NORMALEDIT_MIX_MUL:
140                                 mul_v3_v3(*no_new, *no_old);
141                                 normalize_v3(*no_new);
142                                 break;
143                         case MOD_NORMALEDIT_MIX_COPY:
144                                 break;
145                 }
146
147                 interp_v3_v3v3_slerp_safe(
148                         *no_new, *no_old, *no_new,
149                         (mix_limit < (float)M_PI) ? min_ff(fac, mix_limit / angle_v3v3(*no_new, *no_old)) : fac);
150         }
151
152         MEM_SAFE_FREE(facs);
153 }
154
155 /* Check poly normals and new loop normals are compatible, otherwise flip polygons
156  * (and invert matching poly normals). */
157 static bool polygons_check_flip(
158         MLoop *mloop, float (*nos)[3], CustomData *ldata,
159         MPoly *mpoly, float (*polynors)[3], const int num_polys)
160 {
161         MPoly *mp;
162         MDisps *mdisp = CustomData_get_layer(ldata, CD_MDISPS);
163         int i;
164         bool flipped = false;
165
166         for (i = 0, mp = mpoly; i < num_polys; i++, mp++) {
167                 float norsum[3] = {0.0f};
168                 float (*no)[3];
169                 int j;
170
171                 for (j = 0, no = &nos[mp->loopstart]; j < mp->totloop; j++, no++) {
172                         add_v3_v3(norsum, *no);
173                 }
174
175                 if (!normalize_v3(norsum)) {
176                         continue;
177                 }
178
179                 /* If average of new loop normals is opposed to polygon normal, flip polygon. */
180                 if (dot_v3v3(polynors[i], norsum) < 0.0f) {
181                         BKE_mesh_polygon_flip_ex(mp, mloop, ldata, nos, mdisp, true);
182                         negate_v3(polynors[i]);
183                         flipped = true;
184                 }
185         }
186
187         return flipped;
188 }
189
190 static void normalEditModifier_do_radial(
191         NormalEditModifierData *enmd, const ModifierEvalContext *ctx,
192         Object *ob, Mesh *mesh,
193         short (*clnors)[2], float (*loopnors)[3], float (*polynors)[3],
194         const short mix_mode, const float mix_factor, const float mix_limit,
195         MDeformVert *dvert, const int defgrp_index, const bool use_invert_vgroup,
196         MVert *mvert, const int num_verts, MEdge *medge, const int num_edges,
197         MLoop *mloop, const int num_loops, MPoly *mpoly, const int num_polys)
198 {
199         Object *ob_target = DEG_get_evaluated_object(ctx->depsgraph, enmd->target);
200
201         const bool do_polynors_fix = (enmd->flag & MOD_NORMALEDIT_NO_POLYNORS_FIX) == 0;
202         int i;
203
204         float (*cos)[3] = MEM_malloc_arrayN((size_t)num_verts, sizeof(*cos), __func__);
205         float (*nos)[3] = MEM_malloc_arrayN((size_t)num_loops, sizeof(*nos), __func__);
206         float size[3];
207
208         BLI_bitmap *done_verts = BLI_BITMAP_NEW((size_t)num_verts, __func__);
209
210         generate_vert_coordinates(mesh, ob, ob_target, enmd->offset, num_verts, cos, size);
211
212         /**
213          * size gives us our spheroid coefficients ``(A, B, C)``.
214          * Then, we want to find out for each vert its (a, b, c) triple (proportional to (A, B, C) one).
215          *
216          * Ellipsoid basic equation: ``(x^2/a^2) + (y^2/b^2) + (z^2/c^2) = 1.``
217          * Since we want to find (a, b, c) matching this equation and proportional to (A, B, C), we can do:
218          * <pre>
219          *     m = B / A
220          *     n = C / A
221          * </pre>
222          *
223          * hence:
224          * <pre>
225          *     (x^2/a^2) + (y^2/b^2) + (z^2/c^2) = 1
226          *  -> b^2*c^2*x^2 + a^2*c^2*y^2 + a^2*b^2*z^2 = a^2*b^2*c^2
227          *     b = ma
228          *     c = na
229          *  -> m^2*a^2*n^2*a^2*x^2 + a^2*n^2*a^2*y^2 + a^2*m^2*a^2*z^2 = a^2*m^2*a^2*n^2*a^2
230          *  -> m^2*n^2*a^4*x^2 + n^2*a^4*y^2 + m^2*a^4*z^2 = m^2*n^2*a^6
231          *  -> a^2 = (m^2*n^2*x^2 + n^2y^2 + m^2z^2) / (m^2*n^2) = x^2 + (y^2 / m^2) + (z^2 / n^2)
232          *  -> b^2 = (m^2*n^2*x^2 + n^2y^2 + m^2z^2) / (n^2)     = (m^2 * x^2) + y^2 + (m^2 * z^2 / n^2)
233          *  -> c^2 = (m^2*n^2*x^2 + n^2y^2 + m^2z^2) / (m^2)     = (n^2 * x^2) + (n^2 * y^2 / m^2) + z^2
234          * </pre>
235          *
236          * All we have to do now is compute normal of the spheroid at that point:
237          * <pre>
238          *     n = (x / a^2, y / b^2, z / c^2)
239          * </pre>
240          * And we are done!
241          */
242         {
243                 const float a = size[0], b = size[1], c = size[2];
244                 const float m2 = (b * b) / (a * a);
245                 const float n2 = (c * c) / (a * a);
246
247                 MLoop *ml;
248                 float (*no)[3];
249
250                 /* We reuse cos to now store the ellipsoid-normal of the verts! */
251                 for (i = num_loops, ml = mloop, no = nos; i-- ; ml++, no++) {
252                         const int vidx = ml->v;
253                         float *co = cos[vidx];
254
255                         if (!BLI_BITMAP_TEST(done_verts, vidx)) {
256                                 const float x2 = co[0] * co[0];
257                                 const float y2 = co[1] * co[1];
258                                 const float z2 = co[2] * co[2];
259                                 const float a2 = x2 + (y2 / m2) + (z2 / n2);
260                                 const float b2 = (m2 * x2) + y2 + (m2 * z2 / n2);
261                                 const float c2 = (n2 * x2) + (n2 * y2 / m2) + z2;
262
263                                 co[0] /= a2;
264                                 co[1] /= b2;
265                                 co[2] /= c2;
266                                 normalize_v3(co);
267
268                                 BLI_BITMAP_ENABLE(done_verts, vidx);
269                         }
270                         copy_v3_v3(*no, co);
271                 }
272         }
273
274         if (loopnors) {
275                 mix_normals(mix_factor, dvert, defgrp_index, use_invert_vgroup,
276                             mix_limit, mix_mode, num_verts, mloop, loopnors, nos, num_loops);
277         }
278
279         if (do_polynors_fix && polygons_check_flip(mloop, nos, &mesh->ldata, mpoly, polynors, num_polys)) {
280                 /* XXX TODO is this still needed? */
281                 // mesh->dirty |= DM_DIRTY_TESS_CDLAYERS;
282                 /* We need to recompute vertex normals! */
283                 BKE_mesh_calc_normals(mesh);
284         }
285
286         BKE_mesh_normals_loop_custom_set(mvert, num_verts, medge, num_edges, mloop, nos, num_loops,
287                                          mpoly, (const float(*)[3])polynors, num_polys, clnors);
288
289         MEM_freeN(cos);
290         MEM_freeN(nos);
291         MEM_freeN(done_verts);
292 }
293
294 static void normalEditModifier_do_directional(
295         NormalEditModifierData *enmd, const ModifierEvalContext *ctx,
296         Object *ob, Mesh *mesh,
297         short (*clnors)[2], float (*loopnors)[3], float (*polynors)[3],
298         const short mix_mode, const float mix_factor, const float mix_limit,
299         MDeformVert *dvert, const int defgrp_index, const bool use_invert_vgroup,
300         MVert *mvert, const int num_verts, MEdge *medge, const int num_edges,
301         MLoop *mloop, const int num_loops, MPoly *mpoly, const int num_polys)
302 {
303         Object *ob_target = DEG_get_evaluated_object(ctx->depsgraph, enmd->target);
304
305         const bool do_polynors_fix = (enmd->flag & MOD_NORMALEDIT_NO_POLYNORS_FIX) == 0;
306         const bool use_parallel_normals = (enmd->flag & MOD_NORMALEDIT_USE_DIRECTION_PARALLEL) != 0;
307
308         float (*nos)[3] = MEM_malloc_arrayN((size_t)num_loops, sizeof(*nos), __func__);
309
310         float target_co[3];
311         int i;
312
313         /* Get target's center coordinates in ob local coordinates. */
314         float mat[4][4];
315
316         invert_m4_m4(mat, ob->obmat);
317         mul_m4_m4m4(mat, mat, ob_target->obmat);
318         copy_v3_v3(target_co, mat[3]);
319
320         if (use_parallel_normals) {
321                 float no[3];
322
323                 sub_v3_v3v3(no, target_co, enmd->offset);
324                 normalize_v3(no);
325
326                 for (i = num_loops; i--; ) {
327                         copy_v3_v3(nos[i], no);
328                 }
329         }
330         else {
331                 float (*cos)[3] = MEM_malloc_arrayN((size_t)num_verts, sizeof(*cos), __func__);
332                 generate_vert_coordinates(mesh, ob, ob_target, NULL, num_verts, cos, NULL);
333
334                 BLI_bitmap *done_verts = BLI_BITMAP_NEW((size_t)num_verts, __func__);
335                 MLoop *ml;
336                 float (*no)[3];
337
338                 /* We reuse cos to now store the 'to target' normal of the verts! */
339                 for (i = num_loops, no = nos, ml = mloop; i--; no++, ml++) {
340                         const int vidx = ml->v;
341                         float *co = cos[vidx];
342
343                         if (!BLI_BITMAP_TEST(done_verts, vidx)) {
344                                 sub_v3_v3v3(co, target_co, co);
345                                 normalize_v3(co);
346
347                                 BLI_BITMAP_ENABLE(done_verts, vidx);
348                         }
349
350                         copy_v3_v3(*no, co);
351                 }
352
353                 MEM_freeN(done_verts);
354                 MEM_freeN(cos);
355         }
356
357         if (loopnors) {
358                 mix_normals(mix_factor, dvert, defgrp_index, use_invert_vgroup,
359                             mix_limit, mix_mode, num_verts, mloop, loopnors, nos, num_loops);
360         }
361
362         if (do_polynors_fix && polygons_check_flip(mloop, nos, &mesh->ldata, mpoly, polynors, num_polys)) {
363                 mesh->runtime.cd_dirty_vert |= CD_MASK_NORMAL;
364         }
365
366         BKE_mesh_normals_loop_custom_set(mvert, num_verts, medge, num_edges, mloop, nos, num_loops,
367                                          mpoly, (const float(*)[3])polynors, num_polys, clnors);
368
369         MEM_freeN(nos);
370 }
371
372 static bool is_valid_target(NormalEditModifierData *enmd)
373 {
374         if (enmd->mode == MOD_NORMALEDIT_MODE_RADIAL) {
375                 return true;
376         }
377         else if ((enmd->mode == MOD_NORMALEDIT_MODE_DIRECTIONAL) && enmd->target) {
378                 return true;
379         }
380         modifier_setError((ModifierData *)enmd, "Invalid target settings");
381         return false;
382 }
383
384 static Mesh *normalEditModifier_do(
385         NormalEditModifierData *enmd, const ModifierEvalContext *ctx, Object *ob, Mesh *mesh)
386 {
387         const bool use_invert_vgroup = ((enmd->flag & MOD_NORMALEDIT_INVERT_VGROUP) != 0);
388         const bool use_current_clnors = !((enmd->mix_mode == MOD_NORMALEDIT_MIX_COPY) &&
389                                           (enmd->mix_factor == 1.0f) &&
390                                           (enmd->defgrp_name[0] == '\0') &&
391                                           (enmd->mix_limit == (float)M_PI));
392
393         /* Do not run that modifier at all if autosmooth is disabled! */
394         if (!is_valid_target(enmd) || mesh->totloop == 0) {
395                 return mesh;
396         }
397
398         /* XXX TODO ARG GRRR XYQWNMPRXTYY
399          * Once we fully switch to Mesh evaluation of modifiers, we can expect to get that flag from the COW copy.
400          * But for now, it is lost in the DM intermediate step, so we need to directly check orig object's data. */
401 #if 0
402         if (!(mesh->flag & ME_AUTOSMOOTH)) {
403 #else
404         if (!(((Mesh *)ob->data)->flag & ME_AUTOSMOOTH)) {
405 #endif
406                 modifier_setError((ModifierData *)enmd, "Enable 'Auto Smooth' option in mesh settings");
407                 return mesh;
408         }
409
410         Mesh *result;
411         if (mesh->medge == ((Mesh *)ob->data)->medge) {
412                 /* We need to duplicate data here, otherwise setting custom normals (which may also affect sharp edges) could
413                  * modify org mesh, see T43671. */
414                 BKE_id_copy_ex(
415                         NULL, &mesh->id, (ID **)&result,
416                         LIB_ID_CREATE_NO_MAIN |
417                         LIB_ID_CREATE_NO_USER_REFCOUNT |
418                         LIB_ID_CREATE_NO_DEG_TAG |
419                         LIB_ID_COPY_NO_PREVIEW);
420         }
421         else {
422                 result = mesh;
423         }
424
425         const int num_verts = result->totvert;
426         const int num_edges = result->totedge;
427         const int num_loops = result->totloop;
428         const int num_polys = result->totpoly;
429         MVert *mvert = result->mvert;
430         MEdge *medge = result->medge;
431         MLoop *mloop = result->mloop;
432         MPoly *mpoly = result->mpoly;
433
434         int defgrp_index;
435         MDeformVert *dvert;
436
437         float (*loopnors)[3] = NULL;
438         short (*clnors)[2] = NULL;
439
440         float (*polynors)[3];
441
442         CustomData *ldata = &result->ldata;
443         if (CustomData_has_layer(ldata, CD_NORMAL)) {
444                 loopnors = CustomData_get_layer(ldata, CD_NORMAL);
445         }
446         else {
447                 loopnors = CustomData_add_layer(ldata, CD_NORMAL, CD_CALLOC, NULL, num_loops);
448         }
449
450         /* Compute poly (always needed) and vert normals. */
451         CustomData *pdata = &result->pdata;
452         polynors = CustomData_get_layer(pdata, CD_NORMAL);
453         if (!polynors) {
454                 polynors = CustomData_add_layer(pdata, CD_NORMAL, CD_CALLOC, NULL, num_polys);
455         }
456         BKE_mesh_calc_normals_poly(mvert, NULL, num_verts, mloop, mpoly, num_loops, num_polys, polynors,
457                                    (result->runtime.cd_dirty_vert & CD_MASK_NORMAL) ? false : true);
458
459         result->runtime.cd_dirty_vert &= ~CD_MASK_NORMAL;
460
461         if (use_current_clnors) {
462                 clnors = CustomData_duplicate_referenced_layer(ldata, CD_CUSTOMLOOPNORMAL, num_loops);
463
464                 BKE_mesh_normals_loop_split(mvert, num_verts, medge, num_edges, mloop, loopnors, num_loops,
465                                             mpoly, (const float (*)[3])polynors, num_polys,
466                                             true, result->smoothresh,
467                                             NULL, clnors, NULL);
468         }
469
470         if (!clnors) {
471                 clnors = CustomData_add_layer(ldata, CD_CUSTOMLOOPNORMAL, CD_CALLOC, NULL, num_loops);
472         }
473
474         MOD_get_vgroup(ob, result, enmd->defgrp_name, &dvert, &defgrp_index);
475
476         if (enmd->mode == MOD_NORMALEDIT_MODE_RADIAL) {
477                 normalEditModifier_do_radial(
478                             enmd, ctx, ob, result, clnors, loopnors, polynors,
479                             enmd->mix_mode, enmd->mix_factor, enmd->mix_limit, dvert, defgrp_index, use_invert_vgroup,
480                             mvert, num_verts, medge, num_edges, mloop, num_loops, mpoly, num_polys);
481         }
482         else if (enmd->mode == MOD_NORMALEDIT_MODE_DIRECTIONAL) {
483                 normalEditModifier_do_directional(
484                             enmd, ctx, ob, result, clnors, loopnors, polynors,
485                             enmd->mix_mode, enmd->mix_factor, enmd->mix_limit, dvert, defgrp_index, use_invert_vgroup,
486                             mvert, num_verts, medge, num_edges, mloop, num_loops, mpoly, num_polys);
487         }
488
489         return result;
490 }
491
492 static void initData(ModifierData *md)
493 {
494         NormalEditModifierData *enmd = (NormalEditModifierData *)md;
495
496         enmd->mode = MOD_NORMALEDIT_MODE_RADIAL;
497
498         enmd->mix_mode = MOD_NORMALEDIT_MIX_COPY;
499         enmd->mix_factor = 1.0f;
500         enmd->mix_limit = M_PI;
501 }
502
503 static CustomDataMask requiredDataMask(Object *UNUSED(ob), ModifierData *md)
504 {
505         NormalEditModifierData *enmd = (NormalEditModifierData *)md;
506         CustomDataMask dataMask = CD_MASK_CUSTOMLOOPNORMAL;
507
508         /* Ask for vertexgroups if we need them. */
509         if (enmd->defgrp_name[0]) {
510                 dataMask |= (CD_MASK_MDEFORMVERT);
511         }
512
513         return dataMask;
514 }
515
516 static bool dependsOnNormals(ModifierData *UNUSED(md))
517 {
518         return true;
519 }
520
521 static void foreachObjectLink(ModifierData *md, Object *ob, ObjectWalkFunc walk, void *userData)
522 {
523         NormalEditModifierData *enmd = (NormalEditModifierData *) md;
524
525         walk(userData, ob, &enmd->target, IDWALK_CB_NOP);
526 }
527
528 static bool isDisabled(const struct Scene *UNUSED(scene), ModifierData *md, bool UNUSED(useRenderParams))
529 {
530         NormalEditModifierData *enmd = (NormalEditModifierData *)md;
531
532         return !is_valid_target(enmd);
533 }
534
535 static void updateDepsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
536 {
537         NormalEditModifierData *enmd = (NormalEditModifierData *) md;
538         if (enmd->target) {
539                 DEG_add_object_relation(ctx->node, enmd->target, DEG_OB_COMP_TRANSFORM, "NormalEdit Modifier");
540                 DEG_add_object_relation(ctx->node, ctx->object, DEG_OB_COMP_TRANSFORM, "NormalEdit Modifier");
541         }
542 }
543
544 static Mesh *applyModifier(ModifierData *md, const ModifierEvalContext *ctx, Mesh *mesh)
545 {
546         return normalEditModifier_do((NormalEditModifierData *)md, ctx, ctx->object, mesh);
547 }
548
549 ModifierTypeInfo modifierType_NormalEdit = {
550         /* name */              "Set Split Normals",
551         /* structName */        "NormalEditModifierData",
552         /* structSize */        sizeof(NormalEditModifierData),
553         /* type */              eModifierTypeType_Constructive,
554         /* flags */             eModifierTypeFlag_AcceptsMesh |
555                                 eModifierTypeFlag_SupportsMapping |
556                                 eModifierTypeFlag_SupportsEditmode |
557                                 eModifierTypeFlag_EnableInEditmode,
558
559         /* copyData */          modifier_copyData_generic,
560
561         /* deformVerts_DM */    NULL,
562         /* deformMatrices_DM */ NULL,
563         /* deformVertsEM_DM */  NULL,
564         /* deformMatricesEM_DM*/NULL,
565         /* applyModifier_DM */  NULL,
566
567         /* deformVerts */       NULL,
568         /* deformMatrices */    NULL,
569         /* deformVertsEM */     NULL,
570         /* deformMatricesEM */  NULL,
571         /* applyModifier */     applyModifier,
572
573         /* initData */          initData,
574         /* requiredDataMask */  requiredDataMask,
575         /* freeData */          NULL,
576         /* isDisabled */        isDisabled,
577         /* updateDepsgraph */   updateDepsgraph,
578         /* dependsOnTime */     NULL,
579         /* dependsOnNormals */  dependsOnNormals,
580         /* foreachObjectLink */ foreachObjectLink,
581         /* foreachIDLink */     NULL,
582         /* foreachTexLink */    NULL,
583 };