Imported Upstream version 1.0.0
[platform/upstream/js.git] / js / src / jsdate.h
1 /* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2  *
3  * ***** BEGIN LICENSE BLOCK *****
4  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
5  *
6  * The contents of this file are subject to the Mozilla Public License Version
7  * 1.1 (the "License"); you may not use this file except in compliance with
8  * the License. You may obtain a copy of the License at
9  * http://www.mozilla.org/MPL/
10  *
11  * Software distributed under the License is distributed on an "AS IS" basis,
12  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
13  * for the specific language governing rights and limitations under the
14  * License.
15  *
16  * The Original Code is Mozilla Communicator client code, released
17  * March 31, 1998.
18  *
19  * The Initial Developer of the Original Code is
20  * Netscape Communications Corporation.
21  * Portions created by the Initial Developer are Copyright (C) 1998
22  * the Initial Developer. All Rights Reserved.
23  *
24  * Contributor(s):
25  *
26  * Alternatively, the contents of this file may be used under the terms of
27  * either of the GNU General Public License Version 2 or later (the "GPL"),
28  * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
29  * in which case the provisions of the GPL or the LGPL are applicable instead
30  * of those above. If you wish to allow use of your version of this file only
31  * under the terms of either the GPL or the LGPL, and not to allow others to
32  * use your version of this file under the terms of the MPL, indicate your
33  * decision by deleting the provisions above and replace them with the notice
34  * and other provisions required by the GPL or the LGPL. If you do not delete
35  * the provisions above, a recipient may use your version of this file under
36  * the terms of any one of the MPL, the GPL or the LGPL.
37  *
38  * ***** END LICENSE BLOCK ***** */
39
40 /*
41  * JS Date class interface.
42  */
43
44 #ifndef jsdate_h___
45 #define jsdate_h___
46
47 #include "jsobj.h"
48
49 extern js::Class js_DateClass;
50
51 inline bool
52 JSObject::isDate() const
53 {
54     return getClass() == &js_DateClass;
55 }
56
57 #define HalfTimeDomain  8.64e15
58
59 #define TIMECLIP(d) ((JSDOUBLE_IS_FINITE(d) \
60                       && !((d < 0 ? -d : d) > HalfTimeDomain)) \
61                      ? js_DoubleToInteger(d + (+0.)) : js_NaN)
62
63 extern JSObject *
64 js_InitDateClass(JSContext *cx, JSObject *obj);
65
66 /*
67  * These functions provide a C interface to the date/time object
68  */
69
70 /*
71  * Construct a new Date Object from a time value given in milliseconds UTC
72  * since the epoch.
73  */
74 extern JS_FRIEND_API(JSObject*)
75 js_NewDateObjectMsec(JSContext* cx, jsdouble msec_time);
76
77 /*
78  * Construct a new Date Object from an exploded local time value.
79  *
80  * Assert that mon < 12 to help catch off-by-one user errors, which are common
81  * due to the 0-based month numbering copied into JS from Java (java.util.Date
82  * in 1995).
83  */
84 extern JS_FRIEND_API(JSObject*)
85 js_NewDateObject(JSContext* cx, int year, int mon, int mday,
86                  int hour, int min, int sec);
87
88 /*
89  * Detect whether the internal date value is NaN.  (Because failure is
90  * out-of-band for js_DateGet*)
91  */
92 extern JS_FRIEND_API(JSBool)
93 js_DateIsValid(JSContext *cx, JSObject* obj);
94
95 extern JS_FRIEND_API(int)
96 js_DateGetYear(JSContext *cx, JSObject* obj);
97
98 extern JS_FRIEND_API(int)
99 js_DateGetMonth(JSContext *cx, JSObject* obj);
100
101 extern JS_FRIEND_API(int)
102 js_DateGetDate(JSContext *cx, JSObject* obj);
103
104 extern JS_FRIEND_API(int)
105 js_DateGetHours(JSContext *cx, JSObject* obj);
106
107 extern JS_FRIEND_API(int)
108 js_DateGetMinutes(JSContext *cx, JSObject* obj);
109
110 extern JS_FRIEND_API(int)
111 js_DateGetSeconds(JSContext *cx, JSObject* obj);
112
113 extern JS_FRIEND_API(jsdouble)
114 js_DateGetMsecSinceEpoch(JSContext *cx, JSObject *obj);
115
116 typedef uint32 JSIntervalTime;
117
118 extern JS_FRIEND_API(JSIntervalTime)
119 js_IntervalNow();
120
121 /* Date constructor native. Exposed only so the JIT can know its address. */
122 JSBool
123 js_Date(JSContext *cx, uintN argc, js::Value *vp);
124
125 #endif /* jsdate_h___ */