This source file includes following definitions.
- registerEncodingNames
- newStreamingTextDecoderUserDefined
- registerCodecs
- decode
- encodeComplexUserDefined
- encodeCommon
- encode
- encode
#include "config.h"
#include "wtf/text/TextCodecUserDefined.h"
#include "wtf/PassOwnPtr.h"
#include "wtf/text/CString.h"
#include "wtf/text/StringBuffer.h"
#include "wtf/text/StringBuilder.h"
#include "wtf/text/WTFString.h"
namespace WTF {
void TextCodecUserDefined::registerEncodingNames(EncodingNameRegistrar registrar)
{
registrar("x-user-defined", "x-user-defined");
}
static PassOwnPtr<TextCodec> newStreamingTextDecoderUserDefined(const TextEncoding&, const void*)
{
return adoptPtr(new TextCodecUserDefined);
}
void TextCodecUserDefined::registerCodecs(TextCodecRegistrar registrar)
{
registrar("x-user-defined", newStreamingTextDecoderUserDefined, 0);
}
String TextCodecUserDefined::decode(const char* bytes, size_t length, FlushBehavior, bool, bool&)
{
StringBuilder result;
result.reserveCapacity(length);
for (size_t i = 0; i < length; ++i) {
signed char c = bytes[i];
result.append(static_cast<UChar>(c & 0xF7FF));
}
return result.toString();
}
template<typename CharType>
static CString encodeComplexUserDefined(const CharType* characters, size_t length, UnencodableHandling handling)
{
Vector<char> result(length);
char* bytes = result.data();
size_t resultLength = 0;
for (size_t i = 0; i < length; ) {
UChar32 c;
U16_NEXT(characters, i, length, c);
signed char signedByte = c;
if ((signedByte & 0xF7FF) == c)
bytes[resultLength++] = signedByte;
else {
UnencodableReplacementArray replacement;
int replacementLength = TextCodec::getUnencodableReplacement(c, handling, replacement);
result.grow(resultLength + replacementLength + length - i);
bytes = result.data();
memcpy(bytes + resultLength, replacement, replacementLength);
resultLength += replacementLength;
}
}
return CString(bytes, resultLength);
}
template<typename CharType>
CString TextCodecUserDefined::encodeCommon(const CharType* characters, size_t length, UnencodableHandling handling)
{
char* bytes;
CString result = CString::newUninitialized(length, bytes);
UChar ored = 0;
for (size_t i = 0; i < length; ++i) {
UChar c = characters[i];
bytes[i] = c;
ored |= c;
}
if (!(ored & 0xFF80))
return result;
return encodeComplexUserDefined(characters, length, handling);
}
CString TextCodecUserDefined::encode(const UChar* characters, size_t length, UnencodableHandling handling)
{
return encodeCommon(characters, length, handling);
}
CString TextCodecUserDefined::encode(const LChar* characters, size_t length, UnencodableHandling handling)
{
return encodeCommon(characters, length, handling);
}
}