/* $DOC$ $AUTHOR$ Copyright 1999 Chen Kedem $TEMPLATE$ Function $NAME$ __Dir()* $CATEGORY$ API $SUBCATEGORY$ FileSys $ONELINER$ Display listings of files $SYNTAX$ __Dir( [] ) --> NIL $ARGUMENTS$ File mask to include in the function return. It could contain path and standard wildcard characters as supported by your OS (like * and ?). If contains no path, then SET DEFAULT path is used to display files in the mask. $RETURNS$ __Dir() always returns NIL. $DESCRIPTION$ If no is given, __Dir() displays information about all *.dbf in the SET DEFAULT path. This information contains: file name, number of records, last update date and the size of each file. If is given, __Dir() list all files that match the mask with the following details: Name, Extension, Size, Date. DIR command is preprocessed into __Dir() function during compile time. __Dir() is a compatibility function, it is superseded by Directory() which return all the information in a multidimensional array. If long file names are available Harbour will use/display the first 15 characters else Harbour will use/display a 8.3 file name consistent with CA-Cl*pper. $EXAMPLES$ __Dir() // information for all DBF files in current directory __Dir( "*.dbf" ) // list all DBF file in current directory // list all PRG files in Harbour Run-Time library // for MS-DOS compatible operating systems __Dir( hb_DirSepToOS( "src/rtl/*.prg" ) ) // list all files in the public section on a Unix like machine __Dir( hb_DirSepToOS( "/pub" ) ) $STATUS$ R $COMPLIANCE$ C $PLATFORMS$ All $FILES$ Library is core $SEEALSO$ ADir(), Directory(), SET DEFAULT, DIR $END$ */ /* $DOC$ $AUTHOR$ Copyright 1999 Chen Kedem $TEMPLATE$ Command $NAME$ DIR $CATEGORY$ Command $SUBCATEGORY$ FileSys $ONELINER$ Display listings of files $SYNTAX$ DIR [] $ARGUMENTS$ File mask to include in the function return. It could contain path and standard wildcard characters as supported by your OS (like * and ?). If contains no path, then SET DEFAULT path is used to display files in the mask. $DESCRIPTION$ If no is given, __Dir() display information about all *.dbf in the SET DEFAULT path, this information contain: file name, number of records, last update date and the size of each file. If is given, __Dir() list all files that match the mask with the following details: Name, Extension, Size, Date. DIR command is preprocessed into __Dir() function during compile time. __Dir() is a compatibility function, it is superseded by Directory() which returns all the information in a multidimensional array. If long file names are available Harbour will use/display the first 15 characters else Harbour will use/display a 8.3 file name consistent with CA-Cl*pper. $EXAMPLES$ DIR // information for all DBF files in current directory DIR "*.dbf" // list all DBF file in current directory // list all PRG files in Harbour Run-Time library // for MS-DOS compatible operating systems DIR "src/rtl/*.prg" // list all files in the public section on a Unix like machine DIR "/pub" $STATUS$ R $COMPLIANCE$ C $PLATFORMS$ All $SEEALSO$ ADir(), Directory(), SET DEFAULT, __Dir()* $END$ */ /* $DOC$ $AUTHOR$ Copyright 1999 Chen Kedem $TEMPLATE$ Function $NAME$ ADir() $CATEGORY$ API $SUBCATEGORY$ FileSys $ONELINER$ Fill pre-defined arrays with file/directory information $SYNTAX$ ADir( [], [], [], [], [], [] ) --> nDirEntries $ARGUMENTS$ File mask to include in the function return. It could contain path and standard wildcard characters as supported by your OS (like * and ?). If you omit or if contains no path, then the path from SET DEFAULT is used. Array to fill with file name of files that meet . Each element is a Character string and include the file name and extension without the path. The name is the long file name as reported by the OS and not necessarily the 8.3 uppercase name. Array to fill with file size of files that meet . Each element is a Numeric integer for the file size in Bytes. Directories are always zero in size. Array to fill with file last modification date of files that meet . Each element is of type Date. Array to fill with file last modification time of files that meet . Each element is a Character string in the format HH:mm:ss. Array to fill with attribute of files that meet . Each element is a Character string, see Directory() for information about attribute values. If you pass array to , the function is going to return files with normal, hidden, system and directory attributes. If is not specified or with type other than Array, only files with normal attribute would return. $RETURNS$ ADir() return the number of file entries that meet $DESCRIPTION$ ADir() return the number of files and/or directories that match a specified skeleton, it also fill a series of given arrays with the name, size, date, time and attribute of those files. The passed arrays should pre-initialized to the proper size, see example below. In order to include hidden, system or directories must be specified. ADir() is a compatibility function, it is superseded by Directory() which returns all the information in a multidimensional array. $EXAMPLES$ LOCAL aName, aSize, aDate, aTime, aAttr, tmp LOCAL nLen := ADir( "*.dbf" ) // Number of JPG files in this directory IF nLen > 0 aName := Array( nLen ) // make room to store the information aSize := Array( nLen ) aDate := Array( nLen ) aTime := Array( nLen ) aAttr := Array( nLen ) ADir( "*.prg", aName, aSize, aDate, aTime, aAttr ) FOR tmp := 1 TO nLen ? ; aName[ tmp ], ; aSize[ tmp ], ; aDate[ tmp ], ; aTime[ tmp ], ; aAttr[ tmp ] NEXT ELSE ? "This directory is clean from smut" ENDIF $STATUS$ R $COMPLIANCE$ is going to be filled with long file name and not necessarily the 8.3 uppercase name. $FILES$ Library is core $SEEALSO$ Array(), Directory(), SET DEFAULT $END$ */