home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
World of Shareware - Software Farm 2
/
wosw_2.zip
/
wosw_2
/
QBAS
/
WNDTOOL5.ZIP
/
TAGDIR.SUB
< prev
next >
Wrap
Text File
|
1989-04-26
|
5KB
|
112 lines
'
'$PAGE
'
'******************************************************************************
' Function : *
' *
' Purpose: *
' *
' *
' Results: *
' *
' Usage : *
' *
' *
' Date Written : 01/01/89 - Date Tested: 01/01/89 - Author: James P Morgan *
' Date Modified: - : - : *
'-----------------------------------------------------------------------------*
' NOTE: *
'******************************************************************************
' *
' SUB PROGRAM NAME (PARAMETERS) STATIC/RECURSIVE *
'-----------------------------------------------------------------------------*
' *
'============================================================================
'
SUB TAGDIR(SEARCH$,SHOWITEMS%,FORE%,BACK%,HFORE%,HBACK%,QUADRANT$,SHADOW%,NUMTAGGED%,TAG$(1)) STATIC
DEFINT A-Z 'make all short intergers by default
TAG.MIN=LBOUND(TAG$) 'adjust for callers OPTION BASE
TAG.MAX=UBOUND(TAG$) 'user reserved spaces for this many tagged filenames
REM $DYNAMIC 'allocate arrays off far heap
DIM FILES$(1),TAGITEMS%(1) 'make each one ONLY 1 element to start with
REM $STATIC 'default arrays back to Basics Data segment
TAGDIR.START:
ATTR=0
COUNT=&HFF00 OR ATTR 'Get number of filenames that match SEARCH$
I=INT(VARPTR(FILES$(0)))
CALL DIR(SEARCH$,I,COUNT)
IF (COUNT=-1) OR (COUNT = 0) THEN 'were any matching filenames found?
NUMFILES%=0 'NO
SELECTFILE$="No Files Found"
GOTO TAGDIR.DONE
END IF
IF COUNT <> 0 THEN 're-alloacte filename array big
REDIM FILES$(COUNT),TAGITEMS%(COUNT) 'enough to hold all found
END IF
HEADER$=SEARCH$ 'this was the search filename spec
TEMPHDR$=SPACE$(16)
PAD=8-(LEN(HEADER$)/2)-.5
MID$(TEMPHDR$,PAD+1,LEN(HEADER$))=HEADER$
HEADER$=TEMPHDR$
FOR I=0 TO COUNT-1 'make each filename array element
FILES$(I)=SPACE$(LEN(HEADER$)-2) 'big enough to hold a filename
NEXT
COUNT=ATTR
I=INT(VARPTR(FILES$(0)))
CALL DIR(SEARCH$,I,COUNT) 'load the filenames into the array
FOR J=0 TO COUNT 'allow for room in front of filename
FILES$(J)=" "+FILES$(J) 'to 'tag' it
NEXT
MAXITEMS%=COUNT 'we have this many filenames to display
SHOWFILES=SHOWITEMS% 'but only display this many at a time
NUMTAGGED%=TAG.MAX 'allow only this many to be tagged (all we have room for)
CALL TAGLIST(HEADER$,SHOWITEMS%,MAXITEMS%,NUMTAGGED%,FILES$(),TAGITEMS%(),FORE%,BACK%,HFORE%,HBACK%,QUADRANT$,SHADOW%)
I=0 'number we actually found tagged
I.BASE=0
IF NUMTAGGED%<1 THEN 'did user 'tag' any filenames
GOTO TAGDIR.DONE 'NO
ENDIF
'
' Return the filenames tagged.
'
FOR J=0 TO COUNT-1 'look at all the filenames
IF TAGITEMS%(J)=1 THEN 'was this one tagged?
TAG$((I-I.BASE)+TAG.MIN)=MID$(FILES$(J),3)
I=I+1 'keep count of the number we found tagged
END IF
NEXT
' NUMTAGGED%=I
'
TAGDIR.DONE:
ERASE FILES$ 'free memory allocated to arrays
ERASE TAGITEMS%
EXIT SUB 'return to caller
END SUB