KnowledgeBase Archive

An Archive of Early Microsoft KnowledgeBase Articles

View on GitHub

Q112339: BUG: Opening More Than 61 Files in a FORTRAN Windows NT App

Article: Q112339
Product(s): Microsoft Fortran Compiler
Version(s): 1.0,4.0
Operating System(s): 
Keyword(s): kbcode kbFortranPS kbLangFortran
Last Modified: 05-NOV-1999

-------------------------------------------------------------------------------
The information in this article applies to:

- Microsoft Fortran Powerstation 32 for Windows NT, versions 1.0, 4.0 
-------------------------------------------------------------------------------

SYMPTOMS
========

A FORTRAN PowerStation application on Windows NT can have only 61 files open at
a time. Attempting to OPEN the file number 62 will produce the run- time error:

  error F6417: too many open files

Page 806 of the FORTRAN PowerStation "Programmer's Guide" incorrectly states that
the fix for this problem is to change the FILES= setting in CONFIG.SYS.

CAUSE
=====

The 64-file limit of the PowerStation for MS-DOS has been carried over to
Powerstation for Windows NT. Three of these files are reserved for system use,
leaving 61 files for the program to use.

RESOLUTION
==========

Use WIN32 application programming interface (API) functions to perform some or
all of your file I/O.

STATUS
======

Microsoft has confirmed this to be a problem in the Microsoft products listed at
the beginning of this article. We are researching this problem and will post new
information here in the Microsoft Knowledge Base as it becomes available.

MORE INFORMATION
================

The following sample keeps 100 files open at the same time:

Sample Code #1
--------------

  c Compile options needed: none
  c

        include 'IO.FI'
        program OPEN_TEST
        character*9 fname/'FILE.000 '/ 
        integer*4 j
        fname(9:9) = CHAR(0)  ! Append null character
        do j = 1,100
           write(*,*) fname
           call open(fname)
           write(fname(6:8),'(i3.3)') j ! Write file extension
        enddo
        end

  c

        subroutine open(name)
        character*(*) name, buffer*16
        integer lcreat, handle, len
        data buffer/'Open many files.'/ 

        handle = lcreat(name, 0)         ! Create a new file
        len = lwrite(handle, buffer, 16) ! Write to file
        len = llseek(handle, 0, 0)       ! Seek to the beginning
        len = lread(handle, buffer, 16)  ! Read data back from file
        end

The following interface file, IO.FI, is used by the program above:

Sample Code #2
--------------

  C Open an existing file

        interface to integer function lopen
       +  [stdcall, alias:'__lopen@8'](filename, mode)
        character*1 filename[reference] ! null terminated file name
        integer mode[value] ! 0 = read-only, 1 = write-only
                            ! 2 = read-write
        end

  C Create a file (erase the old file if one exists)

        interface to integer function lcreat
       +  [stdcall, alias:'__lcreat@8'](filename, mode)
        character*1 filename [reference] ! null terminated file name
        integer mode[value] ! 0 = read-write, 1 = read-only
                            ! 2 = hidden, 3 = system
        end
  C Close a file (use with files opened by lcreat or lopen)

        interface to integer function lclose
       +  [stdcall, alias:'__lclose@4'](handle)
        integer handle[value]
        end
  C Move the file pointer to a specific offset in a file

        interface to integer function llseek
       +  [stdcall, alias:'__llseek@12'](handle,offset,origin)
        integer handle[value]
        integer offset[value] ! number of bytes to move pointer
        integer origin[value] ! 0 = beginning, 1 = current position
                              ! 2 = end of the file
        end
  C Read a specified number of bytes from a file

        interface to integer function lread
       +  [stdcall, alias:'__lread@12'](handle,buffer,length)
        integer handle[value]
        character*1 buffer
        integer length[value]  ! number of bytes
        end
  C Write a specified number of bytes to a file

        interface to integer function lwrite
       +  [stdcall, alias:'__lwrite@12'](handle,buffer,length)
        integer handle[value]
        character*1 buffer
        integer length[value]
        end

Additional query words: 1.00 4.00

======================================================================
Keywords          : kbcode kbFortranPS kbLangFortran 
Technology        : kbAudDeveloper kbFortranSearch kbZNotKeyword2 kbFORTRANPower32100NT kbFORTRANPower32400NT
Version           : :1.0,4.0

=============================================================================

THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY.

Copyright Microsoft Corporation 1986-2002.