WebKitTextCodec.cpp [plain text]
#include "config.h"
#include "WebKitTextCodec.h"
#include "KURL.h"
#include "TextCodecICU.h"
#include <BlackBerryPlatformString.h>
#include <wtf/Vector.h>
#include <wtf/text/Base64.h>
#include <wtf/text/CString.h>
#include <wtf/text/WTFString.h>
using WebCore::TextEncoding;
using WebCore::TextCodecICU;
namespace BlackBerry {
namespace WebKit {
#define COMPILE_ASSERT_MATCHING_ENUM(webkitName, wtfName) \
COMPILE_ASSERT(static_cast<int>(webkitName) == static_cast<int>(WTF::wtfName), mismatchingEnums)
COMPILE_ASSERT_MATCHING_ENUM(Base64FailOnInvalidCharacter, Base64FailOnInvalidCharacter);
COMPILE_ASSERT_MATCHING_ENUM(Base64IgnoreWhitespace, Base64IgnoreWhitespace);
COMPILE_ASSERT_MATCHING_ENUM(Base64IgnoreInvalidCharacters, Base64IgnoreInvalidCharacters);
COMPILE_ASSERT_MATCHING_ENUM(Base64DoNotInsertCRLF, Base64DoNotInsertLFs);
COMPILE_ASSERT_MATCHING_ENUM(Base64InsertCRLF, Base64InsertLFs);
bool isSameEncoding(const char* encoding1, const char* encoding2)
{
return TextEncoding(encoding1) == TextEncoding(encoding2);
}
bool isASCIICompatibleEncoding(const char* encoding)
{
TextEncoding textEncoding(encoding);
if (!textEncoding.isValid())
return false;
if (textEncoding == WebCore::UTF8Encoding() || textEncoding == WebCore::Latin1Encoding() || textEncoding == WebCore::ASCIIEncoding())
return true;
String lowercasedEncoding = String(encoding).lower();
if (lowercasedEncoding.startsWith("iso-8859")
|| lowercasedEncoding.startsWith("windows")
|| lowercasedEncoding.startsWith("euc-jp")
|| lowercasedEncoding.startsWith("euc-kr"))
return true;
return false;
}
TranscodeResult transcode(const char* sourceEncoding, const char* targetEncoding, const char*& sourceStart, int sourceLength, char*& targetStart, unsigned targetLength)
{
TextEncoding textEncodingSource(sourceEncoding);
if (!textEncodingSource.isValid())
return SourceEncodingUnsupported;
TextEncoding textEncodingTarget(targetEncoding);
if (!textEncodingTarget.isValid())
return TargetEncodingUnsupported;
bool sawError = false;
String ucs2 = TextCodecICU(textEncodingSource).decode(sourceStart, sourceLength, true, true, sawError);
if (sawError)
return SourceBroken;
CString encoded = TextCodecICU(textEncodingTarget).encode(ucs2.characters(), ucs2.length(), WebCore::EntitiesForUnencodables);
if (encoded.length() > targetLength)
return TargetBufferInsufficient;
strncpy(targetStart, encoded.data(), encoded.length());
targetStart += encoded.length();
return Success;
}
bool base64Decode(const BlackBerry::Platform::String& base64, std::vector<char>& binary, Base64DecodePolicy policy)
{
Vector<char> result;
if (!WTF::base64Decode(base64.c_str(), base64.length(), result, static_cast<WTF::Base64DecodePolicy>(policy)))
return false;
binary.insert(binary.begin(), result.begin(), result.end());
return true;
}
bool base64Encode(const std::vector<char>& binary, BlackBerry::Platform::String& base64, Base64EncodePolicy policy)
{
Vector<char> result;
result.append(&binary[0], binary.size());
WTF::base64Encode(&binary[0], binary.size(), result, static_cast<WTF::Base64EncodePolicy>(policy));
base64 = BlackBerry::Platform::String::fromAscii(&result[0], result.size());
return true;
}
void unescapeURL(const BlackBerry::Platform::String& escaped, BlackBerry::Platform::String& url)
{
url = WebCore::decodeURLEscapeSequences(escaped);
}
void escapeURL(const BlackBerry::Platform::String& url, BlackBerry::Platform::String& escaped)
{
escaped = WebCore::encodeWithURLEscapeSequences(url);
}
} }