forked from mia/Aegisub
Check the right substrings in the spellchecker dialog. Closes #1560.
This commit is contained in:
parent
72ae116196
commit
4e72fff1d9
1 changed files with 18 additions and 14 deletions
|
@ -21,15 +21,6 @@
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
#include <wx/checkbox.h>
|
|
||||||
#include <wx/combobox.h>
|
|
||||||
#include <wx/intl.h>
|
|
||||||
#include <wx/listbox.h>
|
|
||||||
#include <wx/msgdlg.h>
|
|
||||||
#include <wx/sizer.h>
|
|
||||||
#include <wx/stattext.h>
|
|
||||||
#include <wx/textctrl.h>
|
|
||||||
|
|
||||||
#include "dialog_spellchecker.h"
|
#include "dialog_spellchecker.h"
|
||||||
|
|
||||||
#include "ass_dialogue.h"
|
#include "ass_dialogue.h"
|
||||||
|
@ -49,6 +40,15 @@
|
||||||
#include <libaegisub/exception.h>
|
#include <libaegisub/exception.h>
|
||||||
#include <libaegisub/spellchecker.h>
|
#include <libaegisub/spellchecker.h>
|
||||||
|
|
||||||
|
#include <wx/checkbox.h>
|
||||||
|
#include <wx/combobox.h>
|
||||||
|
#include <wx/intl.h>
|
||||||
|
#include <wx/listbox.h>
|
||||||
|
#include <wx/msgdlg.h>
|
||||||
|
#include <wx/sizer.h>
|
||||||
|
#include <wx/stattext.h>
|
||||||
|
#include <wx/textctrl.h>
|
||||||
|
|
||||||
DialogSpellChecker::DialogSpellChecker(agi::Context *context)
|
DialogSpellChecker::DialogSpellChecker(agi::Context *context)
|
||||||
: wxDialog(context->parent, -1, _("Spell Checker"))
|
: wxDialog(context->parent, -1, _("Spell Checker"))
|
||||||
, context(context)
|
, context(context)
|
||||||
|
@ -245,14 +245,18 @@ bool DialogSpellChecker::CheckLine(AssDialogue *active_line, int start_pos, int
|
||||||
|
|
||||||
word_start = 0;
|
word_start = 0;
|
||||||
for (auto const& tok : tokens) {
|
for (auto const& tok : tokens) {
|
||||||
word_start += tok.length;
|
if (tok.type != agi::ass::DialogueTokenType::WORD || word_start < start_pos) {
|
||||||
if (tok.type != agi::ass::DialogueTokenType::WORD) continue;
|
word_start += tok.length;
|
||||||
if (word_start < start_pos) continue;
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
word_len = tok.length;
|
word_len = tok.length;
|
||||||
std::string word = text.substr(word_start, word_len);
|
std::string word = text.substr(word_start, word_len);
|
||||||
|
|
||||||
if (auto_ignore.count(word) || spellchecker->CheckWord(word)) continue;
|
if (auto_ignore.count(word) || spellchecker->CheckWord(word)) {
|
||||||
|
word_start += tok.length;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
auto auto_rep = auto_replace.find(word);
|
auto auto_rep = auto_replace.find(word);
|
||||||
if (auto_rep == auto_replace.end()) {
|
if (auto_rep == auto_replace.end()) {
|
||||||
|
@ -272,7 +276,7 @@ bool DialogSpellChecker::CheckLine(AssDialogue *active_line, int start_pos, int
|
||||||
text.replace(word_start, word_len, auto_rep->second);
|
text.replace(word_start, word_len, auto_rep->second);
|
||||||
active_line->Text = from_wx(text);
|
active_line->Text = from_wx(text);
|
||||||
*commit_id = context->ass->Commit(_("spell check replace"), AssFile::COMMIT_DIAG_TEXT, *commit_id);
|
*commit_id = context->ass->Commit(_("spell check replace"), AssFile::COMMIT_DIAG_TEXT, *commit_id);
|
||||||
word_start += auto_rep->second.size() - auto_rep->first.size();
|
word_start += auto_rep->second.size();
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue