| Index: base/file_util_posix.cc
|
| ===================================================================
|
| --- base/file_util_posix.cc (revision 28219)
|
| +++ base/file_util_posix.cc (working copy)
|
| @@ -35,57 +35,7 @@
|
| #include "base/sys_string_conversions.h"
|
| #include "base/time.h"
|
| #include "base/utf_string_conversions.h"
|
| -#include "unicode/coll.h"
|
|
|
| -
|
| -namespace {
|
| -
|
| -class LocaleAwareComparator {
|
| - public:
|
| - LocaleAwareComparator() {
|
| - UErrorCode error_code = U_ZERO_ERROR;
|
| - // Use the default collator. The default locale should have been properly
|
| - // set by the time this constructor is called.
|
| - collator_.reset(icu::Collator::createInstance(error_code));
|
| - DCHECK(U_SUCCESS(error_code));
|
| - // Make it case-sensitive.
|
| - collator_->setStrength(icu::Collator::TERTIARY);
|
| - // Note: We do not set UCOL_NORMALIZATION_MODE attribute. In other words, we
|
| - // do not pay performance penalty to guarantee sort order correctness for
|
| - // non-FCD (http://unicode.org/notes/tn5/#FCD) file names. This should be a
|
| - // reasonable tradeoff because such file names should be rare and the sort
|
| - // order doesn't change much anyway.
|
| - }
|
| -
|
| - // Note: A similar function is available in l10n_util.
|
| - // We cannot use it because base should not depend on l10n_util.
|
| - // TODO(yuzo): Move some of l10n_util to base.
|
| - int Compare(const string16& a, const string16& b) {
|
| - // We are not sure if Collator::compare is thread-safe.
|
| - // Use an AutoLock just in case.
|
| - AutoLock auto_lock(lock_);
|
| -
|
| - UErrorCode error_code = U_ZERO_ERROR;
|
| - UCollationResult result = collator_->compare(
|
| - static_cast<const UChar*>(a.c_str()),
|
| - static_cast<int>(a.length()),
|
| - static_cast<const UChar*>(b.c_str()),
|
| - static_cast<int>(b.length()),
|
| - error_code);
|
| - DCHECK(U_SUCCESS(error_code));
|
| - return result;
|
| - }
|
| -
|
| - private:
|
| - scoped_ptr<icu::Collator> collator_;
|
| - Lock lock_;
|
| - friend struct DefaultSingletonTraits<LocaleAwareComparator>;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(LocaleAwareComparator);
|
| -};
|
| -
|
| -} // namespace
|
| -
|
| namespace file_util {
|
|
|
| #if defined(OS_FREEBSD) || \
|
| @@ -623,9 +573,6 @@
|
| if (!ReadDirectory(&entries, root_path_, file_type_ & SHOW_SYM_LINKS))
|
| continue;
|
|
|
| - // The API says that order is not guaranteed, but order affects UX
|
| - std::sort(entries.begin(), entries.end(), CompareFiles);
|
| -
|
| directory_entries_.clear();
|
| current_directory_entry_ = 0;
|
| for (std::vector<DirectoryEntryInfo>::const_iterator
|
| @@ -691,23 +638,6 @@
|
| return true;
|
| }
|
|
|
| -bool FileEnumerator::CompareFiles(const DirectoryEntryInfo& a,
|
| - const DirectoryEntryInfo& b) {
|
| - // Order lexicographically with directories before other files.
|
| - if (S_ISDIR(a.stat.st_mode) != S_ISDIR(b.stat.st_mode))
|
| - return S_ISDIR(a.stat.st_mode);
|
| -
|
| - // On linux, the file system encoding is not defined. We assume
|
| - // SysNativeMBToWide takes care of it.
|
| - //
|
| - // ICU's collator can take strings in OS native encoding. But we convert the
|
| - // strings to UTF-16 ourselves to ensure conversion consistency.
|
| - // TODO(yuzo): Perhaps we should define SysNativeMBToUTF16?
|
| - return Singleton<LocaleAwareComparator>()->Compare(
|
| - WideToUTF16(base::SysNativeMBToWide(a.filename.value().c_str())),
|
| - WideToUTF16(base::SysNativeMBToWide(b.filename.value().c_str()))) < 0;
|
| -}
|
| -
|
| ///////////////////////////////////////////////
|
| // MemoryMappedFile
|
|
|
|
|