| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265 | {    Copyright (c) 1999-2000 by Peter Vreman    Deletes all files generated for Pascal (*.exe,units,objects,libs)    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 of the License, 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; if not, write to the Free Software    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. ****************************************************************************}program Delp;uses  dos,getopts;const  Version   = 'Version 1.1';  Title     = 'DelPascal';  Copyright = 'Copyright (c) 1999-2002 by the Free Pascal Development Team';function DStr(l:longint):string;var  TmpStr : string[32];  i : byte;begin  Str(l,tmpstr);  i:=Length(TmpStr);  while (i>3) do   begin     i:=i-3;     if TmpStr[i]<>'-' then      Insert('.',TmpStr,i+1);   end;  DStr:=TmpStr;end;Procedure EraseFile(Const HStr:String);var  f : file;begin  Assign(f,Hstr);  {$I-}   Erase(f);  {$I+}  if ioresult<>0 then;end;function MatchesMask(What, Mask: string): boolean;  function upper(const s : string) : string;  var    i  : longint;  begin     for i:=1 to length(s) do      if s[i] in ['a'..'z'] then       upper[i]:=char(byte(s[i])-32)      else       upper[i]:=s[i];     upper[0]:=s[0];  end;  Function CmpStr(const hstr1,hstr2:string):boolean;  var    found : boolean;    i1,i2 : longint;  begin    i1:=0;    i2:=0;    found:=true;    while found and (i1<length(hstr1)) and (i2<length(hstr2)) do     begin       inc(i2);       inc(i1);       case hstr1[i1] of         '?' :           found:=true;         '*' :           begin             found:=true;             if (i1=length(hstr1)) then              i2:=length(hstr2)             else              if (i1<length(hstr1)) and (hstr1[i1+1]<>hstr2[i2]) then               begin                 if i2<length(hstr2) then                  dec(i1)               end             else              if i2>1 then               dec(i2);           end;         else           found:=(hstr1[i1]=hstr2[i2]) or (hstr2[i2]='?');       end;     end;    if found then     begin       { allow 'p*' matching 'p' }       if (i1<length(hstr1)) and (hstr1[i1+1]='*') then        inc(i1);       found:=(i1>=length(hstr1)) and (i2>=length(hstr2));     end;    CmpStr:=found;  end;var  D1,D2 : DirStr;  N1,N2 : NameStr;  E1,E2 : Extstr;begin{$ifdef Unix}  FSplit(What,D1,N1,E1);  FSplit(Mask,D2,N2,E2);{$else}  FSplit(Upper(What),D1,N1,E1);  FSplit(Upper(Mask),D2,N2,E2);{$endif}  MatchesMask:=CmpStr(N2,N1) and CmpStr(E2,E1);end;type  PMaskItem=^TMaskItem;  TMaskItem=record    Mask  : string[15];    Files : longint;    Size  : longint;    Next  : PMaskItem;  end;var  masklist : pmaskitem;procedure AddMask(s:string);var  maskitem : PMaskItem;  i : longint;begin  repeat    i:=pos(' ',s);    if i=0 then     i:=length(s)+1;    New(maskitem);    fillchar(maskitem^,sizeof(tmaskitem),0);    maskitem^.mask:=Copy(s,1,i-1);    maskitem^.next:=masklist;    masklist:=maskitem;    Delete(s,1,i);  until s='';end;Var quiet: boolean;procedure usage;begin  Writeln('Delp [options] <directory>');  Writeln('Where options is one of:');  writeln('  -e    Delete executables also (Not on Unix)');  writeln('  -h    Display (this) help message.');  writeln('  -q    Quietly perfoms deleting.');  Halt(1);end;procedure processoptions;Var c : char;begin  quiet:=false;  Repeat    C:=Getopt('ehq');    Case C of      'e' : AddMAsk('*.exe *.so *.dll');      'h' : Usage;      'q' : Quiet:=True;      EndOfOptions : ;    end;  Until C=EndOfOptions;end;var  Dir    : Searchrec;  Total  : longint;  hp     : pmaskitem;  found  : boolean;  basedir : string;begin  ProcessOptions;  if Optind<>ParamCount then    Usage;  BaseDir:=Paramstr(OptInd);  If BaseDir[Length(BaseDir)]<>DirectorySeparator then    BaseDir:=BaseDir+DirectorySeparator;  { Win32 target }  AddMask('*.ppw *.ow *.aw *.sw');  AddMask('ppas.bat ppas.sh link.res fpcmaked fpcmade fpcmade.*');  AddMask('*.tpu *.tpp *.tpw *.tr');  AddMask('*.dcu *.dcp *.bpl');  AddMask('*.log *.bak *.~pas *.~pp');  AddMask('*.ppu *.o *.a *.s');  AddMask('*.pp1 *.o1 *.a1 *.s1');  AddMask('*.ppo *.oo *.ao *.so');  AddMask('*.rst');  { OS/2 target }  AddMask('*.oo2 *.so2 *.ppo');  { Amiga target }  AddMask('*.ppa *.asm');  if not quiet then    begin      writeln(Title+' '+Version);      writeln(Copyright);      Writeln;    end;  FindFirst(basedir+'*.*',anyfile,Dir);  Total:=0;  while (doserror=0) do   begin     hp:=masklist;     while assigned(hp) do      begin        if MatchesMask(Dir.Name,hp^.mask) then         begin           EraseFile(BaseDir+Dir.Name);           inc(hp^.Files);           inc(hp^.Size,Dir.Size);           break;         end;        hp:=hp^.next;      end;     FindNext(Dir);   end;{Write Results}  found:=false;  hp:=masklist;  while assigned(hp) do   begin     if hp^.Files>0 then      begin        if not quiet then          WriteLn(' - Removed ',hp^.Files:2,' ',hp^.Mask,' (',DStr(hp^.Size)+' Bytes)');        inc(Total,hp^.Size);        found:=true;      end;     hp:=hp^.next;   end;  if not quiet then    if not found then      WriteLn(' - No Redundant Files Found!')    else      WriteLn(' - Total ',DStr(Total),' Bytes Freed');end.
 |