Provided by: pvm-dev_3.4.6-3.2_amd64 bug

NAME

       pvm_catchout - Catch output from child tasks.

SYNOPSIS

       C    #include <stdio.h>

            int info = pvm_catchout( FILE *ff )

       Fortran   call pvmfcatchout( onoff, info )

PARAMETERS

       ff      File descriptor on which to write collected output.

       onoff   Integer parameter.  Turns output collection on or off.

       info    Integer status code returned by the routine.  Values less than zero indicate an error.

DESCRIPTION

       The  routine  pvm_catchout  causes  the  calling task (the parent) to catch output from any tasks spawned
       after the call to pvm_catchout.  Characters printed on stdout or stderr in children tasks  are  collected
       by  the pvmds and sent in control messages to the parent task, which tags each line and appends it to the
       specified file.  Output from grandchildren (spawned by children) tasks is also  collected,  provided  the
       children don't reset their PvmOutputTid.

       If  option  PvmShowTids (see pvm_setopt) is true (nonzero), output is printed as shown below, tagged with
       the task id where the output originated:
            [txxxxx] BEGIN
            [txxxxx] (text from child task)
            [txxxxx] END

       The output from each task includes one BEGIN line and one END line, with  whatever  the  task  prints  in
       between.  If PvmShowTids is false, raw output is printed with no additional information.

       In C, the output file descriptor may be specified.  Giving a null pointer turns output collection off for
       any  subsequently  spawned  child tasks.  (Any existing output collection will still proceed at the child
       tasks, until they exit or change theirPvmOutputTid or related settings - see man page for  pvm_setopt().)
       In  Fortran,  output  collection  can only be turned on or off (again only for subsequently spawned child
       tasks), and is always logged to the stdout of the parent task.

       If pvm_exit is called while output collection is in effect, it will block  in  order  to  print  all  the
       output,  until all tasks sending the given task output have exited.  To avoid this, output collection can
       be turned off by calling pvm_catchout(0) before calling pvm_exit.

       pvm_catchout() always returns 0.

EXAMPLES

       C:
            #include <stdio.h>

            pvm_catchout(stdout);

       Fortran:
            CALL PVMFCATCHOUT( 1, INFO )

SEE ALSO

       pvm_exit(3PVM), pvm_setopt(3PVM), pvm_spawn(3PVM)

                                                  13 July, 1994                                   CATCHOUT(3PVM)