| Index: webkit/plugins/ppapi/ppb_char_set_impl.cc
|
| diff --git a/webkit/plugins/ppapi/ppb_char_set_impl.cc b/webkit/plugins/ppapi/ppb_char_set_impl.cc
|
| index 74144ed9181d41b243812f2e07a858406f28bbfb..dfa7bd38bea6b1185f9699936f504db82bcf167b 100644
|
| --- a/webkit/plugins/ppapi/ppb_char_set_impl.cc
|
| +++ b/webkit/plugins/ppapi/ppb_char_set_impl.cc
|
| @@ -4,15 +4,10 @@
|
|
|
| #include "webkit/plugins/ppapi/ppb_char_set_impl.h"
|
|
|
| -#include <stdlib.h>
|
| -
|
| -#include "base/i18n/icu_string_conversions.h"
|
| #include "ppapi/c/dev/ppb_char_set_dev.h"
|
| -#include "unicode/ucnv.h"
|
| -#include "unicode/ucnv_cb.h"
|
| -#include "unicode/ucnv_err.h"
|
| -#include "unicode/ustring.h"
|
| +#include "ppapi/shared_impl/char_set_impl.h"
|
| #include "webkit/plugins/ppapi/plugin_delegate.h"
|
| +#include "webkit/plugins/ppapi/plugin_module.h"
|
| #include "webkit/plugins/ppapi/ppapi_plugin_instance.h"
|
| #include "webkit/plugins/ppapi/resource_tracker.h"
|
| #include "webkit/plugins/ppapi/var.h"
|
| @@ -22,97 +17,14 @@ namespace ppapi {
|
|
|
| namespace {
|
|
|
| -// Converts the given PP error handling behavior to the version in base,
|
| -// placing the result in |*result| and returning true on success. Returns false
|
| -// if the enum is invalid.
|
| -bool PPToBaseConversionError(PP_CharSet_ConversionError on_error,
|
| - base::OnStringConversionError::Type* result) {
|
| - switch (on_error) {
|
| - case PP_CHARSET_CONVERSIONERROR_FAIL:
|
| - *result = base::OnStringConversionError::FAIL;
|
| - return true;
|
| - case PP_CHARSET_CONVERSIONERROR_SKIP:
|
| - *result = base::OnStringConversionError::SKIP;
|
| - return true;
|
| - case PP_CHARSET_CONVERSIONERROR_SUBSTITUTE:
|
| - *result = base::OnStringConversionError::SUBSTITUTE;
|
| - return true;
|
| - default:
|
| - return false;
|
| - }
|
| -}
|
| -
|
| -// The "substitution" behavior of this function does not match the
|
| -// implementation in base, so we partially duplicate the code from
|
| -// icu_string_conversions.cc with the correct error handling setup required
|
| -// by this PPAPI interface.
|
| char* UTF16ToCharSet(PP_Instance /* instance */,
|
| const uint16_t* utf16, uint32_t utf16_len,
|
| const char* output_char_set,
|
| PP_CharSet_ConversionError on_error,
|
| uint32_t* output_length) {
|
| - *output_length = 0;
|
| -
|
| - UErrorCode status = U_ZERO_ERROR;
|
| - UConverter* converter = ucnv_open(output_char_set, &status);
|
| - if (!U_SUCCESS(status))
|
| - return NULL;
|
| -
|
| - int encoded_max_length = UCNV_GET_MAX_BYTES_FOR_STRING(utf16_len,
|
| - ucnv_getMaxCharSize(converter));
|
| -
|
| - // Setup our error handler.
|
| - switch (on_error) {
|
| - case PP_CHARSET_CONVERSIONERROR_FAIL:
|
| - ucnv_setFromUCallBack(converter, UCNV_FROM_U_CALLBACK_STOP, 0,
|
| - NULL, NULL, &status);
|
| - break;
|
| - case PP_CHARSET_CONVERSIONERROR_SKIP:
|
| - ucnv_setFromUCallBack(converter, UCNV_FROM_U_CALLBACK_SKIP, 0,
|
| - NULL, NULL, &status);
|
| - break;
|
| - case PP_CHARSET_CONVERSIONERROR_SUBSTITUTE: {
|
| - // ICU sets the substitution char for some character sets (like latin1)
|
| - // to be the ASCII "substitution character" (26). We want to use '?'
|
| - // instead for backwards-compat with Windows behavior.
|
| - char subst_chars[32];
|
| - int8_t subst_chars_len = 32;
|
| - ucnv_getSubstChars(converter, subst_chars, &subst_chars_len, &status);
|
| - if (subst_chars_len == 1 && subst_chars[0] == 26) {
|
| - // Override to the question mark character if possible. When using
|
| - // setSubstString, the input is a Unicode character. The function will
|
| - // try to convert it to the destination character set and fail if that
|
| - // can not be converted to the destination character set.
|
| - //
|
| - // We just ignore any failure. If the dest char set has no
|
| - // representation for '?', then we'll just stick to the ICU default
|
| - // substitution character.
|
| - UErrorCode subst_status = U_ZERO_ERROR;
|
| - UChar question_mark = '?';
|
| - ucnv_setSubstString(converter, &question_mark, 1, &subst_status);
|
| - }
|
| -
|
| - ucnv_setFromUCallBack(converter, UCNV_FROM_U_CALLBACK_SUBSTITUTE, 0,
|
| - NULL, NULL, &status);
|
| - break;
|
| - }
|
| - default:
|
| - return NULL;
|
| - }
|
| -
|
| - // ucnv_fromUChars returns size not including terminating null.
|
| - char* encoded = static_cast<char*>(malloc(encoded_max_length + 1));
|
| - int actual_size = ucnv_fromUChars(converter, encoded,
|
| - encoded_max_length, reinterpret_cast<const UChar*>(utf16), utf16_len,
|
| - &status);
|
| - ucnv_close(converter);
|
| - if (!U_SUCCESS(status)) {
|
| - free(encoded);
|
| - return NULL;
|
| - }
|
| - encoded[actual_size] = 0;
|
| - *output_length = actual_size;
|
| - return encoded;
|
| + return pp::shared_impl::CharSetImpl::UTF16ToCharSet(
|
| + PluginModule::GetCore(), utf16, utf16_len, output_char_set, on_error,
|
| + output_length);
|
| }
|
|
|
| uint16_t* CharSetToUTF16(PP_Instance /* instance */,
|
| @@ -120,27 +32,9 @@ uint16_t* CharSetToUTF16(PP_Instance /* instance */,
|
| const char* input_char_set,
|
| PP_CharSet_ConversionError on_error,
|
| uint32_t* output_length) {
|
| - *output_length = 0;
|
| -
|
| - base::OnStringConversionError::Type base_on_error;
|
| - if (!PPToBaseConversionError(on_error, &base_on_error))
|
| - return NULL; // Invalid enum value.
|
| -
|
| - // We can convert this call to the implementation in base to avoid code
|
| - // duplication, although this does introduce an extra copy of the data.
|
| - string16 output;
|
| - if (!base::CodepageToUTF16(std::string(input, input_len), input_char_set,
|
| - base_on_error, &output))
|
| - return NULL;
|
| -
|
| - uint16_t* ret_buf = static_cast<uint16_t*>(
|
| - malloc((output.size() + 1) * sizeof(uint16_t)));
|
| - if (!ret_buf)
|
| - return NULL;
|
| -
|
| - *output_length = static_cast<uint32_t>(output.size());
|
| - memcpy(ret_buf, output.c_str(), (output.size() + 1) * sizeof(uint16_t));
|
| - return ret_buf;
|
| + return pp::shared_impl::CharSetImpl::CharSetToUTF16(
|
| + PluginModule::GetCore(), input, input_len, input_char_set, on_error,
|
| + output_length);
|
| }
|
|
|
| PP_Var GetDefaultCharSet(PP_Instance instance_id) {
|
| @@ -167,4 +61,3 @@ const struct PPB_CharSet_Dev* PPB_CharSet_Impl::GetInterface() {
|
|
|
| } // namespace ppapi
|
| } // namespace webkit
|
| -
|
|
|