Using FSEEK() Function to Determine Size of File in Bytes

Last reviewed: June 27, 1995
Article ID: Q87502
The information in this article applies to:
  • Microsoft FoxPro for MS-DOS, versions 1.0, 1.01, 1.02, 2.0, 2.5, and 2.5a
  • Microsoft FoxPro for Windows, versions 2.5 and 2.5a

SUMMARY

The text below provides a code example to determine the size (in bytes) of a specific file using a user-defined function (UDF) that uses the FSEEK() function.

MORE INFORMATION

To determine the size of the C:\COMMAND.COM file, invoke the filesize UDF as follows:

   clear
   @ 2,5 say filesize('c:\command.com')

   FUNCTION filesize
   PARAMETERS mfile

   PRIVATE mhandle, fsize

   IF PARAMETERS() = 0  && Return -2 if no parameter passed.
       RETURN -2
   ELSE
      IF ! FILE(mfile)  && Return -1 if file does not exist.
         RETURN -1
      ENDIF
   ENDIF

   mhandle = FOPEN(mfile)        && Open specified file.
   fsize = FSEEK(mhandle, 0, 2)  && Determine file size and
                                 &&   assign to fsize.
   = FCLOSE(mhandle)             && Close file.

   RETURN fsize         && Return value.


Additional reference words: FoxDos FoxWin 1.00 1.01 1.02 2.00 2.50 2.50a
KBCategory: kbprg
KBSubcategory: FxprgGeneral


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.

Last reviewed: June 27, 1995
© 1998 Microsoft Corporation. All rights reserved. Terms of Use.