diff options
author | Oz Linden <oz@lindenlab.com> | 2011-10-24 16:14:07 -0400 |
---|---|---|
committer | Oz Linden <oz@lindenlab.com> | 2011-10-24 16:14:07 -0400 |
commit | b7a349f231977d5917b29faacca143a85d925576 (patch) | |
tree | 7440d0bbf864586cef6332c1112fc491bcadfc47 /indra/newview/lltranslate.cpp | |
parent | 5b221f01cf0bf7c83e96287c2ae3d84d5d23d537 (diff) | |
parent | cc719670d9ae9c2793f291dd4a3fd9f0118b5876 (diff) |
merge changes for storm-1664
Diffstat (limited to 'indra/newview/lltranslate.cpp')
-rwxr-xr-x[-rw-r--r--] | indra/newview/lltranslate.cpp | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/indra/newview/lltranslate.cpp b/indra/newview/lltranslate.cpp index 2f60b6b90b..3692f67a8d 100644..100755 --- a/indra/newview/lltranslate.cpp +++ b/indra/newview/lltranslate.cpp @@ -53,6 +53,45 @@ const char* LLTranslate::m_GoogleData = "responseData"; const char* LLTranslate::m_GoogleTranslation = "translatedText"; const char* LLTranslate::m_GoogleLanguage = "detectedSourceLanguage"; +// virtual +void LLTranslate::TranslationReceiver::completedRaw( U32 status, + const std::string& reason, + const LLChannelDescriptors& channels, + const LLIOPipe::buffer_ptr_t& buffer) +{ + if (200 <= status && status < 300) + { + LLBufferStream istr(channels, buffer.get()); + std::stringstream strstrm; + strstrm << istr.rdbuf(); + + const std::string result = strstrm.str(); + std::string translation; + std::string detected_language; + + if (!parseGoogleTranslate(result, translation, detected_language)) + { + handleFailure(); + return; + } + + // Fix up the response + LLStringUtil::replaceString(translation, "<", "<"); + LLStringUtil::replaceString(translation, ">",">"); + LLStringUtil::replaceString(translation, ""","\""); + LLStringUtil::replaceString(translation, "'","'"); + LLStringUtil::replaceString(translation, "&","&"); + LLStringUtil::replaceString(translation, "'","'"); + + handleResponse(translation, detected_language); + } + else + { + LL_WARNS("Translate") << "HTTP request for Google Translate failed with status " << status << ", reason: " << reason << LL_ENDL; + handleFailure(); + } +} + //static void LLTranslate::translateMessage(LLHTTPClient::ResponderPtr &result, const std::string &from_lang, const std::string &to_lang, const std::string &mesg) { |