From 53728487f15e5f324edf550d64894a95ea48aa54 Mon Sep 17 00:00:00 2001 From: Eli Zaretskii Date: Fri, 17 Oct 2008 19:37:14 +0000 Subject: [PATCH] (Processor Run Time): Document `emacs-uptime' and `emacs-init-time'. (Time Parsing): Document `format-seconds'. --- doc/lispref/ChangeLog | 2 ++ doc/lispref/os.texi | 76 ++++++++++++++++++++++++++++++++++++++++++- etc/NEWS | 3 ++ 3 files changed, 80 insertions(+), 1 deletion(-) diff --git a/doc/lispref/ChangeLog b/doc/lispref/ChangeLog index c0e27ea4712..5891f611050 100644 --- a/doc/lispref/ChangeLog +++ b/doc/lispref/ChangeLog @@ -5,6 +5,8 @@ `window-system-initialization-alist'. Document reading the abbrevs file. Document the call to `server-start' under --daemon. Rearrange a bit to be consistent with the code flow. + (Processor Run Time): Document `emacs-uptime' and `emacs-init-time'. + (Time Parsing): Document `format-seconds'. 2008-10-17 Martin Rudalics diff --git a/doc/lispref/os.texi b/doc/lispref/os.texi index fda4ed2c8a5..7236f0c0e18 100644 --- a/doc/lispref/os.texi +++ b/doc/lispref/os.texi @@ -1330,9 +1330,72 @@ seconds since the epoch, to a time value and returns that. To perform the inverse conversion, use @code{float-time}. @end defun +@defun format-seconds format-string seconds +This function converts its argument @var{seconds} into a string of +years, days, hours, etc., according to @var{format-string}. The +argument @var{format-string} may contain @samp{%}-sequences which +control the conversion. Here is a table of what the +@samp{%}-sequences mean: + +@table @samp +@item %y +@itemx %Y +The number of full 365-day years. +@item %d +@itemx %D +The number of full days. +@item %h +@itemx %H +The number of full hours. +@item %m +@itemx %M +The number of full minutes. +@item %s +@itemx %S +The number of seconds. +@item %z +Non-printing control flag. When it is used, other specifiers must be +given in the order of decreasing size, i.e.@: years before days, hours +before minutes, etc. Nothing will be produced in the result string to +the left of @samp{%z} until the first non-zero conversion is +encountered. For example, the default format used by +@code{emacs-uptime} (@pxref{Processor Run Time, emacs-uptime}) +@w{@code{"%Y, %D, %H, %M, %z%S"}} means that the number of seconds +will always be produced, but years, days, hours, and minutes will only +be shown if they are non-zero. +@item %% +Produces a literal @samp{%}. +@end table + +Upper-case format sequences produce the units in addition to the +numbers, lower-case formats produce only the numbers. + +You can also specify the field width by following the @samp{%} with a +number; shorter numbers will be padded with blanks. An optional +period before the width requests zero-padding instead. For example, +@code{"%.3Y"} might produce @code{"004 years"}. + +@emph{Warning:} This function works only with values of @var{seconds} +that don't exceed @code{most-positive-fixnum} (@pxref{Integer Basics, +most-positive-fixnum}). +@end defun + @node Processor Run Time @section Processor Run time @cindex processor run time +@cindex Emacs process run time + + Emacs provides several functions and primitives that return time, +both elapsed and processor time, used by the Emacs process. + +@defun emacs-uptime &optional format +This function returns a string representing the Emacs +@dfn{uptime}---the elapsed wall-clock time this instance of Emacs is +running. The string is formatted according to the optional argument +@var{format}. For the available format descriptors, see @ref{Time +Parsing, format-seconds}. If @var{format} is nil or omitted, it +defaults to @code{"%Y, %D, %H, %M, %z%S"}. +@end defun @defun get-internal-run-time This function returns the processor run time used by Emacs as a list @@ -1349,8 +1412,19 @@ $high*2^{16}+low$. The third element, @var{microsec}, gives the microseconds (or 0 for systems that return time with the resolution of only one second). +Note that the time returned by this function excludes the time Emacs +was not using the processor, and if the Emacs process has several +threads, the returned value is the sum of the processor times used up +by all Emacs threads. + If the system doesn't provide a way to determine the processor run -time, get-internal-run-time returns the same time as current-time. +time, @code{get-internal-run-time} returns the same time as +@code{current-time}. +@end defun + +@defun emacs-init-time +This function returns the duration of the Emacs initialization +(@pxref{Startup Summary}) in seconds, as a string. @end defun @node Time Calculations diff --git a/etc/NEWS b/etc/NEWS index bf6b4622473..58c4388fba2 100644 --- a/etc/NEWS +++ b/etc/NEWS @@ -1212,8 +1212,10 @@ reset transient-mark-mode to the value OLDVAL. The values `only' and *** The new variables `before-init-time' and `after-init-time' record the value of `current-time' before and after Emacs loads the init files. ++++ *** The new function `emacs-uptime' returns the uptime of an Emacs instance. ++++ *** The new function `emacs-init-time' returns the duration of the Emacs initialization. @@ -1550,6 +1552,7 @@ times the default column width. ** Miscellaneous new functions ++++ *** `format-seconds' converts a number of seconds into a readable string of days, hours, etc. -- 2.39.5