summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authordhollowa@chromium.org <dhollowa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-09-14 00:39:01 +0000
committerdhollowa@chromium.org <dhollowa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-09-14 00:39:01 +0000
commit4699e7bb9e5ef3c35009442c9954dd2b7489e191 (patch)
treed0d239f875583014aa6e505381f97000c5a0569a
parentb09f128a727d89bff77438377176510c16774b69 (diff)
downloadchromium_src-4699e7bb9e5ef3c35009442c9954dd2b7489e191.zip
chromium_src-4699e7bb9e5ef3c35009442c9954dd2b7489e191.tar.gz
chromium_src-4699e7bb9e5ef3c35009442c9954dd2b7489e191.tar.bz2
Revert 100973 - Updated *.pak file format to support both UTF8 and UTF16
Chromeframe tests started failing with this, see: http://build.chromium.org/p/chromium/builders/Chrome%20Frame%20Tests%20%28ie6%29/builds/14472/steps/chrome_frame_tests/logs/stdio http://build.chromium.org/p/chromium/builders/Chrome%20Frame%20Tests%20%28ie7%29/builds/14446/steps/chrome_frame_tests/logs/stdio http://build.chromium.org/p/chromium/builders/Chrome%20Frame%20Tests%20%28ie8%29/builds/14187/steps/chrome_frame_tests/logs/stdio FullTabDownloadTest.TopLevelPostReissueFromChromeFramePage: Did not complete. [----------] 2 tests from FullTabDownloadTest [ RUN ] FullTabDownloadTest.CF_DownloadFileFromPost [ OK ] FullTabDownloadTest.CF_DownloadFileFromPost (16 ms) [ RUN ] FullTabDownloadTest.TopLevelPostReissueFromChromeFramePage [712:3268:0913/153614:1242640:INFO:chrome_frame_test_utils.h(89)] chrome_frame_test::HungCOMCallDetector::~HungCOMCallDetector [712:3268:0913/153614:1242640:INFO:navigation_test.cc(753)] Not running test on Vista with IE7 [712:3268:0913/153614:1242656:INFO:chrome_frame_test_utils.h(85)] chrome_frame_test::HungCOMCallDetector::HungCOMCallDetector Inserted a new field in the header that specifies which encoding is to be used for the text resources. I also upped file format to version 4. BUG=76281 TEST=unit_tests Review URL: http://codereview.chromium.org/7744017 TBR=adriansc@chromium.org Review URL: http://codereview.chromium.org/7891028 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@101004 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/browser/autofill/autofill_regexes.cc1
-rw-r--r--chrome/browser/prefs/pref_service_unittest.cc25
-rw-r--r--chrome/browser/themes/browser_theme_pack.cc4
-rwxr-xr-xtools/data_pack/data_pack.py26
-rwxr-xr-xtools/data_pack/repack.py20
-rwxr-xr-xtools/grit/grit/format/data_pack.py61
-rw-r--r--tools/grit/grit/format/data_pack_unittest.py16
-rw-r--r--tools/grit/grit/node/include.py5
-rw-r--r--tools/grit/grit/node/message.py18
-rw-r--r--ui/base/resource/data_pack.cc39
-rw-r--r--ui/base/resource/data_pack.h21
-rw-r--r--ui/base/resource/data_pack_literal.cc15
-rw-r--r--ui/base/resource/data_pack_unittest.cc18
-rw-r--r--ui/base/resource/resource_bundle.cc18
14 files changed, 97 insertions, 190 deletions
diff --git a/chrome/browser/autofill/autofill_regexes.cc b/chrome/browser/autofill/autofill_regexes.cc
index 61b4fa0..b1ed629 100644
--- a/chrome/browser/autofill/autofill_regexes.cc
+++ b/chrome/browser/autofill/autofill_regexes.cc
@@ -81,3 +81,4 @@ bool MatchesPattern(const string16& input, const string16& pattern) {
}
} // namespace autofill
+
diff --git a/chrome/browser/prefs/pref_service_unittest.cc b/chrome/browser/prefs/pref_service_unittest.cc
index c1ebd2b..f2f6935 100644
--- a/chrome/browser/prefs/pref_service_unittest.cc
+++ b/chrome/browser/prefs/pref_service_unittest.cc
@@ -27,6 +27,31 @@
using testing::_;
using testing::Mock;
+// TODO(port): port this test to POSIX.
+#if defined(OS_WIN)
+TEST(PrefServiceTest, LocalizedPrefs) {
+ TestingPrefService prefs;
+ const char kBoolean[] = "boolean";
+ const char kInteger[] = "integer";
+ const char kString[] = "string";
+ prefs.RegisterLocalizedBooleanPref(kBoolean, IDS_LOCALE_BOOL);
+ prefs.RegisterLocalizedIntegerPref(kInteger, IDS_LOCALE_INT);
+ prefs.RegisterLocalizedStringPref(kString, IDS_LOCALE_STRING);
+
+ // The locale default should take preference over the user default.
+ EXPECT_FALSE(prefs.GetBoolean(kBoolean));
+ EXPECT_EQ(1, prefs.GetInteger(kInteger));
+ EXPECT_EQ("hello", prefs.GetString(kString));
+
+ prefs.SetBoolean(kBoolean, true);
+ EXPECT_TRUE(prefs.GetBoolean(kBoolean));
+ prefs.SetInteger(kInteger, 5);
+ EXPECT_EQ(5, prefs.GetInteger(kInteger));
+ prefs.SetString(kString, "foo");
+ EXPECT_EQ("foo", prefs.GetString(kString));
+}
+#endif
+
TEST(PrefServiceTest, NoObserverFire) {
TestingPrefService prefs;
diff --git a/chrome/browser/themes/browser_theme_pack.cc b/chrome/browser/themes/browser_theme_pack.cc
index d050ebe..d348077 100644
--- a/chrome/browser/themes/browser_theme_pack.cc
+++ b/chrome/browser/themes/browser_theme_pack.cc
@@ -29,7 +29,7 @@ namespace {
// Version number of the current theme pack. We just throw out and rebuild
// theme packs that aren't int-equal to this.
-const int kThemePackVersion = 18;
+const int kThemePackVersion = 17;
// IDs that are in the DataPack won't clash with the positive integer
// uint16. kHeaderID should always have the maximum value because we want the
@@ -450,7 +450,7 @@ bool BrowserThemePack::WriteToDisk(FilePath path) const {
RepackImages(prepared_images_, &reencoded_images);
AddRawImagesTo(reencoded_images, &resources);
- return ui::DataPack::WritePack(path, resources, ui::DataPack::BINARY);
+ return ui::DataPack::WritePack(path, resources);
}
bool BrowserThemePack::GetTint(int id, color_utils::HSL* hsl) const {
diff --git a/tools/data_pack/data_pack.py b/tools/data_pack/data_pack.py
index aeeeb78..93a6cfd 100755
--- a/tools/data_pack/data_pack.py
+++ b/tools/data_pack/data_pack.py
@@ -12,33 +12,25 @@ to point to grit scripts.
import struct
-FILE_FORMAT_VERSION = 4
-HEADER_LENGTH = 2 * 4 + 1 # Two uint32s. (file version, number of entries) and
- # one uint8 (encoding of text resources)
-BINARY, UTF8, UTF16 = range(3)
+FILE_FORMAT_VERSION = 3
+HEADER_LENGTH = 2 * 4 # Two uint32s. (file version and number of entries)
class WrongFileVersion(Exception):
pass
-class DataPackContents:
- def __init__(self, resources, encoding):
- self.resources = resources
- self.encoding = encoding
-
def ReadDataPack(input_file):
"""Reads a data pack file and returns a dictionary."""
data = open(input_file, "rb").read()
original_data = data
# Read the header.
- version, num_entries, encoding = struct.unpack("<IIB", data[:HEADER_LENGTH])
+ version, num_entries = struct.unpack("<II", data[:HEADER_LENGTH])
if version != FILE_FORMAT_VERSION:
- print "Wrong file version in ", input_file
raise WrongFileVersion
resources = {}
if num_entries == 0:
- return DataPackContents(resources, encoding)
+ return resources
# Read the index and data.
data = data[HEADER_LENGTH:]
@@ -49,15 +41,15 @@ def ReadDataPack(input_file):
next_id, next_offset = struct.unpack("<HI", data[:kIndexEntrySize])
resources[id] = original_data[offset:next_offset]
- return DataPackContents(resources, encoding)
+ return resources
-def WriteDataPack(resources, output_file, encoding):
+def WriteDataPack(resources, output_file):
"""Write a map of id=>data into output_file as a data pack."""
ids = sorted(resources.keys())
file = open(output_file, "wb")
# Write file header.
- file.write(struct.pack("<IIB", FILE_FORMAT_VERSION, len(ids), encoding))
+ file.write(struct.pack("<II", FILE_FORMAT_VERSION, len(ids)))
# Each entry is a uint16 and a uint32. We have one extra entry for the last
# item.
@@ -78,9 +70,9 @@ def WriteDataPack(resources, output_file, encoding):
def main():
# Just write a simple file.
data = { 1: "", 4: "this is id 4", 6: "this is id 6", 10: "" }
- WriteDataPack(data, "datapack1.pak", UTF8)
+ WriteDataPack(data, "datapack1.pak")
data2 = { 1000: "test", 5: "five" }
- WriteDataPack(data2, "datapack2.pak", UTF8)
+ WriteDataPack(data2, "datapack2.pak")
print "wrote datapack1 and datapack2 to current directory."
if __name__ == '__main__':
diff --git a/tools/data_pack/repack.py b/tools/data_pack/repack.py
index 335fe6f..2729b10 100755
--- a/tools/data_pack/repack.py
+++ b/tools/data_pack/repack.py
@@ -20,29 +20,17 @@ def RePack(output_file, input_files):
"""Write a new data pack to |output_file| based on a list of filenames
(|input_files|)"""
resources = {}
- encoding = None
for filename in input_files:
- new_content = data_pack.ReadDataPack(filename)
+ new_resources = data_pack.ReadDataPack(filename)
# Make sure we have no dups.
- duplicate_keys = set(new_content.resources.keys()) & set(resources.keys())
+ duplicate_keys = set(new_resources.keys()) & set(resources.keys())
if len(duplicate_keys) != 0:
raise exceptions.KeyError("Duplicate keys: " + str(list(duplicate_keys)))
- # Make sure encoding is consistent.
- if encoding in (None, data_pack.BINARY):
- encoding = new_content.encoding
- elif new_content.encoding not in (data_pack.BINARY, encoding):
- raise exceptions.KeyError("Inconsistent encodings: " +
- str(encoding) + " vs " +
- str(new_content.encoding))
+ resources.update(new_resources)
- resources.update(new_content.resources)
-
- # Encoding is 0 for BINARY, 1 for UTF8 and 2 for UTF16
- if encoding is None:
- encoding = data_pack.BINARY
- data_pack.WriteDataPack(resources, output_file, encoding)
+ data_pack.WriteDataPack(resources, output_file)
def main(argv):
if len(argv) < 3:
diff --git a/tools/grit/grit/format/data_pack.py b/tools/grit/grit/format/data_pack.py
index 87db064..01c0c9e 100755
--- a/tools/grit/grit/format/data_pack.py
+++ b/tools/grit/grit/format/data_pack.py
@@ -19,19 +19,12 @@ from grit.node import message
from grit.node import misc
-PACK_FILE_VERSION = 4
-HEADER_LENGTH = 2 * 4 + 1 # Two uint32s. (file version, number of entries) and
- # one uint8 (encoding of text resources)
-BINARY, UTF8, UTF16 = range(3)
+FILE_FORMAT_VERSION = 3
+HEADER_LENGTH = 2 * 4 # Two uint32s. (file version and number of entries)
class WrongFileVersion(Exception):
pass
-class DataPackContents:
- def __init__(self, resources, encoding):
- self.resources = resources
- self.encoding = encoding
-
class DataPack(interface.ItemFormatter):
'''Writes out the data pack file format (platform agnostic resource file).'''
def Format(self, item, lang='en', begin_item=True, output_dir='.'):
@@ -43,9 +36,9 @@ class DataPack(interface.ItemFormatter):
nodes = DataPack.GetDataNodes(item)
data = {}
for node in nodes:
- id, value = node.GetDataPackPair(lang, UTF8)
+ id, value = node.GetDataPackPair(lang)
data[id] = value
- return DataPack.WriteDataPackToString(data, UTF8)
+ return DataPack.WriteDataPackToString(data)
@staticmethod
def GetDataNodes(item):
@@ -70,15 +63,13 @@ class DataPack(interface.ItemFormatter):
original_data = data
# Read the header.
- version, num_entries, encoding = struct.unpack("<IIB",
- data[:HEADER_LENGTH])
- if version != PACK_FILE_VERSION:
- print "Wrong file version in ", input_file
+ version, num_entries = struct.unpack("<II", data[:HEADER_LENGTH])
+ if version != FILE_FORMAT_VERSION:
raise WrongFileVersion
resources = {}
if num_entries == 0:
- return DataPackContents(resources, encoding)
+ return resources
# Read the index and data.
data = data[HEADER_LENGTH:]
@@ -89,18 +80,18 @@ class DataPack(interface.ItemFormatter):
next_id, next_offset = struct.unpack("<HI", data[:kIndexEntrySize])
resources[id] = original_data[offset:next_offset]
- return DataPackContents(resources, encoding)
+ return resources
@staticmethod
- def WriteDataPackToString(resources, encoding):
+ def WriteDataPackToString(resources):
"""Write a map of id=>data into a string in the data pack format and return
it."""
ids = sorted(resources.keys())
ret = []
# Write file header.
- ret.append(struct.pack("<IIB", PACK_FILE_VERSION, len(ids), encoding))
- HEADER_LENGTH = 2 * 4 + 1 # Two uint32s and one uint8.
+ ret.append(struct.pack("<II", FILE_FORMAT_VERSION, len(ids)))
+ HEADER_LENGTH = 2 * 4 # Two uint32s.
# Each entry is a uint16 + a uint32s. We have one extra entry for the last
# item.
@@ -120,10 +111,10 @@ class DataPack(interface.ItemFormatter):
return ''.join(ret)
@staticmethod
- def WriteDataPack(resources, output_file, encoding):
+ def WriteDataPack(resources, output_file):
"""Write a map of id=>data into output_file as a data pack."""
file = open(output_file, "wb")
- content = DataPack.WriteDataPackToString(resources, encoding)
+ content = DataPack.WriteDataPackToString(resources)
file.write(content)
@staticmethod
@@ -131,37 +122,25 @@ class DataPack(interface.ItemFormatter):
"""Write a new data pack to |output_file| based on a list of filenames
(|input_files|)"""
resources = {}
- encoding = None
for filename in input_files:
- new_content = DataPack.ReadDataPack(filename)
+ new_resources = DataPack.ReadDataPack(filename)
- # Make sure we have no dups.
- duplicate_keys = set(new_content.resources.keys()) & set(resources.keys())
+ # Make sure we have no duplicates.
+ duplicate_keys = set(new_resources.keys()) & set(resources.keys())
if len(duplicate_keys) != 0:
raise exceptions.KeyError("Duplicate keys: " +
str(list(duplicate_keys)))
- # Make sure encoding is consistent.
- if encoding in (None, BINARY):
- encoding = new_content.encoding
- elif new_content.encoding not in (BINARY, encoding):
- raise exceptions.KeyError("Inconsistent encodings: " +
- str(encoding) + " vs " +
- str(new_content.encoding))
-
- resources.update(new_content.resources)
+ resources.update(new_resources)
- # Encoding is 0 for BINARY, 1 for UTF8 and 2 for UTF16
- if encoding is None:
- encoding = BINARY
- DataPack.WriteDataPack(resources, output_file, encoding)
+ DataPack.WriteDataPack(resources, output_file)
def main():
# Just write a simple file.
data = { 1: "", 4: "this is id 4", 6: "this is id 6", 10: "" }
- DataPack.WriteDataPack(data, "datapack1.pak", UTF8)
+ WriteDataPack(data, "datapack1.pak")
data2 = { 1000: "test", 5: "five" }
- DataPack.WriteDataPack(data2, "datapack2.pak", UTF8)
+ WriteDataPack(data2, "datapack2.pak")
print "wrote datapack1 and datapack2 to current directory."
if __name__ == '__main__':
diff --git a/tools/grit/grit/format/data_pack_unittest.py b/tools/grit/grit/format/data_pack_unittest.py
index 8de54ef..35966639 100644
--- a/tools/grit/grit/format/data_pack_unittest.py
+++ b/tools/grit/grit/format/data_pack_unittest.py
@@ -16,17 +16,15 @@ from grit.format import data_pack
class FormatDataPackUnittest(unittest.TestCase):
def testWriteDataPack(self):
expected = (
- '\x04\x00\x00\x00' # header(version
- '\x04\x00\x00\x00' # no. entries,
- '\x01' # encoding)
- '\x01\x00\x27\x00\x00\x00' # index entry 1
- '\x04\x00\x27\x00\x00\x00' # index entry 4
- '\x06\x00\x33\x00\x00\x00' # index entry 6
- '\x0a\x00\x3f\x00\x00\x00' # index entry 10
- '\x00\x00\x3f\x00\x00\x00' # extra entry for the size of last
+ '\x03\x00\x00\x00\x04\x00\x00\x00' # header (version, no. entries)
+ '\x01\x00\x26\x00\x00\x00' # index entry 1
+ '\x04\x00\x26\x00\x00\x00' # index entry 4
+ '\x06\x00\x32\x00\x00\x00' # index entry 6
+ '\x0a\x00\x3e\x00\x00\x00' # index entry 10
+ '\x00\x00\x3e\x00\x00\x00' # extra entry for the size of last
'this is id 4this is id 6') # data
input = { 1: "", 4: "this is id 4", 6: "this is id 6", 10: "" }
- output = data_pack.DataPack.WriteDataPackToString(input, data_pack.UTF8)
+ output = data_pack.DataPack.WriteDataPackToString(input)
self.failUnless(output == expected)
diff --git a/tools/grit/grit/node/include.py b/tools/grit/grit/node/include.py
index dc29315..b073bc7 100644
--- a/tools/grit/grit/node/include.py
+++ b/tools/grit/grit/node/include.py
@@ -74,7 +74,7 @@ class IncludeNode(base.Node):
'''
return self.FilenameToOpen()
- def GetDataPackPair(self, lang, encoding):
+ def GetDataPackPair(self, lang):
'''Returns a (id, string) pair that represents the resource id and raw
bytes of the data. This is used to generate the data pack data file.
'''
@@ -90,8 +90,6 @@ class IncludeNode(base.Node):
data = infile.read()
infile.close()
- # Include does not care about the encoding, because it only returns binary
- # data.
return id, data
def Flatten(self, output_dir):
@@ -138,3 +136,4 @@ class IncludeNode(base.Node):
node.EndParsing()
return node
Construct = staticmethod(Construct)
+
diff --git a/tools/grit/grit/node/message.py b/tools/grit/grit/node/message.py
index 3c5ac64..a48a645 100644
--- a/tools/grit/grit/node/message.py
+++ b/tools/grit/grit/node/message.py
@@ -1,5 +1,5 @@
#!/usr/bin/python2.4
-# Copyright (c) 2011 The Chromium Authors. All rights reserved.
+# Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
@@ -19,7 +19,6 @@ from grit import exception
from grit import tclib
from grit import util
-BINARY, UTF8, UTF16 = range(3)
# Finds whitespace at the start and end of a string which can be multiline.
_WHITESPACE = re.compile('(?P<start>\s*)(?P<body>.+?)(?P<end>\s*)\Z',
@@ -187,7 +186,7 @@ class MessageNode(base.ContentNode):
else:
return self.attrs['offset']
- def GetDataPackPair(self, lang, encoding):
+ def GetDataPackPair(self, lang):
'''Returns a (id, string) pair that represents the string id and the string
in utf8. This is used to generate the data pack data file.
'''
@@ -200,15 +199,10 @@ class MessageNode(base.ContentNode):
# Windows automatically translates \n to a new line, but GTK+ doesn't.
# Manually do the conversion here rather than at run time.
message = message.replace("\\n", "\n")
- # |message| is a python unicode string, so convert to a byte stream that
- # has the correct encoding requested for the datapacks. We skip the first
- # 2 bytes of text resources because it is the BOM.
- if encoding == UTF8:
- return id, message.encode('utf8')
- if encoding == UTF16:
- return id, message.encode('utf16')[2:]
- # Default is BINARY
- return id, message
+ # |message| is a python unicode string, so convert to a utf16 byte stream
+ # because that's the format of datapacks. We skip the first 2 bytes
+ # because it is the BOM.
+ return id, message.encode('utf16')[2:]
# static method
def Construct(parent, message, name, desc='', meaning='', translateable=True):
diff --git a/ui/base/resource/data_pack.cc b/ui/base/resource/data_pack.cc
index 5a0dcf1..c4b1594 100644
--- a/ui/base/resource/data_pack.cc
+++ b/ui/base/resource/data_pack.cc
@@ -17,9 +17,9 @@
namespace {
-static const uint32 kFileFormatVersion = 4;
-// Length of file header: version, entry count and text encoding type.
-static const size_t kHeaderLength = 2 * sizeof(uint32) + sizeof(uint8);
+static const uint32 kFileFormatVersion = 3;
+// Length of file header: version and entry count.
+static const size_t kHeaderLength = 2 * sizeof(uint32);
#pragma pack(push,2)
struct DataPackEntry {
@@ -60,7 +60,7 @@ enum LoadErrors {
namespace ui {
// In .cc for MemoryMappedFile dtor.
-DataPack::DataPack() : resource_count_(0), text_encoding_type_(BINARY) {
+DataPack::DataPack() : resource_count_(0) {
}
DataPack::~DataPack() {
}
@@ -83,7 +83,7 @@ bool DataPack::Load(const FilePath& path) {
}
// Parse the header of the file.
- // First uint32: version; second: resource count;
+ // First uint32: version; second: resource count.
const uint32* ptr = reinterpret_cast<const uint32*>(mmap_->data());
uint32 version = ptr[0];
if (version != kFileFormatVersion) {
@@ -96,17 +96,6 @@ bool DataPack::Load(const FilePath& path) {
}
resource_count_ = ptr[1];
- // third: text encoding.
- const uint8* ptr_encoding = reinterpret_cast<const uint8*>(ptr + 2);
- text_encoding_type_ = static_cast<TextEncodingType>(*ptr_encoding);
- if (text_encoding_type_ != UTF8 && text_encoding_type_ != UTF16 &&
- text_encoding_type_ != BINARY) {
- LOG(ERROR) << "Bad data pack text encoding: got " << text_encoding_type_
- << ", expected between " << BINARY << " and " << UTF16;
- mmap_.reset();
- return false;
- }
-
// Sanity check the file.
// 1) Check we have enough entries.
if (kHeaderLength + resource_count_ * sizeof(DataPackEntry) >
@@ -174,8 +163,7 @@ RefCountedStaticMemory* DataPack::GetStaticMemory(uint16 resource_id) const {
// static
bool DataPack::WritePack(const FilePath& path,
- const std::map<uint16, base::StringPiece>& resources,
- TextEncodingType textEncodingType) {
+ const std::map<uint16, base::StringPiece>& resources) {
FILE* file = file_util::OpenFile(path, "wb");
if (!file)
return false;
@@ -195,21 +183,6 @@ bool DataPack::WritePack(const FilePath& path,
return false;
}
- if (textEncodingType != UTF8 && textEncodingType != UTF16 &&
- textEncodingType != BINARY) {
- LOG(ERROR) << "Invalid text encoding type, got " << textEncodingType
- << ", expected between " << BINARY << " and " << UTF16;
- file_util::CloseFile(file);
- return false;
- }
-
- uint8 write_buffer = textEncodingType;
- if (fwrite(&write_buffer, sizeof(uint8), 1, file) != 1) {
- LOG(ERROR) << "Failed to write file text resources encoding";
- file_util::CloseFile(file);
- return false;
- }
-
// Each entry is a uint16 + a uint32. We have an extra entry after the last
// item so we can compute the size of the list item.
uint32 index_length = (entry_count + 1) * sizeof(DataPackEntry);
diff --git a/ui/base/resource/data_pack.h b/ui/base/resource/data_pack.h
index 0cc3b31..f6ee78d 100644
--- a/ui/base/resource/data_pack.h
+++ b/ui/base/resource/data_pack.h
@@ -31,13 +31,6 @@ namespace ui {
class UI_EXPORT DataPack {
public:
- // What type of encoding the text resources use.
- enum TextEncodingType {
- BINARY,
- UTF8,
- UTF16
- };
-
DataPack();
~DataPack();
@@ -54,16 +47,9 @@ class UI_EXPORT DataPack {
// for localization strings.
RefCountedStaticMemory* GetStaticMemory(uint16 resource_id) const;
- // Writes a pack file containing |resources| to |path|. If there are any
- // text resources to be written, their encoding must already agree to the
- // |textEncodingType| specified. If no text resources are present, please
- // indicate BINARY.
+ // Writes a pack file containing |resources| to |path|.
static bool WritePack(const FilePath& path,
- const std::map<uint16, base::StringPiece>& resources,
- TextEncodingType textEncodingType);
-
- // Get the encoding type of text resources.
- TextEncodingType GetTextEncodingType() const { return text_encoding_type_; }
+ const std::map<uint16, base::StringPiece>& resources);
private:
// The memory-mapped data.
@@ -72,9 +58,6 @@ class UI_EXPORT DataPack {
// Number of resources in the data.
size_t resource_count_;
- // Type of encoding for text resources.
- TextEncodingType text_encoding_type_;
-
DISALLOW_COPY_AND_ASSIGN(DataPack);
};
diff --git a/ui/base/resource/data_pack_literal.cc b/ui/base/resource/data_pack_literal.cc
index 510d07a..4a32fa9 100644
--- a/ui/base/resource/data_pack_literal.cc
+++ b/ui/base/resource/data_pack_literal.cc
@@ -7,14 +7,13 @@
namespace ui {
extern const char kSamplePakContents[] = {
- 0x04, 0x00, 0x00, 0x00, // header(version
- 0x04, 0x00, 0x00, 0x00, // no. entries
- 0x01, // encoding)
- 0x01, 0x00, 0x27, 0x00, 0x00, 0x00, // index entry 1
- 0x04, 0x00, 0x27, 0x00, 0x00, 0x00, // index entry 4
- 0x06, 0x00, 0x33, 0x00, 0x00, 0x00, // index entry 6
- 0x0a, 0x00, 0x3f, 0x00, 0x00, 0x00, // index entry 10
- 0x00, 0x00, 0x3f, 0x00, 0x00, 0x00, // extra entry for the size of last
+ 0x03, 0x00, 0x00, 0x00, // header(version
+ 0x04, 0x00, 0x00, 0x00, // no. entries)
+ 0x01, 0x00, 0x26, 0x00, 0x00, 0x00, // index entry 1
+ 0x04, 0x00, 0x26, 0x00, 0x00, 0x00, // index entry 4
+ 0x06, 0x00, 0x32, 0x00, 0x00, 0x00, // index entry 6
+ 0x0a, 0x00, 0x3e, 0x00, 0x00, 0x00, // index entry 10
+ 0x00, 0x00, 0x3e, 0x00, 0x00, 0x00, // extra entry for the size of last
't', 'h', 'i', 's', ' ', 'i', 's', ' ', 'i', 'd', ' ', '4',
't', 'h', 'i', 's', ' ', 'i', 's', ' ', 'i', 'd', ' ', '6'
};
diff --git a/ui/base/resource/data_pack_unittest.cc b/ui/base/resource/data_pack_unittest.cc
index 1c0bd7a..fe3613c 100644
--- a/ui/base/resource/data_pack_unittest.cc
+++ b/ui/base/resource/data_pack_unittest.cc
@@ -12,12 +12,6 @@
namespace ui {
-class DataPackTest
- : public testing::TestWithParam<DataPack::TextEncodingType> {
- public:
- DataPackTest() {}
-};
-
extern const char kSamplePakContents[];
extern const size_t kSamplePakSize;
@@ -50,13 +44,6 @@ TEST(DataPackTest, Load) {
ASSERT_FALSE(pack.GetStringPiece(140, &data));
}
-INSTANTIATE_TEST_CASE_P(WriteBINARY, DataPackTest, ::testing::Values(
- DataPack::BINARY));
-INSTANTIATE_TEST_CASE_P(WriteUTF8, DataPackTest, ::testing::Values(
- DataPack::UTF8));
-INSTANTIATE_TEST_CASE_P(WriteUTF16, DataPackTest, ::testing::Values(
- DataPack::UTF16));
-
TEST(DataPackTest, LoadFileWithTruncatedHeader) {
FilePath data_path;
PathService::Get(base::DIR_SOURCE_ROOT, &data_path);
@@ -67,7 +54,7 @@ TEST(DataPackTest, LoadFileWithTruncatedHeader) {
ASSERT_FALSE(pack.Load(data_path));
}
-TEST_P(DataPackTest, Write) {
+TEST(DataPackTest, Write) {
ScopedTempDir dir;
ASSERT_TRUE(dir.CreateUniqueTempDir());
FilePath file = dir.path().Append(FILE_PATH_LITERAL("data.pak"));
@@ -84,12 +71,11 @@ TEST_P(DataPackTest, Write) {
resources.insert(std::make_pair(15, base::StringPiece(fifteen)));
resources.insert(std::make_pair(3, base::StringPiece(three)));
resources.insert(std::make_pair(4, base::StringPiece(four)));
- ASSERT_TRUE(DataPack::WritePack(file, resources, GetParam()));
+ ASSERT_TRUE(DataPack::WritePack(file, resources));
// Now try to read the data back in.
DataPack pack;
ASSERT_TRUE(pack.Load(file));
- EXPECT_EQ(pack.GetTextEncodingType(), GetParam());
base::StringPiece data;
ASSERT_TRUE(pack.GetStringPiece(1, &data));
diff --git a/ui/base/resource/resource_bundle.cc b/ui/base/resource/resource_bundle.cc
index a030251..04cf392 100644
--- a/ui/base/resource/resource_bundle.cc
+++ b/ui/base/resource/resource_bundle.cc
@@ -11,7 +11,6 @@
#include "base/stl_util.h"
#include "base/string_piece.h"
#include "base/synchronization/lock.h"
-#include "base/utf_string_conversions.h"
#include "build/build_config.h"
#include "third_party/skia/include/core/SkBitmap.h"
#include "ui/base/l10n/l10n_util.h"
@@ -186,19 +185,10 @@ string16 ResourceBundle::GetLocalizedString(int message_id) {
}
}
- // Strings should not be loaded from a data pack that contains binary data.
- DCHECK(locale_resources_data_->GetTextEncodingType() == DataPack::UTF16 ||
- locale_resources_data_->GetTextEncodingType() == DataPack::UTF8)
- << "requested localized string from binary pack file";
-
- // Data pack encodes strings as either UTF8 or UTF16.
- string16 msg;
- if (locale_resources_data_->GetTextEncodingType() == DataPack::UTF16) {
- msg = string16(reinterpret_cast<const char16*>(data.data()),
- data.length() / 2);
- } else if (locale_resources_data_->GetTextEncodingType() == DataPack::UTF8) {
- msg = UTF8ToUTF16(data);
- }
+ // Data pack encodes strings as UTF16.
+ DCHECK_EQ(data.length() % 2, 0U);
+ string16 msg(reinterpret_cast<const char16*>(data.data()),
+ data.length() / 2);
return msg;
}