PRINT_WATCH
prints the current value of a StopWatch
watch
SYNOPSIS
subroutine print_watch (watch, clock, title, form, err)
DESCRIPTION
Prints the specified clocks of the specified watches. A title line is printed
followed by two lines for each watch. The first contains the name of the
watch, which was defined in create_watch(3)
and maintained internally,
and the second contains the values of the specified clocks. Output is
written to a user specified
I/O unit (see option_stopwatch(3))
which is 6 by default.
Clocks can be printed regardless of whether they are running, stopped or
paused.
One or more watches must be specified. The argument watch can be a single variable of type watchtype (see stopwatch(3)) to print one watch, an array of type watchtype to print several watches, or a variable of type watchgroup (see stopwatch(3)) to print the watches in a group.
The optional argument clock specifies which clocks to print from the specified watch(es). If omitted, the current default clocks (see option_stopwatch(3)) are printed. If present, clock must be a character string containing 'cpu', 'user', 'sys', or 'wall', or an array of such character strings.
The optional argument title is a character string to be printed before printing the watch values. If omitted, the string ``Times printed by StopWatch:'' is printed.
The optional argument form determines the form for printing time. Currently all the forms print the time to .01 seconds. The valid values are:
If omitted, the current default form is used. The default form is initially 'sec' and can be reset by option_stopwatch(3) .
DIAGNOSTICS
If present, the optional intent OUT integer argument err
returns
a status code. The code is the sum of the values listed below.
An error message will be printed to a specified I/O unit (unit 6 by default) if print_errors is TRUE (default is TRUE). The error message contains more detail about the cause of the error than can be obtained from just the status code, so you should set print_errors to TRUE if you have trouble determining the cause of the error.
If abort_errors is TRUE (default is FALSE), the program will terminate on an error condition. Otherwise, the program will continue execution but the watch(es) will not be printed.
See option_stopwatch(3) for further information on print_errors, abort_errors and I/O units.
The relevant status codes and messages are:
In addition to the run time diagnostics generated by StopWatch
, the following
problem may arise:
EXAMPLES
type (watchtype) w1, w2(3)
type (watchgroup) g1
integer errcode
call print_watch(w1)
call print_watch(w2, title='Array of 3 watches', err=errcode)
call print_watch(g1, (/'cpu ', 'wall'/), errcode)
The first call prints the default clocks from a single watch, and the default title. The second call prints the default clocks on three watches given as an array and the title ``Array of 3 watches'', and returns a status code. The third call prints the cpu and wall clocks on the watches in the group g1, and returns a status code.
BUGS
It cannot be determined whether or not a watch variable or
watch group has been created (passed
as an argument to create_watch
or create_watchgroup).
If
a watch or watch group that has never been created
is passed into print_watch,
it might
generate a Fortran error due to passing a pointer with undefined association
status to the Fortran intrinsic function associated.
Some compilers
will allow this as an extension to the Fortran 90 standard and recognize that
the pointer is not associated, in which case the ``Watch needs to be created''
error message is generated.