LPARAMETERS CHNGREF laFiles,INP loEngine
EXTERNAL ARRAY laFiles
LOCAL liEnd,lcData,lii,liAT,liy,liz,lcPom,lnFileSize
DIMENSION laFiles(100,7)
liEnd=AT(CRLF,loEngine.cData,1)
lii=0
DO WHILE liEnd>0
lcData=LEFT(loEngine.cData,liEnd-1)
loEngine.cData=SUBSTR(loEngine.cData,liEnd+2)
liEnd=AT(CRLF,loEngine.cData,1)
lii=lii+1
IF lii>ALEN(laFiles,1)
DIMENSION laFiles(lii+100,7)
ENDIF
* Row processing
laFiles(lii,1)=SUBSTR(lcData,1,10)
laFiles(lii,2)=VAL(SUBSTR(lcData,12,3))
* Check where is: "Mon Da HH:MM" or "Mon Da YYYY"
liAT=This.FindDT(@lcData)
IF liAT=0 && Fail at parsing file
This.oFTP.SetExtendedError(_FTPS_UE_PLF,lcRow)
RETURN .F.
ENDIF
* Date last modify
laFiles(lii,6)=This.FormatDT(SUBSTR(lcData,liAT,12))
* File name
laFiles(lii,7)=SUBSTR(lcData,liAT+13)
* from 16. char to liAT-2 are three columns
lcPom=ALLTRIM(SUBSTR(lcData,16,liAT-16-1))
liy=AT(" ",lcPom)
liz=RAT(" ",lcPom)
laFiles(lii,3)=ALLTRIM(LEFT(lcPom,liy-1)) && Owner
laFiles(lii,4)=ALLTRIM(SUBSTR(lcPom,liy+1,liz-1-liy)) && Group
* laFiles(lii,5)=VAL(SUBSTR(lcPom,liz+1)) && Size
IF This.oFTP.GetFileSize(laFiles(lii,7),@lnFileSize)
laFiles(lii,5)=lnFileSize
ENDIF
ENDDO
IF lii>0 AND lii<>ALEN(laFiles,1)
DIMENSION laFiles(lii,7)
ENDIF
RETURN .T.