// 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. #include "base/time_format.h" #include "base/logging.h" #include "base/scoped_ptr.h" #include "base/string_util.h" #include "base/time.h" #include "unicode/datefmt.h" using base::Time; namespace { std::wstring TimeFormat(const DateFormat* formatter, const Time& time) { DCHECK(formatter); UnicodeString date_string; formatter->format(static_cast(time.ToDoubleT() * 1000), date_string); std::wstring output; bool success = UTF16ToWide(date_string.getBuffer(), date_string.length(), &output); DCHECK(success); return output; } } namespace base { std::wstring TimeFormatTimeOfDay(const Time& time) { // We can omit the locale parameter because the default should match // Chrome's application locale. scoped_ptr formatter(DateFormat::createTimeInstance( DateFormat::kShort)); return TimeFormat(formatter.get(), time); } std::wstring TimeFormatShortDate(const Time& time) { scoped_ptr formatter(DateFormat::createDateInstance( DateFormat::kMedium)); return TimeFormat(formatter.get(), time); } std::wstring TimeFormatShortDateNumeric(const Time& time) { scoped_ptr formatter(DateFormat::createDateInstance( DateFormat::kShort)); return TimeFormat(formatter.get(), time); } std::wstring TimeFormatShortDateAndTime(const Time& time) { scoped_ptr formatter(DateFormat::createDateTimeInstance( DateFormat::kShort)); return TimeFormat(formatter.get(), time); } std::wstring TimeFormatFriendlyDateAndTime(const Time& time) { scoped_ptr formatter(DateFormat::createDateTimeInstance( DateFormat::kFull)); return TimeFormat(formatter.get(), time); } std::wstring TimeFormatFriendlyDate(const Time& time) { scoped_ptr formatter(DateFormat::createDateInstance( DateFormat::kFull)); return TimeFormat(formatter.get(), time); } } // namespace base