Use SubsTextEditCtrl in the translation assistant

This gives spellchecking and thesaurus support for the translation (and
syntax highlighting, but that usually won't be useful).

Originally committed to SVN as r6578.
This commit is contained in:
Thomas Goyne 2012-03-12 23:34:45 +00:00
parent de9cc755d2
commit 7e5b241260
4 changed files with 29 additions and 38 deletions

View file

@ -36,7 +36,7 @@
#include "help_button.h" #include "help_button.h"
#include "libresrc/libresrc.h" #include "libresrc/libresrc.h"
#include "persist_location.h" #include "persist_location.h"
#include "scintilla_text_ctrl.h" #include "subs_edit_ctrl.h"
#include "selection_controller.h" #include "selection_controller.h"
#include "utils.h" #include "utils.h"
#include "video_context.h" #include "video_context.h"
@ -64,7 +64,7 @@ static bool bad_block(AssDialogueBlock *block) {
} }
DialogTranslation::DialogTranslation(agi::Context *c) DialogTranslation::DialogTranslation(agi::Context *c)
: wxDialog(c->parent, -1, _("Translation Assistant"), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER | wxMINIMIZE_BOX, "TranslationAssistant") : wxDialog(c->parent, -1, _("Translation Assistant"), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER | wxMINIMIZE_BOX)
, c(c) , c(c)
, active_line(c->selectionController->GetActiveLine()) , active_line(c->selectionController->GetActiveLine())
, cur_block(0) , cur_block(0)
@ -93,7 +93,7 @@ DialogTranslation::DialogTranslation(agi::Context *c)
} }
{ {
translated_text = new ScintillaTextCtrl(this, -1, "", wxDefaultPosition, wxSize(320, 80)); translated_text = new SubsTextEditCtrl(this, wxSize(320, 80), 0, 0);
translated_text->SetWrapMode(wxSTC_WRAP_WORD); translated_text->SetWrapMode(wxSTC_WRAP_WORD);
translated_text->SetMarginWidth(1, 0); translated_text->SetMarginWidth(1, 0);
translated_text->SetFocus(); translated_text->SetFocus();

View file

@ -31,6 +31,7 @@ namespace agi { struct Context; }
class AssDialogue; class AssDialogue;
class PersistLocation; class PersistLocation;
class ScintillaTextCtrl; class ScintillaTextCtrl;
class SubsTextEditCtrl;
class wxStaticText; class wxStaticText;
class wxCheckBox; class wxCheckBox;
@ -43,7 +44,7 @@ class DialogTranslation : public wxDialog {
/// The active line /// The active line
AssDialogue *active_line; AssDialogue *active_line;
/// Which dialogue block in the active line is currrently being translated /// Which dialogue block in the active line is currently being translated
size_t cur_block; size_t cur_block;
/// Total number of dialogue lines in the file /// Total number of dialogue lines in the file
@ -53,7 +54,7 @@ class DialogTranslation : public wxDialog {
wxStaticText *line_number_display; wxStaticText *line_number_display;
ScintillaTextCtrl *original_text; ScintillaTextCtrl *original_text;
ScintillaTextCtrl *translated_text; SubsTextEditCtrl *translated_text;
wxCheckBox *seek_video; wxCheckBox *seek_video;
agi::scoped_ptr<PersistLocation> persist; agi::scoped_ptr<PersistLocation> persist;

View file

@ -167,10 +167,15 @@ SubsTextEditCtrl::SubsTextEditCtrl(wxWindow* parent, wxSize wsize, long style, a
using namespace std::tr1; using namespace std::tr1;
Bind(wxEVT_COMMAND_MENU_SELECTED, function<void (wxCommandEvent &)>(bind(&SubsTextEditCtrl::Cut, this)), EDIT_MENU_CUT); Bind(wxEVT_COMMAND_MENU_SELECTED, bind(&SubsTextEditCtrl::Cut, this), EDIT_MENU_CUT);
Bind(wxEVT_COMMAND_MENU_SELECTED, function<void (wxCommandEvent &)>(bind(&SubsTextEditCtrl::Copy, this)), EDIT_MENU_COPY); Bind(wxEVT_COMMAND_MENU_SELECTED, bind(&SubsTextEditCtrl::Copy, this), EDIT_MENU_COPY);
Bind(wxEVT_COMMAND_MENU_SELECTED, function<void (wxCommandEvent &)>(bind(&SubsTextEditCtrl::Paste, this)), EDIT_MENU_PASTE); Bind(wxEVT_COMMAND_MENU_SELECTED, bind(&SubsTextEditCtrl::Paste, this), EDIT_MENU_PASTE);
Bind(wxEVT_COMMAND_MENU_SELECTED, function<void (wxCommandEvent &)>(bind(&SubsTextEditCtrl::SelectAll, this)), EDIT_MENU_SELECT_ALL); Bind(wxEVT_COMMAND_MENU_SELECTED, bind(&SubsTextEditCtrl::SelectAll, this), EDIT_MENU_SELECT_ALL);
if (context) {
Bind(wxEVT_COMMAND_MENU_SELECTED, bind(&SubsTextEditCtrl::SplitLine, this, true), EDIT_MENU_SPLIT_PRESERVE);
Bind(wxEVT_COMMAND_MENU_SELECTED, bind(&SubsTextEditCtrl::SplitLine, this, false), EDIT_MENU_SPLIT_ESTIMATE);
}
Bind(wxEVT_STC_STYLENEEDED, &SubsTextEditCtrl::UpdateCallTip, this); Bind(wxEVT_STC_STYLENEEDED, &SubsTextEditCtrl::UpdateCallTip, this);
@ -208,8 +213,6 @@ void SubsTextEditCtrl::Subscribe(std::string const& name) {
BEGIN_EVENT_TABLE(SubsTextEditCtrl,wxStyledTextCtrl) BEGIN_EVENT_TABLE(SubsTextEditCtrl,wxStyledTextCtrl)
EVT_KILL_FOCUS(SubsTextEditCtrl::OnLoseFocus) EVT_KILL_FOCUS(SubsTextEditCtrl::OnLoseFocus)
EVT_MENU(EDIT_MENU_SPLIT_PRESERVE,SubsTextEditCtrl::OnSplitLinePreserve)
EVT_MENU(EDIT_MENU_SPLIT_ESTIMATE,SubsTextEditCtrl::OnSplitLineEstimate)
EVT_MENU(EDIT_MENU_ADD_TO_DICT,SubsTextEditCtrl::OnAddToDictionary) EVT_MENU(EDIT_MENU_ADD_TO_DICT,SubsTextEditCtrl::OnAddToDictionary)
EVT_MENU_RANGE(EDIT_MENU_SUGGESTIONS,EDIT_MENU_THESAURUS-1,SubsTextEditCtrl::OnUseSuggestion) EVT_MENU_RANGE(EDIT_MENU_SUGGESTIONS,EDIT_MENU_THESAURUS-1,SubsTextEditCtrl::OnUseSuggestion)
EVT_MENU_RANGE(EDIT_MENU_THESAURUS_SUGS,EDIT_MENU_DIC_LANGUAGE-1,SubsTextEditCtrl::OnUseSuggestion) EVT_MENU_RANGE(EDIT_MENU_THESAURUS_SUGS,EDIT_MENU_DIC_LANGUAGE-1,SubsTextEditCtrl::OnUseSuggestion)
@ -282,7 +285,7 @@ void SubsTextEditCtrl::UpdateStyle() {
if (text.empty()) return; if (text.empty()) return;
// Check if it's a template line // Check if it's a template line
AssDialogue *diag = context->selectionController->GetActiveLine(); AssDialogue *diag = context ? context->selectionController->GetActiveLine() : 0;
bool templateLine = diag && diag->Comment && diag->Effect.Lower().StartsWith("template"); bool templateLine = diag && diag->Comment && diag->Effect.Lower().StartsWith("template");
size_t last_template = 0; size_t last_template = 0;
@ -719,9 +722,6 @@ void SubsTextEditCtrl::Paste() {
} }
void SubsTextEditCtrl::OnContextMenu(wxContextMenuEvent &event) { void SubsTextEditCtrl::OnContextMenu(wxContextMenuEvent &event) {
if (!context->selectionController->GetActiveLine())
return;
wxPoint pos = event.GetPosition(); wxPoint pos = event.GetPosition();
int activePos; int activePos;
if (pos == wxDefaultPosition) { if (pos == wxDefaultPosition) {
@ -750,9 +750,11 @@ void SubsTextEditCtrl::OnContextMenu(wxContextMenuEvent &event) {
menu.Append(EDIT_MENU_SELECT_ALL,_("Select &All")); menu.Append(EDIT_MENU_SELECT_ALL,_("Select &All"));
// Split // Split
menu.AppendSeparator(); if (context) {
menu.Append(EDIT_MENU_SPLIT_PRESERVE,_("Split at cursor (preserve times)")); menu.AppendSeparator();
menu.Append(EDIT_MENU_SPLIT_ESTIMATE,_("Split at cursor (estimate times)")); menu.Append(EDIT_MENU_SPLIT_PRESERVE,_("Split at cursor (preserve times)"));
menu.Append(EDIT_MENU_SPLIT_ESTIMATE,_("Split at cursor (estimate times)"));
}
PopupMenu(&menu); PopupMenu(&menu);
} }
@ -865,14 +867,6 @@ void SubsTextEditCtrl::SplitLine(bool estimateTimes) {
context->ass->Commit(_("split"), AssFile::COMMIT_DIAG_ADDREM | AssFile::COMMIT_DIAG_FULL); context->ass->Commit(_("split"), AssFile::COMMIT_DIAG_ADDREM | AssFile::COMMIT_DIAG_FULL);
} }
void SubsTextEditCtrl::OnSplitLinePreserve(wxCommandEvent &) {
SplitLine(false);
}
void SubsTextEditCtrl::OnSplitLineEstimate(wxCommandEvent &) {
SplitLine(true);
}
void SubsTextEditCtrl::OnAddToDictionary(wxCommandEvent &) { void SubsTextEditCtrl::OnAddToDictionary(wxCommandEvent &) {
if (spellchecker) spellchecker->AddWord(currentWord); if (spellchecker) spellchecker->AddWord(currentWord);
UpdateStyle(); UpdateStyle();

View file

@ -48,18 +48,16 @@ class SubsEditBox;
class Thesaurus; class Thesaurus;
namespace agi { struct Context; } namespace agi { struct Context; }
/// DOCME
/// @class SubsTextEditCtrl /// @class SubsTextEditCtrl
/// @brief DOCME /// @brief A Scintilla control with spell checking and syntax highlighting
///
/// DOCME
class SubsTextEditCtrl : public ScintillaTextCtrl { class SubsTextEditCtrl : public ScintillaTextCtrl {
/// DOCME /// Backend spellchecker to use
agi::scoped_ptr<SpellChecker> spellchecker; agi::scoped_ptr<SpellChecker> spellchecker;
/// DOCME /// Backend thesaurus to use
agi::scoped_ptr<Thesaurus> thesaurus; agi::scoped_ptr<Thesaurus> thesaurus;
/// Project context, for splitting lines
agi::Context *context; agi::Context *context;
/// The word right-clicked on, used for spellchecker replacing /// The word right-clicked on, used for spellchecker replacing
@ -68,21 +66,19 @@ class SubsTextEditCtrl : public ScintillaTextCtrl {
/// The beginning of the word right-clicked on, for spellchecker replacing /// The beginning of the word right-clicked on, for spellchecker replacing
int currentWordPos; int currentWordPos;
/// DOCME /// Spellchecker suggestions for the last right-clicked word
wxArrayString sugs; wxArrayString sugs;
/// DOCME /// Thesaurus suggestions for the last right-clicked word
std::vector<std::string> thesSugs; std::vector<std::string> thesSugs;
/// DOCME /// Calltip prototypes
wxArrayString proto; wxArrayString proto;
/// DOCME /// Last show calltip, to avoid flickering the currently active one
int tipProtoN; int tipProtoN;
void OnContextMenu(wxContextMenuEvent &); void OnContextMenu(wxContextMenuEvent &);
void OnSplitLinePreserve(wxCommandEvent &event);
void OnSplitLineEstimate(wxCommandEvent &event);
void OnAddToDictionary(wxCommandEvent &event); void OnAddToDictionary(wxCommandEvent &event);
void OnUseSuggestion(wxCommandEvent &event); void OnUseSuggestion(wxCommandEvent &event);
void OnSetDicLanguage(wxCommandEvent &event); void OnSetDicLanguage(wxCommandEvent &event);