1 /* Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 * Use of this source code is governed by a BSD-style license that can be
3 * found in the LICENSE file.
7 * This file defines the <code>PPB_CharSet_Trusted</code> interface.
14 [assert_size
(4)] enum PP_CharSet_Trusted_ConversionError
{
16 * Causes the entire conversion to fail if an error is encountered. The
17 * conversion function will return NULL.
19 PP_CHARSET_TRUSTED_CONVERSIONERROR_FAIL
,
22 * Silently skips over errors. Unrepresentable characters and input encoding
23 * errors will be removed from the output.
25 PP_CHARSET_TRUSTED_CONVERSIONERROR_SKIP
,
28 * Replaces the error or unrepresentable character with a substitution
29 * character. When converting to a Unicode character set (UTF-8 or UTF-16) it
30 * will use the unicode "substitution character" U+FFFD. When converting to
31 * another character set, the character will be charset-specific. For many
32 * languages this will be the representation of the '?' character.
34 PP_CHARSET_TRUSTED_CONVERSIONERROR_SUBSTITUTE
38 * The <code>PPB_CharSet_Trusted</code> interface provides functions for
39 * converting between character sets.
41 * This inteface is provided for trusted plugins only since in Native Client it
42 * would require an expensive out-of-process IPC call for each conversion,
43 * which makes performance unacceptable. Native Client plugins should include
44 * ICU or some other library if they need this feature.
46 interface PPB_CharSet_Trusted
{
48 * Converts the UTF-16 string pointed to by |*utf16| to an 8-bit string in
49 * the specified code page. |utf16_len| is measured in UTF-16 units, not
50 * bytes. This value may not be NULL.
52 * The given output buffer will be filled up to output_length bytes with the
53 * result. output_length will be updated with the number of bytes required
54 * for the given string. The output buffer may be null to just retrieve the
55 * required buffer length.
57 * This function will return PP_FALSE if there was an error converting the
58 * string and you requested PP_CHARSET_CONVERSIONERROR_FAIL, or the output
59 * character set was unknown. Otherwise, it will return PP_TRUE.
61 PP_Bool UTF16ToCharSet
([in, size_as
=utf16_len
] uint16_t
[] utf16
,
62 [in] uint32_t utf16_len
,
63 [in] str_t output_char_set
,
64 [in] PP_CharSet_Trusted_ConversionError on_error
,
65 [out] str_t output_buffer
,
66 [inout
] uint32_t output_length
);
69 * Same as UTF16ToCharSet except converts in the other direction. The input
70 * is in the given charset, and the |input_len| is the number of bytes in
73 * Note that the output_utf16_length is measured in UTF-16 characters.
75 * Since UTF16 can represent every Unicode character, the only time the
76 * replacement character will be used is if the encoding in the input string
79 PP_Bool CharSetToUTF16
([in] str_t input
,
80 [in] uint32_t input_len
,
81 [in] str_t input_char_set
,
82 [in] PP_CharSet_Trusted_ConversionError on_error
,
83 [out] uint16_t output_buffer
,
84 [inout
] uint32_t output_utf16_length
);
87 * Returns a string var representing the current multi-byte character set of
90 * WARNING: You really shouldn't be using this function unless you're dealing
91 * with legacy data. You should be using UTF-8 or UTF-16 and you don't have
92 * to worry about the character sets.
94 PP_Var GetDefaultCharSet
([in] PP_Instance instance
);