!XDR_LONG

This system variable controls the number of bytes for LONG data types written to an XDR file. !XDR_LONG applies to the SAVE/RESTORE routines and to the OPEN procedures (OPENR, OPENU, and OPENW) that have the /XDR keyword set.

Note:

If large LONG integers are hard-coded into a routine, the COMPILE command will fail even if !XDR_LONG is set to 64, i.e., .cpr files cannot contain hard-coded LONG integers greater than 231–1. The reason for this restriction is to ensure that any .cpr file runs correctly on 32-bit and 64-bit platforms.

Usage

!XDR_LONG=<bit_size> 

The possible <bit_size> is:

32—PV-WAVE outputs LONG integers as 4-byte, 32-bit values. This setting is valid for both 32-bit or 64-bit platforms when creating and writing to an XDR-formatted file.

64—PV-WAVE outputs LONG integers as 8-byte, 64-bit values. This setting is only valid on 64-bit platforms. Note: XRD-formatted files created with the 64 setting are unreadable on 32-bit machines and 64-bit machines with !XDR_LONG set to 32.

The default value is 32.

Note:

You can set !XDR_LONG to any value, but when it applies to SAVE or OPEN* procedures, valid values are 32 and 64.

OPEN* Procedures

!XDR_LONG applies to the OPEN* procedures that have the /XDR keyword set. Changes to the !XDR_LONG system variable do not affect open files. In order to change the size of LONG and output to a file, you would have to close the file and then open it again.

SAVE Procedure

On the 32-bit version of PV-WAVE, the only valid value of !XDR_LONG is 32. If !XDR_LONG is set to 64, an error message is issued and execution is stopped.

RESTORE Procedure

The system variable !XDR_LONG has no impact relative to the RESTORE command. !XDR_LONG is only considered during output operations (SAVE and WRITEU). Calling the RESTORE procedure does not change the !XDR_LONG value.

If you restore a 64-bit file on a 32-bit platform, an error message is issued and execution is stopped.