13.6 OPEN Statement

The OPEN statement connects an external file to a unit, creates a new file and connects it to a unit, creates a preconnected file, or changes certain properties of a connection.

The OPEN statement takes the following form:

OPEN ([UNIT=]io-unit [, FILE=name] [, ERR=label] [, IOSTAT=i-var], slist)

io-unit
Is an external unit specifier.

name
Is a character or numeric expression specifying the name of the file to be connected. For more information, see Section 13.6.13.

label
Is the label of the branch target statement that receives control if an error occurs.

i-var
Is a scalar integer variable that is defined as a positive integer if an error occurs and zero if no error occurs.

slist
Is one or more OPEN specifiers in the form specifier=value or specifier. Each specifier can appear only once.

The OPEN specifiers and their acceptable values are summarized in Table 13-1.

The OPEN specifiers are described individually in the following sections. The control specifiers that can be specified in an OPEN statement (UNIT, ERR, and IOSTAT) are discussed in Section 10.2.1.

Table 13-1 OPEN Statement Specifiers and Values on Tru64 UNIX, Linux, and Windows Systems

Specifier  Values  Function  Default 
ACCESS  'SEQUENTIAL'
'DIRECT'
'APPEND'
 
Access mode  'SEQUENTIAL'  
ACTION
(or MODE 1)  
'READ'
'WRITE'
'READWRITE'  
File access  'READWRITE'  
ASSOCIATEVARIABLE  var   Next direct access record  No default 
BLANK  'NULL'
'ZERO'  
Interpretation of blanks  'NULL'  
BLOCKSIZE  n_expr   Physical block size  Filesystem default 
BUFFERCOUNT  n_expr   Number of I/O buffers  One 
BUFFERED  'YES'
'NO' 
Buffering for WRITE operations  'NO' 
CARRIAGECONTROL  'FORTRAN'
'LIST'
'NONE'
 
Print control  Formatted: 'LIST' 2
Unformatted: 'NONE'
 
CONVERT   'LITTLE_ENDIAN'
'BIG_ENDIAN'
'CRAY'
'FDX'
'FGX'
'IBM'
'VAXD'
'VAXG'
'NATIVE'
 
Numeric format specification   'NATIVE'  
DEFAULTFILE  c_expr  Default file pathname  Current working directory 
DELIM  'APOSTROPHE'
'QUOTE'
'NONE'  
Delimiter for character constants  'NONE' 
DISPOSE
(or DISP)
 
'KEEP' or 'SAVE'
'DELETE'
'PRINT'
'PRINT/DELETE'
'SUBMIT'
'SUBMIT/DELETE'
File disposition at close   'KEEP'  
ERR  label  Error transfer control  No default 
FILE
(or NAME)  
c_expr  File pathname (file name)   fort.n 3 
FORM  'FORMATTED'
'UNFORMATTED'
'BINARY' 1  
Format type  Depends on ACCESS setting 
IOFOCUS1   .TRUE. .FALSE.  Active window in QuickWin application  .TRUE. 4 
IOSTAT  var  I/O status  No default 
MAXREC  n_expr  Direct access record limit  No limit 
ORGANIZATION  'SEQUENTIAL'
'RELATIVE'
 
File organization   'SEQUENTIAL'  
PAD  'YES'
'NO'  
Record padding  'YES' 
POSITION  'ASIS'
'REWIND'
'APPEND'  
File positioning  'ASIS' 
READONLY  No value  Write protection  No default 
RECL
(or RECORDSIZE) 
n_expr   Record length  Depends on RECORDTYPE, ORGANIZATION, and FORM settings 5 
RECORDTYPE  'FIXED'
'VARIABLE'
'SEGMENTED'
'STREAM'
'STREAM_CR'
'STREAM_LF'
 
Record type  Depends on ORGANIZATION, CARRIAGECONTROL, ACCESS, and FORM settings 
SHARE 1,6  'DENYRW'
'DENYWR'
'DENYRD'
'DENYNONE'
 
File locking   'DENYWR'  
SHARED 6  No value  File sharing allowed  U*X: SHARED
WNT AND W9*: No default 
STATUS (or TYPE)   'OLD'
'NEW'
'SCRATCH'
'REPLACE'
'UNKNOWN'  
File status at open   'UNKNOWN' 7 
TITLE 1  c_expr  Title for child window in QuickWin application  No default 
UNIT  n_expr  Logical unit number  No default; an io-unit must be specified 
USEROPEN  func   User program option  No default 
1 WNT, W9*
2 If you use the compiler option specifying OpenVMS defaults, and the unit is connected to a terminal, the default is 'FORTRAN'.
3 n is the unit number.
4 If you specify unit '*' the default is .FALSE..
5 On Tru64 UNIX and Linux systems, the default depends only on the FORM setting.
6 For information on file sharing, see your user manual or programmer's guide.
7 The default differs under certain conditions (see Section 13.6.28).
Key to Values
   c_expr: A scalar default character expression
   func:   An external function
   label:  A statement label
   n_expr: A scalar numeric expression
   var:    A scalar integer variable

Rules and Behavior

The control specifiers ([UNIT=]io-unit, ERR=label, and IOSTAT=i-var) and OPEN specifiers can appear anywhere within the parentheses following OPEN. However, if the UNIT keyword is omitted, the io-unit must appear first in the list.

Specifier values that are scalar numeric expressions can be any integer or real expression. The value of the expression is converted to integer data type before it is used in the OPEN statement.

Only one unit at a time can be connected to a file, but multiple OPENs can be performed on the same unit. If an OPEN statement is executed for a unit that already exists, the following occurs:

The ERR and IOSTAT specifiers from any previously executed OPEN statement have no effect on any currently executing OPEN statement. If an error occurs, no file is opened or created.

Secondary operating system messages do not display when IOSTAT is specified. To display these messages, remove IOSTAT or use a platform-specific method. (For more information, see your user manual or programmer's guide.)

Examples

You can specify character values at run time by substituting a character expression for a specifier value in the OPEN statement. The character value can contain trailing blanks but not leading or embedded blanks; for example:

  CHARACTER*6 FINAL /' '/
  ...
  IF (expr) FINAL = 'DELETE'
  OPEN (UNIT=1, STATUS='NEW', DISP=FINAL)
The following statement creates a new sequential formatted file on unit 1 with the default file name fort.1:
  OPEN (UNIT=1, STATUS='NEW', ERR=100)
The following statement creates a file on magnetic tape:
OPEN (UNIT=I, FILE='/dev/rmt8',                                  &
     STATUS='NEW', ERR=14, RECL=1024)

The following statement opens the file (created in the previous example) for input:

OPEN (UNIT=I, FILE='/dev/rmt8', READONLY, STATUS='OLD',          &
     RECL=1024)

The following example opens the existing file /usr/users/someone/test.dat:

 OPEN (unit=10, DEFAULTFILE='/usr/users/someone/', FILE='test.dat',
1     FORM='FORMATTED', STATUS='OLD')

For More Information:


Previous Page Next Page Table of Contents