/* * hb_DirScan() * * Copyright 2008 Przemyslaw Czerpak * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; see the file LICENSE.txt. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301 USA (or visit https://www.gnu.org/licenses/). * * As a special exception, the Harbour Project gives permission for * additional uses of the text contained in its release of Harbour. * * The exception is that, if you link the Harbour libraries with other * files to produce an executable, this does not by itself cause the * resulting executable to be covered by the GNU General Public License. * Your use of that executable is in no way restricted on account of * linking the Harbour library code into it. * * This exception does not however invalidate any other reasons why * the executable file might be covered by the GNU General Public License. * * This exception applies only to the code released by the Harbour * Project under the name Harbour. If you copy code from other * Harbour Project or Free Software Foundation releases into a copy of * Harbour, as the General Public License permits, the exception does * not apply to the code that you add in this way. To avoid misleading * anyone as to the status of such modified files, you must delete * this exception notice from them. * * If you write modifications of your own for Harbour, it is your choice * whether to permit this exception to apply to your modifications. * If you do not wish that, delete this exception notice. * */ #include "directry.ch" #include "fileio.ch" STATIC FUNCTION hb_doScan( cPath, cMask, cAttr, cPathSep ) LOCAL aFile LOCAL lMatch LOCAL aResult := {} FOR EACH aFile IN hb_vfDirectory( cPath + hb_osFileMask(), cAttr + "D" ) lMatch := hb_FileMatch( aFile[ F_NAME ], cMask ) IF "D" $ aFile[ F_ATTR ] IF lMatch .AND. "D" $ cAttr AAdd( aResult, aFile ) ENDIF IF !( aFile[ F_NAME ] == "." .OR. aFile[ F_NAME ] == ".." .OR. aFile[ F_NAME ] == "" ) AEval( hb_DoScan( cPath + aFile[ F_NAME ] + cPathSep, cMask, cAttr, cPathSep ), ; {| x | x[ F_NAME ] := aFile[ F_NAME ] + cPathSep + x[ F_NAME ], ; AAdd( aResult, x ) } ) ENDIF ELSEIF lMatch AAdd( aResult, aFile ) ENDIF NEXT RETURN aResult FUNCTION hb_DirScan( cPath, cFileMask, cAttr ) RETURN hb_DoScan( hb_DirSepAdd( hb_defaultValue( cPath, "" ) ), ; iif( HB_ISSTRING( cFileMask ), cFileMask, hb_osFileMask() ), ; hb_defaultValue( cAttr, "" ), ; hb_ps() ) FUNCTION hb_DirRemoveAll( cDir ) LOCAL aFile, cPath, cFile, nAttr IF ! Empty( cDir ) .AND. hb_vfDirExists( cDir ) cPath := hb_DirSepDel( cDir ) IF hb_vfAttrGet( cPath, @nAttr ) .AND. ! hb_bitAnd( nAttr, HB_FA_READONLY ) == 0 hb_vfAttrSet( cPath, hb_bitXor( nAttr, HB_FA_READONLY ) ) ENDIF cPath := hb_DirSepAdd( cPath ) FOR EACH aFile IN hb_vfDirectory( cPath + hb_osFileMask(), "HSDL" ) IF "D" $ aFile[ F_ATTR ] .AND. ! "L" $ aFile[ F_ATTR ] IF !( aFile[ F_NAME ] == "." .OR. aFile[ F_NAME ] == ".." .OR. aFile[ F_NAME ] == "" ) IF ! hb_DirRemoveAll( cPath + aFile[ F_NAME ] ) RETURN .F. ENDIF ENDIF ELSE cFile := cPath + aFile[ F_NAME ] IF "R" $ aFile[ F_ATTR ] .AND. hb_vfAttrGet( cFile, @nAttr ) hb_vfAttrSet( cFile, hb_bitAnd( nAttr, hb_bitNot( HB_FA_READONLY ) ) ) ENDIF IF ! hb_vfErase( cFile ) == 0 RETURN .F. ENDIF ENDIF NEXT RETURN hb_vfDirRemove( cDir ) == 0 ENDIF RETURN .T. FUNCTION hb_FileDelete( cFileMask, cAttr ) LOCAL lAny := .F., aFile, cPath, cFile, cAttrMask, nAttr IF HB_ISSTRING( cFileMask ) .AND. ! Empty( cFileMask ) .AND. ; ! hb_vfDirExists( cFileMask ) cPath := hb_FNameDir( cFileMask ) cAttrMask := StrTran( hb_defaultValue( cAttr, "" ), "D" ) + "L" FOR EACH aFile IN hb_vfDirectory( cFileMask, cAttrMask ) cFile := cPath + aFile[ F_NAME ] IF "R" $ aFile[ F_ATTR ] .AND. hb_vfAttrGet( cFile, @nAttr ) hb_vfAttrSet( cFile, hb_bitAnd( nAttr, hb_bitNot( HB_FA_READONLY ) ) ) ENDIF IF hb_vfErase( cFile ) == 0 lAny := .T. ENDIF NEXT ENDIF RETURN lAny