Bugfix #5022
If you rename a Constraint, the used Constraint Channels (Ipo curves) were not renamed as well, making animations not work anymore. Now renaming works up to this level: - own object constraints - own object Action constraints This is identical to Bone renaming. Note that other actions (like in NLA) are not corrected for renaming. Have to look at ways to provide that once.
This commit is contained in:
@@ -817,3 +817,66 @@ void ob_clear_constraints(void)
|
||||
|
||||
}
|
||||
|
||||
/* con already has the new name */
|
||||
void rename_constraint(Object *ob, bConstraint *con, char *oldname)
|
||||
{
|
||||
bConstraint *tcon;
|
||||
bConstraintChannel *conchan;
|
||||
ListBase *conlist= NULL;
|
||||
int from_object= 0;
|
||||
char *channame;
|
||||
|
||||
/* get context by searching for con (primitive...) */
|
||||
for(tcon= ob->constraints.first; tcon; tcon= tcon->next)
|
||||
if(tcon==con)
|
||||
break;
|
||||
|
||||
if(tcon) {
|
||||
conlist= &ob->constraints;
|
||||
channame= "Object";
|
||||
from_object= 1;
|
||||
}
|
||||
else if(ob->pose) {
|
||||
bPoseChannel *pchan;
|
||||
|
||||
for(pchan= ob->pose->chanbase.first; pchan; pchan= pchan->next) {
|
||||
for(tcon= pchan->constraints.first; tcon; tcon= tcon->next) {
|
||||
if(tcon==con)
|
||||
break;
|
||||
}
|
||||
if(tcon)
|
||||
break;
|
||||
}
|
||||
if(tcon) {
|
||||
conlist= &pchan->constraints;
|
||||
channame= pchan->name;
|
||||
}
|
||||
}
|
||||
|
||||
if(conlist==NULL) {
|
||||
printf("rename constraint failed\n"); /* should not happen in UI */
|
||||
return;
|
||||
}
|
||||
|
||||
/* first make sure it's a unique name within context */
|
||||
unique_constraint_name (con, conlist);
|
||||
|
||||
/* own channels */
|
||||
if(from_object) {
|
||||
for(conchan= ob->constraintChannels.first; conchan; conchan= conchan->next) {
|
||||
if( strcmp(oldname, conchan->name)==0 )
|
||||
BLI_strncpy(conchan->name, con->name, sizeof(conchan->name));
|
||||
}
|
||||
}
|
||||
/* own action */
|
||||
if(ob->action) {
|
||||
bActionChannel *achan= get_action_channel(ob->action, channame);
|
||||
if(achan) {
|
||||
conchan= get_constraint_channel(&achan->constraintChannels, oldname);
|
||||
if(conchan)
|
||||
BLI_strncpy(conchan->name, con->name, sizeof(conchan->name));
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user