1 /*
2  * Copyright (C) 2011 Apple Inc. All Rights Reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  */
25 
26 #ifndef LocalizedDate_h
27 #define LocalizedDate_h
28 
29 #include "DateComponents.h"
30 #include <wtf/text/WTFString.h>
31 
32 namespace WebCore {
33 
34 // Parses a string representation of a date string localized
35 // for the browser's current locale for a particular date type.
36 // If the input string is not valid or an implementation doesn't
37 // support localized dates, this function returns NaN. If the
38 // input string is valid this function returns the number
39 // of milliseconds since 1970-01-01 00:00:00.000 UTC.
40 double parseLocalizedDate(const String&, DateComponents::Type);
41 
42 // Serializes the specified date into a formatted date string
43 // to display to the user. If an implementation doesn't support
44 // localized dates the function should return an empty string.
45 String formatLocalizedDate(const DateComponents& dateComponents);
46 
47 } // namespace WebCore
48 
49 #endif // LocalizedDate_h
50