|
|
@ -228,9 +228,8 @@ plAGChannel * plAGModifier::MergeChannel(plAGApplicator *app, |
|
|
|
hsBool plAGModifier::DetachChannel(plAGChannel * channel) |
|
|
|
hsBool plAGModifier::DetachChannel(plAGChannel * channel) |
|
|
|
{ |
|
|
|
{ |
|
|
|
plAppTable::iterator i = fApps.begin(); |
|
|
|
plAppTable::iterator i = fApps.begin(); |
|
|
|
hsBool done = false; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for( ; i != fApps.end(); i++) |
|
|
|
while( i != fApps.end() ) |
|
|
|
{ |
|
|
|
{ |
|
|
|
plAGApplicator *app = *i; |
|
|
|
plAGApplicator *app = *i; |
|
|
|
plAGChannel *existingChannel = app->GetChannel(); |
|
|
|
plAGChannel *existingChannel = app->GetChannel(); |
|
|
@ -243,17 +242,16 @@ hsBool plAGModifier::DetachChannel(plAGChannel * channel) |
|
|
|
app->SetChannel(replacementChannel); |
|
|
|
app->SetChannel(replacementChannel); |
|
|
|
if( ! replacementChannel && app->AutoDelete()) |
|
|
|
if( ! replacementChannel && app->AutoDelete()) |
|
|
|
{ |
|
|
|
{ |
|
|
|
plAppTable::iterator old = i; |
|
|
|
// Don't need to adjust the iterator since we're about to exit the loop
|
|
|
|
i--; |
|
|
|
fApps.erase(i); |
|
|
|
fApps.erase(old); |
|
|
|
|
|
|
|
delete app; |
|
|
|
delete app; |
|
|
|
} |
|
|
|
} |
|
|
|
done = true; |
|
|
|
return true; |
|
|
|
break; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
++i; |
|
|
|
} |
|
|
|
} |
|
|
|
return done; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// READ
|
|
|
|
// READ
|
|
|
|