forked from mia/Aegisub
Close the spell checker after all lines have been checked rather than only once there are no errors remaining. Closes #1442.
Originally committed to SVN as r6410.
This commit is contained in:
parent
3af57cdbcd
commit
04cc422391
2 changed files with 20 additions and 9 deletions
|
@ -56,6 +56,9 @@ DialogSpellChecker::DialogSpellChecker(agi::Context *context)
|
||||||
: wxDialog(context->parent, -1, _("Spell Checker"))
|
: wxDialog(context->parent, -1, _("Spell Checker"))
|
||||||
, context(context)
|
, context(context)
|
||||||
, spellchecker(SpellCheckerFactory::GetSpellChecker())
|
, spellchecker(SpellCheckerFactory::GetSpellChecker())
|
||||||
|
, start_line(0)
|
||||||
|
, active_line(0)
|
||||||
|
, has_looped(false)
|
||||||
{
|
{
|
||||||
SetIcon(BitmapToIcon(GETIMAGE(spellcheck_toolbutton_24)));
|
SetIcon(BitmapToIcon(GETIMAGE(spellcheck_toolbutton_24)));
|
||||||
|
|
||||||
|
@ -203,16 +206,21 @@ void DialogSpellChecker::OnClose(wxCommandEvent&) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DialogSpellChecker::FindNext() {
|
bool DialogSpellChecker::FindNext() {
|
||||||
AssDialogue *active_line = context->selectionController->GetActiveLine();
|
AssDialogue *real_active_line = context->selectionController->GetActiveLine();
|
||||||
|
// User has changed the active line; restart search from this position
|
||||||
|
if (real_active_line != active_line) {
|
||||||
|
active_line = real_active_line;
|
||||||
|
has_looped = false;
|
||||||
|
start_line = active_line;
|
||||||
|
}
|
||||||
|
|
||||||
int start_pos = context->editBox->GetReverseUnicodePosition(context->editBox->GetCurrentPos());
|
int start_pos = context->editBox->GetReverseUnicodePosition(context->editBox->GetCurrentPos());
|
||||||
int commit_id = -1;
|
int commit_id = -1;
|
||||||
|
|
||||||
if (CheckLine(active_line, start_pos, &commit_id))
|
if (CheckLine(active_line, start_pos, &commit_id))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
AssDialogue *start_line = active_line;
|
|
||||||
std::list<AssEntry*>::iterator it = find(context->ass->Line.begin(), context->ass->Line.end(), active_line);
|
std::list<AssEntry*>::iterator it = find(context->ass->Line.begin(), context->ass->Line.end(), active_line);
|
||||||
bool has_looped = false;
|
|
||||||
|
|
||||||
// Note that it is deliberate that the start line is checked twice, as if
|
// Note that it is deliberate that the start line is checked twice, as if
|
||||||
// the cursor is past the first misspelled word in the current line, that
|
// the cursor is past the first misspelled word in the current line, that
|
||||||
|
@ -298,4 +306,3 @@ void DialogSpellChecker::SetWord(wxString const& word) {
|
||||||
|
|
||||||
add_button->Enable(spellchecker->CanAddWord(word));
|
add_button->Enable(spellchecker->CanAddWord(word));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -68,6 +68,10 @@ class DialogSpellChecker : public wxDialog {
|
||||||
wxButton *add_button; ///< Add word to currently active dictionary
|
wxButton *add_button; ///< Add word to currently active dictionary
|
||||||
wxCheckBox *skip_comments; ///< Skip over commented lines
|
wxCheckBox *skip_comments; ///< Skip over commented lines
|
||||||
|
|
||||||
|
AssDialogue *start_line; ///< The first line checked
|
||||||
|
AssDialogue *active_line; ///< The most recently checked line
|
||||||
|
bool has_looped; ///< Has the search already looped from the end to beginning?
|
||||||
|
|
||||||
/// Find the next misspelled word and close the dialog if there are none
|
/// Find the next misspelled word and close the dialog if there are none
|
||||||
/// @return Are there any more misspelled words?
|
/// @return Are there any more misspelled words?
|
||||||
bool FindNext();
|
bool FindNext();
|
||||||
|
|
Loading…
Reference in a new issue