Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2011-03-31 15:21:21 +0400
committerCampbell Barton <ideasman42@gmail.com>2011-03-31 15:21:21 +0400
commitc7183d2622a0cba5e07653daa4a5aca9ad9ed9cc (patch)
tree9c59cb1fef580eedefaf22d15fa2b1be26c00bb8 /source/blender/blenloader
parent75cd392a570ded2c8b1e2abf1d98383aaab706a5 (diff)
library linked modifiers were not having their ID linked expanded properly.
was missing array cap ends, wave map object and shrinkwrap objects. use modifiers_foreachIDLink() rather then having to list all modifiers ID's in this function. also add foreachIDLink() for smoke domain. This fixes a bug where a linked object has as a modifier using an indirectly linked object for the missing cases mentioned above.
Diffstat (limited to 'source/blender/blenloader')
-rw-r--r--source/blender/blenloader/intern/readfile.c58
1 files changed, 16 insertions, 42 deletions
diff --git a/source/blender/blenloader/intern/readfile.c b/source/blender/blenloader/intern/readfile.c
index a304084c7b2..e8fa56c4b01 100644
--- a/source/blender/blenloader/intern/readfile.c
+++ b/source/blender/blenloader/intern/readfile.c
@@ -12301,50 +12301,19 @@ static void expand_armature(FileData *fd, Main *mainvar, bArmature *arm)
}
}
-static void expand_modifier(FileData *fd, Main *mainvar, ModifierData *md)
+static void expand_object_expandModifiers(void *userData, Object *UNUSED(ob),
+ ID **idpoin)
{
- if (md->type==eModifierType_Lattice) {
- LatticeModifierData *lmd = (LatticeModifierData*) md;
-
- expand_doit(fd, mainvar, lmd->object);
- }
- else if (md->type==eModifierType_Curve) {
- CurveModifierData *cmd = (CurveModifierData*) md;
-
- expand_doit(fd, mainvar, cmd->object);
- }
- else if (md->type==eModifierType_Array) {
- ArrayModifierData *amd = (ArrayModifierData*) md;
-
- expand_doit(fd, mainvar, amd->curve_ob);
- expand_doit(fd, mainvar, amd->offset_ob);
- }
- else if (md->type==eModifierType_Mirror) {
- MirrorModifierData *mmd = (MirrorModifierData*) md;
-
- expand_doit(fd, mainvar, mmd->mirror_ob);
- }
- else if (md->type==eModifierType_Displace) {
- DisplaceModifierData *dmd = (DisplaceModifierData*) md;
-
- expand_doit(fd, mainvar, dmd->map_object);
- expand_doit(fd, mainvar, dmd->texture);
- }
- else if (md->type==eModifierType_Smoke) {
- SmokeModifierData *smd = (SmokeModifierData*) md;
-
- if(smd->type==MOD_SMOKE_TYPE_DOMAIN && smd->domain)
- {
- expand_doit(fd, mainvar, smd->domain->coll_group);
- expand_doit(fd, mainvar, smd->domain->fluid_group);
- expand_doit(fd, mainvar, smd->domain->eff_group);
- }
- }
+ struct { FileData *fd; Main *mainvar; } *data= userData;
+
+ FileData *fd= data->fd;
+ Main *mainvar= data->mainvar;
+
+ expand_doit(fd, mainvar, *idpoin);
}
static void expand_object(FileData *fd, Main *mainvar, Object *ob)
{
- ModifierData *md;
ParticleSystem *psys;
bSensor *sens;
bController *cont;
@@ -12354,9 +12323,14 @@ static void expand_object(FileData *fd, Main *mainvar, Object *ob)
int a;
expand_doit(fd, mainvar, ob->data);
-
- for (md=ob->modifiers.first; md; md=md->next) {
- expand_modifier(fd, mainvar, md);
+
+ /* expand_object_expandModifier() */
+ if(ob->modifiers.first) {
+ struct { FileData *fd; Main *mainvar; } data;
+ data.fd= fd;
+ data.mainvar= mainvar;
+
+ modifiers_foreachIDLink(ob, expand_object_expandModifiers, (void *)&data);
}
expand_pose(fd, mainvar, ob->pose);