Use remove_and_dispose_if where applicable

This commit is contained in:
Thomas Goyne 2012-11-28 08:17:59 -08:00
parent 6ab8345148
commit 174a992974
2 changed files with 11 additions and 23 deletions

View File

@ -517,12 +517,9 @@ static void delete_lines(agi::Context *c, wxString const& commit_message) {
} }
// Delete selected lines // Delete selected lines
for (entryIter it = c->ass->Line.begin(); it != c->ass->Line.end(); ) { c->ass->Line.remove_and_dispose_if([&sel](AssEntry const& e) {
if (sel.count(static_cast<AssDialogue*>(&*it))) return sel.count(const_cast<AssDialogue *>(static_cast<const AssDialogue*>(&e)));
delete &*it++; }, [](AssEntry *e) { delete e; });
else
++it;
}
// If we didn't get a new active line then we just deleted all the dialogue // If we didn't get a new active line then we just deleted all the dialogue
// lines, so make a new one // lines, so make a new one

View File

@ -182,24 +182,16 @@ void SubtitleFormat::ConvertNewlines(AssFile &file, wxString const& newline, boo
} }
void SubtitleFormat::StripComments(AssFile &file) { void SubtitleFormat::StripComments(AssFile &file) {
for (entryIter it = file.Line.begin(); it != file.Line.end(); ) { file.Line.remove_and_dispose_if([](AssEntry const& e) {
AssDialogue *diag = dynamic_cast<AssDialogue*>(&*it); const AssDialogue *diag = dynamic_cast<const AssDialogue*>(&e);
if (!diag || (!diag->Comment && diag->Text.size())) return diag && (diag->Comment || !diag->Text);
++it; }, [](AssEntry *e) { delete e; });
else {
delete &*it++;
}
}
} }
void SubtitleFormat::StripNonDialogue(AssFile &file) { void SubtitleFormat::StripNonDialogue(AssFile &file) {
for (entryIter it = file.Line.begin(); it != file.Line.end(); ) { file.Line.remove_and_dispose_if([](AssEntry const& e) {
if (dynamic_cast<AssDialogue*>(&*it)) return e.Group() != ENTRY_DIALOGUE;
++it; }, [](AssEntry *e) { delete e; });
else {
delete &*it++;
}
}
} }
static bool dialog_start_lt(AssEntry &pos, AssDialogue *to_insert) { static bool dialog_start_lt(AssEntry &pos, AssDialogue *to_insert) {
@ -318,8 +310,7 @@ void SubtitleFormat::LoadFormats() {
} }
void SubtitleFormat::DestroyFormats() { void SubtitleFormat::DestroyFormats() {
for (auto it = formats.begin(); it != formats.end(); ) delete_clear(formats);
delete *it++;
} }
template<class Cont, class Pred> template<class Cont, class Pred>