diff options
Diffstat (limited to 'linden/indra/llui/lllineeditor.cpp')
-rw-r--r-- | linden/indra/llui/lllineeditor.cpp | 77 |
1 files changed, 33 insertions, 44 deletions
diff --git a/linden/indra/llui/lllineeditor.cpp b/linden/indra/llui/lllineeditor.cpp index b3da7fd..e73b287 100644 --- a/linden/indra/llui/lllineeditor.cpp +++ b/linden/indra/llui/lllineeditor.cpp | |||
@@ -231,38 +231,22 @@ LLLineEditor::LLLineEditor(const std::string& name, const LLRect& rect, | |||
231 | menu->appendSeparator("Transep"); | 231 | menu->appendSeparator("Transep"); |
232 | LLMenuGL* translatemenu = new LLMenuGL("Translate To"); | 232 | LLMenuGL* translatemenu = new LLMenuGL("Translate To"); |
233 | translatemenu->setCanTearOff(FALSE); | 233 | translatemenu->setCanTearOff(FALSE); |
234 | SpellMenuBind* t=new SpellMenuBind;t->origin=this;t->word="en"; | 234 | translatemenu->append(new LLMenuItemCallGL("en", "English", context_translate, context_enable_translate, this)); |
235 | translatemenu->append(new LLMenuItemCallGL("English", context_translate, context_enable_translate, t)); | 235 | translatemenu->append(new LLMenuItemCallGL("da", "Danish", context_translate, context_enable_translate, this)); |
236 | t=new SpellMenuBind;t->origin=this;t->word="da"; | 236 | translatemenu->append(new LLMenuItemCallGL("de", "Deutsch(German)", context_translate, context_enable_translate, this)); |
237 | translatemenu->append(new LLMenuItemCallGL("Danish", context_translate, context_enable_translate, t)); | 237 | translatemenu->append(new LLMenuItemCallGL("es", "Spanish", context_translate, context_enable_translate, this)); |
238 | t=new SpellMenuBind;t->origin=this;t->word="de"; | 238 | translatemenu->append(new LLMenuItemCallGL("fr", "French", context_translate, context_enable_translate, this)); |
239 | translatemenu->append(new LLMenuItemCallGL("Deutsch(German)", context_translate, context_enable_translate, t)); | 239 | translatemenu->append(new LLMenuItemCallGL("it", "Italian", context_translate, context_enable_translate, this)); |
240 | t=new SpellMenuBind;t->origin=this;t->word="es"; | 240 | translatemenu->append(new LLMenuItemCallGL("hu", "Hungarian", context_translate, context_enable_translate, this)); |
241 | translatemenu->append(new LLMenuItemCallGL("Spanish", context_translate, context_enable_translate, t)); | 241 | translatemenu->append(new LLMenuItemCallGL("nl", "Dutch", context_translate, context_enable_translate, this)); |
242 | t=new SpellMenuBind;t->origin=this;t->word="fr"; | 242 | translatemenu->append(new LLMenuItemCallGL("pl", "Polish", context_translate, context_enable_translate, this)); |
243 | translatemenu->append(new LLMenuItemCallGL("French", context_translate, context_enable_translate, t)); | 243 | translatemenu->append(new LLMenuItemCallGL("pt", "Portugese", context_translate, context_enable_translate, this)); |
244 | t=new SpellMenuBind;t->origin=this;t->word="it"; | 244 | translatemenu->append(new LLMenuItemCallGL("ru", "Russian", context_translate, context_enable_translate, this)); |
245 | translatemenu->append(new LLMenuItemCallGL("Italian", context_translate, context_enable_translate, t)); | 245 | translatemenu->append(new LLMenuItemCallGL("tr", "Turkish", context_translate, context_enable_translate, this)); |
246 | t=new SpellMenuBind;t->origin=this;t->word="hu"; | 246 | translatemenu->append(new LLMenuItemCallGL("uk", "Ukrainian", context_translate, context_enable_translate, this)); |
247 | translatemenu->append(new LLMenuItemCallGL("Hungarian", context_translate, context_enable_translate, t)); | 247 | translatemenu->append(new LLMenuItemCallGL("zh", "Chinese", context_translate, context_enable_translate, this)); |
248 | t=new SpellMenuBind;t->origin=this;t->word="nl"; | 248 | translatemenu->append(new LLMenuItemCallGL("ja", "Japanese", context_translate, context_enable_translate, this)); |
249 | translatemenu->append(new LLMenuItemCallGL("Dutch", context_translate, context_enable_translate, t)); | 249 | translatemenu->append(new LLMenuItemCallGL("ko", "Korean", context_translate, context_enable_translate, this)); |
250 | t=new SpellMenuBind;t->origin=this;t->word="pl"; | ||
251 | translatemenu->append(new LLMenuItemCallGL("Polish", context_translate, context_enable_translate, t)); | ||
252 | t=new SpellMenuBind;t->origin=this;t->word="pt"; | ||
253 | translatemenu->append(new LLMenuItemCallGL("Portugese", context_translate, context_enable_translate, t)); | ||
254 | t=new SpellMenuBind;t->origin=this;t->word="ru"; | ||
255 | translatemenu->append(new LLMenuItemCallGL("Russian", context_translate, context_enable_translate, t)); | ||
256 | t=new SpellMenuBind;t->origin=this;t->word="tr"; | ||
257 | translatemenu->append(new LLMenuItemCallGL("Turkish", context_translate, context_enable_translate, t)); | ||
258 | t=new SpellMenuBind;t->origin=this;t->word="uk"; | ||
259 | translatemenu->append(new LLMenuItemCallGL("Ukrainian", context_translate, context_enable_translate, t)); | ||
260 | t=new SpellMenuBind;t->origin=this;t->word="zh"; | ||
261 | translatemenu->append(new LLMenuItemCallGL("Chinese", context_translate, context_enable_translate, t)); | ||
262 | t=new SpellMenuBind;t->origin=this;t->word="ja"; | ||
263 | translatemenu->append(new LLMenuItemCallGL("Japanese", context_translate, context_enable_translate, t)); | ||
264 | t=new SpellMenuBind;t->origin=this;t->word="ko"; | ||
265 | translatemenu->append(new LLMenuItemCallGL("Korean", context_translate, context_enable_translate, t)); | ||
266 | 250 | ||
267 | menu->appendMenu(translatemenu); | 251 | menu->appendMenu(translatemenu); |
268 | menu->appendSeparator("Spelsep"); | 252 | menu->appendSeparator("Spelsep"); |
@@ -555,15 +539,20 @@ void LLLineEditor::spell_correct(void* data) | |||
555 | 539 | ||
556 | BOOL LLLineEditor::context_enable_translate(void* data) | 540 | BOOL LLLineEditor::context_enable_translate(void* data) |
557 | { | 541 | { |
558 | SpellMenuBind* t = (SpellMenuBind*)data; | 542 | LLLineEditor* line = (LLLineEditor*)data; |
559 | return (t && t->origin && t->origin->canTranslate()); | 543 | return line && line->canTranslate(); |
560 | } | 544 | } |
561 | 545 | ||
562 | void LLLineEditor::context_translate(void * data) | 546 | void LLLineEditor::context_translate(void * data) |
563 | { | 547 | { |
564 | SpellMenuBind* t = (SpellMenuBind*)data; | 548 | LLLineEditor* line = (LLLineEditor*)data; |
565 | LLLineEditor* line = t->origin; | 549 | LLMenuGL* menu = line ? (LLMenuGL*)(line->mPopupMenuHandle.get()) : NULL; |
566 | const std::string &toLang = t->word;//LLTranslate::getTranslateLanguage(); | 550 | LLMenuGL* translate_menu = menu ? menu->getChildMenuByName("Translate To", TRUE) : NULL; |
551 | if (!translate_menu) | ||
552 | { | ||
553 | return; | ||
554 | } | ||
555 | const std::string to_lang = translate_menu->getHighlightedItem()->getName(); | ||
567 | 556 | ||
568 | bool has_text = false; | 557 | bool has_text = false; |
569 | S32 start, length; | 558 | S32 start, length; |
@@ -584,8 +573,8 @@ void LLLineEditor::context_translate(void * data) | |||
584 | if (has_text) | 573 | if (has_text) |
585 | { | 574 | { |
586 | std::string to_translate = wstring_to_utf8str(line->getWText().substr(start, length)); | 575 | std::string to_translate = wstring_to_utf8str(line->getWText().substr(start, length)); |
587 | LLHTTPClient::ResponderPtr result = LineChatTranslationReceiver::build(toLang, line, start, length); | 576 | LLHTTPClient::ResponderPtr result = LineChatTranslationReceiver::build(to_lang, line, start, length); |
588 | LLTranslate::translateMessage(result,"", toLang, to_translate); | 577 | LLTranslate::translateMessage(result,"", to_lang, to_translate); |
589 | } | 578 | } |
590 | } | 579 | } |
591 | 580 | ||
@@ -790,7 +779,7 @@ BOOL LLLineEditor::handleRightMouseDown( S32 x, S32 y, MASK mask ) | |||
790 | 779 | ||
791 | //setCursorAtLocalPos( x); | 780 | //setCursorAtLocalPos( x); |
792 | S32 wordStart = 0; | 781 | S32 wordStart = 0; |
793 | S32 wordEnd = 0; | 782 | S32 wordLen = 0; |
794 | S32 pos = calculateCursorFromMouse(x); | 783 | S32 pos = calculateCursorFromMouse(x); |
795 | 784 | ||
796 | LLMenuGL* menu = (LLMenuGL*)mPopupMenuHandle.get(); | 785 | LLMenuGL* menu = (LLMenuGL*)mPopupMenuHandle.get(); |
@@ -819,11 +808,11 @@ BOOL LLLineEditor::handleRightMouseDown( S32 x, S32 y, MASK mask ) | |||
819 | if (!mReadOnly && mSpellCheckable) | 808 | if (!mReadOnly && mSpellCheckable) |
820 | { | 809 | { |
821 | // search for word matches | 810 | // search for word matches |
822 | bool is_word_part = getWordBoundriesAt(pos, &wordStart, &wordEnd); | 811 | bool is_word_part = getWordBoundriesAt(pos, &wordStart, &wordLen); |
823 | if (is_word_part) | 812 | if (is_word_part) |
824 | { | 813 | { |
825 | const LLWString& text = mText.getWString(); | 814 | const LLWString& text = mText.getWString(); |
826 | std::string selectedWord(std::string(text.begin(), text.end()).substr(wordStart,wordEnd-wordStart)); | 815 | std::string selectedWord(std::string(text.begin(), text.end()).substr(wordStart,wordLen)); |
827 | 816 | ||
828 | if (!glggHunSpell->isSpelledRight(selectedWord)) | 817 | if (!glggHunSpell->isSpelledRight(selectedWord)) |
829 | { | 818 | { |
@@ -835,7 +824,7 @@ BOOL LLLineEditor::handleRightMouseDown( S32 x, S32 y, MASK mask ) | |||
835 | SpellMenuBind * tempStruct = new SpellMenuBind; | 824 | SpellMenuBind * tempStruct = new SpellMenuBind; |
836 | tempStruct->origin = this; | 825 | tempStruct->origin = this; |
837 | tempStruct->word = suggs[i]; | 826 | tempStruct->word = suggs[i]; |
838 | tempStruct->wordPositionEnd = wordEnd; | 827 | tempStruct->wordPositionEnd = wordStart + wordLen; |
839 | tempStruct->wordPositionStart=wordStart; | 828 | tempStruct->wordPositionStart=wordStart; |
840 | LLMenuItemCallGL * suggMenuItem = new LLMenuItemCallGL( | 829 | LLMenuItemCallGL * suggMenuItem = new LLMenuItemCallGL( |
841 | tempStruct->word, spell_correct, NULL, tempStruct); | 830 | tempStruct->word, spell_correct, NULL, tempStruct); |
@@ -847,7 +836,7 @@ BOOL LLLineEditor::handleRightMouseDown( S32 x, S32 y, MASK mask ) | |||
847 | SpellMenuBind * tempStruct = new SpellMenuBind; | 836 | SpellMenuBind * tempStruct = new SpellMenuBind; |
848 | tempStruct->origin = this; | 837 | tempStruct->origin = this; |
849 | tempStruct->word = selectedWord; | 838 | tempStruct->word = selectedWord; |
850 | tempStruct->wordPositionEnd = wordEnd; | 839 | tempStruct->wordPositionEnd = wordStart + wordLen; |
851 | tempStruct->wordPositionStart=wordStart; | 840 | tempStruct->wordPositionStart=wordStart; |
852 | LLMenuItemCallGL * suggMenuItem = new LLMenuItemCallGL( | 841 | LLMenuItemCallGL * suggMenuItem = new LLMenuItemCallGL( |
853 | "Add Word", spell_add, NULL, tempStruct); | 842 | "Add Word", spell_add, NULL, tempStruct); |