X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b236c10f77e9ed0bc3c16d1cceb4a62f7048b4f9..6d0f32ddb8e1aec3b8707db31ed244758c242672:/docs/latex/wx/datetime.tex diff --git a/docs/latex/wx/datetime.tex b/docs/latex/wx/datetime.tex index a9bff2b6b1..dd67d84bd7 100644 --- a/docs/latex/wx/datetime.tex +++ b/docs/latex/wx/datetime.tex @@ -6,7 +6,7 @@ %% Created: 07.03.00 %% RCS-ID: $Id$ %% Copyright: (c) Vadim Zeitlin -%% License: wxWidgets license +%% License: wxWindows license %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \section{\class{wxDateTime}}\label{wxdatetime} @@ -43,7 +43,7 @@ Time zone symbolic names: GMT_6, GMT_5, GMT_4, GMT_3, GMT_2, GMT_1, GMT0, GMT1, GMT2, GMT3, GMT4, GMT5, GMT6, - GMT7, GMT8, GMT9, GMT10, GMT11, GMT12, + GMT7, GMT8, GMT9, GMT10, GMT11, GMT12, GMT13, // Note that GMT12 and GMT_12 are not the same: there is a difference // of exactly one day between them @@ -77,10 +77,14 @@ Time zone symbolic names: // Australia A_WST = GMT8, // Western Standard Time - A_CST = GMT12 + 1, // Central Standard Time (+9.5) + A_CST = GMT13 + 1, // Central Standard Time (+9.5) A_EST = GMT10, // Eastern Standard Time A_ESST = GMT11, // Eastern Summer Time + // New Zealand + NZST = GMT12, // Standard Time + NZDT = GMT13, // Daylight Saving Time + // Universal Coordinated Time = the new and politically correct name // for GMT UTC = GMT0 @@ -97,7 +101,7 @@ Likewise, Sun, Mon, Tue, Wed, Thu, Fri, Sat, and Inv\_WeekDay are the values in Finally, Inv\_Year is defined to be an invalid value for year parameter. \helpref{GetMonthName()}{wxdatetimegetmonthname} and -\helpref{GetWeekDayName}{wxdatetimegetweekdayname} functions use the followign +\helpref{GetWeekDayName}{wxdatetimegetweekdayname} functions use the following flags: \begin{verbatim} @@ -121,7 +125,7 @@ parameters is one of the following values: \end{verbatim} Date calculations often depend on the country and wxDateTime allows to set the -country whose conventions should be used using +country whose conventions should be used using \helpref{SetCountry}{wxdatetimesetcountry}. It takes one of the following values as parameter: @@ -148,7 +152,7 @@ values as parameter: Different parts of the world use different conventions for the week start. In some countries, the week starts on Sunday, while in others -- on Monday. The ISO standard doesn't address this issue, so we support both conventions in -the functions whose result depends on it (\helpref{GetWeekOfYear}{wxdatetimegetweekofyear} and +the functions whose result depends on it (\helpref{GetWeekOfYear}{wxdatetimegetweekofyear} and \helpref{GetWeekOfMonth}{wxdatetimegetweekofmonth}). The desired behvaiour may be specified by giving one of the following @@ -171,6 +175,10 @@ No base class +\wxheading{Library} + +\helpref{wxBase}{librarieslist} + \wxheading{See also} \helpref{Date classes overview}{wxdatetimeoverview},\rtfsp @@ -192,7 +200,7 @@ Please note that although several function accept an extra {\it Calendar} parameter, it is currently ignored as only the Gregorian calendar is supported. Future versions will support other calendars. -\pythonnote{These methods are standalone functions named +\pythonnote{These methods are standalone functions named {\tt wxDateTime\_} in wxPython.} \helpref{SetCountry}{wxdatetimesetcountry}\\ @@ -202,7 +210,7 @@ supported. Future versions will support other calendars. \helpref{ConvertYearToBC}{wxdatetimeconvertyeartobc}\\ \helpref{GetCurrentMonth}{wxdatetimegetcurrentmonth}\\ \helpref{IsLeapYear}{wxdatetimeisleapyear}\\ -\helpref{GetCentury}{wxdatetimegetcentury}\\ +\helpref{GetCentury}{wxdatetimegetcenturystatic}\\ \helpref{GetNumberOfDays}{wxdatetimegetnumberofdays}\\ \helpref{GetNumberOfDays}{wxdatetimegetnumberofdays}\\ \helpref{GetMonthName}{wxdatetimegetmonthname}\\ @@ -253,11 +261,12 @@ values were correct as constructors can not return an error code. \membersection{Accessors}\label{datetimeaccessors} Here are the trivial accessors. Other functions, which might have to perform -some more complicated calculations to find the answer are under the +some more complicated calculations to find the answer are under the \helpref{Calendar calculations}{datetimecalculations} section. \helpref{IsValid}{wxdatetimeisvalid}\\ \helpref{GetTicks}{wxdatetimegetticks}\\ +\helpref{GetCentury}{wxdatetimegetcentury}\\ \helpref{GetYear}{wxdatetimegetyear}\\ \helpref{GetMonth}{wxdatetimegetmonth}\\ \helpref{GetDay}{wxdatetimegetday}\\ @@ -298,7 +307,7 @@ added to wxDateTime, hence all functions are overloaded to accept both arguments. Also, both {\tt Add()} and {\tt Subtract()} have both const and non-const -version. The first one returns a new obejct which represents the +version. The first one returns a new object which represents the sum/difference of the original one with the argument while the second form modifies the object to which it is applied. The operators $-=$ and $+=$ are defined to be equivalent to the second forms of these functions. @@ -316,36 +325,44 @@ defined to be equivalent to the second forms of these functions. \membersection{Parsing and formatting dates}\label{datetimeparsing} -These functions convert wxDateTime obejcts to and from text. The +These functions convert wxDateTime objects to and from text. The conversions to text are mostly trivial: you can either do it using the default -date and time representations for the current locale ( -\helpref{FormatDate}{wxdatetimeformatdate} and +date and time representations for the current locale ( +\helpref{FormatDate}{wxdatetimeformatdate} and \helpref{FormatTime}{wxdatetimeformattime}), using the international standard -representation defined by ISO 8601 ( -\helpref{FormatISODate}{wxdatetimeformatisodate} and +representation defined by ISO 8601 ( +\helpref{FormatISODate}{wxdatetimeformatisodate} and \helpref{FormatISOTime}{wxdatetimeformatisotime}) or by specifying any format at all and using \helpref{Format}{wxdatetimeformat} directly. The conversions from text are more interesting, as there are much more -possibilities to care about. The simplest cases can be taken care of with +possibilities to care about. The simplest cases can be taken care of with \helpref{ParseFormat}{wxdatetimeparseformat} which can parse any date in the given (rigid) format. \helpref{ParseRfc822Date}{wxdatetimeparserfc822date} is another function for parsing dates in predefined format -- the one of RFC 822 which (still...) defines the format of email messages on the Internet. This -format can not be described with {\tt strptime(3)}-like format strings used by +format can not be described with {\tt strptime(3)}-like format strings used by \helpref{Format}{wxdatetimeformat}, hence the need for a separate function. -But the most interesting functions are -\helpref{ParseTime}{wxdatetimeparsetime}, -\helpref{ParseDate}{wxdatetimeparsedate} and +But the most interesting functions are +\helpref{ParseTime}{wxdatetimeparsetime}, +\helpref{ParseDate}{wxdatetimeparsedate} and \helpref{ParseDateTime}{wxdatetimeparsedatetime}. They try to parse the date ans time (or only one of them) in `free' format, i.e. allow them to be specified in any of possible ways. These functions will usually be used to parse the (interactive) user input which is not bound to be in any predefined format. As an example, \helpref{ParseDateTime}{wxdatetimeparsedatetime} can -parse the strings such as {\tt "tomorrow"}, {\tt "March first"} and even +parse the strings such as {\tt "tomorrow"}, {\tt "March first"} and even {\tt "next Sunday"}. +Finally notice that each of the parsing functions is available in several +overloads: if the input string is a narrow (\texttt{char *}) string, then a +narrow pointer is returned. If the input string is a wide string, a wide char +pointer is returned. Finally, if the input parameter is a wxString, a narrow +char pointer is also returned for backwards compatibility but there is also an +additional argument of wxString::const\_iterator type in which, if it is not +\NULL, an iterator pointing to the end of the scanned string part is returned. + \helpref{ParseRfc822Date}{wxdatetimeparserfc822date}\\ \helpref{ParseFormat}{wxdatetimeparseformat}\\ \helpref{ParseDateTime}{wxdatetimeparsedatetime}\\ @@ -404,12 +421,14 @@ provided. You can construct a wxDateTime object from a \membersection{Time zone and DST support}\label{datetimedstzone} Please see the \helpref{time zone overview}{tdatetimezones} for more -information about time zones. ormally, these functions should be rarely used. +information about time zones. Normally, these functions should be rarely used. +\helpref{FromTimezone}{wxdatetimefromtimezone}\\ \helpref{ToTimezone}{wxdatetimetotimezone}\\ \helpref{MakeTimezone}{wxdatetimemaketimezone}\\ -\helpref{ToGMT}{wxdatetimetogmt}\\ -\helpref{MakeGMT}{wxdatetimemakegmt}\\ +\helpref{MakeFromTimezone}{wxdatetimemakefromtimezone}\\ +\helpref{ToUTC}{wxdatetimetoutc}\\ +\helpref{MakeUTC}{wxdatetimemakeutc}\\ \helpref{GetBeginDST}{wxdatetimegetbegindst}\\ \helpref{GetEndDST}{wxdatetimegetenddst}\\ \helpref{IsDST}{wxdatetimeisdst} @@ -489,9 +508,9 @@ Get the current year in given calendar (only Gregorian is currently supported). Get the current month in given calendar (only Gregorian is currently supported). -\membersection{wxDateTime::GetCentury}\label{wxdatetimegetcentury} +\membersection{wxDateTime::GetCentury}\label{wxdatetimegetcenturystatic} -\func{static int}{GetCentury}{\param{int }{year = Inv\_Year}} +\func{static int}{GetCentury}{\param{int }{year}} Get the current century, i.e. first two digits of the year, in given calendar (only Gregorian is currently supported). @@ -536,6 +555,31 @@ The only supported value for {\it cal} parameter is currently {\tt Gregorian}. and {\tt GetNumberOfDaysInMonth} in wxPython.} +\membersection{wxDateTime::GetTimeNow}\label{wxdatetimegettimenow} + +\func{static time\_t}{GetTimeNow}{\void} + +Returns the current time. + + +\membersection{wxDateTime::GetTmNow}\label{wxdatetimegettmnow} + +\func{static struct tm *}{GetTmNow}{\param{struct tm *}{tm}} + +Returns the current time broken down, uses the buffer whose adress is +passed to the function via {\it tm} to store the result. + +\membersection{wxDateTime::GetTmNow} + +\func{static struct tm *}{GetTmNow}{\void} + +Returns the current time broken down. Note that this function returns a +pointer to a static buffer that's reused by calls to this function and +certain C library functions (e.g. localtime). If there is any chance your +code might be used in a multi-threaded application, you really should use +the flavour of function \helpref{wxDateTime::GetTmNow}{wxdatetimegettmnow} +taking a parameter. + \membersection{wxDateTime::GetWeekDayName}\label{wxdatetimegetweekdayname} \func{static wxString}{GetWeekDayName}{\param{WeekDay }{weekday}, \param{NameFlags }{flags = Name\_Full}} @@ -587,7 +631,7 @@ Example: printf("Current time in Paris:\t%s\n", now.Format("%c", wxDateTime::CET).c_str()); \end{verbatim} -Note that this function is accurate up to second: +Note that this function is accurate up to second: \helpref{wxDateTime::UNow}{wxdatetimeunow} should be used for better precision (but it is less efficient and might not be available on all platforms). @@ -684,7 +728,7 @@ Same as \helpref{Set}{wxdatetimewxdatetimetime} \membersection{wxDateTime::wxDateTime}\label{wxdatetimewxdatetimedate} -\func{wxDateTime\&}{wxDateTime}{\param{wxDateTime\_t }{day}, \param{Month }{month = Inv\_Month}, \param{int}{ Inv\_Year}, +\func{wxDateTime\&}{wxDateTime}{\param{wxDateTime\_t }{day}, \param{Month }{month = Inv\_Month}, \param{int}{ Inv\_Year}, \param{wxDateTime\_t }{hour = 0}, \param{wxDateTime\_t }{minute = 0}, \param{wxDateTime\_t }{second = 0}, \param{wxDateTime\_t }{millisec = 0}} Same as \helpref{Set}{wxdatetimesetdate} @@ -830,6 +874,20 @@ Same as \helpref{Set}{wxdatetimesettm}. Returns {\tt true} if the object represents a valid time moment. +\membersection{wxDateTime::GetDateOnly}\label{wxdatetimegetdateonly} + +\constfunc{wxDateTime}{GetDateOnly}{\void} + +Returns the object having the same date component as this one but time of +00:00:00. + +\newsince{2.8.2} + +\wxheading{See also} + +\helpref{ResetTime}{wxdatetimeresettime} + + \membersection{wxDateTime::GetTm}\label{wxdatetimegettm} \constfunc{Tm}{GetTm}{\param{const TimeZone\& }{tz = Local}} @@ -845,6 +903,13 @@ Returns the number of seconds since Jan 1, 1970. An assert failure will occur if the date is not in the range covered by {\tt time\_t} type. +\membersection{wxDateTime::GetCentury}\label{wxdatetimegetcentury} + +\constfunc{int}{GetCentury}{\param{const TimeZone\& }{tz = Local}} + +Returns the century of this date. + + \membersection{wxDateTime::GetYear}\label{wxdatetimegetyear} \constfunc{int}{GetYear}{\param{const TimeZone\& }{tz = Local}} @@ -918,10 +983,10 @@ the year is, according to international standards, the one containing Jan 4 or, equivalently, the first week which has Thursday in this year. Both of these definitions are the same as saying that the first week of the year must contain more than half of its days in this year. Accordingly, the week number will -always be in $1\ldots53$ range ($52$ for non leap years). +always be in $1\ldots53$ range ($52$ for non-leap years). The function depends on the \helpref{week start}{wxdatetime} convention -specified by the {\it flags} argument but its results for +specified by the {\it flags} argument but its results for \texttt{Sunday\_First} are not well-defined as the ISO definition quoted above applies to the weeks starting on Monday only. @@ -959,8 +1024,8 @@ calculations make sense for it). \func{wxDateTime\&}{Set}{\param{unsigned long }{ddt}} -Sets the date from the date and time in -\urlref{DOS}{http://developer.novell.com/ndk/doc/smscomp/index.html?page=/ndk/doc/smscomp/sms\_docs/data/hc2vlu5i.html} +Sets the date from the date and time in +\urlref{DOS}{http://developer.novell.com/ndk/doc/smscomp/index.html?page=/ndk/doc/smscomp/sms\_docs/data/hc2vlu5i.html} format. @@ -968,8 +1033,8 @@ format. \constfunc{unsigned long}{GetAsDOS}{\void} -Returns the date and time in -\urlref{DOS}{http://developer.novell.com/ndk/doc/smscomp/index.html?page=/ndk/doc/smscomp/sms\_docs/data/hc2vlu5i.html} +Returns the date and time in +\urlref{DOS}{http://developer.novell.com/ndk/doc/smscomp/index.html?page=/ndk/doc/smscomp/sms\_docs/data/hc2vlu5i.html} format. %%%%%%%%%%%%%%%%%%%%%%%%%%% comparison %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% @@ -1112,9 +1177,13 @@ as wxTimeSpan. \membersection{wxDateTime::ParseRfc822Date}\label{wxdatetimeparserfc822date} -\func{const wxChar *}{ParseRfc822Date}{\param{const wxChar* }{date}} +\func{const char *}{ParseRfc822Date}{\param{const wxString\& }{date}, \param{wxString::const\_iterator *}{end = \NULL}} + +\func{const char *}{ParseRfc822Date}{\param{const char* }{date}} -Parses the string {\it date} looking for a date formatted according to the RFC +\func{const wchar\_t *}{ParseRfc822Date}{\param{const wchar\_t* }{date}} + +Parses the string \arg{date} looking for a date formatted according to the RFC 822 in it. The exact description of this format may, of course, be found in the RFC (section $5$), but, briefly, this is the format used in the headers of Internet email messages and one of the most common strings expressing date in @@ -1133,7 +1202,11 @@ free ways, you should use \helpref{ParseDateTime}{wxdatetimeparsedatetime} or \membersection{wxDateTime::ParseFormat}\label{wxdatetimeparseformat} -\func{const wxChar *}{ParseFormat}{\param{const wxChar *}{date}, \param{const wxChar *}{format = "\%c"}, \param{const wxDateTime\& }{dateDef = wxDefaultDateTime}} +\func{const char *}{ParseFormat}{\param{const wxString\& }{date}, \param{const wxString\& }{format = wxDefaultDateTimeFormat}, \param{const wxDateTime\& }{dateDef = wxDefaultDateTime}, \param{wxString::const\_iterator *}{end = \NULL}} + +\func{const char *}{ParseFormat}{\param{const char *}{date}, \param{const wxString\& }{format = wxDefaultDateTimeFormat}, \param{const wxDateTime\& }{dateDef = wxDefaultDateTime}} + +\func{const wchar\_t *}{ParseFormat}{\param{const wchar\_t *}{date}, \param{const wxString\& }{format = wxDefaultDateTimeFormat}, \param{const wxDateTime\& }{dateDef = wxDefaultDateTime}} This function parses the string {\it date} according to the given {\it format}. The system {\tt strptime(3)} function is used whenever available, @@ -1158,7 +1231,11 @@ the character which stopped the scan. \membersection{wxDateTime::ParseDateTime}\label{wxdatetimeparsedatetime} -\func{const wxChar *}{ParseDateTime}{\param{const wxChar *}{datetime}} +\func{const char *}{ParseDateTime}{\param{const wxString\& }{datetime}, \param{wxString::const\_iterator *}{end = \NULL}} + +\func{const char *}{ParseDateTime}{\param{const char *}{datetime}} + +\func{const wchar\_t *}{ParseDateTime}{\param{const wchar\_t *}{datetime}} Parses the string {\it datetime} containing the date and time in free format. This function tries as hard as it can to interpret the given string as date @@ -1167,16 +1244,19 @@ will accept anything that may be accepted and will only reject strings which can not be parsed in any way at all. Returns {\tt NULL} if the conversion failed, otherwise return the pointer to -the character which stopped the scan. This method is currently not -implemented, so always returns NULL. +the character which stopped the scan. \membersection{wxDateTime::ParseDate}\label{wxdatetimeparsedate} -\func{const wxChar *}{ParseDate}{\param{const wxChar *}{date}} +\func{const char *}{ParseDate}{\param{const wxString\& }{date}, \param{wxString::const\_iterator *}{end = \NULL}} + +\func{const char *}{ParseDate}{\param{const char *}{date}} + +\func{const wchar\_t *}{ParseDate}{\param{const wchar\_t *}{date}} This function is like \helpref{ParseDateTime}{wxdatetimeparsedatetime}, but it -only allows the date to be specified. It is thus less flexible then +only allows the date to be specified. It is thus less flexible then \helpref{ParseDateTime}{wxdatetimeparsedatetime}, but also has less chances to misinterpret the user input. @@ -1186,7 +1266,11 @@ the character which stopped the scan. \membersection{wxDateTime::ParseTime}\label{wxdatetimeparsetime} -\func{const wxChar *}{ParseTime}{\param{const wxChar *}{time}} +\func{const char *}{ParseTime}{\param{const wxString\& }{time}, \param{wxString::const\_iterator *}{end = \NULL}} + +\func{const char *}{ParseTime}{\param{const char *}{time}} + +\func{const wchar\_t *}{ParseTime}{\param{const wchar\_t *}{time}} This functions is like \helpref{ParseDateTime}{wxdatetimeparsedatetime}, but only allows the time to be specified in the input string. @@ -1197,7 +1281,7 @@ the character which stopped the scan. \membersection{wxDateTime::Format}\label{wxdatetimeformat} -\constfunc{wxString }{Format}{\param{const wxChar *}{format = "\%c"}, \param{const TimeZone\& }{tz = Local}} +\constfunc{wxString }{Format}{\param{const wxChar *}{format = wxDefaultDateTimeFormat}, \param{const TimeZone\& }{tz = Local}} This function does the same as the standard ANSI C {\tt strftime(3)} function. Please see its description for the meaning of {\it format} parameter. @@ -1259,7 +1343,7 @@ Returns the reference to the modified object itself. \constfunc{wxDateTime}{GetWeekDayInSameWeek}{\param{WeekDay }{weekday}, \param{WeekFlags}{flags = {\tt Monday\_First}}} -Returns the copy of this object to which +Returns the copy of this object to which \helpref{SetToWeekDayInSameWeek}{wxdatetimesettoweekdayinsameweek} was applied. @@ -1353,7 +1437,7 @@ given \arg{year} . The number should be in range $1\ldots53$. Note that the returned date may be in a different year than the one passed to this function because both the week $1$ and week $52$ or $53$ (for leap years) -contain days from different years. See +contain days from different years. See \helpref{GetWeekOfYear}{wxdatetimegetweekofyear} for the explanation of how the year weeks are counted. @@ -1447,6 +1531,16 @@ year 1 is Rata Die day 1. %%%%%%%%%%%%%%%%%%%%%%%%%%% timezone and DST %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +\membersection{wxDateTime::FromTimezone}\label{wxdatetimefromtimezone} + +\constfunc{wxDateTime}{FromTimezone}{\param{const TimeZone\& }{tz}, \param{bool }{noDST = false}} + +Transform the date from the given time zone to the local one. If {\it noDST} is +{\tt true}, no DST adjustments will be made. + +Returns the date in the local time zone. + + \membersection{wxDateTime::ToTimezone}\label{wxdatetimetotimezone} \constfunc{wxDateTime}{ToTimezone}{\param{const TimeZone\& }{tz}, \param{bool }{noDST = false}} @@ -1465,17 +1559,25 @@ Modifies the object in place to represent the date in another time zone. If {\it noDST} is {\tt true}, no DST adjustments will be made. -\membersection{wxDateTime::ToGMT}\label{wxdatetimetogmt} +\membersection{wxDateTime::MakeFromTimezone}\label{wxdatetimemakefromtimezone} + +\func{wxDateTime\&}{MakeFromTimezone}{\param{const TimeZone\& }{tz}, \param{bool }{noDST = false}} + +Same as \helpref{FromTimezone}{wxdatetimefromtimezone} but modifies the object +in place. + + +\membersection{wxDateTime::ToUTC}\label{wxdatetimetoutc} -\constfunc{wxDateTime}{ToGMT}{\param{bool }{noDST = false}} +\constfunc{wxDateTime}{ToUTC}{\param{bool }{noDST = false}} This is the same as calling \helpref{ToTimezone}{wxdatetimetotimezone} with the argument {\tt GMT0}. -\membersection{wxDateTime::MakeGMT}\label{wxdatetimemakegmt} +\membersection{wxDateTime::MakeUTC}\label{wxdatetimemakeutc} -\func{wxDateTime\&}{MakeGMT}{\param{bool }{noDST = false}} +\func{wxDateTime\&}{MakeUTC}{\param{bool }{noDST = false}} This is the same as calling \helpref{MakeTimezone}{wxdatetimemaketimezone} with the argument {\tt GMT0}. @@ -1494,9 +1596,37 @@ Returns {\tt true} if the DST is applied for this date in the given country. \section{\class{wxDateTimeHolidayAuthority}}\label{wxdatetimeholidayauthority} +\wxheading{Derived from} + +No base class + +\wxheading{Include files} + + + +\wxheading{Library} + +\helpref{wxBase}{librarieslist} + +\latexignore{\rtfignore{\wxheading{Members}}} + TODO \section{\class{wxDateTimeWorkDays}}\label{wxdatetimeworkdays} +\wxheading{Derived from} + +No base class + +\wxheading{Include files} + + + +\wxheading{Library} + +\helpref{wxBase}{librarieslist} + +\latexignore{\rtfignore{\wxheading{Members}}} + TODO