Provided by: pvm-dev_3.4.6-1build2_amd64 bug

NAME

       pvm_unpack - Unpack the active message buffer into arrays of prescribed data type.

SYNOPSIS

       C
            int info = pvm_unpackf( const char *fmt, ... )
            int info = pvm_upkbyte( char *xp, int nitem, int stride)
            int info = pvm_upkcplx( float *cp, int nitem, int stride)
            int info = pvm_upkdcplx( double *zp, int nitem, int stride)
            int info = pvm_upkdouble( double *dp, int nitem, int stride)
            int info = pvm_upkfloat( float *fp, int nitem, int stride)
            int info = pvm_upkint( int *ip, int nitem, int stride)
            int info = pvm_upkuint( unsigned int *ip, int nitem, int stride )
            int info = pvm_upkushort( unsigned short *ip, int nitem, int stride )
            int info = pvm_upkulong( unsigned long *ip, int nitem, int stride )
            int info = pvm_upklong( long *ip, int nitem, int stride)
            int info = pvm_upkshort( short *jp, int nitem, int stride)
            int info = pvm_upkstr( char *sp )

       Fortran
            call pvmfunpack( what, xp, nitem, stride, info )

PARAMETERS

       fmt     Printf-like format expression specifying what to pack. (See discussion)

       nitem   The total number of items to be unpacked (not the number of bytes).

       stride  The  stride  to  be used when packing the items.  For example, if stride = 2 in pvm_upkcplx, then
               every other complex number will be unpacked.

       xp      Pointer to the beginning of a block  of  bytes.  Can  be  any  data  type,  but  must  match  the
               corresponding pack data type.

       cp      Complex array at least nitem*stride items long.

       zp      Double precision complex array at least nitem*stride items long.

       dp      Double precision real array at least nitem*stride items long.

       fp      Real array at least nitem*stride items long.

       ip      Integer array at least nitem*stride items long.

       jp      Integer*2 array at least nitem*stride items long.

       sp      Pointer to a null terminated character string.

       what    Integer specifying the type of data being unpacked.

                                                         what options
                    STRING         0    REAL4          4
                    BYTE1          1    COMPLEX8       5
                    INTEGER2       2    REAL8          6
                    INTEGER4       3    COMPLEX16      7

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

DESCRIPTION

       Each  of  the  pvm_upk*  routines unpacks an array of the given data type from the active receive buffer.
       The arguments for each of the routines are a pointer to the array to be unpacked into, nitem which is the
       total number of items to unpack, and stride which is the stride to use when unpacking.

       An exception is pvm_upkstr() which by definition unpacks a NULL terminated character string and thus does
       not need nitem or stride arguments.  The Fortran routine pvmfunpack( STRING, ... ) expects  nitem  to  be
       the number of characters in the string and stride to be 1.

       If the unpacking is successful, info will be 0. If some error occurs then info will be < 0.

       A single variable (not an array) can be unpacked by setting nitem = 1 and stride = 1.

       The  routine  pvm_unpackf()  uses  a printf-like format expression to specify what and how to unpack data
       from the receive buffer.  All variables are passed as addresses.  A BNF-like description  of  the  format
       syntax is:
           format : null | init | format fmt
           init : null | '%' '+'
           fmt : '%' count stride modifiers fchar
           fchar : 'c' | 'd' | 'f' | 'x' | 's'
           count : null | [0-9]+ | '*'
           stride : null | '.' ( [0-9]+ | '*' )
           modifiers : null | modifiers mchar
           mchar : 'h' | 'l' | 'u'

       Formats:
         +  means initsend - must match an int (how) in the param list.
         c  pack/unpack bytes
         d  integer
         f  float
         x  complex float
         s  string

       Modifiers:
         h  short (int)
         l  long  (int, float, complex float)
         u  unsigned (int)

       ’*' count or stride must match an int in the param list.

       Future extensions to the what argument in pvmfunpack will include 64 bit types when XDR encoding of these
       types is available.  Meanwhile users should be aware that precision can be lost when passing data from  a
       64  bit machine like a Cray to a 32 bit machine like a SPARCstation. As a mnemonic the what argument name
       includes the number of bytes of precision to expect. By setting encoding  to  PVMRAW  (see  pvmfinitsend)
       data  can be transferred between two 64 bit machines with full precision even if the PVM configuration is
       heterogeneous.

       Messages should be unpacked exactly like they were packed to insure data integrity.  Packing integers and
       unpacking them as floats will often fail because a type encoding will have occurred transferring the data
       between heterogeneous hosts. Packing 10 integers and 100 floats then trying to unpack only 3 integers and
       the 100 floats will also fail.

EXAMPLES

       C:
            info = pvm_recv( tid, msgtag );
            info = pvm_upkstr( string );
            info = pvm_upkint( &size, 1, 1 );
            info = pvm_upkint( array, size, 1 );
            info = pvm_upkdouble( matrix, size*size, 1 );

            int count, *iarry;
            double darry[4];
               pvm_unpackf("%d", &count);
               pvm_unpackf("%*d %4lf", count, iarry, darry);

       Fortran:
            CALL PVMFRECV( TID, MSGTAG, INFO );
            CALL PVMFUNPACK( INTEGER4, NSIZE, 1, 1, INFO )
            CALL PVMFUNPACK( STRING, STEPNAME, 8, 1, INFO )
            CALL PVMFUNPACK( REAL4, A(5,1), NSIZE, NSIZE , INFO )

ERRORS

       PvmNoData
              Reading  beyond  the  end of the receive buffer.  Most likely cause is trying to unpack more items
              than were originally packed into the buffer.

       PvmBadMsg
              The received message can not be decoded.  Most likely because the hosts are heterogeneous and  the
              user  specified  an  incompatible  encoding.   Try  setting  the  encoding  to PvmDataDefault (see
              pvm_mkbuf).

       PvmNoBuf
              There is no active receive buffer to unpack.

SEE ALSO

       pvm_pack(3PVM) pvm_send(3PVM), pvm_recv(3PVM), pvm_pkmesg(3PVM)

                                                 30 August, 1993                                    UNPACK(3PVM)