summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--base/json_writer.cc4
-rw-r--r--base/string_escape.cc7
-rw-r--r--base/string_escape.h5
-rw-r--r--base/string_escape_unittest.cc16
-rw-r--r--base/string_util.h13
-rw-r--r--net/base/net_util.cc7
6 files changed, 32 insertions, 20 deletions
diff --git a/base/json_writer.cc b/base/json_writer.cc
index 0da2925..20c533b 100644
--- a/base/json_writer.cc
+++ b/base/json_writer.cc
@@ -156,7 +156,8 @@ void JSONWriter::BuildJSONString(const Value* const node, int depth) {
}
void JSONWriter::AppendQuotedString(const std::wstring& str) {
- string_escape::JavascriptDoubleQuote(str, true, json_string_);
+ string_escape::JavascriptDoubleQuote(WideToUTF16Hack(str), true,
+ json_string_);
}
void JSONWriter::IndentLine(int depth) {
@@ -164,4 +165,3 @@ void JSONWriter::IndentLine(int depth) {
// reallocating.
json_string_->append(std::string(depth * 3, ' '));
}
-
diff --git a/base/string_escape.cc b/base/string_escape.cc
index c2fc542..aafee11 100644
--- a/base/string_escape.cc
+++ b/base/string_escape.cc
@@ -46,14 +46,14 @@ static bool JavascriptSingleEscapeChar(const CHAR c, std::string* dst) {
return true;
}
-void JavascriptDoubleQuote(const std::wstring& str,
+void JavascriptDoubleQuote(const string16& str,
bool put_in_quotes,
std::string* dst) {
if (put_in_quotes)
dst->push_back('"');
- for (std::wstring::const_iterator it = str.begin(); it != str.end(); ++it) {
- wchar_t c = *it;
+ for (string16::const_iterator it = str.begin(); it != str.end(); ++it) {
+ char16 c = *it;
if (!JavascriptSingleEscapeChar(c, dst)) {
if (c > 255) {
// Non-ascii values need to be unicode dst->
@@ -96,4 +96,3 @@ void JavascriptDoubleQuote(const std::string& str,
}
} // namespace string_escape
-
diff --git a/base/string_escape.h b/base/string_escape.h
index f58651e..9c6233a 100644
--- a/base/string_escape.h
+++ b/base/string_escape.h
@@ -7,7 +7,7 @@
#ifndef BASE_STRING_ESCAPE_H__
#define BASE_STRING_ESCAPE_H__
-#include <string>
+#include "base/string16.h"
namespace string_escape {
@@ -17,7 +17,7 @@ namespace string_escape {
// If |put_in_quotes| is true, the result will be surrounded in double quotes.
// The outputted literal, when interpreted by the browser, should result in a
// javascript string that is identical and the same length as the input |str|.
-void JavascriptDoubleQuote(const std::wstring& str,
+void JavascriptDoubleQuote(const string16& str,
bool put_in_quotes,
std::string* dst);
@@ -33,4 +33,3 @@ void JavascriptDoubleQuote(const std::string& str,
} // namespace string_escape
#endif // BASE_STRING_ESCAPE_H__
-
diff --git a/base/string_escape_unittest.cc b/base/string_escape_unittest.cc
index 28be9bd..e6a1806 100644
--- a/base/string_escape_unittest.cc
+++ b/base/string_escape_unittest.cc
@@ -4,6 +4,7 @@
#include "testing/gtest/include/gtest/gtest.h"
#include "base/string_escape.h"
+#include "base/string_util.h"
TEST(StringEscapeTest, JavascriptDoubleQuote) {
static const char* kToEscape = "\b\001aZ\"\\wee";
@@ -17,21 +18,21 @@ TEST(StringEscapeTest, JavascriptDoubleQuote) {
// Test wide unicode escaping
out = "testy: ";
- string_escape::JavascriptDoubleQuote(std::wstring(kUToEscape), false, &out);
+ string_escape::JavascriptDoubleQuote(WideToUTF16(kUToEscape), false, &out);
ASSERT_EQ(std::string("testy: ") + kUEscaped, out);
out = "testy: ";
- string_escape::JavascriptDoubleQuote(std::wstring(kUToEscape), true, &out);
+ string_escape::JavascriptDoubleQuote(WideToUTF16(kUToEscape), true, &out);
ASSERT_EQ(std::string("testy: ") + kUEscapedQuoted, out);
// Test null and high bit / negative unicode values
- std::wstring wstr(L"TeSt");
- wstr.push_back(0);
- wstr.push_back(0xffb1);
- wstr.push_back(0x00ff);
+ string16 str16 = UTF8ToUTF16("TeSt");
+ str16.push_back(0);
+ str16.push_back(0xffb1);
+ str16.push_back(0x00ff);
out = "testy: ";
- string_escape::JavascriptDoubleQuote(wstr, false, &out);
+ string_escape::JavascriptDoubleQuote(str16, false, &out);
ASSERT_EQ("testy: TeSt\\x00\\uFFB1\\xFF", out);
// Test escaping of 7bit ascii
@@ -61,4 +62,3 @@ TEST(StringEscapeTest, JavascriptDoubleQuote) {
string_escape::JavascriptDoubleQuote("a\b\f\n\r\t\v\1\\.\"z", false, &out);
ASSERT_EQ("testy: a\\b\\f\\n\\r\\t\\v\\x01\\\\.\\\"z", out);
}
-
diff --git a/base/string_util.h b/base/string_util.h
index 6ee079a..500a114 100644
--- a/base/string_util.h
+++ b/base/string_util.h
@@ -181,6 +181,19 @@ string16 UTF8ToUTF16(const std::string& utf8);
bool UTF16ToUTF8(const char16* src, size_t src_len, std::string* output);
std::string UTF16ToUTF8(const string16& utf16);
+// We are trying to get rid of wstring as much as possible, but it's too big
+// a mess to do it all at once. These conversions should be used when we
+// really should just be passing a string16 around, but we haven't finished
+// porting whatever module uses wstring and the conversion is being used as a
+// stopcock. This makes it easy to grep for the ones that should be removed.
+#if defined(OS_WIN)
+# define WideToUTF16Hack
+# define UTF16ToWideHack
+#else
+# define WideToUTF16Hack WideToUTF16
+# define UTF16ToWideHack UTF16ToWide
+#endif
+
// Defines the error handling modes of WideToCodepage and CodepageToWide.
class OnStringUtilConversionError {
public:
diff --git a/net/base/net_util.cc b/net/base/net_util.cc
index 5c042d1..7cee8f1 100644
--- a/net/base/net_util.cc
+++ b/net/base/net_util.cc
@@ -848,14 +848,15 @@ std::string GetDirectoryListingEntry(const std::string& name,
}
string_escape::JavascriptDoubleQuote(
- FormatBytes(size, GetByteDisplayUnits(size), true), true, &result);
+ WideToUTF16Hack(FormatBytes(size, GetByteDisplayUnits(size), true)), true,
+ &result);
result.append(",");
- std::wstring modified_str;
+ string16 modified_str;
// |modified| can be NULL in FTP listings.
if (!modified.is_null()) {
- modified_str = base::TimeFormatShortDateAndTime(modified);
+ modified_str = WideToUTF16Hack(base::TimeFormatShortDateAndTime(modified));
}
string_escape::JavascriptDoubleQuote(modified_str, true, &result);